1 /*
2 * Copyright (C) Texas Instruments - http://www.ti.com/
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17 /**
18 * @file CameraProperties.cpp
19 *
20 * This file maps the CameraHardwareInterface to the Camera interfaces on OMAP4 (mainly OMX).
21 *
22 */
23
24 //#include "CameraHal.h"
25 #include <utils/threads.h>
26
27 #include "DebugUtils.h"
28 #include "CameraProperties.h"
29
30 #define CAMERA_ROOT "CameraRoot"
31 #define CAMERA_INSTANCE "CameraInstance"
32
33 namespace android {
34
35 // lower entries have higher priority
36 static const char* g_camera_adapters[] = {
37 #ifdef OMAP4_SUPPORT_OMX_CAMERA_ADAPTER
38 "libomxcameraadapter.so",
39 #endif
40 #ifdef OMAP4_SUPPORT_USB_CAMERA_ADAPTER
41 "libusbcameraadapter.so"
42 #endif
43 };
44
45 /*********************************************************
46 CameraProperties - public function implemetation
47 **********************************************************/
48
CameraProperties()49 CameraProperties::CameraProperties() : mCamerasSupported(0)
50 {
51 LOG_FUNCTION_NAME;
52
53 mCamerasSupported = 0;
54 mInitialized = 0;
55
56 LOG_FUNCTION_NAME_EXIT;
57 }
58
~CameraProperties()59 CameraProperties::~CameraProperties()
60 {
61 LOG_FUNCTION_NAME;
62
63 LOG_FUNCTION_NAME_EXIT;
64 }
65
66
67 // Initializes the CameraProperties class
initialize()68 status_t CameraProperties::initialize()
69 {
70 LOG_FUNCTION_NAME;
71
72 status_t ret;
73
74 Mutex::Autolock lock(mLock);
75
76 if(mInitialized)
77 return NO_ERROR;
78
79 ret = loadProperties();
80
81 mInitialized = 1;
82
83 LOG_FUNCTION_NAME_EXIT;
84
85 return ret;
86 }
87
88 extern "C" int CameraAdapter_Capabilities(CameraProperties::Properties* properties_array,
89 const unsigned int starting_camera,
90 const unsigned int max_camera);
91
92 ///Loads all the Camera related properties
loadProperties()93 status_t CameraProperties::loadProperties()
94 {
95 LOG_FUNCTION_NAME;
96
97 status_t ret = NO_ERROR;
98
99 // adapter updates capabilities and we update camera count
100 mCamerasSupported = CameraAdapter_Capabilities(mCameraProps, mCamerasSupported, MAX_CAMERAS_SUPPORTED);
101
102 if((int)mCamerasSupported < 0) {
103 LOGE("error while getting capabilities");
104 ret = UNKNOWN_ERROR;
105 } else if (mCamerasSupported > MAX_CAMERAS_SUPPORTED) {
106 LOGE("returned too many adapaters");
107 ret = UNKNOWN_ERROR;
108 } else {
109 LOGE("num_cameras = %d", mCamerasSupported);
110
111 for (unsigned int i = 0; i < mCamerasSupported; i++) {
112 mCameraProps[i].set(CAMERA_SENSOR_INDEX, i);
113 mCameraProps[i].dump();
114 }
115 }
116
117 LOGV("mCamerasSupported = %d", mCamerasSupported);
118 LOG_FUNCTION_NAME_EXIT;
119 return ret;
120 }
121
122 // Returns the number of Cameras found
camerasSupported()123 int CameraProperties::camerasSupported()
124 {
125 LOG_FUNCTION_NAME;
126 return mCamerasSupported;
127 }
128
129 };
130