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