| Glenn Kasten | fdf4e4f | 2013-01-18 15:31:41 -0800 | [diff] [blame] | 1 | /* | 
|  | 2 | ** | 
|  | 3 | ** Copyright 2007, The Android Open Source Project | 
|  | 4 | ** | 
|  | 5 | ** Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | 6 | ** you may not use this file except in compliance with the License. | 
|  | 7 | ** You may obtain a copy of the License at | 
|  | 8 | ** | 
|  | 9 | **     http://www.apache.org/licenses/LICENSE-2.0 | 
|  | 10 | ** | 
|  | 11 | ** Unless required by applicable law or agreed to in writing, software | 
|  | 12 | ** distributed under the License is distributed on an "AS IS" BASIS, | 
|  | 13 | ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | 14 | ** See the License for the specific language governing permissions and | 
|  | 15 | ** limitations under the License. | 
|  | 16 | */ | 
|  | 17 |  | 
|  | 18 | #define LOG_TAG "IMediaLogService" | 
|  | 19 | //#define LOG_NDEBUG 0 | 
|  | 20 |  | 
|  | 21 | #include <utils/Log.h> | 
|  | 22 | #include <stdint.h> | 
|  | 23 | #include <sys/types.h> | 
|  | 24 | #include <binder/Parcel.h> | 
|  | 25 | #include <media/IMediaLogService.h> | 
|  | 26 |  | 
|  | 27 | namespace android { | 
|  | 28 |  | 
|  | 29 | enum { | 
|  | 30 | REGISTER_WRITER = IBinder::FIRST_CALL_TRANSACTION, | 
|  | 31 | UNREGISTER_WRITER, | 
|  | 32 | }; | 
|  | 33 |  | 
|  | 34 | class BpMediaLogService : public BpInterface<IMediaLogService> | 
|  | 35 | { | 
|  | 36 | public: | 
| Chih-Hung Hsieh | 090ef60 | 2016-04-27 10:39:54 -0700 | [diff] [blame] | 37 | explicit BpMediaLogService(const sp<IBinder>& impl) | 
| Glenn Kasten | fdf4e4f | 2013-01-18 15:31:41 -0800 | [diff] [blame] | 38 | : BpInterface<IMediaLogService>(impl) | 
|  | 39 | { | 
|  | 40 | } | 
|  | 41 |  | 
|  | 42 | virtual void    registerWriter(const sp<IMemory>& shared, size_t size, const char *name) { | 
|  | 43 | Parcel data, reply; | 
|  | 44 | data.writeInterfaceToken(IMediaLogService::getInterfaceDescriptor()); | 
| Marco Nelissen | 06b4606 | 2014-11-14 07:58:25 -0800 | [diff] [blame] | 45 | data.writeStrongBinder(IInterface::asBinder(shared)); | 
| Glenn Kasten | e03dd22 | 2014-01-28 11:04:39 -0800 | [diff] [blame] | 46 | data.writeInt64((int64_t) size); | 
| Glenn Kasten | fdf4e4f | 2013-01-18 15:31:41 -0800 | [diff] [blame] | 47 | data.writeCString(name); | 
| Lajos Molnar | f1063e2 | 2015-04-17 15:19:42 -0700 | [diff] [blame] | 48 | status_t status __unused = remote()->transact(REGISTER_WRITER, data, &reply); | 
| Glenn Kasten | fdf4e4f | 2013-01-18 15:31:41 -0800 | [diff] [blame] | 49 | // FIXME ignores status | 
|  | 50 | } | 
|  | 51 |  | 
|  | 52 | virtual void    unregisterWriter(const sp<IMemory>& shared) { | 
|  | 53 | Parcel data, reply; | 
|  | 54 | data.writeInterfaceToken(IMediaLogService::getInterfaceDescriptor()); | 
| Marco Nelissen | 06b4606 | 2014-11-14 07:58:25 -0800 | [diff] [blame] | 55 | data.writeStrongBinder(IInterface::asBinder(shared)); | 
| Lajos Molnar | f1063e2 | 2015-04-17 15:19:42 -0700 | [diff] [blame] | 56 | status_t status __unused = remote()->transact(UNREGISTER_WRITER, data, &reply); | 
| Glenn Kasten | fdf4e4f | 2013-01-18 15:31:41 -0800 | [diff] [blame] | 57 | // FIXME ignores status | 
|  | 58 | } | 
|  | 59 |  | 
|  | 60 | }; | 
|  | 61 |  | 
|  | 62 | IMPLEMENT_META_INTERFACE(MediaLogService, "android.media.IMediaLogService"); | 
|  | 63 |  | 
|  | 64 | // ---------------------------------------------------------------------- | 
|  | 65 |  | 
|  | 66 | status_t BnMediaLogService::onTransact( | 
|  | 67 | uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags) | 
|  | 68 | { | 
|  | 69 | switch (code) { | 
|  | 70 |  | 
|  | 71 | case REGISTER_WRITER: { | 
|  | 72 | CHECK_INTERFACE(IMediaLogService, data, reply); | 
|  | 73 | sp<IMemory> shared = interface_cast<IMemory>(data.readStrongBinder()); | 
| Glenn Kasten | e03dd22 | 2014-01-28 11:04:39 -0800 | [diff] [blame] | 74 | size_t size = (size_t) data.readInt64(); | 
| Glenn Kasten | fdf4e4f | 2013-01-18 15:31:41 -0800 | [diff] [blame] | 75 | const char *name = data.readCString(); | 
|  | 76 | registerWriter(shared, size, name); | 
|  | 77 | return NO_ERROR; | 
|  | 78 | } | 
|  | 79 |  | 
|  | 80 | case UNREGISTER_WRITER: { | 
|  | 81 | CHECK_INTERFACE(IMediaLogService, data, reply); | 
|  | 82 | sp<IMemory> shared = interface_cast<IMemory>(data.readStrongBinder()); | 
|  | 83 | unregisterWriter(shared); | 
|  | 84 | return NO_ERROR; | 
|  | 85 | } | 
|  | 86 |  | 
|  | 87 | default: | 
|  | 88 | return BBinder::onTransact(code, data, reply, flags); | 
|  | 89 | } | 
|  | 90 | } | 
|  | 91 |  | 
|  | 92 | // ---------------------------------------------------------------------------- | 
|  | 93 |  | 
| Glenn Kasten | 40bc906 | 2015-03-20 09:09:33 -0700 | [diff] [blame] | 94 | } // namespace android |