diff options
| author | Nathan Harold <nharold@google.com> | 2021-01-29 16:10:29 -0800 | 
|---|---|---|
| committer | Nathan Harold <nharold@google.com> | 2021-03-25 15:46:15 -0700 | 
| commit | 8c23380d2f3707346a853bbbeeb639355b7717fa (patch) | |
| tree | 15079e7acbcb8899c8d3de1eba6b488928704bad /libs/rs/rsg_ScriptJavaClass.cpp | |
| parent | 01a61615d84cc4c80f78f9bc78308c9a39b9f656 (diff) | |
Ensure Async APIs receive callbacks
There are currently a couple silent failure for
APIs that are defined as asynchronous.
-If the remote binder object is null then in some cases
 the response is dropped. It's important that the response
 be triggered on a thread other than the calling one due
 to the oddball possibility of non-reentrant locking.
-If the remote dies while awaiting a response, the RemoteException
 is generally dropped, and because the API is asynchronous there is
 no way for the caller to know, leaving a dangling async request.
This CL ensures that remote exceptions due to process death invoke
the asynchronous callbacks, delivering an error message using the
BackgroundThread to ensure that the calls are received on a thread
other than the original caller's.
Bug: 182185642
Test: atest CtsTelephonyTestCases
Change-Id: I5121734194f07c53f94fb6585da3c90e3e2c4bf7
Diffstat (limited to 'libs/rs/rsg_ScriptJavaClass.cpp')
0 files changed, 0 insertions, 0 deletions
