diff options
author | Mathias Agopian <mathias@google.com> | 2009-05-22 19:00:22 -0700 |
---|---|---|
committer | Mathias Agopian <mathias@google.com> | 2009-05-26 16:12:20 -0700 |
commit | aaf834a284a025cedd8ec1cf01d09e1790c1dcf8 (patch) | |
tree | 6314488c2ccaa1ab96923a1c771593ee65e7a726 /libs/binder/IServiceManager.cpp | |
parent | 7f36a5729f17fcb37a7b65a13fd86b0d922caca9 (diff) | |
download | frameworks_base-aaf834a284a025cedd8ec1cf01d09e1790c1dcf8.zip frameworks_base-aaf834a284a025cedd8ec1cf01d09e1790c1dcf8.tar.gz frameworks_base-aaf834a284a025cedd8ec1cf01d09e1790c1dcf8.tar.bz2 |
some work to try to reduce the code size of some native libraries
- make sure that all binder Bn classes define a ctor and dtor in their respective library.
This avoids duplication of the ctor/dtor in libraries where these objects are instantiated.
This is also cleaner, should we want these ctor/dtor to do something one day.
- same change as above for some Bp classes and various other non-binder classes
- moved the definition of CHECK_INTERFACE() in IInterface.h instead of having it everywhere.
- improved the CHECK_INTERFACE() macro so it calls a single method in Parcel, instead of inlining its code everywhere
- IBinder::getInterfaceDescriptor() now returns a "const String16&" instead of String16, which saves calls to String16 and ~String16
- implemented a cache for BpBinder::getInterfaceDescriptor(), since this does an IPC. HOWEVER, this method never seems to be called.
The cache makes BpBinder bigger, so we need to figure out if we need this method at all.
Diffstat (limited to 'libs/binder/IServiceManager.cpp')
-rw-r--r-- | libs/binder/IServiceManager.cpp | 6 |
1 files changed, 0 insertions, 6 deletions
diff --git a/libs/binder/IServiceManager.cpp b/libs/binder/IServiceManager.cpp index 2f265b8..88774e7 100644 --- a/libs/binder/IServiceManager.cpp +++ b/libs/binder/IServiceManager.cpp @@ -178,12 +178,6 @@ IMPLEMENT_META_INTERFACE(ServiceManager, "android.os.IServiceManager"); // ---------------------------------------------------------------------- -#define CHECK_INTERFACE(interface, data, reply) \ - do { if (!data.enforceInterface(interface::getInterfaceDescriptor())) { \ - LOGW("Call incorrectly routed to " #interface); \ - return PERMISSION_DENIED; \ - } } while (0) - status_t BnServiceManager::onTransact( uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags) { |