• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /* Copyright (c) 2012-2014, The Linux Foundataion. All rights reserved.
2 *
3 * Redistribution and use in source and binary forms, with or without
4 * modification, are permitted provided that the following conditions are
5 * met:
6 *     * Redistributions of source code must retain the above copyright
7 *       notice, this list of conditions and the following disclaimer.
8 *     * Redistributions in binary form must reproduce the above
9 *       copyright notice, this list of conditions and the following
10 *       disclaimer in the documentation and/or other materials provided
11 *       with the distribution.
12 *     * Neither the name of The Linux Foundation nor the names of its
13 *       contributors may be used to endorse or promote products derived
14 *       from this software without specific prior written permission.
15 *
16 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
19 * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
20 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
23 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
24 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
25 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
26 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 *
28 */
29 
30 #define LOG_TAG "QCamera3Factory"
31 //#define LOG_NDEBUG 0
32 
33 #include <stdlib.h>
34 #include <utils/Log.h>
35 #include <utils/Errors.h>
36 #include <hardware/camera3.h>
37 
38 #include "QCamera3Factory.h"
39 
40 using namespace android;
41 
42 namespace qcamera {
43 
44 QCamera3Factory *gQCamera3Factory = NULL;
45 
46 /*===========================================================================
47  * FUNCTION   : QCamera3Factory
48  *
49  * DESCRIPTION: default constructor of QCamera3Factory
50  *
51  * PARAMETERS : none
52  *
53  * RETURN     : None
54  *==========================================================================*/
QCamera3Factory()55 QCamera3Factory::QCamera3Factory()
56 {
57     camera_info info;
58 
59     mNumOfCameras = get_num_of_cameras();
60 
61     //Query camera at this point in order
62     //to avoid any delays during subsequent
63     //calls to 'getCameraInfo()'
64     for (int i = 0 ; i < mNumOfCameras ; i++) {
65         getCameraInfo(i, &info);
66     }
67     //
68 
69 }
70 
71 /*===========================================================================
72  * FUNCTION   : ~QCamera3Factory
73  *
74  * DESCRIPTION: deconstructor of QCamera2Factory
75  *
76  * PARAMETERS : none
77  *
78  * RETURN     : None
79  *==========================================================================*/
~QCamera3Factory()80 QCamera3Factory::~QCamera3Factory()
81 {
82 }
83 
84 /*===========================================================================
85  * FUNCTION   : get_number_of_cameras
86  *
87  * DESCRIPTION: static function to query number of cameras detected
88  *
89  * PARAMETERS : none
90  *
91  * RETURN     : number of cameras detected
92  *==========================================================================*/
get_number_of_cameras()93 int QCamera3Factory::get_number_of_cameras()
94 {
95     if (!gQCamera3Factory) {
96         gQCamera3Factory = new QCamera3Factory();
97         if (!gQCamera3Factory) {
98             ALOGE("%s: Failed to allocate Camera3Factory object", __func__);
99             return 0;
100         }
101     }
102     return gQCamera3Factory->getNumberOfCameras();
103 }
104 
105 /*===========================================================================
106  * FUNCTION   : get_camera_info
107  *
108  * DESCRIPTION: static function to query camera information with its ID
109  *
110  * PARAMETERS :
111  *   @camera_id : camera ID
112  *   @info      : ptr to camera info struct
113  *
114  * RETURN     : int32_t type of status
115  *              NO_ERROR  -- success
116  *              none-zero failure code
117  *==========================================================================*/
get_camera_info(int camera_id,struct camera_info * info)118 int QCamera3Factory::get_camera_info(int camera_id, struct camera_info *info)
119 {
120     return gQCamera3Factory->getCameraInfo(camera_id, info);
121 }
122 
123 /*===========================================================================
124  * FUNCTION   : getNumberOfCameras
125  *
126  * DESCRIPTION: query number of cameras detected
127  *
128  * PARAMETERS : none
129  *
130  * RETURN     : number of cameras detected
131  *==========================================================================*/
getNumberOfCameras()132 int QCamera3Factory::getNumberOfCameras()
133 {
134     return mNumOfCameras;
135 }
136 
137 /*===========================================================================
138  * FUNCTION   : getCameraInfo
139  *
140  * DESCRIPTION: query camera information with its ID
141  *
142  * PARAMETERS :
143  *   @camera_id : camera ID
144  *   @info      : ptr to camera info struct
145  *
146  * RETURN     : int32_t type of status
147  *              NO_ERROR  -- success
148  *              none-zero failure code
149  *==========================================================================*/
getCameraInfo(int camera_id,struct camera_info * info)150 int QCamera3Factory::getCameraInfo(int camera_id, struct camera_info *info)
151 {
152     int rc;
153     ALOGV("%s: E, camera_id = %d", __func__, camera_id);
154 
155     if (!mNumOfCameras || camera_id >= mNumOfCameras || !info ||
156         (camera_id < 0)) {
157         return -ENODEV;
158     }
159 
160     rc = QCamera3HardwareInterface::getCamInfo(camera_id, info);
161     ALOGV("%s: X", __func__);
162     return rc;
163 }
164 
165 /*===========================================================================
166  * FUNCTION   : cameraDeviceOpen
167  *
168  * DESCRIPTION: open a camera device with its ID
169  *
170  * PARAMETERS :
171  *   @camera_id : camera ID
172  *   @hw_device : ptr to struct storing camera hardware device info
173  *
174  * RETURN     : int32_t type of status
175  *              NO_ERROR  -- success
176  *              none-zero failure code
177  *==========================================================================*/
cameraDeviceOpen(int camera_id,struct hw_device_t ** hw_device)178 int QCamera3Factory::cameraDeviceOpen(int camera_id,
179                     struct hw_device_t **hw_device)
180 {
181     int rc = NO_ERROR;
182     if (camera_id < 0 || camera_id >= mNumOfCameras)
183         return -ENODEV;
184 
185     QCamera3HardwareInterface *hw = new QCamera3HardwareInterface(camera_id);
186     if (!hw) {
187         ALOGE("Allocation of hardware interface failed");
188         return NO_MEMORY;
189     }
190     rc = hw->openCamera(hw_device);
191     if (rc != 0) {
192         delete hw;
193     }
194     return rc;
195 }
196 
197 /*===========================================================================
198  * FUNCTION   : camera_device_open
199  *
200  * DESCRIPTION: static function to open a camera device by its ID
201  *
202  * PARAMETERS :
203  *   @camera_id : camera ID
204  *   @hw_device : ptr to struct storing camera hardware device info
205  *
206  * RETURN     : int32_t type of status
207  *              NO_ERROR  -- success
208  *              none-zero failure code
209  *==========================================================================*/
camera_device_open(const struct hw_module_t * module,const char * id,struct hw_device_t ** hw_device)210 int QCamera3Factory::camera_device_open(
211     const struct hw_module_t *module, const char *id,
212     struct hw_device_t **hw_device)
213 {
214     if (module != &HAL_MODULE_INFO_SYM.common) {
215         ALOGE("Invalid module. Trying to open %p, expect %p",
216             module, &HAL_MODULE_INFO_SYM.common);
217         return INVALID_OPERATION;
218     }
219     if (!id) {
220         ALOGE("Invalid camera id");
221         return BAD_VALUE;
222     }
223     return gQCamera3Factory->cameraDeviceOpen(atoi(id), hw_device);
224 }
225 
226 struct hw_module_methods_t QCamera3Factory::mModuleMethods = {
227     open: QCamera3Factory::camera_device_open,
228 };
229 
230 }; // namespace qcamera
231 
232