Commit Graph

3 Commits

Author SHA1 Message Date
Alan Stokes 88805d55c5 Native API fixes
Port is always 32 bits, move it to uint32_t.

Add _Nullable / _Nonnull annotations in the headers. That initially
triggered a warning because we deliberately pass null to the
getDiceAttestation* functions to get the size needed. Which led me to
notice that our Rust code technically had undefined behavior, because
a null pointer is never valid even for size 0. Added a guard for that,
and documented that null is only allowed for size 0.

Bug: 262415211
Test: atest MicrodroidTests
Change-Id: I44bb2946989f7254e581d885542b41399c3ee059
2022-12-16 16:53:45 +00:00
Alan Stokes 65bbb91d48 Panic on non-actionable failures
This is based on Michael's comments on aosp/2280849. For methods which
should never fail unless the VM is already dying, and for which
clients cannot take any meaningful action, panic instead of returning
false. Make sure we log the cause first.

Update client code to match. Update doc comments in the header file.

Also clarify that calling notify read more than once is harmless
(otherwise it would panic).

Incidentally, rename vs_payload_service.rs because it was confusing me
(we have a file of the same name in microdroid manager which actually
implements the service.)

Changes to AVmPayload_runVsockRpcServer will come later.

Bug: 243512108
Test: atest MicrodroidTests
Test: composd_cmd --test-compile
Change-Id: Ie6f6203ba54246cac669f4a68e8ab76f0a5792ae
2022-11-23 15:36:11 +00:00
Alan Stokes 06cba6fd5f Move vm_payload to the top level
Makes it more visible, and easier to expose to potential clients.

Bug: 243512108
Test: atest MicrodroidTests
Change-Id: I79c4724fac0df6c29761d4b4c2eb85362f588fe5
2022-11-23 09:44:17 +00:00