blob: fbe035c5d15292d03829ca05678c39405155758a [file] [log] [blame]
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +05301/*
2Copyright (c) 2015, The Linux Foundation. All rights reserved.
3
4Redistribution and use in source and binary forms, with or without
5modification, are permitted provided that the following conditions are
6met:
7 * Redistributions of source code must retain the above copyright
8 notice, this list of conditions and the following disclaimer.
9 * Redistributions in binary form must reproduce the above
10 copyright notice, this list of conditions and the following
11 disclaimer in the documentation and/or other materials provided
12 with the distribution.
13 * Neither the name of The Linux Foundation nor the names of its
14 contributors may be used to endorse or promote products derived
15 from this software without specific prior written permission.
16
17THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
18WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
19MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
20ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
21BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
24BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
25WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
26OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
27IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28*/
29
30#include "FmIoctlsInterface.h"
31#include <cstdio>
32#include <cstdlib>
33#include <cstring>
34#include <fcntl.h>
35#include <cutils/properties.h>
36#include <sys/ioctl.h>
37#include <linux/videodev2.h>
38#include <math.h>
39#include <utils/Log.h>
40
41int FmIoctlsInterface :: start_fm_patch_dl
42(
43 UINT fd
44)
45{
46 int ret;
47 int init_success = 0;
48 char versionStr[MAX_VER_STR_LEN] = {'\0'};
49 char prop_value[PROPERTY_VALUE_MAX] = {'\0'};
50 struct v4l2_capability cap;
51
52 ALOGE("start_fm_patch_dl = %d\n",fd);
53 ret = ioctl(fd, VIDIOC_QUERYCAP, &cap);
54 ALOGE("executed cmd\n");
55 if(ret == IOCTL_SUCC) {
56 ret = snprintf(versionStr, MAX_VER_STR_LEN, "%d", cap.version);
57 if(ret >= MAX_VER_STR_LEN) {
58 return FM_FAILURE;
59 }else {
60 ret = property_set(FM_VERSION_PROP, versionStr);
61 ALOGE("set versionStr done");
62 if(ret != PROP_SET_SUCC)
63 return FM_FAILURE;
64 ret = property_set(FM_MODE_PROP, "normal");
65 ALOGE("set FM_MODE_PROP done");
66 if(ret != PROP_SET_SUCC)
67 return FM_FAILURE;
68 ret = property_set(FM_INIT_PROP, "0");
69 ALOGE("set FM_INIT_PROP done");
70 if(ret != PROP_SET_SUCC)
71 return FM_FAILURE;
72 ret = property_set(SCRIPT_START_PROP, SOC_PATCH_DL_SCRPT);
73 if(ret != PROP_SET_SUCC)
74 return FM_FAILURE;
75 for(int i = 0; i < INIT_LOOP_CNT; i++) {
76 property_get(FM_INIT_PROP, prop_value, NULL);
77 if (strcmp(prop_value, "1") == 0) {
78 init_success = 1;
79 break;
80 }else {
81 usleep(INIT_WAIT_TIMEOUT);
82 }
83 }
84 if(!init_success) {
85 property_set(SCRIPT_STOP_PROP, SOC_PATCH_DL_SCRPT);
86 return FM_FAILURE;
87 }else {
88 return FM_SUCCESS;
89 }
90 }
91 }else {
92 return FM_FAILURE;
93 }
94}
95
96int FmIoctlsInterface :: close_fm_patch_dl
97(
98 void
99)
100{
101 int ret;
102
103 ret = property_set(SCRIPT_STOP_PROP, SOC_PATCH_DL_SCRPT);
104 if(ret != PROP_SET_SUCC) {
105 return FM_FAILURE;
106 }else {
107 return FM_SUCCESS;
108 }
109}
110
111int FmIoctlsInterface :: get_cur_freq
112(
113 UINT fd, long &freq
114)
115{
116 int ret;
117 struct v4l2_frequency channel;
118
119 channel.type = V4L2_TUNER_RADIO;
120 ret = ioctl(fd, VIDIOC_G_FREQUENCY, &channel);
121
Venkateshwarlu Domakondac09c3d82015-07-24 12:58:48 +0530122 if(ret < IOCTL_SUCC) {
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +0530123 return FM_FAILURE;
124 }else {
125 freq = (channel.frequency / TUNE_MULT);
126 return FM_SUCCESS;
127 }
128}
129
130int FmIoctlsInterface :: set_freq
131(
132 UINT fd, ULINT freq
133)
134{
135 int ret;
136 struct v4l2_frequency channel;
137
138 channel.type = V4L2_TUNER_RADIO;
139 channel.frequency = (freq * TUNE_MULT);
140
141 ret = ioctl(fd, VIDIOC_S_FREQUENCY, &channel);
Venkateshwarlu Domakondac09c3d82015-07-24 12:58:48 +0530142 if(ret < IOCTL_SUCC) {
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +0530143 return FM_FAILURE;
144 }else {
145 return FM_SUCCESS;
146 }
147}
148
149int FmIoctlsInterface :: set_control
150(
151 UINT fd, UINT id, int val
152)
153{
154 int ret;
155 struct v4l2_control control;
156
157 control.value = val;
158 control.id = id;
159
160 ret = ioctl(fd, VIDIOC_S_CTRL, &control);
Venkateshwarlu Domakondac09c3d82015-07-24 12:58:48 +0530161 if(ret < IOCTL_SUCC) {
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +0530162 return FM_FAILURE;
163 }else {
164 return FM_SUCCESS;
165 }
166}
167
168int FmIoctlsInterface :: set_calibration
169(
170 UINT fd
171)
172{
173 int ret;
174 FILE *cal_fp;
175 struct v4l2_ext_control ext_ctl;
176 struct v4l2_ext_controls v4l2_ctls;
177 char cal_data[CAL_DATA_SIZE] = {0};
178
179 cal_fp = fopen(CALIB_DATA_NAME, "r");
180 if(cal_fp != NULL) {
181 if(fread(&cal_data[0], 1, CAL_DATA_SIZE, cal_fp)
182 < CAL_DATA_SIZE) {
183 fclose(cal_fp);
184 return FM_FAILURE;
185 }
186 fclose(cal_fp);
187 ext_ctl.string = cal_data;
188 ext_ctl.size = CAL_DATA_SIZE;
189 v4l2_ctls.ctrl_class = V4L2_CTRL_CLASS_USER;
190 v4l2_ctls.count = 1;
191 v4l2_ctls.controls = &ext_ctl;
192 ret = ioctl(fd, VIDIOC_S_EXT_CTRLS, &v4l2_ctls);
Venkateshwarlu Domakondac09c3d82015-07-24 12:58:48 +0530193 if(ret < IOCTL_SUCC) {
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +0530194 return FM_FAILURE;
195 }else {
196 return FM_SUCCESS;
197 }
198 }else {
199 return FM_FAILURE;
200 }
201}
202
203int FmIoctlsInterface :: get_control
204(
205 UINT fd, UINT id, long &val
206)
207{
208 int ret;
209 struct v4l2_control control;
210
211 control.id = id;
212 ret = ioctl(fd, VIDIOC_G_CTRL, &control);
Venkateshwarlu Domakondac09c3d82015-07-24 12:58:48 +0530213 if(ret < IOCTL_SUCC) {
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +0530214 return FM_FAILURE;
215 }else {
216 val = control.value;
217 return FM_SUCCESS;
218 }
219}
220
221int FmIoctlsInterface :: start_search
222(
223 UINT fd, UINT dir
224)
225{
226 int ret;
227 struct v4l2_hw_freq_seek hw_seek;
228
229 hw_seek.seek_upward = dir;
230 hw_seek.type = V4L2_TUNER_RADIO;
231
232 ret = ioctl(fd, VIDIOC_S_HW_FREQ_SEEK, &hw_seek);
Venkateshwarlu Domakondac09c3d82015-07-24 12:58:48 +0530233 if(ret < IOCTL_SUCC) {
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +0530234 return FM_FAILURE;
235 }else {
236 return FM_SUCCESS;
237 }
238}
239
240int FmIoctlsInterface :: set_band
241(
242 UINT fd, ULINT low, ULINT high
243)
244{
245 int ret;
246 struct v4l2_tuner tuner;
247
248 tuner.index = 0;
249 tuner.signal = 0;
250 tuner.rangelow = (low * TUNE_MULT);
251 tuner.rangehigh = (high * TUNE_MULT);
252
253 ret = ioctl(fd, VIDIOC_S_TUNER, &tuner);
254 ret = set_control(fd, V4L2_CID_PRV_REGION, 0);
Venkateshwarlu Domakondac09c3d82015-07-24 12:58:48 +0530255 if(ret < IOCTL_SUCC) {
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +0530256 return FM_FAILURE;
257 }else {
258 return FM_SUCCESS;
259 }
260}
261
262int FmIoctlsInterface :: get_rmssi
263(
264 UINT fd, long &rmssi
265)
266{
267 struct v4l2_tuner tuner;
268 int ret;
269
270 tuner.index = 0;
271 tuner.signal = 0;
272 ret = ioctl(fd, VIDIOC_G_TUNER, &tuner);
Venkateshwarlu Domakondac09c3d82015-07-24 12:58:48 +0530273 if(ret < IOCTL_SUCC) {
274 ret = FM_FAILURE;
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +0530275 }else {
276 rmssi = tuner.signal;
277 ret = FM_SUCCESS;
278 }
279 return ret;
280}
281
282int FmIoctlsInterface :: get_upperband_limit
283(
284 UINT fd, ULINT &freq
285)
286{
287 int ret;
288 struct v4l2_tuner tuner;
289
290 tuner.index = 0;
291 ret = ioctl(fd, VIDIOC_G_TUNER, &tuner);
Venkateshwarlu Domakondac09c3d82015-07-24 12:58:48 +0530292 if(ret < IOCTL_SUCC) {
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +0530293 return FM_FAILURE;
294 }else {
295 freq = (tuner.rangehigh / TUNE_MULT);
296 ALOGE("high freq: %d\n",freq);
297 return FM_SUCCESS;
298 }
299}
300
301int FmIoctlsInterface :: get_lowerband_limit
302(
303 UINT fd, ULINT &freq
304)
305{
306 int ret;
307 struct v4l2_tuner tuner;
308
309 tuner.index = 0;
310 ret = ioctl(fd, VIDIOC_G_TUNER, &tuner);
Venkateshwarlu Domakondac09c3d82015-07-24 12:58:48 +0530311 if(ret < IOCTL_SUCC) {
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +0530312 return FM_FAILURE;
313 }else {
314 freq = (tuner.rangelow / TUNE_MULT);
315 ALOGE("low freq: %d\n",freq);
316 return FM_SUCCESS;
317 }
318}
319
320int FmIoctlsInterface :: set_audio_mode
321(
322 UINT fd, enum AUDIO_MODE mode
323)
324{
325 int ret;
326 struct v4l2_tuner tuner;
327
328 tuner.index = 0;
329 ret = ioctl(fd, VIDIOC_G_TUNER, &tuner);
Venkateshwarlu Domakondac09c3d82015-07-24 12:58:48 +0530330 if(ret < IOCTL_SUCC) {
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +0530331 return FM_FAILURE;
332 }else {
333 tuner.audmode = mode;
334 ret = ioctl(fd, VIDIOC_S_TUNER, &tuner);
335 if(ret != IOCTL_SUCC) {
336 return FM_FAILURE;
337 }else {
338 return FM_SUCCESS;
339 }
340 }
341}
342
343int FmIoctlsInterface :: get_buffer
344(
345 UINT fd, char *buff, UINT len, UINT index
346)
347{
348 int ret;
349 struct v4l2_buffer v4l2_buf;
350
351 if((len < STD_BUF_SIZE) || (buff == NULL)) {
352 return FM_FAILURE;
353 }else {
354 memset(&v4l2_buf, 0, sizeof(v4l2_buf));
355 v4l2_buf.index = index;
356 v4l2_buf.type = V4L2_BUF_TYPE_PRIVATE;
357 v4l2_buf.length = STD_BUF_SIZE;
358 v4l2_buf.m.userptr = (ULINT)buff;
359 ret = ioctl(fd, VIDIOC_DQBUF, &v4l2_buf);
Venkateshwarlu Domakondac09c3d82015-07-24 12:58:48 +0530360 if(ret < IOCTL_SUCC) {
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +0530361 return FM_FAILURE;
362 }else {
363 return v4l2_buf.bytesused;
364 }
365 }
366}
367
368int FmIoctlsInterface :: set_ext_control
369(
370 UINT fd,
371 struct v4l2_ext_controls *v4l2_ctls
372)
373{
374 int ret;
375
376 ret = ioctl(fd, VIDIOC_S_EXT_CTRLS, v4l2_ctls);
377
Venkateshwarlu Domakondac09c3d82015-07-24 12:58:48 +0530378 if(ret < IOCTL_SUCC) {
Venkateshwarlu Domakondaacdd9a42015-03-24 10:28:37 +0530379 return FM_FAILURE;
380 }else {
381 return FM_SUCCESS;
382 }
383}
384