blob: 5a328de2deb3ab61967fbab6fb94d8d5557a04b4 [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
yq.wang6a3437f2024-07-27 02:57:20 -0700363static gnss_err_enum gnss_8122_freqcfg(int fd, uint8 mode)
364{
365 uint8 buff[GNSS_PACK_BUFF_SIZE];
366 LOGD("FREQCFG");
367 uint8 data[20];
368 memset(data, 0x00, 20);
369 data[1] = mode;
370 data[2] = 0x66;
371 int len = pack_create(HD8122_ID_TYPE_CFG, HD8122_ID_CFG_PWRCTL, 20, data, buff, sizeof(buff));
372 if(len <= 0)
373 {
374 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_PWRCTL);
380 return GNSS_ERR_OK;
381}
382
b.liud0ba7152024-06-19 14:47:21 +0800383static gnss_err_enum gnss_8122_msgcfg(int fd, uint8 type, uint8 id, uint8 period)
384{
385 uint8 buff[GNSS_PACK_BUFF_SIZE];
386 LOGD("MSGCFG");
387 uint8 data[3];
388 data[0] = type;
389 data[1] = id;
390 data[2] = period;
391 int len = pack_create(HD8122_ID_TYPE_CFG, HD8122_ID_CFG_MSG, 3, data, buff, sizeof(buff));
b.liudbc3f4b2024-06-25 18:22:24 +0800392 if(len <= 0)
393 {
b.liud0ba7152024-06-19 14:47:21 +0800394 LOGE("pack_create() fail.");
395 return GNSS_ERR_ARG;
396 }
397 log_hex("PACK", buff, len);
398 gnss_write(fd, buff, len);
399 msg_insert(HD8122_ID_TYPE_CFG, HD8122_ID_CFG_MSG);
400 return GNSS_ERR_OK;
401}
402
403static gnss_err_enum gnss_8122_minel(int fd, float *elev)
404{
405 uint8 buff[GNSS_PACK_BUFF_SIZE];
406 LOGD("ELEV");
407 //uint8 elev_buff[4];
408 //uint32_2_byte((uint32)elev, elev_buff, TRUE);
409 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 +0800410 if(len <= 0)
411 {
b.liud0ba7152024-06-19 14:47:21 +0800412 LOGE("pack_create() fail.");
413 return GNSS_ERR_ARG;
414 }
415 log_hex("PACK", buff, len);
416 gnss_write(fd, buff, len);
417 return GNSS_ERR_OK;
418}
419
420static gnss_err_enum gnss_8122_nmeaver(int fd, uint8 ver)
421{
422 uint8 buff[GNSS_PACK_BUFF_SIZE];
423 LOGD("NMEA-VER");
424 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 +0800425 if(len <= 0)
426 {
b.liud0ba7152024-06-19 14:47:21 +0800427 LOGE("pack_create() fail.");
428 return GNSS_ERR_ARG;
429 }
430 log_hex("PACK", buff, len);
431 gnss_write(fd, buff, len);
432 return GNSS_ERR_OK;
433}
434
b.liuf9fbfa12024-06-14 15:53:59 +0800435int gnss_8122_dev_open()
436{
yq.wang5fe6e612024-07-17 01:18:12 -0700437 //return mbtk_gpio_value_set(GNSS_POWER_GPIO, MBTK_GPIO_DIRECT_OUT, 1);
438 system("i2cset -y -f 2 0x31 0x15 0x86");
439 return 0;
b.liuf9fbfa12024-06-14 15:53:59 +0800440}
441
b.liu978f5432024-07-01 18:04:18 +0800442int gnss_8122_dev_close(int fd)
b.liuf9fbfa12024-06-14 15:53:59 +0800443{
yq.wang5fe6e612024-07-17 01:18:12 -0700444 //return mbtk_gpio_value_set(GNSS_POWER_GPIO, MBTK_GPIO_DIRECT_OUT, 0);
445 system("i2cset -y -f 2 0x31 0x15 0x00");
446 return 0;
b.liuf9fbfa12024-06-14 15:53:59 +0800447}
448
449int gnss_8122_open(const char *dev)
450{
451 pthread_mutex_init(&read_mutex, NULL);
452 pthread_cond_init(&read_cond, NULL);
453 return gnss_port_open(dev, O_RDWR | O_NONBLOCK | O_NOCTTY, UART_BITRATE_NMEA_DEF_FW, TRUE);
454}
455
456int gnss_8122_close(int fd)
457{
458 pthread_mutex_destroy(&read_mutex);
459 pthread_cond_destroy(&read_cond);
460 return gnss_port_close(fd);
461}
462
b.liudbc3f4b2024-06-25 18:22:24 +0800463int gnss_8122_fw_dl(int fd, const char *fw_name, const char *dev)
b.liuf9fbfa12024-06-14 15:53:59 +0800464{
b.liudbc3f4b2024-06-25 18:22:24 +0800465 int uart_fd = OpenUart(dev);//PORT_NAME234
466 if (uart_fd < 0)
467 {
468 LOGE("open uart failed %d[%d]", uart_fd, errno);
469 return GNSS_ERR_OPEN_DEV;
470 }
471
472 uint8_t *g_bin_buff = (uint8_t*)malloc(500*1024);
473 if(g_bin_buff == NULL) {
474 LOGE("malloc() fail : %d", errno);
475 return GNSS_ERR_UNKNOWN;
476 }
477 memset(g_bin_buff, 0, 500*1024);
478 uint32_t len = read_bin_file(fw_name, g_bin_buff);
479 if (len <= 0)
480 {
481 LOGE("Read file failed ,len = %d", len);
482 return GNSS_ERR_DL_FW;
483 }
484 if(gnss_8122_dev_open()) {
485 LOGE("open gnss device fail:%d", errno);
486 return GNSS_ERR_DL_FW;
487 }
488 int ret = fw_update_boot(uart_fd, g_bin_buff, len);
489 free(g_bin_buff);
490 if (ret < 0)
491 {
492 LOGE("fw_update_boot() fail : %d", ret);
493 return GNSS_ERR_DL_FW;
494 }
495 uart_close(uart_fd);
496 if(ret == HDBD_UPG_SUCESS)
497 {
498 LOGD("upgrade sucess!");
499 return GNSS_ERR_OK;
500 }
501 else
502 {
503 LOGD("upgrade FAIL, fail style:%d", ret);
504 return GNSS_ERR_DL_FW;
505 }
b.liuf9fbfa12024-06-14 15:53:59 +0800506}
507
b.liu5f950c52024-06-15 20:13:12 +0800508void gnss_8122_set_cb(const void *data, int data_len)
509{
510 const char *buff = (const char*)data;
b.liudbc3f4b2024-06-25 18:22:24 +0800511 if(setting_busy) // Has setting cmd process.
512 {
b.liu5f950c52024-06-15 20:13:12 +0800513 gnss_cmd_rsp_process(data, data_len);
514 }
515}
b.liuf9fbfa12024-06-14 15:53:59 +0800516
517gnss_err_enum gnss_8122_set(int fd, const char *cmd, void *cmd_rsp, int cmd_rsp_len)
518{
b.liudbc3f4b2024-06-25 18:22:24 +0800519 if(setting_busy)
520 {
b.liu5f950c52024-06-15 20:13:12 +0800521 return GNSS_ERR_SET_BUSY;
b.liudbc3f4b2024-06-25 18:22:24 +0800522 }
523 else
524 {
b.liu5f950c52024-06-15 20:13:12 +0800525 bool should_wait_rsp = TRUE;
526 setting_busy = TRUE;
527 gnss_set_rsp_ptr = cmd_rsp;
528 gnss_set_result = GNSS_ERR_OK;
b.liud0ba7152024-06-19 14:47:21 +0800529 msg_init();
b.liu5f950c52024-06-15 20:13:12 +0800530 mbtk_timer_set(gnss_set_timer_cb, GNSS_SET_TIMEOUT);
531
b.liudbc3f4b2024-06-25 18:22:24 +0800532 if(memcmp(cmd, "$RESET", 6) == 0) // $RESET,<mode>
533 {
b.liud0ba7152024-06-19 14:47:21 +0800534 gnss_reset_type_enum mode = (gnss_reset_type_enum)atoi(cmd + 7);
yq.wang1ddd1fd2024-07-25 23:00:14 -0700535 LOGD("set reset: %d", mode);
b.liudbc3f4b2024-06-25 18:22:24 +0800536 if(mode == GNSS_RESET_TYPE_HOT)
537 {
b.liud0ba7152024-06-19 14:47:21 +0800538 gnss_set_result = gnss_8122_reset(fd, 3);
b.liudbc3f4b2024-06-25 18:22:24 +0800539 }
540 else if(mode == GNSS_RESET_TYPE_WARM)
541 {
b.liud0ba7152024-06-19 14:47:21 +0800542 gnss_set_result = gnss_8122_reset(fd, 2);
b.liudbc3f4b2024-06-25 18:22:24 +0800543 }
544 else if(mode == GNSS_RESET_TYPE_COLD)
545 {
b.liud0ba7152024-06-19 14:47:21 +0800546 gnss_set_result = gnss_8122_reset(fd, 1);
b.liudbc3f4b2024-06-25 18:22:24 +0800547 }
548 else
549 {
b.liud0ba7152024-06-19 14:47:21 +0800550 gnss_set_result = GNSS_ERR_ARG;
551 goto set_fail;
552 }
b.liudbc3f4b2024-06-25 18:22:24 +0800553 if(gnss_set_result != GNSS_ERR_OK)
554 {
b.liu5f950c52024-06-15 20:13:12 +0800555 goto set_fail;
556 }
557 should_wait_rsp = FALSE;
b.liudbc3f4b2024-06-25 18:22:24 +0800558 }
559 else if(memcmp(cmd, "$SYSCFG", 7) == 0) // $SYSCFG,<mode>
560 {
b.liud0ba7152024-06-19 14:47:21 +0800561 uint32 mode = 0;
562 mode = (uint32)atoi(cmd + 8);
563 uint32 new_mode = 0;
b.liudbc3f4b2024-06-25 18:22:24 +0800564 if(((GNSS_SET_SYSCFG_GPS | GNSS_SET_SYSCFG_BDS | GNSS_SET_SYSCFG_GLO | GNSS_SET_SYSCFG_GAL) & mode) != mode)
565 {
b.liud0ba7152024-06-19 14:47:21 +0800566 gnss_set_result = GNSS_ERR_ARG;
567 goto set_fail;
568 }
569
b.liudbc3f4b2024-06-25 18:22:24 +0800570 if(mode & GNSS_SET_SYSCFG_GPS) // GPS
571 {
b.liud0ba7152024-06-19 14:47:21 +0800572 new_mode |= 0x00000001;
573 }
b.liudbc3f4b2024-06-25 18:22:24 +0800574 if(mode & GNSS_SET_SYSCFG_BDS) // BDS
575 {
b.liud0ba7152024-06-19 14:47:21 +0800576 new_mode |= 0x00000002;
577 }
b.liudbc3f4b2024-06-25 18:22:24 +0800578 if(mode & GNSS_SET_SYSCFG_GLO) // GLO
579 {
b.liud0ba7152024-06-19 14:47:21 +0800580 new_mode |= 0x00000004;
581 }
b.liudbc3f4b2024-06-25 18:22:24 +0800582 if(mode & GNSS_SET_SYSCFG_GAL) // GAL
583 {
b.liud0ba7152024-06-19 14:47:21 +0800584 new_mode |= 0x00000010;
585 }
586
587 gnss_set_result = gnss_8122_syscfg(fd, new_mode);
b.liudbc3f4b2024-06-25 18:22:24 +0800588 if(gnss_set_result != GNSS_ERR_OK)
589 {
b.liud0ba7152024-06-19 14:47:21 +0800590 goto set_fail;
591 }
592 should_wait_rsp = TRUE;
b.liudbc3f4b2024-06-25 18:22:24 +0800593 }
yq.wang6a3437f2024-07-27 02:57:20 -0700594 else if(memcmp(cmd, "$FREQCFG", 8) == 0) //$FREQCFG,<freq>
595 {
596 uint32 freq = 0;
597 freq = (uint32)atoi(cmd + 9);
598 LOGD("set freq: %d", freq);
599 if((GNSS_SET_FREQCFG_1 != freq) && (GNSS_SET_FREQCFG_2 != freq) && (GNSS_SET_FREQCFG_5 != freq))
600 {
601 gnss_set_result = GNSS_ERR_ARG;
602 goto set_fail;
603 }
604 gnss_set_result = gnss_8122_freqcfg(fd, (uint8)freq);
605 if(gnss_set_result != GNSS_ERR_OK)
606 {
607 goto set_fail;
608 }
609 should_wait_rsp = TRUE;
610 }
b.liudbc3f4b2024-06-25 18:22:24 +0800611 else if(memcmp(cmd, "$MSGCFG", 7) == 0) // $MSGCFG,<mode>,<rate>
612 {
b.liud0ba7152024-06-19 14:47:21 +0800613 uint32 mode;
614 int rate;
b.liudbc3f4b2024-06-25 18:22:24 +0800615 if(2 == sscanf(cmd, "$MSGCFG,%d,%d", &mode, &rate))
616 {
yq.wang1ddd1fd2024-07-25 23:00:14 -0700617 LOGD("set msgcfg: %d, %d", mode, rate);
b.liud0ba7152024-06-19 14:47:21 +0800618 int time = rate / 1000; // s
b.liudbc3f4b2024-06-25 18:22:24 +0800619 if(time < 0)
620 {
b.liud0ba7152024-06-19 14:47:21 +0800621 gnss_set_result = GNSS_ERR_ARG;
622 goto set_fail;
623 }
624
625 if(((GNSS_SET_MSGCFG_RMC | GNSS_SET_MSGCFG_VTG | GNSS_SET_MSGCFG_GGA | GNSS_SET_MSGCFG_GSA
b.liudbc3f4b2024-06-25 18:22:24 +0800626 | GNSS_SET_MSGCFG_GRS | GNSS_SET_MSGCFG_GSV | GNSS_SET_MSGCFG_GLL | GNSS_SET_MSGCFG_ZDA
627 | GNSS_SET_MSGCFG_GST | GNSS_SET_MSGCFG_TXT) & mode) != mode)
628 {
yq.wang1ddd1fd2024-07-25 23:00:14 -0700629 LOGD("msgcfg not support mode");
b.liud0ba7152024-06-19 14:47:21 +0800630 gnss_set_result = GNSS_ERR_ARG;
631 goto set_fail;
632 }
633
b.liudbc3f4b2024-06-25 18:22:24 +0800634 if(mode & GNSS_SET_MSGCFG_RMC)
635 {
yq.wang1ddd1fd2024-07-25 23:00:14 -0700636 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x05, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800637 if(gnss_set_result != GNSS_ERR_OK)
638 {
b.liud0ba7152024-06-19 14:47:21 +0800639 goto set_fail;
640 }
641 }
642
b.liudbc3f4b2024-06-25 18:22:24 +0800643 if(mode & GNSS_SET_MSGCFG_VTG)
644 {
b.liud0ba7152024-06-19 14:47:21 +0800645 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x06, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800646 if(gnss_set_result != GNSS_ERR_OK)
647 {
b.liud0ba7152024-06-19 14:47:21 +0800648 goto set_fail;
649 }
650 }
651
b.liudbc3f4b2024-06-25 18:22:24 +0800652 if(mode & GNSS_SET_MSGCFG_GGA)
653 {
b.liud0ba7152024-06-19 14:47:21 +0800654 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x00, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800655 if(gnss_set_result != GNSS_ERR_OK)
656 {
b.liud0ba7152024-06-19 14:47:21 +0800657 goto set_fail;
658 }
659 }
660
b.liudbc3f4b2024-06-25 18:22:24 +0800661 if(mode & GNSS_SET_MSGCFG_GSA)
662 {
b.liud0ba7152024-06-19 14:47:21 +0800663 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x02, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800664 if(gnss_set_result != GNSS_ERR_OK)
665 {
b.liud0ba7152024-06-19 14:47:21 +0800666 goto set_fail;
667 }
668 }
669
b.liudbc3f4b2024-06-25 18:22:24 +0800670 if(mode & GNSS_SET_MSGCFG_GRS)
671 {
b.liud0ba7152024-06-19 14:47:21 +0800672 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x03, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800673 if(gnss_set_result != GNSS_ERR_OK)
674 {
b.liud0ba7152024-06-19 14:47:21 +0800675 goto set_fail;
676 }
677 }
678
b.liudbc3f4b2024-06-25 18:22:24 +0800679 if(mode & GNSS_SET_MSGCFG_GSV)
680 {
b.liud0ba7152024-06-19 14:47:21 +0800681 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x04, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800682 if(gnss_set_result != GNSS_ERR_OK)
683 {
b.liud0ba7152024-06-19 14:47:21 +0800684 goto set_fail;
685 }
686 }
687
b.liudbc3f4b2024-06-25 18:22:24 +0800688 if(mode & GNSS_SET_MSGCFG_GLL)
689 {
b.liud0ba7152024-06-19 14:47:21 +0800690 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x01, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800691 if(gnss_set_result != GNSS_ERR_OK)
692 {
b.liud0ba7152024-06-19 14:47:21 +0800693 goto set_fail;
694 }
695 }
696
b.liudbc3f4b2024-06-25 18:22:24 +0800697 if(mode & GNSS_SET_MSGCFG_ZDA)
698 {
b.liud0ba7152024-06-19 14:47:21 +0800699 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x07, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800700 if(gnss_set_result != GNSS_ERR_OK)
701 {
b.liud0ba7152024-06-19 14:47:21 +0800702 goto set_fail;
703 }
704 }
705
b.liudbc3f4b2024-06-25 18:22:24 +0800706 if(mode & GNSS_SET_MSGCFG_GST)
707 {
b.liud0ba7152024-06-19 14:47:21 +0800708 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x08, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800709 if(gnss_set_result != GNSS_ERR_OK)
710 {
b.liud0ba7152024-06-19 14:47:21 +0800711 goto set_fail;
712 }
713 }
714
b.liudbc3f4b2024-06-25 18:22:24 +0800715 if(mode & GNSS_SET_MSGCFG_TXT)
716 {
b.liud0ba7152024-06-19 14:47:21 +0800717 gnss_set_result = gnss_8122_msgcfg(fd, 0xF0, 0x20, time);
b.liudbc3f4b2024-06-25 18:22:24 +0800718 if(gnss_set_result != GNSS_ERR_OK)
719 {
b.liud0ba7152024-06-19 14:47:21 +0800720 goto set_fail;
721 }
722 }
b.liudbc3f4b2024-06-25 18:22:24 +0800723 }
724 else
725 {
b.liud0ba7152024-06-19 14:47:21 +0800726 gnss_set_result = GNSS_ERR_ARG;
727 goto set_fail;
728 }
729
730 should_wait_rsp = TRUE;
b.liudbc3f4b2024-06-25 18:22:24 +0800731 }
732 else if(memcmp(cmd, "$MINEL", 6) == 0) // $MINEL,<elev>
733 {
b.liud0ba7152024-06-19 14:47:21 +0800734#if 0
735 float elev = 0.0f;
736 elev = (float)atof(cmd + 7);
737// LOGD("ELEV : %f", elev);
738// log_hex("ELEV", &elev, sizeof(double));
b.liudbc3f4b2024-06-25 18:22:24 +0800739 if(elev < -90.0f || elev > 90.0f)
740 {
b.liud0ba7152024-06-19 14:47:21 +0800741 gnss_set_result = GNSS_ERR_ARG;
742 goto set_fail;
743 }
744 float elevs[2];
745 elevs[0] = elev;
746 elevs[1] = elev;
747 gnss_set_result = gnss_8122_minel(fd, elevs);
b.liudbc3f4b2024-06-25 18:22:24 +0800748 if(gnss_set_result != GNSS_ERR_OK)
749 {
b.liud0ba7152024-06-19 14:47:21 +0800750 goto set_fail;
751 }
752 should_wait_rsp = FALSE;
753#else
754 gnss_set_result = GNSS_ERR_UNSUPPORT;
755 goto set_fail;
756#endif
b.liudbc3f4b2024-06-25 18:22:24 +0800757 }
758 else if(memcmp(cmd, "$NMEACFG", 8) == 0) // $NMEACFG,<ver>
759 {
b.liud0ba7152024-06-19 14:47:21 +0800760#if 0
761 gnss_memaver_type_enum version = (gnss_memaver_type_enum)atoi(cmd + 9);
b.liudbc3f4b2024-06-25 18:22:24 +0800762 if(version == GNSS_MEMAVER_TYPE_3_0)
763 {
b.liud0ba7152024-06-19 14:47:21 +0800764 gnss_set_result = gnss_8122_nmeaver(fd, 1);
b.liudbc3f4b2024-06-25 18:22:24 +0800765 }
766 else if(version == GNSS_MEMAVER_TYPE_4_0)
767 {
b.liud0ba7152024-06-19 14:47:21 +0800768 gnss_set_result = gnss_8122_nmeaver(fd, 2);
b.liudbc3f4b2024-06-25 18:22:24 +0800769 }
770 else if(version == GNSS_MEMAVER_TYPE_4_1)
771 {
b.liud0ba7152024-06-19 14:47:21 +0800772 gnss_set_result = gnss_8122_nmeaver(fd, 3);
b.liudbc3f4b2024-06-25 18:22:24 +0800773 }
774 else
775 {
b.liud0ba7152024-06-19 14:47:21 +0800776 gnss_set_result = GNSS_ERR_ARG;
777 goto set_fail;
778 }
b.liudbc3f4b2024-06-25 18:22:24 +0800779 if(gnss_set_result != GNSS_ERR_OK)
780 {
b.liud0ba7152024-06-19 14:47:21 +0800781 goto set_fail;
782 }
783 should_wait_rsp = FALSE;
784#else
785 gnss_set_result = GNSS_ERR_UNSUPPORT;
786 goto set_fail;
787#endif
b.liu5f950c52024-06-15 20:13:12 +0800788 }
789 else
790 {
791 LOGW("Unknown cmd:%s", cmd);
792 gnss_set_result = GNSS_ERR_UNSUPPORT;
793 goto set_fail;
794 }
795
b.liudbc3f4b2024-06-25 18:22:24 +0800796 set_success:
797 if(should_wait_rsp)
798 {
b.liud0ba7152024-06-19 14:47:21 +0800799 setting_waitting = TRUE;
b.liu5f950c52024-06-15 20:13:12 +0800800 pthread_mutex_lock(&read_mutex);
801 pthread_cond_wait(&read_cond, &read_mutex);
802 pthread_mutex_unlock(&read_mutex);
b.liudbc3f4b2024-06-25 18:22:24 +0800803 }
804 else
805 {
b.liu5f950c52024-06-15 20:13:12 +0800806 mbtk_timer_clear();
807 }
808
809 setting_busy = FALSE;
810 return gnss_set_result;
b.liudbc3f4b2024-06-25 18:22:24 +0800811 set_fail:
b.liu5f950c52024-06-15 20:13:12 +0800812 setting_busy = FALSE;
813 mbtk_timer_clear();
814 return gnss_set_result;
815 }
b.liuf9fbfa12024-06-14 15:53:59 +0800816}
817
b.liu5f950c52024-06-15 20:13:12 +0800818