xref: /aosp_15_r20/frameworks/native/libs/binder/tests/IBinderRpcTest.aidl (revision 38e8c45f13ce32b0dcecb25141ffecaf386fa17f)
1*38e8c45fSAndroid Build Coastguard Worker /*
2*38e8c45fSAndroid Build Coastguard Worker  * Copyright (C) 2020 The Android Open Source Project
3*38e8c45fSAndroid Build Coastguard Worker  *
4*38e8c45fSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*38e8c45fSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*38e8c45fSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*38e8c45fSAndroid Build Coastguard Worker  *
8*38e8c45fSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*38e8c45fSAndroid Build Coastguard Worker  *
10*38e8c45fSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*38e8c45fSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*38e8c45fSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*38e8c45fSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*38e8c45fSAndroid Build Coastguard Worker  * limitations under the License.
15*38e8c45fSAndroid Build Coastguard Worker  */
16*38e8c45fSAndroid Build Coastguard Worker 
17*38e8c45fSAndroid Build Coastguard Worker interface IBinderRpcTest {
sendString(@tf8InCpp String str)18*38e8c45fSAndroid Build Coastguard Worker     oneway void sendString(@utf8InCpp String str);
doubleString(@tf8InCpp String str)19*38e8c45fSAndroid Build Coastguard Worker     @utf8InCpp String doubleString(@utf8InCpp String str);
20*38e8c45fSAndroid Build Coastguard Worker 
21*38e8c45fSAndroid Build Coastguard Worker     // get the port that a client used to connect to this object
getClientPort()22*38e8c45fSAndroid Build Coastguard Worker     int getClientPort();
23*38e8c45fSAndroid Build Coastguard Worker 
24*38e8c45fSAndroid Build Coastguard Worker     // number of known RPC binders to process, RpcState::countBinders by session
countBinders()25*38e8c45fSAndroid Build Coastguard Worker     int[] countBinders();
26*38e8c45fSAndroid Build Coastguard Worker 
27*38e8c45fSAndroid Build Coastguard Worker     // Return a null binder with a non-nullable return type.
getNullBinder()28*38e8c45fSAndroid Build Coastguard Worker     IBinder getNullBinder();
29*38e8c45fSAndroid Build Coastguard Worker 
30*38e8c45fSAndroid Build Coastguard Worker     // Caller sends server, callee pings caller's server and returns error code.
pingMe(IBinder binder)31*38e8c45fSAndroid Build Coastguard Worker     int pingMe(IBinder binder);
repeatBinder(@ullable IBinder binder)32*38e8c45fSAndroid Build Coastguard Worker     @nullable IBinder repeatBinder(@nullable IBinder binder);
33*38e8c45fSAndroid Build Coastguard Worker 
holdBinder(@ullable IBinder binder)34*38e8c45fSAndroid Build Coastguard Worker     void holdBinder(@nullable IBinder binder);
getHeldBinder()35*38e8c45fSAndroid Build Coastguard Worker     @nullable IBinder getHeldBinder();
36*38e8c45fSAndroid Build Coastguard Worker 
37*38e8c45fSAndroid Build Coastguard Worker     // Idea is client creates its own instance of IBinderRpcTest and calls this,
38*38e8c45fSAndroid Build Coastguard Worker     // and the server calls 'binder' with (calls - 1) passing itself as 'binder',
39*38e8c45fSAndroid Build Coastguard Worker     // going back and forth until calls = 0
nestMe(IBinderRpcTest binder, int calls)40*38e8c45fSAndroid Build Coastguard Worker     void nestMe(IBinderRpcTest binder, int calls);
41*38e8c45fSAndroid Build Coastguard Worker 
42*38e8c45fSAndroid Build Coastguard Worker     // should always return the same binder
alwaysGiveMeTheSameBinder()43*38e8c45fSAndroid Build Coastguard Worker     IBinder alwaysGiveMeTheSameBinder();
44*38e8c45fSAndroid Build Coastguard Worker 
45*38e8c45fSAndroid Build Coastguard Worker     // Idea is that the server will not hold onto the session, the remote session
46*38e8c45fSAndroid Build Coastguard Worker     // object must. This is to test lifetimes of binder objects, and consequently, also
47*38e8c45fSAndroid Build Coastguard Worker     // identity (since by assigning sessions names, we can make sure a section always
48*38e8c45fSAndroid Build Coastguard Worker     // references the session it was originally opened with).
openSession(@tf8InCpp String name)49*38e8c45fSAndroid Build Coastguard Worker     IBinderRpcSession openSession(@utf8InCpp String name);
50*38e8c45fSAndroid Build Coastguard Worker 
51*38e8c45fSAndroid Build Coastguard Worker     // Decremented in ~IBinderRpcSession
getNumOpenSessions()52*38e8c45fSAndroid Build Coastguard Worker     int getNumOpenSessions();
53*38e8c45fSAndroid Build Coastguard Worker 
54*38e8c45fSAndroid Build Coastguard Worker     // primitives to test threading behavior
lock()55*38e8c45fSAndroid Build Coastguard Worker     void lock();
unlockInMsAsync(int ms)56*38e8c45fSAndroid Build Coastguard Worker     oneway void unlockInMsAsync(int ms);
lockUnlock()57*38e8c45fSAndroid Build Coastguard Worker     void lockUnlock(); // locks and unlocks a mutex
58*38e8c45fSAndroid Build Coastguard Worker 
59*38e8c45fSAndroid Build Coastguard Worker     // take up binder thread for some time
sleepMs(int ms)60*38e8c45fSAndroid Build Coastguard Worker     void sleepMs(int ms);
sleepMsAsync(int ms)61*38e8c45fSAndroid Build Coastguard Worker     oneway void sleepMsAsync(int ms);
62*38e8c45fSAndroid Build Coastguard Worker 
doCallback(IBinderRpcCallback callback, boolean isOneway, boolean delayed, @utf8InCpp String value)63*38e8c45fSAndroid Build Coastguard Worker     void doCallback(IBinderRpcCallback callback, boolean isOneway, boolean delayed, @utf8InCpp String value);
doCallbackAsync(IBinderRpcCallback callback, boolean isOneway, boolean delayed, @utf8InCpp String value)64*38e8c45fSAndroid Build Coastguard Worker     oneway void doCallbackAsync(IBinderRpcCallback callback, boolean isOneway, boolean delayed, @utf8InCpp String value);
65*38e8c45fSAndroid Build Coastguard Worker 
die(boolean cleanup)66*38e8c45fSAndroid Build Coastguard Worker     void die(boolean cleanup);
scheduleShutdown()67*38e8c45fSAndroid Build Coastguard Worker     void scheduleShutdown();
68*38e8c45fSAndroid Build Coastguard Worker 
useKernelBinderCallingId()69*38e8c45fSAndroid Build Coastguard Worker     void useKernelBinderCallingId();
70*38e8c45fSAndroid Build Coastguard Worker 
echoAsFile(@tf8InCpp String content)71*38e8c45fSAndroid Build Coastguard Worker     ParcelFileDescriptor echoAsFile(@utf8InCpp String content);
72*38e8c45fSAndroid Build Coastguard Worker 
concatFiles(in List<ParcelFileDescriptor> files)73*38e8c45fSAndroid Build Coastguard Worker     ParcelFileDescriptor concatFiles(in List<ParcelFileDescriptor> files);
74*38e8c45fSAndroid Build Coastguard Worker 
75*38e8c45fSAndroid Build Coastguard Worker     // FDs sent via `blockingSendFdOneway` can be received via
76*38e8c45fSAndroid Build Coastguard Worker     // `blockingRecvFd`. The handler for `blockingSendFdOneway` will block
77*38e8c45fSAndroid Build Coastguard Worker     // until the next `blockingRecvFd` call.
78*38e8c45fSAndroid Build Coastguard Worker     //
79*38e8c45fSAndroid Build Coastguard Worker     // This is useful for carefully controlling how/when oneway transactions
80*38e8c45fSAndroid Build Coastguard Worker     // get queued.
blockingSendFdOneway(in ParcelFileDescriptor fd)81*38e8c45fSAndroid Build Coastguard Worker     oneway void blockingSendFdOneway(in ParcelFileDescriptor fd);
blockingRecvFd()82*38e8c45fSAndroid Build Coastguard Worker     ParcelFileDescriptor blockingRecvFd();
83*38e8c45fSAndroid Build Coastguard Worker 
84*38e8c45fSAndroid Build Coastguard Worker     // Same as blockingSendFdOneway, but with integers.
blockingSendIntOneway(int n)85*38e8c45fSAndroid Build Coastguard Worker     oneway void blockingSendIntOneway(int n);
blockingRecvInt()86*38e8c45fSAndroid Build Coastguard Worker     int blockingRecvInt();
87*38e8c45fSAndroid Build Coastguard Worker }
88