blob: b02ea4d14bac5e80df7951b072c7e1729a1acc4d [file] [log] [blame]
wangyouqiang3d09b4d2024-01-04 13:50:51 +08001#include <time.h>
wangyouqiang75b6cfd2024-05-31 14:25:45 +08002#include <pthread.h>
liuyanga812f1b2024-07-25 17:49:14 +08003#include <stdio.h>
4#include <stdlib.h>
5#include <string.h>
wangyouqiang75b6cfd2024-05-31 14:25:45 +08006
b.liu4e243dc2023-11-27 11:20:00 +08007#include "lynq_gnss.h"
liuyanga812f1b2024-07-25 17:49:14 +08008
wangyouqiang3d09b4d2024-01-04 13:50:51 +08009#define QSER_RESULT_SUCCESS 0
10#define QSER_RESULT_FAIL -1
liuyanga812f1b2024-07-25 17:49:14 +080011#define QSER_GNSS_TIMEOUT 5
wangyouqiang3d09b4d2024-01-04 13:50:51 +080012
13/**********************************VARIABLE***********************************/
14static bool inited = FALSE;
yq.wang6a3437f2024-07-27 02:57:20 -070015static uint32_t qser_h_gnss = 0x5F6F7F8F;
wangyouqiang3d09b4d2024-01-04 13:50:51 +080016gnss_handler_func_t qser_gnss_callback = NULL;
wangyouqiang3d09b4d2024-01-04 13:50:51 +080017static time_t qser_gnss_time = 0;
yq.wang937355d2024-07-26 01:24:42 -070018qser_agps_info qser_agps_info_save = {0};
wangyouqiang75b6cfd2024-05-31 14:25:45 +080019gnss_async_func_t qser_gnss_async_callback = NULL;
wangyouqiang3d09b4d2024-01-04 13:50:51 +080020
21extern long timezone;
22/**********************************VARIABLE***********************************/
23
24/**********************************FUNC***********************************/
wangyouqiang75b6cfd2024-05-31 14:25:45 +080025static void qser_gnss_async_set_cb(gnss_async_func_t cb)
26{
27 qser_gnss_async_callback = cb;
28}
29
30static gnss_async_func_t qser_gnss_async_get_cb(void)
31{
32 return qser_gnss_async_callback;
33}
34
35
wangyouqiang3d09b4d2024-01-04 13:50:51 +080036static time_t qser_get_timestamp(char *time)
37{
38 char tmp_char[4] = {0};
39 struct tm* tmp_time = (struct tm*)malloc(sizeof(struct tm));
40
41 memset(tmp_time, 0, sizeof(struct tm));
42 memset(tmp_char, 0, sizeof(tmp_char));
43 memcpy(tmp_char, &time[4], 2);
44 tmp_time->tm_sec = atoi(tmp_char);
45 memcpy(tmp_char, &time[2], 2);
46 tmp_time->tm_min = atoi(tmp_char);
47 memcpy(tmp_char, &time[0], 2);
48 tmp_time->tm_hour = atoi(tmp_char);
49 memcpy(tmp_char, &time[6], 2);
50 tmp_time->tm_mday = atoi(tmp_char);
51 memcpy(tmp_char, &time[8], 2);
52 tmp_time->tm_mon = atoi(tmp_char) - 1;
53 memcpy(tmp_char, &time[10], 2);
54 tmp_time->tm_year = 100 + atoi(tmp_char);
55
56 time_t _t = mktime(tmp_time);//按当地时区解析tmp_time
57 //gnss_log("timestamp: %ld\n",_t);
58 tzset(); // 自动设置本地时区
59 _t = _t - timezone;
60 //gnss_log("timestamp: %ld\n",_t);
61
62 free(tmp_time);
63 return _t;
64}
65
yq.wang937355d2024-07-26 01:24:42 -070066static time_t qser_get_gnss_time_sec(const void *data, int data_len)
wangyouqiang3d09b4d2024-01-04 13:50:51 +080067{
68 int i = 0, num = 0;
yq.wang937355d2024-07-26 01:24:42 -070069 const char *nmea = (const char *)data;
wangyouqiang3d09b4d2024-01-04 13:50:51 +080070 char time[15] = {0};
71 char *check_state = NULL;
72
73 //$GNRMC,024142.000,A,3039.364421,N,10403.417935,E,0.051,0.00,030124,,E,A*00
74 check_state = strstr(nmea, "RMC");
75 if(check_state != NULL)
76 {
77 for(i = 0; i < data_len; i++)
78 {
79 if(check_state[i] == ',')
80 {
81 num++;
82 i++;
wangyouqiange039fe32024-01-04 16:02:42 +080083 if(num == 1)//get time
wangyouqiang3d09b4d2024-01-04 13:50:51 +080084 {
wangyouqiange039fe32024-01-04 16:02:42 +080085 if(check_state[i] >= '0' && check_state[i] <= '9')
86 {
87 memcpy(time, check_state + i, 6);
liuyanga812f1b2024-07-25 17:49:14 +080088 LOGE("[qser_gnss] %s.", time);
wangyouqiange039fe32024-01-04 16:02:42 +080089 }
90 else
91 {
92 qser_gnss_time = 0;
93 return qser_gnss_time;
94 }
wangyouqiang3d09b4d2024-01-04 13:50:51 +080095 }
wangyouqiange039fe32024-01-04 16:02:42 +080096 else if(num == 9)//get date
wangyouqiang3d09b4d2024-01-04 13:50:51 +080097 {
wangyouqiange039fe32024-01-04 16:02:42 +080098 if(check_state[i] >= '0' && check_state[i] <= '9')
99 {
100 memcpy(time + 6, check_state + i, 6);
liuyanga812f1b2024-07-25 17:49:14 +0800101 LOGE("[qser_gnss] %s.", time);
wangyouqiange039fe32024-01-04 16:02:42 +0800102 break;
103 }
104 else
105 {
106 qser_gnss_time = 0;
107 return qser_gnss_time;
108 }
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800109 }
wangyouqiange039fe32024-01-04 16:02:42 +0800110 else if(num > 9)
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800111 {
112 qser_gnss_time = 0;
113 return qser_gnss_time;
114 }
115 }
116 }
117
118 qser_gnss_time = qser_get_timestamp(time);
119 }
120
121 return qser_gnss_time;
122}
123
wangyouqiang75b6cfd2024-05-31 14:25:45 +0800124static void* gnss_async_thread(void* arg)
125{
126 qser_gnss_error_e state = QSER_GNSS_ERROR_SUCCESS;
127 gnss_async_func_t cb = qser_gnss_async_get_cb();
yq.wang6a3437f2024-07-27 02:57:20 -0700128 int ret = qser_Gnss_Start(qser_h_gnss);
wangyouqiang75b6cfd2024-05-31 14:25:45 +0800129 if(ret != QSER_RESULT_SUCCESS)
130 {
131 LOGE("[qser_gnss] gnss_async_thread() fail.");
132 state = QSER_GNSS_ERROR_FAIL;
133 }
134
135 if(cb != NULL)
136 {
137 cb(state);
138 }
139 return NULL;
140}
141
liuyanga812f1b2024-07-25 17:49:14 +0800142static void gnss_callback(uint32 ind_type, const void* data, uint32 data_len)
143{
yq.wang937355d2024-07-26 01:24:42 -0700144 if(data == NULL || data_len <= 0)
145 {
146 LOGE("[qser_gnss] data is NULL.");
147 return;
148 }
149
150 if(qser_gnss_callback == NULL)
151 {
152 //LOGE("[qser_gnss] qser_gnss_callback is NULL.");
153 return;
154 }
155
liuyanga812f1b2024-07-25 17:49:14 +0800156 if(ind_type == MBTK_GNSS_IND_LOCATION) {
yq.wang937355d2024-07-26 01:24:42 -0700157 if(data_len != sizeof(mbtk_gnss_location_info_t))
158 {
159 LOGE("[qser_gnss] data size error");
160 return;
161 }
162 mbtk_gnss_location_info_t *locl_info = (mbtk_gnss_location_info_t *)data;
163 mopen_location_info_t qser_locl_info;
164 memset(&qser_locl_info, 0x0, sizeof(mopen_location_info_t));
165 qser_locl_info.latitude = locl_info->latitude;
166 qser_locl_info.longitude = locl_info->longitude;
167 qser_locl_info.altitude = locl_info->altitude;
168 qser_locl_info.speed = locl_info->speed;
169 qser_locl_info.bearing = locl_info->bearing;
170 qser_locl_info.timestamp = locl_info->timestamp;
171 qser_gnss_callback(NULL, E_MT_LOC_MSG_ID_LOCATION_INFO, (void *)(&qser_locl_info), NULL);
liuyanga812f1b2024-07-25 17:49:14 +0800172 } else if(ind_type == MBTK_GNSS_IND_NMEA) {
yq.wang937355d2024-07-26 01:24:42 -0700173 mopen_gnss_nmea_info_t qser_nmea = {0};
174 memset(&qser_nmea, 0x0, sizeof(mopen_gnss_nmea_info_t));
175 qser_nmea.length = data_len;
176 memcpy(qser_nmea.nmea, (char *)data, data_len);
177 qser_nmea.timestamp = qser_get_gnss_time_sec(data, data_len);
178 qser_gnss_callback(NULL, E_MT_LOC_MSG_ID_NMEA_INFO, (void *)(&qser_nmea), NULL);
liuyanga812f1b2024-07-25 17:49:14 +0800179 } else {
180 printf("Unknown IND : %d\n", ind_type);
181 }
182}
183
184
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800185/**********************************FUNC***********************************/
186
187/**********************************API***********************************/
b.liu4e243dc2023-11-27 11:20:00 +0800188int qser_Gnss_Init (uint32_t *h_gnss)
liubin281ac462023-07-19 14:22:54 +0800189{
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800190 //UNUSED(h_gnss);
liuyanga812f1b2024-07-25 17:49:14 +0800191 gnss_err_enum ret = GNSS_ERR_UNKNOWN;
liubin281ac462023-07-19 14:22:54 +0800192
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800193 if(!inited)
194 {
liuyanga812f1b2024-07-25 17:49:14 +0800195 ret = mbtk_gnss_init(gnss_callback);
196 if(ret == GNSS_ERR_OK)
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800197 {
yq.wang937355d2024-07-26 01:24:42 -0700198 ret = mbtk_gnss_ind_set(MBTK_GNSS_IND_NMEA, QSER_GNSS_TIMEOUT);
199 if(ret == GNSS_ERR_OK)
200 {
201 inited = TRUE;
202 }
203 else
204 {
yq.wang5c647e02024-08-10 00:01:11 -0700205 LOGE("[qser_gnss] init mbtk_gnss_ind_set() fail.ret = [%d]", ret);
yq.wang937355d2024-07-26 01:24:42 -0700206 return QSER_RESULT_FAIL;
207 }
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800208 }
209 else
210 {
yq.wang5c647e02024-08-10 00:01:11 -0700211 LOGE("[qser_gnss] mbtk_gnss_init() fail.ret = [%d]", ret);
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800212 return QSER_RESULT_FAIL;
213 }
214 }
yq.wang6a3437f2024-07-27 02:57:20 -0700215 *h_gnss = qser_h_gnss;
liubin281ac462023-07-19 14:22:54 +0800216
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800217 return QSER_RESULT_SUCCESS;
liubin281ac462023-07-19 14:22:54 +0800218}
219
b.liu4e243dc2023-11-27 11:20:00 +0800220int qser_Gnss_Deinit (uint32_t h_gnss)
liubin281ac462023-07-19 14:22:54 +0800221{
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800222 //UNUSED(h_gnss);
yq.wang6a3437f2024-07-27 02:57:20 -0700223 if(h_gnss != qser_h_gnss)
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800224 {
yq.wang6a3437f2024-07-27 02:57:20 -0700225 LOGE("[qser_gnss] h_gnss is error.");
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800226 return QSER_RESULT_FAIL;
227 }
228
liuyanga812f1b2024-07-25 17:49:14 +0800229 gnss_err_enum ret = GNSS_ERR_UNKNOWN;
liubin281ac462023-07-19 14:22:54 +0800230
yq.wang6a3437f2024-07-27 02:57:20 -0700231 if(inited)
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800232 {
yq.wang6a3437f2024-07-27 02:57:20 -0700233 ret = mbtk_gnss_deinit();
234 if(ret == GNSS_ERR_OK)
235 {
236 inited = FALSE;
237 }
238 else
239 {
yq.wang5c647e02024-08-10 00:01:11 -0700240 LOGE("[qser_gnss] mbtk_gnss_init() fail.ret = [%d]", ret);
yq.wang6a3437f2024-07-27 02:57:20 -0700241 return QSER_RESULT_FAIL;
242 }
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800243 }
liubin281ac462023-07-19 14:22:54 +0800244
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800245 return QSER_RESULT_SUCCESS;
liubin281ac462023-07-19 14:22:54 +0800246}
b.liu5fa9e772023-11-23 18:00:55 +0800247
b.liu4e243dc2023-11-27 11:20:00 +0800248int qser_AddRxIndMsgHandler (gnss_handler_func_t handler_ptr,uint32_t h_gnss)
249{
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800250 //UNUSED(handler_ptr);
251 //UNUSED(h_gnss);
yq.wang6a3437f2024-07-27 02:57:20 -0700252 if(h_gnss != qser_h_gnss)
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800253 {
yq.wang6a3437f2024-07-27 02:57:20 -0700254 LOGE("[qser_gnss] h_gnss is error.");
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800255 return QSER_RESULT_FAIL;
256 }
b.liu4e243dc2023-11-27 11:20:00 +0800257
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800258 if(handler_ptr == NULL)
259 {
260 LOGE("[qser_gnss] handler_ptr is NULL.");
261 return QSER_RESULT_FAIL;
262 }
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800263
264 qser_gnss_callback = handler_ptr;
265 return QSER_RESULT_SUCCESS;
b.liu5fa9e772023-11-23 18:00:55 +0800266}
267
b.liu4e243dc2023-11-27 11:20:00 +0800268int qser_Set_Indications (uint32_t h_gnss,e_msg_id_t type)
269{
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800270 //UNUSED(h_gnss);
271 //UNUSED(type);
yq.wang6a3437f2024-07-27 02:57:20 -0700272 if(h_gnss != qser_h_gnss)
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800273 {
yq.wang6a3437f2024-07-27 02:57:20 -0700274 LOGE("[qser_gnss] h_gnss is error.");
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800275 return QSER_RESULT_FAIL;
276 }
b.liu4e243dc2023-11-27 11:20:00 +0800277
yq.wang937355d2024-07-26 01:24:42 -0700278 gnss_err_enum ret = GNSS_ERR_OK;
279 if(type == E_MT_LOC_MSG_ID_LOCATION_INFO)
280 {
281 ret = mbtk_gnss_ind_set(MBTK_GNSS_IND_LOCATION, QSER_GNSS_TIMEOUT);
282 }
283 else if(type == E_MT_LOC_MSG_ID_NMEA_INFO)
284 {
285 ret = mbtk_gnss_ind_set(MBTK_GNSS_IND_NMEA, QSER_GNSS_TIMEOUT);
286 }
287 else
288 {
289 LOGE("[qser_gnss] type is fail.");
290 return QSER_RESULT_FAIL;
291 }
292
293 if(ret != GNSS_ERR_OK)
294 {
yq.wang5c647e02024-08-10 00:01:11 -0700295 LOGE("[qser_gnss] mbtk_gnss_ind_set() fail.ret = [%d]", ret);
yq.wang937355d2024-07-26 01:24:42 -0700296 return QSER_RESULT_FAIL;
297 }
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800298 return QSER_RESULT_SUCCESS;
b.liu4e243dc2023-11-27 11:20:00 +0800299}
300
wangyouqiang75b6cfd2024-05-31 14:25:45 +0800301int qser_Gnss_Set_Async_Callback(gnss_async_func_t cb)
302{
303 qser_gnss_async_set_cb(cb);
304 return QSER_RESULT_SUCCESS;
305}
306
b.liu4e243dc2023-11-27 11:20:00 +0800307int qser_Gnss_Start (uint32_t h_gnss)
308{
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800309 //UNUSED(h_gnss);
yq.wang6a3437f2024-07-27 02:57:20 -0700310 if(h_gnss != qser_h_gnss)
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800311 {
yq.wang6a3437f2024-07-27 02:57:20 -0700312 LOGE("[qser_gnss] h_gnss is error.");
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800313 return QSER_RESULT_FAIL;
314 }
b.liu4e243dc2023-11-27 11:20:00 +0800315
liuyanga812f1b2024-07-25 17:49:14 +0800316 gnss_err_enum ret = GNSS_ERR_UNKNOWN;
wangyouqiang7d66fb12024-01-26 19:19:00 +0800317
yq.wang937355d2024-07-26 01:24:42 -0700318 ret = mbtk_gnss_open(255, QSER_GNSS_TIMEOUT);
liuyanga812f1b2024-07-25 17:49:14 +0800319 if(ret != GNSS_ERR_OK)
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800320 {
yq.wang5c647e02024-08-10 00:01:11 -0700321 LOGE("[qser_gnss] mbtk_gnss_open is error.ret = [%d]", ret);
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800322 return QSER_RESULT_FAIL;
323 }
324
325 return QSER_RESULT_SUCCESS;
b.liu4e243dc2023-11-27 11:20:00 +0800326}
327
wangyouqiang75b6cfd2024-05-31 14:25:45 +0800328int qser_Gnss_Start_Async(uint32_t h_gnss)
329{
330 //UNUSED(h_gnss);
yq.wang6a3437f2024-07-27 02:57:20 -0700331 if(h_gnss != qser_h_gnss)
wangyouqiang75b6cfd2024-05-31 14:25:45 +0800332 {
yq.wang6a3437f2024-07-27 02:57:20 -0700333 LOGE("[qser_gnss] h_gnss is error.");
wangyouqiang75b6cfd2024-05-31 14:25:45 +0800334 return QSER_RESULT_FAIL;
335 }
336
337 pthread_attr_t thread_attr;
338 pthread_t gnss_thread_id;
339 pthread_attr_init(&thread_attr);
340 if(pthread_attr_setdetachstate(&thread_attr, PTHREAD_CREATE_DETACHED))
341 {
342 LOGE("[qser_gnss] pthread_attr_setdetachstate() fail.");
343 return QSER_RESULT_FAIL;
344 }
345
346 //memcpy(&qser_data_backup, data_call, sizeof(qser_data_call_s));
347 if(pthread_create(&gnss_thread_id, &thread_attr, gnss_async_thread, NULL))
348 {
349 LOGE("[qser_gnss] pthread_create() fail.");
350 return QSER_RESULT_FAIL;
351 }
352 pthread_attr_destroy(&thread_attr);
353
354 return QSER_RESULT_SUCCESS;
355}
356
b.liu4e243dc2023-11-27 11:20:00 +0800357int qser_Gnss_Stop (uint32_t h_gnss)
358{
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800359 //UNUSED(h_gnss);
yq.wang6a3437f2024-07-27 02:57:20 -0700360 if(h_gnss != qser_h_gnss)
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800361 {
yq.wang6a3437f2024-07-27 02:57:20 -0700362 LOGE("[qser_gnss] h_gnss is error.");
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800363 return QSER_RESULT_FAIL;
364 }
b.liu4e243dc2023-11-27 11:20:00 +0800365
liuyanga812f1b2024-07-25 17:49:14 +0800366 gnss_err_enum ret = GNSS_ERR_UNKNOWN;
367 ret = mbtk_gnss_close(QSER_GNSS_TIMEOUT);
368 if(ret != GNSS_ERR_OK)
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800369 {
yq.wang5c647e02024-08-10 00:01:11 -0700370 LOGE("[qser_gnss] mbtk_gnss_close is error.ret = [%d]", ret);
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800371 return QSER_RESULT_FAIL;
372 }
liuyanga812f1b2024-07-25 17:49:14 +0800373
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800374 return QSER_RESULT_SUCCESS;
b.liu4e243dc2023-11-27 11:20:00 +0800375}
376
377int qser_Gnss_InjectTime (uint32_t h_gnss,LYNQ_INJECT_TIME_INTO_T *time_info)
378{
yq.wang6a3437f2024-07-27 02:57:20 -0700379 //UNUSED(h_gnss);
b.liu4e243dc2023-11-27 11:20:00 +0800380 UNUSED(time_info);
381
yq.wang6a3437f2024-07-27 02:57:20 -0700382 if(h_gnss != qser_h_gnss)
383 {
384 LOGE("[qser_gnss] h_gnss is error.");
385 return QSER_RESULT_FAIL;
386 }
387 return QSER_RESULT_SUCCESS;
b.liu4e243dc2023-11-27 11:20:00 +0800388}
389
390int qser_Gnss_Delete_Aiding_Data (uint32_t h_gnss,DELETE_AIDING_DATA_TYPE_T flags)
391{
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800392 //UNUSED(h_gnss);
393 //UNUSED(flags);
394
yq.wang6a3437f2024-07-27 02:57:20 -0700395 if(h_gnss != qser_h_gnss)
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800396 {
yq.wang6a3437f2024-07-27 02:57:20 -0700397 LOGE("[qser_gnss] h_gnss is error.");
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800398 return QSER_RESULT_FAIL;
399 }
400 return QSER_RESULT_SUCCESS;
401}
402
403int qser_Gnss_Server_Configuration(char *host, char *id, char *password)
404{
wangyouqiang7d66fb12024-01-26 19:19:00 +0800405 //UNUSED(host);
406 //UNUSED(id);
407 //UNUSED(password);
408
yq.wang6a3437f2024-07-27 02:57:20 -0700409 if(!inited)
410 {
411 LOGE("[qser_gnss] api not init.");
412 return QSER_RESULT_FAIL;
413 }
414
wangyouqiang7d66fb12024-01-26 19:19:00 +0800415 if(host != NULL)
416 {
417 memcpy(qser_agps_info_save.host, host, QSER_LEN_MAX);
418 }
419
420 if(id != NULL)
421 {
422 memcpy(qser_agps_info_save.id, id, QSER_LEN_MAX);
423 }
424
425 if(password != NULL)
426 {
427 memcpy(qser_agps_info_save.passwd, password, QSER_LEN_MAX);
428 }
429 return QSER_RESULT_SUCCESS;
b.liu4e243dc2023-11-27 11:20:00 +0800430}
431
yq.wang6a3437f2024-07-27 02:57:20 -0700432int qser_Gnss_download_tle()
b.liu5fa9e772023-11-23 18:00:55 +0800433{
yq.wang6a3437f2024-07-27 02:57:20 -0700434 if(!inited)
wangyouqiang7d66fb12024-01-26 19:19:00 +0800435 {
yq.wang6a3437f2024-07-27 02:57:20 -0700436 LOGE("[qser_gnss] api not init.");
wangyouqiang7d66fb12024-01-26 19:19:00 +0800437 return QSER_RESULT_FAIL;
438 }
439 return QSER_RESULT_SUCCESS;
b.liu5fa9e772023-11-23 18:00:55 +0800440}
441
yq.wang6a3437f2024-07-27 02:57:20 -0700442int qser_Gnss_injectEphemeris(uint32_t h_gnss)
443{
444 //UNUSED(h_gnss);
445
446 if(h_gnss != qser_h_gnss)
447 {
448 LOGE("[qser_gnss] h_gnss is error.");
449 return QSER_RESULT_FAIL;
450 }
451 return QSER_RESULT_SUCCESS;
452}
453
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800454int qser_Gnss_Set_Frequency(uint32_t h_gnss, int frequency)
455{
456 //UNUSED(h_gnss);
457 //UNUSED(frequency);
458
yq.wang6a3437f2024-07-27 02:57:20 -0700459 if(h_gnss != qser_h_gnss)
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800460 {
yq.wang6a3437f2024-07-27 02:57:20 -0700461 LOGE("[qser_gnss] h_gnss is error.");
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800462 return QSER_RESULT_FAIL;
463 }
464
465 if(frequency != 1 && frequency != 2 && frequency != 5)
466 {
467 LOGE("[qser_gnss] frequency out of range.");
468 return QSER_RESULT_FAIL;
469 }
470
liuyanga812f1b2024-07-25 17:49:14 +0800471 gnss_err_enum ret = GNSS_ERR_UNKNOWN;
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800472 char param_buf[32] = {0};
473 int length = 0;
yq.wang6a3437f2024-07-27 02:57:20 -0700474 length = snprintf(param_buf, 32, "$FREQCFG,%d", frequency);
475 ret = mbtk_gnss_setting(param_buf, QSER_GNSS_TIMEOUT);
476 if(ret != GNSS_ERR_OK)
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800477 {
yq.wang5c647e02024-08-10 00:01:11 -0700478 LOGE("[qser_gnss] mbtk_gnss_setting fail.ret = [%d]", ret);
wangyouqiang3d09b4d2024-01-04 13:50:51 +0800479 return QSER_RESULT_FAIL;
480 }
481 return QSER_RESULT_SUCCESS;
482}
483/**********************************API***********************************/
484
485