blob: f5998798362482ad2da8fc1ae9651686ca6d5e71 [file] [log] [blame]
Igor Murashkine7ee7632013-06-11 18:10:18 -07001/*
2**
3** Copyright 2013, 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_NDEBUG 0
19#define LOG_TAG "ICameraDeviceCallbacks"
20#include <utils/Log.h>
21#include <stdint.h>
22#include <sys/types.h>
23
24#include <binder/Parcel.h>
25#include <gui/IGraphicBufferProducer.h>
26#include <gui/Surface.h>
27#include <utils/Mutex.h>
28
Eino-Ville Talvala7b82efe2013-07-25 17:12:35 -070029#include <camera/camera2/ICameraDeviceCallbacks.h>
Igor Murashkine7ee7632013-06-11 18:10:18 -070030#include "camera/CameraMetadata.h"
Jianing Weicb0652e2014-03-12 18:29:36 -070031#include "camera/CaptureResult.h"
Igor Murashkine7ee7632013-06-11 18:10:18 -070032
33namespace android {
34
35enum {
Eino-Ville Talvalaf1e98d82013-09-06 09:32:43 -070036 CAMERA_ERROR = IBinder::FIRST_CALL_TRANSACTION,
37 CAMERA_IDLE,
38 CAPTURE_STARTED,
Igor Murashkine7ee7632013-06-11 18:10:18 -070039 RESULT_RECEIVED,
Eino-Ville Talvala4d44cad2015-04-11 13:15:45 -070040 PREPARED
Igor Murashkine7ee7632013-06-11 18:10:18 -070041};
42
43class BpCameraDeviceCallbacks: public BpInterface<ICameraDeviceCallbacks>
44{
45public:
46 BpCameraDeviceCallbacks(const sp<IBinder>& impl)
47 : BpInterface<ICameraDeviceCallbacks>(impl)
48 {
49 }
50
Jianing Weicb0652e2014-03-12 18:29:36 -070051 void onDeviceError(CameraErrorCode errorCode, const CaptureResultExtras& resultExtras)
Igor Murashkine7ee7632013-06-11 18:10:18 -070052 {
Eino-Ville Talvalaf1e98d82013-09-06 09:32:43 -070053 ALOGV("onDeviceError");
Igor Murashkine7ee7632013-06-11 18:10:18 -070054 Parcel data, reply;
55 data.writeInterfaceToken(ICameraDeviceCallbacks::getInterfaceDescriptor());
Eino-Ville Talvalaf1e98d82013-09-06 09:32:43 -070056 data.writeInt32(static_cast<int32_t>(errorCode));
Jianing Weicb0652e2014-03-12 18:29:36 -070057 data.writeInt32(1); // to mark presence of CaptureResultExtras object
58 resultExtras.writeToParcel(&data);
Eino-Ville Talvalaf1e98d82013-09-06 09:32:43 -070059 remote()->transact(CAMERA_ERROR, data, &reply, IBinder::FLAG_ONEWAY);
Igor Murashkine7ee7632013-06-11 18:10:18 -070060 data.writeNoException();
61 }
62
Eino-Ville Talvalaf1e98d82013-09-06 09:32:43 -070063 void onDeviceIdle()
64 {
65 ALOGV("onDeviceIdle");
66 Parcel data, reply;
67 data.writeInterfaceToken(ICameraDeviceCallbacks::getInterfaceDescriptor());
68 remote()->transact(CAMERA_IDLE, data, &reply, IBinder::FLAG_ONEWAY);
69 data.writeNoException();
70 }
71
Jianing Weicb0652e2014-03-12 18:29:36 -070072 void onCaptureStarted(const CaptureResultExtras& result, int64_t timestamp)
Eino-Ville Talvalaf1e98d82013-09-06 09:32:43 -070073 {
74 ALOGV("onCaptureStarted");
75 Parcel data, reply;
76 data.writeInterfaceToken(ICameraDeviceCallbacks::getInterfaceDescriptor());
Jianing Weicb0652e2014-03-12 18:29:36 -070077 data.writeInt32(1); // to mark presence of CaptureResultExtras object
78 result.writeToParcel(&data);
Eino-Ville Talvalaf1e98d82013-09-06 09:32:43 -070079 data.writeInt64(timestamp);
80 remote()->transact(CAPTURE_STARTED, data, &reply, IBinder::FLAG_ONEWAY);
81 data.writeNoException();
82 }
83
Jianing Weicb0652e2014-03-12 18:29:36 -070084 void onResultReceived(const CameraMetadata& metadata,
85 const CaptureResultExtras& resultExtras) {
Igor Murashkine7ee7632013-06-11 18:10:18 -070086 ALOGV("onResultReceived");
87 Parcel data, reply;
88 data.writeInterfaceToken(ICameraDeviceCallbacks::getInterfaceDescriptor());
Zhijun He11d0d442013-07-31 09:50:58 -070089 data.writeInt32(1); // to mark presence of metadata object
Jianing Weicb0652e2014-03-12 18:29:36 -070090 metadata.writeToParcel(&data);
91 data.writeInt32(1); // to mark presence of CaptureResult object
92 resultExtras.writeToParcel(&data);
Igor Murashkine7ee7632013-06-11 18:10:18 -070093 remote()->transact(RESULT_RECEIVED, data, &reply, IBinder::FLAG_ONEWAY);
94 data.writeNoException();
95 }
Eino-Ville Talvala4d44cad2015-04-11 13:15:45 -070096
97 void onPrepared(int streamId)
98 {
99 ALOGV("onPrepared");
100 Parcel data, reply;
101 data.writeInterfaceToken(ICameraDeviceCallbacks::getInterfaceDescriptor());
102 data.writeInt32(streamId);
103 remote()->transact(PREPARED, data, &reply, IBinder::FLAG_ONEWAY);
104 data.writeNoException();
105 }
106
Igor Murashkine7ee7632013-06-11 18:10:18 -0700107};
108
109IMPLEMENT_META_INTERFACE(CameraDeviceCallbacks,
Eino-Ville Talvala7b82efe2013-07-25 17:12:35 -0700110 "android.hardware.camera2.ICameraDeviceCallbacks");
Igor Murashkine7ee7632013-06-11 18:10:18 -0700111
112// ----------------------------------------------------------------------
113
114status_t BnCameraDeviceCallbacks::onTransact(
115 uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags)
116{
117 ALOGV("onTransact - code = %d", code);
118 switch(code) {
Eino-Ville Talvalaf1e98d82013-09-06 09:32:43 -0700119 case CAMERA_ERROR: {
120 ALOGV("onDeviceError");
Igor Murashkine7ee7632013-06-11 18:10:18 -0700121 CHECK_INTERFACE(ICameraDeviceCallbacks, data, reply);
Eino-Ville Talvalaf1e98d82013-09-06 09:32:43 -0700122 CameraErrorCode errorCode =
123 static_cast<CameraErrorCode>(data.readInt32());
Jianing Weicb0652e2014-03-12 18:29:36 -0700124 CaptureResultExtras resultExtras;
125 if (data.readInt32() != 0) {
126 resultExtras.readFromParcel(const_cast<Parcel*>(&data));
127 } else {
128 ALOGE("No CaptureResultExtras object is present!");
129 }
130 onDeviceError(errorCode, resultExtras);
Eino-Ville Talvalaf1e98d82013-09-06 09:32:43 -0700131 data.readExceptionCode();
132 return NO_ERROR;
133 } break;
134 case CAMERA_IDLE: {
135 ALOGV("onDeviceIdle");
136 CHECK_INTERFACE(ICameraDeviceCallbacks, data, reply);
137 onDeviceIdle();
138 data.readExceptionCode();
139 return NO_ERROR;
140 } break;
141 case CAPTURE_STARTED: {
142 ALOGV("onCaptureStarted");
143 CHECK_INTERFACE(ICameraDeviceCallbacks, data, reply);
Jianing Weicb0652e2014-03-12 18:29:36 -0700144 CaptureResultExtras result;
145 if (data.readInt32() != 0) {
146 result.readFromParcel(const_cast<Parcel*>(&data));
147 } else {
148 ALOGE("No CaptureResultExtras object is present in result!");
149 }
Eino-Ville Talvalaf1e98d82013-09-06 09:32:43 -0700150 int64_t timestamp = data.readInt64();
Jianing Weicb0652e2014-03-12 18:29:36 -0700151 onCaptureStarted(result, timestamp);
Igor Murashkine7ee7632013-06-11 18:10:18 -0700152 data.readExceptionCode();
153 return NO_ERROR;
154 } break;
155 case RESULT_RECEIVED: {
Eino-Ville Talvalaf1e98d82013-09-06 09:32:43 -0700156 ALOGV("onResultReceived");
Igor Murashkine7ee7632013-06-11 18:10:18 -0700157 CHECK_INTERFACE(ICameraDeviceCallbacks, data, reply);
Jianing Weicb0652e2014-03-12 18:29:36 -0700158 CameraMetadata metadata;
Zhijun He11d0d442013-07-31 09:50:58 -0700159 if (data.readInt32() != 0) {
Jianing Weicb0652e2014-03-12 18:29:36 -0700160 metadata.readFromParcel(const_cast<Parcel*>(&data));
Zhijun He11d0d442013-07-31 09:50:58 -0700161 } else {
162 ALOGW("No metadata object is present in result");
163 }
Jianing Weicb0652e2014-03-12 18:29:36 -0700164 CaptureResultExtras resultExtras;
165 if (data.readInt32() != 0) {
166 resultExtras.readFromParcel(const_cast<Parcel*>(&data));
167 } else {
168 ALOGW("No capture result extras object is present in result");
169 }
170 onResultReceived(metadata, resultExtras);
Igor Murashkine7ee7632013-06-11 18:10:18 -0700171 data.readExceptionCode();
172 return NO_ERROR;
Eino-Ville Talvalaf1e98d82013-09-06 09:32:43 -0700173 } break;
Eino-Ville Talvala4d44cad2015-04-11 13:15:45 -0700174 case PREPARED: {
175 ALOGV("onPrepared");
176 CHECK_INTERFACE(ICameraDeviceCallbacks, data, reply);
177 CaptureResultExtras result;
178 int streamId = data.readInt32();
179 onPrepared(streamId);
180 data.readExceptionCode();
181 return NO_ERROR;
182 } break;
Igor Murashkine7ee7632013-06-11 18:10:18 -0700183 default:
184 return BBinder::onTransact(code, data, reply, flags);
185 }
186}
187
188// ----------------------------------------------------------------------------
189
190}; // namespace android