blob: 2ae29c17a98f56616b3f4cce9de214df2a1ee91c [file] [log] [blame]
b.liuf9fbfa12024-06-14 15:53:59 +08001/*
2* gnss_hd8122.c
3*
4* HD8122 GNSS source.
5*
6*/
7/******************************************************************************
8
9 EDIT HISTORY FOR FILE
10
11 WHEN WHO WHAT,WHERE,WHY
12-------- -------- -------------------------------------------------------
132024/6/14 LiuBin Initial version
14
15******************************************************************************/
16#include <stdio.h>
17#include <stdlib.h>
18#include <unistd.h>
19#include <errno.h>
20#include <fcntl.h>
b.liu778645e2024-06-21 16:47:42 +080021#include <pthread.h>
b.liuf9fbfa12024-06-14 15:53:59 +080022
23#include "mbtk_log.h"
24#include "mbtk_type.h"
25#include "mbtk_gpio.h"
b.liu778645e2024-06-21 16:47:42 +080026#include "mbtk_utils.h"
b.liuf9fbfa12024-06-14 15:53:59 +080027#include "gnss_utils.h"
28#include "gnss_hd8122.h"
b.liudbc3f4b2024-06-25 18:22:24 +080029#include "hd8122_dl/hd8040_upgrade.h"
b.liuf9fbfa12024-06-14 15:53:59 +080030
31#define UART_BITRATE_NMEA_DEF_FW 115200 // Default bitrate.
32#define GNSS_POWER_GPIO 43
b.liu5f950c52024-06-15 20:13:12 +080033#define GNSS_SET_TIMEOUT 3000 // 3s
34#define GNSS_PACK_BUFF_SIZE 1024
b.liud0ba7152024-06-19 14:47:21 +080035#define GNSS_MSG_NUM_MAX 30
b.liudbc3f4b2024-06-25 18:22:24 +080036#define READ_LEN_MAX 1024 //BOOT_UPGRADE_BUFF_MAX_1
b.liu5f950c52024-06-15 20:13:12 +080037
b.liuf9fbfa12024-06-14 15:53:59 +080038
39static pthread_cond_t read_cond;
40static pthread_mutex_t read_mutex;
b.liud0ba7152024-06-19 14:47:21 +080041static bool setting_waitting = FALSE;
b.liu5f950c52024-06-15 20:13:12 +080042static bool setting_busy = FALSE;
43static void *gnss_set_rsp_ptr = NULL;
44static gnss_err_enum gnss_set_result = GNSS_ERR_OK;
b.liud0ba7152024-06-19 14:47:21 +080045static hd8122_msg_id_t msg_array[GNSS_MSG_NUM_MAX];
b.liuf9fbfa12024-06-14 15:53:59 +080046
b.liu5f950c52024-06-15 20:13:12 +080047int gnss_write(int fd, const void *data, int data_len);
b.liudbc3f4b2024-06-25 18:22:24 +080048int OpenUart(char* UART_DEV);
49int uart_close(int fd);
50int fw_update_boot(int uart_fd, uint8_t *data, uint32_t len);
b.liu5f950c52024-06-15 20:13:12 +080051
b.liudbc3f4b2024-06-25 18:22:24 +080052static uint16 fletcher16(const uint8_t* data, int data_len)
53{
b.liud0ba7152024-06-19 14:47:21 +080054 uint32_t sum1 = 0;
55 uint32_t sum2 = 0;
b.liu5f950c52024-06-15 20:13:12 +080056 int index;
57
b.liudbc3f4b2024-06-25 18:22:24 +080058 for (index = 0; index < data_len; ++index )
59 {
b.liud0ba7152024-06-19 14:47:21 +080060 sum1 += data[index];
61 sum2 += sum1;
b.liu5f950c52024-06-15 20:13:12 +080062 }
63
b.liud0ba7152024-06-19 14:47:21 +080064 return ((0xFF & sum2) << 8) | (0xFF & sum1);
b.liu5f950c52024-06-15 20:13:12 +080065}
66
67static void gnss_set_timer_cb(int signo)
68{
b.liudbc3f4b2024-06-25 18:22:24 +080069 if(setting_busy)
70 {
b.liu5f950c52024-06-15 20:13:12 +080071 pthread_mutex_lock(&read_mutex);
72 pthread_cond_signal(&read_cond);
73 pthread_mutex_unlock(&read_mutex);
74 gnss_set_result = GNSS_ERR_TIMEOUT;
75 }
76 return;
77}
78
b.liud0ba7152024-06-19 14:47:21 +080079static void msg_init()
80{
b.liu778645e2024-06-21 16:47:42 +080081 unsigned int i = 0;
b.liudbc3f4b2024-06-25 18:22:24 +080082 while(i < ARRAY_SIZE(msg_array))
83 {
b.liud0ba7152024-06-19 14:47:21 +080084 msg_array[i].enable = FALSE;
85 i++;
86 }
87}
88
b.liud0ba7152024-06-19 14:47:21 +080089static int msg_insert(uint8 gid, uint8 sid)
90{
b.liu778645e2024-06-21 16:47:42 +080091 unsigned int i = 0;
b.liudbc3f4b2024-06-25 18:22:24 +080092 while(i < ARRAY_SIZE(msg_array))
93 {
b.liud0ba7152024-06-19 14:47:21 +080094 if(!msg_array[i].enable)
95 break;
96 i++;
97 }
98
b.liudbc3f4b2024-06-25 18:22:24 +080099 if(i == ARRAY_SIZE(msg_array))
100 {
b.liud0ba7152024-06-19 14:47:21 +0800101 LOGE("Msg full : %d", i);
102 return -1;
b.liudbc3f4b2024-06-25 18:22:24 +0800103 }
104 else
105 {
b.liud0ba7152024-06-19 14:47:21 +0800106 msg_array[i].enable = TRUE;
107 msg_array[i].gid = gid;
108 msg_array[i].sid = sid;
109 return 0;
110 }
111}
112
113static int msg_find(uint8 gid, uint8 sid)
114{
b.liu778645e2024-06-21 16:47:42 +0800115 unsigned int i = 0;
b.liudbc3f4b2024-06-25 18:22:24 +0800116 while(i < ARRAY_SIZE(msg_array))
117 {
b.liud0ba7152024-06-19 14:47:21 +0800118 if(msg_array[i].enable && gid == msg_array[i].gid && sid == msg_array[i].sid)
119 break;
120 i++;
121 }
122
b.liudbc3f4b2024-06-25 18:22:24 +0800123 if(i == ARRAY_SIZE(msg_array))
124 {
b.liud0ba7152024-06-19 14:47:21 +0800125 LOGE("No found %d - %d", gid, sid);
126 return -1;
b.liudbc3f4b2024-06-25 18:22:24 +0800127 }
128 else
129 {
b.liud0ba7152024-06-19 14:47:21 +0800130 return i;
131 }
132}
133
134static int msg_remove(uint8 gid, uint8 sid)
135{
136 int i = msg_find(gid, sid);
b.liudbc3f4b2024-06-25 18:22:24 +0800137 if(i >= 0)
138 {
b.liud0ba7152024-06-19 14:47:21 +0800139 msg_array[i].enable = FALSE;
140 msg_array[i].gid = 0;
141 msg_array[i].sid = 0;
142 return 0;
b.liudbc3f4b2024-06-25 18:22:24 +0800143 }
144 else
145 {
b.liud0ba7152024-06-19 14:47:21 +0800146 return -1;
147 }
148}
149
150static int msg_count()
151{
b.liu778645e2024-06-21 16:47:42 +0800152 unsigned int i = 0;
b.liud0ba7152024-06-19 14:47:21 +0800153 int count = 0;
b.liudbc3f4b2024-06-25 18:22:24 +0800154 while(i < ARRAY_SIZE(msg_array))
155 {
b.liud0ba7152024-06-19 14:47:21 +0800156 if(msg_array[i].enable)
157 count++;
158 i++;
159 }
160 return count;
161}
b.liu5f950c52024-06-15 20:13:12 +0800162
b.liudbc3f4b2024-06-25 18:22:24 +0800163static uint32_t read_bin_file(uint8_t *path, uint8_t *buff)
164{
165 int fp = -1;
166 int ret = 0;
167 int i = 0;
168 int size = 0;
169
170 if (NULL == path || NULL == buff)
171 {
172 LOGE("ARG error");
173 return 0;
174 }
175
176 fp = open((char *)path, O_RDONLY);
177 if(fp < 0)
178 {
179 LOGE( "open file failed ! errno is %d", errno);
180 return 0;
181 }
182
183 size = lseek(fp, 0x00, SEEK_END);
184 if(size <= 0)
185 {
186 LOGE( "file is empty.");
187 return 0;
188 }
189
190 LOGD( "file size is:%d", size);
191 lseek(fp, 0x00, SEEK_SET);
192 while(1)
193 {
194 ret = read(fp, buff, READ_LEN_MAX);
195 i += ret;
196 if(ret == READ_LEN_MAX)
197 {
198 buff += READ_LEN_MAX;
199 }
200 else
201 {
202 break;
203 }
204 }
205
206 LOGD("file size is:%d,i:%d", size, i);
207 close(fp);
208 if(size != i)
209 {
210 return 0;
211 }
212 return size;
213}
214
215
b.liu5f950c52024-06-15 20:13:12 +0800216static int pack_create(hd8122_id_type_enum id_type, uint8 id, uint16 data_len, const uint8 *data, uint8 *pack, int pack_len)
217{
b.liudbc3f4b2024-06-25 18:22:24 +0800218 if(pack == NULL || pack_len < HD8122_PACK_LEN_MIN)
219 {
b.liu5f950c52024-06-15 20:13:12 +0800220 return -1;
221 }
222 memset(pack, 0, pack_len);
223 uint8 *data_ptr = pack;
224 data_ptr += uint16_2_byte(HD8122_PACK_HEAD, data_ptr, false);
225 *data_ptr++ = (uint8)id_type;
226 *data_ptr++ = id;
227 data_ptr += uint16_2_byte(data_len, data_ptr, false);
b.liudbc3f4b2024-06-25 18:22:24 +0800228 if(data_len > 0)
229 {
b.liu5f950c52024-06-15 20:13:12 +0800230 memcpy(data_ptr, data, data_len);
231 data_ptr += data_len;
232 }
233 data_ptr += uint16_2_byte(fletcher16(pack + 2, 4 + data_len), data_ptr, false);
234 return (data_ptr - pack);
235}
236
b.liud0ba7152024-06-19 14:47:21 +0800237// f1 d9 05 01 02 00 06 01 0f 38
238// or
239// f1 d9 05 00 02 00 06 01 0f 38
240static int msg_array_change(const uint8 *pack, int pack_len, hd8122_id_ack_enum *ack_nak)
241{
b.liudbc3f4b2024-06-25 18:22:24 +0800242 if(pack_len == 0 || pack_len % 10)
243 {
b.liud0ba7152024-06-19 14:47:21 +0800244 LOGE("pack_len(%d) error.", pack_len);
245 return -1;
246 }
247 int count = pack_len / 10;
248 int i = 0;
b.liudbc3f4b2024-06-25 18:22:24 +0800249 while(i < count)
250 {
b.liu778645e2024-06-21 16:47:42 +0800251 const uint8 *ptr = pack + i * 10;
b.liudbc3f4b2024-06-25 18:22:24 +0800252 if(ptr[0] != 0xf1 || ptr[1] != 0xd9)
253 {
b.liud0ba7152024-06-19 14:47:21 +0800254 LOGE("Pack head error : %02x %02x", ptr[0], ptr[1]);
255 return -1;
256 }
257
b.liudbc3f4b2024-06-25 18:22:24 +0800258 if(ptr[2] != 0x05)
259 {
b.liud0ba7152024-06-19 14:47:21 +0800260 LOGE("Type not 0x05 : %02x", ptr[2]);
261 return -1;
262 }
263
264 int index = msg_find(ptr[6], ptr[7]);
b.liudbc3f4b2024-06-25 18:22:24 +0800265 if(index >= 0)
266 {
267 if(ptr[3] == 0x01)
268 {
b.liud0ba7152024-06-19 14:47:21 +0800269 msg_array[index].ack_nak = HD8122_ID_ACK_ACK;
b.liudbc3f4b2024-06-25 18:22:24 +0800270 }
271 else if(ptr[3] == 0x00)
272 {
b.liud0ba7152024-06-19 14:47:21 +0800273 msg_array[index].ack_nak = HD8122_ID_ACK_NAK;
274
275 // There is a nak as a failure.
276 *ack_nak = HD8122_ID_ACK_NAK;
b.liudbc3f4b2024-06-25 18:22:24 +0800277 }
278 else
279 {
b.liud0ba7152024-06-19 14:47:21 +0800280 LOGE("ID not 0x00 or 0x01 : %02x", ptr[3]);
281 return -1;
282 }
283
284 msg_array[index].enable = FALSE;
b.liudbc3f4b2024-06-25 18:22:24 +0800285 }
286 else
287 {
b.liud0ba7152024-06-19 14:47:21 +0800288 LOGE("Unknown gid - %d, sid - %d", ptr[6], ptr[7]);
289 return -1;
290 }
291 i++;
292 }
293
294 return 0;
295}
296
b.liudbc3f4b2024-06-25 18:22:24 +0800297static void gnss_cmd_rsp_process(const void *data, int data_len)
298{
b.liu5f950c52024-06-15 20:13:12 +0800299 const char *ptr = (const char*)data;
300 log_hex("RSP", data, data_len);
b.liu5f950c52024-06-15 20:13:12 +0800301
b.liud0ba7152024-06-19 14:47:21 +0800302 hd8122_id_ack_enum ack_nak = HD8122_ID_ACK_ACK;
b.liudbc3f4b2024-06-25 18:22:24 +0800303 if(!msg_array_change((const uint8*)data, data_len, &ack_nak))
304 {
b.liud0ba7152024-06-19 14:47:21 +0800305 if(setting_waitting && msg_count() == 0)
306 {
b.liudbc3f4b2024-06-25 18:22:24 +0800307 if(ack_nak == HD8122_ID_ACK_ACK)
308 {
b.liud0ba7152024-06-19 14:47:21 +0800309 gnss_set_result = GNSS_ERR_OK;
b.liudbc3f4b2024-06-25 18:22:24 +0800310 }
311 else
312 {
b.liud0ba7152024-06-19 14:47:21 +0800313 gnss_set_result = GNSS_ERR_UNKNOWN;
314 }
315
316 mbtk_timer_clear();
317
318 pthread_mutex_lock(&read_mutex);
319 pthread_cond_signal(&read_cond);
320 pthread_mutex_unlock(&read_mutex);
321 setting_waitting = FALSE;
322 }
b.liudbc3f4b2024-06-25 18:22:24 +0800323 }
324 else
325 {
b.liud0ba7152024-06-19 14:47:21 +0800326 LOGW("Unknown rsp data.");
b.liu5f950c52024-06-15 20:13:12 +0800327 }
328}
329
b.liud0ba7152024-06-19 14:47:21 +0800330static gnss_err_enum gnss_8122_reset(int fd, uint8 reset)
b.liu5f950c52024-06-15 20:13:12 +0800331{
332 uint8 buff[GNSS_PACK_BUFF_SIZE];
333 LOGD("RESET");
334 int len = pack_create(HD8122_ID_TYPE_CFG, HD8122_ID_CFG_SIMPLERST, 1, (uint8*)(&reset), buff, sizeof(buff));
b.liudbc3f4b2024-06-25 18:22:24 +0800335 if(len <= 0)
336 {
b.liu5f950c52024-06-15 20:13:12 +0800337 LOGE("pack_create() fail.");
338 return GNSS_ERR_ARG;
339 }
340 log_hex("PACK", buff, len);
341 gnss_write(fd, buff, len);
342 return GNSS_ERR_OK;
343}
b.liuf9fbfa12024-06-14 15:53:59 +0800344
b.liud0ba7152024-06-19 14:47:21 +0800345static gnss_err_enum gnss_8122_syscfg(int fd, uint32 mode)
346{
347 uint8 buff[GNSS_PACK_BUFF_SIZE];
348 LOGD("SYSCFG");
349 //uint8 mode_str[4];
350 //uint32_2_byte(mode, mode_str, TRUE);
351 int len = pack_create(HD8122_ID_TYPE_CFG, HD8122_ID_CFG_NAVSAT, 4, (uint8*)(&mode), buff, sizeof(buff));
b.liudbc3f4b2024-06-25 18:22:24 +0800352 if(len <= 0)
353 {
b.liud0ba7152024-06-19 14:47:21 +0800354 LOGE("pack_create() fail.");
355 return GNSS_ERR_ARG;
356 }
357 log_hex("PACK", buff, len);
358 gnss_write(fd, buff, len);
359 msg_insert(HD8122_ID_TYPE_CFG, HD8122_ID_CFG_NAVSAT);
360 return GNSS_ERR_OK;
361}
362
363static gnss_err_enum gnss_8122_msgcfg(int fd, uint8 type, uint8 id, uint8 period)
364{
365 uint8 buff[GNSS_PACK_BUFF_SIZE];
366 LOGD("MSGCFG");
367 uint8 data[3];
368 data[0] = type;
369 data[1] = id;
370 data[2] = period;
371 int len = pack_create(HD8122_ID_TYPE_CFG, HD8122_ID_CFG_MSG, 3, data, buff, sizeof(buff));
b.liudbc3f4b2024-06-25 18:22:24 +0800372 if(len <= 0)
373 {
b.liud0ba7152024-06-19 14:47:21 +0800374 LOGE("pack_create() fail.");
375 return GNSS_ERR_ARG;
376 }
377 log_hex("PACK", buff, len);
378 gnss_write(fd, buff, len);
379 msg_insert(HD8122_ID_TYPE_CFG, HD8122_ID_CFG_MSG);
380 return GNSS_ERR_OK;
381}
382
383static gnss_err_enum gnss_8122_minel(int fd, float *elev)
384{
385 uint8 buff[GNSS_PACK_BUFF_SIZE];
386 LOGD("ELEV");
387 //uint8 elev_buff[4];
388 //uint32_2_byte((uint32)elev, elev_buff, TRUE);
389 int len = pack_create(HD8122_ID_TYPE_CFG, HD8122_ID_CFG_ELEV, 8, (uint8*)elev, buff, sizeof(buff));
b.liudbc3f4b2024-06-25 18:22:24 +0800390 if(len <= 0)
391 {
b.liud0ba7152024-06-19 14:47:21 +0800392 LOGE("pack_create() fail.");
393 return GNSS_ERR_ARG;
394 }
395 log_hex("PACK", buff, len);
396 gnss_write(fd, buff, len);
397 return GNSS_ERR_OK;
398}
399
400static gnss_err_enum gnss_8122_nmeaver(int fd, uint8 ver)
401{
402 uint8 buff[GNSS_PACK_BUFF_SIZE];
403 LOGD("NMEA-VER");
404 int len = pack_create(HD8122_ID_TYPE_CFG, HD8122_ID_CFG_NMEAVER, 1, (uint8*)(&ver), buff, sizeof(buff));
b.liudbc3f4b2024-06-25 18:22:24 +0800405 if(len <= 0)
406 {
b.liud0ba7152024-06-19 14:47:21 +0800407 LOGE("pack_create() fail.");
408 return GNSS_ERR_ARG;
409 }
410 log_hex("PACK", buff, len);
411 gnss_write(fd, buff, len);
412 return GNSS_ERR_OK;
413}
414
b.liuf9fbfa12024-06-14 15:53:59 +0800415int gnss_8122_dev_open()
416{
417 return mbtk_gpio_value_set(GNSS_POWER_GPIO, MBTK_GPIO_DIRECT_OUT, 1);
418}
419
420int gnss_8122_dev_close()
421{
422 return mbtk_gpio_value_set(GNSS_POWER_GPIO, MBTK_GPIO_DIRECT_OUT, 0);
423}
424
425int gnss_8122_open(const char *dev)
426{
427 pthread_mutex_init(&read_mutex, NULL);
428 pthread_cond_init(&read_cond, NULL);
429 return gnss_port_open(dev, O_RDWR | O_NONBLOCK | O_NOCTTY, UART_BITRATE_NMEA_DEF_FW, TRUE);
430}
431
432int gnss_8122_close(int fd)
433{
434 pthread_mutex_destroy(&read_mutex);
435 pthread_cond_destroy(&read_cond);
436 return gnss_port_close(fd);
437}
438
b.liudbc3f4b2024-06-25 18:22:24 +0800439int gnss_8122_fw_dl(int fd, const char *fw_name, const char *dev)
b.liuf9fbfa12024-06-14 15:53:59 +0800440{
b.liudbc3f4b2024-06-25 18:22:24 +0800441 int uart_fd = OpenUart(dev);//PORT_NAME234
442 if (uart_fd < 0)
443 {
444 LOGE("open uart failed %d[%d]", uart_fd, errno);
445 return GNSS_ERR_OPEN_DEV;
446 }
447
448 uint8_t *g_bin_buff = (uint8_t*)malloc(500*1024);
449 if(g_bin_buff == NULL) {
450 LOGE("malloc() fail : %d", errno);
451 return GNSS_ERR_UNKNOWN;
452 }
453 memset(g_bin_buff, 0, 500*1024);
454 uint32_t len = read_bin_file(fw_name, g_bin_buff);
455 if (len <= 0)
456 {
457 LOGE("Read file failed ,len = %d", len);
458 return GNSS_ERR_DL_FW;
459 }
460 if(gnss_8122_dev_open()) {
461 LOGE("open gnss device fail:%d", errno);
462 return GNSS_ERR_DL_FW;
463 }
464 int ret = fw_update_boot(uart_fd, g_bin_buff, len);
465 free(g_bin_buff);
466 if (ret < 0)
467 {
468 LOGE("fw_update_boot() fail : %d", ret);
469 return GNSS_ERR_DL_FW;
470 }
471 uart_close(uart_fd);
472 if(ret == HDBD_UPG_SUCESS)
473 {
474 LOGD("upgrade sucess!");
475 return GNSS_ERR_OK;
476 }
477 else
478 {
479 LOGD("upgrade FAIL, fail style:%d", ret);
480 return GNSS_ERR_DL_FW;
481 }
b.liuf9fbfa12024-06-14 15:53:59 +0800482}
483
b.liu5f950c52024-06-15 20:13:12 +0800484void gnss_8122_set_cb(const void *data, int data_len)
485{
486 const char *buff = (const char*)data;
b.liudbc3f4b2024-06-25 18:22:24 +0800487 if(setting_busy) // Has setting cmd process.
488 {
b.liu5f950c52024-06-15 20:13:12 +0800489 gnss_cmd_rsp_process(data, data_len);
490 }
491}
b.liuf9fbfa12024-06-14 15:53:59 +0800492
493gnss_err_enum gnss_8122_set(int fd, const char *cmd, void *cmd_rsp, int cmd_rsp_len)
494{
b.liudbc3f4b2024-06-25 18:22:24 +0800495 if(setting_busy)
496 {
b.liu5f950c52024-06-15 20:13:12 +0800497 return GNSS_ERR_SET_BUSY;
b.liudbc3f4b2024-06-25 18:22:24 +0800498 }
499 else
500 {
b.liu5f950c52024-06-15 20:13:12 +0800501 bool should_wait_rsp = TRUE;
502 setting_busy = TRUE;
503 gnss_set_rsp_ptr = cmd_rsp;
504 gnss_set_result = GNSS_ERR_OK;
b.liud0ba7152024-06-19 14:47:21 +0800505 msg_init();
b.liu5f950c52024-06-15 20:13:12 +0800506 mbtk_timer_set(gnss_set_timer_cb, GNSS_SET_TIMEOUT);
507
b.liudbc3f4b2024-06-25 18:22:24 +0800508 if(memcmp(cmd, "$RESET", 6) == 0) // $RESET,<mode>
509 {
b.liud0ba7152024-06-19 14:47:21 +0800510 gnss_reset_type_enum mode = (gnss_reset_type_enum)atoi(cmd + 7);
b.liudbc3f4b2024-06-25 18:22:24 +0800511 if(mode == GNSS_RESET_TYPE_HOT)
512 {
b.liud0ba7152024-06-19 14:47:21 +0800513 gnss_set_result = gnss_8122_reset(fd, 3);
b.liudbc3f4b2024-06-25 18:22:24 +0800514 }
515 else if(mode == GNSS_RESET_TYPE_WARM)
516 {
b.liud0ba7152024-06-19 14:47:21 +0800517 gnss_set_result = gnss_8122_reset(fd, 2);
b.liudbc3f4b2024-06-25 18:22:24 +0800518 }
519 else if(mode == GNSS_RESET_TYPE_COLD)
520 {
b.liud0ba7152024-06-19 14:47:21 +0800521 gnss_set_result = gnss_8122_reset(fd, 1);
b.liudbc3f4b2024-06-25 18:22:24 +0800522 }
523 else
524 {
b.liud0ba7152024-06-19 14:47:21 +0800525 gnss_set_result = GNSS_ERR_ARG;
526 goto set_fail;
527 }
b.liudbc3f4b2024-06-25 18:22:24 +0800528 if(gnss_set_result != GNSS_ERR_OK)
529 {
b.liu5f950c52024-06-15 20:13:12 +0800530 goto set_fail;
531 }
532 should_wait_rsp = FALSE;
b.liudbc3f4b2024-06-25 18:22:24 +0800533 }
534 else if(memcmp(cmd, "$SYSCFG", 7) == 0) // $SYSCFG,<mode>
535 {
b.liud0ba7152024-06-19 14:47:21 +0800536 uint32 mode = 0;
537 mode = (uint32)atoi(cmd + 8);
538 uint32 new_mode = 0;
b.liudbc3f4b2024-06-25 18:22:24 +0800539 if(((GNSS_SET_SYSCFG_GPS | GNSS_SET_SYSCFG_BDS | GNSS_SET_SYSCFG_GLO | GNSS_SET_SYSCFG_GAL) & mode) != mode)
540 {
b.liud0ba7152024-06-19 14:47:21 +0800541 gnss_set_result = GNSS_ERR_ARG;
542 goto set_fail;
543 }
544
b.liudbc3f4b2024-06-25 18:22:24 +0800545 if(mode & GNSS_SET_SYSCFG_GPS) // GPS
546 {
b.liud0ba7152024-06-19 14:47:21 +0800547 new_mode |= 0x00000001;
548 }
b.liudbc3f4b2024-06-25 18:22:24 +0800549 if(mode & GNSS_SET_SYSCFG_BDS) // BDS
550 {
b.liud0ba7152024-06-19 14:47:21 +0800551 new_mode |= 0x00000002;
552 }
b.liudbc3f4b2024-06-25 18:22:24 +0800553 if(mode & GNSS_SET_SYSCFG_GLO) // GLO
554 {
b.liud0ba7152024-06-19 14:47:21 +0800555 new_mode |= 0x00000004;
556 }
b.liudbc3f4b2024-06-25 18:22:24 +0800557 if(mode & GNSS_SET_SYSCFG_GAL) // GAL
558 {
b.liud0ba7152024-06-19 14:47:21 +0800559 new_mode |= 0x00000010;
560 }
561
562 gnss_set_result = gnss_8122_syscfg(fd, new_mode);
b.liudbc3f4b2024-06-25 18:22:24 +0800563 if(gnss_set_result != GNSS_ERR_OK)
564 {
b.liud0ba7152024-06-19 14:47:21 +0800565 goto set_fail;
566 }
567 should_wait_rsp = TRUE;
b.liudbc3f4b2024-06-25 18:22:24 +0800568 }
569 else if(memcmp(cmd, "$MSGCFG", 7) == 0) // $MSGCFG,<mode>,<rate>
570 {
b.liud0ba7152024-06-19 14:47:21 +0800571 uint32 mode;
572 int rate;
b.liudbc3f4b2024-06-25 18:22:24 +0800573 if(2 == sscanf(cmd, "$MSGCFG,%d,%d", &mode, &rate))
574 {
b.liud0ba7152024-06-19 14:47:21 +0800575 int time = rate / 1000; // s
b.liudbc3f4b2024-06-25 18:22:24 +0800576 if(time < 0)
577 {
b.liud0ba7152024-06-19 14:47:21 +0800578 gnss_set_result = GNSS_ERR_ARG;
579 goto set_fail;
580 }
581
582 if(((GNSS_SET_MSGCFG_RMC | GNSS_SET_MSGCFG_VTG | GNSS_SET_MSGCFG_GGA | GNSS_SET_MSGCFG_GSA
b.liudbc3f4b2024-06-25 18:22:24 +0800583 | GNSS_SET_MSGCFG_GRS | GNSS_SET_MSGCFG_GSV | GNSS_SET_MSGCFG_GLL | GNSS_SET_MSGCFG_ZDA
584 | GNSS_SET_MSGCFG_GST | GNSS_SET_MSGCFG_TXT) & mode) != mode)
585 {
b.liud0ba7152024-06-19 14:47:21 +0800586 gnss_set_result = GNSS_ERR_ARG;
587 goto set_fail;
588 }
589
b.liudbc3f4b2024-06-25 18:22:24 +0800590 if(mode & GNSS_SET_MSGCFG_RMC)
591 {
b.liud0ba7152024-06-19 14:47:21 +0800592 gnss_set_result = gnss_8122_msgcfg(fd, 0xF8, 0x05, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800593 if(gnss_set_result != GNSS_ERR_OK)
594 {
b.liud0ba7152024-06-19 14:47:21 +0800595 goto set_fail;
596 }
597 }
598
b.liudbc3f4b2024-06-25 18:22:24 +0800599 if(mode & GNSS_SET_MSGCFG_VTG)
600 {
b.liud0ba7152024-06-19 14:47:21 +0800601 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x06, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800602 if(gnss_set_result != GNSS_ERR_OK)
603 {
b.liud0ba7152024-06-19 14:47:21 +0800604 goto set_fail;
605 }
606 }
607
b.liudbc3f4b2024-06-25 18:22:24 +0800608 if(mode & GNSS_SET_MSGCFG_GGA)
609 {
b.liud0ba7152024-06-19 14:47:21 +0800610 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x00, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800611 if(gnss_set_result != GNSS_ERR_OK)
612 {
b.liud0ba7152024-06-19 14:47:21 +0800613 goto set_fail;
614 }
615 }
616
b.liudbc3f4b2024-06-25 18:22:24 +0800617 if(mode & GNSS_SET_MSGCFG_GSA)
618 {
b.liud0ba7152024-06-19 14:47:21 +0800619 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x02, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800620 if(gnss_set_result != GNSS_ERR_OK)
621 {
b.liud0ba7152024-06-19 14:47:21 +0800622 goto set_fail;
623 }
624 }
625
b.liudbc3f4b2024-06-25 18:22:24 +0800626 if(mode & GNSS_SET_MSGCFG_GRS)
627 {
b.liud0ba7152024-06-19 14:47:21 +0800628 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x03, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800629 if(gnss_set_result != GNSS_ERR_OK)
630 {
b.liud0ba7152024-06-19 14:47:21 +0800631 goto set_fail;
632 }
633 }
634
b.liudbc3f4b2024-06-25 18:22:24 +0800635 if(mode & GNSS_SET_MSGCFG_GSV)
636 {
b.liud0ba7152024-06-19 14:47:21 +0800637 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x04, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800638 if(gnss_set_result != GNSS_ERR_OK)
639 {
b.liud0ba7152024-06-19 14:47:21 +0800640 goto set_fail;
641 }
642 }
643
b.liudbc3f4b2024-06-25 18:22:24 +0800644 if(mode & GNSS_SET_MSGCFG_GLL)
645 {
b.liud0ba7152024-06-19 14:47:21 +0800646 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x01, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800647 if(gnss_set_result != GNSS_ERR_OK)
648 {
b.liud0ba7152024-06-19 14:47:21 +0800649 goto set_fail;
650 }
651 }
652
b.liudbc3f4b2024-06-25 18:22:24 +0800653 if(mode & GNSS_SET_MSGCFG_ZDA)
654 {
b.liud0ba7152024-06-19 14:47:21 +0800655 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x07, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800656 if(gnss_set_result != GNSS_ERR_OK)
657 {
b.liud0ba7152024-06-19 14:47:21 +0800658 goto set_fail;
659 }
660 }
661
b.liudbc3f4b2024-06-25 18:22:24 +0800662 if(mode & GNSS_SET_MSGCFG_GST)
663 {
b.liud0ba7152024-06-19 14:47:21 +0800664 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x08, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800665 if(gnss_set_result != GNSS_ERR_OK)
666 {
b.liud0ba7152024-06-19 14:47:21 +0800667 goto set_fail;
668 }
669 }
670
b.liudbc3f4b2024-06-25 18:22:24 +0800671 if(mode & GNSS_SET_MSGCFG_TXT)
672 {
b.liud0ba7152024-06-19 14:47:21 +0800673 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x20, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800674 if(gnss_set_result != GNSS_ERR_OK)
675 {
b.liud0ba7152024-06-19 14:47:21 +0800676 goto set_fail;
677 }
678 }
b.liudbc3f4b2024-06-25 18:22:24 +0800679 }
680 else
681 {
b.liud0ba7152024-06-19 14:47:21 +0800682 gnss_set_result = GNSS_ERR_ARG;
683 goto set_fail;
684 }
685
686 should_wait_rsp = TRUE;
b.liudbc3f4b2024-06-25 18:22:24 +0800687 }
688 else if(memcmp(cmd, "$MINEL", 6) == 0) // $MINEL,<elev>
689 {
b.liud0ba7152024-06-19 14:47:21 +0800690#if 0
691 float elev = 0.0f;
692 elev = (float)atof(cmd + 7);
693// LOGD("ELEV : %f", elev);
694// log_hex("ELEV", &elev, sizeof(double));
b.liudbc3f4b2024-06-25 18:22:24 +0800695 if(elev < -90.0f || elev > 90.0f)
696 {
b.liud0ba7152024-06-19 14:47:21 +0800697 gnss_set_result = GNSS_ERR_ARG;
698 goto set_fail;
699 }
700 float elevs[2];
701 elevs[0] = elev;
702 elevs[1] = elev;
703 gnss_set_result = gnss_8122_minel(fd, elevs);
b.liudbc3f4b2024-06-25 18:22:24 +0800704 if(gnss_set_result != GNSS_ERR_OK)
705 {
b.liud0ba7152024-06-19 14:47:21 +0800706 goto set_fail;
707 }
708 should_wait_rsp = FALSE;
709#else
710 gnss_set_result = GNSS_ERR_UNSUPPORT;
711 goto set_fail;
712#endif
b.liudbc3f4b2024-06-25 18:22:24 +0800713 }
714 else if(memcmp(cmd, "$NMEACFG", 8) == 0) // $NMEACFG,<ver>
715 {
b.liud0ba7152024-06-19 14:47:21 +0800716#if 0
717 gnss_memaver_type_enum version = (gnss_memaver_type_enum)atoi(cmd + 9);
b.liudbc3f4b2024-06-25 18:22:24 +0800718 if(version == GNSS_MEMAVER_TYPE_3_0)
719 {
b.liud0ba7152024-06-19 14:47:21 +0800720 gnss_set_result = gnss_8122_nmeaver(fd, 1);
b.liudbc3f4b2024-06-25 18:22:24 +0800721 }
722 else if(version == GNSS_MEMAVER_TYPE_4_0)
723 {
b.liud0ba7152024-06-19 14:47:21 +0800724 gnss_set_result = gnss_8122_nmeaver(fd, 2);
b.liudbc3f4b2024-06-25 18:22:24 +0800725 }
726 else if(version == GNSS_MEMAVER_TYPE_4_1)
727 {
b.liud0ba7152024-06-19 14:47:21 +0800728 gnss_set_result = gnss_8122_nmeaver(fd, 3);
b.liudbc3f4b2024-06-25 18:22:24 +0800729 }
730 else
731 {
b.liud0ba7152024-06-19 14:47:21 +0800732 gnss_set_result = GNSS_ERR_ARG;
733 goto set_fail;
734 }
b.liudbc3f4b2024-06-25 18:22:24 +0800735 if(gnss_set_result != GNSS_ERR_OK)
736 {
b.liud0ba7152024-06-19 14:47:21 +0800737 goto set_fail;
738 }
739 should_wait_rsp = FALSE;
740#else
741 gnss_set_result = GNSS_ERR_UNSUPPORT;
742 goto set_fail;
743#endif
b.liu5f950c52024-06-15 20:13:12 +0800744 }
745 else
746 {
747 LOGW("Unknown cmd:%s", cmd);
748 gnss_set_result = GNSS_ERR_UNSUPPORT;
749 goto set_fail;
750 }
751
b.liudbc3f4b2024-06-25 18:22:24 +0800752 set_success:
753 if(should_wait_rsp)
754 {
b.liud0ba7152024-06-19 14:47:21 +0800755 setting_waitting = TRUE;
b.liu5f950c52024-06-15 20:13:12 +0800756 pthread_mutex_lock(&read_mutex);
757 pthread_cond_wait(&read_cond, &read_mutex);
758 pthread_mutex_unlock(&read_mutex);
b.liudbc3f4b2024-06-25 18:22:24 +0800759 }
760 else
761 {
b.liu5f950c52024-06-15 20:13:12 +0800762 mbtk_timer_clear();
763 }
764
765 setting_busy = FALSE;
766 return gnss_set_result;
b.liudbc3f4b2024-06-25 18:22:24 +0800767 set_fail:
b.liu5f950c52024-06-15 20:13:12 +0800768 setting_busy = FALSE;
769 mbtk_timer_clear();
770 return gnss_set_result;
771 }
b.liuf9fbfa12024-06-14 15:53:59 +0800772}
773
b.liu5f950c52024-06-15 20:13:12 +0800774