blob: b34b4a43d0e39b2bd8b971c5abcf7be693d4410f [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{
yq.wang5fe6e612024-07-17 01:18:12 -0700417 //return mbtk_gpio_value_set(GNSS_POWER_GPIO, MBTK_GPIO_DIRECT_OUT, 1);
418 system("i2cset -y -f 2 0x31 0x15 0x86");
419 return 0;
b.liuf9fbfa12024-06-14 15:53:59 +0800420}
421
b.liu978f5432024-07-01 18:04:18 +0800422int gnss_8122_dev_close(int fd)
b.liuf9fbfa12024-06-14 15:53:59 +0800423{
yq.wang5fe6e612024-07-17 01:18:12 -0700424 //return mbtk_gpio_value_set(GNSS_POWER_GPIO, MBTK_GPIO_DIRECT_OUT, 0);
425 system("i2cset -y -f 2 0x31 0x15 0x00");
426 return 0;
b.liuf9fbfa12024-06-14 15:53:59 +0800427}
428
429int gnss_8122_open(const char *dev)
430{
431 pthread_mutex_init(&read_mutex, NULL);
432 pthread_cond_init(&read_cond, NULL);
433 return gnss_port_open(dev, O_RDWR | O_NONBLOCK | O_NOCTTY, UART_BITRATE_NMEA_DEF_FW, TRUE);
434}
435
436int gnss_8122_close(int fd)
437{
438 pthread_mutex_destroy(&read_mutex);
439 pthread_cond_destroy(&read_cond);
440 return gnss_port_close(fd);
441}
442
b.liudbc3f4b2024-06-25 18:22:24 +0800443int gnss_8122_fw_dl(int fd, const char *fw_name, const char *dev)
b.liuf9fbfa12024-06-14 15:53:59 +0800444{
b.liudbc3f4b2024-06-25 18:22:24 +0800445 int uart_fd = OpenUart(dev);//PORT_NAME234
446 if (uart_fd < 0)
447 {
448 LOGE("open uart failed %d[%d]", uart_fd, errno);
449 return GNSS_ERR_OPEN_DEV;
450 }
451
452 uint8_t *g_bin_buff = (uint8_t*)malloc(500*1024);
453 if(g_bin_buff == NULL) {
454 LOGE("malloc() fail : %d", errno);
455 return GNSS_ERR_UNKNOWN;
456 }
457 memset(g_bin_buff, 0, 500*1024);
458 uint32_t len = read_bin_file(fw_name, g_bin_buff);
459 if (len <= 0)
460 {
461 LOGE("Read file failed ,len = %d", len);
462 return GNSS_ERR_DL_FW;
463 }
464 if(gnss_8122_dev_open()) {
465 LOGE("open gnss device fail:%d", errno);
466 return GNSS_ERR_DL_FW;
467 }
468 int ret = fw_update_boot(uart_fd, g_bin_buff, len);
469 free(g_bin_buff);
470 if (ret < 0)
471 {
472 LOGE("fw_update_boot() fail : %d", ret);
473 return GNSS_ERR_DL_FW;
474 }
475 uart_close(uart_fd);
476 if(ret == HDBD_UPG_SUCESS)
477 {
478 LOGD("upgrade sucess!");
479 return GNSS_ERR_OK;
480 }
481 else
482 {
483 LOGD("upgrade FAIL, fail style:%d", ret);
484 return GNSS_ERR_DL_FW;
485 }
b.liuf9fbfa12024-06-14 15:53:59 +0800486}
487
b.liu5f950c52024-06-15 20:13:12 +0800488void gnss_8122_set_cb(const void *data, int data_len)
489{
490 const char *buff = (const char*)data;
b.liudbc3f4b2024-06-25 18:22:24 +0800491 if(setting_busy) // Has setting cmd process.
492 {
b.liu5f950c52024-06-15 20:13:12 +0800493 gnss_cmd_rsp_process(data, data_len);
494 }
495}
b.liuf9fbfa12024-06-14 15:53:59 +0800496
497gnss_err_enum gnss_8122_set(int fd, const char *cmd, void *cmd_rsp, int cmd_rsp_len)
498{
b.liudbc3f4b2024-06-25 18:22:24 +0800499 if(setting_busy)
500 {
b.liu5f950c52024-06-15 20:13:12 +0800501 return GNSS_ERR_SET_BUSY;
b.liudbc3f4b2024-06-25 18:22:24 +0800502 }
503 else
504 {
b.liu5f950c52024-06-15 20:13:12 +0800505 bool should_wait_rsp = TRUE;
506 setting_busy = TRUE;
507 gnss_set_rsp_ptr = cmd_rsp;
508 gnss_set_result = GNSS_ERR_OK;
b.liud0ba7152024-06-19 14:47:21 +0800509 msg_init();
b.liu5f950c52024-06-15 20:13:12 +0800510 mbtk_timer_set(gnss_set_timer_cb, GNSS_SET_TIMEOUT);
511
b.liudbc3f4b2024-06-25 18:22:24 +0800512 if(memcmp(cmd, "$RESET", 6) == 0) // $RESET,<mode>
513 {
b.liud0ba7152024-06-19 14:47:21 +0800514 gnss_reset_type_enum mode = (gnss_reset_type_enum)atoi(cmd + 7);
b.liudbc3f4b2024-06-25 18:22:24 +0800515 if(mode == GNSS_RESET_TYPE_HOT)
516 {
b.liud0ba7152024-06-19 14:47:21 +0800517 gnss_set_result = gnss_8122_reset(fd, 3);
b.liudbc3f4b2024-06-25 18:22:24 +0800518 }
519 else if(mode == GNSS_RESET_TYPE_WARM)
520 {
b.liud0ba7152024-06-19 14:47:21 +0800521 gnss_set_result = gnss_8122_reset(fd, 2);
b.liudbc3f4b2024-06-25 18:22:24 +0800522 }
523 else if(mode == GNSS_RESET_TYPE_COLD)
524 {
b.liud0ba7152024-06-19 14:47:21 +0800525 gnss_set_result = gnss_8122_reset(fd, 1);
b.liudbc3f4b2024-06-25 18:22:24 +0800526 }
527 else
528 {
b.liud0ba7152024-06-19 14:47:21 +0800529 gnss_set_result = GNSS_ERR_ARG;
530 goto set_fail;
531 }
b.liudbc3f4b2024-06-25 18:22:24 +0800532 if(gnss_set_result != GNSS_ERR_OK)
533 {
b.liu5f950c52024-06-15 20:13:12 +0800534 goto set_fail;
535 }
536 should_wait_rsp = FALSE;
b.liudbc3f4b2024-06-25 18:22:24 +0800537 }
538 else if(memcmp(cmd, "$SYSCFG", 7) == 0) // $SYSCFG,<mode>
539 {
b.liud0ba7152024-06-19 14:47:21 +0800540 uint32 mode = 0;
541 mode = (uint32)atoi(cmd + 8);
542 uint32 new_mode = 0;
b.liudbc3f4b2024-06-25 18:22:24 +0800543 if(((GNSS_SET_SYSCFG_GPS | GNSS_SET_SYSCFG_BDS | GNSS_SET_SYSCFG_GLO | GNSS_SET_SYSCFG_GAL) & mode) != mode)
544 {
b.liud0ba7152024-06-19 14:47:21 +0800545 gnss_set_result = GNSS_ERR_ARG;
546 goto set_fail;
547 }
548
b.liudbc3f4b2024-06-25 18:22:24 +0800549 if(mode & GNSS_SET_SYSCFG_GPS) // GPS
550 {
b.liud0ba7152024-06-19 14:47:21 +0800551 new_mode |= 0x00000001;
552 }
b.liudbc3f4b2024-06-25 18:22:24 +0800553 if(mode & GNSS_SET_SYSCFG_BDS) // BDS
554 {
b.liud0ba7152024-06-19 14:47:21 +0800555 new_mode |= 0x00000002;
556 }
b.liudbc3f4b2024-06-25 18:22:24 +0800557 if(mode & GNSS_SET_SYSCFG_GLO) // GLO
558 {
b.liud0ba7152024-06-19 14:47:21 +0800559 new_mode |= 0x00000004;
560 }
b.liudbc3f4b2024-06-25 18:22:24 +0800561 if(mode & GNSS_SET_SYSCFG_GAL) // GAL
562 {
b.liud0ba7152024-06-19 14:47:21 +0800563 new_mode |= 0x00000010;
564 }
565
566 gnss_set_result = gnss_8122_syscfg(fd, new_mode);
b.liudbc3f4b2024-06-25 18:22:24 +0800567 if(gnss_set_result != GNSS_ERR_OK)
568 {
b.liud0ba7152024-06-19 14:47:21 +0800569 goto set_fail;
570 }
571 should_wait_rsp = TRUE;
b.liudbc3f4b2024-06-25 18:22:24 +0800572 }
573 else if(memcmp(cmd, "$MSGCFG", 7) == 0) // $MSGCFG,<mode>,<rate>
574 {
b.liud0ba7152024-06-19 14:47:21 +0800575 uint32 mode;
576 int rate;
b.liudbc3f4b2024-06-25 18:22:24 +0800577 if(2 == sscanf(cmd, "$MSGCFG,%d,%d", &mode, &rate))
578 {
b.liud0ba7152024-06-19 14:47:21 +0800579 int time = rate / 1000; // s
b.liudbc3f4b2024-06-25 18:22:24 +0800580 if(time < 0)
581 {
b.liud0ba7152024-06-19 14:47:21 +0800582 gnss_set_result = GNSS_ERR_ARG;
583 goto set_fail;
584 }
585
586 if(((GNSS_SET_MSGCFG_RMC | GNSS_SET_MSGCFG_VTG | GNSS_SET_MSGCFG_GGA | GNSS_SET_MSGCFG_GSA
b.liudbc3f4b2024-06-25 18:22:24 +0800587 | GNSS_SET_MSGCFG_GRS | GNSS_SET_MSGCFG_GSV | GNSS_SET_MSGCFG_GLL | GNSS_SET_MSGCFG_ZDA
588 | GNSS_SET_MSGCFG_GST | GNSS_SET_MSGCFG_TXT) & mode) != mode)
589 {
b.liud0ba7152024-06-19 14:47:21 +0800590 gnss_set_result = GNSS_ERR_ARG;
591 goto set_fail;
592 }
593
b.liudbc3f4b2024-06-25 18:22:24 +0800594 if(mode & GNSS_SET_MSGCFG_RMC)
595 {
b.liud0ba7152024-06-19 14:47:21 +0800596 gnss_set_result = gnss_8122_msgcfg(fd, 0xF8, 0x05, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800597 if(gnss_set_result != GNSS_ERR_OK)
598 {
b.liud0ba7152024-06-19 14:47:21 +0800599 goto set_fail;
600 }
601 }
602
b.liudbc3f4b2024-06-25 18:22:24 +0800603 if(mode & GNSS_SET_MSGCFG_VTG)
604 {
b.liud0ba7152024-06-19 14:47:21 +0800605 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x06, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800606 if(gnss_set_result != GNSS_ERR_OK)
607 {
b.liud0ba7152024-06-19 14:47:21 +0800608 goto set_fail;
609 }
610 }
611
b.liudbc3f4b2024-06-25 18:22:24 +0800612 if(mode & GNSS_SET_MSGCFG_GGA)
613 {
b.liud0ba7152024-06-19 14:47:21 +0800614 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x00, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800615 if(gnss_set_result != GNSS_ERR_OK)
616 {
b.liud0ba7152024-06-19 14:47:21 +0800617 goto set_fail;
618 }
619 }
620
b.liudbc3f4b2024-06-25 18:22:24 +0800621 if(mode & GNSS_SET_MSGCFG_GSA)
622 {
b.liud0ba7152024-06-19 14:47:21 +0800623 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x02, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800624 if(gnss_set_result != GNSS_ERR_OK)
625 {
b.liud0ba7152024-06-19 14:47:21 +0800626 goto set_fail;
627 }
628 }
629
b.liudbc3f4b2024-06-25 18:22:24 +0800630 if(mode & GNSS_SET_MSGCFG_GRS)
631 {
b.liud0ba7152024-06-19 14:47:21 +0800632 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x03, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800633 if(gnss_set_result != GNSS_ERR_OK)
634 {
b.liud0ba7152024-06-19 14:47:21 +0800635 goto set_fail;
636 }
637 }
638
b.liudbc3f4b2024-06-25 18:22:24 +0800639 if(mode & GNSS_SET_MSGCFG_GSV)
640 {
b.liud0ba7152024-06-19 14:47:21 +0800641 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x04, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800642 if(gnss_set_result != GNSS_ERR_OK)
643 {
b.liud0ba7152024-06-19 14:47:21 +0800644 goto set_fail;
645 }
646 }
647
b.liudbc3f4b2024-06-25 18:22:24 +0800648 if(mode & GNSS_SET_MSGCFG_GLL)
649 {
b.liud0ba7152024-06-19 14:47:21 +0800650 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x01, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800651 if(gnss_set_result != GNSS_ERR_OK)
652 {
b.liud0ba7152024-06-19 14:47:21 +0800653 goto set_fail;
654 }
655 }
656
b.liudbc3f4b2024-06-25 18:22:24 +0800657 if(mode & GNSS_SET_MSGCFG_ZDA)
658 {
b.liud0ba7152024-06-19 14:47:21 +0800659 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x07, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800660 if(gnss_set_result != GNSS_ERR_OK)
661 {
b.liud0ba7152024-06-19 14:47:21 +0800662 goto set_fail;
663 }
664 }
665
b.liudbc3f4b2024-06-25 18:22:24 +0800666 if(mode & GNSS_SET_MSGCFG_GST)
667 {
b.liud0ba7152024-06-19 14:47:21 +0800668 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x08, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800669 if(gnss_set_result != GNSS_ERR_OK)
670 {
b.liud0ba7152024-06-19 14:47:21 +0800671 goto set_fail;
672 }
673 }
674
b.liudbc3f4b2024-06-25 18:22:24 +0800675 if(mode & GNSS_SET_MSGCFG_TXT)
676 {
b.liud0ba7152024-06-19 14:47:21 +0800677 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x20, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800678 if(gnss_set_result != GNSS_ERR_OK)
679 {
b.liud0ba7152024-06-19 14:47:21 +0800680 goto set_fail;
681 }
682 }
b.liudbc3f4b2024-06-25 18:22:24 +0800683 }
684 else
685 {
b.liud0ba7152024-06-19 14:47:21 +0800686 gnss_set_result = GNSS_ERR_ARG;
687 goto set_fail;
688 }
689
690 should_wait_rsp = TRUE;
b.liudbc3f4b2024-06-25 18:22:24 +0800691 }
692 else if(memcmp(cmd, "$MINEL", 6) == 0) // $MINEL,<elev>
693 {
b.liud0ba7152024-06-19 14:47:21 +0800694#if 0
695 float elev = 0.0f;
696 elev = (float)atof(cmd + 7);
697// LOGD("ELEV : %f", elev);
698// log_hex("ELEV", &elev, sizeof(double));
b.liudbc3f4b2024-06-25 18:22:24 +0800699 if(elev < -90.0f || elev > 90.0f)
700 {
b.liud0ba7152024-06-19 14:47:21 +0800701 gnss_set_result = GNSS_ERR_ARG;
702 goto set_fail;
703 }
704 float elevs[2];
705 elevs[0] = elev;
706 elevs[1] = elev;
707 gnss_set_result = gnss_8122_minel(fd, elevs);
b.liudbc3f4b2024-06-25 18:22:24 +0800708 if(gnss_set_result != GNSS_ERR_OK)
709 {
b.liud0ba7152024-06-19 14:47:21 +0800710 goto set_fail;
711 }
712 should_wait_rsp = FALSE;
713#else
714 gnss_set_result = GNSS_ERR_UNSUPPORT;
715 goto set_fail;
716#endif
b.liudbc3f4b2024-06-25 18:22:24 +0800717 }
718 else if(memcmp(cmd, "$NMEACFG", 8) == 0) // $NMEACFG,<ver>
719 {
b.liud0ba7152024-06-19 14:47:21 +0800720#if 0
721 gnss_memaver_type_enum version = (gnss_memaver_type_enum)atoi(cmd + 9);
b.liudbc3f4b2024-06-25 18:22:24 +0800722 if(version == GNSS_MEMAVER_TYPE_3_0)
723 {
b.liud0ba7152024-06-19 14:47:21 +0800724 gnss_set_result = gnss_8122_nmeaver(fd, 1);
b.liudbc3f4b2024-06-25 18:22:24 +0800725 }
726 else if(version == GNSS_MEMAVER_TYPE_4_0)
727 {
b.liud0ba7152024-06-19 14:47:21 +0800728 gnss_set_result = gnss_8122_nmeaver(fd, 2);
b.liudbc3f4b2024-06-25 18:22:24 +0800729 }
730 else if(version == GNSS_MEMAVER_TYPE_4_1)
731 {
b.liud0ba7152024-06-19 14:47:21 +0800732 gnss_set_result = gnss_8122_nmeaver(fd, 3);
b.liudbc3f4b2024-06-25 18:22:24 +0800733 }
734 else
735 {
b.liud0ba7152024-06-19 14:47:21 +0800736 gnss_set_result = GNSS_ERR_ARG;
737 goto set_fail;
738 }
b.liudbc3f4b2024-06-25 18:22:24 +0800739 if(gnss_set_result != GNSS_ERR_OK)
740 {
b.liud0ba7152024-06-19 14:47:21 +0800741 goto set_fail;
742 }
743 should_wait_rsp = FALSE;
744#else
745 gnss_set_result = GNSS_ERR_UNSUPPORT;
746 goto set_fail;
747#endif
b.liu5f950c52024-06-15 20:13:12 +0800748 }
749 else
750 {
751 LOGW("Unknown cmd:%s", cmd);
752 gnss_set_result = GNSS_ERR_UNSUPPORT;
753 goto set_fail;
754 }
755
b.liudbc3f4b2024-06-25 18:22:24 +0800756 set_success:
757 if(should_wait_rsp)
758 {
b.liud0ba7152024-06-19 14:47:21 +0800759 setting_waitting = TRUE;
b.liu5f950c52024-06-15 20:13:12 +0800760 pthread_mutex_lock(&read_mutex);
761 pthread_cond_wait(&read_cond, &read_mutex);
762 pthread_mutex_unlock(&read_mutex);
b.liudbc3f4b2024-06-25 18:22:24 +0800763 }
764 else
765 {
b.liu5f950c52024-06-15 20:13:12 +0800766 mbtk_timer_clear();
767 }
768
769 setting_busy = FALSE;
770 return gnss_set_result;
b.liudbc3f4b2024-06-25 18:22:24 +0800771 set_fail:
b.liu5f950c52024-06-15 20:13:12 +0800772 setting_busy = FALSE;
773 mbtk_timer_clear();
774 return gnss_set_result;
775 }
b.liuf9fbfa12024-06-14 15:53:59 +0800776}
777
b.liu5f950c52024-06-15 20:13:12 +0800778