blob: 37b307479dadd41d496e8298951fe62adb65720d [file] [log] [blame]
b.liud440f9f2025-04-18 10:44:31 +08001#include <time.h>
2#include <pthread.h>
3#include <stdio.h>
4#include <stdlib.h>
5#include <string.h>
6
7#include "lynq_gnss.h"
8
9#define QSER_RESULT_SUCCESS 0
10#define QSER_RESULT_FAIL -1
11#define QSER_GNSS_TIMEOUT 5
12#define QSER_AGNSS_DOWNLOAD_TIMEPUT 60
13#define QSER_AGNSS_INJECT_TIMEOUT 20
14
15/**********************************VARIABLE***********************************/
16static bool inited = FALSE;
17static uint32_t qser_h_gnss = 0x5F6F7F8F;
18gnss_handler_func_t qser_gnss_callback = NULL;
19static time_t qser_gnss_time = 0;
20qser_agps_info qser_agps_info_save = {0};
21gnss_async_func_t qser_gnss_async_callback = NULL;
22
23extern long timezone;
24/**********************************VARIABLE***********************************/
25
26/**********************************FUNC***********************************/
27static void qser_gnss_async_set_cb(gnss_async_func_t cb)
28{
29 qser_gnss_async_callback = cb;
30}
31
32static gnss_async_func_t qser_gnss_async_get_cb(void)
33{
34 return qser_gnss_async_callback;
35}
36
37
38static time_t qser_get_timestamp(char *time)
39{
40 char tmp_char[4] = {0};
41 struct tm* tmp_time = (struct tm*)malloc(sizeof(struct tm));
42
43 memset(tmp_time, 0, sizeof(struct tm));
44 memset(tmp_char, 0, sizeof(tmp_char));
45 memcpy(tmp_char, &time[4], 2);
46 tmp_time->tm_sec = atoi(tmp_char);
47 memcpy(tmp_char, &time[2], 2);
48 tmp_time->tm_min = atoi(tmp_char);
49 memcpy(tmp_char, &time[0], 2);
50 tmp_time->tm_hour = atoi(tmp_char);
51 memcpy(tmp_char, &time[6], 2);
52 tmp_time->tm_mday = atoi(tmp_char);
53 memcpy(tmp_char, &time[8], 2);
54 tmp_time->tm_mon = atoi(tmp_char) - 1;
55 memcpy(tmp_char, &time[10], 2);
56 tmp_time->tm_year = 100 + atoi(tmp_char);
57
58 time_t _t = mktime(tmp_time);//按当地时区解析tmp_time
59 //gnss_log("timestamp: %ld\n",_t);
60 tzset(); // 自动设置本地时区
61 _t = _t - timezone;
62 //gnss_log("timestamp: %ld\n",_t);
63
64 free(tmp_time);
65 return _t;
66}
67
68static time_t qser_get_gnss_time_sec(const void *data, int data_len)
69{
70 int i = 0, num = 0;
71 const char *nmea = (const char *)data;
72 char time[15] = {0};
73 char *check_state = NULL;
74
75 //$GNRMC,024142.000,A,3039.364421,N,10403.417935,E,0.051,0.00,030124,,E,A*00
76 check_state = strstr(nmea, "RMC");
77 if(check_state != NULL)
78 {
79 for(i = 0; i < data_len; i++)
80 {
81 if(check_state[i] == ',')
82 {
83 num++;
84 i++;
85 if(num == 1)//get time
86 {
87 if(check_state[i] >= '0' && check_state[i] <= '9')
88 {
89 memcpy(time, check_state + i, 6);
90 //LOGE("[qser_gnss] %s.", time);
91 }
92 else
93 {
94 qser_gnss_time = 0;
95 return qser_gnss_time;
96 }
97 }
98 else if(num == 9)//get date
99 {
100 if(check_state[i] >= '0' && check_state[i] <= '9')
101 {
102 memcpy(time + 6, check_state + i, 6);
103 //LOGE("[qser_gnss] %s.", time);
104 break;
105 }
106 else
107 {
108 qser_gnss_time = 0;
109 return qser_gnss_time;
110 }
111 }
112 else if(num > 9)
113 {
114 qser_gnss_time = 0;
115 return qser_gnss_time;
116 }
117 }
118 }
119
120 qser_gnss_time = qser_get_timestamp(time);
121 }
122
123 return qser_gnss_time;
124}
125
126static void* gnss_async_thread(void* arg)
127{
128 qser_gnss_error_e state = QSER_GNSS_ERROR_SUCCESS;
129 gnss_async_func_t cb = qser_gnss_async_get_cb();
130 int ret = qser_Gnss_Start(qser_h_gnss);
131 if(ret != QSER_RESULT_SUCCESS)
132 {
133 LOGE("[qser_gnss] gnss_async_thread() fail.");
134 state = QSER_GNSS_ERROR_FAIL;
135 }
136
137 if(cb != NULL)
138 {
139 cb(state);
140 }
141 return NULL;
142}
143
144static void gnss_callback(uint32 ind_type, const void* data, uint32 data_len)
145{
146 if(data == NULL || data_len <= 0)
147 {
148 LOGE("[qser_gnss] data is NULL.");
149 return;
150 }
151
152 if(qser_gnss_callback == NULL)
153 {
154 //LOGE("[qser_gnss] qser_gnss_callback is NULL.");
155 return;
156 }
157
158 if(ind_type == MBTK_GNSS_IND_LOCATION) {
159 if(data_len != sizeof(mbtk_gnss_location_info_t))
160 {
161 LOGE("[qser_gnss] data size error");
162 return;
163 }
164 mbtk_gnss_location_info_t *locl_info = (mbtk_gnss_location_info_t *)data;
165 mopen_location_info_t qser_locl_info;
166 memset(&qser_locl_info, 0x0, sizeof(mopen_location_info_t));
167 qser_locl_info.latitude = locl_info->latitude;
168 qser_locl_info.longitude = locl_info->longitude;
169 qser_locl_info.altitude = locl_info->altitude;
170 qser_locl_info.speed = locl_info->speed;
171 qser_locl_info.bearing = locl_info->bearing;
172 qser_locl_info.timestamp = locl_info->timestamp;
173 qser_gnss_callback(NULL, E_MT_LOC_MSG_ID_LOCATION_INFO, (void *)(&qser_locl_info), NULL);
174 } else if(ind_type == MBTK_GNSS_IND_NMEA) {
175 mopen_gnss_nmea_info_t qser_nmea = {0};
176 memset(&qser_nmea, 0x0, sizeof(mopen_gnss_nmea_info_t));
177 qser_nmea.length = data_len;
178 memcpy(qser_nmea.nmea, (char *)data, data_len);
179 qser_nmea.timestamp = qser_get_gnss_time_sec(data, data_len);
180 qser_gnss_callback(NULL, E_MT_LOC_MSG_ID_NMEA_INFO, (void *)(&qser_nmea), NULL);
181 } else {
182 printf("Unknown IND : %d\n", ind_type);
183 }
184}
185
186
187/**********************************FUNC***********************************/
188
189/**********************************API***********************************/
190int qser_Gnss_Init (uint32_t *h_gnss)
191{
192 //UNUSED(h_gnss);
193 gnss_err_enum ret = GNSS_ERR_UNKNOWN;
194
195 if(!inited)
196 {
197 ret = mbtk_gnss_init(gnss_callback);
198 if(ret == GNSS_ERR_OK)
199 {
200 ret = mbtk_gnss_ind_set(MBTK_GNSS_IND_NMEA, QSER_GNSS_TIMEOUT);
201 if(ret == GNSS_ERR_OK)
202 {
203 inited = TRUE;
204 }
205 else
206 {
207 LOGE("[qser_gnss] init mbtk_gnss_ind_set() fail.ret = [%d]", ret);
208 return QSER_RESULT_FAIL;
209 }
210 }
211 else
212 {
213 LOGE("[qser_gnss] mbtk_gnss_init() fail.ret = [%d]", ret);
214 return QSER_RESULT_FAIL;
215 }
216 }
217 *h_gnss = qser_h_gnss;
218
219 return QSER_RESULT_SUCCESS;
220}
221
222int qser_Gnss_Deinit (uint32_t h_gnss)
223{
224 //UNUSED(h_gnss);
225 if(h_gnss != qser_h_gnss)
226 {
227 LOGE("[qser_gnss] h_gnss is error.");
228 return QSER_RESULT_FAIL;
229 }
230
231 gnss_err_enum ret = GNSS_ERR_UNKNOWN;
232
233 if(inited)
234 {
235 ret = mbtk_gnss_deinit();
236 if(ret == GNSS_ERR_OK)
237 {
238 inited = FALSE;
239 }
240 else
241 {
242 LOGE("[qser_gnss] mbtk_gnss_init() fail.ret = [%d]", ret);
243 return QSER_RESULT_FAIL;
244 }
245 }
246
247 return QSER_RESULT_SUCCESS;
248}
249
250int qser_AddRxIndMsgHandler (gnss_handler_func_t handler_ptr,uint32_t h_gnss)
251{
252 //UNUSED(handler_ptr);
253 //UNUSED(h_gnss);
254 if(h_gnss != qser_h_gnss)
255 {
256 LOGE("[qser_gnss] h_gnss is error.");
257 return QSER_RESULT_FAIL;
258 }
259
260 if(handler_ptr == NULL)
261 {
262 LOGE("[qser_gnss] handler_ptr is NULL.");
263 return QSER_RESULT_FAIL;
264 }
265
266 qser_gnss_callback = handler_ptr;
267 return QSER_RESULT_SUCCESS;
268}
269
270int qser_Set_Indications (uint32_t h_gnss,e_msg_id_t type)
271{
272 //UNUSED(h_gnss);
273 //UNUSED(type);
274 if(h_gnss != qser_h_gnss)
275 {
276 LOGE("[qser_gnss] h_gnss is error.");
277 return QSER_RESULT_FAIL;
278 }
279
280 gnss_err_enum ret = GNSS_ERR_OK;
281 if(type == E_MT_LOC_MSG_ID_LOCATION_INFO)
282 {
283 ret = mbtk_gnss_ind_set(MBTK_GNSS_IND_LOCATION, QSER_GNSS_TIMEOUT);
284 }
285 else if(type == E_MT_LOC_MSG_ID_NMEA_INFO)
286 {
287 ret = mbtk_gnss_ind_set(MBTK_GNSS_IND_NMEA, QSER_GNSS_TIMEOUT);
288 }
289 else
290 {
291 LOGE("[qser_gnss] type is fail.");
292 return QSER_RESULT_FAIL;
293 }
294
295 if(ret != GNSS_ERR_OK)
296 {
297 LOGE("[qser_gnss] mbtk_gnss_ind_set() fail.ret = [%d]", ret);
298 return QSER_RESULT_FAIL;
299 }
300 return QSER_RESULT_SUCCESS;
301}
302
303int qser_Gnss_Set_Async_Callback(gnss_async_func_t cb)
304{
305 qser_gnss_async_set_cb(cb);
306 return QSER_RESULT_SUCCESS;
307}
308
309int qser_Gnss_Start (uint32_t h_gnss)
310{
311 //UNUSED(h_gnss);
312 if(h_gnss != qser_h_gnss)
313 {
314 LOGE("[qser_gnss] h_gnss is error.");
315 return QSER_RESULT_FAIL;
316 }
317
318 gnss_err_enum ret = GNSS_ERR_UNKNOWN;
319
320 ret = mbtk_gnss_open(255, QSER_GNSS_TIMEOUT);
321 if(ret != GNSS_ERR_OK)
322 {
323 LOGE("[qser_gnss] mbtk_gnss_open is error.ret = [%d]", ret);
324 return QSER_RESULT_FAIL;
325 }
326
327 return QSER_RESULT_SUCCESS;
328}
329
330int qser_Gnss_Start_Async(uint32_t h_gnss)
331{
332 //UNUSED(h_gnss);
333 if(h_gnss != qser_h_gnss)
334 {
335 LOGE("[qser_gnss] h_gnss is error.");
336 return QSER_RESULT_FAIL;
337 }
338
339 pthread_attr_t thread_attr;
340 pthread_t gnss_thread_id;
341 pthread_attr_init(&thread_attr);
342 if(pthread_attr_setdetachstate(&thread_attr, PTHREAD_CREATE_DETACHED))
343 {
344 LOGE("[qser_gnss] pthread_attr_setdetachstate() fail.");
345 return QSER_RESULT_FAIL;
346 }
347
348 //memcpy(&qser_data_backup, data_call, sizeof(qser_data_call_s));
349 if(pthread_create(&gnss_thread_id, &thread_attr, gnss_async_thread, NULL))
350 {
351 LOGE("[qser_gnss] pthread_create() fail.");
352 return QSER_RESULT_FAIL;
353 }
354 pthread_attr_destroy(&thread_attr);
355
356 return QSER_RESULT_SUCCESS;
357}
358
359int qser_Gnss_Stop (uint32_t h_gnss)
360{
361 //UNUSED(h_gnss);
362 if(h_gnss != qser_h_gnss)
363 {
364 LOGE("[qser_gnss] h_gnss is error.");
365 return QSER_RESULT_FAIL;
366 }
367
368 gnss_err_enum ret = GNSS_ERR_UNKNOWN;
369 ret = mbtk_gnss_close(QSER_GNSS_TIMEOUT);
370 if(ret != GNSS_ERR_OK)
371 {
372 LOGE("[qser_gnss] mbtk_gnss_close is error.ret = [%d]", ret);
373 return QSER_RESULT_FAIL;
374 }
375
376 return QSER_RESULT_SUCCESS;
377}
378
379int qser_Gnss_InjectTime (uint32_t h_gnss,LYNQ_INJECT_TIME_INTO_T *time_info)
380{
381 //UNUSED(h_gnss);
382 UNUSED(time_info);
383
384 if(h_gnss != qser_h_gnss)
385 {
386 LOGE("[qser_gnss] h_gnss is error.");
387 return QSER_RESULT_FAIL;
388 }
389 return QSER_RESULT_SUCCESS;
390}
391
392int qser_Gnss_Delete_Aiding_Data (uint32_t h_gnss,DELETE_AIDING_DATA_TYPE_T flags)
393{
394 //UNUSED(h_gnss);
395 //UNUSED(flags);
396
397 if(h_gnss != qser_h_gnss)
398 {
399 LOGE("[qser_gnss] h_gnss is error.");
400 return QSER_RESULT_FAIL;
401 }
402 return QSER_RESULT_SUCCESS;
403}
404
405int qser_Gnss_Server_Configuration(char *host, char *id, char *password)
406{
407 //UNUSED(host);
408 //UNUSED(id);
409 //UNUSED(password);
410
411 if(!inited)
412 {
413 LOGE("[qser_gnss] api not init.");
414 return QSER_RESULT_FAIL;
415 }
416
417 memset(qser_agps_info_save.host, 0x0, QSER_LEN_MAX);
418 if(host != NULL && strlen(host) > 0 && strlen(host) < QSER_LEN_MAX)
419 {
420 memcpy(qser_agps_info_save.host, host, strlen(host));
421 }
422
423 memset(qser_agps_info_save.id, 0x0, QSER_LEN_MAX);
424 if(id != NULL && strlen(id) > 0 && strlen(id) < QSER_LEN_MAX)
425 {
426 memcpy(qser_agps_info_save.id, id, strlen(id));
427 }
428
429 memset(qser_agps_info_save.passwd, 0x0, QSER_LEN_MAX);
430 if(password != NULL && strlen(password) > 0 && strlen(password) < QSER_LEN_MAX)
431 {
432 memcpy(qser_agps_info_save.passwd, password, strlen(password));
433 }
434
435 gnss_err_enum ret = GNSS_ERR_UNKNOWN;
436 char write_buff[512] = {0};
437// int write_length = 0;
438 snprintf(write_buff, 512, "$AGPSCFG,%s,%s,%s", strlen(qser_agps_info_save.host) > 0 ? qser_agps_info_save.host : "NULL",
439 strlen(qser_agps_info_save.id) > 0 ? qser_agps_info_save.id : "NULL",
440 strlen(qser_agps_info_save.passwd) > 0 ? qser_agps_info_save.passwd : "NULL");
441 ret = mbtk_gnss_setting(write_buff, QSER_GNSS_TIMEOUT);
442 if(ret != GNSS_ERR_OK)
443 {
444 LOGE("[qser_gnss] mbtk_gnss_setting fail.ret = [%d]", ret);
445 return QSER_RESULT_FAIL;
446 }
447 return QSER_RESULT_SUCCESS;
448}
449
450int qser_Gnss_download_tle()
451{
452 if(!inited)
453 {
454 LOGE("[qser_gnss] api not init.");
455 return QSER_RESULT_FAIL;
456 }
457
458 gnss_err_enum ret = GNSS_ERR_UNKNOWN;
459 ret = mbtk_gnss_eph_download(QSER_AGNSS_DOWNLOAD_TIMEPUT);
460 if(ret != GNSS_ERR_OK)
461 {
462 LOGE("[qser_gnss] mbtk_gnss_eph_download fail.ret = [%d]", ret);
463 return QSER_RESULT_FAIL;
464 }
465 return QSER_RESULT_SUCCESS;
466}
467
468int qser_Gnss_injectEphemeris(uint32_t h_gnss)
469{
470 //UNUSED(h_gnss);
471
472 if(h_gnss != qser_h_gnss)
473 {
474 LOGE("[qser_gnss] h_gnss is error.");
475 return QSER_RESULT_FAIL;
476 }
477
478 gnss_err_enum ret = GNSS_ERR_UNKNOWN;
479 ret = mbtk_gnss_eph_inject(QSER_AGNSS_INJECT_TIMEOUT);
480 if(ret != GNSS_ERR_OK)
481 {
482 LOGE("[qser_gnss] mbtk_gnss_eph_inject fail.ret = [%d]", ret);
483 return QSER_RESULT_FAIL;
484 }
485 return QSER_RESULT_SUCCESS;
486}
487
488int qser_Gnss_Set_Frequency(uint32_t h_gnss, int frequency)
489{
490 //UNUSED(h_gnss);
491 //UNUSED(frequency);
492
493 if(h_gnss != qser_h_gnss)
494 {
495 LOGE("[qser_gnss] h_gnss is error.");
496 return QSER_RESULT_FAIL;
497 }
498
499 if(frequency != 1 && frequency != 2 && frequency != 5)
500 {
501 LOGE("[qser_gnss] frequency out of range.");
502 return QSER_RESULT_FAIL;
503 }
504
505 gnss_err_enum ret = GNSS_ERR_UNKNOWN;
506 char param_buf[32] = {0};
507// int length = 0;
508 snprintf(param_buf, 32, "$FREQCFG,%d", frequency);
509 ret = mbtk_gnss_setting(param_buf, QSER_GNSS_TIMEOUT);
510 if(ret != GNSS_ERR_OK)
511 {
512 LOGE("[qser_gnss] mbtk_gnss_setting fail.ret = [%d]", ret);
513 return QSER_RESULT_FAIL;
514 }
515 return QSER_RESULT_SUCCESS;
516}
517/**********************************API***********************************/
518
519