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