123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617 |
- /*================================================================
- Copyright (c) 2020 Quectel Wireless Solution, Co., Ltd. All Rights Reserved.
- Quectel Wireless Solution Proprietary and Confidential.
- =================================================================*/
- /*=================================================================
- EDIT HISTORY FOR MODULE
- This section contains comments describing changes made to the module.
- Notice that changes are listed in reverse chronological order.
- WHEN WHO WHAT, WHERE, WHY
- ------------ ------- -------------------------------------------------------------------------------
- =================================================================*/
- #include <stdio.h>
- #include <string.h>
- #include <stdlib.h>
- #include "ql_api_osi.h"
- #include "ql_api_spi.h"
- #include "ql_log.h"
- #include "spi_demo.h"
- #include "ql_gpio.h"
- #include "ql_power.h"
- #define QL_SPI_DEMO_LOG_LEVEL QL_LOG_LEVEL_INFO
- #define QL_SPI_DEMO_LOG(msg, ...) QL_LOG(QL_SPI_DEMO_LOG_LEVEL, "ql_SPI_DEMO", msg, ##__VA_ARGS__)
- #define QL_SPI_DEMO_LOG_PUSH(msg, ...) QL_LOG_PUSH("ql_SPI_DEMO", msg, ##__VA_ARGS__)
- /**
- * 使用SPI DMA注意事项:
- * 8910:
- * 1. SPI DMA POLLING和SPI DMA IRQ只支持8bit和16bit的数据传输,不支持32bit数据传输
- * 2. 在使用16bit传输数据时,DMA实际使用的是32bit位宽,需要对输出数据插入一些无效数据,对输入数据去除无效数据,
- * 因此新增16bit dma api用于16bit情况下的读写,api包含ql_spi_write_16bit_dma、ql_spi_read_16bit_dma、
- * ql_spi_write_read_16bit_dma,这部分代码在demo中开源,客户可自行优化,或直接使用
- * 3. QL_SPI_16BIT_DMA置为1表示使用16bit DMA demo
- * 8850:
- * 1. SPI DMA POLLING和SPI DMA IRQ支持8bits、16bits和32bits的数据传输,但是传输的数据大小需要framesize对齐。
- */
- #define QL_SPI_16BIT_DMA 0 //16bit DMA demo
- #define QL_SPI_DEMO_LOW_POWER_USE 0 //0-not run in lower power mode;1-run in lower power mode
- ql_task_t spi_demo_task = NULL;
- ql_sem_t spi_demo_write;
- ql_sem_t spi_demo_read;
- int spi_power_lock = 0;
- #define QL_SPI_DEMO_WAIT_NONE 0
- #define QL_SPI_DEMO_WAIT_WRITE 1
- #define QL_SPI_DEMO_WAIT_READ 2
- unsigned char spi_demo_wait_write_read = QL_SPI_DEMO_WAIT_NONE;
- #if 1
- #define QL_CUR_SPI_PORT QL_SPI_PORT1
- #define QL_CUR_SPI_CS_PIN QL_CUR_SPI1_CS_PIN
- #define QL_CUR_SPI_CS_FUNC QL_CUR_SPI1_CS_FUNC
- #define QL_CUR_SPI_CLK_PIN QL_CUR_SPI1_CLK_PIN
- #define QL_CUR_SPI_CLK_FUNC QL_CUR_SPI1_CLK_FUNC
- #define QL_CUR_SPI_DO_PIN QL_CUR_SPI1_DO_PIN
- #define QL_CUR_SPI_DO_FUNC QL_CUR_SPI1_DO_FUNC
- #define QL_CUR_SPI_DI_PIN QL_CUR_SPI1_DI_PIN
- #define QL_CUR_SPI_DI_FUNC QL_CUR_SPI1_DI_FUNC
- #else
- #define QL_CUR_SPI_PORT QL_SPI_PORT2
- #define QL_CUR_SPI_CS_PIN QL_CUR_SPI2_CS_PIN
- #define QL_CUR_SPI_CS_FUNC QL_CUR_SPI2_CS_FUNC
- #define QL_CUR_SPI_CLK_PIN QL_CUR_SPI2_CLK_PIN
- #define QL_CUR_SPI_CLK_FUNC QL_CUR_SPI2_CLK_FUNC
- #define QL_CUR_SPI_DO_PIN QL_CUR_SPI2_DO_PIN
- #define QL_CUR_SPI_DO_FUNC QL_CUR_SPI2_DO_FUNC
- #define QL_CUR_SPI_DI_PIN QL_CUR_SPI2_DI_PIN
- #define QL_CUR_SPI_DI_FUNC QL_CUR_SPI2_DI_FUNC
- #endif
- #define QL_TYPE_SHIFT_8 8
- uint32_t g_inbuf[QL_SPI_DMA_IRQ_SIZE/4] OSI_CACHE_LINE_ALIGNED;
- uint32_t g_outbuf[QL_SPI_DMA_IRQ_SIZE/4] OSI_CACHE_LINE_ALIGNED;
- void ql_spi_read_data_transform(unsigned char *buf, unsigned int len)
- {
- if(len%2 != 0 || len > QL_SPI_DMA_IRQ_SIZE/2)
- {
- QL_SPI_DEMO_LOG("invalid parm");
- return;
- }
- for(int i = 0; i < len/2; i++)
- {
- buf[i*2] = (g_inbuf[i] >> QL_TYPE_SHIFT_8) & 0xFF;
- buf[i*2+1] = g_inbuf[i] & 0xFF;
- }
- }
- ql_errcode_spi_e ql_spi_write_16bit_dma(ql_spi_port_e port, unsigned char *buf, unsigned int len)
- {
- if(len%2 != 0 || len > QL_SPI_DMA_IRQ_SIZE/2)
- {
- QL_SPI_DEMO_LOG("invalid parm");
- return QL_SPI_PARAM_DATA_ERROR;
- }
-
- unsigned short out_temp = 0;
- for(int i = 0; i < len/2; i++)
- {
- out_temp = buf[i*2];
- g_outbuf[i] = (out_temp << QL_TYPE_SHIFT_8) + buf[i*2+1];
- }
- return ql_spi_write(port, (unsigned char*)g_outbuf, len*2);
- }
- ql_errcode_spi_e ql_spi_read_16bit_dma(ql_spi_port_e port, unsigned char *buf, unsigned int len)
- {
- if(len%2 != 0 || len > QL_SPI_DMA_IRQ_SIZE/2)
- {
- QL_SPI_DEMO_LOG("invalid parm");
- return QL_SPI_PARAM_DATA_ERROR;
- }
- return ql_spi_read(port, (unsigned char*)g_inbuf, len*2);
- }
- ql_errcode_spi_e ql_spi_write_read_16bit_dma(ql_spi_port_e port, unsigned char *inbuf, unsigned char *outbuf, unsigned int len)
- {
- if(len%2 != 0 || len > QL_SPI_DMA_IRQ_SIZE/2)
- {
- QL_SPI_DEMO_LOG("invalid parm");
- return QL_SPI_PARAM_DATA_ERROR;
- }
- unsigned short out_temp = 0;
-
- for(int i = 0; i < len/2; i++)
- {
- out_temp = outbuf[i*2];
- g_outbuf[i] = (out_temp << QL_TYPE_SHIFT_8) + outbuf[i*2+1];
- }
-
- return ql_spi_write_read(port, (unsigned char*)g_inbuf, (unsigned char*)g_outbuf, len*2);
- }
- void ql_spi_flash_data_printf(unsigned char *data, int len)
- {
- int i = 0;
- int count_len = 256;
- int count = 0;
- int exit = 0;
- int write_len = 0;
- int pos = 0;
-
- unsigned char *str_data = (unsigned char *)malloc(len*2+64);
- if (str_data == NULL)
- {
- QL_SPI_DEMO_LOG("malloc err");
- return ;
- }
- QL_SPI_DEMO_LOG("read len=%d", len);
-
- while ((exit == 0))
- {
- if (len - count > 256)
- {
- count_len = 256;
- }
- else
- {
- count_len = len - count;
- exit = 1;
- }
-
- memset(str_data, 0, len*2+64);
- for (i=count; i<count+count_len; i++)
- {
- //sprintf((char *)str_data,"%s%02x", str_data, data[i]);
- write_len += snprintf((char *)(str_data + write_len),(len*2+64 - write_len), "%02x", data[i]);
- }
- QL_SPI_DEMO_LOG("data[%d-%d]=%s", count, count+count_len, (char *)(str_data+pos));
- pos += write_len;
- count += count_len;
- }
- free(str_data);
- }
- void ql_spi_demo_cb_handler(ql_spi_irq_s cause)
- {
- if (cause.tx_dma_done == 1 && spi_demo_wait_write_read == QL_SPI_DEMO_WAIT_WRITE)
- {
- spi_demo_wait_write_read = QL_SPI_DEMO_WAIT_NONE;
- ql_rtos_semaphore_release(spi_demo_write);
- }
- if (cause.rx_dma_done == 1 && spi_demo_wait_write_read == QL_SPI_DEMO_WAIT_READ)
- {
- spi_demo_wait_write_read = QL_SPI_DEMO_WAIT_NONE;
- ql_rtos_semaphore_release(spi_demo_read);
- }
- QL_SPI_DEMO_LOG("cause.tx_dma_done=%d", cause.tx_dma_done);
- QL_SPI_DEMO_LOG("cause.rx_dma_done=%d", cause.rx_dma_done);
- }
- static void ql_spi_demo_task_pthread(void *ctx)
- {
- QlOSStatus err = 0;
- unsigned char *outdata = NULL;
- unsigned short outlen;
- unsigned char *indata = NULL;
- unsigned short inlen;
- unsigned char *out_mal_data = NULL;
- unsigned char *in_mal_data = NULL;
- ql_errcode_gpio ret;
- ql_spi_clk_e spiclk;
- ql_spi_transfer_mode_e transmode;
- unsigned int framesize;
- unsigned int tx_free = 0;
- ql_spi_config_s spi_config = {0};
-
- if (QL_CUR_SPI_CS_PIN == QUEC_PIN_NONE || QL_CUR_SPI_CS_PIN == QUEC_PIN_NONE || \
- QL_CUR_SPI_DO_PIN == QUEC_PIN_NONE || QL_CUR_SPI_DI_PIN == QUEC_PIN_NONE)
- {
- QL_SPI_DEMO_LOG("pin err");
- goto QL_SPI_EXIT;
- }
- ret = ql_pin_set_func(QL_CUR_SPI_CS_PIN, QL_CUR_SPI_CS_FUNC);
- if (ret != QL_GPIO_SUCCESS)
- {
- QL_SPI_DEMO_LOG("set pin err");
- goto QL_SPI_EXIT;
- }
-
- ret = ql_pin_set_func(QL_CUR_SPI_CLK_PIN, QL_CUR_SPI_CLK_FUNC);
- if (ret != QL_GPIO_SUCCESS)
- {
- QL_SPI_DEMO_LOG("set pin err");
- goto QL_SPI_EXIT;
- }
- ret = ql_pin_set_func(QL_CUR_SPI_DO_PIN, QL_CUR_SPI_DO_FUNC);
- if (ret != QL_GPIO_SUCCESS)
- {
- QL_SPI_DEMO_LOG("set pin err");
- goto QL_SPI_EXIT;
- }
- ret = ql_pin_set_func(QL_CUR_SPI_DI_PIN, QL_CUR_SPI_DI_FUNC);
- if (ret != QL_GPIO_SUCCESS)
- {
- QL_SPI_DEMO_LOG("set pin err");
- goto QL_SPI_EXIT;
- }
- //If you use the default parameters, you can initialize it with ql_spi_init
- /*transmode = QL_SPI_DMA_IRQ;
- spiclk = QL_SPI_CLK_25MHZ;
- framesize = 8;
- ql_spi_init(QL_CUR_SPI_PORT, transmode, spiclk);
- */
- spi_config.input_mode = QL_SPI_INPUT_TRUE;
- spi_config.port = QL_CUR_SPI_PORT;
- #if QL_SPI_16BIT_DMA
- framesize = 16;
- #else
- framesize = 8;
- #endif
- transmode = QL_SPI_DMA_IRQ; //使用QL_SPI_DMA_IRQ模式,传输一次最大的数据量为512个字节
- spiclk = QL_SPI_CLK_2MHZ;
- spi_config.spiclk = spiclk;
- spi_config.framesize = framesize;
- spi_config.cs_polarity0 = QL_SPI_CS_ACTIVE_LOW;
- spi_config.cs_polarity1 = QL_SPI_CS_ACTIVE_LOW;
- spi_config.cpol = QL_SPI_CPOL_LOW;
- spi_config.cpha = QL_SPI_CPHA_1Edge;
- spi_config.input_sel = QL_SPI_DI_1;
- spi_config.transmode = transmode;
- spi_config.cs = QL_SPI_CS0;
- spi_config.clk_delay = QL_SPI_CLK_DELAY_0;
- ql_spi_init_ext(spi_config);
- //使用QL_SPI_DMA_IRQ模式才会使用到信号量
- if(transmode == QL_SPI_DMA_IRQ)
- {
- ql_spi_irq_s mask = {0};
- mask.rx_dma_done = 1;
- mask.tx_dma_done = 1;
- //mask.tx_threshold = QL_SPI_TRIGGER_4_DATA;
- //mask.rx_threshold = QL_SPI_TRIGGER_4_DATA;
- ql_rtos_semaphore_create(&spi_demo_write, 0);
- ql_rtos_semaphore_create(&spi_demo_read, 0);
- ql_spi_set_irq(QL_CUR_SPI_PORT, mask, ql_spi_demo_cb_handler);
- }
-
- //用来测试SPI CS脚可以强制拉低,CS脚恢复成系统控制后,不需要强制拉高拉低
- ql_spi_cs_low(QL_CUR_SPI_PORT);
- ql_rtos_task_sleep_s(3);
- ql_spi_cs_auto(QL_CUR_SPI_PORT);
- //使用QL_SPI_DMA_IRQ模式,传输一次最大的数据量为512个字节,如果采用16bit传输数据,需要填充256字节无效数据用于DMA对齐,实际有效最大数据量为256字节
- #if QL_SPI_16BIT_DMA
- outlen = QL_SPI_DMA_IRQ_SIZE/2;
- inlen = QL_SPI_DMA_IRQ_SIZE/2;
- #else
- outlen = QL_SPI_DMA_IRQ_SIZE;
- inlen = QL_SPI_DMA_IRQ_SIZE;
- #endif
- out_mal_data = (unsigned char *)malloc(QL_SPI_DMA_ADDR_ALIN+outlen);
- in_mal_data = (unsigned char *)malloc(QL_SPI_DMA_ADDR_ALIN+outlen);
- if (out_mal_data == NULL || in_mal_data == NULL)
- {
- QL_SPI_DEMO_LOG("malloc err");
- goto QL_SPI_EXIT;
- }
- //使用QL_SPI_DMA_POLLING和QL_SPI_DMA_IRQ模式,使用的地址必须4字节对齐
- if(transmode == QL_SPI_DMA_POLLING || transmode == QL_SPI_DMA_IRQ)
- {
- outdata = (unsigned char *)OSI_ALIGN_UP(out_mal_data, QL_SPI_DMA_ADDR_ALIN);
- indata = (unsigned char *)OSI_ALIGN_UP(in_mal_data, QL_SPI_DMA_ADDR_ALIN);
- }
- else
- {
- outdata = out_mal_data;
- indata = in_mal_data;
- }
-
- memset(outdata, 0x00, outlen);
- memset(indata, 0x00, inlen);
- ql_spi_flash_data_printf(outdata, outlen);
- #if QL_SPI_DEMO_LOW_POWER_USE
- ql_autosleep_enable(QL_ALLOW_SLEEP);
- ql_rtos_task_sleep_s(2);
- #endif
- static uint8_t cmd_type = 0;
- while(1)
- {
- #if QL_SPI_DEMO_LOW_POWER_USE
- ql_lpm_wakelock_lock(spi_power_lock);
- #endif
- ql_spi_cs_low(QL_CUR_SPI_PORT);
- #if 1
- memset(outdata, 0x00, outlen);
- memset(indata, 0x00, inlen);
- if(transmode == QL_SPI_DMA_IRQ)
- {
- spi_demo_wait_write_read = QL_SPI_DEMO_WAIT_WRITE;
- //不允许进入慢时钟
- ql_spi_request_sys_clk(QL_CUR_SPI_PORT);
- }
- cmd_type = cmd_type + 1 > 4 ? 1 : cmd_type + 1;
- data_mpu_pack(outdata, &outlen, 0X50, cmd_type);
- ql_spi_write(QL_CUR_SPI_PORT, outdata, 256);
- if(transmode == QL_SPI_DMA_IRQ)
- {
- ql_rtos_semaphore_wait(spi_demo_write, QL_WAIT_FOREVER);
- //tx_dma_done只是DMA完成了,但是SPI的FIFO还可能存在数据未发送,在进入慢时钟或clk频率较低时出现
- ql_spi_get_tx_fifo_free(QL_CUR_SPI_PORT, &tx_free);
- QL_SPI_DEMO_LOG("tx_free=%d",tx_free);
- ql_delay_us((framesize+2)*(QL_SPI_FIFO_SIZE - tx_free)*1000000/spiclk);
- //恢复允许进入慢时钟
- ql_spi_release_sys_clk(QL_CUR_SPI_PORT);
- ql_spi_flash_data_printf(outdata, outlen);
- }
- //ql_rtos_task_sleep_ms(10);
- //ql_spi_write_read(QL_CUR_SPI_PORT, outdata, indata, 256);
- /////////////////////////////////////
- /////////////READ////////////////////
- /////////////////////////////////////
- if(transmode == QL_SPI_DMA_IRQ)
- {
- spi_demo_wait_write_read = QL_SPI_DEMO_WAIT_READ;
- //不允许进入慢时钟
- ql_spi_request_sys_clk(QL_CUR_SPI_PORT);
- }
- ql_spi_read(QL_CUR_SPI_PORT, indata, 512);
- if(transmode == QL_SPI_DMA_IRQ)
- {
- ql_rtos_semaphore_wait(spi_demo_read, QL_WAIT_FOREVER);
- //恢复允许进入慢时钟
- ql_spi_release_sys_clk(QL_CUR_SPI_PORT);
- ql_spi_flash_data_printf(indata, inlen);
- unsigned short sendLen = 0;
- data_decode_mpu(indata, 256, outdata, &sendLen);
- }
- #endif
- ql_rtos_task_sleep_ms(500);
- }
- ql_spi_release(QL_CUR_SPI_PORT);
- free(out_mal_data);
- free(in_mal_data);
- QL_SPI_EXIT:
- QL_SPI_DEMO_LOG("ql_rtos_task_delete");
- err = ql_rtos_task_delete(NULL);
- if(err != QL_OSI_SUCCESS)
- {
- QL_SPI_DEMO_LOG("task deleted failed");
- }
- }
- QlOSStatus ql_spi_demo_init(void)
- {
- QlOSStatus err = QL_OSI_SUCCESS;
- #if QL_SPI_DEMO_LOW_POWER_USE
- spi_power_lock = ql_lpm_wakelock_create("spi_irq", strlen("spi_irq"));
- #endif
- err = ql_rtos_task_create(&spi_demo_task, SPI_DEMO_TASK_STACK_SIZE, SPI_DEMO_TASK_PRIO, "ql_spi_demo", ql_spi_demo_task_pthread, NULL, SPI_DEMO_TASK_EVENT_CNT);
- if(err != QL_OSI_SUCCESS)
- {
- QL_SPI_DEMO_LOG("demo_task created failed");
- return err;
- }
-
- return err;
- }
- uint16_t Full_Frame_Verifi(uint8_t *srcdata, uint16_t srcLen, uint16_t* frame_start)
- {
- uint16_t frame_len = 0; // 获取帧长度
- uint8_t frame_flag = 0; //找到帧起始位
-
- for(uint32_t i = 0; i < (srcLen - sizeof(frame_pack_t)) && 0 == frame_flag; i++)
- {
- if(0X5A == srcdata[i])
- {
- frame_len = srcdata[i + FRAME_LEN_INDEX] + (srcdata[i + FRAME_LEN_INDEX + 1] << 8);
- if((i + frame_len + 1) < srcLen &&
- (srcdata[i + frame_len - 2] + (srcdata[i + frame_len - 1] << 8) == crc16_modbus(srcdata + i, frame_len -2)))
- {
- frame_flag = 1;
- (*frame_start) = i;
- //QL_SPI_DEMO_LOG("cmd :%d %d %dxxxxxx len %d", frame_flag, *frame_start, i, frame_len);
- return frame_len;
- }
- }
- }
-
- return 0;
- }
- uint8_t data_mpu_pack(uint8_t* output, uint16_t* output_data_len, uint8_t cmd, uint8_t cmd_type)
- {
- frame_pack_t frame_tmp = {0};
- frame_tmp.destination_addr = MCU_ADDR;
- frame_tmp.source_addr = MPU_ADDR;
- frame_tmp.frame_head = 0X5A;
- switch (cmd)
- {
- case 0X50:
- /* code */
- frame_tmp.cmd = 0X50;
- switch (cmd_type)
- {
- case 0X01:
- frame_tmp.cmd_type = 0X01;
- break;
- case 0X02:
- frame_tmp.cmd_type = 0X02;
- break;
- case 0X03:
- frame_tmp.cmd_type = 0X03;
- break;
- default:
- break;
- }
- *output_data_len = sizeof(frame_pack_t);
- break;
- case 0X60:
- /* code */
- frame_tmp.cmd = 0X60;
- switch (cmd_type)
- {
- case 0X01:
- frame_tmp.cmd_type = 0X01;
- break;
- case 0X02:
- frame_tmp.cmd_type = 0X02;
- break;
- case 0X03:
- frame_tmp.cmd_type = 0X03;
- break;
- default:
- break;
- }
- break;
-
- default:
- break;
- }
- frame_tmp.data_lenth = 2 + *output_data_len;
- memcpy(output, &frame_tmp, sizeof(frame_pack_t));
- uint16_t crc16 = crc16_modbus(output, *output_data_len);
- output[(*output_data_len)++] = crc16 & 0XFF;
- output[(*output_data_len)++] = (crc16 >> 8) & 0XFF;
- return 0;
- }
- uint8_t data_decode_mpu(uint8_t *input_data, uint16_t input_data_len, uint8_t* output, uint16_t* output_data_len)
- {
-
- uint16_t frame_start = 0; // 帧起始位
- uint16_t frame_len = 0;
-
- *output_data_len = 0;
- static frame_pack_t frame_tmp = {0};
- frame_tmp.frame_head = 0X5A;
- frame_tmp.destination_addr = MPU_ADDR;
- frame_tmp.source_addr = MCU_ADDR;
- //frame_pack_t* frame_read_tmp;
- frame_len = Full_Frame_Verifi(input_data, input_data_len, &frame_start);
- //QL_SPI_DEMO_LOG("cmd :%d %dxxxxxx",frame_len, frame_start);
- if(0 == frame_len)
- return 1;
- else
- {}
- *output_data_len += sizeof(frame_pack_t);
- //QL_SPI_DEMO_LOG("cmd :%d %dxxxxxx",input_data[frame_start + FRAME_CMD_INDEX], frame_start);
-
- switch(input_data[frame_start + FRAME_CMD_INDEX])
- {
- case 0X50:
- frame_tmp.cmd = 0X50;
- switch(input_data[frame_start + FRAME_CMD_TYPE_INDEX])
- {
- case 0X01:
- QL_SPI_DEMO_LOG("cmd :0X01----");
- break;
- case 0X02:
- QL_SPI_DEMO_LOG("cmd :0X02----");
- break;
- case 0X03:
- QL_SPI_DEMO_LOG("cmd :0X03----");
- break;
- default:
- break;
- }
- break;
- case 0X60:
- //
- switch(input_data[frame_start + FRAME_CMD_TYPE_INDEX])
- {
- case 0X01:
- ///
- *output_data_len = 0;
- break;
- case 0X02:
- ///
-
- break;
- case 0X03:
- //
- break;
- case 0X04:
- //
- break;
- default:
- break;
- }
- *output_data_len = 0;
- return 0;
- break;
- default:
- break;
- }
- memcpy(output, &frame_tmp, sizeof(frame_pack_t)); //帧固定帧在此复制
-
- uint16_t crc16 = crc16_modbus(output, *output_data_len);
- output[(*output_data_len)++] = crc16 & 0XFF;
- output[(*output_data_len)++] = (crc16 << 8) & 0XFF;
- return 0;
- }
- unsigned short crc16_modbus(unsigned char *pdata, int len)
- {
- int j = 0;
- int i = 0;
- uint16_t reg_crc = 0xffff;
- while (i < len )
- {
- reg_crc ^= pdata[i];
- i++;
- for (j = 0; j < 8; j++)
- {
- if ((reg_crc & 0x01) == 1)
- {
- reg_crc = (uint16_t)((reg_crc >> 1) ^ 0xa001);
- }
- else
- {
- reg_crc = (uint16_t)( reg_crc >> 1);
- }
- }
- }
-
- return reg_crc;
- }
|