mirror of
https://gitee.com/beecue/fastbee.git
synced 2025-12-21 02:15:55 +08:00
更新硬件SDK
This commit is contained in:
12
sdk/合宙/air780e/csdk/luatos-soc-2022/project/README.md
Normal file
12
sdk/合宙/air780e/csdk/luatos-soc-2022/project/README.md
Normal file
@@ -0,0 +1,12 @@
|
||||
# porject项目集合
|
||||
|
||||
* 本目录下的项目基于合宙标准CSDK接口开发,后续会一直维护;
|
||||
* 客户项目开发请参考此目录下的example和项目示例
|
||||
|
||||
|
||||
|
||||
* example 模板项目,最基本的demo, 演示入口函数和启动task, 启动后定时打印日志
|
||||
* example_xxx xxx功能demo代码
|
||||
* targets:多target编译演示
|
||||
* luatos:基于合宙标准csdk实现的LuatOS项目
|
||||
|
||||
@@ -0,0 +1,26 @@
|
||||
# 说明
|
||||
|
||||
* 此demo是云喇叭演示demo
|
||||
|
||||
## 功能说明
|
||||
1:设备启动后首先播报:“正在开机”
|
||||
2:设备连接mqtt服务器并订阅主题成功后,会播报:“服务器连接成功”
|
||||
3:用另一个mqtt clinet向设备订阅的主题发送固定格式的报文,设备则会播报支付宝收款xxxx元
|
||||
|
||||
## 设备订阅的主题
|
||||
/sub/topic/money/{imei} {imei}为模块的imei
|
||||
如模块的imei为:866714xxxx16190
|
||||
|
||||
则设备订阅的主题为/sub/topic/money/866714xxxx16190
|
||||
|
||||
## 设备连接的服务器
|
||||
host:lbsmqtt.airm2m.com
|
||||
port:1884
|
||||
|
||||
## 报文下发格式
|
||||
{"money":"number"}
|
||||
其中number为一个不大于99999999.99的数字
|
||||
|
||||
如:
|
||||
向主题“/sub/topic/money/866714xxxx16190”下发{"money":"12345678.9"}
|
||||
设备则会播报 “支付宝收款一千两百三十四万五千六百七十八点九元”
|
||||
@@ -0,0 +1,350 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 1
|
||||
#define RTE_UART1_RTS_PIN_EN 1
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN21}, // 0 : gpio16 / 1 : UART1 RTS / 2 : SPI0 SSn
|
||||
// { PAD_PIN22}, // 0 : gpio11 / 1 : UART1 CTS / 2 : SPI0 MOSI
|
||||
// { PAD_PIN23}, // 0 : gpio14 / 1 : UART1 RXD / 2 : SPI0 MISO
|
||||
// { PAD_PIN24}, // 0 : gpio15 / 1 : UART1 TXD / 2 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 21
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 22
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 23
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 24
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 1
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 0
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 1
|
||||
|
||||
// { PAD_PIN13}, // 0 : gpio2 / 1 : UART0 RTSn / 3 : SPI1 SSn
|
||||
// { PAD_PIN14}, // 0 : gpio3 / 1 : UART0 CTSn / 3 : SPI1 MOSI
|
||||
// { PAD_PIN15}, // 0 : gpio4 / 1 : UART0 RXD / 3 : SPI1 MISO
|
||||
// { PAD_PIN16}, // 0 : gpio5 / 1 : UART0 TXD / 3 : SPI1 SCLK
|
||||
#define RTE_SPI1_SSN_BIT 13
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 14
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 15
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 16
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,39 @@
|
||||
#ifndef __AUDIO_EXTERN_H__
|
||||
#define __AUDIO_EXTERN_H__
|
||||
extern const unsigned char audio0[];
|
||||
extern const unsigned char audio1[];
|
||||
extern const unsigned char audio10[];
|
||||
extern const unsigned char audio100[];
|
||||
extern const unsigned char audio1000[];
|
||||
extern const unsigned char audio10000[];
|
||||
extern const unsigned char audio2[];
|
||||
extern const unsigned char audio3[];
|
||||
extern const unsigned char audio4[];
|
||||
extern const unsigned char audio5[];
|
||||
extern const unsigned char audio6[];
|
||||
extern const unsigned char audio7[];
|
||||
extern const unsigned char audio8[];
|
||||
extern const unsigned char audio9[];
|
||||
extern const unsigned char audiodot[];
|
||||
extern const unsigned char audioshoukuanchenggong[];
|
||||
extern const unsigned char audioyuan[];
|
||||
extern const unsigned char audiozhifubao[];
|
||||
extern const int audio0Size;
|
||||
extern const int audio1Size;
|
||||
extern const int audio10Size;
|
||||
extern const int audio100Size;
|
||||
extern const int audio1000Size;
|
||||
extern const int audio10000Size;
|
||||
extern const int audio2Size;
|
||||
extern const int audio3Size;
|
||||
extern const int audio4Size;
|
||||
extern const int audio5Size;
|
||||
extern const int audio6Size;
|
||||
extern const int audio7Size;
|
||||
extern const int audio8Size;
|
||||
extern const int audio9Size;
|
||||
extern const int audiodotSize;
|
||||
extern const int audioshoukuanchenggongSize;
|
||||
extern const int audioyuanSize;
|
||||
extern const int audiozhifubaoSize;
|
||||
#endif
|
||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,41 @@
|
||||
#ifndef __AUDIO_TASK__
|
||||
#define __AUDIO_TASK__
|
||||
#include "queue.h"
|
||||
// #include "audio_play.h"
|
||||
#include "luat_audio_play_ec618.h"
|
||||
typedef struct
|
||||
{
|
||||
uint32_t priority;
|
||||
uint32_t playType;
|
||||
union
|
||||
{
|
||||
struct
|
||||
{
|
||||
char *data;
|
||||
uint8_t len;
|
||||
} tts;
|
||||
struct
|
||||
{
|
||||
luat_audio_play_info_t *info;
|
||||
uint8_t count;
|
||||
} file;
|
||||
} message;
|
||||
void * userParam;
|
||||
} audioQueueData;
|
||||
|
||||
typedef enum
|
||||
{
|
||||
MONEY_PLAY = 0,
|
||||
PAD_PLAY,
|
||||
SYS_PLAY
|
||||
} AUDIO_PLAY_PRIORITY;
|
||||
|
||||
typedef enum
|
||||
{
|
||||
TTS_PLAY = 0,
|
||||
FILE_PLAY,
|
||||
} AUDIO_PLAY_TYPE;
|
||||
|
||||
|
||||
void audio_task_init(void);
|
||||
#endif
|
||||
@@ -0,0 +1,18 @@
|
||||
#ifndef __MQTT_PUBLISH_H__
|
||||
#define __MQTT_PUBLISH_H__
|
||||
#include "MQTTClient.h"
|
||||
typedef struct mqtt_publish_para
|
||||
{
|
||||
mqttSendMsg* publish;
|
||||
void (*callback)(int result);
|
||||
}mqtt_publish_para_t;
|
||||
|
||||
|
||||
typedef enum MQTT_PUBLISH_RESULT
|
||||
{
|
||||
MQTT_PUBLISH_SUCCESS,
|
||||
MQTT_PUBLISH_FAIL,
|
||||
MQTT_NOT_READY,
|
||||
NETWORK_NOT_READY
|
||||
}MQTT_PUBLISH_RESULT_E;
|
||||
#endif
|
||||
@@ -0,0 +1,5 @@
|
||||
#ifndef __MQTT_STATUS_H_
|
||||
#define __MQTT_STATUS_H_
|
||||
bool getNetStatus();
|
||||
bool getServerStatus();
|
||||
#endif
|
||||
@@ -0,0 +1,165 @@
|
||||
#include "FreeRTOS.h"
|
||||
#include "common_api.h"
|
||||
#include "audio_task.h"
|
||||
#include "bsp_custom.h"
|
||||
#include "audio_extern.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_audio_play_ec618.h"
|
||||
#include "luat_i2s_ec618.h"
|
||||
#include "ivTTSSDKID_all.h"
|
||||
#include "ivTTS.h"
|
||||
#include "luat_gpio.h"
|
||||
#include "luat_debug.h"
|
||||
|
||||
//AIR780E+TM8211开发板配置
|
||||
#define CODEC_PWR_PIN HAL_GPIO_12
|
||||
#define CODEC_PWR_PIN_ALT_FUN 4
|
||||
#define PA_PWR_PIN HAL_GPIO_25
|
||||
#define PA_PWR_PIN_ALT_FUN 0
|
||||
#define CHARGE_EN_PIN HAL_GPIO_2
|
||||
#define CHARGE_EN_PIN_ALT_FUN 0
|
||||
|
||||
#define AUDIO_QUEUE_SIZE 100
|
||||
|
||||
|
||||
extern const unsigned char audiopoweron[];
|
||||
static luat_rtos_semaphore_t audio_semaphore_handle;
|
||||
static luat_rtos_task_handle audio_task_handle;
|
||||
|
||||
|
||||
luat_rtos_queue_t audio_queue_handle;
|
||||
static uint8_t audio_sleep_handler = 0xff;
|
||||
static HANDLE g_s_delay_timer;
|
||||
|
||||
void audio_data_cb(uint8_t *data, uint32_t len, uint8_t bits, uint8_t channels)
|
||||
{
|
||||
int value = 15;
|
||||
int ret = luat_kv_get("volume", &value, sizeof(int));
|
||||
if(ret > 0)
|
||||
{
|
||||
// LUAT_DEBUG_PRINT("cloud_speaker_audio_task get volume success %d", value); //这里的打印打开会出来很多,影响日志查看,有需要可自行打开
|
||||
HAL_I2sSrcAdjustVolumn(data, len, value);
|
||||
}
|
||||
else
|
||||
{
|
||||
// LUAT_DEBUG_PRINT("cloud_speaker_audio_task get volume fail %d", value); //这里的打印打开会出来很多,影响日志查看,有需要可自行打开
|
||||
HAL_I2sSrcAdjustVolumn(data, len, 15);
|
||||
}
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task %x,%d,%d,%d,%d", data, len, bits, channels);
|
||||
}
|
||||
void app_pa_on(uint32_t arg)
|
||||
{
|
||||
luat_gpio_set(PA_PWR_PIN, 1); //如果是780E+音频扩展小板,可以注释掉此行代码,因为PA长开
|
||||
}
|
||||
void audio_event_cb(uint32_t event, void *param)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task event_cb %d", event);
|
||||
switch (event)
|
||||
{
|
||||
case MULTIMEDIA_CB_AUDIO_DECODE_START:
|
||||
luat_gpio_set(CODEC_PWR_PIN, 1);
|
||||
luat_audio_play_write_blank_raw(0, 6, 1);
|
||||
break;
|
||||
case MULTIMEDIA_CB_AUDIO_OUTPUT_START:
|
||||
luat_rtos_timer_start(g_s_delay_timer, 200, 0, app_pa_on, NULL); //如果是780E+音频扩展小板,可以注释掉此行代码,因为PA长开
|
||||
break;
|
||||
case MULTIMEDIA_CB_TTS_INIT:
|
||||
break;
|
||||
case LUAT_MULTIMEDIA_CB_TTS_DONE:
|
||||
if (!luat_audio_play_get_last_error(0))
|
||||
{
|
||||
luat_audio_play_write_blank_raw(0, 1, 0);
|
||||
}
|
||||
break;
|
||||
case MULTIMEDIA_CB_AUDIO_DONE:
|
||||
luat_rtos_timer_stop(g_s_delay_timer);
|
||||
LUAT_DEBUG_PRINT("audio play done, result=%d!", luat_audio_play_get_last_error(0));
|
||||
luat_gpio_set(PA_PWR_PIN, 0); //如果是780E+音频扩展小板,可以注释掉此行代码,因为PA长开
|
||||
luat_gpio_set(CODEC_PWR_PIN, 0);
|
||||
luat_rtos_semaphore_release(audio_semaphore_handle);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void audio_task(void *param)
|
||||
{
|
||||
audioQueueData audioQueueRecv = {0};
|
||||
uint32_t result = 0;
|
||||
while (1)
|
||||
{
|
||||
if (luat_rtos_queue_recv(audio_queue_handle, &audioQueueRecv, NULL, portMAX_DELAY) == 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task this is play priority %d", audioQueueRecv.priority);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task this is play playType %d", audioQueueRecv.playType);
|
||||
if (audioQueueRecv.priority == MONEY_PLAY)
|
||||
{
|
||||
|
||||
if (audioQueueRecv.playType == TTS_PLAY)
|
||||
{
|
||||
luat_audio_play_tts_text(0, audioQueueRecv.message.tts.data, audioQueueRecv.message.tts.len);
|
||||
}
|
||||
else if (audioQueueRecv.playType == FILE_PLAY)
|
||||
{
|
||||
luat_audio_play_multi_files(0, audioQueueRecv.message.file.info, audioQueueRecv.message.file.count);
|
||||
}
|
||||
}
|
||||
else if (audioQueueRecv.priority == PAD_PLAY)
|
||||
{
|
||||
}
|
||||
luat_rtos_semaphore_take(audio_semaphore_handle, LUAT_WAIT_FOREVER);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task this is play wait result %d", result);
|
||||
if (audioQueueRecv.playType == TTS_PLAY) {
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task free tts data");
|
||||
free(audioQueueRecv.message.tts.data);
|
||||
}
|
||||
else if(audioQueueRecv.playType == FILE_PLAY)
|
||||
{
|
||||
free(audioQueueRecv.message.file.info);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task free file data");
|
||||
}
|
||||
}
|
||||
}
|
||||
luat_rtos_task_delete(audio_task_handle);
|
||||
}
|
||||
|
||||
void audio_task_init(void)
|
||||
{
|
||||
luat_rtos_timer_create(&g_s_delay_timer);
|
||||
|
||||
luat_gpio_cfg_t gpio_cfg;
|
||||
luat_gpio_set_default_cfg(&gpio_cfg);
|
||||
|
||||
gpio_cfg.pull = LUAT_GPIO_DEFAULT;
|
||||
|
||||
//如果是780E+音频扩展小板,可以注释掉下面两行代码,因为PA长开
|
||||
gpio_cfg.pin = PA_PWR_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
|
||||
gpio_cfg.pin = CODEC_PWR_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.alt_fun = CODEC_PWR_PIN_ALT_FUN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
|
||||
luat_audio_play_global_init(audio_event_cb, audio_data_cb, luat_audio_play_file_default_fun, luat_audio_play_tts_default_fun, NULL);
|
||||
ivCStrA sdk_id = AISOUND_SDK_USERID_16K;
|
||||
luat_audio_play_tts_set_resource(ivtts_16k, sdk_id, NULL);
|
||||
// luat_i2s_base_setup(0, I2S_MODE_I2S, I2S_FRAME_SIZE_16_16); //如果是780E+音频扩展小板,打开这行注释代码,这个配置对应ES7148/ES7149
|
||||
luat_i2s_base_setup(0, I2S_MODE_MSB, I2S_FRAME_SIZE_16_16); //此处配置对应TM8211
|
||||
luat_rtos_semaphore_create(&audio_semaphore_handle, 1);
|
||||
|
||||
luat_rtos_queue_create(&audio_queue_handle, AUDIO_QUEUE_SIZE, sizeof(audioQueueData));
|
||||
audioQueueData powerOn = {0};
|
||||
powerOn.playType = TTS_PLAY;
|
||||
powerOn.priority = MONEY_PLAY;
|
||||
char str[] = "正在开机";
|
||||
powerOn.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(powerOn.message.tts.data, str, sizeof(str));
|
||||
powerOn.message.tts.len = sizeof(str);
|
||||
if (-1 == luat_rtos_queue_send(audio_queue_handle, &powerOn, NULL, 0))
|
||||
{
|
||||
free(powerOn.message.tts.data);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task start send audio fail");
|
||||
}
|
||||
int result = luat_rtos_task_create(&audio_task_handle, 2048, 20, "mqtt", audio_task, NULL, NULL);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task create task result %d", result);
|
||||
}
|
||||
@@ -0,0 +1,36 @@
|
||||
#include "FreeRTOS.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "common_api.h"
|
||||
#include "luat_debug.h"
|
||||
#include "luat_adc.h"
|
||||
static luat_rtos_task_handle charge_task_handle;
|
||||
|
||||
#define ADC_ID_VBAT 11
|
||||
static volatile uint16_t vbat = 0;
|
||||
|
||||
uint16_t get_vbat()
|
||||
{
|
||||
return vbat;
|
||||
}
|
||||
|
||||
static void charge_task(void *param)
|
||||
{
|
||||
int origin, revert;
|
||||
luat_adc_open(ADC_ID_VBAT, NULL);
|
||||
luat_adc_read(ADC_ID_VBAT, &origin, &revert);
|
||||
luat_rtos_task_sleep(1000);
|
||||
while (1)
|
||||
{
|
||||
luat_adc_read(ADC_ID_VBAT, &origin, &revert);
|
||||
vbat = revert;
|
||||
luat_rtos_task_sleep(60000);
|
||||
}
|
||||
luat_rtos_task_delete(charge_task_handle);
|
||||
}
|
||||
|
||||
|
||||
void charge_task_init(void)
|
||||
{
|
||||
int result = luat_rtos_task_create(&charge_task_handle, 256, 20, "charge task", charge_task, NULL, NULL);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_charge_task create task result %d", result);
|
||||
}
|
||||
@@ -0,0 +1,696 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
#include "bsp.h"
|
||||
#include "bsp_custom.h"
|
||||
#include "common_api.h"
|
||||
#include "cJSON.h"
|
||||
#include "MQTTClient.h"
|
||||
#include "audio_task.h"
|
||||
#include "audio_file.h"
|
||||
#include "math.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_mobile.h"
|
||||
#include "luat_debug.h"
|
||||
#include "luat_pm.h"
|
||||
#include "mqtt_publish.h"
|
||||
uint8_t g_s_is_link_up = 0;
|
||||
static luat_rtos_semaphore_t net_semaphore_handle;
|
||||
static luat_rtos_task_handle mqtt_task_handle;
|
||||
extern luat_rtos_queue_t audio_queue_handle;
|
||||
|
||||
#define MQTT_HOST "lbsmqtt.airm2m.com" // MQTT服务器的地址和端口号
|
||||
#define MQTT_PORT 1884
|
||||
|
||||
#define MQTT_SEND_BUFF_LEN (1024)
|
||||
#define MQTT_RECV_BUFF_LEN (1024)
|
||||
|
||||
#define CLIENTID "12345678"
|
||||
const static char mqtt_sub_topic_head[] = "/sub/topic/money/"; //订阅的主题头,待与设备imei进行拼接
|
||||
const static char mqtt_pub_topic[] = "/pub/topic/message"; //发布的主题
|
||||
static char mqtt_send_payload[] = "hello mqtt_test!!!";
|
||||
static char mqtt_sub_topic[40]; //订阅的主题,待存放订阅的主题头和设备imei,共计17+15,32个字符
|
||||
static bool netStatus = false;
|
||||
static bool serverStatus = false;
|
||||
|
||||
bool getNetStatus()
|
||||
{
|
||||
return netStatus;
|
||||
}
|
||||
bool getServerStatus()
|
||||
{
|
||||
return serverStatus;
|
||||
}
|
||||
|
||||
int fomatMoney(int num, audioQueueData *data, int *index, BOOL flag)
|
||||
{
|
||||
uint32_t audioArray[10][2] =
|
||||
{
|
||||
{audio0, sizeof(audio0)},
|
||||
{audio1, sizeof(audio1)},
|
||||
{audio2, sizeof(audio2)},
|
||||
{audio3, sizeof(audio3)},
|
||||
{audio4, sizeof(audio4)},
|
||||
{audio5, sizeof(audio5)},
|
||||
{audio6, sizeof(audio6)},
|
||||
{audio7, sizeof(audio7)},
|
||||
{audio8, sizeof(audio8)},
|
||||
{audio9, sizeof(audio9)}
|
||||
};
|
||||
int thousand = (num - num % 1000) / 1000;
|
||||
int hundred = ((num % 1000) - ((num % 1000) % 100)) / 100;
|
||||
int ten = ((num % 100) - ((num % 100) % 10)) / 10;
|
||||
int unit = num % 10;
|
||||
if (thousand == 0)
|
||||
{
|
||||
thousand = -1;
|
||||
if (hundred == 0)
|
||||
{
|
||||
hundred = -1;
|
||||
if (ten == 0)
|
||||
{
|
||||
ten = -1;
|
||||
if (unit == 0)
|
||||
{
|
||||
unit = -1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (unit == 0)
|
||||
{
|
||||
unit = -1;
|
||||
if (ten == 0)
|
||||
{
|
||||
ten = -1;
|
||||
if (hundred == 0)
|
||||
{
|
||||
hundred = -1;
|
||||
if (thousand == 0)
|
||||
{
|
||||
thousand = -1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (ten == 0 && hundred == 0)
|
||||
{
|
||||
ten = -1;
|
||||
}
|
||||
if (thousand != -1)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
if(2 == thousand)
|
||||
{
|
||||
data->message.file.info[*index].address = audioliang;
|
||||
data->message.file.info[*index].rom_data_len = audioliangSize;
|
||||
}
|
||||
else
|
||||
{
|
||||
data->message.file.info[*index].address = audioArray[thousand][0];
|
||||
data->message.file.info[*index].rom_data_len = audioArray[thousand][1];
|
||||
}
|
||||
}
|
||||
*index += 1;
|
||||
if (flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audio1000;
|
||||
data->message.file.info[*index].rom_data_len = sizeof(audio1000);
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
if (hundred != -1)
|
||||
{
|
||||
if(flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
if(2 == hundred)
|
||||
{
|
||||
data->message.file.info[*index].address = audioliang;
|
||||
data->message.file.info[*index].rom_data_len = audioliangSize;
|
||||
}
|
||||
else
|
||||
{
|
||||
data->message.file.info[*index].address = audioArray[hundred][0];
|
||||
data->message.file.info[*index].rom_data_len = audioArray[hundred][1];
|
||||
}
|
||||
}
|
||||
*index += 1;
|
||||
if(flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audio100;
|
||||
data->message.file.info[*index].rom_data_len = sizeof(audio100);
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
if (ten != -1)
|
||||
{
|
||||
if (!(ten == 1 && hundred == -1 && thousand == -1))
|
||||
{
|
||||
if(flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audioArray[ten][0];
|
||||
data->message.file.info[*index].rom_data_len = audioArray[ten][1];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
if (ten != 0)
|
||||
{
|
||||
if(flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audio10;
|
||||
data->message.file.info[*index].rom_data_len = sizeof(audio10);
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
}
|
||||
if (unit != -1)
|
||||
{
|
||||
if(flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audioArray[unit][0];
|
||||
data->message.file.info[*index].rom_data_len = audioArray[unit][1];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
static int strToFile(char *money, audioQueueData *data, int *index, bool flag)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->message.file.info[*index].address = audiozhifubao;
|
||||
data->message.file.info[*index].rom_data_len = sizeof(audiozhifubao);
|
||||
}
|
||||
*index += 1;
|
||||
uint32_t audioArray[10][2] =
|
||||
{
|
||||
{audio0, sizeof(audio0)},
|
||||
{audio1, sizeof(audio1)},
|
||||
{audio2, sizeof(audio2)},
|
||||
{audio3, sizeof(audio3)},
|
||||
{audio4, sizeof(audio4)},
|
||||
{audio5, sizeof(audio5)},
|
||||
{audio6, sizeof(audio6)},
|
||||
{audio7, sizeof(audio7)},
|
||||
{audio8, sizeof(audio8)},
|
||||
{audio9, sizeof(audio9)}
|
||||
};
|
||||
int count = 0;
|
||||
int integer = 0;
|
||||
char *str = NULL;
|
||||
char intStr[8] = {0};
|
||||
char decStr[3] = {0};
|
||||
str = strstr(money, ".");
|
||||
if (str != NULL)
|
||||
{
|
||||
memcpy(intStr, money, str - money);
|
||||
str = str + 1;
|
||||
memcpy(decStr, str, 2);
|
||||
integer = atoi(intStr);
|
||||
}
|
||||
else
|
||||
{
|
||||
integer = atoi(money);
|
||||
}
|
||||
if (integer >= 10000)
|
||||
{
|
||||
int filecount = fomatMoney(integer / 10000, data, index, flag);
|
||||
if (flag)
|
||||
{
|
||||
if((2 == *index) && (data->message.file.info[1].address == audio2))
|
||||
{
|
||||
data->message.file.info[1].address = audioliang;
|
||||
data->message.file.info[1].rom_data_len = sizeof(audioliang);
|
||||
}
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audio10000;
|
||||
data->message.file.info[*index].rom_data_len = sizeof(audio10000);
|
||||
}
|
||||
*index += 1;
|
||||
if (((integer % 10000) < 1000) && ((integer % 10000) != 0))
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audioArray[0][0];
|
||||
data->message.file.info[*index].rom_data_len = audioArray[0][1];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
}
|
||||
if ((integer % 10000) > 0)
|
||||
{
|
||||
int filecount = fomatMoney(integer % 10000, data, index, flag);
|
||||
}
|
||||
if (*index == 1)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audioArray[0][0];
|
||||
data->message.file.info[*index].rom_data_len = audioArray[0][1];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
int fraction = atoi(decStr);
|
||||
if (fraction > 0)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audiodot;
|
||||
data->message.file.info[*index].rom_data_len = sizeof(audiodot);
|
||||
}
|
||||
*index += 1;
|
||||
if (fraction >= 10)
|
||||
{
|
||||
int ten = fraction / 10;
|
||||
int unit = fraction % 10;
|
||||
if (ten != 0 && unit != 0)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audioArray[ten][0];
|
||||
data->message.file.info[*index].rom_data_len = audioArray[ten][1];
|
||||
}
|
||||
*index += 1;
|
||||
if(flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audioArray[unit][0];
|
||||
data->message.file.info[*index].rom_data_len = audioArray[unit][1];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
else if(ten == 0 && unit!=0)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audioArray[0][0];
|
||||
data->message.file.info[*index].rom_data_len = audioArray[0][1];
|
||||
}
|
||||
*index += 1;
|
||||
if(flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audioArray[unit][0];
|
||||
data->message.file.info[*index].rom_data_len = audioArray[0][1];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
else if(ten !=0 && unit == 0)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audioArray[ten][0];
|
||||
data->message.file.info[*index].rom_data_len = audioArray[ten][1];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if(decStr[0] == 0x30)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audioArray[0][0];
|
||||
data->message.file.info[*index].rom_data_len = audioArray[0][1];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
if (flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audioArray[fraction][0];
|
||||
data->message.file.info[*index].rom_data_len = audioArray[fraction][1];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
}
|
||||
if (flag)
|
||||
{
|
||||
data->message.file.info[*index].path = NULL;
|
||||
data->message.file.info[*index].address = audioyuan;
|
||||
data->message.file.info[*index].rom_data_len = sizeof(audioyuan);
|
||||
}
|
||||
*index += 1;
|
||||
return count;
|
||||
}
|
||||
|
||||
void messageArrived(MessageData* data)
|
||||
{
|
||||
if (strcmp(mqtt_sub_topic, data->topicName->lenstring.data) == 0)
|
||||
{
|
||||
cJSON *boss = NULL;
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_mqtt mqtt Message arrived on topic %.*s: %.*s\n", data->topicName->lenstring.len, data->topicName->lenstring.data, data->message->payloadlen, data->message->payload);
|
||||
boss = cJSON_Parse((const char *)data->message->payload);
|
||||
if (boss == NULL){
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_mqtt cjson parse fail");
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_mqtt cjson parse success");
|
||||
cJSON *money = cJSON_GetObjectItem(boss, "money");
|
||||
if(money == NULL)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_mqtt Missing amount field %d", money);
|
||||
return 0;
|
||||
}
|
||||
if (cJSON_IsString(money))
|
||||
{
|
||||
audioQueueData moneyPlay = {0};
|
||||
moneyPlay.priority = MONEY_PLAY;
|
||||
moneyPlay.playType = FILE_PLAY;
|
||||
char* str = NULL;
|
||||
str = strstr(money->valuestring, ".");
|
||||
//判断金额长度是否大于8个,也就是千万级别的金额,如果是,则播报收款成功,如果不是,则播报对应金额,这里并未对金额字段做合法性判断
|
||||
if (str != NULL)
|
||||
{
|
||||
if((str - money->valuestring) > 8)
|
||||
{
|
||||
moneyPlay.message.file.info = (audio_play_info_t *)calloc(1, sizeof(audio_play_info_t));
|
||||
moneyPlay.message.file.info->address = audioshoukuanchenggong;
|
||||
moneyPlay.message.file.info->rom_data_len = audioshoukuanchenggongSize;
|
||||
moneyPlay.message.file.count = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
str++;
|
||||
//如果小数点位数大于两位,则说明数字金额不合法,播报收款成功
|
||||
if(strlen(str) > 2)
|
||||
{
|
||||
moneyPlay.message.file.info = (audio_play_info_t *)calloc(1, sizeof(audio_play_info_t));
|
||||
moneyPlay.message.file.info->address = audioshoukuanchenggong;
|
||||
moneyPlay.message.file.info->rom_data_len = audioshoukuanchenggongSize;
|
||||
moneyPlay.message.file.count = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
//调用strToFile来将金额格式化为对应的文件播报数据,需要调用两次,第一次获取需要malloc的空间,第二次将文件数据放进空间里
|
||||
int index = 0;
|
||||
strToFile(money->valuestring, &moneyPlay, &index, false);
|
||||
moneyPlay.message.file.info = (audio_play_info_t *)calloc(index, sizeof(audio_play_info_t));
|
||||
index = 0;
|
||||
strToFile(money->valuestring, &moneyPlay, &index, true);
|
||||
moneyPlay.message.file.count = index;
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if(strlen(money->valuestring) > 8)
|
||||
{
|
||||
moneyPlay.message.file.info = (audio_play_info_t *)calloc(1, sizeof(audio_play_info_t));
|
||||
moneyPlay.message.file.info->address = audioshoukuanchenggong;
|
||||
moneyPlay.message.file.info->rom_data_len = audioshoukuanchenggongSize;
|
||||
moneyPlay.message.file.count = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
//调用strToFile来将金额格式化为对应的文件播报数据,需要调用两次,第一次获取需要malloc的空间,第二次将文件数据放进空间里
|
||||
int index = 0;
|
||||
strToFile(money->valuestring, &moneyPlay, &index, false);
|
||||
moneyPlay.message.file.info = (audio_play_info_t *)calloc(index, sizeof(audio_play_info_t));
|
||||
index = 0;
|
||||
strToFile(money->valuestring, &moneyPlay, &index, true);
|
||||
moneyPlay.message.file.count = index;
|
||||
}
|
||||
}
|
||||
if (-1 == luat_rtos_queue_send(audio_queue_handle, &moneyPlay, NULL, 0)){
|
||||
free(moneyPlay.message.file.info);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_mqtt sub queue send error");
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_mqtt money data is invalid %d", cJSON_IsString(money));
|
||||
}
|
||||
}
|
||||
cJSON_Delete(boss);
|
||||
}
|
||||
}
|
||||
|
||||
static void mobile_event_cb(LUAT_MOBILE_EVENT_E event, uint8_t index, uint8_t status)
|
||||
{
|
||||
switch(event)
|
||||
{
|
||||
case LUAT_MOBILE_EVENT_CFUN:
|
||||
LUAT_DEBUG_PRINT("CFUN消息,status %d", status);
|
||||
break;
|
||||
case LUAT_MOBILE_EVENT_SIM:
|
||||
LUAT_DEBUG_PRINT("SIM卡消息");
|
||||
switch(status)
|
||||
{
|
||||
case LUAT_MOBILE_SIM_READY:
|
||||
LUAT_DEBUG_PRINT("SIM卡正常工作");
|
||||
break;
|
||||
case LUAT_MOBILE_NO_SIM:
|
||||
LUAT_DEBUG_PRINT("SIM卡不存在");
|
||||
break;
|
||||
case LUAT_MOBILE_SIM_NEED_PIN:
|
||||
LUAT_DEBUG_PRINT("SIM卡需要输入PIN码");
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case LUAT_MOBILE_EVENT_REGISTER_STATUS:
|
||||
LUAT_DEBUG_PRINT("移动网络服务状态变更,当前为%d", status);
|
||||
break;
|
||||
case LUAT_MOBILE_EVENT_CELL_INFO:
|
||||
switch(status)
|
||||
{
|
||||
case LUAT_MOBILE_CELL_INFO_UPDATE:
|
||||
break;
|
||||
case LUAT_MOBILE_SIGNAL_UPDATE:
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case LUAT_MOBILE_EVENT_PDP:
|
||||
LUAT_DEBUG_PRINT("CID %d PDP激活状态变更为 %d", index, status);
|
||||
break;
|
||||
case LUAT_MOBILE_EVENT_NETIF:
|
||||
LUAT_DEBUG_PRINT("internet工作状态变更为 %d", status);
|
||||
switch (status)
|
||||
{
|
||||
case LUAT_MOBILE_NETIF_LINK_ON:
|
||||
LUAT_DEBUG_PRINT("可以上网");
|
||||
g_s_is_link_up = 1;
|
||||
break;
|
||||
default:
|
||||
g_s_is_link_up = 0;
|
||||
LUAT_DEBUG_PRINT("不能上网");
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case LUAT_MOBILE_EVENT_TIME_SYNC:
|
||||
LUAT_DEBUG_PRINT("通过移动网络同步了UTC时间");
|
||||
break;
|
||||
case LUAT_MOBILE_EVENT_CSCON:
|
||||
LUAT_DEBUG_PRINT("RRC状态 %d", status);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
extern luat_rtos_task_handle mqtt_publish_task_handle;
|
||||
extern void mqtt_publish_task(void *args);
|
||||
static void mqtt_demo(void){
|
||||
int rc = 0;
|
||||
unsigned char mqttSendbuf[MQTT_SEND_BUFF_LEN] = {0}, mqttReadbuf[MQTT_RECV_BUFF_LEN] = {0};
|
||||
static MQTTClient mqttClient;
|
||||
static Network n = {0};
|
||||
|
||||
MQTTMessage message = {0};
|
||||
MQTTPacket_connectData connectData = MQTTPacket_connectData_initializer;
|
||||
connectData.MQTTVersion = 4;
|
||||
int ret = 0;
|
||||
char str[32] = {0};
|
||||
char clientId[17] = {0};
|
||||
char username[17] = {0};
|
||||
char password[17] = {0};
|
||||
ret = luat_kv_get("clientId", str, 17); //从数据库中读取clientId
|
||||
if(ret > 0 )
|
||||
{
|
||||
memcpy(clientId, str, 16); //留一位确保字符串结尾能有0x00
|
||||
connectData.clientID.cstring = clientId;
|
||||
}
|
||||
else //数据库中没有写入过clientId,获取设备imei作为clientId
|
||||
{
|
||||
int result = 0;
|
||||
result = luat_mobile_get_imei(0, clientId, 15); //imei是15位,留一个位置放0x00
|
||||
if(result <= 0)
|
||||
{
|
||||
connectData.clientID.cstring = CLIENTID;
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_mqtt clientid get fail");
|
||||
}
|
||||
else
|
||||
{
|
||||
connectData.clientID.cstring = clientId;
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_mqtt clientid get success %s", clientId);
|
||||
}
|
||||
}
|
||||
memset(str, 0, 32);
|
||||
ret = luat_kv_get("username", str, 17); //从数据库中读取username,如果没读到,则用默认的
|
||||
if(ret > 0 )
|
||||
{
|
||||
memcpy(username, str, 16); //留一位确保字符串结尾能有0x00
|
||||
connectData.username.cstring = username;
|
||||
}
|
||||
else
|
||||
{
|
||||
connectData.username.cstring = NULL;
|
||||
}
|
||||
memset(str, 0, 32);
|
||||
ret = luat_kv_get("password", str, 17); //从数据库中读取password,如果没读到,则用默认的
|
||||
if(ret > 0 )
|
||||
{
|
||||
memcpy(password, str, 16); //留一位确保字符串结尾能有0x00
|
||||
connectData.password.cstring = password;
|
||||
}
|
||||
else
|
||||
{
|
||||
connectData.password.cstring = NULL;
|
||||
}
|
||||
memset(str, 0, 32);
|
||||
memset(mqtt_sub_topic, 0x00, sizeof(mqtt_sub_topic));
|
||||
snprintf(mqtt_sub_topic, 40, "%s%s", mqtt_sub_topic_head, clientId);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_mqtt subscribe_topic %s %s %s %s", mqtt_sub_topic, clientId, username, password);
|
||||
connectData.keepAliveInterval = 120;
|
||||
|
||||
while(!g_s_is_link_up)
|
||||
{
|
||||
luat_rtos_task_sleep(1000);
|
||||
}
|
||||
// 设置my_app标记可以休眠到LIGHT等级
|
||||
luat_pm_set_sleep_mode(LUAT_PM_SLEEP_MODE_LIGHT, "my_app");
|
||||
|
||||
NetworkInit(&n);
|
||||
MQTTClientInit(&mqttClient, &n, 40000, mqttSendbuf, MQTT_SEND_BUFF_LEN, mqttReadbuf, MQTT_RECV_BUFF_LEN);
|
||||
|
||||
if ((NetworkConnect(&n, MQTT_HOST, MQTT_PORT)) != 0){
|
||||
mqttClient.keepAliveInterval = connectData.keepAliveInterval;
|
||||
mqttClient.ping_outstanding = 1;
|
||||
goto error;
|
||||
}else{
|
||||
if ((MQTTConnect(&mqttClient, &connectData)) != 0){
|
||||
mqttClient.ping_outstanding = 1;
|
||||
goto error;
|
||||
}else{
|
||||
LUAT_DEBUG_PRINT("MQTTStartTask \n");
|
||||
#if defined(MQTT_TASK)
|
||||
if ((MQTTStartTask(&mqttClient)) != pdPASS){
|
||||
goto error;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
}
|
||||
while (1){
|
||||
// 支付报文一般来说不能丢失,也最好不要重复发送,这里设置qos为1即可,保证只收到一次
|
||||
if ((rc = MQTTSubscribe(&mqttClient, mqtt_sub_topic, 1, messageArrived)) != 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("mqtt Return code from MQTT subscribe error is %d\n", rc);
|
||||
}
|
||||
else
|
||||
{
|
||||
serverStatus = true;
|
||||
audioQueueData welcome = {0};
|
||||
welcome.playType = TTS_PLAY;
|
||||
welcome.priority = MONEY_PLAY;
|
||||
char str[] = "服务器连接成功";
|
||||
welcome.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(welcome.message.tts.data, str, sizeof(str));
|
||||
welcome.message.tts.len = sizeof(str);
|
||||
if (-1 == luat_rtos_queue_send(audio_queue_handle, &welcome, NULL, 0)){
|
||||
free(welcome.message.tts.data);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_mqtt sub audio queue send error");
|
||||
}
|
||||
if (mqtt_publish_task_handle == NULL)
|
||||
{
|
||||
luat_rtos_task_create(&mqtt_publish_task_handle, 2048, 20, "mqtt_publish_task", mqtt_publish_task, (void *)&mqttClient, 10);
|
||||
}
|
||||
}
|
||||
|
||||
while (1)
|
||||
{
|
||||
if(MQTTIsConnected(&mqttClient) == 0){
|
||||
goto error;
|
||||
}
|
||||
|
||||
|
||||
luat_rtos_task_sleep(5000);
|
||||
}
|
||||
error:
|
||||
while(!g_s_is_link_up){
|
||||
luat_rtos_task_sleep(1000);
|
||||
}
|
||||
|
||||
if (rc = MQTTReConnect(&mqttClient, &connectData) != 0){
|
||||
luat_rtos_task_sleep(5000);
|
||||
LUAT_DEBUG_PRINT("MQTTReConnect %d\n", rc);
|
||||
goto error;
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("MQTTReConnect OK");
|
||||
}
|
||||
}
|
||||
luat_rtos_task_delete(mqtt_task_handle);
|
||||
}
|
||||
|
||||
static void task_init(void){
|
||||
luat_mobile_event_register_handler(mobile_event_cb);
|
||||
}
|
||||
|
||||
static void mqttclient_task_init(void){
|
||||
int result = luat_rtos_task_create(&mqtt_task_handle, 4096, 20, "mqtt", mqtt_demo, NULL, NULL);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_mqtt create task result %d", result);
|
||||
}
|
||||
|
||||
extern void led_task_init(void);
|
||||
extern void key_task_init(void);
|
||||
extern void charge_task_init(void);
|
||||
extern void usb_uart_init(void);
|
||||
extern void fdb_init(void);
|
||||
extern void mqtt_send_task_init(void);
|
||||
|
||||
|
||||
INIT_HW_EXPORT(task_init, "1");
|
||||
INIT_HW_EXPORT(fdb_init, "1");
|
||||
INIT_TASK_EXPORT(mqttclient_task_init, "2");
|
||||
INIT_TASK_EXPORT(audio_task_init, "2");
|
||||
INIT_TASK_EXPORT(led_task_init, "2");
|
||||
INIT_TASK_EXPORT(key_task_init, "3");
|
||||
INIT_TASK_EXPORT(charge_task_init, "2");
|
||||
INIT_TASK_EXPORT(usb_uart_init, "2");
|
||||
INIT_TASK_EXPORT(mqtt_send_task_init, "3");
|
||||
|
||||
@@ -0,0 +1,335 @@
|
||||
#include "FreeRTOS.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_gpio.h"
|
||||
#include "common_api.h"
|
||||
#include "luat_debug.h"
|
||||
#include "luat_pm.h"
|
||||
#include "audio_task.h"
|
||||
#define KEY1_MESSAGE (0x1)
|
||||
#define KEY2_MESSAGE (0x2)
|
||||
#define KEY3_MESSAGE (0x3)
|
||||
#define PWR_MESSAGE (0x4)
|
||||
#define CHARGE_START_MESSAGE (0x5)
|
||||
#define CHARGE_END_MESSAGE (0x6)
|
||||
|
||||
#define PAD_PIN_ALT_FUN 0
|
||||
#define KEY_QUEUE_SIZE 2
|
||||
extern uint16_t get_vbat();
|
||||
typedef struct
|
||||
{
|
||||
uint8_t messageId;
|
||||
} key_message_t;
|
||||
|
||||
static luat_rtos_task_handle key_task_handle;
|
||||
static luat_rtos_queue_t key_queue_handle;
|
||||
static luat_rtos_timer_t pwrkey_timer_handle;
|
||||
static luat_rtos_timer_t powoff_timer_handle;
|
||||
extern luat_rtos_queue_t audio_queue_handle;
|
||||
|
||||
static luat_rtos_timer_callback_t pwrkey_long_press_callback(void *param)
|
||||
{
|
||||
if (param == &pwrkey_timer_handle)
|
||||
{
|
||||
luat_stop_rtos_timer(pwrkey_timer_handle);
|
||||
luat_rtos_timer_start(powoff_timer_handle, 3000, 0, pwrkey_long_press_callback, &powoff_timer_handle);
|
||||
audioQueueData powerOff = {0};
|
||||
powerOff.playType = TTS_PLAY;
|
||||
powerOff.priority = MONEY_PLAY;
|
||||
char str[] = "正在关机";
|
||||
powerOff.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(powerOff.message.tts.data, str, sizeof(str));
|
||||
powerOff.message.tts.len = sizeof(str);
|
||||
if (-1 == luat_rtos_queue_send(audio_queue_handle, &powerOff, NULL, 0))
|
||||
{
|
||||
free(powerOff.message.tts.data);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_key_task start send audio fail");
|
||||
}
|
||||
}
|
||||
else if (param == &powoff_timer_handle)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("poweroff");
|
||||
luat_pm_poweroff();
|
||||
}
|
||||
}
|
||||
|
||||
luat_pm_pwrkey_callback_t pwrkey_callback(LUAT_PM_POWERKEY_STATE_E status)
|
||||
{
|
||||
if (LUAT_PM_PWRKEY_PRESS == status)
|
||||
{
|
||||
luat_rtos_timer_start(pwrkey_timer_handle, 3000, 0, pwrkey_long_press_callback, &pwrkey_timer_handle);
|
||||
}
|
||||
else if (LUAT_PM_PWRKEY_RELEASE == status)
|
||||
{
|
||||
uint8_t id = PWR_MESSAGE;
|
||||
luat_rtos_queue_send(key_queue_handle, &id, NULL, 0);
|
||||
}
|
||||
}
|
||||
|
||||
static void key_task(void *param)
|
||||
{
|
||||
uint8_t msgId = 0;
|
||||
int volume = 15;
|
||||
int ret = 0;
|
||||
while (1)
|
||||
{
|
||||
if (luat_rtos_queue_recv(key_queue_handle, &msgId, NULL, LUAT_WAIT_FOREVER) == 0)
|
||||
{
|
||||
switch (msgId)
|
||||
{
|
||||
case KEY1_MESSAGE:
|
||||
{
|
||||
audioQueueData volMinus = {0};
|
||||
volMinus.playType = TTS_PLAY;
|
||||
volMinus.priority = MONEY_PLAY;
|
||||
volume = 15;
|
||||
ret = luat_kv_get("volume", &volume, sizeof(int));
|
||||
if (ret > 0)
|
||||
{
|
||||
if (volume > 3)
|
||||
{
|
||||
volume = volume - 3;
|
||||
if (volume < 3)
|
||||
{
|
||||
volume = 3;
|
||||
}
|
||||
luat_kv_set("volume", &volume, sizeof(int));
|
||||
}
|
||||
if (volume == 3)
|
||||
{
|
||||
char str[] = "音量最小";
|
||||
volMinus.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(volMinus.message.tts.data, str, sizeof(str));
|
||||
volMinus.message.tts.len = sizeof(str);
|
||||
}
|
||||
else
|
||||
{
|
||||
char str[] = "音量减";
|
||||
volMinus.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(volMinus.message.tts.data, str, sizeof(str));
|
||||
volMinus.message.tts.len = sizeof(str);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
char str[] = "音量减";
|
||||
volMinus.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(volMinus.message.tts.data, str, sizeof(str));
|
||||
volMinus.message.tts.len = sizeof(str);
|
||||
}
|
||||
if (-1 == luat_rtos_queue_send(audio_queue_handle, &volMinus, NULL, 0))
|
||||
{
|
||||
free(volMinus.message.tts.data);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_key_task start send audio fail");
|
||||
}
|
||||
break;
|
||||
}
|
||||
case KEY2_MESSAGE:
|
||||
{
|
||||
audioQueueData volPlus = {0};
|
||||
volPlus.playType = TTS_PLAY;
|
||||
volPlus.priority = MONEY_PLAY;
|
||||
volume = 4;
|
||||
ret = luat_kv_get("volume", &volume, sizeof(int));
|
||||
if (ret > 0)
|
||||
{
|
||||
if (volume < 21)
|
||||
{
|
||||
volume = volume + 3;
|
||||
if (volume > 21)
|
||||
{
|
||||
volume = 21;
|
||||
}
|
||||
luat_kv_set("volume", &volume, sizeof(int));
|
||||
}
|
||||
if (volume == 21)
|
||||
{
|
||||
char str[] = "音量最大";
|
||||
volPlus.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(volPlus.message.tts.data, str, sizeof(str));
|
||||
volPlus.message.tts.len = sizeof(str);
|
||||
}
|
||||
else
|
||||
{
|
||||
char str[] = "音量加";
|
||||
volPlus.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(volPlus.message.tts.data, str, sizeof(str));
|
||||
volPlus.message.tts.len = sizeof(str);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
char str[] = "音量加";
|
||||
volPlus.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(volPlus.message.tts.data, str, sizeof(str));
|
||||
volPlus.message.tts.len = sizeof(str);
|
||||
}
|
||||
if (-1 == luat_rtos_queue_send(audio_queue_handle, &volPlus, NULL, 0))
|
||||
{
|
||||
free(volPlus.message.tts.data);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_key_task start send audio fail");
|
||||
}
|
||||
break;
|
||||
}
|
||||
case KEY3_MESSAGE:
|
||||
{
|
||||
audioQueueData func = {0};
|
||||
func.playType = TTS_PLAY;
|
||||
func.priority = MONEY_PLAY;
|
||||
char str[] = "功能键";
|
||||
func.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(func.message.tts.data, str, sizeof(str));
|
||||
func.message.tts.len = sizeof(str);
|
||||
if (-1 == luat_rtos_queue_send(audio_queue_handle, &func, NULL, 0))
|
||||
{
|
||||
free(func.message.tts.data);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_key_task start send audio fail");
|
||||
}
|
||||
break;
|
||||
}
|
||||
case PWR_MESSAGE:
|
||||
{
|
||||
if (1 == luat_rtos_timer_is_active(pwrkey_timer_handle))
|
||||
{
|
||||
luat_stop_rtos_timer(pwrkey_timer_handle);
|
||||
uint16_t vbat = get_vbat();
|
||||
audioQueueData currentElec = {0};
|
||||
currentElec.playType = TTS_PLAY;
|
||||
currentElec.priority = MONEY_PLAY;
|
||||
if (vbat > 4000)
|
||||
{
|
||||
char str[] = "当前电量高";
|
||||
currentElec.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(currentElec.message.tts.data, str, sizeof(str));
|
||||
currentElec.message.tts.len = sizeof(str);
|
||||
}
|
||||
else if (vbat > 3700 && vbat < 4000)
|
||||
{
|
||||
char str[] = "当前电量中";
|
||||
currentElec.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(currentElec.message.tts.data, str, sizeof(str));
|
||||
currentElec.message.tts.len = sizeof(str);
|
||||
}
|
||||
else
|
||||
{
|
||||
char str[] = "当前电量低";
|
||||
currentElec.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(currentElec.message.tts.data, str, sizeof(str));
|
||||
currentElec.message.tts.len = sizeof(str);
|
||||
}
|
||||
if (-1 == luat_rtos_queue_send(audio_queue_handle, ¤tElec, NULL, 0))
|
||||
{
|
||||
free(currentElec.message.tts.data);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_key_task start send audio fail");
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
case CHARGE_START_MESSAGE:
|
||||
{
|
||||
audioQueueData chargeIn = {0};
|
||||
chargeIn.playType = TTS_PLAY;
|
||||
chargeIn.priority = MONEY_PLAY;
|
||||
char str[] = "正在充电";
|
||||
chargeIn.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(chargeIn.message.tts.data, str, sizeof(str));
|
||||
chargeIn.message.tts.len = sizeof(str);
|
||||
if (-1 == luat_rtos_queue_send(audio_queue_handle, &chargeIn, NULL, 0))
|
||||
{
|
||||
free(chargeIn.message.tts.data);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_key_task start send audio fail");
|
||||
}
|
||||
break;
|
||||
}
|
||||
case CHARGE_END_MESSAGE:
|
||||
{
|
||||
audioQueueData chargeOut = {0};
|
||||
chargeOut.playType = TTS_PLAY;
|
||||
chargeOut.priority = MONEY_PLAY;
|
||||
char str[] = "充电结束";
|
||||
chargeOut.message.tts.data = malloc(sizeof(str));
|
||||
memcpy(chargeOut.message.tts.data, str, sizeof(str));
|
||||
chargeOut.message.tts.len = sizeof(str);
|
||||
if (-1 == luat_rtos_queue_send(audio_queue_handle, &chargeOut, NULL, 0))
|
||||
{
|
||||
free(chargeOut.message.tts.data);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_key_task start send audio fail");
|
||||
}
|
||||
break;
|
||||
}
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
luat_rtos_task_delete(key_task_handle);
|
||||
}
|
||||
|
||||
luat_pm_wakeup_pad_isr_callback_t down_key_callback(int num)
|
||||
{
|
||||
if (LUAT_PM_WAKEUP_PAD_0 == num)
|
||||
{
|
||||
if (0 == luat_pm_wakeup_pad_get_value(LUAT_PM_WAKEUP_PAD_0))
|
||||
{
|
||||
uint8_t id = KEY1_MESSAGE;
|
||||
luat_rtos_queue_send(key_queue_handle, &id, NULL, 0);
|
||||
}
|
||||
}
|
||||
else if (LUAT_PM_WAKEUP_PAD_3 == num)
|
||||
{
|
||||
if (0 == luat_pm_wakeup_pad_get_value(LUAT_PM_WAKEUP_PAD_3))
|
||||
{
|
||||
uint8_t id = KEY2_MESSAGE;
|
||||
luat_rtos_queue_send(key_queue_handle, &id, NULL, 0);
|
||||
}
|
||||
}
|
||||
else if (LUAT_PM_WAKEUP_PAD_4 == num)
|
||||
{
|
||||
if (0 == luat_pm_wakeup_pad_get_value(LUAT_PM_WAKEUP_PAD_4))
|
||||
{
|
||||
uint8_t id = KEY3_MESSAGE;
|
||||
luat_rtos_queue_send(key_queue_handle, &id, NULL, 0);
|
||||
}
|
||||
}
|
||||
// 新的开发板如果不接电池只插usb,这个中断会一直触发
|
||||
/* else if (LUAT_PM_WAKEUP_PAD_5 == num)
|
||||
{
|
||||
if (0 == luat_pm_wakeup_pad_get_value(LUAT_PM_WAKEUP_PAD_5))
|
||||
{
|
||||
uint8_t id = CHARGE_START_MESSAGE;
|
||||
luat_rtos_queue_send(key_queue_handle, &id, NULL, 0);
|
||||
}
|
||||
else
|
||||
{
|
||||
uint8_t id = CHARGE_END_MESSAGE;
|
||||
luat_rtos_queue_send(key_queue_handle, &id, NULL, 0);
|
||||
}
|
||||
} */
|
||||
}
|
||||
|
||||
void key_task_init(void)
|
||||
{
|
||||
|
||||
luat_rtos_timer_create(&pwrkey_timer_handle);
|
||||
luat_rtos_timer_create(&powoff_timer_handle);
|
||||
|
||||
luat_pm_wakeup_pad_set_callback(down_key_callback);
|
||||
luat_pm_wakeup_pad_cfg_t cfg = {0};
|
||||
cfg.neg_edge_enable = 1;
|
||||
cfg.pos_edge_enable = 0;
|
||||
cfg.pull_up_enable = 1;
|
||||
cfg.pull_down_enable = 0;
|
||||
luat_pm_wakeup_pad_set(true, LUAT_PM_WAKEUP_PAD_0, &cfg);
|
||||
luat_pm_wakeup_pad_set(true, LUAT_PM_WAKEUP_PAD_3, &cfg);
|
||||
luat_pm_wakeup_pad_set(true, LUAT_PM_WAKEUP_PAD_4, &cfg);
|
||||
// 新的开发板如果不接电池只插usb,这个中断会一直触发
|
||||
/* cfg.pos_edge_enable = 1;
|
||||
luat_pm_wakeup_pad_set(true, LUAT_PM_WAKEUP_PAD_5, &cfg); */
|
||||
luat_pm_pwrkey_cfg_t pwrkey_cfg = {0};
|
||||
pwrkey_cfg.long_press_timeout = 3000;
|
||||
pwrkey_cfg.repeat_timeout = 3000;
|
||||
luat_pm_set_pwrkey(LUAT_PM_PWRKEY_WAKEUP_LOWACTIVE_MODE, true, &pwrkey_cfg, pwrkey_callback);
|
||||
|
||||
luat_rtos_queue_create(&key_queue_handle, KEY_QUEUE_SIZE, sizeof(key_message_t));
|
||||
int result = luat_rtos_task_create(&key_task_handle, 1024, 20, "key task", key_task, NULL, NULL);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_key_task create task result %d", result);
|
||||
}
|
||||
@@ -0,0 +1,33 @@
|
||||
#include "common_api.h"
|
||||
#include "luat_debug.h"
|
||||
void fdb_init(void)
|
||||
{
|
||||
luat_kv_init();
|
||||
char value[2];
|
||||
int ret = luat_kv_get("flag", value, 2);
|
||||
//读取kv数据库用户是否初始化过,如果没有,则写入一个flag和需要初始化的值,表示用户已初始化;如果用户初始化过,则不做任何操作
|
||||
LUAT_DEBUG_PRINT("get value result %d", ret);
|
||||
if (ret > 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("get value %s", value);
|
||||
if(memcmp("1", value, strlen("1")))
|
||||
{
|
||||
LUAT_DEBUG_PRINT("need init");
|
||||
ret = luat_kv_set("flag", "1", 2);
|
||||
LUAT_DEBUG_PRINT("init result1 %d", ret);
|
||||
int volume = 15;
|
||||
ret = luat_kv_set("volume", &volume, sizeof(int));
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("no need init");
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
ret = luat_kv_set("flag", "1", 2);
|
||||
int volume = 15;
|
||||
ret = luat_kv_set("volume", &volume, sizeof(int));
|
||||
LUAT_DEBUG_PRINT("init result2 %d", ret);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,51 @@
|
||||
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_gpio.h"
|
||||
#include "common_api.h"
|
||||
#include "luat_debug.h"
|
||||
|
||||
#define LED_PIN_ALT_FUN 0
|
||||
|
||||
#define LED1_PIN HAL_GPIO_24
|
||||
#define LED2_PIN HAL_GPIO_28
|
||||
#define LED3_PIN HAL_GPIO_27
|
||||
|
||||
static luat_rtos_task_handle led_task_handle;
|
||||
|
||||
static void led_task(void *param)
|
||||
{
|
||||
luat_gpio_cfg_t gpio_cfg;
|
||||
luat_gpio_set_default_cfg(&gpio_cfg);
|
||||
luat_rtos_task_handle task_handle;
|
||||
|
||||
gpio_cfg.pull = LUAT_GPIO_DEFAULT;
|
||||
|
||||
//如果是780E+音频扩展小板,需要注释掉下面四行代码,因为这个板子上只有一个可控LED
|
||||
gpio_cfg.pin = LED1_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.pin = LED2_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
|
||||
|
||||
gpio_cfg.pin = LED3_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
|
||||
while (1)
|
||||
{
|
||||
luat_rtos_task_sleep(200);
|
||||
luat_gpio_set(LED1_PIN, 1); //如果是780E+音频扩展小板,需要注释掉此行代码
|
||||
luat_gpio_set(LED2_PIN, 1); //如果是780E+音频扩展小板,需要注释掉此行代码
|
||||
luat_gpio_set(LED3_PIN, 1);
|
||||
luat_rtos_task_sleep(200);
|
||||
luat_gpio_set(LED1_PIN, 0); //如果是780E+音频扩展小板,需要注释掉此行代码
|
||||
luat_gpio_set(LED2_PIN, 0); //如果是780E+音频扩展小板,需要注释掉此行代码
|
||||
luat_gpio_set(LED3_PIN, 0);
|
||||
}
|
||||
luat_rtos_task_delete(led_task_handle);
|
||||
}
|
||||
|
||||
void led_task_init(void)
|
||||
{
|
||||
int result = luat_rtos_task_create(&led_task_handle, 256, 20, "led task", led_task, NULL, NULL);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_led_task create task result %d", result);
|
||||
}
|
||||
@@ -0,0 +1,64 @@
|
||||
#include "luat_debug.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "mqtt_publish.h"
|
||||
#include "MQTTClient.h"
|
||||
luat_rtos_task_handle mqtt_publish_task_handle = NULL;
|
||||
extern uint8_t g_s_is_link_up;
|
||||
void mqtt_publish_task(void *args)
|
||||
{
|
||||
uint32_t id; // 暂时没什么用,因为只有publish的时候才会触发这条消息
|
||||
int rc;
|
||||
MQTTClient *mqttClient;
|
||||
mqttClient = (MQTTClient *)(args);
|
||||
mqtt_publish_para_t *publish_para = NULL;
|
||||
while (1)
|
||||
{
|
||||
if (luat_rtos_message_recv(mqtt_publish_task_handle, &id, (void **)&publish_para, LUAT_WAIT_FOREVER) == 0)
|
||||
{
|
||||
if (!g_s_is_link_up)
|
||||
{
|
||||
if (publish_para->callback != NULL)
|
||||
publish_para->callback(NETWORK_NOT_READY);
|
||||
}
|
||||
else if (MQTTIsConnected(&mqttClient) == 0)
|
||||
{
|
||||
if (publish_para->callback != NULL)
|
||||
publish_para->callback(MQTT_NOT_READY);
|
||||
}
|
||||
else
|
||||
{
|
||||
rc = MQTTPublish(mqttClient, publish_para->publish->topic, &publish_para->publish->message);
|
||||
if (rc != 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("MQTTPublish error %d", rc);
|
||||
if (publish_para->callback != NULL)
|
||||
publish_para->callback(MQTT_PUBLISH_FAIL);
|
||||
}
|
||||
else
|
||||
{
|
||||
if (publish_para->callback != NULL)
|
||||
publish_para->callback(MQTT_PUBLISH_SUCCESS);
|
||||
}
|
||||
}
|
||||
if (publish_para->publish->topic != NULL)
|
||||
{
|
||||
free(publish_para->publish->topic);
|
||||
}
|
||||
|
||||
if (publish_para->publish->message.payload != NULL)
|
||||
{
|
||||
free(publish_para->publish->message.payload);
|
||||
}
|
||||
|
||||
if (publish_para->publish != NULL)
|
||||
{
|
||||
free(publish_para->publish);
|
||||
}
|
||||
|
||||
if (publish_para != NULL)
|
||||
{
|
||||
free(publish_para);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,54 @@
|
||||
#include "luat_debug.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "MQTTClient.h"
|
||||
#include "mqtt_publish.h"
|
||||
luat_rtos_task_handle mqtt_send_task_handle;
|
||||
|
||||
extern luat_rtos_task_handle mqtt_publish_task_handle;
|
||||
|
||||
void publish_callback(int result)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("mqtt_send_task send mqtt message result %d", result);
|
||||
}
|
||||
|
||||
static void mqtt_send_task(void)
|
||||
{
|
||||
while (1)
|
||||
{
|
||||
mqtt_publish_para_t *publish_para = NULL;
|
||||
publish_para = (mqtt_publish_para_t *)malloc(sizeof(mqtt_publish_para_t));
|
||||
memset(publish_para, 0x00, sizeof(mqtt_publish_para_t));
|
||||
|
||||
publish_para->publish = (mqttSendMsg *)malloc(sizeof(mqttSendMsg));
|
||||
memset(publish_para->publish, 0x00, sizeof(mqttSendMsg));
|
||||
|
||||
char topic[] = "/cloud_speaker/publish/test_topic";
|
||||
publish_para->publish->topic = malloc(sizeof(topic));
|
||||
memcpy(publish_para->publish->topic, topic, sizeof(topic));
|
||||
publish_para->publish->topicLen = sizeof(topic);
|
||||
|
||||
char payload[] = "{\"time\": \"2000-00-00\"}";
|
||||
publish_para->publish->message.payload = malloc(sizeof(payload));
|
||||
memcpy(publish_para->publish->message.payload, payload, sizeof(payload));
|
||||
|
||||
publish_para->publish->message.payloadlen = sizeof(payload) - 1;
|
||||
publish_para->publish->message.qos = 1;
|
||||
publish_para->callback = publish_callback;
|
||||
uint32_t id = 0;
|
||||
if (luat_rtos_message_send(mqtt_publish_task_handle, &id, (void *)publish_para) != 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("colud_speaker_mqtt publish message send error");
|
||||
free(publish_para->publish->topic);
|
||||
free(publish_para->publish->message.payload);
|
||||
free(publish_para->publish);
|
||||
free(publish_para);
|
||||
|
||||
}
|
||||
luat_rtos_task_sleep(5000);
|
||||
}
|
||||
}
|
||||
|
||||
void mqtt_send_task_init(void)
|
||||
{
|
||||
luat_rtos_task_create(&mqtt_send_task_handle, 2048, 20, "mqtt_send_task", mqtt_send_task, NULL, 0);
|
||||
}
|
||||
@@ -0,0 +1,112 @@
|
||||
#include "luat_uart.h"
|
||||
#include "luat_debug.h"
|
||||
|
||||
void luat_uart_recv_cb(int uart_id, uint32_t data_len){
|
||||
char* data_buff = malloc(data_len+1);
|
||||
memset(data_buff,0,data_len+1);
|
||||
luat_uart_read(uart_id, data_buff, data_len);
|
||||
LUAT_DEBUG_PRINT("luat_uart_cb uart_id:%d data:%s data_len:%d",uart_id,data_buff,data_len);
|
||||
if (strcmp("AT+CLIENTID?\r\n", data_buff) == 0)
|
||||
{
|
||||
char clientId[32] = {0};
|
||||
int ret = luat_kv_get("clientId", clientId, 16);
|
||||
if(ret > 0 )
|
||||
{
|
||||
luat_uart_write(LUAT_VUART_ID_0, clientId, strlen(clientId));
|
||||
}
|
||||
else
|
||||
{
|
||||
luat_uart_write(LUAT_VUART_ID_0, "OK", strlen("OK"));
|
||||
}
|
||||
}
|
||||
else if (strstr(data_buff, "AT+CLIENTID=") != NULL)
|
||||
{
|
||||
char *flag = NULL;
|
||||
flag = strstr(data_buff, "=");
|
||||
if(flag != NULL)
|
||||
{
|
||||
flag++;
|
||||
char *flag2 = NULL;
|
||||
flag2 = strstr(flag, "\r\n");
|
||||
if (flag2 != NULL)
|
||||
{
|
||||
int ret = luat_kv_set("clientId", flag, strlen(flag) - 2); //减去末尾的\r\n
|
||||
luat_uart_write(LUAT_VUART_ID_0, "OK", strlen("OK"));
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
else if (strcmp("AT+USERNAME?\r\n", data_buff) == 0)
|
||||
{
|
||||
int ret = 0;
|
||||
char name[32] = {0};
|
||||
ret = luat_kv_get("username", name, 31);
|
||||
if (ret > 0)
|
||||
{
|
||||
luat_uart_write(LUAT_VUART_ID_0, name, strlen(name));
|
||||
}
|
||||
else
|
||||
{
|
||||
luat_uart_write(LUAT_VUART_ID_0, "OK", strlen("OK"));
|
||||
}
|
||||
}
|
||||
else if (strstr(data_buff, "AT+USERNAME=") != NULL)
|
||||
{
|
||||
char *flag = NULL;
|
||||
flag = strstr(data_buff, "=");
|
||||
if(flag != NULL)
|
||||
{
|
||||
flag++;
|
||||
char *flag2 = NULL;
|
||||
flag2 = strstr(flag, "\r\n");
|
||||
if (flag2 != NULL)
|
||||
{
|
||||
int ret = luat_kv_set("username", flag, strlen(flag) - 2); //减去末尾的\r\n
|
||||
luat_uart_write(LUAT_VUART_ID_0, "OK", strlen("OK"));
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
else if (strcmp("AT+PASSWORD?\r\n", data_buff) == 0)
|
||||
{
|
||||
int ret = 0;
|
||||
char name[32] = {0};
|
||||
ret = luat_kv_get("password", name, 31);
|
||||
if (ret > 0)
|
||||
{
|
||||
luat_uart_write(LUAT_VUART_ID_0, name, strlen(name));
|
||||
}
|
||||
else
|
||||
{
|
||||
luat_uart_write(LUAT_VUART_ID_0, "OK", strlen("OK"));
|
||||
}
|
||||
}
|
||||
else if (strstr(data_buff, "AT+PASSWORD=") != NULL)
|
||||
{
|
||||
char *flag = NULL;
|
||||
flag = strstr(data_buff, "=");
|
||||
if(flag != NULL)
|
||||
{
|
||||
flag++;
|
||||
char *flag2 = NULL;
|
||||
flag2 = strstr(flag, "\r\n");
|
||||
if (flag2 != NULL)
|
||||
{
|
||||
int ret = luat_kv_set("password", flag, strlen(flag) - 2); //减去末尾的\r\n
|
||||
luat_uart_write(LUAT_VUART_ID_0, "OK", strlen("OK"));
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
free(data_buff);
|
||||
}
|
||||
|
||||
void usb_uart_init(void)
|
||||
{
|
||||
char send_buff[] = "hello LUAT!!!\n";
|
||||
luat_uart_t uart = {
|
||||
.id = LUAT_VUART_ID_0,
|
||||
};
|
||||
luat_uart_setup(&uart);
|
||||
luat_uart_ctrl(LUAT_VUART_ID_0, LUAT_UART_SET_RECV_CALLBACK, luat_uart_recv_cb);
|
||||
}
|
||||
@@ -0,0 +1,34 @@
|
||||
local TARGET_NAME = "cloud_speaker"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
includes(SDK_TOP .. "/thirdparty/audio_decoder")
|
||||
target(TARGET_NAME)
|
||||
local LIB_DIR = "$(buildir)/mqttclient/"
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
add_deps("audio_decoder")
|
||||
add_defines("MQTT_TASK",{public = true})
|
||||
|
||||
includes(SDK_TOP .. "/thirdparty/mqtt")
|
||||
add_deps("mqtt")
|
||||
includes(SDK_TOP .. "/thirdparty/cJSON")
|
||||
-- --加入代码和头文件
|
||||
add_includedirs(SDK_TOP .. "/thirdparty/mqtt/MQTTClient-C/src",{public = true})
|
||||
add_files(SDK_TOP .. "/thirdparty/mqtt/MQTTClient-C/src/*.c",{public = true})
|
||||
add_includedirs(SDK_TOP .. "/PLAT/core/tts/include/16k_lite_ver",{public = true})
|
||||
--加入自己代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
-- add_includedirs("../../thirdparty/fal/inc",{public = true})
|
||||
-- add_includedirs("../../thirdparty/flashdb/inc",{public = true})
|
||||
-- add_includedirs("../../thirdparty/am_kv/inc",{public = true})
|
||||
-- add_files("../../thirdparty/fal/src/*.c",{public = true})
|
||||
-- add_files("../../thirdparty/flashdb/src/*.c",{public = true})
|
||||
-- add_files("../../thirdparty/am_kv/src/*.c",{public = true})
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. "/PLAT/core/lib/libaisound50_16K.a "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,349 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 1
|
||||
#define RTE_UART1_RTS_PIN_EN 1
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN21}, // 0 : gpio16 / 1 : UART1 RTS / 2 : SPI0 SSn
|
||||
// { PAD_PIN22}, // 0 : gpio11 / 1 : UART1 CTS / 2 : SPI0 MOSI
|
||||
// { PAD_PIN23}, // 0 : gpio14 / 1 : UART1 RXD / 2 : SPI0 MISO
|
||||
// { PAD_PIN24}, // 0 : gpio15 / 1 : UART1 TXD / 2 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 21
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 22
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 23
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 24
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 1
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 0
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 1
|
||||
|
||||
// { PAD_PIN13}, // 0 : gpio2 / 1 : UART0 RTSn / 3 : SPI1 SSn
|
||||
// { PAD_PIN14}, // 0 : gpio3 / 1 : UART0 CTSn / 3 : SPI1 MOSI
|
||||
// { PAD_PIN15}, // 0 : gpio4 / 1 : UART0 RXD / 3 : SPI1 MISO
|
||||
// { PAD_PIN16}, // 0 : gpio5 / 1 : UART0 TXD / 3 : SPI1 SCLK
|
||||
#define RTE_SPI1_SSN_BIT 13
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 14
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 15
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 16
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,92 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
|
||||
#include "common_api.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_mem.h"
|
||||
#include "luat_debug.h"
|
||||
|
||||
luat_rtos_task_handle task1_handle;
|
||||
luat_rtos_task_handle task2_handle;
|
||||
|
||||
|
||||
static void hw_demoA_init(void)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("this hw demo1");
|
||||
}
|
||||
|
||||
static void hw_demoB_init(void)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("this hw demo2");
|
||||
}
|
||||
|
||||
static void dr_demoC_init(void)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("this dr demo1");
|
||||
}
|
||||
|
||||
static void dr_demoD_init(void)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("this dr demo2");
|
||||
}
|
||||
|
||||
static void task1(void *param)
|
||||
{
|
||||
while(1)
|
||||
{
|
||||
luat_rtos_task_sleep(1000);
|
||||
LUAT_DEBUG_PRINT("task1 loop");
|
||||
}
|
||||
}
|
||||
|
||||
static void task2(void *param)
|
||||
{
|
||||
while(1)
|
||||
{
|
||||
luat_rtos_task_sleep(1000);
|
||||
LUAT_DEBUG_PRINT("task2 loop");
|
||||
}
|
||||
}
|
||||
|
||||
static void task_demoE_init(void)
|
||||
{
|
||||
luat_rtos_task_create(&task1_handle, 2*1024, 50, "task1", task1, NULL, 0);
|
||||
}
|
||||
|
||||
static void task_demoF_init(void)
|
||||
{
|
||||
luat_rtos_task_create(&task2_handle, 2*1024, 50, "task2", task2, NULL, 0);
|
||||
}
|
||||
|
||||
//启动hw_demoA_init,启动位置硬件初始1级
|
||||
INIT_HW_EXPORT(hw_demoA_init, "1");
|
||||
//启动hw_demoB_init,启动位置硬件初始2级
|
||||
INIT_HW_EXPORT(hw_demoB_init, "2");
|
||||
//启动dr_demoC_init,启动位置驱动1级
|
||||
INIT_DRV_EXPORT(dr_demoC_init, "1");
|
||||
//启动dr_demoD_init,启动位置驱动2级
|
||||
INIT_DRV_EXPORT(dr_demoD_init, "2");
|
||||
//启动task_demoE_init,启动位置任务1级
|
||||
INIT_TASK_EXPORT(task_demoE_init, "1");
|
||||
//启动task_demoF_init,启动位置任务2级
|
||||
INIT_TASK_EXPORT(task_demoF_init, "2");
|
||||
|
||||
@@ -0,0 +1,21 @@
|
||||
local TARGET_NAME = "example"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,354 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 0
|
||||
#define RTE_UART1_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN23}, // 0 : gpio8 / 1 : SPI0 SSn
|
||||
// { PAD_PIN24}, // 0 : gpio9 / 1 : SPI0 MOSI
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 1 : SPI0 MISO
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 1 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 23
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 24
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 25
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 26
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 8
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 1 : SPI1 SSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 1 : SPI1 MOSI
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 1 : SPI1 MISO
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 1 : SPI1 SCLK
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 4 : SPI1 SSn1
|
||||
#define RTE_SPI1_SSN_BIT 27
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 28
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 29
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 30
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 12
|
||||
|
||||
#define RTE_SPI1_SSN1_BIT 31
|
||||
#define RTE_SPI1_SSN1_FUNC PAD_MUX_ALT4
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 0
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,91 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
#include "common_api.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_debug.h"
|
||||
|
||||
#include "luat_adc.h"
|
||||
|
||||
luat_rtos_task_handle adc_task_handle;
|
||||
|
||||
static void task_test_adc(void *param)
|
||||
{
|
||||
int val, val2;
|
||||
|
||||
// adc0和adc1的说明如下:
|
||||
// 1、adc引脚允许输入的最大电压是3.4V
|
||||
// 2、如果采用内部分压,外部不分压的方式,软件上通过调用luat_adc_ctrl接口来设置量程,支持1.2V、1.4V、1.6、1.9、2.4、2.7、3.2、3.8V几种量程;
|
||||
// 3、如果采用外部分压,内部不分压的方式,软件上通过调用luat_adc_ctrl接口来设置量程为1.2V;
|
||||
// 4、不建议同时启动内部分压和外部分压的方式,这样的误差会变大
|
||||
|
||||
// 外部输入电压,超过3.4v的话:
|
||||
// 只能采用外部分压,内部不分压的方式,软件上通过调用luat_adc_ctrl接口来设置量程为1.2V;
|
||||
|
||||
// 外部输入电压,不超过3.4V的话:
|
||||
// 1、可以采用外部分压,内部不分压的方式,软件上通过调用luat_adc_ctrl接口来设置量程为1.2V;
|
||||
// 2、也可以采用内部分压,外部不分压的方式,软件上通过调用luat_adc_ctrl接口来设置量程,设置的量程大于等于实际输入的最大电压,选择最接近的量程即可;
|
||||
// 从硬件成本考虑,推荐第2种;
|
||||
// 从测量精确度来看,第2种方式,12bit表示设置的最大量程,最大量程/4096为测量精度;第1种方式,根据外部硬件电路,自行计算对比下;
|
||||
|
||||
// 内外部分压选择其中一种即可;不能外部分压时,才选择内部分压;
|
||||
// 如果采用外部分压,建议一步到位,外部分压后输入电压在0.1-1.2V范围(内部使用直通模式,不再分压),越靠近1.2V越好,精度越高。
|
||||
// 如果采用内部分压,在满足测量要求的前提下,配置的量程越靠近1.2V越好,精度越高。
|
||||
|
||||
// adc默认打开了内部分压,配置的量程为3.8V;
|
||||
// 以下三行注释掉的代码设置adc0的量程为1.2V,关闭了内部分压;建议用户采用外部分压;
|
||||
// 如果采用外部分压方式,用户可根据自己的需要打开以下三行代码;
|
||||
// luat_adc_ctrl_param_t ctrl_param;
|
||||
// ctrl_param.range = LUAT_ADC_AIO_RANGE_1_2;
|
||||
// luat_adc_ctrl(0, LUAT_ADC_SET_GLOBAL_RANGE, ctrl_param);
|
||||
|
||||
|
||||
// LUAT_ADC_CH_CPU和LUAT_ADC_CH_VBAT的说明如下:
|
||||
// LUAT_ADC_CH_CPU被芯片内部用来检测温度,仅支持软件上open、read和close操作,用户不能做其他用途使用;
|
||||
// LUAT_ADC_CH_VBAT被芯片内部用来检测VBAT电压,仅支持软件上open、read和close操作,用户不能做其他用途使用;
|
||||
|
||||
luat_adc_open(0 , NULL);
|
||||
luat_adc_open(1 , NULL);
|
||||
luat_adc_open(LUAT_ADC_CH_CPU, NULL);
|
||||
luat_adc_open(LUAT_ADC_CH_VBAT, NULL);
|
||||
while (1)
|
||||
{
|
||||
luat_rtos_task_sleep(1000);
|
||||
luat_adc_read(0 , &val, &val2);
|
||||
LUAT_DEBUG_PRINT("adc0: adc 原始值 %d, 电压 %d 微伏",val, val2);
|
||||
luat_adc_read(1 , &val, &val2);
|
||||
LUAT_DEBUG_PRINT("adc1: adc 原始值 %d, 电压 %d 微伏",val, val2);
|
||||
luat_adc_read(LUAT_ADC_CH_CPU, &val, &val2);
|
||||
LUAT_DEBUG_PRINT("temp: adc 原始值 %d, %d 摄氏度",val, val2);
|
||||
luat_adc_read(LUAT_ADC_CH_VBAT, &val, &val2);
|
||||
LUAT_DEBUG_PRINT("vbat: adc 原始值 %d, 电压 %d 毫伏",val, val2);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
static void task_demo_adc(void)
|
||||
{
|
||||
luat_rtos_task_create(&adc_task_handle, 1024, 20, "adc", task_test_adc, NULL, NULL);
|
||||
}
|
||||
|
||||
INIT_TASK_EXPORT(task_demo_adc,"1");
|
||||
|
||||
|
||||
|
||||
@@ -0,0 +1,21 @@
|
||||
local TARGET_NAME = "example_adc"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,350 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 1
|
||||
#define RTE_UART1_RTS_PIN_EN 1
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN21}, // 0 : gpio16 / 1 : UART1 RTS / 2 : SPI0 SSn
|
||||
// { PAD_PIN22}, // 0 : gpio11 / 1 : UART1 CTS / 2 : SPI0 MOSI
|
||||
// { PAD_PIN23}, // 0 : gpio14 / 1 : UART1 RXD / 2 : SPI0 MISO
|
||||
// { PAD_PIN24}, // 0 : gpio15 / 1 : UART1 TXD / 2 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 21
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 22
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 23
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 24
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 1
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 0
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 1
|
||||
|
||||
// { PAD_PIN13}, // 0 : gpio2 / 1 : UART0 RTSn / 3 : SPI1 SSn
|
||||
// { PAD_PIN14}, // 0 : gpio3 / 1 : UART0 CTSn / 3 : SPI1 MOSI
|
||||
// { PAD_PIN15}, // 0 : gpio4 / 1 : UART0 RXD / 3 : SPI1 MISO
|
||||
// { PAD_PIN16}, // 0 : gpio5 / 1 : UART0 TXD / 3 : SPI1 SCLK
|
||||
#define RTE_SPI1_SSN_BIT 13
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 14
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 15
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 16
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,46 @@
|
||||
const unsigned char amr_10_data[] =
|
||||
{
|
||||
0x23, 0x21, 0x41, 0x4D, 0x52, 0x0A, 0x3C, 0xD1, 0xEB, 0x45, 0x38, 0x17, 0x4B, 0xC7, 0xEC,
|
||||
0xAC, 0x4E, 0xCF, 0xE5, 0x37, 0x62, 0x13, 0x80, 0x00, 0x2C, 0x5C, 0xA3, 0xDA, 0x63, 0x3C, 0x00,
|
||||
0x05, 0x44, 0xD4, 0xDE, 0xA5, 0x9C, 0xB0, 0x3C, 0x91, 0xBB, 0x0D, 0x95, 0x72, 0xFB, 0x9F, 0x8F,
|
||||
0x1D, 0xD0, 0xFB, 0xDA, 0x41, 0x8C, 0x4D, 0x7E, 0x6C, 0xAE, 0x61, 0x27, 0xEB, 0xD7, 0x6B, 0x58,
|
||||
0x7A, 0x96, 0xFD, 0x47, 0x4B, 0x45, 0xE0, 0x3C, 0xB9, 0xEA, 0xB7, 0xC0, 0xB6, 0x32, 0x07, 0x1E,
|
||||
0x0D, 0xC4, 0x6A, 0xAA, 0x9C, 0x80, 0x4F, 0xFA, 0xA7, 0x72, 0x90, 0x8E, 0x0C, 0x8B, 0x69, 0xD7,
|
||||
0x4B, 0x15, 0xB1, 0x77, 0x55, 0x6F, 0x80, 0x3C, 0xB9, 0xE8, 0xB3, 0xBA, 0xEB, 0xDC, 0x4F, 0x5E,
|
||||
0x1D, 0xC1, 0x0A, 0xA2, 0xD4, 0x1E, 0x7C, 0xED, 0xDE, 0x0D, 0x02, 0xE1, 0x3C, 0x74, 0xB8, 0x78,
|
||||
0xD5, 0x8E, 0x22, 0x6E, 0xB5, 0x11, 0x50, 0x3C, 0xC3, 0xE0, 0xB9, 0xC8, 0x28, 0x60, 0x83, 0x5E,
|
||||
0x16, 0xE1, 0x8F, 0xB6, 0x8D, 0x90, 0xD5, 0xA9, 0x98, 0xDE, 0xFD, 0xD5, 0xE6, 0xF4, 0x07, 0x85,
|
||||
0xDB, 0x97, 0xEC, 0x3A, 0xB2, 0xD6, 0xB0, 0x3C, 0xB9, 0xE4, 0xB5, 0xC2, 0x40, 0x66, 0x1A, 0x1E,
|
||||
0x0A, 0xC0, 0x2A, 0xEA, 0x49, 0xE3, 0x97, 0xFD, 0x61, 0x04, 0x95, 0xC8, 0xD1, 0x7D, 0x00, 0xBC,
|
||||
0xCB, 0x39, 0xE0, 0x10, 0x58, 0x8F, 0x90, 0x3C, 0xB9, 0xDA, 0xB9, 0xB9, 0xE4, 0x5C, 0x18, 0x7E,
|
||||
0x16, 0xF1, 0xBF, 0x34, 0x87, 0x59, 0x0F, 0x82, 0xA5, 0xA6, 0x03, 0x11, 0x99, 0xCD, 0xEF, 0x5E,
|
||||
0xA9, 0xEE, 0x5F, 0xA8, 0xD0, 0x1F, 0xA0, 0x3C, 0xC3, 0xE4, 0xB5, 0xC1, 0x20, 0x10, 0x09, 0x5E,
|
||||
0x1B, 0x6E, 0xEA, 0x93, 0x46, 0x05, 0xC7, 0xD3, 0x95, 0x92, 0x31, 0xB4, 0xEF, 0xCD, 0x04, 0x10,
|
||||
0xF7, 0x4A, 0x64, 0x74, 0x9A, 0xC5, 0x90, 0x3C, 0xB5, 0xE0, 0xBD, 0xC5, 0xD0, 0x6C, 0x02, 0xDE,
|
||||
0x05, 0x81, 0x3A, 0x9C, 0xD8, 0xDB, 0x2C, 0xC5, 0x02, 0xC6, 0xAD, 0xE4, 0xA1, 0x4D, 0x37, 0x75,
|
||||
0x63, 0x43, 0xA0, 0xFB, 0x2C, 0x4A, 0xF0, 0x3C, 0x01, 0xB5, 0x10, 0x99, 0x72, 0x8C, 0x52, 0x9E,
|
||||
0x1E, 0x8B, 0x9A, 0x06, 0x5E, 0xB6, 0xA8, 0xC3, 0x98, 0x92, 0xB7, 0xD9, 0x4F, 0x87, 0x4D, 0x15,
|
||||
0x54, 0x0F, 0xC5, 0x1E, 0x4B, 0xED, 0xC0, 0x3C, 0x42, 0x1D, 0x3C, 0xF9, 0x81, 0x94, 0x7A, 0x5E,
|
||||
0x16, 0x90, 0xCA, 0x15, 0x46, 0x59, 0xE0, 0xFC, 0x73, 0xB4, 0x02, 0xC6, 0xB5, 0xC0, 0xC0, 0xA2,
|
||||
0x22, 0x5B, 0x7B, 0x75, 0x08, 0x90, 0xA0, 0x3C, 0x04, 0xA6, 0xB3, 0xA1, 0x81, 0x83, 0xEA, 0x9E,
|
||||
0x0F, 0x84, 0xDA, 0xB9, 0xC6, 0xA2, 0x91, 0xC1, 0x5F, 0x9F, 0xCB, 0x86, 0xD2, 0x3D, 0x3D, 0x6C,
|
||||
0x55, 0x03, 0xC6, 0xB8, 0x47, 0xAB, 0xD0, 0x3C, 0x1E, 0x26, 0x98, 0xF9, 0x83, 0x42, 0xD7, 0x1E,
|
||||
0x0D, 0x2A, 0xCF, 0x99, 0x68, 0xD3, 0xE2, 0x90, 0x0F, 0x9E, 0x65, 0x97, 0x73, 0xD9, 0x8B, 0x25,
|
||||
0xAE, 0xB4, 0x80, 0xAE, 0x8E, 0x81, 0x20, 0x3C, 0x0E, 0xB3, 0x07, 0xA1, 0x84, 0xBB, 0xF0, 0xFE,
|
||||
0x1E, 0xD5, 0x5A, 0xC0, 0x96, 0x36, 0xE4, 0xC0, 0x3B, 0xBC, 0x27, 0x93, 0x39, 0x69, 0x1F, 0xFB,
|
||||
0x18, 0x68, 0x44, 0x8A, 0x7F, 0x16, 0xD0, 0x3C, 0x26, 0x18, 0xB1, 0xA1, 0x81, 0x6B, 0x86, 0xDE,
|
||||
0x93, 0x3F, 0x1F, 0xF3, 0x71, 0x38, 0x82, 0x86, 0x22, 0xA3, 0x07, 0x6A, 0x16, 0xEE, 0x0D, 0x09,
|
||||
0x71, 0x49, 0x2F, 0x86, 0x28, 0x0B, 0x90, 0x3C, 0x1E, 0x1A, 0xAE, 0xA0, 0x7D, 0xBF, 0xC2, 0x3E,
|
||||
0x0C, 0x7D, 0x1B, 0x3B, 0xB1, 0x18, 0x65, 0x40, 0x25, 0x7E, 0x97, 0x04, 0x6E, 0x01, 0x4D, 0xC8,
|
||||
0xC2, 0xA4, 0xEA, 0x00, 0xEF, 0x57, 0xD0, 0x3C, 0x26, 0x13, 0x0D, 0x98, 0x72, 0xCD, 0xE0, 0x9E,
|
||||
0x19, 0x2A, 0xDA, 0x83, 0x1D, 0xB1, 0x36, 0xEA, 0x13, 0x34, 0xBA, 0x6B, 0x28, 0xBD, 0x4B, 0x7E,
|
||||
0xC2, 0xFE, 0xE1, 0xB9, 0x66, 0x80, 0x00, 0x3C, 0x20, 0x38, 0x88, 0x38, 0x64, 0x81, 0xE1, 0xDF,
|
||||
0x0A, 0xD4, 0x2C, 0x01, 0xC7, 0xE8, 0x35, 0x32, 0xAB, 0x83, 0x39, 0xCC, 0x97, 0x4A, 0x64, 0x53,
|
||||
0xD1, 0xE5, 0x73, 0xFA, 0x09, 0x9F, 0xA0, 0x3C, 0xF3, 0x7A, 0x91, 0xF8, 0x4A, 0x2A, 0x5A, 0x5E,
|
||||
0x14, 0x7D, 0x8A, 0xE4, 0xE3, 0xD2, 0x19, 0xF6, 0xC0, 0x22, 0xA7, 0xF4, 0x4B, 0x31, 0x04, 0x04,
|
||||
0x32, 0xF2, 0x5A, 0xED, 0x99, 0x6F, 0x80, 0x3C, 0x1E, 0x3C, 0x7B, 0x28, 0x19, 0xC0, 0x5A, 0x0D,
|
||||
0x32, 0xD5, 0x1A, 0x9F, 0xCA, 0xF3, 0xD5, 0xCC, 0x0B, 0xC8, 0x96, 0xDF, 0x7C, 0xE0, 0x5E, 0x61,
|
||||
0x26, 0xBF, 0x98, 0x25, 0xB9, 0x4B, 0x20, 0x3C, 0x1C, 0x41, 0x1C, 0x30, 0x13, 0x92, 0x08, 0x81,
|
||||
0xD9, 0x82, 0x8B, 0xA7, 0x57, 0x29, 0xD4, 0x47, 0x7F, 0x1A, 0x9C, 0x33, 0x50, 0xE0, 0xC9, 0x2B,
|
||||
0x66, 0x77, 0x00, 0x36, 0xA1, 0xE4, 0x20,
|
||||
};
|
||||
@@ -0,0 +1,28 @@
|
||||
const unsigned char amr_2_data[] =
|
||||
{
|
||||
0x23, 0x21, 0x41, 0x4D, 0x52, 0x0A, 0x3C, 0x9B, 0x36, 0x1C, 0x60, 0xB4, 0x01, 0xE7, 0xEE,
|
||||
0xCE, 0x4B, 0xBF, 0xF6, 0x74, 0x72, 0x62, 0x80, 0x00, 0x37, 0xCF, 0xCE, 0xF2, 0xE1, 0xE4, 0x00,
|
||||
0x02, 0x3C, 0xBB, 0x5F, 0xB3, 0x49, 0xA0, 0x3C, 0x6A, 0x72, 0x20, 0x10, 0x18, 0x43, 0xE2, 0xCF,
|
||||
0x17, 0x80, 0xDC, 0xCE, 0xF0, 0xB1, 0xEA, 0x14, 0x32, 0x4F, 0x4B, 0xDB, 0x09, 0xB0, 0x89, 0xC0,
|
||||
0x47, 0x8D, 0x68, 0x8E, 0xD1, 0xF2, 0xE0, 0x3C, 0x8A, 0xF1, 0x91, 0x58, 0x12, 0xAB, 0xF4, 0xBE,
|
||||
0x0B, 0x2A, 0x9A, 0x3A, 0xDE, 0x72, 0xF2, 0xE1, 0x2B, 0x21, 0xB4, 0xFB, 0x8C, 0xB0, 0x3B, 0x30,
|
||||
0x6E, 0xC0, 0x6C, 0x83, 0xE1, 0xDE, 0x10, 0x3C, 0x40, 0x71, 0x88, 0x08, 0x18, 0x03, 0xE1, 0x7E,
|
||||
0x09, 0x80, 0xDA, 0x69, 0x34, 0x33, 0x5D, 0xC3, 0x78, 0xC9, 0x25, 0xC3, 0x90, 0x46, 0x5C, 0x54,
|
||||
0x10, 0xE0, 0x05, 0x60, 0xB8, 0x93, 0xA0, 0x3C, 0x42, 0x67, 0x95, 0x08, 0x18, 0x3E, 0x79, 0xFE,
|
||||
0x07, 0x86, 0x5A, 0xFC, 0xB8, 0x84, 0x56, 0xDA, 0xC3, 0x64, 0x16, 0x1C, 0x4A, 0x26, 0x14, 0x61,
|
||||
0xF8, 0x7D, 0x8C, 0xEE, 0x1E, 0x46, 0x40, 0x3C, 0x26, 0x69, 0x9B, 0x00, 0x1B, 0x10, 0xF3, 0x1E,
|
||||
0x09, 0x98, 0x4A, 0x3B, 0x34, 0x2E, 0x1B, 0xC1, 0x10, 0x8C, 0xE3, 0x1F, 0xA6, 0xFD, 0xE7, 0x8D,
|
||||
0x7F, 0x16, 0xC5, 0xC3, 0xE2, 0x61, 0xD0, 0x3C, 0x44, 0x62, 0x16, 0x00, 0x35, 0x19, 0x68, 0x1E,
|
||||
0x19, 0x8D, 0x2A, 0xF2, 0x4A, 0xB4, 0x97, 0xF7, 0xA3, 0x8D, 0x86, 0xE0, 0x24, 0x00, 0x68, 0x8F,
|
||||
0x13, 0x24, 0x61, 0xB3, 0x50, 0xF3, 0xC0, 0x3C, 0x44, 0x52, 0x15, 0x00, 0x63, 0x80, 0x5B, 0x9E,
|
||||
0x0D, 0x92, 0x4F, 0xBC, 0x8A, 0xB7, 0x71, 0xCC, 0x2C, 0x0C, 0x00, 0x6C, 0xAF, 0x5A, 0x6A, 0xAB,
|
||||
0x71, 0xF3, 0x41, 0x87, 0x12, 0xCB, 0xC0, 0x3C, 0x1A, 0x55, 0x95, 0x60, 0x6D, 0xEE, 0x52, 0xDE,
|
||||
0x0B, 0xB2, 0x0A, 0xD2, 0x38, 0x73, 0x4A, 0xCA, 0x9F, 0x94, 0x03, 0x94, 0x44, 0x60, 0x42, 0x6D,
|
||||
0x13, 0xEA, 0x63, 0xEA, 0xFC, 0x8E, 0x70, 0x3C, 0xE0, 0x62, 0x1B, 0x58, 0xDD, 0x4E, 0x12, 0xCB,
|
||||
0x5C, 0x69, 0x1F, 0x1B, 0x4C, 0xEB, 0x57, 0xF2, 0x73, 0x9A, 0xF8, 0x7A, 0xA7, 0x5D, 0x79, 0xF2,
|
||||
0xC0, 0x7F, 0xE6, 0x02, 0x52, 0x14, 0x30, 0x3C, 0x1A, 0x53, 0x7F, 0x89, 0xB5, 0xD7, 0x48, 0x3C,
|
||||
0x27, 0x8B, 0x18, 0x65, 0x35, 0xB9, 0x65, 0x10, 0x9C, 0x17, 0x03, 0xF6, 0xB9, 0x1D, 0x85, 0x75,
|
||||
0x8E, 0x87, 0x90, 0xAD, 0x17, 0x1C, 0x10, 0x3C, 0xE0, 0x4B, 0x63, 0x51, 0x4E, 0x44, 0x18, 0x18,
|
||||
0x01, 0x34, 0xE8, 0xD1, 0x1A, 0x6F, 0xA2, 0x7E, 0xAD, 0xD9, 0x95, 0x8E, 0x9B, 0x0C, 0xA6, 0x33,
|
||||
0x08, 0x45, 0x49, 0x36, 0xF3, 0xEF, 0x20,
|
||||
};
|
||||
@@ -0,0 +1,104 @@
|
||||
const unsigned char amr_alipay_data[] =
|
||||
{
|
||||
0x23, 0x21, 0x41, 0x4D, 0x52, 0x0A, 0x3C, 0x71, 0xC7, 0x43, 0xD9, 0x06, 0xA3, 0x81, 0xAC,
|
||||
0xAC, 0x4B, 0xBF, 0xC5, 0x65, 0x62, 0x27, 0xC0, 0x00, 0x7B, 0x97, 0xE2, 0x73, 0xAA, 0x6C, 0x00,
|
||||
0x07, 0x3E, 0xFA, 0xC1, 0x76, 0x0C, 0x60, 0x3C, 0x55, 0xE8, 0xFF, 0xD4, 0xCF, 0x2E, 0x1E, 0x5E,
|
||||
0x04, 0x03, 0x18, 0x4B, 0x71, 0x95, 0xD6, 0xCB, 0xF6, 0x88, 0xBE, 0x63, 0x3A, 0x0C, 0x6A, 0xA7,
|
||||
0x05, 0x35, 0x43, 0x28, 0x53, 0xEE, 0xF0, 0x3C, 0xB5, 0xDA, 0xB1, 0xCB, 0x30, 0x53, 0x23, 0x9E,
|
||||
0x0A, 0x67, 0x8F, 0xE2, 0x78, 0x01, 0x1C, 0xB4, 0x81, 0x57, 0xEB, 0xFF, 0x84, 0x0B, 0x10, 0x70,
|
||||
0xA0, 0x41, 0x60, 0x2A, 0xD5, 0x03, 0x00, 0x3C, 0xF3, 0xB6, 0xB5, 0xC7, 0x7D, 0x8C, 0x1B, 0x5E,
|
||||
0x16, 0x48, 0x07, 0x94, 0xB5, 0xB0, 0xEA, 0x3F, 0xC7, 0x6A, 0xE5, 0xE0, 0xC3, 0x8B, 0x5C, 0x0F,
|
||||
0xE0, 0xFB, 0xA6, 0x3A, 0xB6, 0x7F, 0x20, 0x3C, 0x2E, 0x0E, 0x88, 0xB8, 0x01, 0xAC, 0x16, 0x7E,
|
||||
0x12, 0x0A, 0x59, 0x56, 0x9D, 0xBF, 0x05, 0xA4, 0x7A, 0xF7, 0xAD, 0x38, 0x31, 0x59, 0xD5, 0x9C,
|
||||
0x40, 0x57, 0xF8, 0x96, 0xC5, 0x13, 0x00, 0x3C, 0x24, 0xB8, 0x95, 0xB8, 0x01, 0xE7, 0xC3, 0x1E,
|
||||
0x06, 0x1B, 0x52, 0xF8, 0xBD, 0x44, 0x94, 0xD2, 0xA7, 0x0C, 0x96, 0x79, 0xCF, 0x80, 0xD5, 0x43,
|
||||
0x9F, 0x90, 0x5F, 0xF2, 0x87, 0xEB, 0x70, 0x3C, 0x2C, 0xAD, 0x29, 0x28, 0x01, 0x85, 0x0C, 0xFE,
|
||||
0x0C, 0x18, 0x0B, 0xE9, 0x6D, 0x9B, 0x60, 0xEC, 0xD3, 0x66, 0xD1, 0x88, 0x11, 0xF9, 0x3C, 0x94,
|
||||
0xD8, 0xC0, 0xF0, 0x13, 0x22, 0x7E, 0x30, 0x3C, 0x2C, 0xAC, 0x9A, 0xB0, 0xAA, 0x76, 0x11, 0xDC,
|
||||
0x22, 0x0F, 0xBB, 0x59, 0x0B, 0xEC, 0xF5, 0xFC, 0x9E, 0x59, 0x10, 0xD1, 0x53, 0x42, 0xA4, 0x69,
|
||||
0x27, 0xBC, 0x1A, 0xBB, 0x6D, 0x53, 0xF0, 0x3C, 0x2F, 0x9F, 0x1D, 0x8C, 0x2F, 0xBA, 0x00, 0x6B,
|
||||
0x55, 0x4F, 0x2F, 0xD9, 0x15, 0xAF, 0x5B, 0x44, 0x33, 0xFF, 0x89, 0xA8, 0xBE, 0xB0, 0x42, 0x66,
|
||||
0x25, 0x23, 0xB6, 0xF9, 0x61, 0x46, 0x40, 0x3C, 0xB5, 0x13, 0x34, 0xA4, 0x42, 0x30, 0x09, 0x45,
|
||||
0xBA, 0x5F, 0x3A, 0xDF, 0x82, 0xF6, 0x44, 0xE8, 0x95, 0x75, 0x5B, 0x3C, 0xAB, 0x3D, 0xC9, 0xF2,
|
||||
0xA6, 0x8F, 0xC7, 0xA1, 0xEE, 0xEA, 0xC0, 0x3C, 0xF3, 0x3E, 0x59, 0x41, 0x54, 0xF2, 0x10, 0xBE,
|
||||
0x02, 0x01, 0x77, 0x37, 0x99, 0xEE, 0xDB, 0x86, 0xB2, 0xF7, 0x6B, 0x82, 0x7E, 0xF9, 0xA0, 0xBE,
|
||||
0x53, 0xF9, 0x96, 0x90, 0xBF, 0x0F, 0xE0, 0x3C, 0x37, 0x7A, 0x02, 0x50, 0x00, 0x82, 0x74, 0x54,
|
||||
0xAA, 0x18, 0xCF, 0xF3, 0x94, 0xEF, 0x4E, 0xA8, 0x28, 0x8E, 0x14, 0x1C, 0xBF, 0xDE, 0x94, 0xA1,
|
||||
0xE3, 0x64, 0x7C, 0x59, 0x35, 0x1E, 0xF0, 0x3C, 0x1C, 0x44, 0x0D, 0xE8, 0x01, 0xBB, 0xE1, 0xD8,
|
||||
0x62, 0x34, 0x5F, 0xD5, 0xCF, 0xEB, 0x91, 0x8A, 0x0E, 0x7B, 0x5D, 0x82, 0x0D, 0xC1, 0xFD, 0x75,
|
||||
0x9E, 0x6D, 0x34, 0x57, 0x5E, 0xD0, 0x10, 0x3C, 0x24, 0x1D, 0xBE, 0x38, 0x06, 0xE1, 0x85, 0x12,
|
||||
0xCC, 0xEF, 0x5F, 0xBD, 0x1F, 0x57, 0x3D, 0x9F, 0x97, 0x64, 0x29, 0xBC, 0x8E, 0x9B, 0xF9, 0xE1,
|
||||
0x91, 0xDC, 0xF2, 0xBF, 0xB2, 0x2A, 0xC0, 0x3C, 0x06, 0x19, 0x9F, 0x51, 0x5C, 0xFB, 0x44, 0x70,
|
||||
0x6C, 0xBF, 0x4B, 0xFE, 0x42, 0xF9, 0x8F, 0x46, 0x1B, 0x10, 0x8B, 0xD1, 0xD1, 0xA6, 0xD9, 0x48,
|
||||
0x20, 0x7F, 0x6E, 0xB4, 0xF1, 0xD5, 0x80, 0x3C, 0x0C, 0x02, 0x64, 0x98, 0x35, 0x84, 0x11, 0xA0,
|
||||
0xD3, 0x00, 0x9F, 0xA0, 0x58, 0xA1, 0x49, 0xBD, 0x9B, 0x78, 0x76, 0x56, 0x19, 0x0C, 0xE2, 0x8E,
|
||||
0xC9, 0x0E, 0x14, 0x9A, 0x13, 0x60, 0x30, 0x3C, 0x20, 0x6E, 0x40, 0x68, 0x33, 0x11, 0x67, 0xFE,
|
||||
0x31, 0xF1, 0xD4, 0xF4, 0x37, 0xE4, 0x25, 0x23, 0xC8, 0x7B, 0xCB, 0x5C, 0xC3, 0xE1, 0xF7, 0xFE,
|
||||
0xCD, 0x7F, 0xCF, 0x72, 0x4E, 0xFF, 0x10, 0x3C, 0x4F, 0x7E, 0x0E, 0xE8, 0x67, 0xC6, 0xA5, 0xDE,
|
||||
0x14, 0xDE, 0xEF, 0xC7, 0x2B, 0x8C, 0x52, 0xDD, 0x16, 0x2E, 0xD8, 0x38, 0x00, 0x34, 0x59, 0xF6,
|
||||
0xD3, 0x87, 0xCA, 0xA0, 0x17, 0x76, 0x10, 0x3C, 0x44, 0xEA, 0x0B, 0x00, 0x7B, 0xC5, 0xF0, 0x1E,
|
||||
0x31, 0x8C, 0x48, 0xA0, 0x83, 0xE7, 0x4C, 0x2C, 0xCC, 0x12, 0x37, 0xA6, 0x04, 0x28, 0xA0, 0x65,
|
||||
0x30, 0x31, 0x42, 0x2A, 0xA3, 0x82, 0x60, 0x3C, 0x42, 0x4A, 0x13, 0x61, 0x80, 0x81, 0xF0, 0x9E,
|
||||
0x05, 0x86, 0xAF, 0x63, 0xCA, 0x35, 0x15, 0xDD, 0x56, 0xE3, 0xE3, 0x04, 0xA4, 0xCD, 0x23, 0x86,
|
||||
0x03, 0xAE, 0x71, 0xDB, 0xF7, 0xF8, 0xD0, 0x3C, 0x44, 0x4C, 0x11, 0x01, 0x86, 0xBE, 0x3D, 0xCF,
|
||||
0x11, 0x98, 0x8C, 0xCB, 0xF0, 0xA0, 0x0F, 0x11, 0xF0, 0x82, 0x40, 0x34, 0xFE, 0x30, 0x4C, 0x46,
|
||||
0x9C, 0x74, 0x14, 0x76, 0x34, 0x78, 0x50, 0x3C, 0x21, 0x7A, 0x16, 0xE9, 0x9B, 0xCC, 0x79, 0x7E,
|
||||
0x01, 0x92, 0xAF, 0xC0, 0x3C, 0x69, 0xC3, 0xF7, 0x7A, 0xFD, 0xCC, 0x53, 0x13, 0xC1, 0x52, 0x19,
|
||||
0xAB, 0xF7, 0x99, 0xC4, 0xB8, 0x4E, 0x50, 0x3C, 0x0E, 0x13, 0x87, 0x51, 0x9F, 0xAD, 0x68, 0xE9,
|
||||
0x77, 0x84, 0x42, 0x47, 0x21, 0xEC, 0xFB, 0x1B, 0x52, 0xCC, 0x72, 0x75, 0x56, 0x4E, 0xD8, 0xD2,
|
||||
0xB9, 0x3D, 0xD7, 0x63, 0x27, 0x15, 0xF0, 0x3C, 0x06, 0x14, 0x7D, 0x79, 0x9E, 0x76, 0x1E, 0x6D,
|
||||
0x32, 0x73, 0x7A, 0xE1, 0x4F, 0x99, 0xDB, 0xC5, 0x2D, 0x2F, 0xC6, 0x75, 0xD6, 0x27, 0x0C, 0x07,
|
||||
0xE0, 0x1C, 0x9D, 0x28, 0xE6, 0xD4, 0x70, 0x3C, 0x05, 0xFE, 0xAD, 0xA9, 0x9D, 0xBB, 0x1F, 0x9E,
|
||||
0x13, 0x9B, 0xE7, 0x82, 0x13, 0xE8, 0xED, 0x03, 0xEB, 0x0E, 0x1D, 0x36, 0xFA, 0x50, 0x9C, 0xE4,
|
||||
0xEC, 0x30, 0x00, 0xB2, 0x0D, 0xA6, 0x70, 0x3C, 0xE1, 0xDD, 0x06, 0xC2, 0xF3, 0x70, 0x0A, 0x76,
|
||||
0x88, 0x90, 0xAF, 0x8F, 0x4D, 0xB1, 0x07, 0x8F, 0x36, 0xA7, 0x6A, 0x83, 0x13, 0x18, 0x81, 0xC8,
|
||||
0x44, 0x4B, 0x63, 0x66, 0xD4, 0x6C, 0xF0, 0x3C, 0x53, 0xE5, 0x06, 0xC5, 0x52, 0x02, 0x1D, 0x1E,
|
||||
0x03, 0xA8, 0x0A, 0xDE, 0x13, 0xCB, 0xD0, 0x56, 0xBF, 0xB6, 0xC1, 0xE1, 0x78, 0xC8, 0x8F, 0xAC,
|
||||
0xD8, 0x7E, 0x8D, 0x38, 0x93, 0x9B, 0x30, 0x3C, 0xD1, 0xCD, 0x07, 0xD5, 0x64, 0xFA, 0xB9, 0x1E,
|
||||
0x02, 0xC1, 0x39, 0x0E, 0x1C, 0x03, 0x85, 0xE6, 0x4B, 0x87, 0x3B, 0x87, 0x79, 0x62, 0x5E, 0xD3,
|
||||
0x0E, 0xFA, 0x6E, 0xF9, 0x20, 0x32, 0xB0, 0x3C, 0xF3, 0xE6, 0xB4, 0xBE, 0xA2, 0x6A, 0x10, 0xFE,
|
||||
0x07, 0x1F, 0x97, 0xA8, 0x8F, 0x25, 0xA8, 0x36, 0x10, 0x8C, 0x81, 0x78, 0xDB, 0x31, 0xFD, 0xAA,
|
||||
0xC1, 0x3E, 0xEE, 0xA4, 0x2C, 0xA1, 0xC0, 0x3C, 0x28, 0x0E, 0x18, 0x48, 0x0C, 0x69, 0x17, 0x9E,
|
||||
0x17, 0x94, 0x73, 0xBD, 0xEC, 0x18, 0x07, 0xF6, 0xCB, 0xC2, 0xFD, 0x35, 0x82, 0x77, 0xD1, 0xF1,
|
||||
0xB7, 0x85, 0x90, 0x44, 0x4C, 0xD8, 0xA0, 0x3C, 0x46, 0x6D, 0x90, 0xE8, 0x19, 0x82, 0x79, 0xFA,
|
||||
0x4D, 0x81, 0xD9, 0xB9, 0x39, 0x3D, 0x28, 0x80, 0xC0, 0x2C, 0x5D, 0x9C, 0x0C, 0x5D, 0x66, 0x38,
|
||||
0xD0, 0x94, 0xBE, 0xEE, 0x18, 0xB3, 0x90, 0x3C, 0x35, 0x7A, 0x02, 0x50, 0x19, 0x91, 0x68, 0x89,
|
||||
0x77, 0x80, 0x1A, 0x3F, 0x26, 0x94, 0xBD, 0xE5, 0x4A, 0x83, 0x97, 0x9E, 0x9D, 0x93, 0x68, 0x3A,
|
||||
0x48, 0x9C, 0x5E, 0x54, 0xE0, 0x48, 0xB0, 0x3C, 0x30, 0x41, 0xAE, 0x58, 0x18, 0x4F, 0xE0, 0x58,
|
||||
0x66, 0xD5, 0x9E, 0x92, 0x53, 0x1C, 0x43, 0xF2, 0x8C, 0x6D, 0x03, 0x3B, 0xE0, 0x03, 0x0F, 0x00,
|
||||
0x84, 0x6A, 0x7A, 0x10, 0x26, 0x61, 0xE0, 0x3C, 0x1C, 0x44, 0x02, 0x50, 0x18, 0x04, 0x1F, 0xAB,
|
||||
0x54, 0x7F, 0xDF, 0xE8, 0xE7, 0xA8, 0x25, 0x93, 0x4A, 0x66, 0x8C, 0xFA, 0x0C, 0x34, 0xCF, 0xFC,
|
||||
0x05, 0x09, 0x80, 0xCB, 0x91, 0x39, 0xF0, 0x3C, 0x24, 0x54, 0x09, 0x10, 0x12, 0xE0, 0x01, 0xE1,
|
||||
0xF9, 0x85, 0xDB, 0x11, 0xA1, 0x5F, 0x52, 0x6C, 0xD3, 0xEC, 0x45, 0x77, 0x44, 0xB5, 0x64, 0x78,
|
||||
0x44, 0x6F, 0x89, 0x81, 0xE3, 0xAA, 0x30, 0x3C, 0x8A, 0xEB, 0x93, 0x65, 0x66, 0xD8, 0x2B, 0x87,
|
||||
0x91, 0x9A, 0xA3, 0x06, 0xFC, 0xB7, 0xD4, 0x3A, 0xA5, 0xDB, 0x74, 0x2F, 0x4C, 0x09, 0x70, 0x32,
|
||||
0xE8, 0x72, 0x63, 0xD7, 0x3D, 0x49, 0xD0, 0x3C, 0x28, 0x6C, 0x0F, 0x13, 0xF3, 0x28, 0x1D, 0xFA,
|
||||
0x54, 0x97, 0x7C, 0x62, 0x1A, 0x77, 0xBF, 0x35, 0xC0, 0x08, 0x68, 0xBC, 0xA1, 0x93, 0xA5, 0x44,
|
||||
0x6B, 0xE0, 0x4D, 0x3A, 0x71, 0x74, 0xA0, 0x3C, 0x8B, 0x2D, 0x8D, 0x55, 0xE1, 0xF4, 0x30, 0x96,
|
||||
0x9B, 0x87, 0x49, 0x7E, 0x1D, 0x0F, 0x01, 0x31, 0x4C, 0x8F, 0x1C, 0x19, 0x76, 0x58, 0x66, 0x57,
|
||||
0xEE, 0x02, 0x93, 0x2C, 0x37, 0xCF, 0x30, 0x3C, 0x68, 0x72, 0x21, 0x1C, 0x03, 0xAA, 0x01, 0xBE,
|
||||
0x01, 0x81, 0x4A, 0x71, 0xAF, 0xDB, 0x64, 0x4F, 0xD3, 0x31, 0x58, 0x2B, 0x71, 0x24, 0x8D, 0xD8,
|
||||
0x1B, 0x59, 0x12, 0x2C, 0x9C, 0x65, 0x80, 0x3C, 0xE4, 0x71, 0x93, 0x54, 0x34, 0x9A, 0x74, 0xDE,
|
||||
0x01, 0x88, 0xDF, 0xE7, 0x56, 0xBC, 0x18, 0xFE, 0xC8, 0xE2, 0xC9, 0x0B, 0x3E, 0x7A, 0xA2, 0x02,
|
||||
0xEC, 0x71, 0x3F, 0xDD, 0x9F, 0x09, 0x80, 0x3C, 0xF2, 0x5B, 0x7B, 0x18, 0x67, 0x8C, 0x3D, 0x1E,
|
||||
0x05, 0x6F, 0x5A, 0x1D, 0x0F, 0x96, 0xCA, 0x36, 0xDE, 0x18, 0x74, 0x7C, 0x16, 0xE0, 0x34, 0x9B,
|
||||
0x0F, 0x0B, 0x14, 0x5C, 0x92, 0x94, 0x90, 0x3C, 0xE0, 0x63, 0x88, 0x62, 0xEB, 0x3E, 0x20, 0x9E,
|
||||
0x07, 0x39, 0x3F, 0x9A, 0x24, 0xC9, 0x94, 0xD5, 0xA9, 0xEC, 0x1C, 0xC5, 0x22, 0x2E, 0xF5, 0x9E,
|
||||
0x9F, 0x03, 0x6E, 0xF7, 0xDC, 0x76, 0x20, 0x3C, 0x16, 0x62, 0x2D, 0x20, 0xD5, 0x96, 0x25, 0xDE,
|
||||
0x11, 0xA5, 0xB8, 0xE7, 0x13, 0x1A, 0xBF, 0x07, 0x8A, 0x59, 0xD4, 0x66, 0x7E, 0x64, 0xD4, 0xD1,
|
||||
0x92, 0x1B, 0xD4, 0xD5, 0x8C, 0x9E, 0x60, 0x3C, 0xE0, 0x68, 0x28, 0x0B, 0xAD, 0xDC, 0x12, 0x5E,
|
||||
0x05, 0xF4, 0x1A, 0xDF, 0x18, 0x00, 0xFC, 0x8B, 0x69, 0x18, 0xA1, 0x42, 0xC7, 0x9C, 0x17, 0x86,
|
||||
0x67, 0x40, 0x20, 0x47, 0xB7, 0x7B, 0x80, 0x3C, 0xD8, 0x56, 0x30, 0x49, 0xE3, 0x08, 0x5B, 0xDE,
|
||||
0x05, 0xA5, 0xA8, 0x08, 0x1D, 0x5D, 0xA4, 0x46, 0x1B, 0x0E, 0x29, 0x54, 0x2F, 0xE6, 0xF3, 0x03,
|
||||
0xDC, 0x04, 0x21, 0x18, 0x8D, 0x31, 0xE0, 0x3C, 0xE0, 0x5D, 0x64, 0x11, 0xF8, 0xB6, 0x1E, 0x9C,
|
||||
0x2B, 0xA5, 0xC8, 0x09, 0xE6, 0xB5, 0x5A, 0xF4, 0xED, 0x0A, 0xE2, 0x92, 0x2C, 0x4E, 0x9C, 0xCB,
|
||||
0xE0, 0x3A, 0x32, 0x4F, 0x8F, 0x57, 0x70, 0x3C, 0x1A, 0x47, 0x71, 0x1E, 0x00, 0xC4, 0x1E, 0xDE,
|
||||
0x00, 0xF5, 0x39, 0x1A, 0x94, 0xE7, 0xCB, 0xB2, 0x88, 0xF1, 0x38, 0x3E, 0x83, 0xE0, 0x6E, 0x01,
|
||||
0x9F, 0xE8, 0x37, 0xFD, 0x00, 0x74, 0x80, 0x3C, 0x08, 0x47, 0x6D, 0x14, 0xAE, 0xE0, 0x07, 0x8D,
|
||||
0x33, 0xAA, 0x47, 0x51, 0xE9, 0x90, 0x6C, 0x1C, 0x04, 0x5E, 0x81, 0xEF, 0x97, 0xA6, 0xD7, 0x09,
|
||||
0x50, 0xC5, 0x43, 0xAB, 0xF1, 0x78, 0xE0, 0x3C, 0x0C, 0x08, 0x4A, 0x1C, 0x20, 0xC6, 0x43, 0x01,
|
||||
0x6C, 0x28, 0xBA, 0x4E, 0x42, 0xCE, 0x89, 0x0A, 0xB7, 0x9E, 0x6D, 0x72, 0x13, 0xFF, 0xA1, 0xAB,
|
||||
0xF0, 0x73, 0xF8, 0x90, 0x98, 0x0C, 0xD0, 0x3C, 0x06, 0x1A, 0x85, 0x84, 0x8A, 0x12, 0x01, 0xC5,
|
||||
0x00, 0xAD, 0xDA, 0x09, 0x2B, 0xF9, 0xC9, 0xD6, 0xBC, 0xED, 0xC0, 0x7F, 0xFF, 0x80, 0x10, 0xC5,
|
||||
0xC0, 0xE5, 0xD1, 0xE7, 0xA0, 0x06, 0xD0,
|
||||
};
|
||||
@@ -0,0 +1,52 @@
|
||||
const unsigned char amr_yuan_data[] =
|
||||
{
|
||||
0x23, 0x21, 0x41, 0x4D, 0x52, 0x0A, 0x3C, 0x02, 0x2E, 0x27, 0x42, 0xC1, 0x79, 0xC3, 0xC8,
|
||||
0xAC, 0x64, 0xB8, 0xE4, 0x32, 0x33, 0x67, 0x00, 0x00, 0x24, 0xBD, 0x98, 0x4C, 0x9A, 0x40, 0x00,
|
||||
0x07, 0x46, 0x9C, 0x17, 0xFD, 0x55, 0xE0, 0x3C, 0x0C, 0x07, 0xA2, 0xC8, 0xD5, 0x3F, 0xDB, 0xE5,
|
||||
0xA6, 0x96, 0xD6, 0xC6, 0xAC, 0x0F, 0xCF, 0x22, 0x3A, 0xCD, 0x5D, 0xF4, 0xB2, 0x1E, 0xDB, 0xF7,
|
||||
0xFE, 0xF3, 0xB3, 0xC9, 0x1A, 0x13, 0x50, 0x3C, 0x04, 0x1E, 0xEB, 0x99, 0x81, 0x6B, 0xF9, 0xA9,
|
||||
0x67, 0x80, 0x07, 0xF9, 0x6C, 0x73, 0xE1, 0x1F, 0xF6, 0x50, 0x6A, 0x6B, 0x17, 0x60, 0x06, 0x21,
|
||||
0x7C, 0x32, 0x18, 0x98, 0x1B, 0x5B, 0xF0, 0x3C, 0x06, 0x14, 0xC1, 0xD1, 0x81, 0x2F, 0xFB, 0xCF,
|
||||
0x11, 0x26, 0x34, 0xEB, 0xAD, 0x87, 0x8B, 0xE3, 0x6A, 0xC9, 0xEA, 0xF7, 0x45, 0xB7, 0x3C, 0x5A,
|
||||
0x76, 0xA1, 0xCD, 0x1E, 0xDB, 0x48, 0x90, 0x3C, 0x06, 0x13, 0x3C, 0xB0, 0x7C, 0xEF, 0xF3, 0xDE,
|
||||
0x0B, 0x2E, 0xC7, 0x86, 0xE9, 0x21, 0xA7, 0x0C, 0x55, 0x94, 0x57, 0x92, 0xFB, 0x2D, 0x30, 0x86,
|
||||
0xA9, 0x4A, 0x36, 0x81, 0xB6, 0x30, 0x60, 0x3C, 0x28, 0x11, 0x14, 0xB8, 0x7B, 0xE3, 0xCB, 0xFE,
|
||||
0x39, 0x2E, 0x48, 0xEA, 0xB4, 0xE1, 0xFE, 0xEC, 0xC4, 0x3B, 0x69, 0x0E, 0x7D, 0x35, 0x91, 0x20,
|
||||
0x3D, 0x03, 0x66, 0x35, 0x3B, 0x61, 0xE0, 0x3C, 0x1E, 0x3E, 0x99, 0x41, 0x82, 0x57, 0x79, 0x9E,
|
||||
0x96, 0xD5, 0x57, 0xFB, 0xD3, 0xAD, 0x54, 0x87, 0x58, 0x06, 0x5E, 0xEA, 0x55, 0xA9, 0x04, 0x8E,
|
||||
0xDF, 0xB2, 0x11, 0x11, 0x89, 0xB3, 0xF0, 0x3C, 0x48, 0x3D, 0x20, 0x31, 0x87, 0xAF, 0x68, 0x9E,
|
||||
0x95, 0x84, 0x88, 0x4B, 0x34, 0xDE, 0x2A, 0xDF, 0xD8, 0xCB, 0x8E, 0x12, 0x2F, 0x79, 0x38, 0x04,
|
||||
0xAE, 0x64, 0x18, 0xFC, 0xA2, 0xC9, 0x40, 0x3C, 0x4E, 0x53, 0x76, 0x21, 0x98, 0x0F, 0xE2, 0x5F,
|
||||
0x25, 0x84, 0x36, 0xB6, 0x70, 0x45, 0x76, 0xB3, 0xC0, 0x06, 0x18, 0xB9, 0xB0, 0xE2, 0x02, 0x29,
|
||||
0xCE, 0x39, 0x17, 0x49, 0x41, 0x78, 0xA0, 0x3C, 0x54, 0x53, 0x5D, 0x19, 0x98, 0x63, 0xE3, 0xDE,
|
||||
0x0F, 0x80, 0x18, 0x1C, 0xEC, 0xD1, 0xBB, 0xD5, 0xA2, 0xA3, 0x84, 0x9A, 0x78, 0x21, 0xD6, 0x8E,
|
||||
0xC1, 0x51, 0xD4, 0x45, 0x68, 0x97, 0x30, 0x3C, 0x54, 0x67, 0x71, 0x21, 0x98, 0x4F, 0xF0, 0xFE,
|
||||
0x1F, 0x2A, 0xB8, 0x59, 0x30, 0x4F, 0x43, 0xFD, 0x50, 0x4D, 0xC0, 0x99, 0xB9, 0xFD, 0xA8, 0xCE,
|
||||
0x36, 0x87, 0x54, 0x3D, 0xEC, 0x8C, 0x00, 0x3C, 0x54, 0x5C, 0x63, 0x11, 0x98, 0x05, 0xE1, 0xFE,
|
||||
0x1F, 0x81, 0xB8, 0x32, 0x96, 0x43, 0x83, 0xD7, 0xD6, 0xA4, 0xD1, 0x41, 0x4C, 0x6D, 0x1B, 0xCB,
|
||||
0x93, 0x90, 0x24, 0xAE, 0x2B, 0xCD, 0xD0, 0x3C, 0x54, 0x5D, 0x67, 0x41, 0x98, 0x07, 0xE1, 0x7E,
|
||||
0x1F, 0x83, 0x48, 0x64, 0xDB, 0x58, 0x86, 0x3A, 0xCD, 0x4B, 0xA1, 0x5F, 0x9F, 0x1E, 0x84, 0x6B,
|
||||
0xA6, 0x24, 0x02, 0x0B, 0x72, 0x31, 0x20, 0x3C, 0x42, 0x5D, 0x67, 0x11, 0x98, 0x13, 0xE0, 0xDE,
|
||||
0x1F, 0x81, 0xAA, 0x91, 0xDA, 0x0D, 0x90, 0xFB, 0x22, 0x5A, 0xC8, 0xFF, 0xC4, 0xD8, 0x8E, 0x57,
|
||||
0xFB, 0xA0, 0x46, 0x60, 0xD6, 0xB0, 0xA0, 0x3C, 0x44, 0x41, 0x67, 0x19, 0x87, 0xF7, 0x68, 0x9E,
|
||||
0x05, 0x2A, 0x1A, 0xEB, 0x9F, 0x45, 0xB5, 0x97, 0x5F, 0xFD, 0xD2, 0x8E, 0x0F, 0xD2, 0x0F, 0x8E,
|
||||
0xC0, 0x36, 0xB8, 0x1B, 0xF8, 0x52, 0xA0, 0x3C, 0xE1, 0x78, 0x79, 0x11, 0x86, 0x54, 0x1E, 0x5E,
|
||||
0x12, 0xD9, 0xCA, 0xDA, 0xC5, 0x44, 0xFA, 0xF7, 0x0E, 0xE7, 0x7D, 0x62, 0x26, 0x08, 0x24, 0x02,
|
||||
0x74, 0x16, 0xB4, 0xD4, 0xBA, 0xCF, 0x20, 0x3C, 0x10, 0x12, 0x32, 0x49, 0x2B, 0x66, 0x07, 0x8F,
|
||||
0x11, 0x76, 0x4C, 0x24, 0x82, 0x93, 0xD1, 0x3B, 0xDC, 0x3A, 0xF2, 0x3D, 0x47, 0x19, 0x91, 0xC3,
|
||||
0xCB, 0x93, 0x67, 0xE8, 0x4E, 0x82, 0xD0, 0x3C, 0x0E, 0x0E, 0x38, 0x30, 0x72, 0xF3, 0xA4, 0x01,
|
||||
0xFE, 0x7F, 0x7A, 0x63, 0x3D, 0xE4, 0xAE, 0xC4, 0xFF, 0x88, 0x95, 0xC9, 0x9F, 0x3D, 0xBB, 0x5B,
|
||||
0x65, 0x27, 0x8F, 0x69, 0x00, 0x10, 0x10, 0x3C, 0x0C, 0x08, 0x3A, 0x48, 0x64, 0xFF, 0xF8, 0x45,
|
||||
0xBA, 0x7F, 0xBA, 0xC4, 0xB5, 0x09, 0xE3, 0xC1, 0x6E, 0x27, 0x58, 0x01, 0x6D, 0x3B, 0xEE, 0x1C,
|
||||
0xA3, 0x7A, 0xA0, 0x17, 0x80, 0xAD, 0x00, 0x3C, 0x0C, 0x0E, 0x42, 0x40, 0x61, 0x09, 0xE0, 0x23,
|
||||
0xC9, 0x2A, 0xFA, 0x31, 0xC3, 0xF4, 0x4F, 0x22, 0x1A, 0x07, 0x70, 0xCB, 0x1B, 0xF2, 0x55, 0xEA,
|
||||
0x82, 0x72, 0x19, 0x4B, 0x2E, 0xD3, 0xF0, 0x3C, 0x12, 0x09, 0x89, 0x40, 0x1F, 0xD7, 0x9F, 0xE5,
|
||||
0xAA, 0xD5, 0x6A, 0x0C, 0x6B, 0xA3, 0xC5, 0xFC, 0x74, 0xFD, 0x72, 0x74, 0xAF, 0x86, 0x1F, 0x15,
|
||||
0xA8, 0x63, 0xB0, 0x65, 0x11, 0x54, 0x10, 0x3C, 0x0C, 0x06, 0x2D, 0x42, 0xB9, 0xEE, 0x19, 0xA0,
|
||||
0xF8, 0xF6, 0xDA, 0x94, 0x53, 0x37, 0x3A, 0xC9, 0xC7, 0xA3, 0x22, 0x78, 0x9A, 0xAB, 0xF2, 0x20,
|
||||
0x55, 0x7B, 0xD2, 0x84, 0x13, 0x54, 0x80, 0x3C, 0x24, 0x08, 0xDC, 0x38, 0x18, 0xA4, 0x09, 0x81,
|
||||
0x87, 0x04, 0x5B, 0x6E, 0xE4, 0x5A, 0x53, 0x6C, 0x1F, 0xF1, 0x52, 0xF4, 0xB1, 0xF9, 0x8C, 0x11,
|
||||
0xBB, 0xCE, 0x90, 0xDD, 0x36, 0x93, 0xC0, 0x3C, 0x08, 0x88, 0x58, 0x3D, 0x56, 0x24, 0x01, 0x81,
|
||||
0x10, 0x9C, 0x96, 0x2E, 0x55, 0xCD, 0x55, 0xAD, 0xA3, 0xA6, 0xF2, 0x37, 0x3A, 0x53, 0x4A, 0xF5,
|
||||
0xC5, 0xFC, 0x90, 0x1F, 0x1A, 0x99, 0x20,
|
||||
};
|
||||
@@ -0,0 +1,104 @@
|
||||
const unsigned char audio_alipay_data[] =
|
||||
{
|
||||
0x23, 0x21, 0x41, 0x4D, 0x52, 0x0A, 0x3C, 0x71, 0xC7, 0x43, 0xD9, 0x06, 0xA3, 0x81, 0xAC,
|
||||
0xAC, 0x4B, 0xBF, 0xC5, 0x65, 0x62, 0x27, 0xC0, 0x00, 0x7B, 0x97, 0xE2, 0x73, 0xAA, 0x6C, 0x00,
|
||||
0x07, 0x3E, 0xFA, 0xC1, 0x76, 0x0C, 0x60, 0x3C, 0x55, 0xE8, 0xFF, 0xD4, 0xCF, 0x2E, 0x1E, 0x5E,
|
||||
0x04, 0x03, 0x18, 0x4B, 0x71, 0x95, 0xD6, 0xCB, 0xF6, 0x88, 0xBE, 0x63, 0x3A, 0x0C, 0x6A, 0xA7,
|
||||
0x05, 0x35, 0x43, 0x28, 0x53, 0xEE, 0xF0, 0x3C, 0xB5, 0xDA, 0xB1, 0xCB, 0x30, 0x53, 0x23, 0x9E,
|
||||
0x0A, 0x67, 0x8F, 0xE2, 0x78, 0x01, 0x1C, 0xB4, 0x81, 0x57, 0xEB, 0xFF, 0x84, 0x0B, 0x10, 0x70,
|
||||
0xA0, 0x41, 0x60, 0x2A, 0xD5, 0x03, 0x00, 0x3C, 0xF3, 0xB6, 0xB5, 0xC7, 0x7D, 0x8C, 0x1B, 0x5E,
|
||||
0x16, 0x48, 0x07, 0x94, 0xB5, 0xB0, 0xEA, 0x3F, 0xC7, 0x6A, 0xE5, 0xE0, 0xC3, 0x8B, 0x5C, 0x0F,
|
||||
0xE0, 0xFB, 0xA6, 0x3A, 0xB6, 0x7F, 0x20, 0x3C, 0x2E, 0x0E, 0x88, 0xB8, 0x01, 0xAC, 0x16, 0x7E,
|
||||
0x12, 0x0A, 0x59, 0x56, 0x9D, 0xBF, 0x05, 0xA4, 0x7A, 0xF7, 0xAD, 0x38, 0x31, 0x59, 0xD5, 0x9C,
|
||||
0x40, 0x57, 0xF8, 0x96, 0xC5, 0x13, 0x00, 0x3C, 0x24, 0xB8, 0x95, 0xB8, 0x01, 0xE7, 0xC3, 0x1E,
|
||||
0x06, 0x1B, 0x52, 0xF8, 0xBD, 0x44, 0x94, 0xD2, 0xA7, 0x0C, 0x96, 0x79, 0xCF, 0x80, 0xD5, 0x43,
|
||||
0x9F, 0x90, 0x5F, 0xF2, 0x87, 0xEB, 0x70, 0x3C, 0x2C, 0xAD, 0x29, 0x28, 0x01, 0x85, 0x0C, 0xFE,
|
||||
0x0C, 0x18, 0x0B, 0xE9, 0x6D, 0x9B, 0x60, 0xEC, 0xD3, 0x66, 0xD1, 0x88, 0x11, 0xF9, 0x3C, 0x94,
|
||||
0xD8, 0xC0, 0xF0, 0x13, 0x22, 0x7E, 0x30, 0x3C, 0x2C, 0xAC, 0x9A, 0xB0, 0xAA, 0x76, 0x11, 0xDC,
|
||||
0x22, 0x0F, 0xBB, 0x59, 0x0B, 0xEC, 0xF5, 0xFC, 0x9E, 0x59, 0x10, 0xD1, 0x53, 0x42, 0xA4, 0x69,
|
||||
0x27, 0xBC, 0x1A, 0xBB, 0x6D, 0x53, 0xF0, 0x3C, 0x2F, 0x9F, 0x1D, 0x8C, 0x2F, 0xBA, 0x00, 0x6B,
|
||||
0x55, 0x4F, 0x2F, 0xD9, 0x15, 0xAF, 0x5B, 0x44, 0x33, 0xFF, 0x89, 0xA8, 0xBE, 0xB0, 0x42, 0x66,
|
||||
0x25, 0x23, 0xB6, 0xF9, 0x61, 0x46, 0x40, 0x3C, 0xB5, 0x13, 0x34, 0xA4, 0x42, 0x30, 0x09, 0x45,
|
||||
0xBA, 0x5F, 0x3A, 0xDF, 0x82, 0xF6, 0x44, 0xE8, 0x95, 0x75, 0x5B, 0x3C, 0xAB, 0x3D, 0xC9, 0xF2,
|
||||
0xA6, 0x8F, 0xC7, 0xA1, 0xEE, 0xEA, 0xC0, 0x3C, 0xF3, 0x3E, 0x59, 0x41, 0x54, 0xF2, 0x10, 0xBE,
|
||||
0x02, 0x01, 0x77, 0x37, 0x99, 0xEE, 0xDB, 0x86, 0xB2, 0xF7, 0x6B, 0x82, 0x7E, 0xF9, 0xA0, 0xBE,
|
||||
0x53, 0xF9, 0x96, 0x90, 0xBF, 0x0F, 0xE0, 0x3C, 0x37, 0x7A, 0x02, 0x50, 0x00, 0x82, 0x74, 0x54,
|
||||
0xAA, 0x18, 0xCF, 0xF3, 0x94, 0xEF, 0x4E, 0xA8, 0x28, 0x8E, 0x14, 0x1C, 0xBF, 0xDE, 0x94, 0xA1,
|
||||
0xE3, 0x64, 0x7C, 0x59, 0x35, 0x1E, 0xF0, 0x3C, 0x1C, 0x44, 0x0D, 0xE8, 0x01, 0xBB, 0xE1, 0xD8,
|
||||
0x62, 0x34, 0x5F, 0xD5, 0xCF, 0xEB, 0x91, 0x8A, 0x0E, 0x7B, 0x5D, 0x82, 0x0D, 0xC1, 0xFD, 0x75,
|
||||
0x9E, 0x6D, 0x34, 0x57, 0x5E, 0xD0, 0x10, 0x3C, 0x24, 0x1D, 0xBE, 0x38, 0x06, 0xE1, 0x85, 0x12,
|
||||
0xCC, 0xEF, 0x5F, 0xBD, 0x1F, 0x57, 0x3D, 0x9F, 0x97, 0x64, 0x29, 0xBC, 0x8E, 0x9B, 0xF9, 0xE1,
|
||||
0x91, 0xDC, 0xF2, 0xBF, 0xB2, 0x2A, 0xC0, 0x3C, 0x06, 0x19, 0x9F, 0x51, 0x5C, 0xFB, 0x44, 0x70,
|
||||
0x6C, 0xBF, 0x4B, 0xFE, 0x42, 0xF9, 0x8F, 0x46, 0x1B, 0x10, 0x8B, 0xD1, 0xD1, 0xA6, 0xD9, 0x48,
|
||||
0x20, 0x7F, 0x6E, 0xB4, 0xF1, 0xD5, 0x80, 0x3C, 0x0C, 0x02, 0x64, 0x98, 0x35, 0x84, 0x11, 0xA0,
|
||||
0xD3, 0x00, 0x9F, 0xA0, 0x58, 0xA1, 0x49, 0xBD, 0x9B, 0x78, 0x76, 0x56, 0x19, 0x0C, 0xE2, 0x8E,
|
||||
0xC9, 0x0E, 0x14, 0x9A, 0x13, 0x60, 0x30, 0x3C, 0x20, 0x6E, 0x40, 0x68, 0x33, 0x11, 0x67, 0xFE,
|
||||
0x31, 0xF1, 0xD4, 0xF4, 0x37, 0xE4, 0x25, 0x23, 0xC8, 0x7B, 0xCB, 0x5C, 0xC3, 0xE1, 0xF7, 0xFE,
|
||||
0xCD, 0x7F, 0xCF, 0x72, 0x4E, 0xFF, 0x10, 0x3C, 0x4F, 0x7E, 0x0E, 0xE8, 0x67, 0xC6, 0xA5, 0xDE,
|
||||
0x14, 0xDE, 0xEF, 0xC7, 0x2B, 0x8C, 0x52, 0xDD, 0x16, 0x2E, 0xD8, 0x38, 0x00, 0x34, 0x59, 0xF6,
|
||||
0xD3, 0x87, 0xCA, 0xA0, 0x17, 0x76, 0x10, 0x3C, 0x44, 0xEA, 0x0B, 0x00, 0x7B, 0xC5, 0xF0, 0x1E,
|
||||
0x31, 0x8C, 0x48, 0xA0, 0x83, 0xE7, 0x4C, 0x2C, 0xCC, 0x12, 0x37, 0xA6, 0x04, 0x28, 0xA0, 0x65,
|
||||
0x30, 0x31, 0x42, 0x2A, 0xA3, 0x82, 0x60, 0x3C, 0x42, 0x4A, 0x13, 0x61, 0x80, 0x81, 0xF0, 0x9E,
|
||||
0x05, 0x86, 0xAF, 0x63, 0xCA, 0x35, 0x15, 0xDD, 0x56, 0xE3, 0xE3, 0x04, 0xA4, 0xCD, 0x23, 0x86,
|
||||
0x03, 0xAE, 0x71, 0xDB, 0xF7, 0xF8, 0xD0, 0x3C, 0x44, 0x4C, 0x11, 0x01, 0x86, 0xBE, 0x3D, 0xCF,
|
||||
0x11, 0x98, 0x8C, 0xCB, 0xF0, 0xA0, 0x0F, 0x11, 0xF0, 0x82, 0x40, 0x34, 0xFE, 0x30, 0x4C, 0x46,
|
||||
0x9C, 0x74, 0x14, 0x76, 0x34, 0x78, 0x50, 0x3C, 0x21, 0x7A, 0x16, 0xE9, 0x9B, 0xCC, 0x79, 0x7E,
|
||||
0x01, 0x92, 0xAF, 0xC0, 0x3C, 0x69, 0xC3, 0xF7, 0x7A, 0xFD, 0xCC, 0x53, 0x13, 0xC1, 0x52, 0x19,
|
||||
0xAB, 0xF7, 0x99, 0xC4, 0xB8, 0x4E, 0x50, 0x3C, 0x0E, 0x13, 0x87, 0x51, 0x9F, 0xAD, 0x68, 0xE9,
|
||||
0x77, 0x84, 0x42, 0x47, 0x21, 0xEC, 0xFB, 0x1B, 0x52, 0xCC, 0x72, 0x75, 0x56, 0x4E, 0xD8, 0xD2,
|
||||
0xB9, 0x3D, 0xD7, 0x63, 0x27, 0x15, 0xF0, 0x3C, 0x06, 0x14, 0x7D, 0x79, 0x9E, 0x76, 0x1E, 0x6D,
|
||||
0x32, 0x73, 0x7A, 0xE1, 0x4F, 0x99, 0xDB, 0xC5, 0x2D, 0x2F, 0xC6, 0x75, 0xD6, 0x27, 0x0C, 0x07,
|
||||
0xE0, 0x1C, 0x9D, 0x28, 0xE6, 0xD4, 0x70, 0x3C, 0x05, 0xFE, 0xAD, 0xA9, 0x9D, 0xBB, 0x1F, 0x9E,
|
||||
0x13, 0x9B, 0xE7, 0x82, 0x13, 0xE8, 0xED, 0x03, 0xEB, 0x0E, 0x1D, 0x36, 0xFA, 0x50, 0x9C, 0xE4,
|
||||
0xEC, 0x30, 0x00, 0xB2, 0x0D, 0xA6, 0x70, 0x3C, 0xE1, 0xDD, 0x06, 0xC2, 0xF3, 0x70, 0x0A, 0x76,
|
||||
0x88, 0x90, 0xAF, 0x8F, 0x4D, 0xB1, 0x07, 0x8F, 0x36, 0xA7, 0x6A, 0x83, 0x13, 0x18, 0x81, 0xC8,
|
||||
0x44, 0x4B, 0x63, 0x66, 0xD4, 0x6C, 0xF0, 0x3C, 0x53, 0xE5, 0x06, 0xC5, 0x52, 0x02, 0x1D, 0x1E,
|
||||
0x03, 0xA8, 0x0A, 0xDE, 0x13, 0xCB, 0xD0, 0x56, 0xBF, 0xB6, 0xC1, 0xE1, 0x78, 0xC8, 0x8F, 0xAC,
|
||||
0xD8, 0x7E, 0x8D, 0x38, 0x93, 0x9B, 0x30, 0x3C, 0xD1, 0xCD, 0x07, 0xD5, 0x64, 0xFA, 0xB9, 0x1E,
|
||||
0x02, 0xC1, 0x39, 0x0E, 0x1C, 0x03, 0x85, 0xE6, 0x4B, 0x87, 0x3B, 0x87, 0x79, 0x62, 0x5E, 0xD3,
|
||||
0x0E, 0xFA, 0x6E, 0xF9, 0x20, 0x32, 0xB0, 0x3C, 0xF3, 0xE6, 0xB4, 0xBE, 0xA2, 0x6A, 0x10, 0xFE,
|
||||
0x07, 0x1F, 0x97, 0xA8, 0x8F, 0x25, 0xA8, 0x36, 0x10, 0x8C, 0x81, 0x78, 0xDB, 0x31, 0xFD, 0xAA,
|
||||
0xC1, 0x3E, 0xEE, 0xA4, 0x2C, 0xA1, 0xC0, 0x3C, 0x28, 0x0E, 0x18, 0x48, 0x0C, 0x69, 0x17, 0x9E,
|
||||
0x17, 0x94, 0x73, 0xBD, 0xEC, 0x18, 0x07, 0xF6, 0xCB, 0xC2, 0xFD, 0x35, 0x82, 0x77, 0xD1, 0xF1,
|
||||
0xB7, 0x85, 0x90, 0x44, 0x4C, 0xD8, 0xA0, 0x3C, 0x46, 0x6D, 0x90, 0xE8, 0x19, 0x82, 0x79, 0xFA,
|
||||
0x4D, 0x81, 0xD9, 0xB9, 0x39, 0x3D, 0x28, 0x80, 0xC0, 0x2C, 0x5D, 0x9C, 0x0C, 0x5D, 0x66, 0x38,
|
||||
0xD0, 0x94, 0xBE, 0xEE, 0x18, 0xB3, 0x90, 0x3C, 0x35, 0x7A, 0x02, 0x50, 0x19, 0x91, 0x68, 0x89,
|
||||
0x77, 0x80, 0x1A, 0x3F, 0x26, 0x94, 0xBD, 0xE5, 0x4A, 0x83, 0x97, 0x9E, 0x9D, 0x93, 0x68, 0x3A,
|
||||
0x48, 0x9C, 0x5E, 0x54, 0xE0, 0x48, 0xB0, 0x3C, 0x30, 0x41, 0xAE, 0x58, 0x18, 0x4F, 0xE0, 0x58,
|
||||
0x66, 0xD5, 0x9E, 0x92, 0x53, 0x1C, 0x43, 0xF2, 0x8C, 0x6D, 0x03, 0x3B, 0xE0, 0x03, 0x0F, 0x00,
|
||||
0x84, 0x6A, 0x7A, 0x10, 0x26, 0x61, 0xE0, 0x3C, 0x1C, 0x44, 0x02, 0x50, 0x18, 0x04, 0x1F, 0xAB,
|
||||
0x54, 0x7F, 0xDF, 0xE8, 0xE7, 0xA8, 0x25, 0x93, 0x4A, 0x66, 0x8C, 0xFA, 0x0C, 0x34, 0xCF, 0xFC,
|
||||
0x05, 0x09, 0x80, 0xCB, 0x91, 0x39, 0xF0, 0x3C, 0x24, 0x54, 0x09, 0x10, 0x12, 0xE0, 0x01, 0xE1,
|
||||
0xF9, 0x85, 0xDB, 0x11, 0xA1, 0x5F, 0x52, 0x6C, 0xD3, 0xEC, 0x45, 0x77, 0x44, 0xB5, 0x64, 0x78,
|
||||
0x44, 0x6F, 0x89, 0x81, 0xE3, 0xAA, 0x30, 0x3C, 0x8A, 0xEB, 0x93, 0x65, 0x66, 0xD8, 0x2B, 0x87,
|
||||
0x91, 0x9A, 0xA3, 0x06, 0xFC, 0xB7, 0xD4, 0x3A, 0xA5, 0xDB, 0x74, 0x2F, 0x4C, 0x09, 0x70, 0x32,
|
||||
0xE8, 0x72, 0x63, 0xD7, 0x3D, 0x49, 0xD0, 0x3C, 0x28, 0x6C, 0x0F, 0x13, 0xF3, 0x28, 0x1D, 0xFA,
|
||||
0x54, 0x97, 0x7C, 0x62, 0x1A, 0x77, 0xBF, 0x35, 0xC0, 0x08, 0x68, 0xBC, 0xA1, 0x93, 0xA5, 0x44,
|
||||
0x6B, 0xE0, 0x4D, 0x3A, 0x71, 0x74, 0xA0, 0x3C, 0x8B, 0x2D, 0x8D, 0x55, 0xE1, 0xF4, 0x30, 0x96,
|
||||
0x9B, 0x87, 0x49, 0x7E, 0x1D, 0x0F, 0x01, 0x31, 0x4C, 0x8F, 0x1C, 0x19, 0x76, 0x58, 0x66, 0x57,
|
||||
0xEE, 0x02, 0x93, 0x2C, 0x37, 0xCF, 0x30, 0x3C, 0x68, 0x72, 0x21, 0x1C, 0x03, 0xAA, 0x01, 0xBE,
|
||||
0x01, 0x81, 0x4A, 0x71, 0xAF, 0xDB, 0x64, 0x4F, 0xD3, 0x31, 0x58, 0x2B, 0x71, 0x24, 0x8D, 0xD8,
|
||||
0x1B, 0x59, 0x12, 0x2C, 0x9C, 0x65, 0x80, 0x3C, 0xE4, 0x71, 0x93, 0x54, 0x34, 0x9A, 0x74, 0xDE,
|
||||
0x01, 0x88, 0xDF, 0xE7, 0x56, 0xBC, 0x18, 0xFE, 0xC8, 0xE2, 0xC9, 0x0B, 0x3E, 0x7A, 0xA2, 0x02,
|
||||
0xEC, 0x71, 0x3F, 0xDD, 0x9F, 0x09, 0x80, 0x3C, 0xF2, 0x5B, 0x7B, 0x18, 0x67, 0x8C, 0x3D, 0x1E,
|
||||
0x05, 0x6F, 0x5A, 0x1D, 0x0F, 0x96, 0xCA, 0x36, 0xDE, 0x18, 0x74, 0x7C, 0x16, 0xE0, 0x34, 0x9B,
|
||||
0x0F, 0x0B, 0x14, 0x5C, 0x92, 0x94, 0x90, 0x3C, 0xE0, 0x63, 0x88, 0x62, 0xEB, 0x3E, 0x20, 0x9E,
|
||||
0x07, 0x39, 0x3F, 0x9A, 0x24, 0xC9, 0x94, 0xD5, 0xA9, 0xEC, 0x1C, 0xC5, 0x22, 0x2E, 0xF5, 0x9E,
|
||||
0x9F, 0x03, 0x6E, 0xF7, 0xDC, 0x76, 0x20, 0x3C, 0x16, 0x62, 0x2D, 0x20, 0xD5, 0x96, 0x25, 0xDE,
|
||||
0x11, 0xA5, 0xB8, 0xE7, 0x13, 0x1A, 0xBF, 0x07, 0x8A, 0x59, 0xD4, 0x66, 0x7E, 0x64, 0xD4, 0xD1,
|
||||
0x92, 0x1B, 0xD4, 0xD5, 0x8C, 0x9E, 0x60, 0x3C, 0xE0, 0x68, 0x28, 0x0B, 0xAD, 0xDC, 0x12, 0x5E,
|
||||
0x05, 0xF4, 0x1A, 0xDF, 0x18, 0x00, 0xFC, 0x8B, 0x69, 0x18, 0xA1, 0x42, 0xC7, 0x9C, 0x17, 0x86,
|
||||
0x67, 0x40, 0x20, 0x47, 0xB7, 0x7B, 0x80, 0x3C, 0xD8, 0x56, 0x30, 0x49, 0xE3, 0x08, 0x5B, 0xDE,
|
||||
0x05, 0xA5, 0xA8, 0x08, 0x1D, 0x5D, 0xA4, 0x46, 0x1B, 0x0E, 0x29, 0x54, 0x2F, 0xE6, 0xF3, 0x03,
|
||||
0xDC, 0x04, 0x21, 0x18, 0x8D, 0x31, 0xE0, 0x3C, 0xE0, 0x5D, 0x64, 0x11, 0xF8, 0xB6, 0x1E, 0x9C,
|
||||
0x2B, 0xA5, 0xC8, 0x09, 0xE6, 0xB5, 0x5A, 0xF4, 0xED, 0x0A, 0xE2, 0x92, 0x2C, 0x4E, 0x9C, 0xCB,
|
||||
0xE0, 0x3A, 0x32, 0x4F, 0x8F, 0x57, 0x70, 0x3C, 0x1A, 0x47, 0x71, 0x1E, 0x00, 0xC4, 0x1E, 0xDE,
|
||||
0x00, 0xF5, 0x39, 0x1A, 0x94, 0xE7, 0xCB, 0xB2, 0x88, 0xF1, 0x38, 0x3E, 0x83, 0xE0, 0x6E, 0x01,
|
||||
0x9F, 0xE8, 0x37, 0xFD, 0x00, 0x74, 0x80, 0x3C, 0x08, 0x47, 0x6D, 0x14, 0xAE, 0xE0, 0x07, 0x8D,
|
||||
0x33, 0xAA, 0x47, 0x51, 0xE9, 0x90, 0x6C, 0x1C, 0x04, 0x5E, 0x81, 0xEF, 0x97, 0xA6, 0xD7, 0x09,
|
||||
0x50, 0xC5, 0x43, 0xAB, 0xF1, 0x78, 0xE0, 0x3C, 0x0C, 0x08, 0x4A, 0x1C, 0x20, 0xC6, 0x43, 0x01,
|
||||
0x6C, 0x28, 0xBA, 0x4E, 0x42, 0xCE, 0x89, 0x0A, 0xB7, 0x9E, 0x6D, 0x72, 0x13, 0xFF, 0xA1, 0xAB,
|
||||
0xF0, 0x73, 0xF8, 0x90, 0x98, 0x0C, 0xD0, 0x3C, 0x06, 0x1A, 0x85, 0x84, 0x8A, 0x12, 0x01, 0xC5,
|
||||
0x00, 0xAD, 0xDA, 0x09, 0x2B, 0xF9, 0xC9, 0xD6, 0xBC, 0xED, 0xC0, 0x7F, 0xFF, 0x80, 0x10, 0xC5,
|
||||
0xC0, 0xE5, 0xD1, 0xE7, 0xA0, 0x06, 0xD0,
|
||||
};
|
||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,212 @@
|
||||
//demo用于AIR600EAC云喇叭开发
|
||||
#include "common_api.h"
|
||||
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_audio_play_ec618.h"
|
||||
#include "luat_i2s_ec618.h"
|
||||
#include "ivTTSSDKID_all.h"
|
||||
#include "ivTTS.h"
|
||||
#include "amr_alipay_data.h"
|
||||
#include "amr_2_data.h"
|
||||
#include "amr_10_data.h"
|
||||
#include "amr_yuan_data.h"
|
||||
#include "power_audio.h"
|
||||
#include "luat_gpio.h"
|
||||
#include "luat_debug.h"
|
||||
//AIR780E+TM8211开发板配置
|
||||
#define CODEC_PWR_PIN HAL_GPIO_12
|
||||
#define CODEC_PWR_PIN_ALT_FUN 4
|
||||
#define PA_PWR_PIN HAL_GPIO_25
|
||||
#define PA_PWR_PIN_ALT_FUN 0
|
||||
#define LED2_PIN HAL_GPIO_24
|
||||
#define LED2_PIN_ALT_FUN 0
|
||||
#define LED3_PIN HAL_GPIO_23
|
||||
#define LED3_PIN_ALT_FUN 0
|
||||
#define LED4_PIN HAL_GPIO_27
|
||||
#define LED4_PIN_ALT_FUN 0
|
||||
#define CHARGE_EN_PIN HAL_GPIO_2
|
||||
#define CHARGE_EN_PIN_ALT_FUN 0
|
||||
|
||||
//AIR600EAC开发板配置
|
||||
//#define CODEC_PWR_PIN HAL_GPIO_12
|
||||
//#define CODEC_PWR_PIN_ALT_FUN 4
|
||||
//#define PA_PWR_PIN HAL_GPIO_10
|
||||
//#define PA_PWR_PIN_ALT_FUN 0
|
||||
//#define CODEC_PWR_PIN HAL_GPIO_12
|
||||
//#define CODEC_PWR_PIN_ALT_FUN 4
|
||||
//#define PA_PWR_PIN HAL_GPIO_10
|
||||
//#define PA_PWR_PIN_ALT_FUN 0
|
||||
//#define LED2_PIN HAL_GPIO_26
|
||||
//#define LED2_PIN_ALT_FUN 0
|
||||
//#define LED3_PIN HAL_GPIO_27
|
||||
//#define LED3_PIN_ALT_FUN 0
|
||||
//#define LED4_PIN HAL_GPIO_20
|
||||
//#define LED4_PIN_ALT_FUN 0
|
||||
//#define CHARGE_EN_PIN HAL_GPIO_NONE
|
||||
//#define CHARGE_EN_PIN_ALT_FUN 0
|
||||
|
||||
//#include "luat_transz.h"
|
||||
//const luat_transz_data_t ivtts_8k_tz = {
|
||||
// .total_size = 641776,
|
||||
// .block_size = 4096,
|
||||
// .compress_mode = TZ_COMPRESS_GZ,
|
||||
// .fragments = ivtts_8k_tz_frags,
|
||||
// .datas = ivtts_8k_tz_data,
|
||||
//};
|
||||
//
|
||||
//const luat_transz_data_t ivtts_16k_tz = {
|
||||
// .total_size = 719278,
|
||||
// .block_size = 4096,
|
||||
// .compress_mode = TZ_COMPRESS_GZ,
|
||||
// .fragments = ivtts_16k_tz_frags,
|
||||
// .datas = ivtts_16k_tz_data,
|
||||
//};
|
||||
|
||||
|
||||
|
||||
extern void download_file();
|
||||
static HANDLE g_s_delay_timer;
|
||||
|
||||
void app_pa_on(uint32_t arg)
|
||||
{
|
||||
luat_gpio_set(PA_PWR_PIN, 1);
|
||||
}
|
||||
|
||||
void audio_event_cb(uint32_t event, void *param)
|
||||
{
|
||||
// PadConfig_t pad_config;
|
||||
// GpioPinConfig_t gpio_config;
|
||||
|
||||
LUAT_DEBUG_PRINT("%d", event);
|
||||
switch(event)
|
||||
{
|
||||
case LUAT_MULTIMEDIA_CB_AUDIO_DECODE_START:
|
||||
luat_gpio_set(CODEC_PWR_PIN, 1);
|
||||
luat_audio_play_write_blank_raw(0, 6, 1);
|
||||
break;
|
||||
case LUAT_MULTIMEDIA_CB_AUDIO_OUTPUT_START:
|
||||
luat_rtos_timer_start(g_s_delay_timer, 200, 0, app_pa_on, NULL);
|
||||
break;
|
||||
case LUAT_MULTIMEDIA_CB_TTS_INIT:
|
||||
break;
|
||||
case LUAT_MULTIMEDIA_CB_TTS_DONE:
|
||||
if (!luat_audio_play_get_last_error(0))
|
||||
{
|
||||
luat_audio_play_write_blank_raw(0, 1, 0);
|
||||
}
|
||||
break;
|
||||
case LUAT_MULTIMEDIA_CB_AUDIO_DONE:
|
||||
luat_rtos_timer_stop(g_s_delay_timer);
|
||||
LUAT_DEBUG_PRINT("audio play done, result=%d!", luat_audio_play_get_last_error(0));
|
||||
luat_gpio_set(PA_PWR_PIN, 0);
|
||||
luat_gpio_set(CODEC_PWR_PIN, 0);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void audio_data_cb(uint8_t *data, uint32_t len, uint8_t bits, uint8_t channels)
|
||||
{
|
||||
//这里可以对音频数据进行软件音量缩放,或者直接清空来静音
|
||||
//软件音量缩放参考HAL_I2sSrcAdjustVolumn
|
||||
//LUAT_DEBUG_PRINT("%x,%d,%d,%d", data, len, bits, channels);
|
||||
}
|
||||
|
||||
ivBool tts_read_data(
|
||||
ivPointer pParameter, /* [in] user callback parameter */
|
||||
ivPointer pBuffer, /* [out] read resource buffer */
|
||||
ivResAddress iPos, /* [in] read start position */
|
||||
ivResSize nSize ) /* [in] read size */
|
||||
{
|
||||
LUAT_DEBUG_PRINT("%x,%d,%d", pParameter, iPos, nSize);
|
||||
memcpy((uint8_t *)pBuffer, (uint8_t *)pParameter + iPos, nSize);
|
||||
return ivTrue;
|
||||
}
|
||||
|
||||
static void demo_task(void *arg)
|
||||
{
|
||||
// luat_rtos_task_sleep(3000);
|
||||
ivCStrA sdk_id = AISOUND_SDK_USERID_16K;
|
||||
//8K用下面的
|
||||
// ivCStrA sdk_id = AISOUND_SDK_USERID_8K;
|
||||
char tts_string[] = "支付宝到账123.45元,微信收款9876.12元ABC";
|
||||
luat_audio_play_info_t info[5];
|
||||
// slpManRegisterUsrdefinedBackupCb(before_sleep, NULL);
|
||||
// slpManRegisterUsrdefinedRestoreCb(after_sleep, NULL);
|
||||
download_file();
|
||||
luat_rtos_timer_create(&g_s_delay_timer);
|
||||
luat_audio_play_global_init(audio_event_cb, audio_data_cb, luat_audio_play_file_default_fun, luat_audio_play_tts_default_fun, NULL);
|
||||
// 无压缩版本
|
||||
luat_audio_play_tts_set_resource(ivtts_16k, sdk_id, NULL);
|
||||
//8K用下面的
|
||||
// luat_audio_play_tts_set_resource(ivtts_8k, sdk_id, NULL);
|
||||
// 透明解压版本
|
||||
//luat_audio_play_tts_set_resource(&ivtts_16k_tz, sdk_id, luat_transz_read);
|
||||
//使用ES7149/ES7148,用如下配置,如果不是,请根据实际情况配置,bus_id直接写0
|
||||
// luat_i2s_base_setup(0, I2S_MODE_I2S, I2S_FRAME_SIZE_16_16);
|
||||
// 如下配置可使用TM8211
|
||||
luat_i2s_base_setup(0, I2S_MODE_MSB, I2S_FRAME_SIZE_16_16);
|
||||
memset(info, 0, sizeof(info));
|
||||
info[0].path = "test1.mp3";
|
||||
info[1].path = "test2.mp3";
|
||||
info[2].path = "test3.mp3";
|
||||
info[3].path = "test4.mp3";
|
||||
luat_audio_play_multi_files(0, info, 4);
|
||||
luat_rtos_task_sleep(9000);
|
||||
// require_lowpower_state(0);
|
||||
while(1)
|
||||
{
|
||||
|
||||
|
||||
info[0].path = NULL;
|
||||
info[0].address = (uint32_t)amr_alipay_data;
|
||||
info[0].rom_data_len = sizeof(amr_alipay_data);
|
||||
info[1].path = NULL;
|
||||
info[1].address = (uint32_t)amr_2_data;
|
||||
info[1].rom_data_len = sizeof(amr_2_data);
|
||||
info[2].path = NULL;
|
||||
info[2].address = (uint32_t)amr_10_data;
|
||||
info[2].rom_data_len = sizeof(amr_10_data);
|
||||
info[3].path = NULL;
|
||||
info[3].address = (uint32_t)amr_2_data;
|
||||
info[3].rom_data_len = sizeof(amr_2_data);
|
||||
info[4].path = NULL;
|
||||
info[4].address = (uint32_t)amr_yuan_data;
|
||||
info[4].rom_data_len = sizeof(amr_yuan_data);
|
||||
luat_audio_play_multi_files(0, info, 5);
|
||||
luat_rtos_task_sleep(9000);
|
||||
luat_audio_play_tts_text(0, tts_string, sizeof(tts_string));
|
||||
luat_rtos_task_sleep(10000);
|
||||
|
||||
// info[0].path = NULL;
|
||||
// info[0].address = (uint32_t)Fqdqwer;
|
||||
// info[0].rom_data_len = sizeof(Fqdqwer);
|
||||
// audio_play_multi_files(0, info, 1);
|
||||
// vTaskDelay(20000);
|
||||
}
|
||||
}
|
||||
|
||||
static void test_audio_demo_init(void)
|
||||
{
|
||||
luat_gpio_cfg_t gpio_cfg;
|
||||
luat_gpio_set_default_cfg(&gpio_cfg);
|
||||
luat_rtos_task_handle task_handle;
|
||||
|
||||
gpio_cfg.pin = LED2_PIN;
|
||||
gpio_cfg.pull = LUAT_GPIO_DEFAULT;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.pin = LED3_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.pin = LED4_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.pin = CHARGE_EN_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.pin = PA_PWR_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.pin = CODEC_PWR_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.alt_fun = CODEC_PWR_PIN_ALT_FUN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
luat_rtos_task_create(&task_handle, 2048, 20, "test", demo_task, NULL, 0);
|
||||
}
|
||||
|
||||
INIT_TASK_EXPORT(test_audio_demo_init, "1");
|
||||
@@ -0,0 +1,865 @@
|
||||
#include "luat_fs.h"
|
||||
|
||||
// Download mp3 info the area of flash which is file system area
|
||||
const uint8_t batteryCharging[] = {
|
||||
0xFF,0xF3,0x28,0xC4,0x00,0x0D,0x10,0x02,0xC4,0xF7,0x40,0x10,0x00,0x98,0x1A,0x80,
|
||||
0x01,0x80,0x48,0x3D,0xAD,0x10,0xDE,0x7C,0x42,0x20,0x28,0xA5,0xA2,0xAD,0x88,0x0B,
|
||||
0x68,0x7E,0xBE,0x40,0x10,0x2E,0x20,0x89,0xC5,0x76,0xD2,0x18,0x08,0x9A,0x0F,0x80,
|
||||
0xC5,0x04,0xC0,0x30,0x8F,0x2E,0x84,0x75,0x20,0x9D,0xB4,0x67,0xFF,0x41,0xFF,0xFC,
|
||||
0xBA,0xD5,0xCA,0x7D,0x3D,0x60,0xC1,0xD4,0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x81,0xFA,
|
||||
0xC0,0x01,0x83,0x28,0x00,0x99,0x85,0xB4,0x2D,0x99,0xC7,0xAB,0xBB,0x9A,0x72,0x66,
|
||||
0x7C,0x4D,0xCB,0x5C,0xF5,0x17,0x99,0x8A,0x02,0x11,0x1C,0x4A,0x22,0x24,0x08,0x04,
|
||||
0x16,0x6B,0x94,0x82,0xC9,0x28,0x83,0xE5,0xAB,0x27,0xFF,0xB3,0x25,0x0C,0x9F,0xFF,
|
||||
0xFD,0x9F,0x12,0xDB,0xFF,0xFF,0xF2,0x9F,0x92,0xF5,0x54,0xE6,0x25,0xE1,0xF2,0x19,
|
||||
0xFF,0xF3,0x28,0xC4,0x07,0x0C,0x78,0xD2,0xBC,0x01,0xD3,0x78,0x01,0x14,0x02,0x34,
|
||||
0x21,0x29,0x22,0x5E,0x4D,0x9A,0xE6,0x2C,0xE1,0x86,0x00,0xEA,0x0A,0x5D,0x44,0xB9,
|
||||
0xA4,0x6A,0xE2,0xDE,0xB0,0x4E,0xF0,0x83,0xA5,0x19,0xA5,0x81,0x1A,0xB5,0xA3,0x7A,
|
||||
0x91,0x56,0xB2,0xEE,0x13,0xBF,0xB8,0xCA,0x96,0xF1,0xF8,0x1A,0xFF,0xFF,0x1F,0x80,
|
||||
0xA5,0xF5,0x2D,0x4B,0x3C,0x5A,0x16,0x80,0xFF,0xF3,0x28,0xC4,0x10,0x11,0x21,0x6E,
|
||||
0xD6,0x5E,0x6B,0x54,0x94,0x3B,0x9B,0xB9,0x61,0xF4,0x10,0x75,0x71,0xF8,0x25,0xCB,
|
||||
0x6A,0xF4,0x4D,0x5D,0xC0,0xC9,0x05,0xB8,0xBA,0x95,0x66,0x2C,0xA4,0x96,0x87,0x0C,
|
||||
0x83,0x77,0x33,0xFD,0x88,0x55,0x3F,0xF3,0x4F,0xFF,0xCE,0x24,0x3D,0xFE,0x67,0xFF,
|
||||
0xFF,0xFC,0x44,0xEB,0x32,0x27,0x7D,0x67,0x7E,0x9A,0x72,0x31,0x20,0x6A,0x49,0x24,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0D,0xE1,0x6E,0xE6,0x5F,0x4C,0x38,0x02,0x10,0x01,0x9D,
|
||||
0x3B,0x35,0xF5,0x9B,0xA7,0x66,0x43,0x49,0x6F,0xC8,0x66,0xCE,0xC5,0xF3,0xD3,0x37,
|
||||
0x31,0xC0,0xC0,0xAC,0x81,0xE9,0xF5,0x11,0x48,0x17,0xFF,0xC5,0x43,0x2B,0xFF,0x94,
|
||||
0x1B,0x9F,0xFF,0xDF,0xFF,0x41,0xD0,0xE7,0xFF,0x9C,0xFF,0xEB,0x11,0xF9,0x6A,0xC7,
|
||||
0xF2,0xD7,0x25,0x18,0x10,0x17,0x95,0x0A,0xFF,0xF3,0x28,0xC4,0x09,0x0E,0x90,0xF2,
|
||||
0xA0,0x01,0x9A,0x58,0x00,0x83,0x7C,0x1C,0x93,0x05,0x02,0x19,0x38,0x49,0x52,0xC1,
|
||||
0xD4,0xB8,0x72,0x83,0xF1,0xAB,0x4E,0x89,0xC7,0x61,0x63,0xED,0x8C,0x87,0x2A,0xE8,
|
||||
0xFB,0xFE,0x4C,0xEF,0xE5,0x16,0x55,0x4D,0xD7,0xA8,0xBF,0x64,0xFF,0x7A,0x8E,0xFE,
|
||||
0x18,0xFF,0xA8,0x30,0x73,0xE4,0x6A,0xC3,0xFB,0x9E,0x3F,0xCA,0xBE,0xAC,0x9F,0x24,
|
||||
0xFF,0xF3,0x28,0xC4,0x09,0x0F,0x0A,0x4A,0xC4,0x01,0x99,0x50,0x00,0xB7,0x10,0x33,
|
||||
0x08,0x7E,0x4E,0x75,0x97,0x80,0x5D,0x0F,0x4F,0x08,0x14,0xF4,0x38,0xA1,0x0A,0x22,
|
||||
0x12,0x35,0x82,0x06,0xDE,0xBF,0xC6,0x4D,0xAD,0xFF,0xF2,0xFD,0x5F,0xFF,0xFF,0xF7,
|
||||
0x53,0x9B,0xD3,0xA1,0xE7,0xE7,0xB7,0x2D,0xFF,0x4F,0xDD,0xBF,0xE4,0x69,0x28,0xF5,
|
||||
0xD5,0xFF,0x65,0x98,0x90,0x12,0x44,0x0C,0xFF,0xF3,0x28,0xC4,0x07,0x0E,0xF2,0x5A,
|
||||
0xC0,0x01,0xD4,0x68,0x00,0x43,0x11,0xC9,0x1C,0xD2,0xEA,0xD0,0x52,0xA8,0x4E,0x13,
|
||||
0x81,0xA9,0x82,0x00,0x83,0xFE,0xA5,0x92,0x63,0x8C,0xF7,0xFE,0x81,0x82,0x5F,0xFA,
|
||||
0x90,0x30,0x7F,0xFE,0x9A,0x3F,0xFA,0xD3,0x33,0x3D,0xFD,0xD0,0x42,0xA2,0x93,0x76,
|
||||
0xFD,0x32,0xF9,0x05,0xFF,0xD5,0xBF,0xFF,0xA8,0xC5,0xFD,0x48,0x4C,0x0D,0x0B,0x40,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x89,0xAA,0xD0,0x00,0x6B,0xC4,0x94,0xC8,0x00,0xC2,
|
||||
0x23,0xD7,0xFF,0x78,0x0F,0x18,0x0B,0xE1,0xE0,0x26,0x62,0x03,0x16,0xB9,0xA5,0x21,
|
||||
0xBF,0x7F,0x3B,0x1B,0x12,0xB6,0x48,0xDF,0xFD,0xD3,0xF3,0xA2,0x9B,0xFF,0xAF,0xFF,
|
||||
0xFF,0xFF,0xD1,0xA7,0x91,0x03,0x98,0x1A,0x0E,0x50,0x55,0xE4,0xD3,0xB5,0x1A,0x10,
|
||||
0x94,0x2A,0xFD,0x64,0xE0,0x07,0x81,0xA3,0xFF,0xF3,0x28,0xC4,0x06,0x0D,0x18,0x96,
|
||||
0xC8,0x00,0x6E,0x12,0x4C,0x17,0x35,0x3A,0x64,0xD9,0x7F,0xFD,0x49,0xF9,0x03,0xAD,
|
||||
0x11,0x04,0x4F,0x05,0x9B,0x8D,0xB6,0x2C,0x1A,0x10,0x86,0x50,0xA1,0x14,0xCC,0x24,
|
||||
0x2C,0x05,0x74,0xF7,0xFF,0xFE,0xE2,0x24,0x09,0x24,0x55,0x81,0x24,0x1E,0x0D,0x08,
|
||||
0x7F,0xA7,0xFD,0x55,0x37,0xFB,0x65,0xB6,0xD9,0x68,0x00,0x7B,0x06,0xA5,0x0E,0xA1,
|
||||
0xFF,0xF3,0x28,0xC4,0x0C,0x0C,0xD0,0x6E,0xED,0xBE,0x0B,0xD8,0x2A,0x1B,0xAD,0x62,
|
||||
0xE2,0x9A,0x5B,0x0A,0x49,0xC9,0x9F,0x77,0xF7,0xE2,0x84,0x0A,0x5E,0x75,0x2D,0xB1,
|
||||
0xCC,0x76,0xF5,0xB7,0x69,0xC0,0x27,0x2E,0x04,0x8E,0x90,0xA1,0xAB,0xBA,0x2C,0x71,
|
||||
0xE8,0xAA,0xCF,0xFA,0x55,0xFF,0x8C,0xD8,0xD8,0x08,0x4A,0x89,0xA3,0xAC,0xC0,0xB0,
|
||||
0xDC,0x12,0xC6,0x10,0x1E,0x53,0x49,0x48,0xFF,0xF3,0x28,0xC4,0x13,0x0F,0x91,0xAE,
|
||||
0xC8,0x00,0x58,0xC4,0x94,0xF7,0x9C,0xCF,0xA7,0x3F,0xFF,0xFF,0xFF,0xE7,0xA6,0xF9,
|
||||
0xEA,0xF7,0x20,0x76,0x72,0x33,0xAB,0x39,0x4B,0xA2,0xD2,0x72,0x30,0x73,0x28,0x41,
|
||||
0x9E,0x1B,0x32,0xE2,0x1D,0x60,0xE4,0x85,0x64,0xF5,0x85,0xC0,0x82,0x76,0x14,0x87,
|
||||
0xD5,0xF5,0xA8,0xE0,0xDD,0xE1,0xC3,0xA5,0x75,0xA8,0xCD,0x8A,0x6D,0xD8,0xAB,0x3C,
|
||||
0xFF,0xF3,0x28,0xC4,0x0F,0x0B,0xE0,0x8E,0xCC,0x00,0x16,0x1E,0x4C,0x87,0x72,0x87,
|
||||
0x84,0x11,0x59,0x4D,0x7F,0x4C,0x3C,0x52,0x38,0xC7,0xBB,0x57,0x20,0xFE,0xB1,0x1F,
|
||||
0x03,0x93,0x5A,0x43,0x4B,0x3B,0x46,0xAF,0xE2,0x22,0xA1,0xAF,0xF9,0x65,0x09,0x78,
|
||||
0x47,0xF2,0xA2,0x24,0x70,0x15,0xE1,0xCB,0x96,0xCE,0xD9,0xC7,0xF5,0x4B,0x19,0x41,
|
||||
0x08,0xFA,0x2F,0x38,0xD0,0xF5,0x6F,0xD7,0xFF,0xF3,0x28,0xC4,0x1A,0x0C,0xB0,0xDA,
|
||||
0xCC,0xCA,0x96,0x14,0x70,0xEE,0xEA,0x3B,0xC7,0x84,0x51,0x31,0xDA,0x24,0x7E,0x02,
|
||||
0x64,0xA6,0xFD,0x8F,0x24,0x7F,0x13,0xBB,0xFF,0xFF,0xFF,0xFF,0xFE,0x4D,0x01,0x8F,
|
||||
0xDF,0x5F,0x7E,0x00,0x1F,0x81,0xFA,0xCD,0xD5,0x07,0x09,0xF8,0xBA,0xB5,0xF5,0x6F,
|
||||
0xB6,0xC1,0x69,0x3D,0x9F,0xC5,0xF6,0xFF,0xE4,0x7C,0xC7,0x28,0xBF,0x69,0x30,0x1D,
|
||||
0xFF,0xF3,0x28,0xC4,0x22,0x0D,0x40,0xD6,0xEA,0x5E,0x6B,0xDA,0x70,0x20,0xB2,0x5D,
|
||||
0x4F,0xF3,0x23,0xDE,0x77,0xFF,0xFF,0xFF,0xFF,0xFF,0x06,0x8F,0x56,0x59,0xBE,0x14,
|
||||
0xD0,0x00,0xD6,0x9F,0xFE,0x38,0x03,0x81,0x7F,0xB2,0x85,0x62,0xF0,0x47,0x04,0x00,
|
||||
0xD5,0xE9,0x75,0x8F,0xA1,0x29,0x8F,0x3D,0xEF,0xE7,0xE2,0xAD,0xC5,0xF8,0x2C,0x97,
|
||||
0xE3,0xEB,0x31,0x7C,0x14,0xC1,0xC4,0x74,0xFF,0xF3,0x28,0xC4,0x28,0x0D,0x38,0xAE,
|
||||
0xD2,0x5E,0x1C,0xDE,0x4C,0xA5,0x4D,0xC2,0xFE,0xC7,0xFF,0xDF,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0x2A,0x10,0x17,0x1B,0x72,0xDA,0x00,0x02,0x81,0xD5,0x01,0xC5,0x60,0x82,0x88,
|
||||
0x4C,0x4D,0xB9,0xB7,0xAD,0xFF,0xE1,0x29,0x40,0xB1,0xE7,0x4C,0xCC,0xEE,0x78,0xE2,
|
||||
0x04,0x09,0x06,0x8F,0xE0,0x55,0xA4,0x42,0x87,0x36,0x08,0x9D,0xE7,0xBF,0xFF,0xFF,
|
||||
0xFF,0xF3,0x28,0xC4,0x2E,0x0C,0xC0,0x9A,0xDE,0x5E,0x13,0xD8,0x4E,0xFF,0xFF,0xFF,
|
||||
0xFF,0xEA,0x24,0x82,0xDF,0xA2,0x33,0xC2,0x96,0x20,0xA1,0xC8,0x80,0x96,0xC0,0x78,
|
||||
0x66,0x01,0x79,0x10,0x57,0x64,0xAA,0x99,0x16,0x43,0x2E,0x87,0xAA,0x6B,0xEB,0x45,
|
||||
0x4A,0x08,0x85,0xC3,0x57,0xFF,0xFB,0x4D,0x69,0xA6,0x8D,0x48,0x9B,0x7F,0xFF,0xE7,
|
||||
0xBC,0x8D,0x47,0x01,0xB4,0x02,0xAD,0xD2,0xFF,0xF3,0x28,0xC4,0x36,0x0B,0xE8,0xF2,
|
||||
0x90,0x38,0xA4,0xCE,0x70,0x48,0x79,0x86,0xB0,0xA8,0x19,0xBD,0x32,0xA0,0x52,0x61,
|
||||
0x8C,0x12,0x53,0x05,0x87,0xA9,0x58,0x68,0x2A,0x09,0xB9,0x43,0xCA,0x87,0x4E,0xB7,
|
||||
0xFB,0x38,0x57,0xA3,0xFF,0xFF,0xFF,0x4B,0x7A,0x3F,0xFE,0xBA,0x7F,0x52,0x4C,0x41,
|
||||
0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0x41,0x0B,0xA8,0x46,0x40,0x1E,0x4E,0x30,0x24,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0x4D,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0x88,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0xC3,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
};
|
||||
|
||||
const uint8_t rebooting[]={
|
||||
|
||||
0xFF,0xF3,0x28,0xC4,0x00,0x0B,0xE0,0x06,0xB1,0x4D,0x40,0x10,0x00,0xE4,0x02,0x0E,
|
||||
0x0A,0x70,0x3F,0x0F,0x94,0x38,0x27,0x3E,0x0F,0xBC,0x10,0x58,0x60,0xBB,0xC8,0x14,
|
||||
0x38,0x27,0x86,0x14,0x70,0xBE,0xA7,0x17,0xF2,0xEF,0xDD,0xFE,0x20,0x70,0x20,0xEF,
|
||||
0x2E,0x0F,0x94,0x07,0xDF,0x5B,0xFF,0xD6,0x0F,0x9F,0xFF,0xFE,0x95,0xAF,0xEE,0xA5,
|
||||
0x4C,0x96,0xE2,0x38,0x13,0x80,0x35,0xC2,0xFF,0xF3,0x28,0xC4,0x0B,0x0F,0xF1,0xEE,
|
||||
0xDC,0x01,0x91,0x50,0x00,0x35,0x76,0x70,0x43,0x3D,0xD1,0x49,0xE6,0x67,0x93,0xE0,
|
||||
0xBA,0x16,0x8E,0xFD,0x3D,0x0D,0x5F,0xFF,0xD1,0x13,0xFF,0xFB,0x1A,0xF5,0x57,0x69,
|
||||
0x9C,0xF6,0x57,0x2F,0x5D,0x4E,0x3B,0xD7,0xCF,0x72,0x32,0x76,0x4A,0x13,0x0F,0x80,
|
||||
0x5C,0x9A,0xD7,0xFE,0x7D,0x49,0x29,0xEC,0x14,0xA9,0x20,0x7F,0xA7,0xF5,0xD6,0x66,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x89,0x62,0xC8,0xCB,0xD3,0x80,0x00,0x66,0x39,0x40,
|
||||
0x42,0x41,0x26,0x87,0xBA,0x42,0x20,0x82,0x0B,0x36,0x4E,0xC6,0x88,0x97,0x41,0xA4,
|
||||
0x1D,0x31,0x78,0xDB,0x6B,0x75,0x18,0x18,0x13,0xDF,0xFE,0xA7,0x45,0xBF,0xAF,0xBA,
|
||||
0x4E,0xEF,0xFB,0xBA,0x73,0x5F,0xE4,0x7F,0x13,0x3F,0xEB,0x77,0xFF,0xFF,0x9E,0x77,
|
||||
0xCA,0xAA,0x1E,0xF1,0xF2,0x0B,0x7F,0xF8,0xFF,0xF3,0x28,0xC4,0x06,0x0E,0xB8,0xDA,
|
||||
0xE6,0x5E,0x3B,0xCA,0x70,0xFF,0x81,0xF4,0xA9,0xA5,0xC4,0x60,0x05,0x5D,0x8E,0xA6,
|
||||
0x63,0xFD,0x50,0xCD,0x99,0x3D,0x7E,0x7B,0x53,0x42,0x1B,0x17,0xFF,0xFF,0x50,0x6F,
|
||||
0xFD,0x04,0x07,0x02,0xAE,0xD2,0x20,0x04,0x44,0x46,0xFB,0x96,0xE4,0x71,0x00,0x17,
|
||||
0xFF,0xA3,0xFF,0xFF,0x80,0x1B,0xFA,0x5C,0x3C,0x3B,0x20,0x26,0x03,0x92,0x49,0x24,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x81,0x06,0xBD,0xBF,0x53,0x38,0x00,0x00,0x7D,0x04,
|
||||
0x10,0x51,0x98,0xEB,0x0F,0x58,0x06,0xE8,0x45,0xCD,0x0F,0x9E,0x49,0x2B,0x27,0x59,
|
||||
0x40,0x47,0x41,0x70,0xC1,0x92,0x5F,0xDE,0x60,0xD8,0x96,0xFE,0x8B,0x1E,0x24,0x77,
|
||||
0xD0,0xF6,0x28,0x26,0x24,0x48,0xC2,0x37,0xFF,0x12,0xFF,0xF1,0xFD,0x1D,0xBF,0xFE,
|
||||
0x25,0xE6,0x5A,0x88,0xEB,0x4F,0xD0,0xE1,0xFF,0xF3,0x28,0xC4,0x07,0x0E,0x7A,0x4E,
|
||||
0xAC,0x01,0x98,0x10,0x00,0x62,0x30,0xDC,0xCD,0x90,0xF0,0xDA,0x90,0xF7,0x7A,0x3A,
|
||||
0xB1,0x5D,0x87,0x21,0x1F,0xF9,0x14,0xE7,0xE7,0xF6,0xA3,0x75,0xFF,0xFF,0x7F,0xFF,
|
||||
0xCE,0x77,0x57,0x9F,0xFF,0xFF,0x79,0x08,0xCE,0x46,0xFF,0xFF,0xFF,0x9C,0xE2,0x0E,
|
||||
0x03,0xE3,0x8C,0x1F,0xFF,0xFC,0xBF,0xD4,0xFE,0x2C,0xC8,0x70,0x90,0x08,0x20,0xCB,
|
||||
0xFF,0xF3,0x28,0xC4,0x08,0x0E,0x21,0xC2,0xD4,0x01,0x90,0x68,0x00,0x04,0x40,0x2F,
|
||||
0xA9,0x11,0x3D,0x51,0x50,0xC0,0x2C,0x59,0x01,0xA5,0x61,0x58,0x00,0xAC,0x50,0x67,
|
||||
0x48,0x6D,0x4D,0x84,0x8A,0x4E,0x0E,0x81,0xE6,0xAF,0x6D,0x0E,0xE8,0xFF,0xFE,0x83,
|
||||
0xFF,0xED,0x54,0xEA,0x5E,0x83,0xB2,0xBF,0xFF,0x43,0x97,0x0F,0x2E,0xAA,0x0C,0xBF,
|
||||
0x87,0xF7,0x74,0x86,0x60,0xF6,0x3C,0x59,0xFF,0xF3,0x28,0xC4,0x0A,0x0E,0x59,0x72,
|
||||
0xE0,0xCB,0xCD,0x50,0x02,0x4A,0xF3,0xA3,0x8C,0x59,0x0F,0x23,0x67,0x7A,0xC7,0x84,
|
||||
0x22,0xD0,0x0C,0x02,0x11,0x37,0xCC,0x30,0x54,0x25,0x1E,0xB7,0xF3,0x18,0xEF,0xF5,
|
||||
0xB2,0x7F,0xDD,0x7E,0x8C,0xA7,0x98,0x61,0x30,0x70,0x4F,0x0F,0x1A,0x54,0xDE,0x05,
|
||||
0x2C,0xC6,0xC5,0xBD,0x35,0x2B,0x67,0x87,0xF3,0x02,0xE0,0xC7,0x86,0xDC,0x4F,0x23,
|
||||
0xFF,0xF3,0x28,0xC4,0x0B,0x0D,0x11,0x7A,0xDC,0xCB,0x50,0x50,0x00,0xD3,0x4C,0x98,
|
||||
0x16,0x60,0x8E,0x49,0x93,0x55,0x7B,0x9A,0x16,0xC0,0x12,0x05,0x51,0xC7,0xF9,0x85,
|
||||
0xC8,0x4D,0x4F,0xFF,0xFF,0xFF,0xFF,0xAC,0xE3,0x90,0xEE,0x79,0x43,0x41,0x23,0xD5,
|
||||
0x13,0x2B,0xC8,0x78,0xB5,0x1A,0xD5,0xDE,0x5F,0x53,0xF6,0x22,0x60,0x90,0x4B,0xCD,
|
||||
0x5B,0xB6,0xEA,0xA7,0x7D,0xB7,0xD7,0x3F,0xFF,0xF3,0x28,0xC4,0x11,0x11,0x61,0xFA,
|
||||
0xB4,0x01,0x98,0x90,0x00,0x03,0x78,0x18,0x4E,0x4C,0x9E,0x74,0xDE,0x3A,0x45,0xC2,
|
||||
0x68,0xFF,0x7D,0x07,0xDF,0xFF,0xA9,0x2A,0x97,0xFF,0xFA,0x29,0x52,0x1C,0x9F,0xD6,
|
||||
0xFA,0xDF,0x3D,0x2F,0x15,0x90,0x75,0xA9,0xD7,0xAF,0xFB,0xFE,0x6A,0x55,0x4D,0x03,
|
||||
0x23,0xE0,0x57,0xDC,0x05,0x09,0xA7,0xFF,0xAA,0xA5,0xAA,0x91,0x66,0x77,0xA6,0x3F,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x41,0xB6,0xD0,0x01,0x82,0x28,0x00,0xB1,0xA3,0x45,
|
||||
0x76,0x61,0xC8,0x45,0xD5,0x3C,0xE4,0x9E,0x63,0x7F,0xA6,0xF7,0xED,0x35,0x6C,0xE2,
|
||||
0x68,0xA2,0xF8,0xB9,0x42,0x25,0x0A,0x04,0x9A,0x10,0x63,0x28,0xAC,0xCF,0x9D,0xC9,
|
||||
0x9D,0x4C,0x82,0x86,0x15,0x30,0xE4,0x91,0x3D,0x4F,0xFB,0x77,0x7F,0xFF,0xEB,0x16,
|
||||
0xFE,0x36,0x74,0x54,0xA5,0x98,0x6B,0xB9,0xFF,0xF3,0x28,0xC4,0x08,0x0B,0xF1,0x16,
|
||||
0xB0,0x01,0xC6,0x30,0x00,0x4F,0xB5,0xCD,0xDB,0x28,0xE2,0xD0,0x98,0xDD,0x8B,0xDF,
|
||||
0xF6,0xED,0x8F,0xD9,0x3F,0x39,0xEC,0xF0,0xD0,0xED,0x07,0xA7,0xC8,0x13,0x1E,0x64,
|
||||
0x93,0x97,0x63,0xC8,0xE1,0xC7,0x88,0x81,0xA0,0xED,0xCB,0xD5,0xA9,0xFF,0xFD,0x54,
|
||||
0x89,0xC0,0x40,0x9B,0x9D,0xC6,0xC8,0x59,0x3D,0x6A,0xC7,0x5C,0x1E,0x09,0xF6,0x68,
|
||||
0xFF,0xF3,0x28,0xC4,0x13,0x0C,0x68,0xF6,0xB0,0x00,0xC3,0xCC,0x71,0xFA,0xB9,0xB8,
|
||||
0x2D,0x87,0x02,0x9D,0xFB,0xCD,0xAE,0x28,0x86,0x30,0x4C,0xF4,0xC5,0x3E,0x54,0xB8,
|
||||
0xBD,0xB8,0x26,0x94,0x3F,0xF5,0xAF,0x30,0x49,0x22,0xE6,0x12,0xF1,0xB3,0x03,0x00,
|
||||
0xFE,0xFF,0x2D,0xC7,0x12,0x54,0x0E,0x52,0x04,0xDF,0xBB,0x17,0xAB,0x2D,0x10,0xEB,
|
||||
0x11,0x19,0xD6,0xA5,0xFE,0x4C,0xB1,0x60,0xFF,0xF3,0x28,0xC4,0x1C,0x0C,0x98,0xBE,
|
||||
0xBD,0x90,0xCE,0x18,0x4C,0x36,0x3B,0x19,0x42,0x7A,0xE9,0xB9,0xC9,0xCD,0x72,0x65,
|
||||
0xC5,0xAB,0x6B,0xB4,0x3F,0x30,0xE7,0x5E,0xF7,0x07,0x32,0x95,0x03,0x32,0x3B,0xC0,
|
||||
0xFF,0xFF,0xDD,0xC8,0x2D,0x35,0x43,0x2E,0x5E,0x04,0x80,0x86,0x71,0x94,0xE8,0xB6,
|
||||
0x05,0xD8,0x6A,0x14,0x71,0xFB,0xD5,0x94,0xF2,0xBD,0x39,0x16,0x99,0xAE,0xAD,0x90,
|
||||
0xFF,0xF3,0x28,0xC4,0x24,0x0C,0xE0,0xC6,0xC5,0x90,0xC3,0xC6,0x71,0x8A,0x64,0xA4,
|
||||
0xDA,0xAB,0x1B,0x06,0x31,0x25,0x6D,0xBB,0xB5,0xB1,0x00,0x1F,0xB5,0xFD,0xE1,0xBD,
|
||||
0x63,0x52,0x1F,0x33,0x39,0x3D,0xAD,0x04,0xC6,0x86,0x07,0x9E,0xFC,0x2F,0xD7,0x88,
|
||||
0x0F,0x48,0x37,0x95,0x31,0xF1,0xF3,0x44,0xF2,0x75,0x52,0xFA,0x2C,0xE6,0x0F,0x2D,
|
||||
0xC2,0xDD,0xA8,0xD5,0x9E,0xF8,0x18,0xF7,0xFF,0xF3,0x28,0xC4,0x2B,0x0C,0xA0,0x82,
|
||||
0xA8,0x00,0xCE,0x9E,0x48,0xB0,0x97,0xDE,0x2B,0x38,0x18,0x7E,0x95,0xFF,0xEF,0xEE,
|
||||
0xAF,0x9B,0x04,0x94,0xD0,0x2C,0x52,0xE3,0xDB,0x35,0x61,0x4F,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xF4,0x44,0xB4,0xE7,0x56,0xFF,0xFF,0xF4,0x4D,0x73,
|
||||
0x9C,0xE7,0x74,0x21,0x0F,0xE4,0x64,0xFF,0x5E,0x4A,0xD1,0x9F,0x3F,0xC8,0x74,0x00,
|
||||
0xFF,0xF3,0x28,0xC4,0x33,0x0D,0x23,0x0A,0xB4,0x00,0x78,0x44,0xB8,0x10,0x45,0xFF,
|
||||
0xFF,0x9F,0xFF,0xFF,0xFF,0xFF,0xE4,0xD9,0x54,0xAB,0x90,0x9F,0xA6,0xE9,0xE5,0xD9,
|
||||
0xAC,0x88,0xCC,0x45,0x29,0x8E,0xE1,0x0C,0xA2,0xDD,0x0E,0xD5,0x7A,0x21,0x24,0x44,
|
||||
0x45,0x51,0x34,0x7A,0xCA,0x8F,0x04,0x98,0xE6,0x52,0x89,0x07,0x04,0x7A,0xFA,0xC8,
|
||||
0x0C,0x60,0x30,0x85,0x74,0xDD,0x91,0xE7,0xFF,0xF3,0x28,0xC4,0x39,0x0B,0xAB,0x0E,
|
||||
0xC0,0x00,0x08,0x04,0xB9,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFD,0x7F,0xFF,
|
||||
0x4B,0x39,0xBF,0xFF,0xAF,0x5E,0xCD,0x4C,0xDA,0x19,0x8E,0xA4,0x08,0xAA,0xC1,0x48,
|
||||
0xB5,0xD7,0x4F,0x7B,0x53,0x98,0xAD,0x04,0xA8,0x61,0xD9,0x22,0xB5,0xD5,0x7F,0x01,
|
||||
0xC7,0xC3,0xA9,0xC5,0x8C,0xBC,0x21,0x2D,0xC8,0x5B,0xC1,0x5C,0x2A,0x4C,0x65,0x4B,
|
||||
0xFF,0xF3,0x28,0xC4,0x45,0x0C,0x8A,0xFA,0xC4,0x00,0x10,0x44,0xB8,0xE6,0xA8,0x8F,
|
||||
0x00,0x67,0x3F,0xFF,0xFF,0xFF,0xFF,0xFD,0x0B,0x10,0x31,0xFF,0xFE,0xE8,0x5C,0x1A,
|
||||
0x7A,0xD5,0xF1,0xC0,0x94,0xEA,0x8F,0x00,0xE7,0x47,0x0A,0x80,0x08,0x85,0x28,0x79,
|
||||
0x9C,0x67,0x22,0x7D,0x5D,0x13,0x51,0xD8,0xEF,0xFF,0xFF,0xFF,0xFF,0xFE,0x93,0xA0,
|
||||
0xD8,0x22,0xEF,0xF7,0xFA,0x50,0x5C,0xE0,0xFF,0xF3,0x28,0xC4,0x4D,0x09,0x90,0x56,
|
||||
0xDC,0xCA,0x13,0xDE,0x26,0x98,0x77,0xF5,0xEB,0x81,0x01,0xE6,0x8C,0x01,0x09,0x40,
|
||||
0x6B,0x2C,0x8F,0xD7,0x4C,0xA2,0xC6,0x38,0x59,0x06,0xB5,0xC9,0x4E,0xA9,0x1F,0x64,
|
||||
0x76,0xFF,0xFF,0xFF,0xFF,0xFF,0xE9,0x40,0x99,0x22,0xA8,0xFF,0xF2,0x2F,0x26,0x2C,
|
||||
0x11,0x41,0x9F,0xB6,0xFA,0x95,0x40,0x79,0xFE,0x2D,0x0B,0x6D,0xCA,0x2C,0x9B,0xA7,
|
||||
0xFF,0xF3,0x28,0xC4,0x61,0x0A,0x80,0x5A,0xCC,0x00,0x3B,0xDE,0x24,0x0B,0xF0,0xBD,
|
||||
0x3C,0x53,0xA0,0xA3,0x40,0x17,0x12,0x16,0x89,0x3C,0xDF,0xFF,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0xFF,0xFF,0xFF,0xFF,0xCA,0xCA,0x02,0xFF,0x47,0xF2,0x2A,0xD4,0x48,0x2A,0x64,
|
||||
0xEF,0xFC,0xEA,0x15,0x06,0x02,0x00,0xD6,0x3A,0x0A,0x83,0x11,0x44,0x4F,0x8C,0x32,
|
||||
0x90,0x39,0x85,0x74,0xC0,0x43,0xD4,0x0A,0xFF,0xF3,0x28,0xC4,0x72,0x0B,0x10,0x66,
|
||||
0xC8,0xCA,0x2B,0xD8,0x28,0xF7,0x27,0xB0,0x23,0x99,0x72,0xBA,0xBF,0xFF,0xFF,0xFF,
|
||||
0xFF,0x85,0x45,0x04,0x8F,0xFF,0xFD,0x62,0x84,0xBF,0x5D,0x51,0x65,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0x80,0x0C,0x11,0xDA,0xB8,0x2A,0x79,0x44,0x94,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0x8A,0x0A,0xE0,0x5A,
|
||||
0x40,0x44,0x1B,0xDE,0x24,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0x99,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
};
|
||||
|
||||
const uint8_t serverConnecting[] = {
|
||||
|
||||
0xFF,0xF3,0x28,0xC4,0x00,0x0B,0xE0,0x02,0xE6,0x37,0x40,0x10,0x02,0x89,0x12,0x56,
|
||||
0xAF,0xE8,0x27,0xC1,0x73,0xE2,0x70,0x39,0xF2,0x05,0x0E,0x02,0x00,0xF8,0x3E,0x1F,
|
||||
0xA8,0xE1,0x05,0x4F,0x97,0x5B,0xF7,0x1C,0xFE,0x53,0xAF,0x89,0xFF,0x5F,0xF5,0x9F,
|
||||
0x28,0xEE,0x43,0xF8,0x63,0x87,0xFF,0xE5,0xDE,0x73,0x77,0xF9,0x75,0xAF,0xED,0x42,
|
||||
0xB4,0xD3,0x0B,0x56,0x05,0xB0,0xCE,0x41,0xFF,0xF3,0x28,0xC4,0x0B,0x0E,0xC1,0xF2,
|
||||
0xE0,0x01,0x90,0x38,0x00,0xDC,0x91,0xC2,0xE6,0x79,0xB3,0x59,0x63,0xE2,0x5E,0x22,
|
||||
0x03,0x7F,0xD9,0xFB,0xFF,0xFF,0xFF,0x45,0xB3,0xFA,0x8D,0xD9,0x3A,0x88,0x8E,0xDB,
|
||||
0xA9,0xA6,0x9E,0xAC,0xFF,0xF9,0x2F,0x39,0x8D,0x24,0xC2,0x07,0x81,0x4D,0xA9,0xAA,
|
||||
0xF9,0xCE,0x77,0x7B,0xE8,0x03,0x32,0xA5,0x62,0xED,0xAD,0xBB,0x01,0xFD,0xC9,0x9E,
|
||||
0xFF,0xF3,0x28,0xC4,0x0B,0x0F,0x89,0xE3,0x22,0x5F,0xC5,0x38,0x02,0x34,0x38,0x06,
|
||||
0x35,0x58,0xB5,0xB3,0xC7,0x00,0x60,0x94,0x77,0xFF,0x1C,0x34,0xDF,0xFE,0xC7,0xB3,
|
||||
0x7F,0xE6,0x2D,0x8D,0xB7,0xD5,0x63,0xE3,0xCA,0x35,0x22,0x8F,0xFD,0xDA,0x69,0xBF,
|
||||
0xF9,0x8A,0xC3,0xA4,0x5B,0xCC,0x80,0x80,0xAE,0xE5,0xFA,0x2B,0x7F,0xED,0x7F,0xCA,
|
||||
0x2A,0xFD,0x75,0x31,0xB1,0x38,0x1E,0xD8,0xFF,0xF3,0x28,0xC4,0x07,0x0E,0xC1,0x5A,
|
||||
0xBC,0x00,0xA4,0x84,0x94,0x18,0xB6,0x60,0x34,0xC4,0x88,0x26,0x83,0x54,0xEF,0x91,
|
||||
0xC2,0x78,0x00,0x98,0x26,0x08,0x32,0xFF,0xE9,0x95,0xCD,0x7F,0xF9,0xD0,0xDF,0xFA,
|
||||
0x33,0xFF,0xA2,0x10,0x38,0x18,0x00,0x10,0xA6,0xF0,0x40,0x16,0x1F,0xEB,0x58,0x2B,
|
||||
0xF5,0xCF,0x72,0x84,0x8B,0x1E,0xD6,0x4C,0x11,0x1A,0x80,0xB0,0x1F,0xED,0x37,0xFC,
|
||||
0xFF,0xF3,0x28,0xC4,0x07,0x0F,0x01,0x86,0xD6,0x5E,0x6A,0x04,0x94,0x01,0xF6,0x4D,
|
||||
0x59,0xC1,0x24,0x02,0xE4,0xBA,0x39,0x4C,0xBD,0x9F,0xFE,0x4A,0x05,0x40,0xD4,0x77,
|
||||
0xFD,0xF6,0x90,0x5A,0x34,0xAF,0xCF,0xC8,0xB3,0x4A,0x5F,0xF5,0x60,0xC0,0x42,0x9F,
|
||||
0xD1,0x9E,0xEA,0x53,0x2B,0x75,0xF4,0x7A,0x0A,0x7F,0x8B,0x7E,0x5B,0xF0,0x55,0xDF,
|
||||
0x22,0x1A,0x1A,0x01,0xEE,0xFF,0xFF,0xFF,0xFF,0xF3,0x28,0xC4,0x06,0x0E,0xA0,0xC2,
|
||||
0xDE,0x5F,0x46,0x18,0x00,0x1C,0x01,0xFF,0xF9,0xEB,0x4B,0xEC,0x0C,0x02,0xDF,0x46,
|
||||
0x95,0x1E,0x0C,0x30,0xA3,0xB7,0x12,0x14,0x11,0x11,0x08,0xCD,0xCE,0x9B,0xFB,0x98,
|
||||
0x70,0x38,0xD6,0x01,0x08,0x40,0xA1,0xD2,0x6D,0x52,0x97,0x5C,0xA0,0x20,0x88,0x62,
|
||||
0xA7,0x56,0xCC,0xBA,0xDE,0xD2,0x9F,0xFF,0xF9,0x2A,0xA5,0xE8,0x12,0x11,0x08,0xC0,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x39,0x6E,0xE0,0x01,0x8D,0x68,0x00,0xC0,0x13,0xC1,
|
||||
0x90,0x07,0x89,0xA1,0x1A,0x64,0x4A,0x14,0x23,0x50,0x1A,0x62,0xC0,0x25,0x89,0x44,
|
||||
0xD3,0x40,0xB1,0xD6,0x22,0xD4,0x98,0x82,0x12,0xE8,0x2B,0x9E,0xD2,0xB5,0x6D,0xFF,
|
||||
0xFF,0xAF,0xFA,0x1C,0xC0,0xDF,0xD0,0x36,0x7F,0xD3,0x45,0x94,0x59,0xFF,0xD1,0xD1,
|
||||
0x02,0xCA,0x13,0x8E,0x8B,0x6D,0x14,0x01,0xFF,0xF3,0x28,0xC4,0x08,0x0D,0x99,0x77,
|
||||
0x26,0x5F,0xCD,0x28,0x02,0xFB,0xA5,0x9B,0x85,0x38,0xF1,0x35,0xFE,0x80,0xF4,0x25,
|
||||
0x92,0x7F,0x9C,0xE1,0x30,0x08,0x5B,0xFA,0x87,0xC6,0xB7,0xFF,0xFE,0x88,0xCE,0x5F,
|
||||
0xD4,0xEE,0x47,0x31,0x8C,0x67,0x90,0x84,0x30,0xA8,0x93,0xF5,0x19,0x73,0xDF,0x2E,
|
||||
0x2B,0xFF,0xFD,0x6A,0xFD,0x13,0xA9,0x13,0x81,0x60,0x14,0xC8,0xF5,0x50,0x33,0x16,
|
||||
0xFF,0xF3,0x28,0xC4,0x0C,0x0D,0x21,0x86,0xD0,0x00,0x6C,0x04,0x94,0x78,0x68,0x65,
|
||||
0x44,0xBF,0x33,0x0F,0xCC,0x2C,0xF0,0x8F,0x93,0x65,0x5B,0xA6,0x6A,0x8F,0xFB,0x14,
|
||||
0xBF,0xCE,0x9F,0xF4,0x2F,0xF4,0x21,0x45,0x2B,0x59,0x64,0x08,0x00,0x1C,0x44,0x0A,
|
||||
0xD2,0x5E,0x79,0xFB,0x7E,0xAA,0x28,0x62,0x2A,0x96,0x20,0x3D,0x50,0xA8,0x98,0x17,
|
||||
0x84,0x30,0x2E,0x94,0x4D,0xF1,0x37,0x06,0xFF,0xF3,0x28,0xC4,0x12,0x0C,0x78,0xAE,
|
||||
0xD1,0x94,0x3B,0xC4,0x4C,0x13,0x7C,0x23,0xA7,0x0F,0x87,0x6D,0x27,0x29,0x05,0x15,
|
||||
0xBF,0x85,0x12,0xEE,0xAF,0x67,0xAC,0x35,0xD4,0x0D,0x1E,0xC2,0x41,0xD0,0x6B,0xD9,
|
||||
0xD6,0xDF,0xFF,0xFB,0x13,0xFA,0xA3,0x98,0x02,0x62,0x07,0x92,0xF6,0xC3,0x75,0x29,
|
||||
0x12,0x30,0xC8,0x44,0x50,0x1A,0x73,0x4A,0x94,0x5D,0xED,0x26,0x12,0x89,0x67,0x2C,
|
||||
0xFF,0xF3,0x28,0xC4,0x1B,0x0C,0xF8,0x7A,0xB4,0x00,0x9E,0x30,0x48,0xEC,0x6B,0xC9,
|
||||
0xF4,0x9C,0xEE,0xFF,0xFE,0xAE,0x36,0xD9,0x7E,0x0F,0xFD,0xAF,0xFF,0xD3,0x22,0x59,
|
||||
0x6E,0xFF,0xFE,0xE0,0x64,0x34,0x18,0xE9,0xC2,0x4C,0x06,0xF0,0x34,0x51,0xDA,0xD6,
|
||||
0x20,0x80,0xBE,0x03,0xE8,0x00,0xE8,0xA4,0xCF,0x5D,0x22,0xC7,0xAD,0x5D,0xA1,0x67,
|
||||
0x28,0x95,0x41,0x1C,0x4E,0xEF,0xD9,0xFF,0xFF,0xF3,0x28,0xC4,0x22,0x0B,0x28,0x66,
|
||||
0xC8,0xCA,0x03,0xDE,0x28,0xFF,0xF4,0x3D,0x00,0x40,0x88,0x5A,0x85,0xA3,0xFF,0x45,
|
||||
0xFC,0x95,0x01,0x90,0x21,0x0F,0x94,0x52,0x72,0x34,0x07,0x68,0x5C,0x99,0xBB,0xCB,
|
||||
0xA6,0x20,0x14,0x0B,0x19,0x6A,0xAC,0x8D,0x30,0x6F,0xA2,0x9F,0xD9,0xBE,0xAD,0xFA,
|
||||
0xFF,0xFF,0xFF,0xFF,0xFB,0xDF,0xD0,0xE4,0xE6,0x02,0x14,0x40,0xF8,0xB8,0x88,0x59,
|
||||
0xFF,0xF3,0x28,0xC4,0x30,0x0C,0xE1,0xC6,0xC4,0x00,0x94,0x04,0x94,0xDF,0xF5,0x54,
|
||||
0x85,0x15,0xD0,0xE9,0x96,0x80,0x05,0x14,0x01,0xD6,0x81,0x99,0x80,0x27,0xC1,0xDC,
|
||||
0x15,0xD0,0xE2,0x56,0xB0,0x06,0x82,0xE1,0x20,0xB6,0x71,0x51,0xA1,0xC4,0xDF,0x53,
|
||||
0x4D,0x67,0xE7,0x50,0xEF,0x9D,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFE,0xF4,0x74,0x62,
|
||||
0xB0,0x61,0x4F,0x6F,0xFF,0xA9,0x10,0x27,0xFF,0xF3,0x28,0xC4,0x37,0x0D,0x31,0xCB,
|
||||
0x06,0x5E,0x6A,0x84,0x96,0x1D,0xDA,0xED,0x86,0xDB,0x01,0xF7,0xA4,0x1D,0x83,0x91,
|
||||
0x7F,0xB9,0x73,0x52,0x98,0xAC,0x5C,0x17,0x5F,0xFC,0xC9,0x23,0x10,0xC8,0x8C,0x9C,
|
||||
0x4E,0x07,0x0F,0xEF,0x98,0x07,0xC1,0xF3,0xFD,0x05,0x0E,0x7F,0xFF,0xD2,0xC7,0x7F,
|
||||
0xFD,0xBF,0xFA,0x3F,0xFE,0x53,0x1A,0x41,0xFD,0xEF,0x99,0x65,0x2B,0x7E,0x0C,0x30,
|
||||
0xFF,0xF3,0x28,0xC4,0x3D,0x0D,0x30,0x7A,0xEE,0x5E,0x6E,0x10,0x4A,0x16,0x0B,0x0E,
|
||||
0x8B,0x76,0xB6,0xF1,0xFC,0x47,0x72,0xDC,0xA5,0x7B,0xCB,0xB7,0xCB,0xE8,0xF6,0xFF,
|
||||
0xBF,0xFF,0xFF,0xFF,0xFE,0xEC,0xBD,0xAE,0xA8,0xCB,0x53,0xE8,0x3A,0x45,0x7B,0xAF,
|
||||
0xFF,0x3D,0xC8,0xD6,0xAD,0xEC,0xE7,0x64,0xDC,0x94,0x66,0xA3,0x6A,0x62,0xF5,0x4D,
|
||||
0xA4,0xCE,0x20,0x2A,0xEC,0xA7,0x45,0x77,0xFF,0xF3,0x28,0xC4,0x43,0x13,0x1B,0x12,
|
||||
0xA4,0x00,0xC0,0x8A,0xB9,0x21,0xE8,0x2C,0x38,0xC3,0x42,0x83,0xA7,0x93,0x4A,0xFF,
|
||||
0xFF,0xCF,0xFF,0x09,0xB9,0x6B,0x8E,0x14,0x61,0xC9,0x0B,0xD5,0xD7,0x88,0x4E,0x53,
|
||||
0x90,0x30,0xC6,0x2E,0x0B,0x03,0x0E,0xCC,0xE9,0xF9,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
|
||||
0xC9,0xFF,0xC8,0xDF,0xC8,0x42,0x1E,0xAE,0x76,0x46,0xFF,0xFF,0xFD,0xE8,0xEA,0x17,
|
||||
0xFF,0xF3,0x28,0xC4,0x31,0x0D,0x2A,0x42,0xBC,0x00,0xC1,0xC4,0xB8,0xFF,0xFF,0xFC,
|
||||
0x95,0xFC,0xFA,0x96,0x91,0x64,0x10,0x10,0x01,0x48,0xA4,0xC1,0x5C,0xD4,0xC8,0xD8,
|
||||
0xF5,0x9E,0x16,0xA0,0x0B,0xB4,0x85,0xDF,0xF4,0x06,0xD3,0x7F,0xEA,0xFF,0xE9,0xFF,
|
||||
0xD7,0xFF,0xA9,0x9F,0xF4,0x38,0x87,0xB9,0xE9,0x9E,0x11,0x2B,0xFF,0xE5,0xFE,0x5F,
|
||||
0xEB,0x3F,0xFF,0xFF,0xF5,0xAA,0xFA,0x8C,0xFF,0xF3,0x28,0xC4,0x37,0x0D,0x09,0xEA,
|
||||
0xBC,0x00,0xA4,0xCE,0x98,0x8C,0x4D,0x89,0xA0,0xF8,0x00,0x59,0x50,0x7C,0xA5,0x66,
|
||||
0x53,0x22,0xEF,0x99,0x81,0x58,0x3E,0xC4,0xF6,0xC9,0x7A,0x88,0x61,0x11,0x6F,0xFF,
|
||||
0xFF,0xD7,0xFF,0xFF,0xF9,0x5B,0xFF,0x56,0xF5,0x2E,0x84,0x0A,0x06,0x6B,0x9C,0xB2,
|
||||
0xBF,0x43,0xE9,0xA1,0x01,0xDA,0xAA,0xFA,0x0D,0x8B,0x80,0xF3,0x04,0x8D,0x29,0x37,
|
||||
0xFF,0xF3,0x28,0xC4,0x3D,0x0C,0xD1,0xBE,0xBC,0x00,0xA4,0x0A,0x94,0x0D,0xD0,0x85,
|
||||
0x59,0xDE,0x39,0xD4,0xC6,0x8E,0x52,0x02,0xA1,0x50,0xE9,0xEB,0xD3,0xEE,0xD4,0xAA,
|
||||
0x7F,0x5F,0xD1,0x9C,0xFF,0x39,0xF4,0x7C,0x93,0x1F,0x44,0xAA,0x1D,0xC8,0xFA,0x1C,
|
||||
0x3B,0xF3,0xAD,0xD1,0xCE,0xBE,0x2F,0x5B,0x2E,0x8B,0x91,0x22,0x2C,0x4A,0xA3,0xE6,
|
||||
0x15,0x14,0x5A,0x07,0x01,0x89,0x17,0x49,0xFF,0xF3,0x28,0xC4,0x44,0x0B,0xF8,0x96,
|
||||
0xA8,0x00,0x3E,0x10,0x4C,0x6D,0x4B,0x56,0x5F,0x9B,0xBE,0xE5,0xBD,0x24,0x75,0x05,
|
||||
0x04,0x02,0x43,0x01,0x15,0x7B,0x89,0x0F,0x84,0x6A,0x6C,0xDE,0x74,0x95,0x66,0xA1,
|
||||
0xD4,0x8C,0xD0,0xD6,0x01,0xCA,0x65,0xC4,0x89,0x3E,0x38,0x60,0x5C,0x00,0x7D,0x81,
|
||||
0x75,0x18,0x38,0x25,0x0E,0xD4,0x28,0xC7,0x28,0xA9,0x18,0x12,0xC4,0xFF,0xEF,0xF7,
|
||||
0xFF,0xF3,0x28,0xC4,0x4F,0x14,0x19,0x4E,0xA4,0x00,0x7A,0x06,0x70,0xB9,0x6A,0x41,
|
||||
0xFF,0xC7,0xFE,0xBC,0x15,0x0D,0x9C,0x03,0x68,0x85,0x19,0x02,0x34,0x42,0x42,0xEC,
|
||||
0x5B,0x70,0x61,0x97,0xCA,0xBF,0xFB,0x19,0xA1,0x52,0xDE,0x9A,0xC4,0xA0,0x18,0x70,
|
||||
0x95,0x91,0x0E,0x04,0x0D,0xA1,0x26,0xC0,0x44,0x9C,0x64,0x08,0xD3,0xBE,0xE5,0xFF,
|
||||
0x5E,0x7A,0x5A,0xF0,0xD7,0xFE,0xBA,0xEC,0xFF,0xF3,0x28,0xC4,0x39,0x0D,0xE0,0xE2,
|
||||
0xC0,0xCA,0x4A,0x46,0x70,0xA4,0xC5,0x70,0x0E,0x88,0x33,0x4B,0x99,0xD6,0x97,0xCB,
|
||||
0x59,0xE9,0x8B,0x08,0x0A,0xA4,0x24,0xB8,0x8D,0x76,0x92,0x35,0xE1,0xC1,0x36,0x05,
|
||||
0xDB,0x62,0xB8,0x0B,0x32,0x3D,0x6A,0x3A,0xF3,0x70,0x51,0xE5,0xA6,0x42,0x80,0x40,
|
||||
0xAD,0x3A,0x2A,0xFA,0xC3,0x1E,0x02,0xEA,0x06,0xF0,0x40,0x13,0x14,0xDA,0x49,0xD3,
|
||||
0xFF,0xF3,0x28,0xC4,0x3C,0x0B,0x90,0xA6,0xBC,0x00,0x96,0x58,0x4C,0x92,0x73,0x14,
|
||||
0x23,0x50,0x85,0x78,0xFE,0x4E,0x7B,0xD2,0x21,0xAA,0xE4,0x31,0xC2,0xBA,0x2F,0xA5,
|
||||
0x69,0xC6,0xA4,0x64,0x81,0x8A,0xC1,0x9A,0xE7,0x22,0x5A,0x80,0x03,0xC0,0x3F,0x5F,
|
||||
0x87,0xD4,0x89,0x96,0xE4,0xD0,0xDC,0x1D,0x63,0xAB,0xAE,0x41,0x50,0xD8,0x10,0x93,
|
||||
0x10,0x13,0x89,0x93,0x88,0x08,0x62,0x7F,0xFF,0xF3,0x28,0xC4,0x48,0x0A,0xA0,0x9E,
|
||||
0xB4,0x00,0x9E,0x5E,0x4C,0x0B,0x2D,0x61,0xB0,0xA4,0x0C,0x38,0xB9,0x79,0x65,0x8A,
|
||||
0x36,0x79,0x4A,0x4C,0xD9,0xA7,0x82,0x08,0x8A,0x6D,0x3C,0x02,0x14,0x12,0xB7,0x6C,
|
||||
0x00,0x1B,0x01,0xFC,0xBC,0x0E,0x10,0x5A,0xDF,0xBE,0x90,0x23,0xE2,0x71,0xFA,0x41,
|
||||
0x44,0x0E,0x34,0x8B,0xA8,0xB3,0xD7,0xEC,0x47,0x78,0xB3,0xB3,0x78,0x17,0xDF,0xF0,
|
||||
0xFF,0xF3,0x28,0xC4,0x58,0x0C,0xC0,0xAA,0xA8,0xF0,0xCE,0x58,0x4D,0x18,0x16,0x7F,
|
||||
0x07,0xFD,0x9F,0xFF,0xFF,0xFF,0xFF,0xFE,0x2B,0xFF,0xF6,0xAE,0x11,0xFC,0xE1,0x14,
|
||||
0x04,0xA0,0xD8,0x90,0x7F,0xF2,0xAF,0x56,0xBB,0x2A,0x30,0xC9,0x8E,0x53,0xC3,0x50,
|
||||
0x15,0x4D,0x6A,0x6F,0xF6,0xA8,0x63,0xB8,0x24,0x5A,0xFA,0xCE,0x42,0xD0,0x90,0x0C,
|
||||
0x40,0x94,0x3F,0xBE,0x54,0x50,0x4B,0x58,0xFF,0xF3,0x28,0xC4,0x60,0x0D,0x40,0xC6,
|
||||
0xEA,0x5E,0x6B,0x5E,0x72,0xE5,0x04,0x47,0x81,0xFE,0x3F,0xF3,0xCF,0xE5,0x0D,0x20,
|
||||
0x28,0x11,0xA9,0xCA,0xB0,0x46,0x63,0x71,0x38,0xDC,0x2D,0x83,0x9B,0x6E,0x11,0x4A,
|
||||
0x9D,0x0E,0x14,0xB3,0x96,0x79,0xD7,0x6B,0x3F,0x9F,0x33,0x95,0x08,0xD4,0x2F,0x3D,
|
||||
0x48,0x2C,0x16,0x0D,0x33,0xF6,0xE3,0x8B,0x35,0x17,0xD6,0x64,0xC2,0x00,0x02,0x10,
|
||||
0xFF,0xF3,0x28,0xC4,0x66,0x0B,0xB8,0xC2,0xA8,0x00,0x96,0x98,0x4D,0x0F,0x09,0x50,
|
||||
0x5A,0x5C,0x88,0x2C,0xA1,0xC8,0x3B,0xDE,0x23,0x65,0x42,0x31,0xC4,0xD7,0x69,0x65,
|
||||
0x4F,0x18,0x68,0xB9,0x99,0x12,0xC3,0xB4,0xF7,0x27,0x41,0xC2,0x0A,0xE0,0x24,0x44,
|
||||
0xB2,0x49,0xD6,0x92,0x0A,0x32,0x65,0xD2,0x7B,0x3A,0xD9,0x5F,0xEE,0xC8,0x27,0x5B,
|
||||
0x24,0xBF,0xF7,0x64,0xFE,0x8D,0x66,0x3F,0xFF,0xF3,0x28,0xC4,0x72,0x0C,0xE8,0xDA,
|
||||
0xAC,0x29,0x59,0x48,0x00,0x14,0x48,0x94,0xEF,0xDE,0x5D,0x07,0xD4,0x11,0x11,0x67,
|
||||
0xBC,0xE7,0x97,0x28,0xE4,0x05,0x42,0xE2,0xF3,0xA2,0x5F,0xFF,0x01,0xA4,0xCA,0x96,
|
||||
0x52,0x0D,0x89,0x45,0xA0,0x50,0x28,0xB4,0x0A,0x2D,0xB6,0xDB,0x2C,0x60,0x0C,0xB7,
|
||||
0x6D,0xDC,0x71,0x5D,0x8E,0x4F,0xDD,0xC9,0xFE,0x77,0xA7,0xDA,0xD9,0xD0,0xC4,0xFF,
|
||||
0xFF,0xF3,0x28,0xC4,0x79,0x16,0x71,0x3A,0x78,0x13,0x9B,0x68,0x00,0xFC,0xAE,0x21,
|
||||
0xFF,0x3F,0x23,0x21,0xD1,0x48,0xC4,0x4F,0x6F,0xB9,0x11,0x5A,0xCE,0xA7,0x12,0x14,
|
||||
0x60,0xE8,0x30,0x06,0x21,0xFE,0xFC,0x84,0x53,0xB9,0x09,0x38,0xB9,0x62,0x66,0x17,
|
||||
0xB2,0xA9,0x8E,0x3C,0x82,0xD6,0x6C,0x9B,0x6A,0x4C,0x8C,0xD8,0x7C,0xEC,0x07,0x51,
|
||||
0x70,0x41,0x70,0xE5,0xD8,0xE2,0x6E,0xF1,0xFF,0xF3,0x28,0xC4,0x5A,0x18,0x2B,0x22,
|
||||
0xEE,0x5F,0x82,0x28,0x02,0x70,0x71,0x41,0x10,0x40,0xF8,0x25,0x1B,0x6D,0xB6,0xC3,
|
||||
0x6D,0xB6,0xD5,0xD1,0xE2,0x5C,0xD2,0xBA,0xD1,0x74,0x84,0xAA,0x5E,0xDB,0xF4,0xFF,
|
||||
0x2A,0x2A,0xF7,0xF5,0xF5,0x92,0xFB,0x77,0x7B,0xFD,0x4A,0xBA,0x3E,0x67,0x42,0x33,
|
||||
0x59,0x32,0xCE,0xE5,0x65,0x63,0xAA,0x80,0xE6,0x50,0xE5,0x05,0x81,0x91,0x55,0x8E,
|
||||
0xFF,0xF3,0x28,0xC4,0x34,0x16,0xC3,0x13,0x0E,0x5F,0xC2,0x28,0x03,0xA6,0x17,0x62,
|
||||
0x21,0x99,0x4C,0xA5,0xB9,0x81,0x0E,0x2A,0x2A,0x61,0x53,0x15,0xC5,0x81,0x14,0x84,
|
||||
0x15,0x0D,0x71,0x76,0x52,0x32,0xCC,0x95,0xB7,0xFF,0xA2,0xA3,0xEA,0xAA,0x47,0x2A,
|
||||
0xA3,0xA0,0xB6,0xE6,0x1A,0x39,0x76,0xDB,0x6D,0xAC,0x8D,0x81,0xD0,0x4E,0x51,0xDE,
|
||||
0x13,0xC2,0x1D,0x0D,0x49,0x43,0x6A,0x59,0xFF,0xF3,0x28,0xC4,0x14,0x0E,0x00,0x5F,
|
||||
0x0E,0x5E,0x08,0xC6,0x2A,0xE5,0x97,0x41,0x15,0x80,0x50,0xB7,0xFA,0x75,0xCE,0xCD,
|
||||
0x56,0x89,0x87,0xFB,0x16,0xB0,0x63,0xA6,0xB7,0x88,0x48,0x93,0x7F,0xEF,0xB6,0xE4,
|
||||
0xB8,0x68,0xAB,0x82,0x5F,0xFF,0xF9,0xE2,0xE8,0xFD,0xEB,0xBF,0xF9,0x46,0xD1,0xF0,
|
||||
0x31,0x0A,0x89,0x9C,0xCA,0x20,0x68,0x65,0xEA,0x5C,0x85,0xA4,0x09,0x10,0x94,0x9B,
|
||||
0xFF,0xF3,0x28,0xC4,0x17,0x0F,0xB2,0x56,0xC0,0x00,0xC3,0x44,0xB8,0x2F,0xE8,0x2F,
|
||||
0xE8,0x59,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0x4F,0xF4,0x6B,0x23,0x1C,0xEB,
|
||||
0x29,0xD0,0x89,0xCE,0xFF,0xDE,0xEF,0x46,0xAC,0xE0,0xC2,0xB8,0x44,0x61,0x1F,0xFF,
|
||||
0x2F,0x8D,0x53,0xD4,0x41,0xFF,0xFF,0xFA,0x8E,0x02,0x01,0x01,0x46,0x81,0x6B,0x52,
|
||||
0xB5,0xB5,0xDE,0x5F,0xF0,0x32,0x84,0xFC,0xFF,0xF3,0x28,0xC4,0x13,0x0C,0xC1,0xEE,
|
||||
0xC8,0x00,0xC3,0x44,0x98,0x64,0xA0,0x5C,0x2E,0x17,0x11,0x4B,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFE,0x8D,0x94,0xA5,0x65,0x12,0x59,0x61,0x6A,0xAA,
|
||||
0xEA,0x96,0x0D,0x21,0x29,0x81,0x01,0xE7,0xF8,0xED,0xE9,0xE5,0xF6,0x35,0xB6,0x32,
|
||||
0xE8,0x32,0xD6,0x42,0xB9,0x68,0xDF,0x6E,0x7E,0xCD,0x06,0x5D,0x46,0x6F,0xFF,0xFF,
|
||||
0xFF,0xF3,0x28,0xC4,0x1B,0x0B,0xC0,0x5E,0xCC,0xCB,0x4F,0x10,0x02,0xFF,0xFF,0xFF,
|
||||
0x4B,0x54,0x6C,0x4E,0x18,0x68,0xA5,0xAF,0x30,0xD6,0x23,0x59,0x00,0x12,0xFF,0xFF,
|
||||
0xE9,0x82,0x9A,0x96,0xDA,0xA7,0xE4,0x62,0x78,0x56,0x88,0x9E,0x80,0x69,0x9F,0x38,
|
||||
0x90,0x80,0xE1,0x64,0xA0,0x83,0xEA,0x89,0x64,0xD8,0x5A,0x0E,0x9C,0xE7,0xAE,0xFA,
|
||||
0x2F,0xAD,0x67,0x23,0xFF,0xA3,0xAF,0xFF,0xFF,0xF3,0x28,0xC4,0x27,0x15,0xEA,0xA6,
|
||||
0x8C,0x01,0x98,0x38,0x01,0xFF,0x9A,0xBE,0x94,0xFE,0xC9,0x44,0x38,0xE0,0x5A,0x22,
|
||||
0xBE,0x93,0x9C,0x77,0xFF,0x07,0x25,0x87,0x0A,0xCD,0x38,0xB9,0x54,0x07,0xC7,0x1A,
|
||||
0x44,0x74,0x6A,0x50,0x75,0x0E,0x52,0x85,0xCE,0xFF,0xF3,0x9B,0xD3,0x41,0xE2,0x8F,
|
||||
0x77,0xFF,0x0A,0x9C,0x68,0x22,0x00,0x6B,0x80,0xC0,0x7C,0x07,0xEC,0x71,0x22,0x56,
|
||||
0xFF,0xF3,0x28,0xC4,0x0A,0x0A,0x58,0x65,0xDC,0x7F,0xC6,0x08,0x00,0x0A,0x01,0x48,
|
||||
0xD4,0x58,0x91,0x2B,0x05,0x00,0xA4,0x69,0x14,0x58,0xEA,0x2A,0xFD,0x47,0xB9,0x6A,
|
||||
0x7F,0xFF,0xFF,0xC4,0xBF,0xFF,0xFF,0xFF,0xAC,0xEF,0xF9,0xD2,0xB5,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0x1B,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0x56,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0x91,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
};
|
||||
|
||||
const uint8_t serverConnectSucceed[] = {
|
||||
|
||||
0xFF,0xF3,0x28,0xC4,0x00,0x0B,0x00,0x02,0xB5,0x6F,0x41,0x10,0x02,0x59,0x52,0x10,
|
||||
0x13,0x83,0xEE,0x58,0xA2,0x8C,0xAC,0x81,0x7B,0x16,0x17,0x88,0x2A,0xCA,0x19,0x53,
|
||||
0x8F,0xEA,0x1A,0x3C,0xFF,0x1A,0x2B,0x13,0xBD,0x73,0x3D,0xEB,0x07,0xE5,0x2A,0xFF,
|
||||
0xCF,0xFF,0xBD,0x1A,0x7F,0xFD,0x4E,0xFF,0x90,0x9E,0x95,0x55,0xBB,0x5D,0xA0,0x8E,
|
||||
0xF7,0x74,0x4B,0x3F,0x3B,0x75,0x2F,0x6B,0xFF,0xF3,0x28,0xC4,0x0F,0x0E,0xB1,0x5E,
|
||||
0xC4,0x01,0x82,0x10,0x00,0x23,0x33,0x13,0x42,0x90,0x1A,0xD1,0x20,0xA8,0x93,0x9E,
|
||||
0x56,0x77,0x3A,0x59,0x5F,0x9D,0x79,0x61,0x85,0x17,0xB6,0x70,0xE3,0xA7,0xDE,0x69,
|
||||
0xDB,0x5A,0x52,0x89,0x6A,0x2E,0x04,0x62,0x77,0x20,0x54,0x73,0xFF,0xD7,0xA3,0xDF,
|
||||
0xA1,0xFF,0xE7,0xFC,0x73,0x70,0x15,0x63,0x8C,0xB9,0xA8,0xD9,0xE7,0xE5,0xF0,0xE5,
|
||||
0xFF,0xF3,0x28,0xC4,0x0F,0x0E,0xE8,0xCE,0xC0,0x01,0xCF,0x30,0x00,0x05,0x42,0x01,
|
||||
0xE7,0xA5,0x31,0xE0,0x05,0xA7,0xFE,0xF7,0x32,0x41,0x21,0xF9,0xE7,0xD4,0x6B,0x4E,
|
||||
0x32,0x4D,0x50,0x68,0x55,0xBA,0xD9,0x0D,0x2B,0x44,0xCB,0x8D,0x4B,0x3E,0x49,0x2B,
|
||||
0x1A,0x64,0x51,0xBD,0x5E,0xEF,0xD5,0xFD,0x7F,0x5A,0xA0,0x04,0x92,0x88,0x20,0x1F,
|
||||
0xBA,0x9C,0x7C,0x00,0xBC,0x62,0x34,0x9A,0xFF,0xF3,0x28,0xC4,0x0E,0x10,0x78,0xA2,
|
||||
0xBD,0x94,0x6E,0x5E,0x4C,0x95,0xF1,0xA5,0xA5,0x9A,0x88,0x08,0x91,0x39,0xF3,0x16,
|
||||
0x01,0x5B,0x65,0x2C,0xB0,0x62,0xF6,0xE2,0xD8,0x1A,0x67,0x1A,0x6D,0x5D,0x09,0x89,
|
||||
0xC9,0x72,0x6B,0x02,0x20,0x91,0xA7,0xCA,0x80,0x80,0xC0,0xC2,0xCB,0x0F,0xA1,0xE8,
|
||||
0x5F,0xFF,0x7F,0xFF,0xFF,0xFF,0xA7,0xC5,0xD7,0x41,0x10,0x23,0xFA,0x0C,0xC6,0xC0,
|
||||
0xFF,0xF3,0x28,0xC4,0x07,0x0E,0x80,0xB2,0xB4,0xCA,0x56,0x5E,0x4C,0x12,0x4A,0xA0,
|
||||
0x79,0xAC,0xEA,0x04,0xB7,0xBE,0x53,0xAE,0x91,0x01,0xE7,0x26,0x26,0xB2,0x8F,0x8A,
|
||||
0x41,0x19,0x7D,0x5B,0x0D,0x64,0xA4,0x6E,0x08,0xF8,0x99,0xC6,0x81,0x67,0xA9,0x23,
|
||||
0x29,0x44,0xB4,0xE9,0xFC,0x77,0xC1,0xAF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xE9,
|
||||
0x0C,0x08,0xC0,0x06,0x50,0x00,0xB2,0x81,0xFF,0xF3,0x28,0xC4,0x08,0x0F,0x30,0xC2,
|
||||
0xE2,0x5E,0x0E,0x0E,0x4E,0xF7,0x8A,0xE3,0x4A,0x4A,0xF0,0x71,0xE3,0x9C,0xD7,0x39,
|
||||
0xFB,0xB9,0x0D,0x02,0x41,0x27,0xE8,0x70,0xF0,0x16,0x18,0xFC,0x78,0xE8,0xA8,0x68,
|
||||
0x37,0x77,0x40,0x20,0xD0,0xB7,0xFF,0xFF,0xFF,0xFF,0xFD,0x56,0x38,0xCB,0x3F,0xA4,
|
||||
0x24,0x3C,0x22,0x0E,0xC2,0xA4,0x8A,0x0B,0x8B,0xA1,0x24,0x28,0x5A,0x76,0x80,0x2D,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x20,0x92,0xD5,0xBE,0x13,0xDE,0x4E,0xA0,0x7D,0x41,
|
||||
0x93,0xE3,0x8F,0x91,0x5B,0xAF,0x4F,0x8C,0x65,0xE3,0x7A,0x24,0x8C,0xC4,0xFE,0x97,
|
||||
0xAE,0xE0,0x5E,0x6C,0x1C,0x61,0x48,0xEA,0x92,0xD5,0x02,0x62,0x71,0xA8,0x94,0x75,
|
||||
0xFF,0xFF,0xFF,0xFF,0xFC,0xD8,0x33,0xE9,0xFA,0x3A,0x56,0x93,0xD7,0x3D,0x31,0x65,
|
||||
0x10,0x03,0xA4,0x97,0xFE,0x00,0xFA,0x34,0xFF,0xF3,0x28,0xC4,0x08,0x0C,0xF8,0xD6,
|
||||
0xD6,0x58,0x6B,0xF0,0x71,0x11,0x61,0x03,0x01,0x34,0x63,0x57,0x70,0xF7,0x4B,0x35,
|
||||
0xB9,0x05,0x40,0x5E,0x99,0x57,0xD7,0xFF,0x3D,0x80,0xE4,0x50,0x02,0xA8,0xDA,0x53,
|
||||
0x8F,0x72,0x93,0x0E,0xDC,0xA2,0x76,0xDD,0xFB,0x12,0x9B,0xF8,0x7E,0xB9,0x5D,0xE4,
|
||||
0x76,0xB6,0x17,0x2B,0x92,0xDB,0x40,0xA0,0x01,0xC7,0xF1,0x66,0x96,0x40,0x05,0x34,
|
||||
0xFF,0xF3,0x28,0xC4,0x0F,0x0F,0x70,0xE7,0x02,0x5E,0x45,0x12,0x72,0xD1,0xF4,0x16,
|
||||
0x78,0x83,0x81,0x88,0x44,0x0D,0x8F,0x17,0x9F,0xEA,0x20,0x05,0xB3,0x55,0x9E,0x86,
|
||||
0x6C,0xFF,0x13,0x41,0x50,0x32,0xC0,0xA5,0x84,0x49,0xBB,0x5B,0x3C,0x4C,0xD3,0x3A,
|
||||
0x03,0x58,0x11,0x1A,0xC2,0xE0,0xF9,0xFF,0xFF,0xFF,0xFE,0x42,0x19,0x36,0xCD,0xDA,
|
||||
0xED,0xB6,0xDA,0x81,0xC1,0x39,0x72,0x81,0xFF,0xF3,0x28,0xC4,0x0C,0x0D,0x11,0x27,
|
||||
0x02,0x5E,0x11,0x84,0x72,0x01,0x1D,0x1F,0x5A,0xF8,0xE6,0xA3,0xD1,0x6D,0xFE,0xAB,
|
||||
0x83,0x0E,0x96,0xF8,0x63,0x3F,0xF4,0x35,0x17,0xFA,0xFF,0x94,0x29,0x9F,0xE7,0x79,
|
||||
0xBF,0xF8,0xDF,0xF1,0x70,0xD2,0x2F,0xB9,0x7A,0x19,0xFF,0xFF,0xE5,0x2A,0xED,0x0F,
|
||||
0x92,0xE4,0x16,0xE8,0x0B,0x3F,0xFF,0xFD,0x7F,0xFF,0xFF,0xFF,0xFD,0x3F,0xEB,0x4B,
|
||||
0xFF,0xF3,0x28,0xC4,0x12,0x10,0xD3,0x16,0xB4,0x00,0x08,0x4A,0xB9,0xEF,0x54,0x91,
|
||||
0xBF,0x57,0x23,0x32,0x96,0x8C,0xFA,0x9C,0x84,0x6E,0xC7,0x9E,0x46,0x1A,0x3F,0x44,
|
||||
0x53,0xA3,0x10,0x92,0x1E,0x74,0x64,0x64,0x6B,0x1E,0x4A,0x10,0x8D,0xD0,0xEA,0x66,
|
||||
0x39,0xC0,0x71,0x61,0x46,0x71,0x30,0x3C,0x8A,0x26,0x10,0x61,0x11,0x69,0xEA,0xF5,
|
||||
0xFF,0xCC,0x67,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xF3,0x28,0xC4,0x09,0x0D,0xA3,0x12,
|
||||
0xC8,0x00,0x08,0x4A,0xB9,0xFF,0xFF,0xFF,0xFF,0xAF,0xFF,0xDF,0x6A,0xB1,0x2A,0x8C,
|
||||
0x55,0xD3,0xEC,0xAF,0x22,0xF7,0x57,0x65,0x6A,0x88,0x87,0xC4,0xC0,0x48,0xB8,0x98,
|
||||
0xA4,0x82,0x8D,0xED,0xA3,0xF4,0x96,0x82,0xC9,0xF4,0x3A,0xD0,0x78,0xB2,0x8F,0x65,
|
||||
0x48,0x99,0x1A,0x3D,0x01,0x97,0xFF,0xD4,0xBD,0x05,0x80,0xF8,0x07,0x97,0xBE,0xE7,
|
||||
0xFF,0xF3,0x28,0xC4,0x0D,0x0C,0xE2,0x6E,0xD4,0xCA,0x58,0x44,0xB8,0xF7,0xFF,0xFF,
|
||||
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xEA,0xF3,0x53,0xB2,0xB5,0x9F,0xFE,0xF5,
|
||||
0xDC,0x8F,0x45,0x6E,0xEC,0xEC,0xA8,0x83,0x20,0x14,0x48,0xF6,0x7F,0x6F,0x26,0x5A,
|
||||
0x45,0x84,0x81,0x9A,0xFF,0xD7,0xE3,0x8D,0x5A,0x7A,0xD5,0xD0,0x98,0x52,0x6A,0x15,
|
||||
0x35,0xE8,0x78,0x4A,0x39,0xE6,0xA8,0xE0,0xFF,0xF3,0x28,0xC4,0x14,0x0D,0x09,0xD2,
|
||||
0xC0,0x00,0xC9,0xC4,0x94,0x38,0x19,0xFF,0xCC,0xFF,0xA3,0xB7,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0xFF,0xFF,0xFD,0xA3,0xB0,0x18,0x7A,0xAA,0xAB,0x16,0x4B,0x83,0x54,0x8B,0x82,
|
||||
0x2B,0x62,0xFF,0xFF,0xF4,0x55,0xAD,0x2A,0x9C,0x10,0xA4,0xEF,0xE6,0x5C,0xEB,0x63,
|
||||
0xAC,0xDE,0xCA,0xF9,0xCC,0xF1,0xC4,0xFA,0xDC,0x98,0x2B,0xC9,0x82,0x5F,0xEB,0xFF,
|
||||
0xFF,0xF3,0x28,0xC4,0x1A,0x0C,0xB0,0x62,0xB8,0x00,0x06,0x1E,0x28,0xFF,0xFF,0x36,
|
||||
0x28,0x16,0xA8,0xDA,0x9A,0xC2,0x28,0xBD,0x96,0x47,0x0B,0x04,0x81,0xD0,0xE1,0x62,
|
||||
0x34,0xE8,0xB1,0x17,0xE9,0xA5,0xF8,0x6D,0xA3,0x9C,0x8E,0xA6,0xB2,0x69,0xF5,0x2B,
|
||||
0x3A,0xE1,0x42,0x1B,0x81,0xCC,0x71,0x5C,0x06,0x17,0x0B,0x96,0x7E,0x05,0x11,0x7F,
|
||||
0xFF,0xFF,0xFF,0xB9,0xE2,0x04,0x52,0xA0,0xFF,0xF3,0x28,0xC4,0x22,0x0B,0xD8,0x5A,
|
||||
0xC0,0x00,0x06,0x1E,0x24,0xC9,0xC0,0x19,0xF4,0x10,0x5A,0x7B,0x56,0xE0,0x89,0x78,
|
||||
0x38,0x82,0x6A,0xFF,0xFD,0x37,0x9D,0x65,0xC0,0x18,0xC7,0x03,0xC3,0x7C,0xCB,0x27,
|
||||
0x83,0x44,0x9F,0x07,0x51,0x0A,0xA5,0xA1,0xDA,0x50,0x48,0xF7,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0x86,0x85,0xC7,0x99,0x4B,0x3F,0xD3,0x1E,0x1A,0x34,0x6C,0x7B,0x7F,0xA2,0x89,
|
||||
0xFF,0xF3,0x28,0xC4,0x2D,0x0A,0xF0,0x5E,0xC4,0x01,0x4F,0x10,0x00,0x41,0x19,0x4B,
|
||||
0xB3,0x7A,0x1A,0x6A,0x3F,0x2D,0x15,0x16,0x58,0x37,0x24,0x32,0x4C,0xEC,0xB4,0x48,
|
||||
0xA4,0xF2,0x41,0xE2,0x61,0x20,0x60,0x21,0x09,0x4D,0x07,0xC3,0x57,0x74,0x67,0x5E,
|
||||
0x72,0xFF,0xFF,0xE9,0x7F,0xFF,0x9F,0xFA,0xFF,0xFF,0x79,0xE7,0x98,0x68,0xD4,0xB5,
|
||||
0x7A,0x1C,0x36,0x2B,0xFF,0x2C,0x44,0xF3,0xFF,0xF3,0x28,0xC4,0x3C,0x16,0xA2,0x96,
|
||||
0x9C,0x01,0x98,0x38,0x00,0x07,0x09,0xBB,0x0D,0xC4,0x71,0x39,0x02,0x28,0xAD,0x34,
|
||||
0xD3,0x7A,0x58,0xB3,0xB1,0xBF,0x9A,0xAD,0x38,0x68,0x38,0x61,0x77,0xE7,0x84,0x47,
|
||||
0x84,0x42,0x59,0x6A,0xE4,0xDD,0x77,0x7F,0x4B,0x25,0xDF,0x64,0x90,0x12,0xB1,0x99,
|
||||
0xC6,0xBB,0x26,0x65,0xEE,0x85,0xD3,0x3D,0xCA,0x06,0x58,0xF3,0xEE,0xE2,0x40,0x0B,
|
||||
0xFF,0xF3,0x28,0xC4,0x1C,0x13,0x12,0x5A,0xA8,0x01,0x98,0x50,0x00,0x8D,0xDB,0xF8,
|
||||
0x96,0x21,0xE4,0xFF,0xF9,0xE6,0x13,0xFF,0xFE,0x93,0xCD,0x52,0x7F,0xFF,0xE7,0x98,
|
||||
0xAE,0x48,0x6F,0xFF,0xFE,0x50,0x92,0x40,0x48,0x37,0x20,0x24,0x26,0xDF,0xFF,0x7F,
|
||||
0xFC,0x90,0x90,0x78,0x3C,0x24,0x1E,0x38,0x54,0xD7,0xFF,0xFF,0x42,0x6A,0xFF,0xFD,
|
||||
0xFF,0xB3,0x89,0x7A,0xC7,0x86,0x16,0x64,0xFF,0xF3,0x28,0xC4,0x0A,0x0E,0x99,0xDE,
|
||||
0xD4,0x01,0x98,0x38,0x00,0x95,0x02,0xE1,0x49,0xDA,0xB5,0x20,0x12,0x86,0x8B,0x42,
|
||||
0x8C,0x78,0x1F,0x1D,0x07,0xA2,0xF5,0x2F,0x35,0x4C,0xA2,0x0B,0x69,0xFD,0xBD,0xFF,
|
||||
0xFF,0xD7,0xFF,0xFF,0xFE,0x8A,0x69,0xC6,0x3D,0x34,0xA6,0xDD,0xA8,0xEA,0x5D,0x95,
|
||||
0xBB,0x56,0xCD,0x56,0x25,0x55,0xFF,0xFF,0xD6,0x52,0xA1,0x1C,0x11,0x62,0x83,0x79,
|
||||
0xFF,0xF3,0x28,0xC4,0x0A,0x0E,0x81,0xBA,0xC8,0x01,0xD8,0x38,0x00,0x6F,0x51,0xE2,
|
||||
0xA9,0x60,0xD8,0xCD,0x34,0xBA,0x9B,0x29,0x28,0xC0,0xAC,0x63,0xFA,0x01,0x20,0x45,
|
||||
0x1B,0xC5,0x2F,0xF5,0x29,0xFA,0x9F,0xFD,0xFF,0x4F,0xFF,0xFF,0xFF,0xA2,0xA1,0x86,
|
||||
0x68,0x36,0x1E,0x67,0xC9,0x03,0x78,0x89,0xBA,0x10,0x97,0x96,0xE8,0x1A,0x6B,0x35,
|
||||
0x9B,0x6D,0x85,0xD8,0x01,0xF7,0x52,0x20,0xFF,0xF3,0x28,0xC4,0x0B,0x0D,0x38,0xA7,
|
||||
0x26,0x5E,0x54,0x16,0x4E,0x15,0x01,0xA0,0x9F,0x4B,0x54,0x81,0x1E,0x34,0x3A,0xD6,
|
||||
0xA4,0x18,0x95,0x13,0x2F,0xE1,0x25,0xCB,0x4F,0xC5,0xF2,0x8D,0x07,0x1F,0x22,0xEC,
|
||||
0x35,0xAF,0xDF,0xFF,0xFD,0x75,0x83,0x46,0xDC,0xF9,0xD3,0xD6,0x9E,0x6F,0xD2,0xFF,
|
||||
0xFF,0xCF,0x38,0x9C,0xF8,0x70,0x63,0x84,0xDC,0x39,0x5C,0x3F,0x97,0x30,0xBB,0x65,
|
||||
0xFF,0xF3,0x28,0xC4,0x11,0x0C,0x90,0x96,0xB4,0x01,0x5A,0x40,0x00,0x81,0x25,0xEC,
|
||||
0x73,0x98,0x63,0x72,0xDC,0x3B,0x24,0x05,0xA4,0x26,0xFB,0x48,0xA9,0xC1,0x5E,0x22,
|
||||
0x24,0xF8,0xB1,0xE7,0x7F,0xFF,0xFD,0xA2,0x22,0x4D,0x2C,0x1D,0x6D,0x83,0xAA,0x1B,
|
||||
0xED,0xF8,0x6D,0x8D,0x47,0xF7,0x97,0xF8,0x02,0x10,0x70,0x4F,0x0C,0x3D,0xFF,0x16,
|
||||
0xBD,0x6E,0x33,0xCF,0x0C,0x1C,0xEA,0x02,0xFF,0xF3,0x28,0xC4,0x19,0x12,0xC3,0x16,
|
||||
0xB4,0xCB,0x99,0x28,0x01,0x93,0x91,0x4E,0xC2,0x22,0xA8,0x23,0xEA,0xF3,0xD8,0xCA,
|
||||
0x86,0x4F,0x77,0xBF,0x47,0xA5,0xFF,0xFF,0xFF,0xFF,0xFF,0x45,0x35,0xBB,0xB9,0xD4,
|
||||
0x78,0xA7,0xFF,0xD7,0xFD,0x53,0xE4,0x33,0x48,0x55,0x27,0xFF,0xFF,0x7D,0xFA,0x76,
|
||||
0x8E,0x13,0x31,0xE8,0x73,0x0E,0x08,0xFA,0x17,0x59,0x70,0x36,0x00,0x04,0x40,0x7C,
|
||||
0xFF,0xF3,0x28,0xC4,0x09,0x0C,0xA1,0xD6,0xB8,0x01,0xCD,0x10,0x00,0x11,0xB3,0x72,
|
||||
0xFA,0x69,0xB7,0xAD,0x3F,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xEB,0xDE,
|
||||
0x9A,0x38,0xCF,0x45,0x7A,0x87,0xB8,0xB3,0xCB,0x1D,0x0A,0x34,0xE8,0xC2,0x5B,0xBF,
|
||||
0x2B,0xAD,0xC8,0x52,0x90,0x99,0x2A,0xFA,0xD2,0x5A,0xCC,0x89,0xA0,0x1E,0x00,0x0D,
|
||||
0xF0,0xD2,0x6C,0x59,0x22,0x24,0x96,0x87,0xFF,0xF3,0x28,0xC4,0x11,0x0C,0x91,0x9A,
|
||||
0xB8,0x00,0xA2,0x84,0x94,0x4E,0x42,0xA0,0x18,0x0D,0x83,0x43,0x15,0xFF,0x22,0x10,
|
||||
0x8D,0xFF,0x45,0xFF,0xEA,0xFF,0xFF,0xFF,0xFF,0xFA,0x28,0x00,0x85,0xE2,0xA4,0x0E,
|
||||
0x2E,0xA3,0x45,0x3F,0xEA,0x52,0xAA,0xFA,0x9F,0x51,0x98,0x88,0x01,0xA9,0x54,0x1C,
|
||||
0xC4,0xD4,0xB7,0xD2,0x7B,0x11,0x20,0x3D,0x9C,0xAE,0xB7,0xFA,0xAA,0x1C,0xB3,0x4F,
|
||||
0xFF,0xF3,0x28,0xC4,0x19,0x0D,0x01,0xFE,0xB8,0x00,0xA4,0xCE,0x98,0xFE,0x7F,0xFF,
|
||||
0xCC,0xFF,0xEA,0xFF,0xFA,0x0F,0x9F,0xFE,0xE2,0x30,0x09,0x09,0xDF,0xFB,0x31,0xAD,
|
||||
0xFF,0x43,0x9C,0xBF,0xB9,0xB6,0x76,0x13,0x3C,0x3F,0xF3,0xFF,0xC0,0x3C,0x08,0xDF,
|
||||
0x37,0x02,0x6A,0x22,0x5D,0x96,0xFD,0x7A,0xA5,0xA0,0x78,0x8F,0x67,0x6B,0x9E,0xFE,
|
||||
0xCA,0x49,0xAC,0xF8,0x6B,0xF7,0x7F,0x5E,0xFF,0xF3,0x28,0xC4,0x20,0x0C,0x68,0xA2,
|
||||
0xDD,0x94,0x0B,0x56,0x4C,0x2A,0x1D,0x42,0xC5,0x06,0xBD,0xAF,0x62,0x87,0x0D,0x0F,
|
||||
0x87,0x3C,0x2E,0x60,0xF9,0xC1,0x05,0x8E,0x41,0x7D,0x45,0x82,0x87,0x8D,0x86,0x8C,
|
||||
0xF8,0x8C,0x78,0xEF,0xF7,0x6F,0xFC,0x2E,0x16,0x0C,0xC1,0x32,0x65,0x0A,0x88,0x80,
|
||||
0xA0,0xB1,0xD0,0xA0,0xF0,0x90,0x50,0x0A,0x12,0x11,0x09,0x00,0x58,0x59,0xE1,0xA0,
|
||||
0xFF,0xF3,0x28,0xC4,0x29,0x0B,0xF0,0x06,0xC8,0x00,0x00,0x46,0x00,0xA8,0x08,0x90,
|
||||
0x49,0xAA,0xD2,0x49,0xEA,0xD0,0x10,0x05,0x02,0x30,0x0C,0x21,0x54,0x82,0x29,0x75,
|
||||
0x97,0xDF,0x7A,0xA5,0xE1,0xAC,0xF6,0xFE,0xB8,0x1B,0x36,0xC6,0xEE,0x35,0xF7,0xFD,
|
||||
0x39,0x1D,0x0E,0x85,0x30,0x89,0x19,0x97,0x42,0xDD,0xE5,0xB9,0xA5,0x32,0x8D,0x77,
|
||||
0xFF,0xFA,0xD9,0xA6,0xA5,0xF4,0x92,0x02,0xFF,0xF3,0x28,0xC4,0x34,0x0C,0x21,0x6A,
|
||||
0xBC,0x00,0x39,0x84,0x94,0x00,0x04,0x51,0x60,0x20,0xAC,0x9C,0x47,0xC0,0x30,0xDC,
|
||||
0xF6,0x95,0x4E,0x21,0x99,0x29,0x3A,0xF4,0xA6,0x60,0x30,0x4F,0x32,0x66,0x8B,0xB0,
|
||||
0x80,0x38,0x2D,0x76,0xE7,0x10,0xB6,0xEF,0x77,0xF3,0x73,0x61,0xEF,0xBD,0xDC,0xA6,
|
||||
0x62,0x40,0x77,0x2D,0xF4,0xCA,0x00,0x0B,0xA0,0x6E,0x61,0xB9,0xB9,0x14,0x49,0xBC,
|
||||
0xFF,0xF3,0x28,0xC4,0x3E,0x0C,0x71,0x02,0xC0,0x00,0x8B,0x0C,0x70,0x0C,0x2E,0x3F,
|
||||
0x34,0xC9,0x3D,0x8C,0xDB,0x8C,0x5C,0xFD,0x2E,0x2D,0xCA,0x2C,0xFF,0x20,0x08,0x92,
|
||||
0x5F,0xF7,0x00,0x91,0xCD,0xEF,0x25,0x7C,0xFF,0x9B,0x54,0xFE,0x54,0x0C,0x49,0x28,
|
||||
0x4D,0x82,0xBB,0xF8,0xFE,0x77,0x1B,0x50,0x0A,0xC1,0x14,0xAD,0x47,0xC8,0xDB,0x9F,
|
||||
0x22,0xA8,0x88,0x43,0xD6,0x57,0x12,0xDB,0xFF,0xF3,0x28,0xC4,0x47,0x0C,0xB8,0xFE,
|
||||
0xB4,0x00,0x9B,0xCC,0x71,0xFD,0xBA,0x95,0x2A,0xC0,0x01,0xC9,0xF7,0xE9,0x63,0x46,
|
||||
0x27,0xFF,0x59,0xEF,0x04,0x24,0x8D,0x4B,0x01,0x5E,0x65,0x46,0xB2,0x4F,0xAE,0x08,
|
||||
0x50,0x6B,0x96,0xDA,0x00,0x14,0x01,0xEA,0x59,0x80,0x7B,0x43,0xAC,0x02,0xAE,0x07,
|
||||
0xF8,0x6D,0xEB,0x21,0xA4,0x41,0xD1,0x51,0xD2,0x50,0xBC,0x91,0xB7,0xA0,0x10,0x14,
|
||||
0xFF,0xF3,0x28,0xC4,0x4F,0x0B,0x70,0x96,0xA0,0x00,0xD6,0x12,0x4C,0x92,0x94,0x4D,
|
||||
0xB1,0x50,0x54,0xC8,0x85,0xC5,0x9F,0x2A,0x0B,0x7F,0xFF,0xFF,0xFF,0xFF,0xBE,0x56,
|
||||
0x02,0x01,0x50,0x30,0x02,0x12,0x18,0x81,0x36,0x88,0x16,0x29,0x6A,0xC0,0x06,0x8B,
|
||||
0x14,0xAB,0x63,0x8F,0x93,0xF8,0xB8,0x1A,0xFA,0x44,0xF7,0xDE,0x77,0x10,0xCA,0x8F,
|
||||
0x16,0x60,0xB9,0x43,0xD7,0xD5,0xF0,0x6E,0xFF,0xF3,0x28,0xC4,0x5C,0x0C,0xF0,0x9A,
|
||||
0xDA,0x5F,0x54,0x10,0x02,0xF0,0xE1,0x00,0xD0,0x00,0xDC,0x7A,0xBE,0x16,0x8E,0x39,
|
||||
0x04,0x30,0x8A,0x8B,0x8F,0x7F,0xF8,0xA5,0xCB,0x04,0x40,0x76,0x19,0xBE,0xFD,0x7F,
|
||||
0xCD,0xD0,0x30,0xD7,0xF6,0xF9,0x4B,0xCE,0x4E,0xB7,0xFF,0xD3,0x76,0xBA,0xB2,0xBF,
|
||||
0xFA,0x6A,0x98,0x96,0x4D,0x4A,0xB0,0x89,0x3E,0xEC,0xF6,0x94,0xE9,0xC4,0x26,0x9F,
|
||||
0xFF,0xF3,0x28,0xC4,0x63,0x15,0x11,0x62,0x80,0xDD,0x9B,0x90,0x00,0xC5,0x2A,0x5D,
|
||||
0xE7,0x04,0x2A,0x42,0x78,0xC1,0xA8,0x50,0x91,0xED,0xD9,0x77,0x22,0x64,0x54,0x2E,
|
||||
0x10,0xC2,0xC1,0x4C,0x36,0x5C,0xC3,0x0B,0x9E,0x0C,0x0F,0x56,0x38,0xEE,0xC7,0x21,
|
||||
0xA4,0x9E,0x42,0xDB,0x68,0x5C,0xC9,0x10,0x3E,0xF4,0xC4,0x45,0xC1,0xA5,0x87,0x69,
|
||||
0x66,0x9D,0xBA,0xDF,0xC9,0x15,0x4B,0xB3,0xFF,0xF3,0x28,0xC4,0x49,0x16,0x98,0xEE,
|
||||
0xB0,0x01,0x98,0xD0,0x00,0xB9,0x81,0x40,0x44,0x45,0xB4,0xA1,0xC9,0xFF,0xFF,0xFF,
|
||||
0xFF,0xFF,0xB0,0x7B,0xFF,0xFD,0x15,0x90,0x02,0xD5,0x6B,0xFF,0xFB,0x60,0x15,0xCC,
|
||||
0x15,0xB1,0x99,0x98,0xC2,0x8F,0x34,0xE8,0x2D,0xEB,0x3C,0x44,0x04,0x70,0x1F,0x8B,
|
||||
0x10,0xF5,0x72,0x45,0x01,0x79,0x36,0xFB,0x8E,0x90,0x04,0xDA,0x4C,0xF4,0x6B,0xD6,
|
||||
0xFF,0xF3,0x28,0xC4,0x29,0x13,0x92,0xB2,0xF6,0x3F,0xCD,0x38,0x02,0x58,0xA7,0xD9,
|
||||
0x50,0x6E,0x5F,0xFD,0x1C,0xA0,0xD0,0xEF,0xCE,0x73,0xD1,0x0D,0xFD,0x9C,0xC3,0xFF,
|
||||
0xA2,0x33,0xFF,0xFF,0xF9,0xC6,0xBF,0x55,0xEA,0x4D,0x5F,0xFD,0x9F,0xFA,0x5C,0x83,
|
||||
0xAB,0x7A,0x95,0x19,0xA9,0x61,0x0A,0xFF,0xFF,0xFF,0x81,0xFB,0x79,0xE5,0x88,0x8D,
|
||||
0xA0,0x40,0x20,0x91,0x3A,0x76,0xE5,0x6C,0xFF,0xF3,0x28,0xC4,0x15,0x11,0xDA,0x57,
|
||||
0x06,0x5E,0x5B,0x44,0xBB,0x74,0x68,0x0A,0x24,0xBF,0xE4,0xD1,0x84,0xFA,0x15,0x98,
|
||||
0x97,0x03,0x90,0x52,0x36,0x3E,0xFB,0xA4,0xA7,0x62,0x9B,0xBF,0xFB,0xFF,0xE6,0x27,
|
||||
0xFE,0xEF,0xFF,0x5F,0xFD,0x7F,0xFF,0xFF,0x56,0x6F,0xF2,0x8D,0xBE,0x91,0x91,0xF1,
|
||||
0xFD,0xDF,0xD2,0x6B,0xDF,0x4A,0xFD,0x4A,0xA2,0x1D,0x69,0x8B,0x6D,0x86,0x17,0x00,
|
||||
0xFF,0xF3,0x28,0xC4,0x08,0x0D,0x40,0xEE,0xF6,0x5E,0x39,0xD4,0x72,0x9F,0x24,0xE6,
|
||||
0xD0,0x08,0x81,0x21,0x59,0x96,0x7B,0x12,0x0C,0x00,0xA0,0x67,0xB6,0x87,0x9A,0x02,
|
||||
0xA6,0x23,0xE4,0x43,0xE2,0x66,0x16,0x84,0x10,0xEB,0xFF,0xC7,0x8F,0xEB,0x7F,0xDD,
|
||||
0xFF,0xFD,0x7F,0xFF,0xF4,0xFA,0xCE,0x7A,0x46,0x95,0x11,0x89,0x2B,0x8B,0x6C,0x30,
|
||||
0x18,0x01,0xE9,0x31,0x0F,0xC0,0x51,0xA0,0xFF,0xF3,0x28,0xC4,0x0E,0x0E,0x50,0xEE,
|
||||
0xE6,0x5E,0x3B,0xCE,0x72,0xEB,0x77,0xFE,0xD5,0x62,0x28,0x78,0x68,0xCF,0x9B,0xEB,
|
||||
0x77,0xC6,0x39,0xC0,0x05,0x3D,0xB3,0x8C,0x5C,0xF1,0x30,0x96,0xF6,0xFA,0x8A,0x8F,
|
||||
0x7F,0x9D,0xFF,0xCB,0x1F,0xFF,0xFF,0xFF,0xE5,0x4C,0x94,0x01,0x03,0x40,0x53,0xA6,
|
||||
0x6A,0x00,0x30,0x18,0xDF,0x80,0x07,0x00,0x7D,0x49,0x5C,0x92,0x22,0x80,0x4A,0x84,
|
||||
0xFF,0xF3,0x28,0xC4,0x0F,0x0C,0xF0,0xF2,0xA5,0xBE,0x6B,0x4A,0x70,0xA9,0xB4,0xD9,
|
||||
0x9F,0x98,0x92,0x00,0xAD,0x09,0x52,0x4E,0xA4,0x96,0xD5,0x28,0x0A,0x2A,0x24,0xF9,
|
||||
0x5B,0x62,0x96,0x22,0x2A,0xC6,0xD7,0x88,0x94,0xEF,0x57,0xFF,0xFF,0xFF,0xFF,0xFA,
|
||||
0x56,0x5A,0x43,0x4F,0x66,0xF3,0x62,0x28,0x0A,0xAA,0x44,0x98,0x60,0x33,0x12,0x90,
|
||||
0x1A,0xC0,0xB0,0x2E,0xE4,0x4E,0x31,0x7A,0xFF,0xF3,0x28,0xC4,0x16,0x0D,0x08,0x96,
|
||||
0x24,0x02,0x66,0x1E,0x4C,0x9A,0x23,0x0C,0x17,0xA1,0x6D,0x33,0x90,0xB6,0x88,0x17,
|
||||
0x7B,0x48,0xD9,0x7B,0x47,0xD8,0x02,0xB3,0x5A,0x45,0xAD,0xFF,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0x6A,0xC8,0xD5,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0x1C,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0x57,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0x92,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
|
||||
};
|
||||
|
||||
void download_file()
|
||||
{
|
||||
uint32_t status;
|
||||
FILE* fp = luat_fs_fopen("test1.mp3", "r");
|
||||
|
||||
if (fp)
|
||||
{
|
||||
luat_fs_fclose(fp);
|
||||
return;
|
||||
}
|
||||
// Create file
|
||||
FILE* fp1 = luat_fs_fopen("test1.mp3", "wb+");//BatteryCharging.mp3
|
||||
|
||||
// Write mp3 data into file
|
||||
status = luat_fs_fwrite((uint8_t *)batteryCharging, sizeof(batteryCharging), 1, fp1);
|
||||
if (status == 0)
|
||||
{
|
||||
while (1);
|
||||
}
|
||||
|
||||
// After writing, close it
|
||||
luat_fs_fclose(fp1);
|
||||
|
||||
|
||||
// Create file
|
||||
fp1 = luat_fs_fopen("test2.mp3", "wb+");//BatteryCharging.mp3
|
||||
|
||||
// Write mp3 data into file
|
||||
status = luat_fs_fwrite((uint8_t *)rebooting, sizeof(rebooting), 1, fp1);
|
||||
if (status == 0)
|
||||
{
|
||||
while (1);
|
||||
}
|
||||
|
||||
// After writing, close it
|
||||
luat_fs_fclose(fp1);
|
||||
|
||||
|
||||
// Create file
|
||||
fp1 = luat_fs_fopen("test3.mp3", "wb+");//BatteryCharging.mp3
|
||||
|
||||
// Write mp3 data into file
|
||||
status = luat_fs_fwrite((uint8_t *)serverConnecting, sizeof(serverConnecting), 1, fp1);
|
||||
if (status == 0)
|
||||
{
|
||||
while (1);
|
||||
}
|
||||
|
||||
// After writing, close it
|
||||
luat_fs_fclose(fp1);
|
||||
|
||||
// Create file
|
||||
fp1 = luat_fs_fopen("test4.mp3", "wb+");//BatteryCharging.mp3
|
||||
|
||||
// Write mp3 data into file
|
||||
status = luat_fs_fwrite((uint8_t *)serverConnectSucceed, sizeof(serverConnectSucceed), 1, fp1);
|
||||
if (status == 0)
|
||||
{
|
||||
while (1);
|
||||
}
|
||||
|
||||
// After writing, close it
|
||||
luat_fs_fclose(fp1);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@@ -0,0 +1,29 @@
|
||||
local TARGET_NAME = "example_audio"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
includes(SDK_TOP .. "/thirdparty/audio_decoder")
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
add_deps("audio_decoder")
|
||||
|
||||
includes(SDK_TOP .. "/thirdparty/miniz")
|
||||
add_deps("miniz")
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs("./include",{public = true})
|
||||
add_includedirs(SDK_TOP .. "/PLAT/core/tts/include/16k_lite_ver",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. "/PLAT/core/lib/libaisound50_16K.a "
|
||||
--8K版本用下面的库,注释掉16K的库
|
||||
-- LIB_USER = LIB_USER .. SDK_TOP .. "/PLAT/core/lib/libaisound50_8K.a "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,350 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 1
|
||||
#define RTE_UART1_RTS_PIN_EN 1
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN23}, // 0 : gpio8 / 1 : SPI0 SSn
|
||||
// { PAD_PIN24}, // 0 : gpio9 / 1 : SPI0 MOSI
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 1 : SPI0 MISO
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 1 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 0xFF
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 24
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 25
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 26
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 8
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 1
|
||||
|
||||
// { PAD_PIN13}, // 0 : gpio2 / 1 : UART0 RTSn / 3 : SPI1 SSn
|
||||
// { PAD_PIN14}, // 0 : gpio3 / 1 : UART0 CTSn / 3 : SPI1 MOSI
|
||||
// { PAD_PIN15}, // 0 : gpio4 / 1 : UART0 RXD / 3 : SPI1 MISO
|
||||
// { PAD_PIN16}, // 0 : gpio5 / 1 : UART0 TXD / 3 : SPI1 SCLK
|
||||
#define RTE_SPI1_SSN_BIT 13
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 14
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 15
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 16
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,46 @@
|
||||
const unsigned char amr_10_data[] =
|
||||
{
|
||||
0x23, 0x21, 0x41, 0x4D, 0x52, 0x0A, 0x3C, 0xD1, 0xEB, 0x45, 0x38, 0x17, 0x4B, 0xC7, 0xEC,
|
||||
0xAC, 0x4E, 0xCF, 0xE5, 0x37, 0x62, 0x13, 0x80, 0x00, 0x2C, 0x5C, 0xA3, 0xDA, 0x63, 0x3C, 0x00,
|
||||
0x05, 0x44, 0xD4, 0xDE, 0xA5, 0x9C, 0xB0, 0x3C, 0x91, 0xBB, 0x0D, 0x95, 0x72, 0xFB, 0x9F, 0x8F,
|
||||
0x1D, 0xD0, 0xFB, 0xDA, 0x41, 0x8C, 0x4D, 0x7E, 0x6C, 0xAE, 0x61, 0x27, 0xEB, 0xD7, 0x6B, 0x58,
|
||||
0x7A, 0x96, 0xFD, 0x47, 0x4B, 0x45, 0xE0, 0x3C, 0xB9, 0xEA, 0xB7, 0xC0, 0xB6, 0x32, 0x07, 0x1E,
|
||||
0x0D, 0xC4, 0x6A, 0xAA, 0x9C, 0x80, 0x4F, 0xFA, 0xA7, 0x72, 0x90, 0x8E, 0x0C, 0x8B, 0x69, 0xD7,
|
||||
0x4B, 0x15, 0xB1, 0x77, 0x55, 0x6F, 0x80, 0x3C, 0xB9, 0xE8, 0xB3, 0xBA, 0xEB, 0xDC, 0x4F, 0x5E,
|
||||
0x1D, 0xC1, 0x0A, 0xA2, 0xD4, 0x1E, 0x7C, 0xED, 0xDE, 0x0D, 0x02, 0xE1, 0x3C, 0x74, 0xB8, 0x78,
|
||||
0xD5, 0x8E, 0x22, 0x6E, 0xB5, 0x11, 0x50, 0x3C, 0xC3, 0xE0, 0xB9, 0xC8, 0x28, 0x60, 0x83, 0x5E,
|
||||
0x16, 0xE1, 0x8F, 0xB6, 0x8D, 0x90, 0xD5, 0xA9, 0x98, 0xDE, 0xFD, 0xD5, 0xE6, 0xF4, 0x07, 0x85,
|
||||
0xDB, 0x97, 0xEC, 0x3A, 0xB2, 0xD6, 0xB0, 0x3C, 0xB9, 0xE4, 0xB5, 0xC2, 0x40, 0x66, 0x1A, 0x1E,
|
||||
0x0A, 0xC0, 0x2A, 0xEA, 0x49, 0xE3, 0x97, 0xFD, 0x61, 0x04, 0x95, 0xC8, 0xD1, 0x7D, 0x00, 0xBC,
|
||||
0xCB, 0x39, 0xE0, 0x10, 0x58, 0x8F, 0x90, 0x3C, 0xB9, 0xDA, 0xB9, 0xB9, 0xE4, 0x5C, 0x18, 0x7E,
|
||||
0x16, 0xF1, 0xBF, 0x34, 0x87, 0x59, 0x0F, 0x82, 0xA5, 0xA6, 0x03, 0x11, 0x99, 0xCD, 0xEF, 0x5E,
|
||||
0xA9, 0xEE, 0x5F, 0xA8, 0xD0, 0x1F, 0xA0, 0x3C, 0xC3, 0xE4, 0xB5, 0xC1, 0x20, 0x10, 0x09, 0x5E,
|
||||
0x1B, 0x6E, 0xEA, 0x93, 0x46, 0x05, 0xC7, 0xD3, 0x95, 0x92, 0x31, 0xB4, 0xEF, 0xCD, 0x04, 0x10,
|
||||
0xF7, 0x4A, 0x64, 0x74, 0x9A, 0xC5, 0x90, 0x3C, 0xB5, 0xE0, 0xBD, 0xC5, 0xD0, 0x6C, 0x02, 0xDE,
|
||||
0x05, 0x81, 0x3A, 0x9C, 0xD8, 0xDB, 0x2C, 0xC5, 0x02, 0xC6, 0xAD, 0xE4, 0xA1, 0x4D, 0x37, 0x75,
|
||||
0x63, 0x43, 0xA0, 0xFB, 0x2C, 0x4A, 0xF0, 0x3C, 0x01, 0xB5, 0x10, 0x99, 0x72, 0x8C, 0x52, 0x9E,
|
||||
0x1E, 0x8B, 0x9A, 0x06, 0x5E, 0xB6, 0xA8, 0xC3, 0x98, 0x92, 0xB7, 0xD9, 0x4F, 0x87, 0x4D, 0x15,
|
||||
0x54, 0x0F, 0xC5, 0x1E, 0x4B, 0xED, 0xC0, 0x3C, 0x42, 0x1D, 0x3C, 0xF9, 0x81, 0x94, 0x7A, 0x5E,
|
||||
0x16, 0x90, 0xCA, 0x15, 0x46, 0x59, 0xE0, 0xFC, 0x73, 0xB4, 0x02, 0xC6, 0xB5, 0xC0, 0xC0, 0xA2,
|
||||
0x22, 0x5B, 0x7B, 0x75, 0x08, 0x90, 0xA0, 0x3C, 0x04, 0xA6, 0xB3, 0xA1, 0x81, 0x83, 0xEA, 0x9E,
|
||||
0x0F, 0x84, 0xDA, 0xB9, 0xC6, 0xA2, 0x91, 0xC1, 0x5F, 0x9F, 0xCB, 0x86, 0xD2, 0x3D, 0x3D, 0x6C,
|
||||
0x55, 0x03, 0xC6, 0xB8, 0x47, 0xAB, 0xD0, 0x3C, 0x1E, 0x26, 0x98, 0xF9, 0x83, 0x42, 0xD7, 0x1E,
|
||||
0x0D, 0x2A, 0xCF, 0x99, 0x68, 0xD3, 0xE2, 0x90, 0x0F, 0x9E, 0x65, 0x97, 0x73, 0xD9, 0x8B, 0x25,
|
||||
0xAE, 0xB4, 0x80, 0xAE, 0x8E, 0x81, 0x20, 0x3C, 0x0E, 0xB3, 0x07, 0xA1, 0x84, 0xBB, 0xF0, 0xFE,
|
||||
0x1E, 0xD5, 0x5A, 0xC0, 0x96, 0x36, 0xE4, 0xC0, 0x3B, 0xBC, 0x27, 0x93, 0x39, 0x69, 0x1F, 0xFB,
|
||||
0x18, 0x68, 0x44, 0x8A, 0x7F, 0x16, 0xD0, 0x3C, 0x26, 0x18, 0xB1, 0xA1, 0x81, 0x6B, 0x86, 0xDE,
|
||||
0x93, 0x3F, 0x1F, 0xF3, 0x71, 0x38, 0x82, 0x86, 0x22, 0xA3, 0x07, 0x6A, 0x16, 0xEE, 0x0D, 0x09,
|
||||
0x71, 0x49, 0x2F, 0x86, 0x28, 0x0B, 0x90, 0x3C, 0x1E, 0x1A, 0xAE, 0xA0, 0x7D, 0xBF, 0xC2, 0x3E,
|
||||
0x0C, 0x7D, 0x1B, 0x3B, 0xB1, 0x18, 0x65, 0x40, 0x25, 0x7E, 0x97, 0x04, 0x6E, 0x01, 0x4D, 0xC8,
|
||||
0xC2, 0xA4, 0xEA, 0x00, 0xEF, 0x57, 0xD0, 0x3C, 0x26, 0x13, 0x0D, 0x98, 0x72, 0xCD, 0xE0, 0x9E,
|
||||
0x19, 0x2A, 0xDA, 0x83, 0x1D, 0xB1, 0x36, 0xEA, 0x13, 0x34, 0xBA, 0x6B, 0x28, 0xBD, 0x4B, 0x7E,
|
||||
0xC2, 0xFE, 0xE1, 0xB9, 0x66, 0x80, 0x00, 0x3C, 0x20, 0x38, 0x88, 0x38, 0x64, 0x81, 0xE1, 0xDF,
|
||||
0x0A, 0xD4, 0x2C, 0x01, 0xC7, 0xE8, 0x35, 0x32, 0xAB, 0x83, 0x39, 0xCC, 0x97, 0x4A, 0x64, 0x53,
|
||||
0xD1, 0xE5, 0x73, 0xFA, 0x09, 0x9F, 0xA0, 0x3C, 0xF3, 0x7A, 0x91, 0xF8, 0x4A, 0x2A, 0x5A, 0x5E,
|
||||
0x14, 0x7D, 0x8A, 0xE4, 0xE3, 0xD2, 0x19, 0xF6, 0xC0, 0x22, 0xA7, 0xF4, 0x4B, 0x31, 0x04, 0x04,
|
||||
0x32, 0xF2, 0x5A, 0xED, 0x99, 0x6F, 0x80, 0x3C, 0x1E, 0x3C, 0x7B, 0x28, 0x19, 0xC0, 0x5A, 0x0D,
|
||||
0x32, 0xD5, 0x1A, 0x9F, 0xCA, 0xF3, 0xD5, 0xCC, 0x0B, 0xC8, 0x96, 0xDF, 0x7C, 0xE0, 0x5E, 0x61,
|
||||
0x26, 0xBF, 0x98, 0x25, 0xB9, 0x4B, 0x20, 0x3C, 0x1C, 0x41, 0x1C, 0x30, 0x13, 0x92, 0x08, 0x81,
|
||||
0xD9, 0x82, 0x8B, 0xA7, 0x57, 0x29, 0xD4, 0x47, 0x7F, 0x1A, 0x9C, 0x33, 0x50, 0xE0, 0xC9, 0x2B,
|
||||
0x66, 0x77, 0x00, 0x36, 0xA1, 0xE4, 0x20,
|
||||
};
|
||||
@@ -0,0 +1,28 @@
|
||||
const unsigned char amr_2_data[] =
|
||||
{
|
||||
0x23, 0x21, 0x41, 0x4D, 0x52, 0x0A, 0x3C, 0x9B, 0x36, 0x1C, 0x60, 0xB4, 0x01, 0xE7, 0xEE,
|
||||
0xCE, 0x4B, 0xBF, 0xF6, 0x74, 0x72, 0x62, 0x80, 0x00, 0x37, 0xCF, 0xCE, 0xF2, 0xE1, 0xE4, 0x00,
|
||||
0x02, 0x3C, 0xBB, 0x5F, 0xB3, 0x49, 0xA0, 0x3C, 0x6A, 0x72, 0x20, 0x10, 0x18, 0x43, 0xE2, 0xCF,
|
||||
0x17, 0x80, 0xDC, 0xCE, 0xF0, 0xB1, 0xEA, 0x14, 0x32, 0x4F, 0x4B, 0xDB, 0x09, 0xB0, 0x89, 0xC0,
|
||||
0x47, 0x8D, 0x68, 0x8E, 0xD1, 0xF2, 0xE0, 0x3C, 0x8A, 0xF1, 0x91, 0x58, 0x12, 0xAB, 0xF4, 0xBE,
|
||||
0x0B, 0x2A, 0x9A, 0x3A, 0xDE, 0x72, 0xF2, 0xE1, 0x2B, 0x21, 0xB4, 0xFB, 0x8C, 0xB0, 0x3B, 0x30,
|
||||
0x6E, 0xC0, 0x6C, 0x83, 0xE1, 0xDE, 0x10, 0x3C, 0x40, 0x71, 0x88, 0x08, 0x18, 0x03, 0xE1, 0x7E,
|
||||
0x09, 0x80, 0xDA, 0x69, 0x34, 0x33, 0x5D, 0xC3, 0x78, 0xC9, 0x25, 0xC3, 0x90, 0x46, 0x5C, 0x54,
|
||||
0x10, 0xE0, 0x05, 0x60, 0xB8, 0x93, 0xA0, 0x3C, 0x42, 0x67, 0x95, 0x08, 0x18, 0x3E, 0x79, 0xFE,
|
||||
0x07, 0x86, 0x5A, 0xFC, 0xB8, 0x84, 0x56, 0xDA, 0xC3, 0x64, 0x16, 0x1C, 0x4A, 0x26, 0x14, 0x61,
|
||||
0xF8, 0x7D, 0x8C, 0xEE, 0x1E, 0x46, 0x40, 0x3C, 0x26, 0x69, 0x9B, 0x00, 0x1B, 0x10, 0xF3, 0x1E,
|
||||
0x09, 0x98, 0x4A, 0x3B, 0x34, 0x2E, 0x1B, 0xC1, 0x10, 0x8C, 0xE3, 0x1F, 0xA6, 0xFD, 0xE7, 0x8D,
|
||||
0x7F, 0x16, 0xC5, 0xC3, 0xE2, 0x61, 0xD0, 0x3C, 0x44, 0x62, 0x16, 0x00, 0x35, 0x19, 0x68, 0x1E,
|
||||
0x19, 0x8D, 0x2A, 0xF2, 0x4A, 0xB4, 0x97, 0xF7, 0xA3, 0x8D, 0x86, 0xE0, 0x24, 0x00, 0x68, 0x8F,
|
||||
0x13, 0x24, 0x61, 0xB3, 0x50, 0xF3, 0xC0, 0x3C, 0x44, 0x52, 0x15, 0x00, 0x63, 0x80, 0x5B, 0x9E,
|
||||
0x0D, 0x92, 0x4F, 0xBC, 0x8A, 0xB7, 0x71, 0xCC, 0x2C, 0x0C, 0x00, 0x6C, 0xAF, 0x5A, 0x6A, 0xAB,
|
||||
0x71, 0xF3, 0x41, 0x87, 0x12, 0xCB, 0xC0, 0x3C, 0x1A, 0x55, 0x95, 0x60, 0x6D, 0xEE, 0x52, 0xDE,
|
||||
0x0B, 0xB2, 0x0A, 0xD2, 0x38, 0x73, 0x4A, 0xCA, 0x9F, 0x94, 0x03, 0x94, 0x44, 0x60, 0x42, 0x6D,
|
||||
0x13, 0xEA, 0x63, 0xEA, 0xFC, 0x8E, 0x70, 0x3C, 0xE0, 0x62, 0x1B, 0x58, 0xDD, 0x4E, 0x12, 0xCB,
|
||||
0x5C, 0x69, 0x1F, 0x1B, 0x4C, 0xEB, 0x57, 0xF2, 0x73, 0x9A, 0xF8, 0x7A, 0xA7, 0x5D, 0x79, 0xF2,
|
||||
0xC0, 0x7F, 0xE6, 0x02, 0x52, 0x14, 0x30, 0x3C, 0x1A, 0x53, 0x7F, 0x89, 0xB5, 0xD7, 0x48, 0x3C,
|
||||
0x27, 0x8B, 0x18, 0x65, 0x35, 0xB9, 0x65, 0x10, 0x9C, 0x17, 0x03, 0xF6, 0xB9, 0x1D, 0x85, 0x75,
|
||||
0x8E, 0x87, 0x90, 0xAD, 0x17, 0x1C, 0x10, 0x3C, 0xE0, 0x4B, 0x63, 0x51, 0x4E, 0x44, 0x18, 0x18,
|
||||
0x01, 0x34, 0xE8, 0xD1, 0x1A, 0x6F, 0xA2, 0x7E, 0xAD, 0xD9, 0x95, 0x8E, 0x9B, 0x0C, 0xA6, 0x33,
|
||||
0x08, 0x45, 0x49, 0x36, 0xF3, 0xEF, 0x20,
|
||||
};
|
||||
@@ -0,0 +1,104 @@
|
||||
const unsigned char amr_alipay_data[] =
|
||||
{
|
||||
0x23, 0x21, 0x41, 0x4D, 0x52, 0x0A, 0x3C, 0x71, 0xC7, 0x43, 0xD9, 0x06, 0xA3, 0x81, 0xAC,
|
||||
0xAC, 0x4B, 0xBF, 0xC5, 0x65, 0x62, 0x27, 0xC0, 0x00, 0x7B, 0x97, 0xE2, 0x73, 0xAA, 0x6C, 0x00,
|
||||
0x07, 0x3E, 0xFA, 0xC1, 0x76, 0x0C, 0x60, 0x3C, 0x55, 0xE8, 0xFF, 0xD4, 0xCF, 0x2E, 0x1E, 0x5E,
|
||||
0x04, 0x03, 0x18, 0x4B, 0x71, 0x95, 0xD6, 0xCB, 0xF6, 0x88, 0xBE, 0x63, 0x3A, 0x0C, 0x6A, 0xA7,
|
||||
0x05, 0x35, 0x43, 0x28, 0x53, 0xEE, 0xF0, 0x3C, 0xB5, 0xDA, 0xB1, 0xCB, 0x30, 0x53, 0x23, 0x9E,
|
||||
0x0A, 0x67, 0x8F, 0xE2, 0x78, 0x01, 0x1C, 0xB4, 0x81, 0x57, 0xEB, 0xFF, 0x84, 0x0B, 0x10, 0x70,
|
||||
0xA0, 0x41, 0x60, 0x2A, 0xD5, 0x03, 0x00, 0x3C, 0xF3, 0xB6, 0xB5, 0xC7, 0x7D, 0x8C, 0x1B, 0x5E,
|
||||
0x16, 0x48, 0x07, 0x94, 0xB5, 0xB0, 0xEA, 0x3F, 0xC7, 0x6A, 0xE5, 0xE0, 0xC3, 0x8B, 0x5C, 0x0F,
|
||||
0xE0, 0xFB, 0xA6, 0x3A, 0xB6, 0x7F, 0x20, 0x3C, 0x2E, 0x0E, 0x88, 0xB8, 0x01, 0xAC, 0x16, 0x7E,
|
||||
0x12, 0x0A, 0x59, 0x56, 0x9D, 0xBF, 0x05, 0xA4, 0x7A, 0xF7, 0xAD, 0x38, 0x31, 0x59, 0xD5, 0x9C,
|
||||
0x40, 0x57, 0xF8, 0x96, 0xC5, 0x13, 0x00, 0x3C, 0x24, 0xB8, 0x95, 0xB8, 0x01, 0xE7, 0xC3, 0x1E,
|
||||
0x06, 0x1B, 0x52, 0xF8, 0xBD, 0x44, 0x94, 0xD2, 0xA7, 0x0C, 0x96, 0x79, 0xCF, 0x80, 0xD5, 0x43,
|
||||
0x9F, 0x90, 0x5F, 0xF2, 0x87, 0xEB, 0x70, 0x3C, 0x2C, 0xAD, 0x29, 0x28, 0x01, 0x85, 0x0C, 0xFE,
|
||||
0x0C, 0x18, 0x0B, 0xE9, 0x6D, 0x9B, 0x60, 0xEC, 0xD3, 0x66, 0xD1, 0x88, 0x11, 0xF9, 0x3C, 0x94,
|
||||
0xD8, 0xC0, 0xF0, 0x13, 0x22, 0x7E, 0x30, 0x3C, 0x2C, 0xAC, 0x9A, 0xB0, 0xAA, 0x76, 0x11, 0xDC,
|
||||
0x22, 0x0F, 0xBB, 0x59, 0x0B, 0xEC, 0xF5, 0xFC, 0x9E, 0x59, 0x10, 0xD1, 0x53, 0x42, 0xA4, 0x69,
|
||||
0x27, 0xBC, 0x1A, 0xBB, 0x6D, 0x53, 0xF0, 0x3C, 0x2F, 0x9F, 0x1D, 0x8C, 0x2F, 0xBA, 0x00, 0x6B,
|
||||
0x55, 0x4F, 0x2F, 0xD9, 0x15, 0xAF, 0x5B, 0x44, 0x33, 0xFF, 0x89, 0xA8, 0xBE, 0xB0, 0x42, 0x66,
|
||||
0x25, 0x23, 0xB6, 0xF9, 0x61, 0x46, 0x40, 0x3C, 0xB5, 0x13, 0x34, 0xA4, 0x42, 0x30, 0x09, 0x45,
|
||||
0xBA, 0x5F, 0x3A, 0xDF, 0x82, 0xF6, 0x44, 0xE8, 0x95, 0x75, 0x5B, 0x3C, 0xAB, 0x3D, 0xC9, 0xF2,
|
||||
0xA6, 0x8F, 0xC7, 0xA1, 0xEE, 0xEA, 0xC0, 0x3C, 0xF3, 0x3E, 0x59, 0x41, 0x54, 0xF2, 0x10, 0xBE,
|
||||
0x02, 0x01, 0x77, 0x37, 0x99, 0xEE, 0xDB, 0x86, 0xB2, 0xF7, 0x6B, 0x82, 0x7E, 0xF9, 0xA0, 0xBE,
|
||||
0x53, 0xF9, 0x96, 0x90, 0xBF, 0x0F, 0xE0, 0x3C, 0x37, 0x7A, 0x02, 0x50, 0x00, 0x82, 0x74, 0x54,
|
||||
0xAA, 0x18, 0xCF, 0xF3, 0x94, 0xEF, 0x4E, 0xA8, 0x28, 0x8E, 0x14, 0x1C, 0xBF, 0xDE, 0x94, 0xA1,
|
||||
0xE3, 0x64, 0x7C, 0x59, 0x35, 0x1E, 0xF0, 0x3C, 0x1C, 0x44, 0x0D, 0xE8, 0x01, 0xBB, 0xE1, 0xD8,
|
||||
0x62, 0x34, 0x5F, 0xD5, 0xCF, 0xEB, 0x91, 0x8A, 0x0E, 0x7B, 0x5D, 0x82, 0x0D, 0xC1, 0xFD, 0x75,
|
||||
0x9E, 0x6D, 0x34, 0x57, 0x5E, 0xD0, 0x10, 0x3C, 0x24, 0x1D, 0xBE, 0x38, 0x06, 0xE1, 0x85, 0x12,
|
||||
0xCC, 0xEF, 0x5F, 0xBD, 0x1F, 0x57, 0x3D, 0x9F, 0x97, 0x64, 0x29, 0xBC, 0x8E, 0x9B, 0xF9, 0xE1,
|
||||
0x91, 0xDC, 0xF2, 0xBF, 0xB2, 0x2A, 0xC0, 0x3C, 0x06, 0x19, 0x9F, 0x51, 0x5C, 0xFB, 0x44, 0x70,
|
||||
0x6C, 0xBF, 0x4B, 0xFE, 0x42, 0xF9, 0x8F, 0x46, 0x1B, 0x10, 0x8B, 0xD1, 0xD1, 0xA6, 0xD9, 0x48,
|
||||
0x20, 0x7F, 0x6E, 0xB4, 0xF1, 0xD5, 0x80, 0x3C, 0x0C, 0x02, 0x64, 0x98, 0x35, 0x84, 0x11, 0xA0,
|
||||
0xD3, 0x00, 0x9F, 0xA0, 0x58, 0xA1, 0x49, 0xBD, 0x9B, 0x78, 0x76, 0x56, 0x19, 0x0C, 0xE2, 0x8E,
|
||||
0xC9, 0x0E, 0x14, 0x9A, 0x13, 0x60, 0x30, 0x3C, 0x20, 0x6E, 0x40, 0x68, 0x33, 0x11, 0x67, 0xFE,
|
||||
0x31, 0xF1, 0xD4, 0xF4, 0x37, 0xE4, 0x25, 0x23, 0xC8, 0x7B, 0xCB, 0x5C, 0xC3, 0xE1, 0xF7, 0xFE,
|
||||
0xCD, 0x7F, 0xCF, 0x72, 0x4E, 0xFF, 0x10, 0x3C, 0x4F, 0x7E, 0x0E, 0xE8, 0x67, 0xC6, 0xA5, 0xDE,
|
||||
0x14, 0xDE, 0xEF, 0xC7, 0x2B, 0x8C, 0x52, 0xDD, 0x16, 0x2E, 0xD8, 0x38, 0x00, 0x34, 0x59, 0xF6,
|
||||
0xD3, 0x87, 0xCA, 0xA0, 0x17, 0x76, 0x10, 0x3C, 0x44, 0xEA, 0x0B, 0x00, 0x7B, 0xC5, 0xF0, 0x1E,
|
||||
0x31, 0x8C, 0x48, 0xA0, 0x83, 0xE7, 0x4C, 0x2C, 0xCC, 0x12, 0x37, 0xA6, 0x04, 0x28, 0xA0, 0x65,
|
||||
0x30, 0x31, 0x42, 0x2A, 0xA3, 0x82, 0x60, 0x3C, 0x42, 0x4A, 0x13, 0x61, 0x80, 0x81, 0xF0, 0x9E,
|
||||
0x05, 0x86, 0xAF, 0x63, 0xCA, 0x35, 0x15, 0xDD, 0x56, 0xE3, 0xE3, 0x04, 0xA4, 0xCD, 0x23, 0x86,
|
||||
0x03, 0xAE, 0x71, 0xDB, 0xF7, 0xF8, 0xD0, 0x3C, 0x44, 0x4C, 0x11, 0x01, 0x86, 0xBE, 0x3D, 0xCF,
|
||||
0x11, 0x98, 0x8C, 0xCB, 0xF0, 0xA0, 0x0F, 0x11, 0xF0, 0x82, 0x40, 0x34, 0xFE, 0x30, 0x4C, 0x46,
|
||||
0x9C, 0x74, 0x14, 0x76, 0x34, 0x78, 0x50, 0x3C, 0x21, 0x7A, 0x16, 0xE9, 0x9B, 0xCC, 0x79, 0x7E,
|
||||
0x01, 0x92, 0xAF, 0xC0, 0x3C, 0x69, 0xC3, 0xF7, 0x7A, 0xFD, 0xCC, 0x53, 0x13, 0xC1, 0x52, 0x19,
|
||||
0xAB, 0xF7, 0x99, 0xC4, 0xB8, 0x4E, 0x50, 0x3C, 0x0E, 0x13, 0x87, 0x51, 0x9F, 0xAD, 0x68, 0xE9,
|
||||
0x77, 0x84, 0x42, 0x47, 0x21, 0xEC, 0xFB, 0x1B, 0x52, 0xCC, 0x72, 0x75, 0x56, 0x4E, 0xD8, 0xD2,
|
||||
0xB9, 0x3D, 0xD7, 0x63, 0x27, 0x15, 0xF0, 0x3C, 0x06, 0x14, 0x7D, 0x79, 0x9E, 0x76, 0x1E, 0x6D,
|
||||
0x32, 0x73, 0x7A, 0xE1, 0x4F, 0x99, 0xDB, 0xC5, 0x2D, 0x2F, 0xC6, 0x75, 0xD6, 0x27, 0x0C, 0x07,
|
||||
0xE0, 0x1C, 0x9D, 0x28, 0xE6, 0xD4, 0x70, 0x3C, 0x05, 0xFE, 0xAD, 0xA9, 0x9D, 0xBB, 0x1F, 0x9E,
|
||||
0x13, 0x9B, 0xE7, 0x82, 0x13, 0xE8, 0xED, 0x03, 0xEB, 0x0E, 0x1D, 0x36, 0xFA, 0x50, 0x9C, 0xE4,
|
||||
0xEC, 0x30, 0x00, 0xB2, 0x0D, 0xA6, 0x70, 0x3C, 0xE1, 0xDD, 0x06, 0xC2, 0xF3, 0x70, 0x0A, 0x76,
|
||||
0x88, 0x90, 0xAF, 0x8F, 0x4D, 0xB1, 0x07, 0x8F, 0x36, 0xA7, 0x6A, 0x83, 0x13, 0x18, 0x81, 0xC8,
|
||||
0x44, 0x4B, 0x63, 0x66, 0xD4, 0x6C, 0xF0, 0x3C, 0x53, 0xE5, 0x06, 0xC5, 0x52, 0x02, 0x1D, 0x1E,
|
||||
0x03, 0xA8, 0x0A, 0xDE, 0x13, 0xCB, 0xD0, 0x56, 0xBF, 0xB6, 0xC1, 0xE1, 0x78, 0xC8, 0x8F, 0xAC,
|
||||
0xD8, 0x7E, 0x8D, 0x38, 0x93, 0x9B, 0x30, 0x3C, 0xD1, 0xCD, 0x07, 0xD5, 0x64, 0xFA, 0xB9, 0x1E,
|
||||
0x02, 0xC1, 0x39, 0x0E, 0x1C, 0x03, 0x85, 0xE6, 0x4B, 0x87, 0x3B, 0x87, 0x79, 0x62, 0x5E, 0xD3,
|
||||
0x0E, 0xFA, 0x6E, 0xF9, 0x20, 0x32, 0xB0, 0x3C, 0xF3, 0xE6, 0xB4, 0xBE, 0xA2, 0x6A, 0x10, 0xFE,
|
||||
0x07, 0x1F, 0x97, 0xA8, 0x8F, 0x25, 0xA8, 0x36, 0x10, 0x8C, 0x81, 0x78, 0xDB, 0x31, 0xFD, 0xAA,
|
||||
0xC1, 0x3E, 0xEE, 0xA4, 0x2C, 0xA1, 0xC0, 0x3C, 0x28, 0x0E, 0x18, 0x48, 0x0C, 0x69, 0x17, 0x9E,
|
||||
0x17, 0x94, 0x73, 0xBD, 0xEC, 0x18, 0x07, 0xF6, 0xCB, 0xC2, 0xFD, 0x35, 0x82, 0x77, 0xD1, 0xF1,
|
||||
0xB7, 0x85, 0x90, 0x44, 0x4C, 0xD8, 0xA0, 0x3C, 0x46, 0x6D, 0x90, 0xE8, 0x19, 0x82, 0x79, 0xFA,
|
||||
0x4D, 0x81, 0xD9, 0xB9, 0x39, 0x3D, 0x28, 0x80, 0xC0, 0x2C, 0x5D, 0x9C, 0x0C, 0x5D, 0x66, 0x38,
|
||||
0xD0, 0x94, 0xBE, 0xEE, 0x18, 0xB3, 0x90, 0x3C, 0x35, 0x7A, 0x02, 0x50, 0x19, 0x91, 0x68, 0x89,
|
||||
0x77, 0x80, 0x1A, 0x3F, 0x26, 0x94, 0xBD, 0xE5, 0x4A, 0x83, 0x97, 0x9E, 0x9D, 0x93, 0x68, 0x3A,
|
||||
0x48, 0x9C, 0x5E, 0x54, 0xE0, 0x48, 0xB0, 0x3C, 0x30, 0x41, 0xAE, 0x58, 0x18, 0x4F, 0xE0, 0x58,
|
||||
0x66, 0xD5, 0x9E, 0x92, 0x53, 0x1C, 0x43, 0xF2, 0x8C, 0x6D, 0x03, 0x3B, 0xE0, 0x03, 0x0F, 0x00,
|
||||
0x84, 0x6A, 0x7A, 0x10, 0x26, 0x61, 0xE0, 0x3C, 0x1C, 0x44, 0x02, 0x50, 0x18, 0x04, 0x1F, 0xAB,
|
||||
0x54, 0x7F, 0xDF, 0xE8, 0xE7, 0xA8, 0x25, 0x93, 0x4A, 0x66, 0x8C, 0xFA, 0x0C, 0x34, 0xCF, 0xFC,
|
||||
0x05, 0x09, 0x80, 0xCB, 0x91, 0x39, 0xF0, 0x3C, 0x24, 0x54, 0x09, 0x10, 0x12, 0xE0, 0x01, 0xE1,
|
||||
0xF9, 0x85, 0xDB, 0x11, 0xA1, 0x5F, 0x52, 0x6C, 0xD3, 0xEC, 0x45, 0x77, 0x44, 0xB5, 0x64, 0x78,
|
||||
0x44, 0x6F, 0x89, 0x81, 0xE3, 0xAA, 0x30, 0x3C, 0x8A, 0xEB, 0x93, 0x65, 0x66, 0xD8, 0x2B, 0x87,
|
||||
0x91, 0x9A, 0xA3, 0x06, 0xFC, 0xB7, 0xD4, 0x3A, 0xA5, 0xDB, 0x74, 0x2F, 0x4C, 0x09, 0x70, 0x32,
|
||||
0xE8, 0x72, 0x63, 0xD7, 0x3D, 0x49, 0xD0, 0x3C, 0x28, 0x6C, 0x0F, 0x13, 0xF3, 0x28, 0x1D, 0xFA,
|
||||
0x54, 0x97, 0x7C, 0x62, 0x1A, 0x77, 0xBF, 0x35, 0xC0, 0x08, 0x68, 0xBC, 0xA1, 0x93, 0xA5, 0x44,
|
||||
0x6B, 0xE0, 0x4D, 0x3A, 0x71, 0x74, 0xA0, 0x3C, 0x8B, 0x2D, 0x8D, 0x55, 0xE1, 0xF4, 0x30, 0x96,
|
||||
0x9B, 0x87, 0x49, 0x7E, 0x1D, 0x0F, 0x01, 0x31, 0x4C, 0x8F, 0x1C, 0x19, 0x76, 0x58, 0x66, 0x57,
|
||||
0xEE, 0x02, 0x93, 0x2C, 0x37, 0xCF, 0x30, 0x3C, 0x68, 0x72, 0x21, 0x1C, 0x03, 0xAA, 0x01, 0xBE,
|
||||
0x01, 0x81, 0x4A, 0x71, 0xAF, 0xDB, 0x64, 0x4F, 0xD3, 0x31, 0x58, 0x2B, 0x71, 0x24, 0x8D, 0xD8,
|
||||
0x1B, 0x59, 0x12, 0x2C, 0x9C, 0x65, 0x80, 0x3C, 0xE4, 0x71, 0x93, 0x54, 0x34, 0x9A, 0x74, 0xDE,
|
||||
0x01, 0x88, 0xDF, 0xE7, 0x56, 0xBC, 0x18, 0xFE, 0xC8, 0xE2, 0xC9, 0x0B, 0x3E, 0x7A, 0xA2, 0x02,
|
||||
0xEC, 0x71, 0x3F, 0xDD, 0x9F, 0x09, 0x80, 0x3C, 0xF2, 0x5B, 0x7B, 0x18, 0x67, 0x8C, 0x3D, 0x1E,
|
||||
0x05, 0x6F, 0x5A, 0x1D, 0x0F, 0x96, 0xCA, 0x36, 0xDE, 0x18, 0x74, 0x7C, 0x16, 0xE0, 0x34, 0x9B,
|
||||
0x0F, 0x0B, 0x14, 0x5C, 0x92, 0x94, 0x90, 0x3C, 0xE0, 0x63, 0x88, 0x62, 0xEB, 0x3E, 0x20, 0x9E,
|
||||
0x07, 0x39, 0x3F, 0x9A, 0x24, 0xC9, 0x94, 0xD5, 0xA9, 0xEC, 0x1C, 0xC5, 0x22, 0x2E, 0xF5, 0x9E,
|
||||
0x9F, 0x03, 0x6E, 0xF7, 0xDC, 0x76, 0x20, 0x3C, 0x16, 0x62, 0x2D, 0x20, 0xD5, 0x96, 0x25, 0xDE,
|
||||
0x11, 0xA5, 0xB8, 0xE7, 0x13, 0x1A, 0xBF, 0x07, 0x8A, 0x59, 0xD4, 0x66, 0x7E, 0x64, 0xD4, 0xD1,
|
||||
0x92, 0x1B, 0xD4, 0xD5, 0x8C, 0x9E, 0x60, 0x3C, 0xE0, 0x68, 0x28, 0x0B, 0xAD, 0xDC, 0x12, 0x5E,
|
||||
0x05, 0xF4, 0x1A, 0xDF, 0x18, 0x00, 0xFC, 0x8B, 0x69, 0x18, 0xA1, 0x42, 0xC7, 0x9C, 0x17, 0x86,
|
||||
0x67, 0x40, 0x20, 0x47, 0xB7, 0x7B, 0x80, 0x3C, 0xD8, 0x56, 0x30, 0x49, 0xE3, 0x08, 0x5B, 0xDE,
|
||||
0x05, 0xA5, 0xA8, 0x08, 0x1D, 0x5D, 0xA4, 0x46, 0x1B, 0x0E, 0x29, 0x54, 0x2F, 0xE6, 0xF3, 0x03,
|
||||
0xDC, 0x04, 0x21, 0x18, 0x8D, 0x31, 0xE0, 0x3C, 0xE0, 0x5D, 0x64, 0x11, 0xF8, 0xB6, 0x1E, 0x9C,
|
||||
0x2B, 0xA5, 0xC8, 0x09, 0xE6, 0xB5, 0x5A, 0xF4, 0xED, 0x0A, 0xE2, 0x92, 0x2C, 0x4E, 0x9C, 0xCB,
|
||||
0xE0, 0x3A, 0x32, 0x4F, 0x8F, 0x57, 0x70, 0x3C, 0x1A, 0x47, 0x71, 0x1E, 0x00, 0xC4, 0x1E, 0xDE,
|
||||
0x00, 0xF5, 0x39, 0x1A, 0x94, 0xE7, 0xCB, 0xB2, 0x88, 0xF1, 0x38, 0x3E, 0x83, 0xE0, 0x6E, 0x01,
|
||||
0x9F, 0xE8, 0x37, 0xFD, 0x00, 0x74, 0x80, 0x3C, 0x08, 0x47, 0x6D, 0x14, 0xAE, 0xE0, 0x07, 0x8D,
|
||||
0x33, 0xAA, 0x47, 0x51, 0xE9, 0x90, 0x6C, 0x1C, 0x04, 0x5E, 0x81, 0xEF, 0x97, 0xA6, 0xD7, 0x09,
|
||||
0x50, 0xC5, 0x43, 0xAB, 0xF1, 0x78, 0xE0, 0x3C, 0x0C, 0x08, 0x4A, 0x1C, 0x20, 0xC6, 0x43, 0x01,
|
||||
0x6C, 0x28, 0xBA, 0x4E, 0x42, 0xCE, 0x89, 0x0A, 0xB7, 0x9E, 0x6D, 0x72, 0x13, 0xFF, 0xA1, 0xAB,
|
||||
0xF0, 0x73, 0xF8, 0x90, 0x98, 0x0C, 0xD0, 0x3C, 0x06, 0x1A, 0x85, 0x84, 0x8A, 0x12, 0x01, 0xC5,
|
||||
0x00, 0xAD, 0xDA, 0x09, 0x2B, 0xF9, 0xC9, 0xD6, 0xBC, 0xED, 0xC0, 0x7F, 0xFF, 0x80, 0x10, 0xC5,
|
||||
0xC0, 0xE5, 0xD1, 0xE7, 0xA0, 0x06, 0xD0,
|
||||
};
|
||||
@@ -0,0 +1,52 @@
|
||||
const unsigned char amr_yuan_data[] =
|
||||
{
|
||||
0x23, 0x21, 0x41, 0x4D, 0x52, 0x0A, 0x3C, 0x02, 0x2E, 0x27, 0x42, 0xC1, 0x79, 0xC3, 0xC8,
|
||||
0xAC, 0x64, 0xB8, 0xE4, 0x32, 0x33, 0x67, 0x00, 0x00, 0x24, 0xBD, 0x98, 0x4C, 0x9A, 0x40, 0x00,
|
||||
0x07, 0x46, 0x9C, 0x17, 0xFD, 0x55, 0xE0, 0x3C, 0x0C, 0x07, 0xA2, 0xC8, 0xD5, 0x3F, 0xDB, 0xE5,
|
||||
0xA6, 0x96, 0xD6, 0xC6, 0xAC, 0x0F, 0xCF, 0x22, 0x3A, 0xCD, 0x5D, 0xF4, 0xB2, 0x1E, 0xDB, 0xF7,
|
||||
0xFE, 0xF3, 0xB3, 0xC9, 0x1A, 0x13, 0x50, 0x3C, 0x04, 0x1E, 0xEB, 0x99, 0x81, 0x6B, 0xF9, 0xA9,
|
||||
0x67, 0x80, 0x07, 0xF9, 0x6C, 0x73, 0xE1, 0x1F, 0xF6, 0x50, 0x6A, 0x6B, 0x17, 0x60, 0x06, 0x21,
|
||||
0x7C, 0x32, 0x18, 0x98, 0x1B, 0x5B, 0xF0, 0x3C, 0x06, 0x14, 0xC1, 0xD1, 0x81, 0x2F, 0xFB, 0xCF,
|
||||
0x11, 0x26, 0x34, 0xEB, 0xAD, 0x87, 0x8B, 0xE3, 0x6A, 0xC9, 0xEA, 0xF7, 0x45, 0xB7, 0x3C, 0x5A,
|
||||
0x76, 0xA1, 0xCD, 0x1E, 0xDB, 0x48, 0x90, 0x3C, 0x06, 0x13, 0x3C, 0xB0, 0x7C, 0xEF, 0xF3, 0xDE,
|
||||
0x0B, 0x2E, 0xC7, 0x86, 0xE9, 0x21, 0xA7, 0x0C, 0x55, 0x94, 0x57, 0x92, 0xFB, 0x2D, 0x30, 0x86,
|
||||
0xA9, 0x4A, 0x36, 0x81, 0xB6, 0x30, 0x60, 0x3C, 0x28, 0x11, 0x14, 0xB8, 0x7B, 0xE3, 0xCB, 0xFE,
|
||||
0x39, 0x2E, 0x48, 0xEA, 0xB4, 0xE1, 0xFE, 0xEC, 0xC4, 0x3B, 0x69, 0x0E, 0x7D, 0x35, 0x91, 0x20,
|
||||
0x3D, 0x03, 0x66, 0x35, 0x3B, 0x61, 0xE0, 0x3C, 0x1E, 0x3E, 0x99, 0x41, 0x82, 0x57, 0x79, 0x9E,
|
||||
0x96, 0xD5, 0x57, 0xFB, 0xD3, 0xAD, 0x54, 0x87, 0x58, 0x06, 0x5E, 0xEA, 0x55, 0xA9, 0x04, 0x8E,
|
||||
0xDF, 0xB2, 0x11, 0x11, 0x89, 0xB3, 0xF0, 0x3C, 0x48, 0x3D, 0x20, 0x31, 0x87, 0xAF, 0x68, 0x9E,
|
||||
0x95, 0x84, 0x88, 0x4B, 0x34, 0xDE, 0x2A, 0xDF, 0xD8, 0xCB, 0x8E, 0x12, 0x2F, 0x79, 0x38, 0x04,
|
||||
0xAE, 0x64, 0x18, 0xFC, 0xA2, 0xC9, 0x40, 0x3C, 0x4E, 0x53, 0x76, 0x21, 0x98, 0x0F, 0xE2, 0x5F,
|
||||
0x25, 0x84, 0x36, 0xB6, 0x70, 0x45, 0x76, 0xB3, 0xC0, 0x06, 0x18, 0xB9, 0xB0, 0xE2, 0x02, 0x29,
|
||||
0xCE, 0x39, 0x17, 0x49, 0x41, 0x78, 0xA0, 0x3C, 0x54, 0x53, 0x5D, 0x19, 0x98, 0x63, 0xE3, 0xDE,
|
||||
0x0F, 0x80, 0x18, 0x1C, 0xEC, 0xD1, 0xBB, 0xD5, 0xA2, 0xA3, 0x84, 0x9A, 0x78, 0x21, 0xD6, 0x8E,
|
||||
0xC1, 0x51, 0xD4, 0x45, 0x68, 0x97, 0x30, 0x3C, 0x54, 0x67, 0x71, 0x21, 0x98, 0x4F, 0xF0, 0xFE,
|
||||
0x1F, 0x2A, 0xB8, 0x59, 0x30, 0x4F, 0x43, 0xFD, 0x50, 0x4D, 0xC0, 0x99, 0xB9, 0xFD, 0xA8, 0xCE,
|
||||
0x36, 0x87, 0x54, 0x3D, 0xEC, 0x8C, 0x00, 0x3C, 0x54, 0x5C, 0x63, 0x11, 0x98, 0x05, 0xE1, 0xFE,
|
||||
0x1F, 0x81, 0xB8, 0x32, 0x96, 0x43, 0x83, 0xD7, 0xD6, 0xA4, 0xD1, 0x41, 0x4C, 0x6D, 0x1B, 0xCB,
|
||||
0x93, 0x90, 0x24, 0xAE, 0x2B, 0xCD, 0xD0, 0x3C, 0x54, 0x5D, 0x67, 0x41, 0x98, 0x07, 0xE1, 0x7E,
|
||||
0x1F, 0x83, 0x48, 0x64, 0xDB, 0x58, 0x86, 0x3A, 0xCD, 0x4B, 0xA1, 0x5F, 0x9F, 0x1E, 0x84, 0x6B,
|
||||
0xA6, 0x24, 0x02, 0x0B, 0x72, 0x31, 0x20, 0x3C, 0x42, 0x5D, 0x67, 0x11, 0x98, 0x13, 0xE0, 0xDE,
|
||||
0x1F, 0x81, 0xAA, 0x91, 0xDA, 0x0D, 0x90, 0xFB, 0x22, 0x5A, 0xC8, 0xFF, 0xC4, 0xD8, 0x8E, 0x57,
|
||||
0xFB, 0xA0, 0x46, 0x60, 0xD6, 0xB0, 0xA0, 0x3C, 0x44, 0x41, 0x67, 0x19, 0x87, 0xF7, 0x68, 0x9E,
|
||||
0x05, 0x2A, 0x1A, 0xEB, 0x9F, 0x45, 0xB5, 0x97, 0x5F, 0xFD, 0xD2, 0x8E, 0x0F, 0xD2, 0x0F, 0x8E,
|
||||
0xC0, 0x36, 0xB8, 0x1B, 0xF8, 0x52, 0xA0, 0x3C, 0xE1, 0x78, 0x79, 0x11, 0x86, 0x54, 0x1E, 0x5E,
|
||||
0x12, 0xD9, 0xCA, 0xDA, 0xC5, 0x44, 0xFA, 0xF7, 0x0E, 0xE7, 0x7D, 0x62, 0x26, 0x08, 0x24, 0x02,
|
||||
0x74, 0x16, 0xB4, 0xD4, 0xBA, 0xCF, 0x20, 0x3C, 0x10, 0x12, 0x32, 0x49, 0x2B, 0x66, 0x07, 0x8F,
|
||||
0x11, 0x76, 0x4C, 0x24, 0x82, 0x93, 0xD1, 0x3B, 0xDC, 0x3A, 0xF2, 0x3D, 0x47, 0x19, 0x91, 0xC3,
|
||||
0xCB, 0x93, 0x67, 0xE8, 0x4E, 0x82, 0xD0, 0x3C, 0x0E, 0x0E, 0x38, 0x30, 0x72, 0xF3, 0xA4, 0x01,
|
||||
0xFE, 0x7F, 0x7A, 0x63, 0x3D, 0xE4, 0xAE, 0xC4, 0xFF, 0x88, 0x95, 0xC9, 0x9F, 0x3D, 0xBB, 0x5B,
|
||||
0x65, 0x27, 0x8F, 0x69, 0x00, 0x10, 0x10, 0x3C, 0x0C, 0x08, 0x3A, 0x48, 0x64, 0xFF, 0xF8, 0x45,
|
||||
0xBA, 0x7F, 0xBA, 0xC4, 0xB5, 0x09, 0xE3, 0xC1, 0x6E, 0x27, 0x58, 0x01, 0x6D, 0x3B, 0xEE, 0x1C,
|
||||
0xA3, 0x7A, 0xA0, 0x17, 0x80, 0xAD, 0x00, 0x3C, 0x0C, 0x0E, 0x42, 0x40, 0x61, 0x09, 0xE0, 0x23,
|
||||
0xC9, 0x2A, 0xFA, 0x31, 0xC3, 0xF4, 0x4F, 0x22, 0x1A, 0x07, 0x70, 0xCB, 0x1B, 0xF2, 0x55, 0xEA,
|
||||
0x82, 0x72, 0x19, 0x4B, 0x2E, 0xD3, 0xF0, 0x3C, 0x12, 0x09, 0x89, 0x40, 0x1F, 0xD7, 0x9F, 0xE5,
|
||||
0xAA, 0xD5, 0x6A, 0x0C, 0x6B, 0xA3, 0xC5, 0xFC, 0x74, 0xFD, 0x72, 0x74, 0xAF, 0x86, 0x1F, 0x15,
|
||||
0xA8, 0x63, 0xB0, 0x65, 0x11, 0x54, 0x10, 0x3C, 0x0C, 0x06, 0x2D, 0x42, 0xB9, 0xEE, 0x19, 0xA0,
|
||||
0xF8, 0xF6, 0xDA, 0x94, 0x53, 0x37, 0x3A, 0xC9, 0xC7, 0xA3, 0x22, 0x78, 0x9A, 0xAB, 0xF2, 0x20,
|
||||
0x55, 0x7B, 0xD2, 0x84, 0x13, 0x54, 0x80, 0x3C, 0x24, 0x08, 0xDC, 0x38, 0x18, 0xA4, 0x09, 0x81,
|
||||
0x87, 0x04, 0x5B, 0x6E, 0xE4, 0x5A, 0x53, 0x6C, 0x1F, 0xF1, 0x52, 0xF4, 0xB1, 0xF9, 0x8C, 0x11,
|
||||
0xBB, 0xCE, 0x90, 0xDD, 0x36, 0x93, 0xC0, 0x3C, 0x08, 0x88, 0x58, 0x3D, 0x56, 0x24, 0x01, 0x81,
|
||||
0x10, 0x9C, 0x96, 0x2E, 0x55, 0xCD, 0x55, 0xAD, 0xA3, 0xA6, 0xF2, 0x37, 0x3A, 0x53, 0x4A, 0xF5,
|
||||
0xC5, 0xFC, 0x90, 0x1F, 0x1A, 0x99, 0x20,
|
||||
};
|
||||
@@ -0,0 +1,104 @@
|
||||
const unsigned char audio_alipay_data[] =
|
||||
{
|
||||
0x23, 0x21, 0x41, 0x4D, 0x52, 0x0A, 0x3C, 0x71, 0xC7, 0x43, 0xD9, 0x06, 0xA3, 0x81, 0xAC,
|
||||
0xAC, 0x4B, 0xBF, 0xC5, 0x65, 0x62, 0x27, 0xC0, 0x00, 0x7B, 0x97, 0xE2, 0x73, 0xAA, 0x6C, 0x00,
|
||||
0x07, 0x3E, 0xFA, 0xC1, 0x76, 0x0C, 0x60, 0x3C, 0x55, 0xE8, 0xFF, 0xD4, 0xCF, 0x2E, 0x1E, 0x5E,
|
||||
0x04, 0x03, 0x18, 0x4B, 0x71, 0x95, 0xD6, 0xCB, 0xF6, 0x88, 0xBE, 0x63, 0x3A, 0x0C, 0x6A, 0xA7,
|
||||
0x05, 0x35, 0x43, 0x28, 0x53, 0xEE, 0xF0, 0x3C, 0xB5, 0xDA, 0xB1, 0xCB, 0x30, 0x53, 0x23, 0x9E,
|
||||
0x0A, 0x67, 0x8F, 0xE2, 0x78, 0x01, 0x1C, 0xB4, 0x81, 0x57, 0xEB, 0xFF, 0x84, 0x0B, 0x10, 0x70,
|
||||
0xA0, 0x41, 0x60, 0x2A, 0xD5, 0x03, 0x00, 0x3C, 0xF3, 0xB6, 0xB5, 0xC7, 0x7D, 0x8C, 0x1B, 0x5E,
|
||||
0x16, 0x48, 0x07, 0x94, 0xB5, 0xB0, 0xEA, 0x3F, 0xC7, 0x6A, 0xE5, 0xE0, 0xC3, 0x8B, 0x5C, 0x0F,
|
||||
0xE0, 0xFB, 0xA6, 0x3A, 0xB6, 0x7F, 0x20, 0x3C, 0x2E, 0x0E, 0x88, 0xB8, 0x01, 0xAC, 0x16, 0x7E,
|
||||
0x12, 0x0A, 0x59, 0x56, 0x9D, 0xBF, 0x05, 0xA4, 0x7A, 0xF7, 0xAD, 0x38, 0x31, 0x59, 0xD5, 0x9C,
|
||||
0x40, 0x57, 0xF8, 0x96, 0xC5, 0x13, 0x00, 0x3C, 0x24, 0xB8, 0x95, 0xB8, 0x01, 0xE7, 0xC3, 0x1E,
|
||||
0x06, 0x1B, 0x52, 0xF8, 0xBD, 0x44, 0x94, 0xD2, 0xA7, 0x0C, 0x96, 0x79, 0xCF, 0x80, 0xD5, 0x43,
|
||||
0x9F, 0x90, 0x5F, 0xF2, 0x87, 0xEB, 0x70, 0x3C, 0x2C, 0xAD, 0x29, 0x28, 0x01, 0x85, 0x0C, 0xFE,
|
||||
0x0C, 0x18, 0x0B, 0xE9, 0x6D, 0x9B, 0x60, 0xEC, 0xD3, 0x66, 0xD1, 0x88, 0x11, 0xF9, 0x3C, 0x94,
|
||||
0xD8, 0xC0, 0xF0, 0x13, 0x22, 0x7E, 0x30, 0x3C, 0x2C, 0xAC, 0x9A, 0xB0, 0xAA, 0x76, 0x11, 0xDC,
|
||||
0x22, 0x0F, 0xBB, 0x59, 0x0B, 0xEC, 0xF5, 0xFC, 0x9E, 0x59, 0x10, 0xD1, 0x53, 0x42, 0xA4, 0x69,
|
||||
0x27, 0xBC, 0x1A, 0xBB, 0x6D, 0x53, 0xF0, 0x3C, 0x2F, 0x9F, 0x1D, 0x8C, 0x2F, 0xBA, 0x00, 0x6B,
|
||||
0x55, 0x4F, 0x2F, 0xD9, 0x15, 0xAF, 0x5B, 0x44, 0x33, 0xFF, 0x89, 0xA8, 0xBE, 0xB0, 0x42, 0x66,
|
||||
0x25, 0x23, 0xB6, 0xF9, 0x61, 0x46, 0x40, 0x3C, 0xB5, 0x13, 0x34, 0xA4, 0x42, 0x30, 0x09, 0x45,
|
||||
0xBA, 0x5F, 0x3A, 0xDF, 0x82, 0xF6, 0x44, 0xE8, 0x95, 0x75, 0x5B, 0x3C, 0xAB, 0x3D, 0xC9, 0xF2,
|
||||
0xA6, 0x8F, 0xC7, 0xA1, 0xEE, 0xEA, 0xC0, 0x3C, 0xF3, 0x3E, 0x59, 0x41, 0x54, 0xF2, 0x10, 0xBE,
|
||||
0x02, 0x01, 0x77, 0x37, 0x99, 0xEE, 0xDB, 0x86, 0xB2, 0xF7, 0x6B, 0x82, 0x7E, 0xF9, 0xA0, 0xBE,
|
||||
0x53, 0xF9, 0x96, 0x90, 0xBF, 0x0F, 0xE0, 0x3C, 0x37, 0x7A, 0x02, 0x50, 0x00, 0x82, 0x74, 0x54,
|
||||
0xAA, 0x18, 0xCF, 0xF3, 0x94, 0xEF, 0x4E, 0xA8, 0x28, 0x8E, 0x14, 0x1C, 0xBF, 0xDE, 0x94, 0xA1,
|
||||
0xE3, 0x64, 0x7C, 0x59, 0x35, 0x1E, 0xF0, 0x3C, 0x1C, 0x44, 0x0D, 0xE8, 0x01, 0xBB, 0xE1, 0xD8,
|
||||
0x62, 0x34, 0x5F, 0xD5, 0xCF, 0xEB, 0x91, 0x8A, 0x0E, 0x7B, 0x5D, 0x82, 0x0D, 0xC1, 0xFD, 0x75,
|
||||
0x9E, 0x6D, 0x34, 0x57, 0x5E, 0xD0, 0x10, 0x3C, 0x24, 0x1D, 0xBE, 0x38, 0x06, 0xE1, 0x85, 0x12,
|
||||
0xCC, 0xEF, 0x5F, 0xBD, 0x1F, 0x57, 0x3D, 0x9F, 0x97, 0x64, 0x29, 0xBC, 0x8E, 0x9B, 0xF9, 0xE1,
|
||||
0x91, 0xDC, 0xF2, 0xBF, 0xB2, 0x2A, 0xC0, 0x3C, 0x06, 0x19, 0x9F, 0x51, 0x5C, 0xFB, 0x44, 0x70,
|
||||
0x6C, 0xBF, 0x4B, 0xFE, 0x42, 0xF9, 0x8F, 0x46, 0x1B, 0x10, 0x8B, 0xD1, 0xD1, 0xA6, 0xD9, 0x48,
|
||||
0x20, 0x7F, 0x6E, 0xB4, 0xF1, 0xD5, 0x80, 0x3C, 0x0C, 0x02, 0x64, 0x98, 0x35, 0x84, 0x11, 0xA0,
|
||||
0xD3, 0x00, 0x9F, 0xA0, 0x58, 0xA1, 0x49, 0xBD, 0x9B, 0x78, 0x76, 0x56, 0x19, 0x0C, 0xE2, 0x8E,
|
||||
0xC9, 0x0E, 0x14, 0x9A, 0x13, 0x60, 0x30, 0x3C, 0x20, 0x6E, 0x40, 0x68, 0x33, 0x11, 0x67, 0xFE,
|
||||
0x31, 0xF1, 0xD4, 0xF4, 0x37, 0xE4, 0x25, 0x23, 0xC8, 0x7B, 0xCB, 0x5C, 0xC3, 0xE1, 0xF7, 0xFE,
|
||||
0xCD, 0x7F, 0xCF, 0x72, 0x4E, 0xFF, 0x10, 0x3C, 0x4F, 0x7E, 0x0E, 0xE8, 0x67, 0xC6, 0xA5, 0xDE,
|
||||
0x14, 0xDE, 0xEF, 0xC7, 0x2B, 0x8C, 0x52, 0xDD, 0x16, 0x2E, 0xD8, 0x38, 0x00, 0x34, 0x59, 0xF6,
|
||||
0xD3, 0x87, 0xCA, 0xA0, 0x17, 0x76, 0x10, 0x3C, 0x44, 0xEA, 0x0B, 0x00, 0x7B, 0xC5, 0xF0, 0x1E,
|
||||
0x31, 0x8C, 0x48, 0xA0, 0x83, 0xE7, 0x4C, 0x2C, 0xCC, 0x12, 0x37, 0xA6, 0x04, 0x28, 0xA0, 0x65,
|
||||
0x30, 0x31, 0x42, 0x2A, 0xA3, 0x82, 0x60, 0x3C, 0x42, 0x4A, 0x13, 0x61, 0x80, 0x81, 0xF0, 0x9E,
|
||||
0x05, 0x86, 0xAF, 0x63, 0xCA, 0x35, 0x15, 0xDD, 0x56, 0xE3, 0xE3, 0x04, 0xA4, 0xCD, 0x23, 0x86,
|
||||
0x03, 0xAE, 0x71, 0xDB, 0xF7, 0xF8, 0xD0, 0x3C, 0x44, 0x4C, 0x11, 0x01, 0x86, 0xBE, 0x3D, 0xCF,
|
||||
0x11, 0x98, 0x8C, 0xCB, 0xF0, 0xA0, 0x0F, 0x11, 0xF0, 0x82, 0x40, 0x34, 0xFE, 0x30, 0x4C, 0x46,
|
||||
0x9C, 0x74, 0x14, 0x76, 0x34, 0x78, 0x50, 0x3C, 0x21, 0x7A, 0x16, 0xE9, 0x9B, 0xCC, 0x79, 0x7E,
|
||||
0x01, 0x92, 0xAF, 0xC0, 0x3C, 0x69, 0xC3, 0xF7, 0x7A, 0xFD, 0xCC, 0x53, 0x13, 0xC1, 0x52, 0x19,
|
||||
0xAB, 0xF7, 0x99, 0xC4, 0xB8, 0x4E, 0x50, 0x3C, 0x0E, 0x13, 0x87, 0x51, 0x9F, 0xAD, 0x68, 0xE9,
|
||||
0x77, 0x84, 0x42, 0x47, 0x21, 0xEC, 0xFB, 0x1B, 0x52, 0xCC, 0x72, 0x75, 0x56, 0x4E, 0xD8, 0xD2,
|
||||
0xB9, 0x3D, 0xD7, 0x63, 0x27, 0x15, 0xF0, 0x3C, 0x06, 0x14, 0x7D, 0x79, 0x9E, 0x76, 0x1E, 0x6D,
|
||||
0x32, 0x73, 0x7A, 0xE1, 0x4F, 0x99, 0xDB, 0xC5, 0x2D, 0x2F, 0xC6, 0x75, 0xD6, 0x27, 0x0C, 0x07,
|
||||
0xE0, 0x1C, 0x9D, 0x28, 0xE6, 0xD4, 0x70, 0x3C, 0x05, 0xFE, 0xAD, 0xA9, 0x9D, 0xBB, 0x1F, 0x9E,
|
||||
0x13, 0x9B, 0xE7, 0x82, 0x13, 0xE8, 0xED, 0x03, 0xEB, 0x0E, 0x1D, 0x36, 0xFA, 0x50, 0x9C, 0xE4,
|
||||
0xEC, 0x30, 0x00, 0xB2, 0x0D, 0xA6, 0x70, 0x3C, 0xE1, 0xDD, 0x06, 0xC2, 0xF3, 0x70, 0x0A, 0x76,
|
||||
0x88, 0x90, 0xAF, 0x8F, 0x4D, 0xB1, 0x07, 0x8F, 0x36, 0xA7, 0x6A, 0x83, 0x13, 0x18, 0x81, 0xC8,
|
||||
0x44, 0x4B, 0x63, 0x66, 0xD4, 0x6C, 0xF0, 0x3C, 0x53, 0xE5, 0x06, 0xC5, 0x52, 0x02, 0x1D, 0x1E,
|
||||
0x03, 0xA8, 0x0A, 0xDE, 0x13, 0xCB, 0xD0, 0x56, 0xBF, 0xB6, 0xC1, 0xE1, 0x78, 0xC8, 0x8F, 0xAC,
|
||||
0xD8, 0x7E, 0x8D, 0x38, 0x93, 0x9B, 0x30, 0x3C, 0xD1, 0xCD, 0x07, 0xD5, 0x64, 0xFA, 0xB9, 0x1E,
|
||||
0x02, 0xC1, 0x39, 0x0E, 0x1C, 0x03, 0x85, 0xE6, 0x4B, 0x87, 0x3B, 0x87, 0x79, 0x62, 0x5E, 0xD3,
|
||||
0x0E, 0xFA, 0x6E, 0xF9, 0x20, 0x32, 0xB0, 0x3C, 0xF3, 0xE6, 0xB4, 0xBE, 0xA2, 0x6A, 0x10, 0xFE,
|
||||
0x07, 0x1F, 0x97, 0xA8, 0x8F, 0x25, 0xA8, 0x36, 0x10, 0x8C, 0x81, 0x78, 0xDB, 0x31, 0xFD, 0xAA,
|
||||
0xC1, 0x3E, 0xEE, 0xA4, 0x2C, 0xA1, 0xC0, 0x3C, 0x28, 0x0E, 0x18, 0x48, 0x0C, 0x69, 0x17, 0x9E,
|
||||
0x17, 0x94, 0x73, 0xBD, 0xEC, 0x18, 0x07, 0xF6, 0xCB, 0xC2, 0xFD, 0x35, 0x82, 0x77, 0xD1, 0xF1,
|
||||
0xB7, 0x85, 0x90, 0x44, 0x4C, 0xD8, 0xA0, 0x3C, 0x46, 0x6D, 0x90, 0xE8, 0x19, 0x82, 0x79, 0xFA,
|
||||
0x4D, 0x81, 0xD9, 0xB9, 0x39, 0x3D, 0x28, 0x80, 0xC0, 0x2C, 0x5D, 0x9C, 0x0C, 0x5D, 0x66, 0x38,
|
||||
0xD0, 0x94, 0xBE, 0xEE, 0x18, 0xB3, 0x90, 0x3C, 0x35, 0x7A, 0x02, 0x50, 0x19, 0x91, 0x68, 0x89,
|
||||
0x77, 0x80, 0x1A, 0x3F, 0x26, 0x94, 0xBD, 0xE5, 0x4A, 0x83, 0x97, 0x9E, 0x9D, 0x93, 0x68, 0x3A,
|
||||
0x48, 0x9C, 0x5E, 0x54, 0xE0, 0x48, 0xB0, 0x3C, 0x30, 0x41, 0xAE, 0x58, 0x18, 0x4F, 0xE0, 0x58,
|
||||
0x66, 0xD5, 0x9E, 0x92, 0x53, 0x1C, 0x43, 0xF2, 0x8C, 0x6D, 0x03, 0x3B, 0xE0, 0x03, 0x0F, 0x00,
|
||||
0x84, 0x6A, 0x7A, 0x10, 0x26, 0x61, 0xE0, 0x3C, 0x1C, 0x44, 0x02, 0x50, 0x18, 0x04, 0x1F, 0xAB,
|
||||
0x54, 0x7F, 0xDF, 0xE8, 0xE7, 0xA8, 0x25, 0x93, 0x4A, 0x66, 0x8C, 0xFA, 0x0C, 0x34, 0xCF, 0xFC,
|
||||
0x05, 0x09, 0x80, 0xCB, 0x91, 0x39, 0xF0, 0x3C, 0x24, 0x54, 0x09, 0x10, 0x12, 0xE0, 0x01, 0xE1,
|
||||
0xF9, 0x85, 0xDB, 0x11, 0xA1, 0x5F, 0x52, 0x6C, 0xD3, 0xEC, 0x45, 0x77, 0x44, 0xB5, 0x64, 0x78,
|
||||
0x44, 0x6F, 0x89, 0x81, 0xE3, 0xAA, 0x30, 0x3C, 0x8A, 0xEB, 0x93, 0x65, 0x66, 0xD8, 0x2B, 0x87,
|
||||
0x91, 0x9A, 0xA3, 0x06, 0xFC, 0xB7, 0xD4, 0x3A, 0xA5, 0xDB, 0x74, 0x2F, 0x4C, 0x09, 0x70, 0x32,
|
||||
0xE8, 0x72, 0x63, 0xD7, 0x3D, 0x49, 0xD0, 0x3C, 0x28, 0x6C, 0x0F, 0x13, 0xF3, 0x28, 0x1D, 0xFA,
|
||||
0x54, 0x97, 0x7C, 0x62, 0x1A, 0x77, 0xBF, 0x35, 0xC0, 0x08, 0x68, 0xBC, 0xA1, 0x93, 0xA5, 0x44,
|
||||
0x6B, 0xE0, 0x4D, 0x3A, 0x71, 0x74, 0xA0, 0x3C, 0x8B, 0x2D, 0x8D, 0x55, 0xE1, 0xF4, 0x30, 0x96,
|
||||
0x9B, 0x87, 0x49, 0x7E, 0x1D, 0x0F, 0x01, 0x31, 0x4C, 0x8F, 0x1C, 0x19, 0x76, 0x58, 0x66, 0x57,
|
||||
0xEE, 0x02, 0x93, 0x2C, 0x37, 0xCF, 0x30, 0x3C, 0x68, 0x72, 0x21, 0x1C, 0x03, 0xAA, 0x01, 0xBE,
|
||||
0x01, 0x81, 0x4A, 0x71, 0xAF, 0xDB, 0x64, 0x4F, 0xD3, 0x31, 0x58, 0x2B, 0x71, 0x24, 0x8D, 0xD8,
|
||||
0x1B, 0x59, 0x12, 0x2C, 0x9C, 0x65, 0x80, 0x3C, 0xE4, 0x71, 0x93, 0x54, 0x34, 0x9A, 0x74, 0xDE,
|
||||
0x01, 0x88, 0xDF, 0xE7, 0x56, 0xBC, 0x18, 0xFE, 0xC8, 0xE2, 0xC9, 0x0B, 0x3E, 0x7A, 0xA2, 0x02,
|
||||
0xEC, 0x71, 0x3F, 0xDD, 0x9F, 0x09, 0x80, 0x3C, 0xF2, 0x5B, 0x7B, 0x18, 0x67, 0x8C, 0x3D, 0x1E,
|
||||
0x05, 0x6F, 0x5A, 0x1D, 0x0F, 0x96, 0xCA, 0x36, 0xDE, 0x18, 0x74, 0x7C, 0x16, 0xE0, 0x34, 0x9B,
|
||||
0x0F, 0x0B, 0x14, 0x5C, 0x92, 0x94, 0x90, 0x3C, 0xE0, 0x63, 0x88, 0x62, 0xEB, 0x3E, 0x20, 0x9E,
|
||||
0x07, 0x39, 0x3F, 0x9A, 0x24, 0xC9, 0x94, 0xD5, 0xA9, 0xEC, 0x1C, 0xC5, 0x22, 0x2E, 0xF5, 0x9E,
|
||||
0x9F, 0x03, 0x6E, 0xF7, 0xDC, 0x76, 0x20, 0x3C, 0x16, 0x62, 0x2D, 0x20, 0xD5, 0x96, 0x25, 0xDE,
|
||||
0x11, 0xA5, 0xB8, 0xE7, 0x13, 0x1A, 0xBF, 0x07, 0x8A, 0x59, 0xD4, 0x66, 0x7E, 0x64, 0xD4, 0xD1,
|
||||
0x92, 0x1B, 0xD4, 0xD5, 0x8C, 0x9E, 0x60, 0x3C, 0xE0, 0x68, 0x28, 0x0B, 0xAD, 0xDC, 0x12, 0x5E,
|
||||
0x05, 0xF4, 0x1A, 0xDF, 0x18, 0x00, 0xFC, 0x8B, 0x69, 0x18, 0xA1, 0x42, 0xC7, 0x9C, 0x17, 0x86,
|
||||
0x67, 0x40, 0x20, 0x47, 0xB7, 0x7B, 0x80, 0x3C, 0xD8, 0x56, 0x30, 0x49, 0xE3, 0x08, 0x5B, 0xDE,
|
||||
0x05, 0xA5, 0xA8, 0x08, 0x1D, 0x5D, 0xA4, 0x46, 0x1B, 0x0E, 0x29, 0x54, 0x2F, 0xE6, 0xF3, 0x03,
|
||||
0xDC, 0x04, 0x21, 0x18, 0x8D, 0x31, 0xE0, 0x3C, 0xE0, 0x5D, 0x64, 0x11, 0xF8, 0xB6, 0x1E, 0x9C,
|
||||
0x2B, 0xA5, 0xC8, 0x09, 0xE6, 0xB5, 0x5A, 0xF4, 0xED, 0x0A, 0xE2, 0x92, 0x2C, 0x4E, 0x9C, 0xCB,
|
||||
0xE0, 0x3A, 0x32, 0x4F, 0x8F, 0x57, 0x70, 0x3C, 0x1A, 0x47, 0x71, 0x1E, 0x00, 0xC4, 0x1E, 0xDE,
|
||||
0x00, 0xF5, 0x39, 0x1A, 0x94, 0xE7, 0xCB, 0xB2, 0x88, 0xF1, 0x38, 0x3E, 0x83, 0xE0, 0x6E, 0x01,
|
||||
0x9F, 0xE8, 0x37, 0xFD, 0x00, 0x74, 0x80, 0x3C, 0x08, 0x47, 0x6D, 0x14, 0xAE, 0xE0, 0x07, 0x8D,
|
||||
0x33, 0xAA, 0x47, 0x51, 0xE9, 0x90, 0x6C, 0x1C, 0x04, 0x5E, 0x81, 0xEF, 0x97, 0xA6, 0xD7, 0x09,
|
||||
0x50, 0xC5, 0x43, 0xAB, 0xF1, 0x78, 0xE0, 0x3C, 0x0C, 0x08, 0x4A, 0x1C, 0x20, 0xC6, 0x43, 0x01,
|
||||
0x6C, 0x28, 0xBA, 0x4E, 0x42, 0xCE, 0x89, 0x0A, 0xB7, 0x9E, 0x6D, 0x72, 0x13, 0xFF, 0xA1, 0xAB,
|
||||
0xF0, 0x73, 0xF8, 0x90, 0x98, 0x0C, 0xD0, 0x3C, 0x06, 0x1A, 0x85, 0x84, 0x8A, 0x12, 0x01, 0xC5,
|
||||
0x00, 0xAD, 0xDA, 0x09, 0x2B, 0xF9, 0xC9, 0xD6, 0xBC, 0xED, 0xC0, 0x7F, 0xFF, 0x80, 0x10, 0xC5,
|
||||
0xC0, 0xE5, 0xD1, 0xE7, 0xA0, 0x06, 0xD0,
|
||||
};
|
||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,283 @@
|
||||
//demo用于AIR600EAC云喇叭开发
|
||||
#include "common_api.h"
|
||||
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_audio_play_ec618.h"
|
||||
#include "luat_i2s_ec618.h"
|
||||
#include "ivTTSSDKID_all.h"
|
||||
#include "ivTTS.h"
|
||||
#include "amr_alipay_data.h"
|
||||
#include "amr_2_data.h"
|
||||
#include "amr_10_data.h"
|
||||
#include "amr_yuan_data.h"
|
||||
#include "power_audio.h"
|
||||
#include "luat_gpio.h"
|
||||
#include "luat_debug.h"
|
||||
|
||||
#include "luat_spi.h"
|
||||
#include "sfud.h"
|
||||
|
||||
#include "soc_spi.h"
|
||||
#include "driver_gpio.h"
|
||||
|
||||
// 这里定义TTS数据在Flash上的起始地址
|
||||
// 因为很多demo都喜欢用0开始演示flash读写
|
||||
// 导致TTS的数据无意中就破坏掉了
|
||||
#define FLASH_TTS_ADDR (64 * 1024)
|
||||
// SPI 接在SPI0, 片选脚GPIO8
|
||||
// 注意, SPI0与UART2冲突
|
||||
#define FLASH_SPI_ID (0)
|
||||
#define FLASH_SPI_CS (8)
|
||||
#define FALSH_SPI_BR (25600000)
|
||||
|
||||
//AIR780E+TM8211开发板配置
|
||||
#define CODEC_PWR_PIN HAL_GPIO_12
|
||||
#define CODEC_PWR_PIN_ALT_FUN 4
|
||||
#define PA_PWR_PIN HAL_GPIO_25
|
||||
#define PA_PWR_PIN_ALT_FUN 0
|
||||
#define LED2_PIN HAL_GPIO_24
|
||||
#define LED2_PIN_ALT_FUN 0
|
||||
#define LED3_PIN HAL_GPIO_23
|
||||
#define LED3_PIN_ALT_FUN 0
|
||||
#define LED4_PIN HAL_GPIO_27
|
||||
#define LED4_PIN_ALT_FUN 0
|
||||
#define CHARGE_EN_PIN HAL_GPIO_2
|
||||
#define CHARGE_EN_PIN_ALT_FUN 0
|
||||
|
||||
//AIR600EAC开发板配置
|
||||
//#define CODEC_PWR_PIN HAL_GPIO_12
|
||||
//#define CODEC_PWR_PIN_ALT_FUN 4
|
||||
//#define PA_PWR_PIN HAL_GPIO_10
|
||||
//#define PA_PWR_PIN_ALT_FUN 0
|
||||
//#define CODEC_PWR_PIN HAL_GPIO_12
|
||||
//#define CODEC_PWR_PIN_ALT_FUN 4
|
||||
//#define PA_PWR_PIN HAL_GPIO_10
|
||||
//#define PA_PWR_PIN_ALT_FUN 0
|
||||
//#define LED2_PIN HAL_GPIO_26
|
||||
//#define LED2_PIN_ALT_FUN 0
|
||||
//#define LED3_PIN HAL_GPIO_27
|
||||
//#define LED3_PIN_ALT_FUN 0
|
||||
//#define LED4_PIN HAL_GPIO_20
|
||||
//#define LED4_PIN_ALT_FUN 0
|
||||
//#define CHARGE_EN_PIN HAL_GPIO_NONE
|
||||
//#define CHARGE_EN_PIN_ALT_FUN 0
|
||||
|
||||
int luat_sfud_read(const sfud_flash* flash, uint8_t* buff, size_t offset, size_t len) {
|
||||
// return sfud_read(flash, offset, len, buff)==0?true:false;
|
||||
// 以下是SPI直接读
|
||||
GPIO_FastOutput(FLASH_SPI_CS, 0);
|
||||
offset += FLASH_TTS_ADDR;
|
||||
char cmd[4] = {0x03, offset >> 16, (offset >> 8) & 0xFF, offset & 0xFF};
|
||||
SPI_FastTransfer(FLASH_SPI_ID, cmd, cmd, 4);
|
||||
if (len >= 200) {
|
||||
SPI_BlockTransfer(FLASH_SPI_ID, buff, buff, len);
|
||||
}
|
||||
else {
|
||||
SPI_FastTransfer(FLASH_SPI_ID, buff, buff, len);
|
||||
}
|
||||
|
||||
GPIO_FastOutput(FLASH_SPI_CS, 1);
|
||||
// if (memcmp(buff, ivtts_16k + offset, len)) {
|
||||
// LUAT_DEBUG_PRINT("tts data NOT match %04X %04X", offset, len);
|
||||
// }
|
||||
return true;
|
||||
}
|
||||
|
||||
luat_spi_t sfud_spi_flash = {
|
||||
.id = FLASH_SPI_ID,
|
||||
.CPHA = 0,
|
||||
.CPOL = 0,
|
||||
.dataw = 8,
|
||||
.bit_dict = 0,
|
||||
.master = 1,
|
||||
.mode = 0,
|
||||
// .bandrate=13*1000*1000,
|
||||
.bandrate=FALSH_SPI_BR,
|
||||
.cs = FLASH_SPI_CS
|
||||
};
|
||||
|
||||
extern void download_file();
|
||||
static HANDLE g_s_delay_timer;
|
||||
|
||||
void app_pa_on(uint32_t arg)
|
||||
{
|
||||
luat_gpio_set(PA_PWR_PIN, 1);
|
||||
}
|
||||
|
||||
void audio_event_cb(uint32_t event, void *param)
|
||||
{
|
||||
// PadConfig_t pad_config;
|
||||
// GpioPinConfig_t gpio_config;
|
||||
|
||||
LUAT_DEBUG_PRINT("%d", event);
|
||||
switch(event)
|
||||
{
|
||||
case LUAT_MULTIMEDIA_CB_AUDIO_DECODE_START:
|
||||
luat_gpio_set(CODEC_PWR_PIN, 1);
|
||||
luat_audio_play_write_blank_raw(0, 6, 1);
|
||||
break;
|
||||
case LUAT_MULTIMEDIA_CB_AUDIO_OUTPUT_START:
|
||||
luat_rtos_timer_start(g_s_delay_timer, 200, 0, app_pa_on, NULL);
|
||||
break;
|
||||
case LUAT_MULTIMEDIA_CB_TTS_INIT:
|
||||
break;
|
||||
case LUAT_MULTIMEDIA_CB_TTS_DONE:
|
||||
if (!luat_audio_play_get_last_error(0))
|
||||
{
|
||||
luat_audio_play_write_blank_raw(0, 1, 0);
|
||||
}
|
||||
break;
|
||||
case LUAT_MULTIMEDIA_CB_AUDIO_DONE:
|
||||
luat_rtos_timer_stop(g_s_delay_timer);
|
||||
LUAT_DEBUG_PRINT("audio play done, result=%d!", luat_audio_play_get_last_error(0));
|
||||
luat_gpio_set(PA_PWR_PIN, 0);
|
||||
luat_gpio_set(CODEC_PWR_PIN, 0);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void audio_data_cb(uint8_t *data, uint32_t len, uint8_t bits, uint8_t channels)
|
||||
{
|
||||
//这里可以对音频数据进行软件音量缩放,或者直接清空来静音
|
||||
//软件音量缩放参考HAL_I2sSrcAdjustVolumn
|
||||
//LUAT_DEBUG_PRINT("%x,%d,%d,%d", data, len, bits, channels);
|
||||
}
|
||||
|
||||
ivBool tts_read_data(
|
||||
ivPointer pParameter, /* [in] user callback parameter */
|
||||
ivPointer pBuffer, /* [out] read resource buffer */
|
||||
ivResAddress iPos, /* [in] read start position */
|
||||
ivResSize nSize ) /* [in] read size */
|
||||
{
|
||||
LUAT_DEBUG_PRINT("%x,%d,%d", pParameter, iPos, nSize);
|
||||
memcpy((uint8_t *)pBuffer, (uint8_t *)pParameter + iPos, nSize);
|
||||
return ivTrue;
|
||||
}
|
||||
|
||||
static void demo_task(void *arg)
|
||||
{
|
||||
int re = -1;
|
||||
uint8_t data[8] = {0};
|
||||
luat_spi_setup(&sfud_spi_flash);
|
||||
|
||||
if (re = sfud_init()!=0){
|
||||
LUAT_DEBUG_PRINT("sfud_init error is %d\n", re);
|
||||
}
|
||||
const sfud_flash *flash = sfud_get_device_table();
|
||||
|
||||
// 第一次刷数据到spi flash才需要开启
|
||||
#if 0
|
||||
if (re = sfud_erase(flash, FLASH_TTS_ADDR, 719278)!=0){
|
||||
LUAT_DEBUG_PRINT("sfud_erase error is %d\n", re);
|
||||
}
|
||||
if (re = sfud_write(flash, FLASH_TTS_ADDR, 719278, ivtts_16k)!=0){
|
||||
LUAT_DEBUG_PRINT("sfud_write error is %d\n", re);
|
||||
}
|
||||
LUAT_DEBUG_PRINT("sfud_write ivtts_16k down\n");
|
||||
if (re = sfud_read(flash, FLASH_TTS_ADDR, 6, &data)!=0){
|
||||
LUAT_DEBUG_PRINT("sfud_read error is %d\n", re);
|
||||
}else{
|
||||
LUAT_DEBUG_PRINT("sfud_read 0x%02x 0x%02x 0x%02x 0x%02x 0x%02x 0x%02x\n", data[0], data[1], data[2], data[3], data[4], data[5]);
|
||||
}
|
||||
#else
|
||||
// 校验数据
|
||||
// char tmp = malloc(4096);
|
||||
// for (size_t i = 0; i < 719278; i+=4096)
|
||||
// {
|
||||
// // sfud_read(flash, i+FLASH_TTS_ADDR, 4096, tmp);
|
||||
// // if (memcmp(tmp, ivtts_16k + i, 4096)) {
|
||||
// // LUAT_DEBUG_PRINT("flash NOT match");
|
||||
// // break;
|
||||
// // }
|
||||
// }
|
||||
|
||||
#endif
|
||||
|
||||
// luat_rtos_task_sleep(3000);
|
||||
ivCStrA sdk_id = AISOUND_SDK_USERID_16K;
|
||||
//8K用下面的
|
||||
// ivCStrA sdk_id = AISOUND_SDK_USERID_8K;
|
||||
// char tts_string[] = "支付宝到账123.45元,微信收款9876.12元ABC支付宝到账123.45元,微信收款9876.12元ABC";
|
||||
char tts_string[] = "一二三四五六七八九十一二三四五六七八九十一二三四五六七八九十一二三四五六七八九十一二三四五六七八九十";
|
||||
luat_audio_play_info_t info[5];
|
||||
// slpManRegisterUsrdefinedBackupCb(before_sleep, NULL);
|
||||
// slpManRegisterUsrdefinedRestoreCb(after_sleep, NULL);
|
||||
// download_file();
|
||||
|
||||
luat_rtos_timer_create(&g_s_delay_timer);
|
||||
luat_audio_play_global_init(audio_event_cb, audio_data_cb, luat_audio_play_file_default_fun, luat_audio_play_tts_default_fun, NULL);
|
||||
// 外部flash版本
|
||||
luat_audio_play_tts_set_resource(flash, sdk_id, luat_sfud_read);
|
||||
|
||||
//使用ES7149/ES7148,用如下配置,如果不是,请根据实际情况配置,bus_id直接写0
|
||||
// luat_i2s_base_setup(0, I2S_MODE_I2S, I2S_FRAME_SIZE_16_16);
|
||||
// 如下配置可使用TM8211
|
||||
luat_i2s_base_setup(0, I2S_MODE_MSB, I2S_FRAME_SIZE_16_16);
|
||||
// memset(info, 0, sizeof(info));
|
||||
// info[0].path = "test1.mp3";
|
||||
// info[1].path = "test2.mp3";
|
||||
// info[2].path = "test3.mp3";
|
||||
// info[3].path = "test4.mp3";
|
||||
// luat_audio_play_multi_files(0, info, 4);
|
||||
// luat_gpio_set(8, 0);
|
||||
luat_rtos_task_sleep(9000);
|
||||
// require_lowpower_state(0);
|
||||
while(1)
|
||||
{
|
||||
|
||||
|
||||
// info[0].path = NULL;
|
||||
// info[0].address = (uint32_t)amr_alipay_data;
|
||||
// info[0].rom_data_len = sizeof(amr_alipay_data);
|
||||
// info[1].path = NULL;
|
||||
// info[1].address = (uint32_t)amr_2_data;
|
||||
// info[1].rom_data_len = sizeof(amr_2_data);
|
||||
// info[2].path = NULL;
|
||||
// info[2].address = (uint32_t)amr_10_data;
|
||||
// info[2].rom_data_len = sizeof(amr_10_data);
|
||||
// info[3].path = NULL;
|
||||
// info[3].address = (uint32_t)amr_2_data;
|
||||
// info[3].rom_data_len = sizeof(amr_2_data);
|
||||
// info[4].path = NULL;
|
||||
// info[4].address = (uint32_t)amr_yuan_data;
|
||||
// info[4].rom_data_len = sizeof(amr_yuan_data);
|
||||
// luat_audio_play_multi_files(0, info, 5);
|
||||
// luat_rtos_task_sleep(9000);
|
||||
luat_audio_play_tts_text(0, tts_string, sizeof(tts_string));
|
||||
luat_rtos_task_sleep(30000);
|
||||
|
||||
// info[0].path = NULL;
|
||||
// info[0].address = (uint32_t)Fqdqwer;
|
||||
// info[0].rom_data_len = sizeof(Fqdqwer);
|
||||
// audio_play_multi_files(0, info, 1);
|
||||
// vTaskDelay(20000);
|
||||
}
|
||||
}
|
||||
|
||||
static void test_audio_demo_init(void)
|
||||
{
|
||||
luat_gpio_cfg_t gpio_cfg;
|
||||
luat_gpio_set_default_cfg(&gpio_cfg);
|
||||
luat_rtos_task_handle task_handle;
|
||||
|
||||
//luat_debug_set_fault_mode(LUAT_DEBUG_FAULT_HANG);
|
||||
|
||||
gpio_cfg.pin = LED2_PIN;
|
||||
gpio_cfg.pull = LUAT_GPIO_DEFAULT;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.pin = LED3_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.pin = LED4_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.pin = CHARGE_EN_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.pin = PA_PWR_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.pin = CODEC_PWR_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.alt_fun = CODEC_PWR_PIN_ALT_FUN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
luat_rtos_task_create(&task_handle, 2048, 20, "test", demo_task, NULL, 0);
|
||||
}
|
||||
|
||||
INIT_TASK_EXPORT(test_audio_demo_init, "1");
|
||||
@@ -0,0 +1,865 @@
|
||||
#include "luat_fs.h"
|
||||
|
||||
// Download mp3 info the area of flash which is file system area
|
||||
const uint8_t batteryCharging[] = {
|
||||
0xFF,0xF3,0x28,0xC4,0x00,0x0D,0x10,0x02,0xC4,0xF7,0x40,0x10,0x00,0x98,0x1A,0x80,
|
||||
0x01,0x80,0x48,0x3D,0xAD,0x10,0xDE,0x7C,0x42,0x20,0x28,0xA5,0xA2,0xAD,0x88,0x0B,
|
||||
0x68,0x7E,0xBE,0x40,0x10,0x2E,0x20,0x89,0xC5,0x76,0xD2,0x18,0x08,0x9A,0x0F,0x80,
|
||||
0xC5,0x04,0xC0,0x30,0x8F,0x2E,0x84,0x75,0x20,0x9D,0xB4,0x67,0xFF,0x41,0xFF,0xFC,
|
||||
0xBA,0xD5,0xCA,0x7D,0x3D,0x60,0xC1,0xD4,0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x81,0xFA,
|
||||
0xC0,0x01,0x83,0x28,0x00,0x99,0x85,0xB4,0x2D,0x99,0xC7,0xAB,0xBB,0x9A,0x72,0x66,
|
||||
0x7C,0x4D,0xCB,0x5C,0xF5,0x17,0x99,0x8A,0x02,0x11,0x1C,0x4A,0x22,0x24,0x08,0x04,
|
||||
0x16,0x6B,0x94,0x82,0xC9,0x28,0x83,0xE5,0xAB,0x27,0xFF,0xB3,0x25,0x0C,0x9F,0xFF,
|
||||
0xFD,0x9F,0x12,0xDB,0xFF,0xFF,0xF2,0x9F,0x92,0xF5,0x54,0xE6,0x25,0xE1,0xF2,0x19,
|
||||
0xFF,0xF3,0x28,0xC4,0x07,0x0C,0x78,0xD2,0xBC,0x01,0xD3,0x78,0x01,0x14,0x02,0x34,
|
||||
0x21,0x29,0x22,0x5E,0x4D,0x9A,0xE6,0x2C,0xE1,0x86,0x00,0xEA,0x0A,0x5D,0x44,0xB9,
|
||||
0xA4,0x6A,0xE2,0xDE,0xB0,0x4E,0xF0,0x83,0xA5,0x19,0xA5,0x81,0x1A,0xB5,0xA3,0x7A,
|
||||
0x91,0x56,0xB2,0xEE,0x13,0xBF,0xB8,0xCA,0x96,0xF1,0xF8,0x1A,0xFF,0xFF,0x1F,0x80,
|
||||
0xA5,0xF5,0x2D,0x4B,0x3C,0x5A,0x16,0x80,0xFF,0xF3,0x28,0xC4,0x10,0x11,0x21,0x6E,
|
||||
0xD6,0x5E,0x6B,0x54,0x94,0x3B,0x9B,0xB9,0x61,0xF4,0x10,0x75,0x71,0xF8,0x25,0xCB,
|
||||
0x6A,0xF4,0x4D,0x5D,0xC0,0xC9,0x05,0xB8,0xBA,0x95,0x66,0x2C,0xA4,0x96,0x87,0x0C,
|
||||
0x83,0x77,0x33,0xFD,0x88,0x55,0x3F,0xF3,0x4F,0xFF,0xCE,0x24,0x3D,0xFE,0x67,0xFF,
|
||||
0xFF,0xFC,0x44,0xEB,0x32,0x27,0x7D,0x67,0x7E,0x9A,0x72,0x31,0x20,0x6A,0x49,0x24,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0D,0xE1,0x6E,0xE6,0x5F,0x4C,0x38,0x02,0x10,0x01,0x9D,
|
||||
0x3B,0x35,0xF5,0x9B,0xA7,0x66,0x43,0x49,0x6F,0xC8,0x66,0xCE,0xC5,0xF3,0xD3,0x37,
|
||||
0x31,0xC0,0xC0,0xAC,0x81,0xE9,0xF5,0x11,0x48,0x17,0xFF,0xC5,0x43,0x2B,0xFF,0x94,
|
||||
0x1B,0x9F,0xFF,0xDF,0xFF,0x41,0xD0,0xE7,0xFF,0x9C,0xFF,0xEB,0x11,0xF9,0x6A,0xC7,
|
||||
0xF2,0xD7,0x25,0x18,0x10,0x17,0x95,0x0A,0xFF,0xF3,0x28,0xC4,0x09,0x0E,0x90,0xF2,
|
||||
0xA0,0x01,0x9A,0x58,0x00,0x83,0x7C,0x1C,0x93,0x05,0x02,0x19,0x38,0x49,0x52,0xC1,
|
||||
0xD4,0xB8,0x72,0x83,0xF1,0xAB,0x4E,0x89,0xC7,0x61,0x63,0xED,0x8C,0x87,0x2A,0xE8,
|
||||
0xFB,0xFE,0x4C,0xEF,0xE5,0x16,0x55,0x4D,0xD7,0xA8,0xBF,0x64,0xFF,0x7A,0x8E,0xFE,
|
||||
0x18,0xFF,0xA8,0x30,0x73,0xE4,0x6A,0xC3,0xFB,0x9E,0x3F,0xCA,0xBE,0xAC,0x9F,0x24,
|
||||
0xFF,0xF3,0x28,0xC4,0x09,0x0F,0x0A,0x4A,0xC4,0x01,0x99,0x50,0x00,0xB7,0x10,0x33,
|
||||
0x08,0x7E,0x4E,0x75,0x97,0x80,0x5D,0x0F,0x4F,0x08,0x14,0xF4,0x38,0xA1,0x0A,0x22,
|
||||
0x12,0x35,0x82,0x06,0xDE,0xBF,0xC6,0x4D,0xAD,0xFF,0xF2,0xFD,0x5F,0xFF,0xFF,0xF7,
|
||||
0x53,0x9B,0xD3,0xA1,0xE7,0xE7,0xB7,0x2D,0xFF,0x4F,0xDD,0xBF,0xE4,0x69,0x28,0xF5,
|
||||
0xD5,0xFF,0x65,0x98,0x90,0x12,0x44,0x0C,0xFF,0xF3,0x28,0xC4,0x07,0x0E,0xF2,0x5A,
|
||||
0xC0,0x01,0xD4,0x68,0x00,0x43,0x11,0xC9,0x1C,0xD2,0xEA,0xD0,0x52,0xA8,0x4E,0x13,
|
||||
0x81,0xA9,0x82,0x00,0x83,0xFE,0xA5,0x92,0x63,0x8C,0xF7,0xFE,0x81,0x82,0x5F,0xFA,
|
||||
0x90,0x30,0x7F,0xFE,0x9A,0x3F,0xFA,0xD3,0x33,0x3D,0xFD,0xD0,0x42,0xA2,0x93,0x76,
|
||||
0xFD,0x32,0xF9,0x05,0xFF,0xD5,0xBF,0xFF,0xA8,0xC5,0xFD,0x48,0x4C,0x0D,0x0B,0x40,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x89,0xAA,0xD0,0x00,0x6B,0xC4,0x94,0xC8,0x00,0xC2,
|
||||
0x23,0xD7,0xFF,0x78,0x0F,0x18,0x0B,0xE1,0xE0,0x26,0x62,0x03,0x16,0xB9,0xA5,0x21,
|
||||
0xBF,0x7F,0x3B,0x1B,0x12,0xB6,0x48,0xDF,0xFD,0xD3,0xF3,0xA2,0x9B,0xFF,0xAF,0xFF,
|
||||
0xFF,0xFF,0xD1,0xA7,0x91,0x03,0x98,0x1A,0x0E,0x50,0x55,0xE4,0xD3,0xB5,0x1A,0x10,
|
||||
0x94,0x2A,0xFD,0x64,0xE0,0x07,0x81,0xA3,0xFF,0xF3,0x28,0xC4,0x06,0x0D,0x18,0x96,
|
||||
0xC8,0x00,0x6E,0x12,0x4C,0x17,0x35,0x3A,0x64,0xD9,0x7F,0xFD,0x49,0xF9,0x03,0xAD,
|
||||
0x11,0x04,0x4F,0x05,0x9B,0x8D,0xB6,0x2C,0x1A,0x10,0x86,0x50,0xA1,0x14,0xCC,0x24,
|
||||
0x2C,0x05,0x74,0xF7,0xFF,0xFE,0xE2,0x24,0x09,0x24,0x55,0x81,0x24,0x1E,0x0D,0x08,
|
||||
0x7F,0xA7,0xFD,0x55,0x37,0xFB,0x65,0xB6,0xD9,0x68,0x00,0x7B,0x06,0xA5,0x0E,0xA1,
|
||||
0xFF,0xF3,0x28,0xC4,0x0C,0x0C,0xD0,0x6E,0xED,0xBE,0x0B,0xD8,0x2A,0x1B,0xAD,0x62,
|
||||
0xE2,0x9A,0x5B,0x0A,0x49,0xC9,0x9F,0x77,0xF7,0xE2,0x84,0x0A,0x5E,0x75,0x2D,0xB1,
|
||||
0xCC,0x76,0xF5,0xB7,0x69,0xC0,0x27,0x2E,0x04,0x8E,0x90,0xA1,0xAB,0xBA,0x2C,0x71,
|
||||
0xE8,0xAA,0xCF,0xFA,0x55,0xFF,0x8C,0xD8,0xD8,0x08,0x4A,0x89,0xA3,0xAC,0xC0,0xB0,
|
||||
0xDC,0x12,0xC6,0x10,0x1E,0x53,0x49,0x48,0xFF,0xF3,0x28,0xC4,0x13,0x0F,0x91,0xAE,
|
||||
0xC8,0x00,0x58,0xC4,0x94,0xF7,0x9C,0xCF,0xA7,0x3F,0xFF,0xFF,0xFF,0xE7,0xA6,0xF9,
|
||||
0xEA,0xF7,0x20,0x76,0x72,0x33,0xAB,0x39,0x4B,0xA2,0xD2,0x72,0x30,0x73,0x28,0x41,
|
||||
0x9E,0x1B,0x32,0xE2,0x1D,0x60,0xE4,0x85,0x64,0xF5,0x85,0xC0,0x82,0x76,0x14,0x87,
|
||||
0xD5,0xF5,0xA8,0xE0,0xDD,0xE1,0xC3,0xA5,0x75,0xA8,0xCD,0x8A,0x6D,0xD8,0xAB,0x3C,
|
||||
0xFF,0xF3,0x28,0xC4,0x0F,0x0B,0xE0,0x8E,0xCC,0x00,0x16,0x1E,0x4C,0x87,0x72,0x87,
|
||||
0x84,0x11,0x59,0x4D,0x7F,0x4C,0x3C,0x52,0x38,0xC7,0xBB,0x57,0x20,0xFE,0xB1,0x1F,
|
||||
0x03,0x93,0x5A,0x43,0x4B,0x3B,0x46,0xAF,0xE2,0x22,0xA1,0xAF,0xF9,0x65,0x09,0x78,
|
||||
0x47,0xF2,0xA2,0x24,0x70,0x15,0xE1,0xCB,0x96,0xCE,0xD9,0xC7,0xF5,0x4B,0x19,0x41,
|
||||
0x08,0xFA,0x2F,0x38,0xD0,0xF5,0x6F,0xD7,0xFF,0xF3,0x28,0xC4,0x1A,0x0C,0xB0,0xDA,
|
||||
0xCC,0xCA,0x96,0x14,0x70,0xEE,0xEA,0x3B,0xC7,0x84,0x51,0x31,0xDA,0x24,0x7E,0x02,
|
||||
0x64,0xA6,0xFD,0x8F,0x24,0x7F,0x13,0xBB,0xFF,0xFF,0xFF,0xFF,0xFE,0x4D,0x01,0x8F,
|
||||
0xDF,0x5F,0x7E,0x00,0x1F,0x81,0xFA,0xCD,0xD5,0x07,0x09,0xF8,0xBA,0xB5,0xF5,0x6F,
|
||||
0xB6,0xC1,0x69,0x3D,0x9F,0xC5,0xF6,0xFF,0xE4,0x7C,0xC7,0x28,0xBF,0x69,0x30,0x1D,
|
||||
0xFF,0xF3,0x28,0xC4,0x22,0x0D,0x40,0xD6,0xEA,0x5E,0x6B,0xDA,0x70,0x20,0xB2,0x5D,
|
||||
0x4F,0xF3,0x23,0xDE,0x77,0xFF,0xFF,0xFF,0xFF,0xFF,0x06,0x8F,0x56,0x59,0xBE,0x14,
|
||||
0xD0,0x00,0xD6,0x9F,0xFE,0x38,0x03,0x81,0x7F,0xB2,0x85,0x62,0xF0,0x47,0x04,0x00,
|
||||
0xD5,0xE9,0x75,0x8F,0xA1,0x29,0x8F,0x3D,0xEF,0xE7,0xE2,0xAD,0xC5,0xF8,0x2C,0x97,
|
||||
0xE3,0xEB,0x31,0x7C,0x14,0xC1,0xC4,0x74,0xFF,0xF3,0x28,0xC4,0x28,0x0D,0x38,0xAE,
|
||||
0xD2,0x5E,0x1C,0xDE,0x4C,0xA5,0x4D,0xC2,0xFE,0xC7,0xFF,0xDF,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0x2A,0x10,0x17,0x1B,0x72,0xDA,0x00,0x02,0x81,0xD5,0x01,0xC5,0x60,0x82,0x88,
|
||||
0x4C,0x4D,0xB9,0xB7,0xAD,0xFF,0xE1,0x29,0x40,0xB1,0xE7,0x4C,0xCC,0xEE,0x78,0xE2,
|
||||
0x04,0x09,0x06,0x8F,0xE0,0x55,0xA4,0x42,0x87,0x36,0x08,0x9D,0xE7,0xBF,0xFF,0xFF,
|
||||
0xFF,0xF3,0x28,0xC4,0x2E,0x0C,0xC0,0x9A,0xDE,0x5E,0x13,0xD8,0x4E,0xFF,0xFF,0xFF,
|
||||
0xFF,0xEA,0x24,0x82,0xDF,0xA2,0x33,0xC2,0x96,0x20,0xA1,0xC8,0x80,0x96,0xC0,0x78,
|
||||
0x66,0x01,0x79,0x10,0x57,0x64,0xAA,0x99,0x16,0x43,0x2E,0x87,0xAA,0x6B,0xEB,0x45,
|
||||
0x4A,0x08,0x85,0xC3,0x57,0xFF,0xFB,0x4D,0x69,0xA6,0x8D,0x48,0x9B,0x7F,0xFF,0xE7,
|
||||
0xBC,0x8D,0x47,0x01,0xB4,0x02,0xAD,0xD2,0xFF,0xF3,0x28,0xC4,0x36,0x0B,0xE8,0xF2,
|
||||
0x90,0x38,0xA4,0xCE,0x70,0x48,0x79,0x86,0xB0,0xA8,0x19,0xBD,0x32,0xA0,0x52,0x61,
|
||||
0x8C,0x12,0x53,0x05,0x87,0xA9,0x58,0x68,0x2A,0x09,0xB9,0x43,0xCA,0x87,0x4E,0xB7,
|
||||
0xFB,0x38,0x57,0xA3,0xFF,0xFF,0xFF,0x4B,0x7A,0x3F,0xFE,0xBA,0x7F,0x52,0x4C,0x41,
|
||||
0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0x41,0x0B,0xA8,0x46,0x40,0x1E,0x4E,0x30,0x24,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0x4D,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0x88,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0xC3,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,0xAA,
|
||||
};
|
||||
|
||||
const uint8_t rebooting[]={
|
||||
|
||||
0xFF,0xF3,0x28,0xC4,0x00,0x0B,0xE0,0x06,0xB1,0x4D,0x40,0x10,0x00,0xE4,0x02,0x0E,
|
||||
0x0A,0x70,0x3F,0x0F,0x94,0x38,0x27,0x3E,0x0F,0xBC,0x10,0x58,0x60,0xBB,0xC8,0x14,
|
||||
0x38,0x27,0x86,0x14,0x70,0xBE,0xA7,0x17,0xF2,0xEF,0xDD,0xFE,0x20,0x70,0x20,0xEF,
|
||||
0x2E,0x0F,0x94,0x07,0xDF,0x5B,0xFF,0xD6,0x0F,0x9F,0xFF,0xFE,0x95,0xAF,0xEE,0xA5,
|
||||
0x4C,0x96,0xE2,0x38,0x13,0x80,0x35,0xC2,0xFF,0xF3,0x28,0xC4,0x0B,0x0F,0xF1,0xEE,
|
||||
0xDC,0x01,0x91,0x50,0x00,0x35,0x76,0x70,0x43,0x3D,0xD1,0x49,0xE6,0x67,0x93,0xE0,
|
||||
0xBA,0x16,0x8E,0xFD,0x3D,0x0D,0x5F,0xFF,0xD1,0x13,0xFF,0xFB,0x1A,0xF5,0x57,0x69,
|
||||
0x9C,0xF6,0x57,0x2F,0x5D,0x4E,0x3B,0xD7,0xCF,0x72,0x32,0x76,0x4A,0x13,0x0F,0x80,
|
||||
0x5C,0x9A,0xD7,0xFE,0x7D,0x49,0x29,0xEC,0x14,0xA9,0x20,0x7F,0xA7,0xF5,0xD6,0x66,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x89,0x62,0xC8,0xCB,0xD3,0x80,0x00,0x66,0x39,0x40,
|
||||
0x42,0x41,0x26,0x87,0xBA,0x42,0x20,0x82,0x0B,0x36,0x4E,0xC6,0x88,0x97,0x41,0xA4,
|
||||
0x1D,0x31,0x78,0xDB,0x6B,0x75,0x18,0x18,0x13,0xDF,0xFE,0xA7,0x45,0xBF,0xAF,0xBA,
|
||||
0x4E,0xEF,0xFB,0xBA,0x73,0x5F,0xE4,0x7F,0x13,0x3F,0xEB,0x77,0xFF,0xFF,0x9E,0x77,
|
||||
0xCA,0xAA,0x1E,0xF1,0xF2,0x0B,0x7F,0xF8,0xFF,0xF3,0x28,0xC4,0x06,0x0E,0xB8,0xDA,
|
||||
0xE6,0x5E,0x3B,0xCA,0x70,0xFF,0x81,0xF4,0xA9,0xA5,0xC4,0x60,0x05,0x5D,0x8E,0xA6,
|
||||
0x63,0xFD,0x50,0xCD,0x99,0x3D,0x7E,0x7B,0x53,0x42,0x1B,0x17,0xFF,0xFF,0x50,0x6F,
|
||||
0xFD,0x04,0x07,0x02,0xAE,0xD2,0x20,0x04,0x44,0x46,0xFB,0x96,0xE4,0x71,0x00,0x17,
|
||||
0xFF,0xA3,0xFF,0xFF,0x80,0x1B,0xFA,0x5C,0x3C,0x3B,0x20,0x26,0x03,0x92,0x49,0x24,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x81,0x06,0xBD,0xBF,0x53,0x38,0x00,0x00,0x7D,0x04,
|
||||
0x10,0x51,0x98,0xEB,0x0F,0x58,0x06,0xE8,0x45,0xCD,0x0F,0x9E,0x49,0x2B,0x27,0x59,
|
||||
0x40,0x47,0x41,0x70,0xC1,0x92,0x5F,0xDE,0x60,0xD8,0x96,0xFE,0x8B,0x1E,0x24,0x77,
|
||||
0xD0,0xF6,0x28,0x26,0x24,0x48,0xC2,0x37,0xFF,0x12,0xFF,0xF1,0xFD,0x1D,0xBF,0xFE,
|
||||
0x25,0xE6,0x5A,0x88,0xEB,0x4F,0xD0,0xE1,0xFF,0xF3,0x28,0xC4,0x07,0x0E,0x7A,0x4E,
|
||||
0xAC,0x01,0x98,0x10,0x00,0x62,0x30,0xDC,0xCD,0x90,0xF0,0xDA,0x90,0xF7,0x7A,0x3A,
|
||||
0xB1,0x5D,0x87,0x21,0x1F,0xF9,0x14,0xE7,0xE7,0xF6,0xA3,0x75,0xFF,0xFF,0x7F,0xFF,
|
||||
0xCE,0x77,0x57,0x9F,0xFF,0xFF,0x79,0x08,0xCE,0x46,0xFF,0xFF,0xFF,0x9C,0xE2,0x0E,
|
||||
0x03,0xE3,0x8C,0x1F,0xFF,0xFC,0xBF,0xD4,0xFE,0x2C,0xC8,0x70,0x90,0x08,0x20,0xCB,
|
||||
0xFF,0xF3,0x28,0xC4,0x08,0x0E,0x21,0xC2,0xD4,0x01,0x90,0x68,0x00,0x04,0x40,0x2F,
|
||||
0xA9,0x11,0x3D,0x51,0x50,0xC0,0x2C,0x59,0x01,0xA5,0x61,0x58,0x00,0xAC,0x50,0x67,
|
||||
0x48,0x6D,0x4D,0x84,0x8A,0x4E,0x0E,0x81,0xE6,0xAF,0x6D,0x0E,0xE8,0xFF,0xFE,0x83,
|
||||
0xFF,0xED,0x54,0xEA,0x5E,0x83,0xB2,0xBF,0xFF,0x43,0x97,0x0F,0x2E,0xAA,0x0C,0xBF,
|
||||
0x87,0xF7,0x74,0x86,0x60,0xF6,0x3C,0x59,0xFF,0xF3,0x28,0xC4,0x0A,0x0E,0x59,0x72,
|
||||
0xE0,0xCB,0xCD,0x50,0x02,0x4A,0xF3,0xA3,0x8C,0x59,0x0F,0x23,0x67,0x7A,0xC7,0x84,
|
||||
0x22,0xD0,0x0C,0x02,0x11,0x37,0xCC,0x30,0x54,0x25,0x1E,0xB7,0xF3,0x18,0xEF,0xF5,
|
||||
0xB2,0x7F,0xDD,0x7E,0x8C,0xA7,0x98,0x61,0x30,0x70,0x4F,0x0F,0x1A,0x54,0xDE,0x05,
|
||||
0x2C,0xC6,0xC5,0xBD,0x35,0x2B,0x67,0x87,0xF3,0x02,0xE0,0xC7,0x86,0xDC,0x4F,0x23,
|
||||
0xFF,0xF3,0x28,0xC4,0x0B,0x0D,0x11,0x7A,0xDC,0xCB,0x50,0x50,0x00,0xD3,0x4C,0x98,
|
||||
0x16,0x60,0x8E,0x49,0x93,0x55,0x7B,0x9A,0x16,0xC0,0x12,0x05,0x51,0xC7,0xF9,0x85,
|
||||
0xC8,0x4D,0x4F,0xFF,0xFF,0xFF,0xFF,0xAC,0xE3,0x90,0xEE,0x79,0x43,0x41,0x23,0xD5,
|
||||
0x13,0x2B,0xC8,0x78,0xB5,0x1A,0xD5,0xDE,0x5F,0x53,0xF6,0x22,0x60,0x90,0x4B,0xCD,
|
||||
0x5B,0xB6,0xEA,0xA7,0x7D,0xB7,0xD7,0x3F,0xFF,0xF3,0x28,0xC4,0x11,0x11,0x61,0xFA,
|
||||
0xB4,0x01,0x98,0x90,0x00,0x03,0x78,0x18,0x4E,0x4C,0x9E,0x74,0xDE,0x3A,0x45,0xC2,
|
||||
0x68,0xFF,0x7D,0x07,0xDF,0xFF,0xA9,0x2A,0x97,0xFF,0xFA,0x29,0x52,0x1C,0x9F,0xD6,
|
||||
0xFA,0xDF,0x3D,0x2F,0x15,0x90,0x75,0xA9,0xD7,0xAF,0xFB,0xFE,0x6A,0x55,0x4D,0x03,
|
||||
0x23,0xE0,0x57,0xDC,0x05,0x09,0xA7,0xFF,0xAA,0xA5,0xAA,0x91,0x66,0x77,0xA6,0x3F,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x41,0xB6,0xD0,0x01,0x82,0x28,0x00,0xB1,0xA3,0x45,
|
||||
0x76,0x61,0xC8,0x45,0xD5,0x3C,0xE4,0x9E,0x63,0x7F,0xA6,0xF7,0xED,0x35,0x6C,0xE2,
|
||||
0x68,0xA2,0xF8,0xB9,0x42,0x25,0x0A,0x04,0x9A,0x10,0x63,0x28,0xAC,0xCF,0x9D,0xC9,
|
||||
0x9D,0x4C,0x82,0x86,0x15,0x30,0xE4,0x91,0x3D,0x4F,0xFB,0x77,0x7F,0xFF,0xEB,0x16,
|
||||
0xFE,0x36,0x74,0x54,0xA5,0x98,0x6B,0xB9,0xFF,0xF3,0x28,0xC4,0x08,0x0B,0xF1,0x16,
|
||||
0xB0,0x01,0xC6,0x30,0x00,0x4F,0xB5,0xCD,0xDB,0x28,0xE2,0xD0,0x98,0xDD,0x8B,0xDF,
|
||||
0xF6,0xED,0x8F,0xD9,0x3F,0x39,0xEC,0xF0,0xD0,0xED,0x07,0xA7,0xC8,0x13,0x1E,0x64,
|
||||
0x93,0x97,0x63,0xC8,0xE1,0xC7,0x88,0x81,0xA0,0xED,0xCB,0xD5,0xA9,0xFF,0xFD,0x54,
|
||||
0x89,0xC0,0x40,0x9B,0x9D,0xC6,0xC8,0x59,0x3D,0x6A,0xC7,0x5C,0x1E,0x09,0xF6,0x68,
|
||||
0xFF,0xF3,0x28,0xC4,0x13,0x0C,0x68,0xF6,0xB0,0x00,0xC3,0xCC,0x71,0xFA,0xB9,0xB8,
|
||||
0x2D,0x87,0x02,0x9D,0xFB,0xCD,0xAE,0x28,0x86,0x30,0x4C,0xF4,0xC5,0x3E,0x54,0xB8,
|
||||
0xBD,0xB8,0x26,0x94,0x3F,0xF5,0xAF,0x30,0x49,0x22,0xE6,0x12,0xF1,0xB3,0x03,0x00,
|
||||
0xFE,0xFF,0x2D,0xC7,0x12,0x54,0x0E,0x52,0x04,0xDF,0xBB,0x17,0xAB,0x2D,0x10,0xEB,
|
||||
0x11,0x19,0xD6,0xA5,0xFE,0x4C,0xB1,0x60,0xFF,0xF3,0x28,0xC4,0x1C,0x0C,0x98,0xBE,
|
||||
0xBD,0x90,0xCE,0x18,0x4C,0x36,0x3B,0x19,0x42,0x7A,0xE9,0xB9,0xC9,0xCD,0x72,0x65,
|
||||
0xC5,0xAB,0x6B,0xB4,0x3F,0x30,0xE7,0x5E,0xF7,0x07,0x32,0x95,0x03,0x32,0x3B,0xC0,
|
||||
0xFF,0xFF,0xDD,0xC8,0x2D,0x35,0x43,0x2E,0x5E,0x04,0x80,0x86,0x71,0x94,0xE8,0xB6,
|
||||
0x05,0xD8,0x6A,0x14,0x71,0xFB,0xD5,0x94,0xF2,0xBD,0x39,0x16,0x99,0xAE,0xAD,0x90,
|
||||
0xFF,0xF3,0x28,0xC4,0x24,0x0C,0xE0,0xC6,0xC5,0x90,0xC3,0xC6,0x71,0x8A,0x64,0xA4,
|
||||
0xDA,0xAB,0x1B,0x06,0x31,0x25,0x6D,0xBB,0xB5,0xB1,0x00,0x1F,0xB5,0xFD,0xE1,0xBD,
|
||||
0x63,0x52,0x1F,0x33,0x39,0x3D,0xAD,0x04,0xC6,0x86,0x07,0x9E,0xFC,0x2F,0xD7,0x88,
|
||||
0x0F,0x48,0x37,0x95,0x31,0xF1,0xF3,0x44,0xF2,0x75,0x52,0xFA,0x2C,0xE6,0x0F,0x2D,
|
||||
0xC2,0xDD,0xA8,0xD5,0x9E,0xF8,0x18,0xF7,0xFF,0xF3,0x28,0xC4,0x2B,0x0C,0xA0,0x82,
|
||||
0xA8,0x00,0xCE,0x9E,0x48,0xB0,0x97,0xDE,0x2B,0x38,0x18,0x7E,0x95,0xFF,0xEF,0xEE,
|
||||
0xAF,0x9B,0x04,0x94,0xD0,0x2C,0x52,0xE3,0xDB,0x35,0x61,0x4F,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xF4,0x44,0xB4,0xE7,0x56,0xFF,0xFF,0xF4,0x4D,0x73,
|
||||
0x9C,0xE7,0x74,0x21,0x0F,0xE4,0x64,0xFF,0x5E,0x4A,0xD1,0x9F,0x3F,0xC8,0x74,0x00,
|
||||
0xFF,0xF3,0x28,0xC4,0x33,0x0D,0x23,0x0A,0xB4,0x00,0x78,0x44,0xB8,0x10,0x45,0xFF,
|
||||
0xFF,0x9F,0xFF,0xFF,0xFF,0xFF,0xE4,0xD9,0x54,0xAB,0x90,0x9F,0xA6,0xE9,0xE5,0xD9,
|
||||
0xAC,0x88,0xCC,0x45,0x29,0x8E,0xE1,0x0C,0xA2,0xDD,0x0E,0xD5,0x7A,0x21,0x24,0x44,
|
||||
0x45,0x51,0x34,0x7A,0xCA,0x8F,0x04,0x98,0xE6,0x52,0x89,0x07,0x04,0x7A,0xFA,0xC8,
|
||||
0x0C,0x60,0x30,0x85,0x74,0xDD,0x91,0xE7,0xFF,0xF3,0x28,0xC4,0x39,0x0B,0xAB,0x0E,
|
||||
0xC0,0x00,0x08,0x04,0xB9,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFD,0x7F,0xFF,
|
||||
0x4B,0x39,0xBF,0xFF,0xAF,0x5E,0xCD,0x4C,0xDA,0x19,0x8E,0xA4,0x08,0xAA,0xC1,0x48,
|
||||
0xB5,0xD7,0x4F,0x7B,0x53,0x98,0xAD,0x04,0xA8,0x61,0xD9,0x22,0xB5,0xD5,0x7F,0x01,
|
||||
0xC7,0xC3,0xA9,0xC5,0x8C,0xBC,0x21,0x2D,0xC8,0x5B,0xC1,0x5C,0x2A,0x4C,0x65,0x4B,
|
||||
0xFF,0xF3,0x28,0xC4,0x45,0x0C,0x8A,0xFA,0xC4,0x00,0x10,0x44,0xB8,0xE6,0xA8,0x8F,
|
||||
0x00,0x67,0x3F,0xFF,0xFF,0xFF,0xFF,0xFD,0x0B,0x10,0x31,0xFF,0xFE,0xE8,0x5C,0x1A,
|
||||
0x7A,0xD5,0xF1,0xC0,0x94,0xEA,0x8F,0x00,0xE7,0x47,0x0A,0x80,0x08,0x85,0x28,0x79,
|
||||
0x9C,0x67,0x22,0x7D,0x5D,0x13,0x51,0xD8,0xEF,0xFF,0xFF,0xFF,0xFF,0xFE,0x93,0xA0,
|
||||
0xD8,0x22,0xEF,0xF7,0xFA,0x50,0x5C,0xE0,0xFF,0xF3,0x28,0xC4,0x4D,0x09,0x90,0x56,
|
||||
0xDC,0xCA,0x13,0xDE,0x26,0x98,0x77,0xF5,0xEB,0x81,0x01,0xE6,0x8C,0x01,0x09,0x40,
|
||||
0x6B,0x2C,0x8F,0xD7,0x4C,0xA2,0xC6,0x38,0x59,0x06,0xB5,0xC9,0x4E,0xA9,0x1F,0x64,
|
||||
0x76,0xFF,0xFF,0xFF,0xFF,0xFF,0xE9,0x40,0x99,0x22,0xA8,0xFF,0xF2,0x2F,0x26,0x2C,
|
||||
0x11,0x41,0x9F,0xB6,0xFA,0x95,0x40,0x79,0xFE,0x2D,0x0B,0x6D,0xCA,0x2C,0x9B,0xA7,
|
||||
0xFF,0xF3,0x28,0xC4,0x61,0x0A,0x80,0x5A,0xCC,0x00,0x3B,0xDE,0x24,0x0B,0xF0,0xBD,
|
||||
0x3C,0x53,0xA0,0xA3,0x40,0x17,0x12,0x16,0x89,0x3C,0xDF,0xFF,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0xFF,0xFF,0xFF,0xFF,0xCA,0xCA,0x02,0xFF,0x47,0xF2,0x2A,0xD4,0x48,0x2A,0x64,
|
||||
0xEF,0xFC,0xEA,0x15,0x06,0x02,0x00,0xD6,0x3A,0x0A,0x83,0x11,0x44,0x4F,0x8C,0x32,
|
||||
0x90,0x39,0x85,0x74,0xC0,0x43,0xD4,0x0A,0xFF,0xF3,0x28,0xC4,0x72,0x0B,0x10,0x66,
|
||||
0xC8,0xCA,0x2B,0xD8,0x28,0xF7,0x27,0xB0,0x23,0x99,0x72,0xBA,0xBF,0xFF,0xFF,0xFF,
|
||||
0xFF,0x85,0x45,0x04,0x8F,0xFF,0xFD,0x62,0x84,0xBF,0x5D,0x51,0x65,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0x80,0x0C,0x11,0xDA,0xB8,0x2A,0x79,0x44,0x94,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0x8A,0x0A,0xE0,0x5A,
|
||||
0x40,0x44,0x1B,0xDE,0x24,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0x99,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
};
|
||||
|
||||
const uint8_t serverConnecting[] = {
|
||||
|
||||
0xFF,0xF3,0x28,0xC4,0x00,0x0B,0xE0,0x02,0xE6,0x37,0x40,0x10,0x02,0x89,0x12,0x56,
|
||||
0xAF,0xE8,0x27,0xC1,0x73,0xE2,0x70,0x39,0xF2,0x05,0x0E,0x02,0x00,0xF8,0x3E,0x1F,
|
||||
0xA8,0xE1,0x05,0x4F,0x97,0x5B,0xF7,0x1C,0xFE,0x53,0xAF,0x89,0xFF,0x5F,0xF5,0x9F,
|
||||
0x28,0xEE,0x43,0xF8,0x63,0x87,0xFF,0xE5,0xDE,0x73,0x77,0xF9,0x75,0xAF,0xED,0x42,
|
||||
0xB4,0xD3,0x0B,0x56,0x05,0xB0,0xCE,0x41,0xFF,0xF3,0x28,0xC4,0x0B,0x0E,0xC1,0xF2,
|
||||
0xE0,0x01,0x90,0x38,0x00,0xDC,0x91,0xC2,0xE6,0x79,0xB3,0x59,0x63,0xE2,0x5E,0x22,
|
||||
0x03,0x7F,0xD9,0xFB,0xFF,0xFF,0xFF,0x45,0xB3,0xFA,0x8D,0xD9,0x3A,0x88,0x8E,0xDB,
|
||||
0xA9,0xA6,0x9E,0xAC,0xFF,0xF9,0x2F,0x39,0x8D,0x24,0xC2,0x07,0x81,0x4D,0xA9,0xAA,
|
||||
0xF9,0xCE,0x77,0x7B,0xE8,0x03,0x32,0xA5,0x62,0xED,0xAD,0xBB,0x01,0xFD,0xC9,0x9E,
|
||||
0xFF,0xF3,0x28,0xC4,0x0B,0x0F,0x89,0xE3,0x22,0x5F,0xC5,0x38,0x02,0x34,0x38,0x06,
|
||||
0x35,0x58,0xB5,0xB3,0xC7,0x00,0x60,0x94,0x77,0xFF,0x1C,0x34,0xDF,0xFE,0xC7,0xB3,
|
||||
0x7F,0xE6,0x2D,0x8D,0xB7,0xD5,0x63,0xE3,0xCA,0x35,0x22,0x8F,0xFD,0xDA,0x69,0xBF,
|
||||
0xF9,0x8A,0xC3,0xA4,0x5B,0xCC,0x80,0x80,0xAE,0xE5,0xFA,0x2B,0x7F,0xED,0x7F,0xCA,
|
||||
0x2A,0xFD,0x75,0x31,0xB1,0x38,0x1E,0xD8,0xFF,0xF3,0x28,0xC4,0x07,0x0E,0xC1,0x5A,
|
||||
0xBC,0x00,0xA4,0x84,0x94,0x18,0xB6,0x60,0x34,0xC4,0x88,0x26,0x83,0x54,0xEF,0x91,
|
||||
0xC2,0x78,0x00,0x98,0x26,0x08,0x32,0xFF,0xE9,0x95,0xCD,0x7F,0xF9,0xD0,0xDF,0xFA,
|
||||
0x33,0xFF,0xA2,0x10,0x38,0x18,0x00,0x10,0xA6,0xF0,0x40,0x16,0x1F,0xEB,0x58,0x2B,
|
||||
0xF5,0xCF,0x72,0x84,0x8B,0x1E,0xD6,0x4C,0x11,0x1A,0x80,0xB0,0x1F,0xED,0x37,0xFC,
|
||||
0xFF,0xF3,0x28,0xC4,0x07,0x0F,0x01,0x86,0xD6,0x5E,0x6A,0x04,0x94,0x01,0xF6,0x4D,
|
||||
0x59,0xC1,0x24,0x02,0xE4,0xBA,0x39,0x4C,0xBD,0x9F,0xFE,0x4A,0x05,0x40,0xD4,0x77,
|
||||
0xFD,0xF6,0x90,0x5A,0x34,0xAF,0xCF,0xC8,0xB3,0x4A,0x5F,0xF5,0x60,0xC0,0x42,0x9F,
|
||||
0xD1,0x9E,0xEA,0x53,0x2B,0x75,0xF4,0x7A,0x0A,0x7F,0x8B,0x7E,0x5B,0xF0,0x55,0xDF,
|
||||
0x22,0x1A,0x1A,0x01,0xEE,0xFF,0xFF,0xFF,0xFF,0xF3,0x28,0xC4,0x06,0x0E,0xA0,0xC2,
|
||||
0xDE,0x5F,0x46,0x18,0x00,0x1C,0x01,0xFF,0xF9,0xEB,0x4B,0xEC,0x0C,0x02,0xDF,0x46,
|
||||
0x95,0x1E,0x0C,0x30,0xA3,0xB7,0x12,0x14,0x11,0x11,0x08,0xCD,0xCE,0x9B,0xFB,0x98,
|
||||
0x70,0x38,0xD6,0x01,0x08,0x40,0xA1,0xD2,0x6D,0x52,0x97,0x5C,0xA0,0x20,0x88,0x62,
|
||||
0xA7,0x56,0xCC,0xBA,0xDE,0xD2,0x9F,0xFF,0xF9,0x2A,0xA5,0xE8,0x12,0x11,0x08,0xC0,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x39,0x6E,0xE0,0x01,0x8D,0x68,0x00,0xC0,0x13,0xC1,
|
||||
0x90,0x07,0x89,0xA1,0x1A,0x64,0x4A,0x14,0x23,0x50,0x1A,0x62,0xC0,0x25,0x89,0x44,
|
||||
0xD3,0x40,0xB1,0xD6,0x22,0xD4,0x98,0x82,0x12,0xE8,0x2B,0x9E,0xD2,0xB5,0x6D,0xFF,
|
||||
0xFF,0xAF,0xFA,0x1C,0xC0,0xDF,0xD0,0x36,0x7F,0xD3,0x45,0x94,0x59,0xFF,0xD1,0xD1,
|
||||
0x02,0xCA,0x13,0x8E,0x8B,0x6D,0x14,0x01,0xFF,0xF3,0x28,0xC4,0x08,0x0D,0x99,0x77,
|
||||
0x26,0x5F,0xCD,0x28,0x02,0xFB,0xA5,0x9B,0x85,0x38,0xF1,0x35,0xFE,0x80,0xF4,0x25,
|
||||
0x92,0x7F,0x9C,0xE1,0x30,0x08,0x5B,0xFA,0x87,0xC6,0xB7,0xFF,0xFE,0x88,0xCE,0x5F,
|
||||
0xD4,0xEE,0x47,0x31,0x8C,0x67,0x90,0x84,0x30,0xA8,0x93,0xF5,0x19,0x73,0xDF,0x2E,
|
||||
0x2B,0xFF,0xFD,0x6A,0xFD,0x13,0xA9,0x13,0x81,0x60,0x14,0xC8,0xF5,0x50,0x33,0x16,
|
||||
0xFF,0xF3,0x28,0xC4,0x0C,0x0D,0x21,0x86,0xD0,0x00,0x6C,0x04,0x94,0x78,0x68,0x65,
|
||||
0x44,0xBF,0x33,0x0F,0xCC,0x2C,0xF0,0x8F,0x93,0x65,0x5B,0xA6,0x6A,0x8F,0xFB,0x14,
|
||||
0xBF,0xCE,0x9F,0xF4,0x2F,0xF4,0x21,0x45,0x2B,0x59,0x64,0x08,0x00,0x1C,0x44,0x0A,
|
||||
0xD2,0x5E,0x79,0xFB,0x7E,0xAA,0x28,0x62,0x2A,0x96,0x20,0x3D,0x50,0xA8,0x98,0x17,
|
||||
0x84,0x30,0x2E,0x94,0x4D,0xF1,0x37,0x06,0xFF,0xF3,0x28,0xC4,0x12,0x0C,0x78,0xAE,
|
||||
0xD1,0x94,0x3B,0xC4,0x4C,0x13,0x7C,0x23,0xA7,0x0F,0x87,0x6D,0x27,0x29,0x05,0x15,
|
||||
0xBF,0x85,0x12,0xEE,0xAF,0x67,0xAC,0x35,0xD4,0x0D,0x1E,0xC2,0x41,0xD0,0x6B,0xD9,
|
||||
0xD6,0xDF,0xFF,0xFB,0x13,0xFA,0xA3,0x98,0x02,0x62,0x07,0x92,0xF6,0xC3,0x75,0x29,
|
||||
0x12,0x30,0xC8,0x44,0x50,0x1A,0x73,0x4A,0x94,0x5D,0xED,0x26,0x12,0x89,0x67,0x2C,
|
||||
0xFF,0xF3,0x28,0xC4,0x1B,0x0C,0xF8,0x7A,0xB4,0x00,0x9E,0x30,0x48,0xEC,0x6B,0xC9,
|
||||
0xF4,0x9C,0xEE,0xFF,0xFE,0xAE,0x36,0xD9,0x7E,0x0F,0xFD,0xAF,0xFF,0xD3,0x22,0x59,
|
||||
0x6E,0xFF,0xFE,0xE0,0x64,0x34,0x18,0xE9,0xC2,0x4C,0x06,0xF0,0x34,0x51,0xDA,0xD6,
|
||||
0x20,0x80,0xBE,0x03,0xE8,0x00,0xE8,0xA4,0xCF,0x5D,0x22,0xC7,0xAD,0x5D,0xA1,0x67,
|
||||
0x28,0x95,0x41,0x1C,0x4E,0xEF,0xD9,0xFF,0xFF,0xF3,0x28,0xC4,0x22,0x0B,0x28,0x66,
|
||||
0xC8,0xCA,0x03,0xDE,0x28,0xFF,0xF4,0x3D,0x00,0x40,0x88,0x5A,0x85,0xA3,0xFF,0x45,
|
||||
0xFC,0x95,0x01,0x90,0x21,0x0F,0x94,0x52,0x72,0x34,0x07,0x68,0x5C,0x99,0xBB,0xCB,
|
||||
0xA6,0x20,0x14,0x0B,0x19,0x6A,0xAC,0x8D,0x30,0x6F,0xA2,0x9F,0xD9,0xBE,0xAD,0xFA,
|
||||
0xFF,0xFF,0xFF,0xFF,0xFB,0xDF,0xD0,0xE4,0xE6,0x02,0x14,0x40,0xF8,0xB8,0x88,0x59,
|
||||
0xFF,0xF3,0x28,0xC4,0x30,0x0C,0xE1,0xC6,0xC4,0x00,0x94,0x04,0x94,0xDF,0xF5,0x54,
|
||||
0x85,0x15,0xD0,0xE9,0x96,0x80,0x05,0x14,0x01,0xD6,0x81,0x99,0x80,0x27,0xC1,0xDC,
|
||||
0x15,0xD0,0xE2,0x56,0xB0,0x06,0x82,0xE1,0x20,0xB6,0x71,0x51,0xA1,0xC4,0xDF,0x53,
|
||||
0x4D,0x67,0xE7,0x50,0xEF,0x9D,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFE,0xF4,0x74,0x62,
|
||||
0xB0,0x61,0x4F,0x6F,0xFF,0xA9,0x10,0x27,0xFF,0xF3,0x28,0xC4,0x37,0x0D,0x31,0xCB,
|
||||
0x06,0x5E,0x6A,0x84,0x96,0x1D,0xDA,0xED,0x86,0xDB,0x01,0xF7,0xA4,0x1D,0x83,0x91,
|
||||
0x7F,0xB9,0x73,0x52,0x98,0xAC,0x5C,0x17,0x5F,0xFC,0xC9,0x23,0x10,0xC8,0x8C,0x9C,
|
||||
0x4E,0x07,0x0F,0xEF,0x98,0x07,0xC1,0xF3,0xFD,0x05,0x0E,0x7F,0xFF,0xD2,0xC7,0x7F,
|
||||
0xFD,0xBF,0xFA,0x3F,0xFE,0x53,0x1A,0x41,0xFD,0xEF,0x99,0x65,0x2B,0x7E,0x0C,0x30,
|
||||
0xFF,0xF3,0x28,0xC4,0x3D,0x0D,0x30,0x7A,0xEE,0x5E,0x6E,0x10,0x4A,0x16,0x0B,0x0E,
|
||||
0x8B,0x76,0xB6,0xF1,0xFC,0x47,0x72,0xDC,0xA5,0x7B,0xCB,0xB7,0xCB,0xE8,0xF6,0xFF,
|
||||
0xBF,0xFF,0xFF,0xFF,0xFE,0xEC,0xBD,0xAE,0xA8,0xCB,0x53,0xE8,0x3A,0x45,0x7B,0xAF,
|
||||
0xFF,0x3D,0xC8,0xD6,0xAD,0xEC,0xE7,0x64,0xDC,0x94,0x66,0xA3,0x6A,0x62,0xF5,0x4D,
|
||||
0xA4,0xCE,0x20,0x2A,0xEC,0xA7,0x45,0x77,0xFF,0xF3,0x28,0xC4,0x43,0x13,0x1B,0x12,
|
||||
0xA4,0x00,0xC0,0x8A,0xB9,0x21,0xE8,0x2C,0x38,0xC3,0x42,0x83,0xA7,0x93,0x4A,0xFF,
|
||||
0xFF,0xCF,0xFF,0x09,0xB9,0x6B,0x8E,0x14,0x61,0xC9,0x0B,0xD5,0xD7,0x88,0x4E,0x53,
|
||||
0x90,0x30,0xC6,0x2E,0x0B,0x03,0x0E,0xCC,0xE9,0xF9,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
|
||||
0xC9,0xFF,0xC8,0xDF,0xC8,0x42,0x1E,0xAE,0x76,0x46,0xFF,0xFF,0xFD,0xE8,0xEA,0x17,
|
||||
0xFF,0xF3,0x28,0xC4,0x31,0x0D,0x2A,0x42,0xBC,0x00,0xC1,0xC4,0xB8,0xFF,0xFF,0xFC,
|
||||
0x95,0xFC,0xFA,0x96,0x91,0x64,0x10,0x10,0x01,0x48,0xA4,0xC1,0x5C,0xD4,0xC8,0xD8,
|
||||
0xF5,0x9E,0x16,0xA0,0x0B,0xB4,0x85,0xDF,0xF4,0x06,0xD3,0x7F,0xEA,0xFF,0xE9,0xFF,
|
||||
0xD7,0xFF,0xA9,0x9F,0xF4,0x38,0x87,0xB9,0xE9,0x9E,0x11,0x2B,0xFF,0xE5,0xFE,0x5F,
|
||||
0xEB,0x3F,0xFF,0xFF,0xF5,0xAA,0xFA,0x8C,0xFF,0xF3,0x28,0xC4,0x37,0x0D,0x09,0xEA,
|
||||
0xBC,0x00,0xA4,0xCE,0x98,0x8C,0x4D,0x89,0xA0,0xF8,0x00,0x59,0x50,0x7C,0xA5,0x66,
|
||||
0x53,0x22,0xEF,0x99,0x81,0x58,0x3E,0xC4,0xF6,0xC9,0x7A,0x88,0x61,0x11,0x6F,0xFF,
|
||||
0xFF,0xD7,0xFF,0xFF,0xF9,0x5B,0xFF,0x56,0xF5,0x2E,0x84,0x0A,0x06,0x6B,0x9C,0xB2,
|
||||
0xBF,0x43,0xE9,0xA1,0x01,0xDA,0xAA,0xFA,0x0D,0x8B,0x80,0xF3,0x04,0x8D,0x29,0x37,
|
||||
0xFF,0xF3,0x28,0xC4,0x3D,0x0C,0xD1,0xBE,0xBC,0x00,0xA4,0x0A,0x94,0x0D,0xD0,0x85,
|
||||
0x59,0xDE,0x39,0xD4,0xC6,0x8E,0x52,0x02,0xA1,0x50,0xE9,0xEB,0xD3,0xEE,0xD4,0xAA,
|
||||
0x7F,0x5F,0xD1,0x9C,0xFF,0x39,0xF4,0x7C,0x93,0x1F,0x44,0xAA,0x1D,0xC8,0xFA,0x1C,
|
||||
0x3B,0xF3,0xAD,0xD1,0xCE,0xBE,0x2F,0x5B,0x2E,0x8B,0x91,0x22,0x2C,0x4A,0xA3,0xE6,
|
||||
0x15,0x14,0x5A,0x07,0x01,0x89,0x17,0x49,0xFF,0xF3,0x28,0xC4,0x44,0x0B,0xF8,0x96,
|
||||
0xA8,0x00,0x3E,0x10,0x4C,0x6D,0x4B,0x56,0x5F,0x9B,0xBE,0xE5,0xBD,0x24,0x75,0x05,
|
||||
0x04,0x02,0x43,0x01,0x15,0x7B,0x89,0x0F,0x84,0x6A,0x6C,0xDE,0x74,0x95,0x66,0xA1,
|
||||
0xD4,0x8C,0xD0,0xD6,0x01,0xCA,0x65,0xC4,0x89,0x3E,0x38,0x60,0x5C,0x00,0x7D,0x81,
|
||||
0x75,0x18,0x38,0x25,0x0E,0xD4,0x28,0xC7,0x28,0xA9,0x18,0x12,0xC4,0xFF,0xEF,0xF7,
|
||||
0xFF,0xF3,0x28,0xC4,0x4F,0x14,0x19,0x4E,0xA4,0x00,0x7A,0x06,0x70,0xB9,0x6A,0x41,
|
||||
0xFF,0xC7,0xFE,0xBC,0x15,0x0D,0x9C,0x03,0x68,0x85,0x19,0x02,0x34,0x42,0x42,0xEC,
|
||||
0x5B,0x70,0x61,0x97,0xCA,0xBF,0xFB,0x19,0xA1,0x52,0xDE,0x9A,0xC4,0xA0,0x18,0x70,
|
||||
0x95,0x91,0x0E,0x04,0x0D,0xA1,0x26,0xC0,0x44,0x9C,0x64,0x08,0xD3,0xBE,0xE5,0xFF,
|
||||
0x5E,0x7A,0x5A,0xF0,0xD7,0xFE,0xBA,0xEC,0xFF,0xF3,0x28,0xC4,0x39,0x0D,0xE0,0xE2,
|
||||
0xC0,0xCA,0x4A,0x46,0x70,0xA4,0xC5,0x70,0x0E,0x88,0x33,0x4B,0x99,0xD6,0x97,0xCB,
|
||||
0x59,0xE9,0x8B,0x08,0x0A,0xA4,0x24,0xB8,0x8D,0x76,0x92,0x35,0xE1,0xC1,0x36,0x05,
|
||||
0xDB,0x62,0xB8,0x0B,0x32,0x3D,0x6A,0x3A,0xF3,0x70,0x51,0xE5,0xA6,0x42,0x80,0x40,
|
||||
0xAD,0x3A,0x2A,0xFA,0xC3,0x1E,0x02,0xEA,0x06,0xF0,0x40,0x13,0x14,0xDA,0x49,0xD3,
|
||||
0xFF,0xF3,0x28,0xC4,0x3C,0x0B,0x90,0xA6,0xBC,0x00,0x96,0x58,0x4C,0x92,0x73,0x14,
|
||||
0x23,0x50,0x85,0x78,0xFE,0x4E,0x7B,0xD2,0x21,0xAA,0xE4,0x31,0xC2,0xBA,0x2F,0xA5,
|
||||
0x69,0xC6,0xA4,0x64,0x81,0x8A,0xC1,0x9A,0xE7,0x22,0x5A,0x80,0x03,0xC0,0x3F,0x5F,
|
||||
0x87,0xD4,0x89,0x96,0xE4,0xD0,0xDC,0x1D,0x63,0xAB,0xAE,0x41,0x50,0xD8,0x10,0x93,
|
||||
0x10,0x13,0x89,0x93,0x88,0x08,0x62,0x7F,0xFF,0xF3,0x28,0xC4,0x48,0x0A,0xA0,0x9E,
|
||||
0xB4,0x00,0x9E,0x5E,0x4C,0x0B,0x2D,0x61,0xB0,0xA4,0x0C,0x38,0xB9,0x79,0x65,0x8A,
|
||||
0x36,0x79,0x4A,0x4C,0xD9,0xA7,0x82,0x08,0x8A,0x6D,0x3C,0x02,0x14,0x12,0xB7,0x6C,
|
||||
0x00,0x1B,0x01,0xFC,0xBC,0x0E,0x10,0x5A,0xDF,0xBE,0x90,0x23,0xE2,0x71,0xFA,0x41,
|
||||
0x44,0x0E,0x34,0x8B,0xA8,0xB3,0xD7,0xEC,0x47,0x78,0xB3,0xB3,0x78,0x17,0xDF,0xF0,
|
||||
0xFF,0xF3,0x28,0xC4,0x58,0x0C,0xC0,0xAA,0xA8,0xF0,0xCE,0x58,0x4D,0x18,0x16,0x7F,
|
||||
0x07,0xFD,0x9F,0xFF,0xFF,0xFF,0xFF,0xFE,0x2B,0xFF,0xF6,0xAE,0x11,0xFC,0xE1,0x14,
|
||||
0x04,0xA0,0xD8,0x90,0x7F,0xF2,0xAF,0x56,0xBB,0x2A,0x30,0xC9,0x8E,0x53,0xC3,0x50,
|
||||
0x15,0x4D,0x6A,0x6F,0xF6,0xA8,0x63,0xB8,0x24,0x5A,0xFA,0xCE,0x42,0xD0,0x90,0x0C,
|
||||
0x40,0x94,0x3F,0xBE,0x54,0x50,0x4B,0x58,0xFF,0xF3,0x28,0xC4,0x60,0x0D,0x40,0xC6,
|
||||
0xEA,0x5E,0x6B,0x5E,0x72,0xE5,0x04,0x47,0x81,0xFE,0x3F,0xF3,0xCF,0xE5,0x0D,0x20,
|
||||
0x28,0x11,0xA9,0xCA,0xB0,0x46,0x63,0x71,0x38,0xDC,0x2D,0x83,0x9B,0x6E,0x11,0x4A,
|
||||
0x9D,0x0E,0x14,0xB3,0x96,0x79,0xD7,0x6B,0x3F,0x9F,0x33,0x95,0x08,0xD4,0x2F,0x3D,
|
||||
0x48,0x2C,0x16,0x0D,0x33,0xF6,0xE3,0x8B,0x35,0x17,0xD6,0x64,0xC2,0x00,0x02,0x10,
|
||||
0xFF,0xF3,0x28,0xC4,0x66,0x0B,0xB8,0xC2,0xA8,0x00,0x96,0x98,0x4D,0x0F,0x09,0x50,
|
||||
0x5A,0x5C,0x88,0x2C,0xA1,0xC8,0x3B,0xDE,0x23,0x65,0x42,0x31,0xC4,0xD7,0x69,0x65,
|
||||
0x4F,0x18,0x68,0xB9,0x99,0x12,0xC3,0xB4,0xF7,0x27,0x41,0xC2,0x0A,0xE0,0x24,0x44,
|
||||
0xB2,0x49,0xD6,0x92,0x0A,0x32,0x65,0xD2,0x7B,0x3A,0xD9,0x5F,0xEE,0xC8,0x27,0x5B,
|
||||
0x24,0xBF,0xF7,0x64,0xFE,0x8D,0x66,0x3F,0xFF,0xF3,0x28,0xC4,0x72,0x0C,0xE8,0xDA,
|
||||
0xAC,0x29,0x59,0x48,0x00,0x14,0x48,0x94,0xEF,0xDE,0x5D,0x07,0xD4,0x11,0x11,0x67,
|
||||
0xBC,0xE7,0x97,0x28,0xE4,0x05,0x42,0xE2,0xF3,0xA2,0x5F,0xFF,0x01,0xA4,0xCA,0x96,
|
||||
0x52,0x0D,0x89,0x45,0xA0,0x50,0x28,0xB4,0x0A,0x2D,0xB6,0xDB,0x2C,0x60,0x0C,0xB7,
|
||||
0x6D,0xDC,0x71,0x5D,0x8E,0x4F,0xDD,0xC9,0xFE,0x77,0xA7,0xDA,0xD9,0xD0,0xC4,0xFF,
|
||||
0xFF,0xF3,0x28,0xC4,0x79,0x16,0x71,0x3A,0x78,0x13,0x9B,0x68,0x00,0xFC,0xAE,0x21,
|
||||
0xFF,0x3F,0x23,0x21,0xD1,0x48,0xC4,0x4F,0x6F,0xB9,0x11,0x5A,0xCE,0xA7,0x12,0x14,
|
||||
0x60,0xE8,0x30,0x06,0x21,0xFE,0xFC,0x84,0x53,0xB9,0x09,0x38,0xB9,0x62,0x66,0x17,
|
||||
0xB2,0xA9,0x8E,0x3C,0x82,0xD6,0x6C,0x9B,0x6A,0x4C,0x8C,0xD8,0x7C,0xEC,0x07,0x51,
|
||||
0x70,0x41,0x70,0xE5,0xD8,0xE2,0x6E,0xF1,0xFF,0xF3,0x28,0xC4,0x5A,0x18,0x2B,0x22,
|
||||
0xEE,0x5F,0x82,0x28,0x02,0x70,0x71,0x41,0x10,0x40,0xF8,0x25,0x1B,0x6D,0xB6,0xC3,
|
||||
0x6D,0xB6,0xD5,0xD1,0xE2,0x5C,0xD2,0xBA,0xD1,0x74,0x84,0xAA,0x5E,0xDB,0xF4,0xFF,
|
||||
0x2A,0x2A,0xF7,0xF5,0xF5,0x92,0xFB,0x77,0x7B,0xFD,0x4A,0xBA,0x3E,0x67,0x42,0x33,
|
||||
0x59,0x32,0xCE,0xE5,0x65,0x63,0xAA,0x80,0xE6,0x50,0xE5,0x05,0x81,0x91,0x55,0x8E,
|
||||
0xFF,0xF3,0x28,0xC4,0x34,0x16,0xC3,0x13,0x0E,0x5F,0xC2,0x28,0x03,0xA6,0x17,0x62,
|
||||
0x21,0x99,0x4C,0xA5,0xB9,0x81,0x0E,0x2A,0x2A,0x61,0x53,0x15,0xC5,0x81,0x14,0x84,
|
||||
0x15,0x0D,0x71,0x76,0x52,0x32,0xCC,0x95,0xB7,0xFF,0xA2,0xA3,0xEA,0xAA,0x47,0x2A,
|
||||
0xA3,0xA0,0xB6,0xE6,0x1A,0x39,0x76,0xDB,0x6D,0xAC,0x8D,0x81,0xD0,0x4E,0x51,0xDE,
|
||||
0x13,0xC2,0x1D,0x0D,0x49,0x43,0x6A,0x59,0xFF,0xF3,0x28,0xC4,0x14,0x0E,0x00,0x5F,
|
||||
0x0E,0x5E,0x08,0xC6,0x2A,0xE5,0x97,0x41,0x15,0x80,0x50,0xB7,0xFA,0x75,0xCE,0xCD,
|
||||
0x56,0x89,0x87,0xFB,0x16,0xB0,0x63,0xA6,0xB7,0x88,0x48,0x93,0x7F,0xEF,0xB6,0xE4,
|
||||
0xB8,0x68,0xAB,0x82,0x5F,0xFF,0xF9,0xE2,0xE8,0xFD,0xEB,0xBF,0xF9,0x46,0xD1,0xF0,
|
||||
0x31,0x0A,0x89,0x9C,0xCA,0x20,0x68,0x65,0xEA,0x5C,0x85,0xA4,0x09,0x10,0x94,0x9B,
|
||||
0xFF,0xF3,0x28,0xC4,0x17,0x0F,0xB2,0x56,0xC0,0x00,0xC3,0x44,0xB8,0x2F,0xE8,0x2F,
|
||||
0xE8,0x59,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0x4F,0xF4,0x6B,0x23,0x1C,0xEB,
|
||||
0x29,0xD0,0x89,0xCE,0xFF,0xDE,0xEF,0x46,0xAC,0xE0,0xC2,0xB8,0x44,0x61,0x1F,0xFF,
|
||||
0x2F,0x8D,0x53,0xD4,0x41,0xFF,0xFF,0xFA,0x8E,0x02,0x01,0x01,0x46,0x81,0x6B,0x52,
|
||||
0xB5,0xB5,0xDE,0x5F,0xF0,0x32,0x84,0xFC,0xFF,0xF3,0x28,0xC4,0x13,0x0C,0xC1,0xEE,
|
||||
0xC8,0x00,0xC3,0x44,0x98,0x64,0xA0,0x5C,0x2E,0x17,0x11,0x4B,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFE,0x8D,0x94,0xA5,0x65,0x12,0x59,0x61,0x6A,0xAA,
|
||||
0xEA,0x96,0x0D,0x21,0x29,0x81,0x01,0xE7,0xF8,0xED,0xE9,0xE5,0xF6,0x35,0xB6,0x32,
|
||||
0xE8,0x32,0xD6,0x42,0xB9,0x68,0xDF,0x6E,0x7E,0xCD,0x06,0x5D,0x46,0x6F,0xFF,0xFF,
|
||||
0xFF,0xF3,0x28,0xC4,0x1B,0x0B,0xC0,0x5E,0xCC,0xCB,0x4F,0x10,0x02,0xFF,0xFF,0xFF,
|
||||
0x4B,0x54,0x6C,0x4E,0x18,0x68,0xA5,0xAF,0x30,0xD6,0x23,0x59,0x00,0x12,0xFF,0xFF,
|
||||
0xE9,0x82,0x9A,0x96,0xDA,0xA7,0xE4,0x62,0x78,0x56,0x88,0x9E,0x80,0x69,0x9F,0x38,
|
||||
0x90,0x80,0xE1,0x64,0xA0,0x83,0xEA,0x89,0x64,0xD8,0x5A,0x0E,0x9C,0xE7,0xAE,0xFA,
|
||||
0x2F,0xAD,0x67,0x23,0xFF,0xA3,0xAF,0xFF,0xFF,0xF3,0x28,0xC4,0x27,0x15,0xEA,0xA6,
|
||||
0x8C,0x01,0x98,0x38,0x01,0xFF,0x9A,0xBE,0x94,0xFE,0xC9,0x44,0x38,0xE0,0x5A,0x22,
|
||||
0xBE,0x93,0x9C,0x77,0xFF,0x07,0x25,0x87,0x0A,0xCD,0x38,0xB9,0x54,0x07,0xC7,0x1A,
|
||||
0x44,0x74,0x6A,0x50,0x75,0x0E,0x52,0x85,0xCE,0xFF,0xF3,0x9B,0xD3,0x41,0xE2,0x8F,
|
||||
0x77,0xFF,0x0A,0x9C,0x68,0x22,0x00,0x6B,0x80,0xC0,0x7C,0x07,0xEC,0x71,0x22,0x56,
|
||||
0xFF,0xF3,0x28,0xC4,0x0A,0x0A,0x58,0x65,0xDC,0x7F,0xC6,0x08,0x00,0x0A,0x01,0x48,
|
||||
0xD4,0x58,0x91,0x2B,0x05,0x00,0xA4,0x69,0x14,0x58,0xEA,0x2A,0xFD,0x47,0xB9,0x6A,
|
||||
0x7F,0xFF,0xFF,0xC4,0xBF,0xFF,0xFF,0xFF,0xAC,0xEF,0xF9,0xD2,0xB5,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0x1B,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0x56,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0x91,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
};
|
||||
|
||||
const uint8_t serverConnectSucceed[] = {
|
||||
|
||||
0xFF,0xF3,0x28,0xC4,0x00,0x0B,0x00,0x02,0xB5,0x6F,0x41,0x10,0x02,0x59,0x52,0x10,
|
||||
0x13,0x83,0xEE,0x58,0xA2,0x8C,0xAC,0x81,0x7B,0x16,0x17,0x88,0x2A,0xCA,0x19,0x53,
|
||||
0x8F,0xEA,0x1A,0x3C,0xFF,0x1A,0x2B,0x13,0xBD,0x73,0x3D,0xEB,0x07,0xE5,0x2A,0xFF,
|
||||
0xCF,0xFF,0xBD,0x1A,0x7F,0xFD,0x4E,0xFF,0x90,0x9E,0x95,0x55,0xBB,0x5D,0xA0,0x8E,
|
||||
0xF7,0x74,0x4B,0x3F,0x3B,0x75,0x2F,0x6B,0xFF,0xF3,0x28,0xC4,0x0F,0x0E,0xB1,0x5E,
|
||||
0xC4,0x01,0x82,0x10,0x00,0x23,0x33,0x13,0x42,0x90,0x1A,0xD1,0x20,0xA8,0x93,0x9E,
|
||||
0x56,0x77,0x3A,0x59,0x5F,0x9D,0x79,0x61,0x85,0x17,0xB6,0x70,0xE3,0xA7,0xDE,0x69,
|
||||
0xDB,0x5A,0x52,0x89,0x6A,0x2E,0x04,0x62,0x77,0x20,0x54,0x73,0xFF,0xD7,0xA3,0xDF,
|
||||
0xA1,0xFF,0xE7,0xFC,0x73,0x70,0x15,0x63,0x8C,0xB9,0xA8,0xD9,0xE7,0xE5,0xF0,0xE5,
|
||||
0xFF,0xF3,0x28,0xC4,0x0F,0x0E,0xE8,0xCE,0xC0,0x01,0xCF,0x30,0x00,0x05,0x42,0x01,
|
||||
0xE7,0xA5,0x31,0xE0,0x05,0xA7,0xFE,0xF7,0x32,0x41,0x21,0xF9,0xE7,0xD4,0x6B,0x4E,
|
||||
0x32,0x4D,0x50,0x68,0x55,0xBA,0xD9,0x0D,0x2B,0x44,0xCB,0x8D,0x4B,0x3E,0x49,0x2B,
|
||||
0x1A,0x64,0x51,0xBD,0x5E,0xEF,0xD5,0xFD,0x7F,0x5A,0xA0,0x04,0x92,0x88,0x20,0x1F,
|
||||
0xBA,0x9C,0x7C,0x00,0xBC,0x62,0x34,0x9A,0xFF,0xF3,0x28,0xC4,0x0E,0x10,0x78,0xA2,
|
||||
0xBD,0x94,0x6E,0x5E,0x4C,0x95,0xF1,0xA5,0xA5,0x9A,0x88,0x08,0x91,0x39,0xF3,0x16,
|
||||
0x01,0x5B,0x65,0x2C,0xB0,0x62,0xF6,0xE2,0xD8,0x1A,0x67,0x1A,0x6D,0x5D,0x09,0x89,
|
||||
0xC9,0x72,0x6B,0x02,0x20,0x91,0xA7,0xCA,0x80,0x80,0xC0,0xC2,0xCB,0x0F,0xA1,0xE8,
|
||||
0x5F,0xFF,0x7F,0xFF,0xFF,0xFF,0xA7,0xC5,0xD7,0x41,0x10,0x23,0xFA,0x0C,0xC6,0xC0,
|
||||
0xFF,0xF3,0x28,0xC4,0x07,0x0E,0x80,0xB2,0xB4,0xCA,0x56,0x5E,0x4C,0x12,0x4A,0xA0,
|
||||
0x79,0xAC,0xEA,0x04,0xB7,0xBE,0x53,0xAE,0x91,0x01,0xE7,0x26,0x26,0xB2,0x8F,0x8A,
|
||||
0x41,0x19,0x7D,0x5B,0x0D,0x64,0xA4,0x6E,0x08,0xF8,0x99,0xC6,0x81,0x67,0xA9,0x23,
|
||||
0x29,0x44,0xB4,0xE9,0xFC,0x77,0xC1,0xAF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xE9,
|
||||
0x0C,0x08,0xC0,0x06,0x50,0x00,0xB2,0x81,0xFF,0xF3,0x28,0xC4,0x08,0x0F,0x30,0xC2,
|
||||
0xE2,0x5E,0x0E,0x0E,0x4E,0xF7,0x8A,0xE3,0x4A,0x4A,0xF0,0x71,0xE3,0x9C,0xD7,0x39,
|
||||
0xFB,0xB9,0x0D,0x02,0x41,0x27,0xE8,0x70,0xF0,0x16,0x18,0xFC,0x78,0xE8,0xA8,0x68,
|
||||
0x37,0x77,0x40,0x20,0xD0,0xB7,0xFF,0xFF,0xFF,0xFF,0xFD,0x56,0x38,0xCB,0x3F,0xA4,
|
||||
0x24,0x3C,0x22,0x0E,0xC2,0xA4,0x8A,0x0B,0x8B,0xA1,0x24,0x28,0x5A,0x76,0x80,0x2D,
|
||||
0xFF,0xF3,0x28,0xC4,0x06,0x0E,0x20,0x92,0xD5,0xBE,0x13,0xDE,0x4E,0xA0,0x7D,0x41,
|
||||
0x93,0xE3,0x8F,0x91,0x5B,0xAF,0x4F,0x8C,0x65,0xE3,0x7A,0x24,0x8C,0xC4,0xFE,0x97,
|
||||
0xAE,0xE0,0x5E,0x6C,0x1C,0x61,0x48,0xEA,0x92,0xD5,0x02,0x62,0x71,0xA8,0x94,0x75,
|
||||
0xFF,0xFF,0xFF,0xFF,0xFC,0xD8,0x33,0xE9,0xFA,0x3A,0x56,0x93,0xD7,0x3D,0x31,0x65,
|
||||
0x10,0x03,0xA4,0x97,0xFE,0x00,0xFA,0x34,0xFF,0xF3,0x28,0xC4,0x08,0x0C,0xF8,0xD6,
|
||||
0xD6,0x58,0x6B,0xF0,0x71,0x11,0x61,0x03,0x01,0x34,0x63,0x57,0x70,0xF7,0x4B,0x35,
|
||||
0xB9,0x05,0x40,0x5E,0x99,0x57,0xD7,0xFF,0x3D,0x80,0xE4,0x50,0x02,0xA8,0xDA,0x53,
|
||||
0x8F,0x72,0x93,0x0E,0xDC,0xA2,0x76,0xDD,0xFB,0x12,0x9B,0xF8,0x7E,0xB9,0x5D,0xE4,
|
||||
0x76,0xB6,0x17,0x2B,0x92,0xDB,0x40,0xA0,0x01,0xC7,0xF1,0x66,0x96,0x40,0x05,0x34,
|
||||
0xFF,0xF3,0x28,0xC4,0x0F,0x0F,0x70,0xE7,0x02,0x5E,0x45,0x12,0x72,0xD1,0xF4,0x16,
|
||||
0x78,0x83,0x81,0x88,0x44,0x0D,0x8F,0x17,0x9F,0xEA,0x20,0x05,0xB3,0x55,0x9E,0x86,
|
||||
0x6C,0xFF,0x13,0x41,0x50,0x32,0xC0,0xA5,0x84,0x49,0xBB,0x5B,0x3C,0x4C,0xD3,0x3A,
|
||||
0x03,0x58,0x11,0x1A,0xC2,0xE0,0xF9,0xFF,0xFF,0xFF,0xFE,0x42,0x19,0x36,0xCD,0xDA,
|
||||
0xED,0xB6,0xDA,0x81,0xC1,0x39,0x72,0x81,0xFF,0xF3,0x28,0xC4,0x0C,0x0D,0x11,0x27,
|
||||
0x02,0x5E,0x11,0x84,0x72,0x01,0x1D,0x1F,0x5A,0xF8,0xE6,0xA3,0xD1,0x6D,0xFE,0xAB,
|
||||
0x83,0x0E,0x96,0xF8,0x63,0x3F,0xF4,0x35,0x17,0xFA,0xFF,0x94,0x29,0x9F,0xE7,0x79,
|
||||
0xBF,0xF8,0xDF,0xF1,0x70,0xD2,0x2F,0xB9,0x7A,0x19,0xFF,0xFF,0xE5,0x2A,0xED,0x0F,
|
||||
0x92,0xE4,0x16,0xE8,0x0B,0x3F,0xFF,0xFD,0x7F,0xFF,0xFF,0xFF,0xFD,0x3F,0xEB,0x4B,
|
||||
0xFF,0xF3,0x28,0xC4,0x12,0x10,0xD3,0x16,0xB4,0x00,0x08,0x4A,0xB9,0xEF,0x54,0x91,
|
||||
0xBF,0x57,0x23,0x32,0x96,0x8C,0xFA,0x9C,0x84,0x6E,0xC7,0x9E,0x46,0x1A,0x3F,0x44,
|
||||
0x53,0xA3,0x10,0x92,0x1E,0x74,0x64,0x64,0x6B,0x1E,0x4A,0x10,0x8D,0xD0,0xEA,0x66,
|
||||
0x39,0xC0,0x71,0x61,0x46,0x71,0x30,0x3C,0x8A,0x26,0x10,0x61,0x11,0x69,0xEA,0xF5,
|
||||
0xFF,0xCC,0x67,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xF3,0x28,0xC4,0x09,0x0D,0xA3,0x12,
|
||||
0xC8,0x00,0x08,0x4A,0xB9,0xFF,0xFF,0xFF,0xFF,0xAF,0xFF,0xDF,0x6A,0xB1,0x2A,0x8C,
|
||||
0x55,0xD3,0xEC,0xAF,0x22,0xF7,0x57,0x65,0x6A,0x88,0x87,0xC4,0xC0,0x48,0xB8,0x98,
|
||||
0xA4,0x82,0x8D,0xED,0xA3,0xF4,0x96,0x82,0xC9,0xF4,0x3A,0xD0,0x78,0xB2,0x8F,0x65,
|
||||
0x48,0x99,0x1A,0x3D,0x01,0x97,0xFF,0xD4,0xBD,0x05,0x80,0xF8,0x07,0x97,0xBE,0xE7,
|
||||
0xFF,0xF3,0x28,0xC4,0x0D,0x0C,0xE2,0x6E,0xD4,0xCA,0x58,0x44,0xB8,0xF7,0xFF,0xFF,
|
||||
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xEA,0xF3,0x53,0xB2,0xB5,0x9F,0xFE,0xF5,
|
||||
0xDC,0x8F,0x45,0x6E,0xEC,0xEC,0xA8,0x83,0x20,0x14,0x48,0xF6,0x7F,0x6F,0x26,0x5A,
|
||||
0x45,0x84,0x81,0x9A,0xFF,0xD7,0xE3,0x8D,0x5A,0x7A,0xD5,0xD0,0x98,0x52,0x6A,0x15,
|
||||
0x35,0xE8,0x78,0x4A,0x39,0xE6,0xA8,0xE0,0xFF,0xF3,0x28,0xC4,0x14,0x0D,0x09,0xD2,
|
||||
0xC0,0x00,0xC9,0xC4,0x94,0x38,0x19,0xFF,0xCC,0xFF,0xA3,0xB7,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0xFF,0xFF,0xFD,0xA3,0xB0,0x18,0x7A,0xAA,0xAB,0x16,0x4B,0x83,0x54,0x8B,0x82,
|
||||
0x2B,0x62,0xFF,0xFF,0xF4,0x55,0xAD,0x2A,0x9C,0x10,0xA4,0xEF,0xE6,0x5C,0xEB,0x63,
|
||||
0xAC,0xDE,0xCA,0xF9,0xCC,0xF1,0xC4,0xFA,0xDC,0x98,0x2B,0xC9,0x82,0x5F,0xEB,0xFF,
|
||||
0xFF,0xF3,0x28,0xC4,0x1A,0x0C,0xB0,0x62,0xB8,0x00,0x06,0x1E,0x28,0xFF,0xFF,0x36,
|
||||
0x28,0x16,0xA8,0xDA,0x9A,0xC2,0x28,0xBD,0x96,0x47,0x0B,0x04,0x81,0xD0,0xE1,0x62,
|
||||
0x34,0xE8,0xB1,0x17,0xE9,0xA5,0xF8,0x6D,0xA3,0x9C,0x8E,0xA6,0xB2,0x69,0xF5,0x2B,
|
||||
0x3A,0xE1,0x42,0x1B,0x81,0xCC,0x71,0x5C,0x06,0x17,0x0B,0x96,0x7E,0x05,0x11,0x7F,
|
||||
0xFF,0xFF,0xFF,0xB9,0xE2,0x04,0x52,0xA0,0xFF,0xF3,0x28,0xC4,0x22,0x0B,0xD8,0x5A,
|
||||
0xC0,0x00,0x06,0x1E,0x24,0xC9,0xC0,0x19,0xF4,0x10,0x5A,0x7B,0x56,0xE0,0x89,0x78,
|
||||
0x38,0x82,0x6A,0xFF,0xFD,0x37,0x9D,0x65,0xC0,0x18,0xC7,0x03,0xC3,0x7C,0xCB,0x27,
|
||||
0x83,0x44,0x9F,0x07,0x51,0x0A,0xA5,0xA1,0xDA,0x50,0x48,0xF7,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0x86,0x85,0xC7,0x99,0x4B,0x3F,0xD3,0x1E,0x1A,0x34,0x6C,0x7B,0x7F,0xA2,0x89,
|
||||
0xFF,0xF3,0x28,0xC4,0x2D,0x0A,0xF0,0x5E,0xC4,0x01,0x4F,0x10,0x00,0x41,0x19,0x4B,
|
||||
0xB3,0x7A,0x1A,0x6A,0x3F,0x2D,0x15,0x16,0x58,0x37,0x24,0x32,0x4C,0xEC,0xB4,0x48,
|
||||
0xA4,0xF2,0x41,0xE2,0x61,0x20,0x60,0x21,0x09,0x4D,0x07,0xC3,0x57,0x74,0x67,0x5E,
|
||||
0x72,0xFF,0xFF,0xE9,0x7F,0xFF,0x9F,0xFA,0xFF,0xFF,0x79,0xE7,0x98,0x68,0xD4,0xB5,
|
||||
0x7A,0x1C,0x36,0x2B,0xFF,0x2C,0x44,0xF3,0xFF,0xF3,0x28,0xC4,0x3C,0x16,0xA2,0x96,
|
||||
0x9C,0x01,0x98,0x38,0x00,0x07,0x09,0xBB,0x0D,0xC4,0x71,0x39,0x02,0x28,0xAD,0x34,
|
||||
0xD3,0x7A,0x58,0xB3,0xB1,0xBF,0x9A,0xAD,0x38,0x68,0x38,0x61,0x77,0xE7,0x84,0x47,
|
||||
0x84,0x42,0x59,0x6A,0xE4,0xDD,0x77,0x7F,0x4B,0x25,0xDF,0x64,0x90,0x12,0xB1,0x99,
|
||||
0xC6,0xBB,0x26,0x65,0xEE,0x85,0xD3,0x3D,0xCA,0x06,0x58,0xF3,0xEE,0xE2,0x40,0x0B,
|
||||
0xFF,0xF3,0x28,0xC4,0x1C,0x13,0x12,0x5A,0xA8,0x01,0x98,0x50,0x00,0x8D,0xDB,0xF8,
|
||||
0x96,0x21,0xE4,0xFF,0xF9,0xE6,0x13,0xFF,0xFE,0x93,0xCD,0x52,0x7F,0xFF,0xE7,0x98,
|
||||
0xAE,0x48,0x6F,0xFF,0xFE,0x50,0x92,0x40,0x48,0x37,0x20,0x24,0x26,0xDF,0xFF,0x7F,
|
||||
0xFC,0x90,0x90,0x78,0x3C,0x24,0x1E,0x38,0x54,0xD7,0xFF,0xFF,0x42,0x6A,0xFF,0xFD,
|
||||
0xFF,0xB3,0x89,0x7A,0xC7,0x86,0x16,0x64,0xFF,0xF3,0x28,0xC4,0x0A,0x0E,0x99,0xDE,
|
||||
0xD4,0x01,0x98,0x38,0x00,0x95,0x02,0xE1,0x49,0xDA,0xB5,0x20,0x12,0x86,0x8B,0x42,
|
||||
0x8C,0x78,0x1F,0x1D,0x07,0xA2,0xF5,0x2F,0x35,0x4C,0xA2,0x0B,0x69,0xFD,0xBD,0xFF,
|
||||
0xFF,0xD7,0xFF,0xFF,0xFE,0x8A,0x69,0xC6,0x3D,0x34,0xA6,0xDD,0xA8,0xEA,0x5D,0x95,
|
||||
0xBB,0x56,0xCD,0x56,0x25,0x55,0xFF,0xFF,0xD6,0x52,0xA1,0x1C,0x11,0x62,0x83,0x79,
|
||||
0xFF,0xF3,0x28,0xC4,0x0A,0x0E,0x81,0xBA,0xC8,0x01,0xD8,0x38,0x00,0x6F,0x51,0xE2,
|
||||
0xA9,0x60,0xD8,0xCD,0x34,0xBA,0x9B,0x29,0x28,0xC0,0xAC,0x63,0xFA,0x01,0x20,0x45,
|
||||
0x1B,0xC5,0x2F,0xF5,0x29,0xFA,0x9F,0xFD,0xFF,0x4F,0xFF,0xFF,0xFF,0xA2,0xA1,0x86,
|
||||
0x68,0x36,0x1E,0x67,0xC9,0x03,0x78,0x89,0xBA,0x10,0x97,0x96,0xE8,0x1A,0x6B,0x35,
|
||||
0x9B,0x6D,0x85,0xD8,0x01,0xF7,0x52,0x20,0xFF,0xF3,0x28,0xC4,0x0B,0x0D,0x38,0xA7,
|
||||
0x26,0x5E,0x54,0x16,0x4E,0x15,0x01,0xA0,0x9F,0x4B,0x54,0x81,0x1E,0x34,0x3A,0xD6,
|
||||
0xA4,0x18,0x95,0x13,0x2F,0xE1,0x25,0xCB,0x4F,0xC5,0xF2,0x8D,0x07,0x1F,0x22,0xEC,
|
||||
0x35,0xAF,0xDF,0xFF,0xFD,0x75,0x83,0x46,0xDC,0xF9,0xD3,0xD6,0x9E,0x6F,0xD2,0xFF,
|
||||
0xFF,0xCF,0x38,0x9C,0xF8,0x70,0x63,0x84,0xDC,0x39,0x5C,0x3F,0x97,0x30,0xBB,0x65,
|
||||
0xFF,0xF3,0x28,0xC4,0x11,0x0C,0x90,0x96,0xB4,0x01,0x5A,0x40,0x00,0x81,0x25,0xEC,
|
||||
0x73,0x98,0x63,0x72,0xDC,0x3B,0x24,0x05,0xA4,0x26,0xFB,0x48,0xA9,0xC1,0x5E,0x22,
|
||||
0x24,0xF8,0xB1,0xE7,0x7F,0xFF,0xFD,0xA2,0x22,0x4D,0x2C,0x1D,0x6D,0x83,0xAA,0x1B,
|
||||
0xED,0xF8,0x6D,0x8D,0x47,0xF7,0x97,0xF8,0x02,0x10,0x70,0x4F,0x0C,0x3D,0xFF,0x16,
|
||||
0xBD,0x6E,0x33,0xCF,0x0C,0x1C,0xEA,0x02,0xFF,0xF3,0x28,0xC4,0x19,0x12,0xC3,0x16,
|
||||
0xB4,0xCB,0x99,0x28,0x01,0x93,0x91,0x4E,0xC2,0x22,0xA8,0x23,0xEA,0xF3,0xD8,0xCA,
|
||||
0x86,0x4F,0x77,0xBF,0x47,0xA5,0xFF,0xFF,0xFF,0xFF,0xFF,0x45,0x35,0xBB,0xB9,0xD4,
|
||||
0x78,0xA7,0xFF,0xD7,0xFD,0x53,0xE4,0x33,0x48,0x55,0x27,0xFF,0xFF,0x7D,0xFA,0x76,
|
||||
0x8E,0x13,0x31,0xE8,0x73,0x0E,0x08,0xFA,0x17,0x59,0x70,0x36,0x00,0x04,0x40,0x7C,
|
||||
0xFF,0xF3,0x28,0xC4,0x09,0x0C,0xA1,0xD6,0xB8,0x01,0xCD,0x10,0x00,0x11,0xB3,0x72,
|
||||
0xFA,0x69,0xB7,0xAD,0x3F,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xEB,0xDE,
|
||||
0x9A,0x38,0xCF,0x45,0x7A,0x87,0xB8,0xB3,0xCB,0x1D,0x0A,0x34,0xE8,0xC2,0x5B,0xBF,
|
||||
0x2B,0xAD,0xC8,0x52,0x90,0x99,0x2A,0xFA,0xD2,0x5A,0xCC,0x89,0xA0,0x1E,0x00,0x0D,
|
||||
0xF0,0xD2,0x6C,0x59,0x22,0x24,0x96,0x87,0xFF,0xF3,0x28,0xC4,0x11,0x0C,0x91,0x9A,
|
||||
0xB8,0x00,0xA2,0x84,0x94,0x4E,0x42,0xA0,0x18,0x0D,0x83,0x43,0x15,0xFF,0x22,0x10,
|
||||
0x8D,0xFF,0x45,0xFF,0xEA,0xFF,0xFF,0xFF,0xFF,0xFA,0x28,0x00,0x85,0xE2,0xA4,0x0E,
|
||||
0x2E,0xA3,0x45,0x3F,0xEA,0x52,0xAA,0xFA,0x9F,0x51,0x98,0x88,0x01,0xA9,0x54,0x1C,
|
||||
0xC4,0xD4,0xB7,0xD2,0x7B,0x11,0x20,0x3D,0x9C,0xAE,0xB7,0xFA,0xAA,0x1C,0xB3,0x4F,
|
||||
0xFF,0xF3,0x28,0xC4,0x19,0x0D,0x01,0xFE,0xB8,0x00,0xA4,0xCE,0x98,0xFE,0x7F,0xFF,
|
||||
0xCC,0xFF,0xEA,0xFF,0xFA,0x0F,0x9F,0xFE,0xE2,0x30,0x09,0x09,0xDF,0xFB,0x31,0xAD,
|
||||
0xFF,0x43,0x9C,0xBF,0xB9,0xB6,0x76,0x13,0x3C,0x3F,0xF3,0xFF,0xC0,0x3C,0x08,0xDF,
|
||||
0x37,0x02,0x6A,0x22,0x5D,0x96,0xFD,0x7A,0xA5,0xA0,0x78,0x8F,0x67,0x6B,0x9E,0xFE,
|
||||
0xCA,0x49,0xAC,0xF8,0x6B,0xF7,0x7F,0x5E,0xFF,0xF3,0x28,0xC4,0x20,0x0C,0x68,0xA2,
|
||||
0xDD,0x94,0x0B,0x56,0x4C,0x2A,0x1D,0x42,0xC5,0x06,0xBD,0xAF,0x62,0x87,0x0D,0x0F,
|
||||
0x87,0x3C,0x2E,0x60,0xF9,0xC1,0x05,0x8E,0x41,0x7D,0x45,0x82,0x87,0x8D,0x86,0x8C,
|
||||
0xF8,0x8C,0x78,0xEF,0xF7,0x6F,0xFC,0x2E,0x16,0x0C,0xC1,0x32,0x65,0x0A,0x88,0x80,
|
||||
0xA0,0xB1,0xD0,0xA0,0xF0,0x90,0x50,0x0A,0x12,0x11,0x09,0x00,0x58,0x59,0xE1,0xA0,
|
||||
0xFF,0xF3,0x28,0xC4,0x29,0x0B,0xF0,0x06,0xC8,0x00,0x00,0x46,0x00,0xA8,0x08,0x90,
|
||||
0x49,0xAA,0xD2,0x49,0xEA,0xD0,0x10,0x05,0x02,0x30,0x0C,0x21,0x54,0x82,0x29,0x75,
|
||||
0x97,0xDF,0x7A,0xA5,0xE1,0xAC,0xF6,0xFE,0xB8,0x1B,0x36,0xC6,0xEE,0x35,0xF7,0xFD,
|
||||
0x39,0x1D,0x0E,0x85,0x30,0x89,0x19,0x97,0x42,0xDD,0xE5,0xB9,0xA5,0x32,0x8D,0x77,
|
||||
0xFF,0xFA,0xD9,0xA6,0xA5,0xF4,0x92,0x02,0xFF,0xF3,0x28,0xC4,0x34,0x0C,0x21,0x6A,
|
||||
0xBC,0x00,0x39,0x84,0x94,0x00,0x04,0x51,0x60,0x20,0xAC,0x9C,0x47,0xC0,0x30,0xDC,
|
||||
0xF6,0x95,0x4E,0x21,0x99,0x29,0x3A,0xF4,0xA6,0x60,0x30,0x4F,0x32,0x66,0x8B,0xB0,
|
||||
0x80,0x38,0x2D,0x76,0xE7,0x10,0xB6,0xEF,0x77,0xF3,0x73,0x61,0xEF,0xBD,0xDC,0xA6,
|
||||
0x62,0x40,0x77,0x2D,0xF4,0xCA,0x00,0x0B,0xA0,0x6E,0x61,0xB9,0xB9,0x14,0x49,0xBC,
|
||||
0xFF,0xF3,0x28,0xC4,0x3E,0x0C,0x71,0x02,0xC0,0x00,0x8B,0x0C,0x70,0x0C,0x2E,0x3F,
|
||||
0x34,0xC9,0x3D,0x8C,0xDB,0x8C,0x5C,0xFD,0x2E,0x2D,0xCA,0x2C,0xFF,0x20,0x08,0x92,
|
||||
0x5F,0xF7,0x00,0x91,0xCD,0xEF,0x25,0x7C,0xFF,0x9B,0x54,0xFE,0x54,0x0C,0x49,0x28,
|
||||
0x4D,0x82,0xBB,0xF8,0xFE,0x77,0x1B,0x50,0x0A,0xC1,0x14,0xAD,0x47,0xC8,0xDB,0x9F,
|
||||
0x22,0xA8,0x88,0x43,0xD6,0x57,0x12,0xDB,0xFF,0xF3,0x28,0xC4,0x47,0x0C,0xB8,0xFE,
|
||||
0xB4,0x00,0x9B,0xCC,0x71,0xFD,0xBA,0x95,0x2A,0xC0,0x01,0xC9,0xF7,0xE9,0x63,0x46,
|
||||
0x27,0xFF,0x59,0xEF,0x04,0x24,0x8D,0x4B,0x01,0x5E,0x65,0x46,0xB2,0x4F,0xAE,0x08,
|
||||
0x50,0x6B,0x96,0xDA,0x00,0x14,0x01,0xEA,0x59,0x80,0x7B,0x43,0xAC,0x02,0xAE,0x07,
|
||||
0xF8,0x6D,0xEB,0x21,0xA4,0x41,0xD1,0x51,0xD2,0x50,0xBC,0x91,0xB7,0xA0,0x10,0x14,
|
||||
0xFF,0xF3,0x28,0xC4,0x4F,0x0B,0x70,0x96,0xA0,0x00,0xD6,0x12,0x4C,0x92,0x94,0x4D,
|
||||
0xB1,0x50,0x54,0xC8,0x85,0xC5,0x9F,0x2A,0x0B,0x7F,0xFF,0xFF,0xFF,0xFF,0xBE,0x56,
|
||||
0x02,0x01,0x50,0x30,0x02,0x12,0x18,0x81,0x36,0x88,0x16,0x29,0x6A,0xC0,0x06,0x8B,
|
||||
0x14,0xAB,0x63,0x8F,0x93,0xF8,0xB8,0x1A,0xFA,0x44,0xF7,0xDE,0x77,0x10,0xCA,0x8F,
|
||||
0x16,0x60,0xB9,0x43,0xD7,0xD5,0xF0,0x6E,0xFF,0xF3,0x28,0xC4,0x5C,0x0C,0xF0,0x9A,
|
||||
0xDA,0x5F,0x54,0x10,0x02,0xF0,0xE1,0x00,0xD0,0x00,0xDC,0x7A,0xBE,0x16,0x8E,0x39,
|
||||
0x04,0x30,0x8A,0x8B,0x8F,0x7F,0xF8,0xA5,0xCB,0x04,0x40,0x76,0x19,0xBE,0xFD,0x7F,
|
||||
0xCD,0xD0,0x30,0xD7,0xF6,0xF9,0x4B,0xCE,0x4E,0xB7,0xFF,0xD3,0x76,0xBA,0xB2,0xBF,
|
||||
0xFA,0x6A,0x98,0x96,0x4D,0x4A,0xB0,0x89,0x3E,0xEC,0xF6,0x94,0xE9,0xC4,0x26,0x9F,
|
||||
0xFF,0xF3,0x28,0xC4,0x63,0x15,0x11,0x62,0x80,0xDD,0x9B,0x90,0x00,0xC5,0x2A,0x5D,
|
||||
0xE7,0x04,0x2A,0x42,0x78,0xC1,0xA8,0x50,0x91,0xED,0xD9,0x77,0x22,0x64,0x54,0x2E,
|
||||
0x10,0xC2,0xC1,0x4C,0x36,0x5C,0xC3,0x0B,0x9E,0x0C,0x0F,0x56,0x38,0xEE,0xC7,0x21,
|
||||
0xA4,0x9E,0x42,0xDB,0x68,0x5C,0xC9,0x10,0x3E,0xF4,0xC4,0x45,0xC1,0xA5,0x87,0x69,
|
||||
0x66,0x9D,0xBA,0xDF,0xC9,0x15,0x4B,0xB3,0xFF,0xF3,0x28,0xC4,0x49,0x16,0x98,0xEE,
|
||||
0xB0,0x01,0x98,0xD0,0x00,0xB9,0x81,0x40,0x44,0x45,0xB4,0xA1,0xC9,0xFF,0xFF,0xFF,
|
||||
0xFF,0xFF,0xB0,0x7B,0xFF,0xFD,0x15,0x90,0x02,0xD5,0x6B,0xFF,0xFB,0x60,0x15,0xCC,
|
||||
0x15,0xB1,0x99,0x98,0xC2,0x8F,0x34,0xE8,0x2D,0xEB,0x3C,0x44,0x04,0x70,0x1F,0x8B,
|
||||
0x10,0xF5,0x72,0x45,0x01,0x79,0x36,0xFB,0x8E,0x90,0x04,0xDA,0x4C,0xF4,0x6B,0xD6,
|
||||
0xFF,0xF3,0x28,0xC4,0x29,0x13,0x92,0xB2,0xF6,0x3F,0xCD,0x38,0x02,0x58,0xA7,0xD9,
|
||||
0x50,0x6E,0x5F,0xFD,0x1C,0xA0,0xD0,0xEF,0xCE,0x73,0xD1,0x0D,0xFD,0x9C,0xC3,0xFF,
|
||||
0xA2,0x33,0xFF,0xFF,0xF9,0xC6,0xBF,0x55,0xEA,0x4D,0x5F,0xFD,0x9F,0xFA,0x5C,0x83,
|
||||
0xAB,0x7A,0x95,0x19,0xA9,0x61,0x0A,0xFF,0xFF,0xFF,0x81,0xFB,0x79,0xE5,0x88,0x8D,
|
||||
0xA0,0x40,0x20,0x91,0x3A,0x76,0xE5,0x6C,0xFF,0xF3,0x28,0xC4,0x15,0x11,0xDA,0x57,
|
||||
0x06,0x5E,0x5B,0x44,0xBB,0x74,0x68,0x0A,0x24,0xBF,0xE4,0xD1,0x84,0xFA,0x15,0x98,
|
||||
0x97,0x03,0x90,0x52,0x36,0x3E,0xFB,0xA4,0xA7,0x62,0x9B,0xBF,0xFB,0xFF,0xE6,0x27,
|
||||
0xFE,0xEF,0xFF,0x5F,0xFD,0x7F,0xFF,0xFF,0x56,0x6F,0xF2,0x8D,0xBE,0x91,0x91,0xF1,
|
||||
0xFD,0xDF,0xD2,0x6B,0xDF,0x4A,0xFD,0x4A,0xA2,0x1D,0x69,0x8B,0x6D,0x86,0x17,0x00,
|
||||
0xFF,0xF3,0x28,0xC4,0x08,0x0D,0x40,0xEE,0xF6,0x5E,0x39,0xD4,0x72,0x9F,0x24,0xE6,
|
||||
0xD0,0x08,0x81,0x21,0x59,0x96,0x7B,0x12,0x0C,0x00,0xA0,0x67,0xB6,0x87,0x9A,0x02,
|
||||
0xA6,0x23,0xE4,0x43,0xE2,0x66,0x16,0x84,0x10,0xEB,0xFF,0xC7,0x8F,0xEB,0x7F,0xDD,
|
||||
0xFF,0xFD,0x7F,0xFF,0xF4,0xFA,0xCE,0x7A,0x46,0x95,0x11,0x89,0x2B,0x8B,0x6C,0x30,
|
||||
0x18,0x01,0xE9,0x31,0x0F,0xC0,0x51,0xA0,0xFF,0xF3,0x28,0xC4,0x0E,0x0E,0x50,0xEE,
|
||||
0xE6,0x5E,0x3B,0xCE,0x72,0xEB,0x77,0xFE,0xD5,0x62,0x28,0x78,0x68,0xCF,0x9B,0xEB,
|
||||
0x77,0xC6,0x39,0xC0,0x05,0x3D,0xB3,0x8C,0x5C,0xF1,0x30,0x96,0xF6,0xFA,0x8A,0x8F,
|
||||
0x7F,0x9D,0xFF,0xCB,0x1F,0xFF,0xFF,0xFF,0xE5,0x4C,0x94,0x01,0x03,0x40,0x53,0xA6,
|
||||
0x6A,0x00,0x30,0x18,0xDF,0x80,0x07,0x00,0x7D,0x49,0x5C,0x92,0x22,0x80,0x4A,0x84,
|
||||
0xFF,0xF3,0x28,0xC4,0x0F,0x0C,0xF0,0xF2,0xA5,0xBE,0x6B,0x4A,0x70,0xA9,0xB4,0xD9,
|
||||
0x9F,0x98,0x92,0x00,0xAD,0x09,0x52,0x4E,0xA4,0x96,0xD5,0x28,0x0A,0x2A,0x24,0xF9,
|
||||
0x5B,0x62,0x96,0x22,0x2A,0xC6,0xD7,0x88,0x94,0xEF,0x57,0xFF,0xFF,0xFF,0xFF,0xFA,
|
||||
0x56,0x5A,0x43,0x4F,0x66,0xF3,0x62,0x28,0x0A,0xAA,0x44,0x98,0x60,0x33,0x12,0x90,
|
||||
0x1A,0xC0,0xB0,0x2E,0xE4,0x4E,0x31,0x7A,0xFF,0xF3,0x28,0xC4,0x16,0x0D,0x08,0x96,
|
||||
0x24,0x02,0x66,0x1E,0x4C,0x9A,0x23,0x0C,0x17,0xA1,0x6D,0x33,0x90,0xB6,0x88,0x17,
|
||||
0x7B,0x48,0xD9,0x7B,0x47,0xD8,0x02,0xB3,0x5A,0x45,0xAD,0xFF,0xFF,0xFF,0xFF,0xFF,
|
||||
0xFF,0x6A,0xC8,0xD5,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0x1C,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0x57,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0x92,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x4C,0x41,0x4D,
|
||||
0x45,0x33,0x2E,0x39,0x39,0x2E,0x35,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0xFF,0xF3,0x28,0xC4,0xC4,0x00,0x00,0x03,
|
||||
0x48,0x00,0x00,0x00,0x00,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,0x55,
|
||||
|
||||
};
|
||||
|
||||
void download_file()
|
||||
{
|
||||
uint32_t status;
|
||||
FILE* fp = luat_fs_fopen("test1.mp3", "r");
|
||||
|
||||
if (fp)
|
||||
{
|
||||
luat_fs_fclose(fp);
|
||||
return;
|
||||
}
|
||||
// Create file
|
||||
FILE* fp1 = luat_fs_fopen("test1.mp3", "wb+");//BatteryCharging.mp3
|
||||
|
||||
// Write mp3 data into file
|
||||
status = luat_fs_fwrite((uint8_t *)batteryCharging, sizeof(batteryCharging), 1, fp1);
|
||||
if (status == 0)
|
||||
{
|
||||
while (1);
|
||||
}
|
||||
|
||||
// After writing, close it
|
||||
luat_fs_fclose(fp1);
|
||||
|
||||
|
||||
// Create file
|
||||
fp1 = luat_fs_fopen("test2.mp3", "wb+");//BatteryCharging.mp3
|
||||
|
||||
// Write mp3 data into file
|
||||
status = luat_fs_fwrite((uint8_t *)rebooting, sizeof(rebooting), 1, fp1);
|
||||
if (status == 0)
|
||||
{
|
||||
while (1);
|
||||
}
|
||||
|
||||
// After writing, close it
|
||||
luat_fs_fclose(fp1);
|
||||
|
||||
|
||||
// Create file
|
||||
fp1 = luat_fs_fopen("test3.mp3", "wb+");//BatteryCharging.mp3
|
||||
|
||||
// Write mp3 data into file
|
||||
status = luat_fs_fwrite((uint8_t *)serverConnecting, sizeof(serverConnecting), 1, fp1);
|
||||
if (status == 0)
|
||||
{
|
||||
while (1);
|
||||
}
|
||||
|
||||
// After writing, close it
|
||||
luat_fs_fclose(fp1);
|
||||
|
||||
// Create file
|
||||
fp1 = luat_fs_fopen("test4.mp3", "wb+");//BatteryCharging.mp3
|
||||
|
||||
// Write mp3 data into file
|
||||
status = luat_fs_fwrite((uint8_t *)serverConnectSucceed, sizeof(serverConnectSucceed), 1, fp1);
|
||||
if (status == 0)
|
||||
{
|
||||
while (1);
|
||||
}
|
||||
|
||||
// After writing, close it
|
||||
luat_fs_fclose(fp1);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
@@ -0,0 +1,32 @@
|
||||
local TARGET_NAME = "example_audio_flash"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
includes(SDK_TOP .. "/thirdparty/audio_decoder")
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
add_deps("audio_decoder")
|
||||
|
||||
includes(SDK_TOP .. "/thirdparty/miniz")
|
||||
add_deps("miniz")
|
||||
|
||||
add_includedirs(SDK_TOP .. "/thirdparty/sfud",{public = true})
|
||||
add_files(SDK_TOP.."/thirdparty/sfud/*.c",{public = true})
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs("./include",{public = true})
|
||||
add_includedirs(SDK_TOP .. "/PLAT/core/tts/include/16k_lite_ver",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. "/PLAT/core/lib/libaisound50_16K.a "
|
||||
--8K版本用下面的库,注释掉16K的库
|
||||
-- LIB_USER = LIB_USER .. SDK_TOP .. "/PLAT/core/lib/libaisound50_8K.a "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,8 @@
|
||||
目前demo中aes和des测试需要到仓库根目录下将下面宏控代码添加进xmake.lua
|
||||
|
||||
add_defines("MBEDTLS_CIPHER_MODE_CBC",{public = true})
|
||||
add_defines("MBEDTLS_CIPHER_MODE_CFB",{public = true})
|
||||
add_defines("MBEDTLS_CIPHER_MODE_CTR",{public = true})
|
||||
add_defines("MBEDTLS_CIPHER_MODE_OFB",{public = true})
|
||||
add_defines("MBEDTLS_CIPHER_MODE_XTS",{public = true})
|
||||
|
||||
@@ -0,0 +1,350 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 1
|
||||
#define RTE_UART1_RTS_PIN_EN 1
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN21}, // 0 : gpio16 / 1 : UART1 RTS / 2 : SPI0 SSn
|
||||
// { PAD_PIN22}, // 0 : gpio11 / 1 : UART1 CTS / 2 : SPI0 MOSI
|
||||
// { PAD_PIN23}, // 0 : gpio14 / 1 : UART1 RXD / 2 : SPI0 MISO
|
||||
// { PAD_PIN24}, // 0 : gpio15 / 1 : UART1 TXD / 2 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 21
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 22
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 23
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 24
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 1
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 0
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 1
|
||||
|
||||
// { PAD_PIN13}, // 0 : gpio2 / 1 : UART0 RTSn / 3 : SPI1 SSn
|
||||
// { PAD_PIN14}, // 0 : gpio3 / 1 : UART0 CTSn / 3 : SPI1 MOSI
|
||||
// { PAD_PIN15}, // 0 : gpio4 / 1 : UART0 RXD / 3 : SPI1 MISO
|
||||
// { PAD_PIN16}, // 0 : gpio5 / 1 : UART0 TXD / 3 : SPI1 SCLK
|
||||
#define RTE_SPI1_SSN_BIT 13
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 14
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 15
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 16
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,220 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
|
||||
#include "common_api.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_mem.h"
|
||||
#include "luat_debug.h"
|
||||
|
||||
luat_rtos_task_handle task_handle;
|
||||
|
||||
#include "cJSON.h"
|
||||
|
||||
|
||||
#define FILE_LENGTH 520
|
||||
|
||||
void test_json_1(char* json_data)
|
||||
{
|
||||
|
||||
LUAT_DEBUG_PRINT("######## Test 12 ########\n");
|
||||
cJSON_Minify(json_data);
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", json_data);
|
||||
|
||||
// test 01
|
||||
cJSON* root = cJSON_Parse(json_data);
|
||||
cJSON* format = cJSON_GetObjectItemCaseSensitive(root, "format");
|
||||
cJSON* framerate_item = cJSON_GetObjectItemCaseSensitive(format, "frame rate");
|
||||
double framerate = 0;
|
||||
if(cJSON_IsNumber(framerate_item)) {
|
||||
framerate = framerate_item->valuedouble;
|
||||
}
|
||||
|
||||
LUAT_DEBUG_PRINT("######## Test START ########\n");
|
||||
|
||||
// test 02
|
||||
cJSON_SetNumberValue(framerate_item, 25);
|
||||
char* rendered = cJSON_Print(root);
|
||||
|
||||
LUAT_DEBUG_PRINT("######## Test 02 ########\n");
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", rendered);
|
||||
|
||||
LUAT_DEBUG_PRINT("######## Test 07 ########\n");
|
||||
LUAT_DEBUG_PRINT("root json size = %d\n", cJSON_GetArraySize(root));
|
||||
LUAT_DEBUG_PRINT("format json size = %d\n", cJSON_GetArraySize(format));
|
||||
|
||||
LUAT_DEBUG_PRINT("######## Test 08 ########\n");
|
||||
cJSON *json_item1 = cJSON_GetArrayItem(root, 0);
|
||||
cJSON *json_item2 = cJSON_GetArrayItem(root, 1);
|
||||
LUAT_DEBUG_PRINT("json_item1 data = %s\n", cJSON_Print(json_item1));
|
||||
LUAT_DEBUG_PRINT("json_item2 data = %s\n", cJSON_Print(json_item2));
|
||||
|
||||
LUAT_DEBUG_PRINT("######## Test 09 ########\n");
|
||||
cJSON* format1 = cJSON_GetObjectItem(root, "format");
|
||||
cJSON* framerate_item1 = cJSON_GetObjectItem(format1, "frame rate");
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", cJSON_Print(format1));
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", cJSON_Print(framerate_item1));
|
||||
|
||||
LUAT_DEBUG_PRINT("######## Test 10 ########\n");
|
||||
cJSON_bool isHasItem1 = cJSON_HasObjectItem(root, "format");
|
||||
cJSON_bool isHasItem2 = cJSON_HasObjectItem(root, "formai");
|
||||
LUAT_DEBUG_PRINT("has format item = %d\n", (int)isHasItem1);
|
||||
LUAT_DEBUG_PRINT("has formai item = %d\n", (int)isHasItem2);
|
||||
|
||||
LUAT_DEBUG_PRINT("######## Test 11 ########\n");
|
||||
cJSON* cjson_null = cJSON_CreateNull();
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", cJSON_Print(cjson_null));
|
||||
LUAT_DEBUG_PRINT("json data is null or not = %d\n", (int)cJSON_IsNull(cjson_null));
|
||||
cJSON_Delete(cjson_null);
|
||||
|
||||
cJSON* cjson_true = cJSON_CreateTrue();
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", cJSON_Print(cjson_true));
|
||||
LUAT_DEBUG_PRINT("json data is true or not = %d\n", (int)cJSON_IsTrue(cjson_true));
|
||||
cJSON_Delete(cjson_true);
|
||||
|
||||
cJSON* cjson_false = cJSON_CreateFalse();
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", cJSON_Print(cjson_false));
|
||||
LUAT_DEBUG_PRINT("json data is false or not = %d\n", (int)cJSON_IsFalse(cjson_false));
|
||||
cJSON_Delete(cjson_false);
|
||||
|
||||
|
||||
cJSON_bool bool_type = (cJSON_bool)1;
|
||||
cJSON* cjson_bool = cJSON_CreateBool(bool_type);
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", cJSON_Print(cjson_bool));
|
||||
LUAT_DEBUG_PRINT("json data is bool or not = %d\n", (int)cJSON_IsBool(cjson_bool));
|
||||
cJSON_Delete(cjson_bool);
|
||||
|
||||
double number_type = 88;
|
||||
cJSON* cjson_number = cJSON_CreateNumber(number_type);
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", cJSON_Print(cjson_number));
|
||||
LUAT_DEBUG_PRINT("json data is number or not = %d\n", (int)cJSON_IsNumber(cjson_number));
|
||||
cJSON_Delete(cjson_number);
|
||||
|
||||
char* string_type = "Welcome to luatOS";
|
||||
cJSON* cjson_string = cJSON_CreateString(string_type);
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", cJSON_Print(cjson_string));
|
||||
LUAT_DEBUG_PRINT("json data is string or not = %d\n", (int)cJSON_IsString(cjson_string));
|
||||
cJSON_Delete(cjson_string);
|
||||
|
||||
char* raw_type = "Welcome to luatOS raw";
|
||||
cJSON* cjson_raw = cJSON_CreateRaw(raw_type);
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", cJSON_Print(cjson_raw));
|
||||
LUAT_DEBUG_PRINT("json data is raw or not = %d\n", (int)cJSON_IsRaw(cjson_raw));
|
||||
cJSON_Delete(cjson_raw);
|
||||
|
||||
cJSON* cjson_array = cJSON_CreateArray();
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", cJSON_Print(cjson_array));
|
||||
LUAT_DEBUG_PRINT("json data is array or not = %d\n", (int)cJSON_IsArray(cjson_array));
|
||||
cJSON_Delete(cjson_array);
|
||||
|
||||
cJSON* cjson_object = cJSON_CreateObject();
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", cJSON_Print(cjson_object));
|
||||
LUAT_DEBUG_PRINT("json data is object or not = %d\n", (int)cJSON_IsObject(cjson_object));
|
||||
cJSON_Delete(cjson_object);
|
||||
|
||||
char* rendered1 = cJSON_Print(root);
|
||||
|
||||
LUAT_DEBUG_PRINT("######## Test ########\n");
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", rendered1);
|
||||
|
||||
}
|
||||
|
||||
void test_json_2()
|
||||
{
|
||||
cJSON *root;
|
||||
cJSON *fmt;
|
||||
root = cJSON_CreateObject();
|
||||
cJSON_AddItemToObject(root, "name", cJSON_CreateString("Jack (\"Bee\") Nimble"));
|
||||
cJSON_AddItemToObject(root, "format", fmt = cJSON_CreateObject());
|
||||
cJSON_AddStringToObject(fmt, "type", "rect");
|
||||
cJSON_AddNumberToObject(fmt, "width", 1920);
|
||||
cJSON_AddNumberToObject(fmt, "height", 1080);
|
||||
cJSON_AddFalseToObject(fmt, "interlace");
|
||||
cJSON_AddNumberToObject(fmt, "frame rate", 24);
|
||||
|
||||
char* result = cJSON_Print(root);
|
||||
LUAT_DEBUG_PRINT("######## Test 03 ########\n");
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", result);
|
||||
|
||||
LUAT_DEBUG_PRINT("######## Test 04 ########\n");
|
||||
LUAT_DEBUG_PRINT("json version = %s\n", cJSON_Version());
|
||||
|
||||
LUAT_DEBUG_PRINT("######## Test 05 ########\n");
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", cJSON_PrintUnformatted(root));
|
||||
|
||||
LUAT_DEBUG_PRINT("######## Test 12 ########\n");
|
||||
cJSON_AddNullToObject(root, "null");
|
||||
cJSON_AddTrueToObject(root, "true");
|
||||
cJSON_AddFalseToObject(root, "false");
|
||||
cJSON_AddBoolToObject(root, "bool", 1);
|
||||
cJSON_AddNumberToObject(root, "number", 88);
|
||||
cJSON_AddStringToObject(root, "string", "Welcome to luatOS");
|
||||
cJSON_AddRawToObject(root, "Raw", "Welcome to luatOS raw");
|
||||
LUAT_DEBUG_PRINT("json data = %s\n", cJSON_Print(root));
|
||||
}
|
||||
|
||||
|
||||
static void demo_init_cjson()
|
||||
{
|
||||
LUAT_DEBUG_PRINT("==================cjson is running==================");
|
||||
LUAT_DEBUG_PRINT("The cJSON version: %s", cJSON_Version());
|
||||
|
||||
char json_data[FILE_LENGTH] = "{\"name\": \"Jack Nimble\",\"format\": \
|
||||
{\"type\":\"rect\",\"width\":1920,\"height\":1080,\"interlace\": false,\"frame rate\": 24}}";
|
||||
|
||||
LUAT_DEBUG_PRINT("json_data = %s\n", json_data);
|
||||
|
||||
char json_test[] = "{\"class\":\"paymsg\",\"data\":{\"sn\":\"30000001\",\"type\":\"alipay\",\"content\":\"1326545647980439\",\"uuid\":\"1b56093bf93f493e904fcbeccbf0a0d0\",\"suffix\":15645548.39}}";
|
||||
|
||||
cJSON_Minify(json_test);
|
||||
LUAT_DEBUG_PRINT("---- %s", json_test);
|
||||
cJSON * a = cJSON_Parse(json_test);
|
||||
cJSON_AddLongLongToObject(a, "testlonglong", 1670751410618);
|
||||
LUAT_DEBUG_PRINT("---- %s", cJSON_Print(a));
|
||||
|
||||
|
||||
// test
|
||||
test_json_1(json_data);
|
||||
test_json_2();
|
||||
}
|
||||
|
||||
|
||||
static void task(void *param)
|
||||
{
|
||||
luat_rtos_task_sleep(1000);
|
||||
demo_init_cjson();
|
||||
|
||||
while(1)
|
||||
{
|
||||
luat_rtos_task_sleep(1000);
|
||||
LUAT_DEBUG_PRINT("==================cjson is done==================");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
static void task_demoE_init(void)
|
||||
{
|
||||
luat_rtos_task_create(&task_handle, 5*1024, 50, "task", task, NULL, 0);
|
||||
}
|
||||
|
||||
|
||||
//启动task_demoE_init,启动位置任务1级
|
||||
INIT_TASK_EXPORT(task_demoE_init, "1");
|
||||
@@ -0,0 +1,28 @@
|
||||
local TARGET_NAME = "example_cjson"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_includedirs(SDK_TOP .. "/thirdparty/cJSON")
|
||||
add_files(SDK_TOP .. "/thirdparty/cJSON/**.c")
|
||||
add_files("./src/**.c")
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
-- add_defines("MBEDTLS_TCPIP_LWIP",{public = true})
|
||||
-- 按需链接mbedtls
|
||||
-- add_defines("MBEDTLS_CONFIG_FILE=\"config_ec_ssl_comm.h\"")
|
||||
-- add_files(SDK_TOP .. "PLAT/middleware/thirdparty/mbedtls/library/*.c")
|
||||
-- 按需编译httpclient
|
||||
-- add_files(SDK_TOP .. "PLAT/middleware/thirdparty/httpclient/*.c")
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,8 @@
|
||||
目前demo中aes和des测试需要到仓库根目录下将下面宏控代码添加进xmake.lua
|
||||
|
||||
add_defines("MBEDTLS_CIPHER_MODE_CBC",{public = true})
|
||||
add_defines("MBEDTLS_CIPHER_MODE_CFB",{public = true})
|
||||
add_defines("MBEDTLS_CIPHER_MODE_CTR",{public = true})
|
||||
add_defines("MBEDTLS_CIPHER_MODE_OFB",{public = true})
|
||||
add_defines("MBEDTLS_CIPHER_MODE_XTS",{public = true})
|
||||
|
||||
@@ -0,0 +1,350 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 1
|
||||
#define RTE_UART1_RTS_PIN_EN 1
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN21}, // 0 : gpio16 / 1 : UART1 RTS / 2 : SPI0 SSn
|
||||
// { PAD_PIN22}, // 0 : gpio11 / 1 : UART1 CTS / 2 : SPI0 MOSI
|
||||
// { PAD_PIN23}, // 0 : gpio14 / 1 : UART1 RXD / 2 : SPI0 MISO
|
||||
// { PAD_PIN24}, // 0 : gpio15 / 1 : UART1 TXD / 2 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 21
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 22
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 23
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 24
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 1
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 0
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 1
|
||||
|
||||
// { PAD_PIN13}, // 0 : gpio2 / 1 : UART0 RTSn / 3 : SPI1 SSn
|
||||
// { PAD_PIN14}, // 0 : gpio3 / 1 : UART0 CTSn / 3 : SPI1 MOSI
|
||||
// { PAD_PIN15}, // 0 : gpio4 / 1 : UART0 RXD / 3 : SPI1 MISO
|
||||
// { PAD_PIN16}, // 0 : gpio5 / 1 : UART0 TXD / 3 : SPI1 SCLK
|
||||
#define RTE_SPI1_SSN_BIT 13
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 14
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 15
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 16
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,27 @@
|
||||
local TARGET_NAME = "example_crypto"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs("/inc",{public = true})
|
||||
add_files("/src/*.c",{public = true})
|
||||
add_includedirs(SDK_TOP .. "/thirdparty/mbedtls",{public = true})
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
-- add_defines("MBEDTLS_TCPIP_LWIP",{public = true})
|
||||
-- 按需链接mbedtls
|
||||
-- add_defines("MBEDTLS_CONFIG_FILE=\"config_ec_ssl_comm.h\"")
|
||||
-- add_files(SDK_TOP .. "PLAT/middleware/thirdparty/mbedtls/library/*.c")
|
||||
-- 按需编译httpclient
|
||||
-- add_files(SDK_TOP .. "PLAT/middleware/thirdparty/httpclient/*.c")
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,66 @@
|
||||
# 文件系统API说明
|
||||
|
||||
## 概述
|
||||
|
||||
* 文件系统的主体是littlefs, 总空间288k, 可用100k左右.
|
||||
* 有多套API, 各有特色, 但不应该混用
|
||||
|
||||
## Osa文件API
|
||||
|
||||
位于 `osasys.h`, 只有少量函数, 与posix API 类似. 不涉及目录操作
|
||||
|
||||
```c
|
||||
OSAFILE OsaFopen(const char *fileName, const char* mode);
|
||||
INT32 OsaFtell(OSAFILE fp);
|
||||
INT32 OsaFclose(OSAFILE fp);
|
||||
UINT32 OsaFread(void *buf, UINT32 size, UINT32 count, OSAFILE fp);
|
||||
UINT32 OsaFwrite(void *buf, UINT32 size, UINT32 count, OSAFILE fp);
|
||||
INT32 OsaFseek(OSAFILE fp, INT32 offset, UINT8 seekType);
|
||||
UINT32 OsaFremove(const char *fileName);
|
||||
```
|
||||
|
||||
通用调用逻辑:
|
||||
```c
|
||||
#define BUFF_SIZE (512)
|
||||
char buff[BUFF_SIZE];
|
||||
UINT32 rlen = 0;
|
||||
OSAFILE fp = OsaFopen("fs_test", "r");
|
||||
if (fp) { // 若成功, 必不为NULL
|
||||
// 读写数据
|
||||
while ((rlen = OsaFread(buff, BUFF_SIZE, 1, fp)) > 0) {
|
||||
// 处理读取到的数据
|
||||
}
|
||||
OsaFclose(fp);
|
||||
}
|
||||
```
|
||||
|
||||
## LiffteFs 文件API
|
||||
|
||||
在原始的lifftefs上, 封装成 `lfs_port.h`
|
||||
|
||||
注意:
|
||||
|
||||
* 不要调用 `LFS_init` `LFS_deinit` , 底层会自行处理
|
||||
* API 均以 `LFS_` 开头, 为同步阻塞且线程安全的函数. 与原生lifftefs的API基本上一一对应
|
||||
|
||||
通用调用逻辑:
|
||||
```c
|
||||
#define BUFF_SIZE (512)
|
||||
char buff[BUFF_SIZE];
|
||||
UINT32 rlen = 0;
|
||||
int ret = 0;
|
||||
lfs_file_t *file = malloc(sizeof(lfs_file_t));
|
||||
if (file == NULL) {
|
||||
// 内存分配出错
|
||||
return -1;
|
||||
}
|
||||
ret = LFS_fileOpen(file, "fs_test", LFS_O_RDONLY);
|
||||
if (ret == LFS_ERR_OK) { // 若成功, 必不为NULL
|
||||
// 读写数据
|
||||
while ((rlen = LFS_fileRead(file, buff, BUFF_SIZE)) > 0) {
|
||||
// 处理读取到的数据
|
||||
}
|
||||
LFS_fileClose(file);
|
||||
}
|
||||
free(file); // 注意释放内存
|
||||
```
|
||||
@@ -0,0 +1,350 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 1
|
||||
#define RTE_UART1_RTS_PIN_EN 1
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN21}, // 0 : gpio16 / 1 : UART1 RTS / 2 : SPI0 SSn
|
||||
// { PAD_PIN22}, // 0 : gpio11 / 1 : UART1 CTS / 2 : SPI0 MOSI
|
||||
// { PAD_PIN23}, // 0 : gpio14 / 1 : UART1 RXD / 2 : SPI0 MISO
|
||||
// { PAD_PIN24}, // 0 : gpio15 / 1 : UART1 TXD / 2 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 21
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 22
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 23
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 24
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 1
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 0
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 1
|
||||
|
||||
// { PAD_PIN13}, // 0 : gpio2 / 1 : UART0 RTSn / 3 : SPI1 SSn
|
||||
// { PAD_PIN14}, // 0 : gpio3 / 1 : UART0 CTSn / 3 : SPI1 MOSI
|
||||
// { PAD_PIN15}, // 0 : gpio4 / 1 : UART0 RXD / 3 : SPI1 MISO
|
||||
// { PAD_PIN16}, // 0 : gpio5 / 1 : UART0 TXD / 3 : SPI1 SCLK
|
||||
#define RTE_SPI1_SSN_BIT 13
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 14
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 15
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 16
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,229 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
/*
|
||||
LFS_xxx 系列函数, 分文件函数和文件夹, 还有几个文件系统相关的函数.
|
||||
**注意**: 不要调用 LFS_init LFS_deinit LFS_format 函数!!!
|
||||
*/
|
||||
|
||||
#include "common_api.h"
|
||||
#include "luat_base.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_fs.h"
|
||||
#include "luat_crypto.h"
|
||||
#include "luat_debug.h"
|
||||
#include "luat_mem.h"
|
||||
|
||||
static int print_fs_info()
|
||||
{
|
||||
luat_fs_info_t fs_info = {0};
|
||||
|
||||
luat_fs_info("/", &fs_info);
|
||||
// 打印文件系统空间信息
|
||||
LUAT_DEBUG_PRINT("fs_info %s %d %d %d %d",
|
||||
fs_info.filesystem,
|
||||
fs_info.type,
|
||||
fs_info.total_block,
|
||||
fs_info.block_used,
|
||||
fs_info.block_size);
|
||||
}
|
||||
|
||||
static int recur_fs(const char* dir_path)
|
||||
{
|
||||
luat_fs_dirent_t *fs_dirent = LUAT_MEM_MALLOC(sizeof(luat_fs_dirent_t)*100);
|
||||
memset(fs_dirent, 0, sizeof(luat_fs_dirent_t)*100);
|
||||
|
||||
int lsdir_cnt = luat_fs_lsdir(dir_path, fs_dirent, 0, 100);
|
||||
|
||||
if (lsdir_cnt > 0)
|
||||
{
|
||||
char path[255] = {0};
|
||||
|
||||
LUAT_DEBUG_PRINT("dir_path=%s, lsdir_cnt=%d", dir_path, lsdir_cnt);
|
||||
|
||||
for (size_t i = 0; i < lsdir_cnt; i++)
|
||||
{
|
||||
memset(path, 0, sizeof(path));
|
||||
|
||||
switch ((fs_dirent+i)->d_type)
|
||||
{
|
||||
// 文件类型
|
||||
case 0:
|
||||
snprintf(path, sizeof(path)-1, "%s%s", dir_path, (fs_dirent+i)->d_name);
|
||||
LUAT_DEBUG_PRINT("\tfile=%s, size=%d", path, luat_fs_fsize(path));
|
||||
break;
|
||||
|
||||
// 文件夹类型
|
||||
case 1:
|
||||
// 移芯618平台不支持文件夹创建操作,以下注释掉的两行代码未经测试
|
||||
// snprintf(path, sizeof(path)-1, "%s/%s/", dir_path, (fs_dirent+i)->d_name);
|
||||
// recur_fs(path);
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
LUAT_MEM_FREE(fs_dirent);
|
||||
fs_dirent = NULL;
|
||||
|
||||
return lsdir_cnt;
|
||||
}
|
||||
|
||||
// 演示文件操作, luat_fs_XXX 文件函数
|
||||
void exmaple_fs_luat_file(void) {
|
||||
FILE* fp = NULL;
|
||||
uint8_t *buff = NULL;
|
||||
const char* filepath = "lfs_test.txt";
|
||||
const char* newpath = "newpath";
|
||||
char tmp[100];
|
||||
int ret = 0;
|
||||
size_t size = 0;
|
||||
|
||||
LUAT_DEBUG_PRINT("check file exists? %s", filepath);
|
||||
// 通过获取大小, 判断文件是否存在, 存在就删除之
|
||||
if (luat_fs_fexist(filepath)) {
|
||||
LUAT_DEBUG_PRINT("remove %s", filepath);
|
||||
luat_fs_remove(filepath);
|
||||
}
|
||||
|
||||
//----------------------------------------------
|
||||
// 文件写入演示
|
||||
//----------------------------------------------
|
||||
// 开始写入文件
|
||||
LUAT_DEBUG_PRINT("test lfs file write");
|
||||
fp = luat_fs_fopen(filepath, "wb+");
|
||||
if (!fp) {
|
||||
LUAT_DEBUG_PRINT("file open failed %s", filepath);
|
||||
return;
|
||||
}
|
||||
// 产生随机数据, 模拟业务写入
|
||||
LUAT_DEBUG_PRINT("call malloc and rngGenRandom");
|
||||
buff = malloc(24 * 100);
|
||||
if (buff == NULL) {
|
||||
LUAT_DEBUG_PRINT("out of memory ?");
|
||||
luat_fs_fclose(fp);
|
||||
goto exit;
|
||||
}
|
||||
for (size_t i = 0; i < 100; i++)
|
||||
{
|
||||
luat_crypto_trng(buff + i*24, 24);
|
||||
}
|
||||
|
||||
// 按块写入数据
|
||||
LUAT_DEBUG_PRINT("call luat_fs_write");
|
||||
for (size_t i = 0; i < 24; i++)
|
||||
{
|
||||
ret = luat_fs_fwrite((const void*)(buff + i * 100), 100, 1, fp);
|
||||
if (ret < 0) {
|
||||
LUAT_DEBUG_PRINT("fail to write ret %d", ret);
|
||||
luat_fs_fclose(fp);
|
||||
goto exit;
|
||||
}
|
||||
}
|
||||
// 关闭文件
|
||||
luat_fs_fclose(fp);
|
||||
|
||||
//----------------------------------------------
|
||||
// 文件读取演示
|
||||
//----------------------------------------------
|
||||
// 读取文件
|
||||
fp = luat_fs_fopen(filepath, "r");
|
||||
if (!fp) {
|
||||
LUAT_DEBUG_PRINT("file open failed %s", filepath);
|
||||
goto exit;
|
||||
}
|
||||
for (size_t i = 0; i < 24; i++)
|
||||
{
|
||||
ret = luat_fs_fread(tmp, 100, 1, fp);
|
||||
if (ret < 0) {
|
||||
LUAT_DEBUG_PRINT("fail to write ret %d", ret);
|
||||
luat_fs_fclose(fp);
|
||||
goto exit;
|
||||
}
|
||||
if (memcmp(tmp, buff + i * 100, 100) != 0) {
|
||||
LUAT_DEBUG_PRINT("file data NOT match");
|
||||
}
|
||||
}
|
||||
// 直接定位 offset=100的位置, 重新读取
|
||||
luat_fs_fseek(fp, 100, SEEK_SET);
|
||||
ret = luat_fs_fread(tmp, 100, 1, fp);
|
||||
if (memcmp(tmp, buff + 100, 100) != 0) {
|
||||
LUAT_DEBUG_PRINT("file data NOT match at offset 100");
|
||||
}
|
||||
ret = luat_fs_ftell(fp);
|
||||
if (ret != 200) {
|
||||
// 按前面的逻辑, 先设置到100, 然后读取100, 当前偏移量应该是200
|
||||
LUAT_DEBUG_PRINT("file seek NOT match at offset 200");
|
||||
}
|
||||
|
||||
// 关闭句柄
|
||||
luat_fs_fclose(fp);
|
||||
|
||||
//----------------------------------------------
|
||||
// 文件截断演示
|
||||
//----------------------------------------------
|
||||
|
||||
// // 直接用路径裁剪
|
||||
luat_fs_truncate(filepath, 300);
|
||||
|
||||
|
||||
//----------------------------------------------
|
||||
// 文件改名演示
|
||||
//----------------------------------------------
|
||||
// 文件还在, 测试改名
|
||||
luat_fs_remove(newpath);
|
||||
luat_fs_rename(filepath, newpath);
|
||||
// 读取文件, 老路径应该得到文件大小不大于0
|
||||
|
||||
size = luat_fs_fsize(filepath);
|
||||
if (size > 0) {
|
||||
LUAT_DEBUG_PRINT("file shall not exist");
|
||||
}
|
||||
// 读取文件, 新路径应该得到文件大小等于300
|
||||
size = luat_fs_fsize(newpath);
|
||||
if (size != 300) {
|
||||
LUAT_DEBUG_PRINT("file shall 300 byte but %d", size);
|
||||
}
|
||||
|
||||
luat_fs_remove(filepath);
|
||||
luat_fs_remove(newpath);
|
||||
|
||||
//------------------------------------------------------
|
||||
// 演示完毕, 清理资源
|
||||
exit:
|
||||
if (buff != NULL) {
|
||||
free(buff);
|
||||
}
|
||||
LUAT_DEBUG_PRINT("file example exited");
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
void exmaple_fs_luat_main(void) {
|
||||
luat_fs_init(); // 必须先初始化
|
||||
print_fs_info();
|
||||
recur_fs("/");
|
||||
exmaple_fs_luat_file();
|
||||
luat_rtos_task_sleep(1000);
|
||||
}
|
||||
@@ -0,0 +1,62 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
// 本文件为入口函数
|
||||
// 具体演示在 example_fs_osa.c 和 example_fs_lfs.c
|
||||
|
||||
#include "common_api.h"
|
||||
#include "luat_base.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_debug.h"
|
||||
|
||||
extern void exmaple_fs_luat_main(void);
|
||||
|
||||
static void fs_example(void *param)
|
||||
{
|
||||
luat_rtos_task_sleep(1500);
|
||||
exmaple_fs_luat_main();
|
||||
while(1)
|
||||
{
|
||||
luat_rtos_task_sleep(1000);
|
||||
LUAT_DEBUG_PRINT("fs demo is done");
|
||||
}
|
||||
}
|
||||
|
||||
static void task_demoE_init(void)
|
||||
{
|
||||
luat_rtos_task_handle handle;
|
||||
luat_rtos_task_create(&handle, 4*1024, 50, "fs", fs_example, NULL, 0);
|
||||
}
|
||||
|
||||
|
||||
//启动hw_demoA_init,启动位置硬件初始1级
|
||||
// INIT_HW_EXPORT(hw_demoA_init, "1");
|
||||
//启动hw_demoB_init,启动位置硬件初始2级
|
||||
// INIT_HW_EXPORT(hw_demoB_init, "2");
|
||||
//启动dr_demoC_init,启动位置驱动1级
|
||||
// INIT_DRV_EXPORT(dr_demoC_init, "1");
|
||||
//启动dr_demoD_init,启动位置驱动2级
|
||||
// INIT_DRV_EXPORT(dr_demoD_init, "2");
|
||||
//启动task_demoE_init,启动位置任务1级
|
||||
INIT_TASK_EXPORT(task_demoE_init, "1");
|
||||
//启动task_demoF_init,启动位置任务2级
|
||||
// INIT_TASK_EXPORT(task_demoF_init, "2");
|
||||
|
||||
@@ -0,0 +1,20 @@
|
||||
local TARGET_NAME = "example_filesystem"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,3 @@
|
||||
# 说明
|
||||
|
||||
* 片上flash读写演示
|
||||
@@ -0,0 +1,350 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 1
|
||||
#define RTE_UART1_RTS_PIN_EN 1
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN21}, // 0 : gpio16 / 1 : UART1 RTS / 2 : SPI0 SSn
|
||||
// { PAD_PIN22}, // 0 : gpio11 / 1 : UART1 CTS / 2 : SPI0 MOSI
|
||||
// { PAD_PIN23}, // 0 : gpio14 / 1 : UART1 RXD / 2 : SPI0 MISO
|
||||
// { PAD_PIN24}, // 0 : gpio15 / 1 : UART1 TXD / 2 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 21
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 22
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 23
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 24
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 1
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 0
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 1
|
||||
|
||||
// { PAD_PIN13}, // 0 : gpio2 / 1 : UART0 RTSn / 3 : SPI1 SSn
|
||||
// { PAD_PIN14}, // 0 : gpio3 / 1 : UART0 CTSn / 3 : SPI1 MOSI
|
||||
// { PAD_PIN15}, // 0 : gpio4 / 1 : UART0 RXD / 3 : SPI1 MISO
|
||||
// { PAD_PIN16}, // 0 : gpio5 / 1 : UART0 TXD / 3 : SPI1 SCLK
|
||||
#define RTE_SPI1_SSN_BIT 13
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 14
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 15
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 16
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,127 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
#include "common_api.h"
|
||||
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_debug.h"
|
||||
#include "luat_flash.h"
|
||||
#include "luat_crypto.h"
|
||||
|
||||
#include "mem_map.h"
|
||||
|
||||
/*
|
||||
本Demo属于高级操作, 请务必先看完提示
|
||||
|
||||
Flash的整体布局如下, 对应非LuatOS应用:
|
||||
|
||||
AP flash layout, toatl 4MB
|
||||
flash raw address: 0x00000000---0x00400000
|
||||
flash xip address(from ap view): 0x00800000---0x00c00000
|
||||
|
||||
|
||||
0x00000000 |---------------------------------|
|
||||
| header1 8KB |
|
||||
0x00002000 |---------------------------------|
|
||||
| header2 8KB |
|
||||
0x00004000 |---------------------------------|
|
||||
| bl part1 32KB |
|
||||
0x0000c000 |---------------------------------|
|
||||
| bl part2 96KB |
|
||||
0x00024000 |---------------------------------|
|
||||
| app img 2.5MB + 384k |------OTA write
|
||||
0x00304000 |---------------------------------|
|
||||
| fota 512KB |-----OTA download write
|
||||
0x00384000 |---------------------------------|
|
||||
| lfs 288KB |-----FS write
|
||||
0x003cc000 |---------------------------------|
|
||||
| kv 64KB |-----kv write
|
||||
0x003dc000 |---------------------------------|
|
||||
| rel_ap(factory) 16KB |-----factory write
|
||||
0x003e0000 |---------------------------------|
|
||||
| rel_ap 16KB |-----factory write
|
||||
0x003e4000 |---------------------------------|
|
||||
| hib backup 96KB |-----hib write
|
||||
0x003fc000 |---------------------------------|
|
||||
| plat config 16KB |-----similar as FS
|
||||
0x00400000 |---------------------------------|
|
||||
|
||||
|
||||
**注意**:
|
||||
1. 若直接读取数据, 可通过 上述地址+0x00800000 直接读取, 不需要经过luat_flash.h
|
||||
2. 若需要写入或抹除数据, 则需要调用luat_flash.h
|
||||
|
||||
按上图可知, 只有两个区域可以动:
|
||||
1. KV数据库区, 若完全不使用luat_kv, 则可以直接使用
|
||||
2. AP空间, 若确定不需要使用全部空间, 可进行裁剪, 但需要改mem_map.h
|
||||
*/
|
||||
|
||||
static void flash_example(void *param)
|
||||
{
|
||||
luat_rtos_task_sleep(1500);
|
||||
fotaNvmNfsPeInit(1); //允许开放出app.img的最后896KB空间可写
|
||||
|
||||
luat_rtos_task_sleep(2000);
|
||||
|
||||
char buff[256] = {0};
|
||||
|
||||
|
||||
uint32_t addr = 0x00284000; // 这是app.img的最后512KB空间
|
||||
|
||||
// flash读写没有太多技巧
|
||||
luat_flash_read(buff, addr, 256);
|
||||
|
||||
luat_flash_erase(addr, 4096);
|
||||
|
||||
// 生成一些随机数据,模拟业务数据
|
||||
luat_crypto_trng(buff, 256);
|
||||
|
||||
luat_flash_write(buff, addr, 256);
|
||||
|
||||
luat_flash_read(buff, addr, 256);
|
||||
fotaNvmNfsPeInit(0); //测试完成,就可以关闭开放了
|
||||
while(1)
|
||||
{
|
||||
luat_rtos_task_sleep(1000);
|
||||
LUAT_DEBUG_PRINT("flash demo is done");
|
||||
}
|
||||
}
|
||||
|
||||
static void task_demoE_init(void)
|
||||
{
|
||||
luat_rtos_task_handle handle;
|
||||
luat_rtos_task_create(&handle, 16*1024, 50, "flash", flash_example, NULL, 0);
|
||||
}
|
||||
|
||||
|
||||
//启动hw_demoA_init,启动位置硬件初始1级
|
||||
// INIT_HW_EXPORT(hw_demoA_init, "1");
|
||||
//启动hw_demoB_init,启动位置硬件初始2级
|
||||
// INIT_HW_EXPORT(hw_demoB_init, "2");
|
||||
//启动dr_demoC_init,启动位置驱动1级
|
||||
// INIT_DRV_EXPORT(dr_demoC_init, "1");
|
||||
//启动dr_demoD_init,启动位置驱动2级
|
||||
// INIT_DRV_EXPORT(dr_demoD_init, "2");
|
||||
//启动task_demoE_init,启动位置任务1级
|
||||
INIT_TASK_EXPORT(task_demoE_init, "1");
|
||||
//启动task_demoF_init,启动位置任务2级
|
||||
// INIT_TASK_EXPORT(task_demoF_init, "2");
|
||||
|
||||
@@ -0,0 +1,20 @@
|
||||
local TARGET_NAME = "example_flash"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--add_files("../../thirdparty/fal/src/*.c",{public = true})
|
||||
--add_files("../../thirdparty/flashdb/src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,354 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 0
|
||||
#define RTE_UART1_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN23}, // 0 : gpio8 / 1 : SPI0 SSn
|
||||
// { PAD_PIN24}, // 0 : gpio9 / 1 : SPI0 MOSI
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 1 : SPI0 MISO
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 1 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 23
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 24
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 25
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 26
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 8
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 1 : SPI1 SSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 1 : SPI1 MOSI
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 1 : SPI1 MISO
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 1 : SPI1 SCLK
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 4 : SPI1 SSn1
|
||||
#define RTE_SPI1_SSN_BIT 27
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 28
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 29
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 30
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 12
|
||||
|
||||
#define RTE_SPI1_SSN1_BIT 31
|
||||
#define RTE_SPI1_SSN1_FUNC PAD_MUX_ALT4
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 0
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,176 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
#include "common_api.h"
|
||||
#include "luat_mobile.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_debug.h"
|
||||
#include "luat_fota.h"
|
||||
#include "reset.h"
|
||||
#include "HTTPClient.h"
|
||||
|
||||
/*
|
||||
FOTA应用开发可以参考:https://doc.openluat.com/wiki/37?wiki_page_id=4562
|
||||
*/
|
||||
|
||||
|
||||
#define PROJECT_VERSION "1.0.0"
|
||||
//ciphersuite: TLS-RSA-WITH-AES-128-CBC-SHA msglen = 2609
|
||||
//support session ticket/fragment
|
||||
|
||||
#define TEST_SERVER_NAME "http://airtest.openluat.com:2900/download/csdk_delta_test.par"
|
||||
|
||||
#define TEST_HOST "http://airtest.openluat.com:2900"
|
||||
#define HTTP_RECV_BUF_SIZE (1501)
|
||||
#define HTTP_HEAD_BUF_SIZE (800)
|
||||
|
||||
static HttpClientContext gHttpClient = {0};
|
||||
luat_fota_img_proc_ctx_ptr test_luat_fota_handle = NULL;
|
||||
|
||||
/**
|
||||
\fn INT32 httpGetData(CHAR *getUrl, CHAR *buf, UINT32 len)
|
||||
\brief
|
||||
\return
|
||||
*/
|
||||
static INT32 httpGetData(CHAR *getUrl, CHAR *buf, UINT32 len)
|
||||
{
|
||||
HTTPResult result = HTTP_INTERNAL;
|
||||
HttpClientData clientData = {0};
|
||||
UINT32 count = 0;
|
||||
uint16_t headerLen = 0;
|
||||
int result1 = 0;
|
||||
|
||||
LUAT_DEBUG_ASSERT(buf != NULL,0,0,0);
|
||||
|
||||
clientData.headerBuf = malloc(HTTP_HEAD_BUF_SIZE);
|
||||
clientData.headerBufLen = HTTP_HEAD_BUF_SIZE;
|
||||
clientData.respBuf = buf;
|
||||
clientData.respBufLen = len;
|
||||
|
||||
result = httpSendRequest(&gHttpClient, getUrl, HTTP_GET, &clientData);
|
||||
LUAT_DEBUG_PRINT("send request result=%d", result);
|
||||
if (result != HTTP_OK)
|
||||
goto exit;
|
||||
do {
|
||||
LUAT_DEBUG_PRINT("recvResponse loop.");
|
||||
memset(clientData.headerBuf, 0, clientData.headerBufLen);
|
||||
memset(clientData.respBuf, 0, clientData.respBufLen);
|
||||
result = httpRecvResponse(&gHttpClient, &clientData);
|
||||
if(result == HTTP_OK || result == HTTP_MOREDATA){
|
||||
headerLen = strlen(clientData.headerBuf);
|
||||
if(headerLen > 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("total content length=%d", clientData.recvContentLength);
|
||||
test_luat_fota_handle = luat_fota_init();
|
||||
}
|
||||
|
||||
if(clientData.blockContentLen > 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("response content:{%s}", (uint8_t*)clientData.respBuf);
|
||||
result1 = luat_fota_write(test_luat_fota_handle,clientData.respBuf,clientData.blockContentLen);
|
||||
if (result1==0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("fota update success");
|
||||
}
|
||||
else{
|
||||
LUAT_DEBUG_PRINT("fota update error");
|
||||
}
|
||||
}
|
||||
count += clientData.blockContentLen;
|
||||
|
||||
|
||||
LUAT_DEBUG_PRINT("has recv=%d", count);
|
||||
}
|
||||
} while (result == HTTP_MOREDATA || result == HTTP_CONN);
|
||||
|
||||
LUAT_DEBUG_PRINT("result=%d", result);
|
||||
if (gHttpClient.httpResponseCode < 200 || gHttpClient.httpResponseCode > 404)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("invalid http response code=%d",gHttpClient.httpResponseCode);
|
||||
} else if (count == 0 || count != clientData.recvContentLength) {
|
||||
LUAT_DEBUG_PRINT("data not receive complete");
|
||||
} else {
|
||||
LUAT_DEBUG_PRINT("receive success");
|
||||
}
|
||||
exit:
|
||||
free(clientData.headerBuf);
|
||||
return result;
|
||||
}
|
||||
|
||||
luat_rtos_semaphore_t net_semaphore_handle;
|
||||
luat_rtos_task_handle https_task_handle;
|
||||
|
||||
void mobile_event_callback(LUAT_MOBILE_EVENT_E event, uint8_t index, uint8_t status){
|
||||
if (event == LUAT_MOBILE_EVENT_NETIF && status == LUAT_MOBILE_NETIF_LINK_ON){
|
||||
LUAT_DEBUG_PRINT("network ready");
|
||||
luat_rtos_semaphore_release(net_semaphore_handle);
|
||||
}
|
||||
}
|
||||
|
||||
static void task_test_fota(void *param)
|
||||
{
|
||||
luat_rtos_semaphore_create(&net_semaphore_handle, 1);
|
||||
|
||||
char *recvBuf = malloc(HTTP_RECV_BUF_SIZE);
|
||||
HTTPResult result = HTTP_INTERNAL;
|
||||
|
||||
luat_mobile_event_register_handler(mobile_event_callback);
|
||||
|
||||
luat_rtos_task_sleep(3000);
|
||||
LUAT_DEBUG_PRINT("version = %s", PROJECT_VERSION);
|
||||
|
||||
gHttpClient.timeout_s = 2;
|
||||
gHttpClient.timeout_r = 20;
|
||||
gHttpClient.seclevel = 1;
|
||||
gHttpClient.ciphersuite[0] = 0xFFFF;
|
||||
gHttpClient.ignore = 1;
|
||||
|
||||
luat_rtos_semaphore_take(net_semaphore_handle, LUAT_WAIT_FOREVER);
|
||||
|
||||
result = httpConnect(&gHttpClient, TEST_HOST);
|
||||
if (result == HTTP_OK)
|
||||
{
|
||||
httpGetData(TEST_SERVER_NAME, recvBuf, HTTP_RECV_BUF_SIZE);
|
||||
httpClose(&gHttpClient);
|
||||
LUAT_DEBUG_PRINT("verify start");
|
||||
int verify = luat_fota_done(test_luat_fota_handle);
|
||||
if(verify != 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("image_verify error");
|
||||
goto exit;
|
||||
}
|
||||
LUAT_DEBUG_PRINT("image_verify ok");
|
||||
ResetStartPorReset(RESET_REASON_FOTA);
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("http client connect error");
|
||||
}
|
||||
exit:
|
||||
luat_rtos_task_delete(https_task_handle);
|
||||
}
|
||||
|
||||
static void task_demo_fota(void)
|
||||
{
|
||||
luat_rtos_task_create(&https_task_handle, 32*1024, 20, "https", task_test_fota, NULL, NULL);
|
||||
}
|
||||
//启动task_demoF_init,启动位置任务2级
|
||||
INIT_TASK_EXPORT(task_demo_fota, "1");
|
||||
|
||||
@@ -0,0 +1,23 @@
|
||||
local TARGET_NAME = "example_fota"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
|
||||
includes(SDK_TOP .. "/thirdparty/httpclient")
|
||||
add_deps("httpclient")
|
||||
--加入代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,354 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 0
|
||||
#define RTE_UART1_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 27
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT5
|
||||
|
||||
#define RTE_UART2_TX_BIT 28
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT5
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN23}, // 0 : gpio8 / 1 : SPI0 SSn
|
||||
// { PAD_PIN24}, // 0 : gpio9 / 1 : SPI0 MOSI
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 1 : SPI0 MISO
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 1 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 23
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 24
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 25
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 26
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 8
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 1 : SPI1 SSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 1 : SPI1 MOSI
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 1 : SPI1 MISO
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 1 : SPI1 SCLK
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 4 : SPI1 SSn1
|
||||
#define RTE_SPI1_SSN_BIT 27
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 28
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 29
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 30
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 12
|
||||
|
||||
#define RTE_SPI1_SSN1_BIT 31
|
||||
#define RTE_SPI1_SSN1_FUNC PAD_MUX_ALT4
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,40 @@
|
||||
#ifndef _EXAMPLE_SOCKET_H
|
||||
#define _EXAMPLE_SOCKET_H
|
||||
|
||||
#include "commontypedef.h"
|
||||
|
||||
#define AM_LOCATION_SERVICE_LOCATION_BCD_LEN 5
|
||||
#define AM_LOCATION_SERVICE_RCV_TIMEOUT 15
|
||||
|
||||
#ifdef PACK_STRUCT_USE_INCLUDES
|
||||
#include "arch/bpstruct.h"
|
||||
#endif
|
||||
PACK_STRUCT_BEGIN
|
||||
struct am_location_service_rsp_data_t
|
||||
{
|
||||
PACK_STRUCT_FLD_8(u8_t result);
|
||||
PACK_STRUCT_FIELD(u8_t latitude[AM_LOCATION_SERVICE_LOCATION_BCD_LEN]);
|
||||
PACK_STRUCT_FIELD(u8_t longitude[AM_LOCATION_SERVICE_LOCATION_BCD_LEN]);
|
||||
PACK_STRUCT_FLD_8(u8_t year);
|
||||
PACK_STRUCT_FLD_8(u8_t month);
|
||||
PACK_STRUCT_FLD_8(u8_t day);
|
||||
PACK_STRUCT_FLD_8(u8_t hour);
|
||||
PACK_STRUCT_FLD_8(u8_t minute);
|
||||
PACK_STRUCT_FLD_8(u8_t second);
|
||||
} PACK_STRUCT_STRUCT;
|
||||
PACK_STRUCT_END
|
||||
#ifdef PACK_STRUCT_USE_INCLUDES
|
||||
#include "arch/epstruct.h"
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,332 @@
|
||||
/*
|
||||
* Copyright © 2014 Kosma Moczek <kosma@cloudyourcar.com>
|
||||
* This program is free software. It comes without any warranty, to the extent
|
||||
* permitted by applicable law. You can redistribute it and/or modify it under
|
||||
* the terms of the Do What The Fuck You Want To Public License, Version 2, as
|
||||
* published by Sam Hocevar. See the COPYING file for more details.
|
||||
*/
|
||||
|
||||
#include "minmea.h"
|
||||
#include "common_api.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_debug.h"
|
||||
#include "luat_uart.h"
|
||||
#include "luat_gpio.h"
|
||||
#include "HTTPClient.h"
|
||||
#include "luat_mobile.h"
|
||||
|
||||
// 注意:780EG内部gps与串口2相连
|
||||
#define UART_ID 2
|
||||
#define HTTP_RECV_BUF_SIZE (6000)
|
||||
#define HTTP_HEAD_BUF_SIZE (800)
|
||||
#define TEST_HOST "http://download.openluat.com/9501-xingli/HXXT_GPS_BDS_AGNSS_DATA.dat"
|
||||
|
||||
|
||||
static HttpClientContext gHttpClient = {0};
|
||||
|
||||
static luat_rtos_task_handle gps_task_handle;
|
||||
static luat_rtos_semaphore_t net_semaphore_handle;
|
||||
static luat_rtos_task_handle https_task_handle;
|
||||
|
||||
void mobile_event_callback(LUAT_MOBILE_EVENT_E event, uint8_t index, uint8_t status){
|
||||
if (event == LUAT_MOBILE_EVENT_NETIF && status == LUAT_MOBILE_NETIF_LINK_ON){
|
||||
LUAT_DEBUG_PRINT("network ready");
|
||||
luat_rtos_semaphore_release(net_semaphore_handle);
|
||||
}
|
||||
}
|
||||
|
||||
static int libminmea_parse_data(const char* data, size_t len) {
|
||||
size_t prev = 0;
|
||||
static char nmea_tmp_buff[86] = {0}; // nmea 最大长度82,含换行符
|
||||
for (size_t offset = 0; offset < len; offset++)
|
||||
{
|
||||
// \r == 0x0D \n == 0x0A
|
||||
if (data[offset] == 0x0A) {
|
||||
// 最短也需要是 OK\r\n
|
||||
// 应该\r\n的
|
||||
// 太长了
|
||||
if (offset - prev < 3 || data[offset - 1] != 0x0D || offset - prev > 82) {
|
||||
prev = offset + 1;
|
||||
continue;
|
||||
}
|
||||
memcpy(nmea_tmp_buff, data + prev, offset - prev - 1);
|
||||
nmea_tmp_buff[offset - prev - 1] = 0x00;
|
||||
if(strstr(nmea_tmp_buff, "GNRMC"))
|
||||
{
|
||||
parse_nmea((const char*)nmea_tmp_buff);
|
||||
}
|
||||
prev = offset + 1;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
void luat_uart_recv_cb(int uart_id, uint32_t data_len){
|
||||
char* data_buff = malloc(data_len+1);
|
||||
memset(data_buff,0,data_len+1);
|
||||
luat_uart_read(uart_id, data_buff, data_len);
|
||||
LUAT_DEBUG_PRINT("uart_id:%d gnssdata:\n %s",uart_id,data_buff);
|
||||
libminmea_parse_data(data_buff, data_len);
|
||||
free(data_buff);
|
||||
}
|
||||
|
||||
static INT32 httpGetData(CHAR *getUrl, CHAR *buf, UINT32 len, UINT32 *dataLen)
|
||||
{
|
||||
HTTPResult result = HTTP_INTERNAL;
|
||||
HttpClientData clientData = {0};
|
||||
UINT32 count = 0;
|
||||
uint16_t headerLen = 0;
|
||||
|
||||
LUAT_DEBUG_ASSERT(buf != NULL,0,0,0);
|
||||
|
||||
clientData.headerBuf = malloc(HTTP_HEAD_BUF_SIZE);
|
||||
clientData.headerBufLen = HTTP_HEAD_BUF_SIZE;
|
||||
clientData.respBuf = buf;
|
||||
clientData.respBufLen = len;
|
||||
|
||||
result = httpSendRequest(&gHttpClient, getUrl, HTTP_GET, &clientData);
|
||||
LUAT_DEBUG_PRINT("send request result=%d", result);
|
||||
if (result != HTTP_OK)
|
||||
goto exit;
|
||||
do {
|
||||
LUAT_DEBUG_PRINT("recvResponse loop.");
|
||||
memset(clientData.headerBuf, 0, clientData.headerBufLen);
|
||||
memset(clientData.respBuf, 0, clientData.respBufLen);
|
||||
result = httpRecvResponse(&gHttpClient, &clientData);
|
||||
if(result == HTTP_OK || result == HTTP_MOREDATA){
|
||||
headerLen = strlen(clientData.headerBuf);
|
||||
if(headerLen > 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("total content length=%d", clientData.recvContentLength);
|
||||
}
|
||||
|
||||
if(clientData.blockContentLen > 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("response content:{%s}", (uint8_t*)clientData.respBuf);
|
||||
}
|
||||
count += clientData.blockContentLen;
|
||||
*dataLen = *dataLen + count;
|
||||
LUAT_DEBUG_PRINT("has recv=%d", count);
|
||||
}
|
||||
} while (result == HTTP_MOREDATA || result == HTTP_CONN);
|
||||
|
||||
LUAT_DEBUG_PRINT("result=%d", result);
|
||||
if (gHttpClient.httpResponseCode < 200 || gHttpClient.httpResponseCode > 404)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("invalid http response code=%d",gHttpClient.httpResponseCode);
|
||||
} else if (count == 0 || count != clientData.recvContentLength) {
|
||||
LUAT_DEBUG_PRINT("data not receive complete");
|
||||
} else {
|
||||
LUAT_DEBUG_PRINT("receive success");
|
||||
}
|
||||
exit:
|
||||
free(clientData.headerBuf);
|
||||
return result;
|
||||
}
|
||||
|
||||
|
||||
static void task_test_https(void *param)
|
||||
{
|
||||
luat_rtos_semaphore_create(&net_semaphore_handle, 1);
|
||||
|
||||
char *recvBuf = malloc(HTTP_RECV_BUF_SIZE);
|
||||
HTTPResult result = HTTP_INTERNAL;
|
||||
uint32_t dataLen = 0;
|
||||
luat_mobile_event_register_handler(mobile_event_callback);
|
||||
gHttpClient.timeout_s = 2;
|
||||
gHttpClient.timeout_r = 20;
|
||||
luat_rtos_semaphore_take(net_semaphore_handle, LUAT_WAIT_FOREVER);
|
||||
result = httpConnect(&gHttpClient, TEST_HOST);
|
||||
if (result == HTTP_OK)
|
||||
{
|
||||
result = httpGetData(TEST_HOST, recvBuf, HTTP_RECV_BUF_SIZE, &dataLen);
|
||||
httpClose(&gHttpClient);
|
||||
|
||||
if (result == HTTP_OK)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("http client get data success %d", dataLen);
|
||||
|
||||
for (size_t i = 0; i < dataLen; i = i + 512)
|
||||
{
|
||||
if (i + 512 < dataLen)
|
||||
luat_uart_write(UART_ID, &recvBuf[i], 512);
|
||||
else
|
||||
luat_uart_write(UART_ID, &recvBuf[i], dataLen - i);
|
||||
luat_rtos_task_sleep(100);
|
||||
}
|
||||
}
|
||||
demo_udp_init();
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("http client connect error");
|
||||
}
|
||||
memset(recvBuf, 0x00, HTTP_RECV_BUF_SIZE);
|
||||
free(recvBuf);
|
||||
luat_rtos_task_delete(https_task_handle);
|
||||
}
|
||||
|
||||
static void task_demo_https(void)
|
||||
{
|
||||
// https所需的栈空间会大很多
|
||||
luat_rtos_task_create(&https_task_handle, 32*1024, 20, "https", task_test_https, NULL, NULL);
|
||||
}
|
||||
|
||||
//启动task_demoF_init,启动位置任务2级
|
||||
|
||||
static void task_test_gps(void *param)
|
||||
{
|
||||
|
||||
luat_uart_t uart = {
|
||||
.id = UART_ID,
|
||||
.baud_rate = 115200,
|
||||
.data_bits = 8,
|
||||
.stop_bits = 1,
|
||||
.parity = 0
|
||||
};
|
||||
luat_uart_pre_setup(UART_ID, 1);
|
||||
luat_uart_setup(&uart);
|
||||
|
||||
luat_uart_ctrl(UART_ID, LUAT_UART_SET_RECV_CALLBACK, luat_uart_recv_cb);
|
||||
|
||||
// gps电源
|
||||
luat_gpio_cfg_t cfg = {0};
|
||||
cfg.pin = HAL_GPIO_13;
|
||||
cfg.mode = LUAT_GPIO_OUTPUT;
|
||||
cfg.output_level = 1;
|
||||
cfg.alt_fun = 4;
|
||||
luat_gpio_open(&cfg);
|
||||
luat_rtos_task_sleep(200);
|
||||
while (1)
|
||||
{
|
||||
char cmd2[] = "$AIDINFO";
|
||||
luat_uart_write(UART_ID, cmd2, strlen(cmd2));
|
||||
luat_rtos_task_sleep(5000);
|
||||
}
|
||||
luat_rtos_task_delete(gps_task_handle);
|
||||
}
|
||||
|
||||
|
||||
#define INDENT_SPACES " "
|
||||
|
||||
int parse_nmea(const char *gpsdata)
|
||||
{
|
||||
switch (minmea_sentence_id(gpsdata, false)) {
|
||||
case MINMEA_SENTENCE_RMC: {
|
||||
struct minmea_sentence_rmc frame;
|
||||
if (minmea_parse_rmc(&frame, gpsdata)) {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxRMC: raw coordinates and speed: (%d/%d,%d/%d) %d/%d\n",
|
||||
frame.latitude.value, frame.latitude.scale,
|
||||
frame.longitude.value, frame.longitude.scale,
|
||||
frame.speed.value, frame.speed.scale);
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxRMC fixed-point coordinates and speed scaled to three decimal places: (%d,%d) %d\n",
|
||||
minmea_rescale(&frame.latitude, 1000),
|
||||
minmea_rescale(&frame.longitude, 1000),
|
||||
minmea_rescale(&frame.speed, 1000));
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxRMC floating point degree coordinates and speed: (%f,%f) %f\n",
|
||||
minmea_tocoord(&frame.latitude),
|
||||
minmea_tocoord(&frame.longitude),
|
||||
minmea_tofloat(&frame.speed));
|
||||
}
|
||||
else {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxRMC sentence is not parsed\n");
|
||||
}
|
||||
} break;
|
||||
case MINMEA_SENTENCE_GGA: {
|
||||
struct minmea_sentence_gga frame;
|
||||
if (minmea_parse_gga(&frame, gpsdata)) {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxGGA: fix quality: %d\n", frame.fix_quality);
|
||||
}
|
||||
else {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxGGA sentence is not parsed\n");
|
||||
}
|
||||
} break;
|
||||
case MINMEA_SENTENCE_GST: {
|
||||
struct minmea_sentence_gst frame;
|
||||
if (minmea_parse_gst(&frame, gpsdata)) {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxGST: raw latitude,longitude and altitude error deviation: (%d/%d,%d/%d,%d/%d)\n",
|
||||
frame.latitude_error_deviation.value, frame.latitude_error_deviation.scale,
|
||||
frame.longitude_error_deviation.value, frame.longitude_error_deviation.scale,
|
||||
frame.altitude_error_deviation.value, frame.altitude_error_deviation.scale);
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxGST fixed point latitude,longitude and altitude error deviation"
|
||||
" scaled to one decimal place: (%d,%d,%d)\n",
|
||||
minmea_rescale(&frame.latitude_error_deviation, 10),
|
||||
minmea_rescale(&frame.longitude_error_deviation, 10),
|
||||
minmea_rescale(&frame.altitude_error_deviation, 10));
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxGST floating point degree latitude, longitude and altitude error deviation: (%f,%f,%f)",
|
||||
minmea_tofloat(&frame.latitude_error_deviation),
|
||||
minmea_tofloat(&frame.longitude_error_deviation),
|
||||
minmea_tofloat(&frame.altitude_error_deviation));
|
||||
}
|
||||
else {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxGST sentence is not parsed\n");
|
||||
}
|
||||
} break;
|
||||
case MINMEA_SENTENCE_GSV: {
|
||||
struct minmea_sentence_gsv frame;
|
||||
if (minmea_parse_gsv(&frame, gpsdata)) {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxGSV: message %d of %d\n", frame.msg_nr, frame.total_msgs);
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxGSV: satellites in view: %d\n", frame.total_sats);
|
||||
for (int i = 0; i < 4; i++)
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxGSV: sat nr %d, elevation: %d, azimuth: %d, snr: %d dbm\n",
|
||||
frame.sats[i].nr,
|
||||
frame.sats[i].elevation,
|
||||
frame.sats[i].azimuth,
|
||||
frame.sats[i].snr);
|
||||
}
|
||||
else {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxGSV sentence is not parsed\n");
|
||||
}
|
||||
} break;
|
||||
case MINMEA_SENTENCE_VTG: {
|
||||
struct minmea_sentence_vtg frame;
|
||||
if (minmea_parse_vtg(&frame, gpsdata)) {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxVTG: true track degrees = %f\n",
|
||||
minmea_tofloat(&frame.true_track_degrees));
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES " magnetic track degrees = %f\n",
|
||||
minmea_tofloat(&frame.magnetic_track_degrees));
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES " speed knots = %f\n",
|
||||
minmea_tofloat(&frame.speed_knots));
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES " speed kph = %f\n",
|
||||
minmea_tofloat(&frame.speed_kph));
|
||||
}
|
||||
else {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxVTG sentence is not parsed\n");
|
||||
}
|
||||
} break;
|
||||
case MINMEA_SENTENCE_ZDA: {
|
||||
struct minmea_sentence_zda frame;
|
||||
if (minmea_parse_zda(&frame, gpsdata)) {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxZDA: %d:%d:%d %02d.%02d.%d UTC%+03d:%02d\n",
|
||||
frame.time.hours,
|
||||
frame.time.minutes,
|
||||
frame.time.seconds,
|
||||
frame.date.day,
|
||||
frame.date.month,
|
||||
frame.date.year,
|
||||
frame.hour_offset,
|
||||
frame.minute_offset);
|
||||
}
|
||||
else {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxZDA sentence is not parsed\n");
|
||||
}
|
||||
} break;
|
||||
case MINMEA_INVALID: {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxxxx sentence is not valid\n");
|
||||
} break;
|
||||
default: {
|
||||
LUAT_DEBUG_PRINT(INDENT_SPACES "$xxxxx sentence is not parsed\n");
|
||||
} break;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void task_demo_gps(void)
|
||||
{
|
||||
luat_rtos_task_create(&gps_task_handle, 1024 * 20, 20, "gps", task_test_gps, NULL, NULL);
|
||||
}
|
||||
|
||||
|
||||
INIT_TASK_EXPORT(task_demo_gps,"1");
|
||||
INIT_TASK_EXPORT(task_demo_https, "2");
|
||||
/* vim: set ts=4 sw=4 et: */
|
||||
@@ -0,0 +1,325 @@
|
||||
#include "common_api.h"
|
||||
#include "sockets.h"
|
||||
#include "dns.h"
|
||||
#include "lwip/ip4_addr.h"
|
||||
#include "netdb.h"
|
||||
#include "luat_debug.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_mobile.h"
|
||||
#include "string.h"
|
||||
#include "lbsLoc.h"
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <stdlib.h>
|
||||
#include <math.h>
|
||||
|
||||
#define DEMO_SERVER_UDP_IP "bs.openluat.com" // 基站定位网址
|
||||
#define DEMO_SERVER_UDP_PORT 12411 // 端口
|
||||
|
||||
/// @brief 合宙IOT 项目productkey ,必须加上,否则定位失败
|
||||
static char *productKey = "vQfJesoQdXDK8X1sXkYg0KTU42UBhdjh";
|
||||
static luat_rtos_task_handle lbsloc_task_handle = NULL;
|
||||
|
||||
static uint8_t lbsloc_task_tatus = 0;
|
||||
|
||||
static bool ddddtoddmm(char *location, char *test)
|
||||
{
|
||||
char *integer = NULL;
|
||||
char *fraction = NULL;
|
||||
char tmpstr[15] = {0};
|
||||
float tmp = 0;
|
||||
integer = strtok(location, ".");
|
||||
if(integer)
|
||||
{
|
||||
fraction = strtok(NULL, ".");
|
||||
sprintf(tmpstr, "0.%d", atoi(fraction));
|
||||
tmp = atof(tmpstr) * 60;
|
||||
tmp = atoi(integer) * 100 + tmp;
|
||||
memset(tmpstr, 0x00, 15);
|
||||
sprintf(tmpstr, "%f", tmp);
|
||||
memcpy(test, tmpstr, strlen(tmpstr) + 1);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
/// @brief 把string 转换为BCD 编码
|
||||
/// @param arr 字符串输入
|
||||
/// @param len 长度
|
||||
/// @param outPut 输出
|
||||
/// @return
|
||||
static uint8_t imeiToBcd(uint8_t *arr, uint8_t len, uint8_t *outPut)
|
||||
{
|
||||
if (len % 2 != 0)
|
||||
{
|
||||
arr[len] = 0x0f;
|
||||
}
|
||||
|
||||
uint8_t tmp = 0;
|
||||
|
||||
for (uint8_t j = 0; j < len; j = j + 2)
|
||||
{
|
||||
outPut[tmp] = (arr[j] & 0x0f) << 4 | (arr[j + 1] & 0x0f);
|
||||
tmp++;
|
||||
}
|
||||
for (uint8_t i = 0; i < 8; i++)
|
||||
{
|
||||
outPut[i] = (outPut[i] % 0x10) * 0x10 + (outPut[i] - (outPut[i] % 0x10)) / 0x10;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
/// @brief BCD ->> str
|
||||
/// @param pOutBuffer
|
||||
/// @param pInBuffer
|
||||
/// @param nInLen 长度
|
||||
/// @return
|
||||
static uint32_t location_service_bcd_to_str(uint8_t *pOutBuffer, uint8_t *pInBuffer, uint32_t nInLen)
|
||||
{
|
||||
uint32_t len = 0;
|
||||
uint8_t ch;
|
||||
uint8_t *p = pOutBuffer;
|
||||
uint32_t i = 0;
|
||||
|
||||
if (pOutBuffer == NULL || pInBuffer == NULL || nInLen == 0)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
for (i = 0; i < nInLen; i++)
|
||||
{
|
||||
ch = pInBuffer[i] & 0x0F;
|
||||
if (ch == 0x0F)
|
||||
{
|
||||
break;
|
||||
}
|
||||
*pOutBuffer++ = ch + '0';
|
||||
|
||||
ch = (pInBuffer[i] >> 4) & 0x0F;
|
||||
if (ch == 0x0F)
|
||||
{
|
||||
break;
|
||||
}
|
||||
*pOutBuffer++ = ch + '0';
|
||||
}
|
||||
|
||||
len = pOutBuffer - p;
|
||||
|
||||
return len;
|
||||
}
|
||||
|
||||
static bool location_service_parse_response(struct am_location_service_rsp_data_t *response, uint8_t *latitude, uint8_t *longitude,
|
||||
uint16_t *year, uint8_t *month, uint8_t *day, uint8_t *hour, uint8_t *minute, uint8_t *second)
|
||||
{
|
||||
uint8_t loc[20] = {0};
|
||||
uint32_t len = 0;
|
||||
|
||||
if (response == NULL || latitude == NULL || longitude == NULL || year == NULL || month == NULL || day == NULL || hour == NULL || minute == NULL || second == NULL)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("location_service_parse_response: invalid parameter");
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
if (!(response->result == 0 || response->result == 0xFF))
|
||||
{
|
||||
LUAT_DEBUG_PRINT("location_service_parse_response: result fail %d", response->result);
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
// latitude
|
||||
len = location_service_bcd_to_str(loc, response->latitude, AM_LOCATION_SERVICE_LOCATION_BCD_LEN);
|
||||
if (len <= 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("location_service_parse_response: latitude fail");
|
||||
return FALSE;
|
||||
}
|
||||
strncat((char *)latitude, (char *)loc, 3);
|
||||
strncat((char *)latitude, ".", 2);
|
||||
strncat((char *)latitude, (char *)(loc + 3), len - 3);
|
||||
len = location_service_bcd_to_str(loc, response->longitude, AM_LOCATION_SERVICE_LOCATION_BCD_LEN);
|
||||
if (len <= 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("location_service_parse_response: longitude fail");
|
||||
return FALSE;
|
||||
}
|
||||
strncat((char *)longitude, (char *)loc, 3);
|
||||
strncat((char *)longitude, (char *)".", 2);
|
||||
strncat((char *)longitude, (char *)(loc + 3), len - 3);
|
||||
*year = response->year + 2000;
|
||||
*month = response->month;
|
||||
*day = response->day;
|
||||
*hour = response->hour;
|
||||
*minute = response->minute;
|
||||
*second = response->second;
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
static void lbsloc_task(void *arg)
|
||||
{
|
||||
lbsloc_task_tatus = 1;
|
||||
ip_addr_t remote_ip;
|
||||
struct sockaddr_in name;
|
||||
socklen_t sockaddr_t_size = sizeof(name);
|
||||
int ret;
|
||||
struct timeval to;
|
||||
int socket_id = -1;
|
||||
struct hostent dns_result;
|
||||
struct hostent *p_result;
|
||||
int h_errnop, read_len;
|
||||
struct am_location_service_rsp_data_t locationServiceResponse;
|
||||
|
||||
uint8_t latitude[20] = {0}; // 经度
|
||||
uint8_t longitude[20] = {0}; // 维度
|
||||
uint16_t year = 0; // 年
|
||||
uint8_t month = 0; // 月
|
||||
uint8_t day = 0; // 日
|
||||
uint8_t hour = 0; // 小时
|
||||
uint8_t minute = 0; // 分钟
|
||||
uint8_t second = 0; // 秒
|
||||
uint8_t lbsLocReqBuf[176] = {0};
|
||||
memset(lbsLocReqBuf, 0, 176);
|
||||
uint8_t sendLen = 0;
|
||||
lbsLocReqBuf[sendLen++] = strlen(productKey);
|
||||
memcpy(&lbsLocReqBuf[sendLen], (UINT8 *)productKey, strlen(productKey));
|
||||
sendLen = sendLen + strlen(productKey);
|
||||
lbsLocReqBuf[sendLen++] = 0x28;
|
||||
CHAR imeiBuf[16];
|
||||
memset(imeiBuf, 0, sizeof(imeiBuf));
|
||||
luat_mobile_get_imei(0, imeiBuf, 16);
|
||||
uint8_t imeiBcdBuf[8] = {0};
|
||||
imeiToBcd((uint8_t *)imeiBuf, 15, imeiBcdBuf);
|
||||
memcpy(&lbsLocReqBuf[sendLen], imeiBcdBuf, 8);
|
||||
sendLen = sendLen + 8;
|
||||
CHAR muidBuf[64];
|
||||
memset(muidBuf, 0, sizeof(muidBuf));
|
||||
luat_mobile_get_muid(muidBuf, sizeof(muidBuf));
|
||||
lbsLocReqBuf[sendLen++] = strlen(muidBuf);
|
||||
memcpy(&lbsLocReqBuf[sendLen], (UINT8 *)muidBuf, strlen(muidBuf));
|
||||
sendLen = sendLen + strlen(muidBuf);
|
||||
luat_mobile_cell_info_t cell_info;
|
||||
memset(&cell_info, 0, sizeof(cell_info));
|
||||
luat_mobile_get_cell_info(&cell_info);
|
||||
lbsLocReqBuf[sendLen++] = 0x01;
|
||||
lbsLocReqBuf[sendLen++] = (cell_info.lte_service_info.tac >> 8) & 0xFF;
|
||||
lbsLocReqBuf[sendLen++] = cell_info.lte_service_info.tac & 0xFF;
|
||||
lbsLocReqBuf[sendLen++] = (cell_info.lte_service_info.mcc >> 8) & 0xFF;
|
||||
lbsLocReqBuf[sendLen++] = cell_info.lte_service_info.mcc & 0XFF;
|
||||
uint8_t mnc = cell_info.lte_service_info.mnc;
|
||||
if (mnc > 10)
|
||||
{
|
||||
CHAR buf[3] = {0};
|
||||
snprintf(buf, 3, "%02x", mnc);
|
||||
int ret1 = atoi(buf);
|
||||
lbsLocReqBuf[sendLen++] = ret1;
|
||||
}
|
||||
else
|
||||
{
|
||||
lbsLocReqBuf[sendLen++] = mnc;
|
||||
}
|
||||
int16_t sRssi;
|
||||
uint8_t retRssi;
|
||||
sRssi = cell_info.lte_service_info.rssi;
|
||||
if (sRssi <= -113)
|
||||
{
|
||||
retRssi = 0;
|
||||
}
|
||||
else if (sRssi < -52)
|
||||
{
|
||||
retRssi = (sRssi + 113) >> 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
retRssi = 31;
|
||||
}
|
||||
lbsLocReqBuf[sendLen++] = retRssi;
|
||||
lbsLocReqBuf[sendLen++] = (cell_info.lte_service_info.cid >> 24) & 0xFF;
|
||||
lbsLocReqBuf[sendLen++] = (cell_info.lte_service_info.cid >> 16) & 0xFF;
|
||||
lbsLocReqBuf[sendLen++] = (cell_info.lte_service_info.cid >> 8) & 0xFF;
|
||||
lbsLocReqBuf[sendLen++] = cell_info.lte_service_info.cid & 0xFF;
|
||||
|
||||
char hostname[128] = {0};
|
||||
ret = lwip_gethostbyname_r(DEMO_SERVER_UDP_IP, &dns_result, hostname, 128, &p_result, &h_errnop);
|
||||
if (!ret)
|
||||
{
|
||||
remote_ip = *((ip_addr_t *)dns_result.h_addr_list[0]);
|
||||
}
|
||||
else
|
||||
{
|
||||
luat_rtos_task_sleep(1000);
|
||||
LUAT_DEBUG_PRINT("dns fail");
|
||||
lbsloc_task_tatus = 0;
|
||||
luat_rtos_task_delete(lbsloc_task_handle);
|
||||
return;
|
||||
}
|
||||
|
||||
socket_id = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
|
||||
struct timeval timeout;
|
||||
timeout.tv_sec = AM_LOCATION_SERVICE_RCV_TIMEOUT;
|
||||
timeout.tv_usec = 0;
|
||||
setsockopt(socket_id, SOL_SOCKET, SO_RCVTIMEO, &timeout, sizeof(timeout));
|
||||
memset(&name, 0, sizeof(name));
|
||||
name.sin_family = AF_INET;
|
||||
name.sin_addr.s_addr = remote_ip.u_addr.ip4.addr;
|
||||
name.sin_port = htons(DEMO_SERVER_UDP_PORT);
|
||||
ret = sendto(socket_id, lbsLocReqBuf, sendLen, 0, (const struct sockaddr *)&name, sockaddr_t_size);
|
||||
if (ret == sendLen)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("lbsLocSendRequest send lbsLoc request success");
|
||||
ret = recv(socket_id, &locationServiceResponse, sizeof(struct am_location_service_rsp_data_t), 0);
|
||||
if (sizeof(struct am_location_service_rsp_data_t) == ret)
|
||||
{
|
||||
if (location_service_parse_response(&locationServiceResponse, latitude, longitude, &year, &month, &day, &hour, &minute, &second) == TRUE)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("latitude:%s,longitude:%s,year:%d,month:%d,day:%d,hour:%d,minute:%d,second:%d\r\n", latitude, longitude, year, month, day, hour, minute, second);
|
||||
char data_buf[60] = {0};
|
||||
snprintf(data_buf, 60, "$AIDTIME,%d,%d,%d,%d,%d,%d,000\r\n", year, month, day, hour, minute, second);
|
||||
luat_uart_write(2, data_buf, strlen(data_buf));
|
||||
LUAT_DEBUG_PRINT("this is test1 %s", data_buf);
|
||||
luat_rtos_task_sleep(200);
|
||||
|
||||
memset(data_buf, 0x00, 60);
|
||||
|
||||
char lat[20] = {0};
|
||||
char lng[20] = {0};
|
||||
ddddtoddmm(latitude, lat);
|
||||
LUAT_DEBUG_PRINT("this is test2 %s", lat);
|
||||
ddddtoddmm(longitude, lng);
|
||||
LUAT_DEBUG_PRINT("this is test3 %s", lng);
|
||||
snprintf(data_buf, 60, "$AIDPOS,%s,N,%s,E,1.0\r\n", lat, lng);
|
||||
LUAT_DEBUG_PRINT("this is test4 %s", data_buf);
|
||||
luat_uart_write(2, data_buf, strlen(data_buf));
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("location_service_task: rcv response, but process fail");
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("lbsLocSendRequest send lbsLoc request fail");
|
||||
}
|
||||
memset(latitude, 0, 20);
|
||||
memset(longitude, 0, 20);
|
||||
year = 0;
|
||||
month = 0;
|
||||
day = 0;
|
||||
hour = 0;
|
||||
minute = 0;
|
||||
second = 0;
|
||||
LUAT_DEBUG_PRINT("socket quit");
|
||||
close(socket_id);
|
||||
socket_id = -1;
|
||||
lbsloc_task_tatus = 0;
|
||||
luat_rtos_task_delete(lbsloc_task_handle);
|
||||
}
|
||||
|
||||
void demo_udp_init(void)
|
||||
{
|
||||
if (lbsloc_task_handle == NULL || lbsloc_task_tatus == 0)
|
||||
luat_rtos_task_create(&lbsloc_task_handle, 4 * 2048, 80, "udp", lbsloc_task, NULL, NULL);
|
||||
else
|
||||
LUAT_DEBUG_PRINT("lbsloc task create fail");
|
||||
}
|
||||
@@ -0,0 +1,24 @@
|
||||
local TARGET_NAME = "example_gnss"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
includes(SDK_TOP .. "/thirdparty/minmea")
|
||||
add_deps("minmea")
|
||||
includes(SDK_TOP .. "/thirdparty/httpclient")
|
||||
add_deps("httpclient")
|
||||
--加入代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,350 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 1
|
||||
#define RTE_UART1_RTS_PIN_EN 1
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN21}, // 0 : gpio16 / 1 : UART1 RTS / 2 : SPI0 SSn
|
||||
// { PAD_PIN22}, // 0 : gpio11 / 1 : UART1 CTS / 2 : SPI0 MOSI
|
||||
// { PAD_PIN23}, // 0 : gpio14 / 1 : UART1 RXD / 2 : SPI0 MISO
|
||||
// { PAD_PIN24}, // 0 : gpio15 / 1 : UART1 TXD / 2 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 21
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 22
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 23
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 24
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 1
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 0
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 1
|
||||
|
||||
// { PAD_PIN13}, // 0 : gpio2 / 1 : UART0 RTSn / 3 : SPI1 SSn
|
||||
// { PAD_PIN14}, // 0 : gpio3 / 1 : UART0 CTSn / 3 : SPI1 MOSI
|
||||
// { PAD_PIN15}, // 0 : gpio4 / 1 : UART0 RXD / 3 : SPI1 MISO
|
||||
// { PAD_PIN16}, // 0 : gpio5 / 1 : UART0 TXD / 3 : SPI1 SCLK
|
||||
#define RTE_SPI1_SSN_BIT 13
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 14
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 15
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 16
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,284 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
#include "common_api.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_debug.h"
|
||||
#include "luat_gpio.h"
|
||||
#include "platform_define.h"
|
||||
|
||||
/*
|
||||
移芯618平台上GPIO使用有如下注意事项:
|
||||
|
||||
系统有几种工作模式:ACTIVE、IDLE、SLEEP1、SLEEP2、HIBERNATE,几种模式的区别,参考example_pm的说明;
|
||||
|
||||
1、IO分为normal IO和retention/AON IO两种
|
||||
normal IO:普通IO
|
||||
在ACTIVE和IDLE工作模式下,可以正常控制使用;
|
||||
在SLEEP1、SLEEP2、HIBERNATE工作模式下,IO电源被强制关闭,无法使用;
|
||||
retention/AON IO:保持IO
|
||||
在ACTIVE和IDLE工作模式下,可以正常控制使用;
|
||||
在SLEEP1、SLEEP2、HIBERNATE工作模式下,只能作为输出使用,而且只能维持一种输出电平状态,无法翻转控制;
|
||||
|
||||
2、带AON功能的引脚,做retention/AON IO功能或者其他外设功能使用时,做软件配置上拉无效,只能使用默认的上下拉;
|
||||
|
||||
3、系统进入SLEEP1、SLEEP2、HIBERNATE休眠模式后,除了软件运行代码调用唤醒接口可以主动唤醒外,可以唤醒的外部事件有以下几种:
|
||||
(1). 配置为wakeup软件功能的wakeup pad引脚;
|
||||
(2). low power uart,如果波特率为9600,唤醒时数据也不会丢失,其他波特率会丢失前面的部分数据;
|
||||
(3). low power usb
|
||||
(4). power key;
|
||||
(5). charge pad;
|
||||
(6). rtc;
|
||||
详情参考example_pm的说明。
|
||||
|
||||
4、所有IO都支持中断:
|
||||
GPIO20、GPIO21、GPIO22三个IO支持同时配置为双边沿中断或者同时配置为高低电平中断;
|
||||
|
||||
其余GPIO仅支持单边沿、单电平中断;如果这些GPIO配置了双边沿或者双电平中断,则会被系统自动调整配置为上升沿或者高电平中断;
|
||||
所以为了防止被系统自动调整配置,其余的这些GPIO,使用中断时仅配置为单边沿或者单电平中断。
|
||||
*/
|
||||
|
||||
//本example基于EVB_Air780E_V1.5硬件
|
||||
|
||||
#define NET_LED_PIN HAL_GPIO_27
|
||||
#define LCD_RST_PIN HAL_GPIO_1
|
||||
|
||||
#define LCD_RS_PIN HAL_GPIO_10
|
||||
#define LCD_CS_PIN HAL_GPIO_8
|
||||
|
||||
#define DTR_PIN HAL_GPIO_22
|
||||
#define LCD_DATA_PIN HAL_GPIO_9
|
||||
|
||||
#define DEMO_IRQ_PIN HAL_GPIO_20
|
||||
|
||||
//控制NET指示灯闪烁
|
||||
static void task_gpio_output_run(void *param)
|
||||
{
|
||||
luat_gpio_cfg_t gpio_cfg;
|
||||
luat_gpio_set_default_cfg(&gpio_cfg);
|
||||
|
||||
gpio_cfg.pin = NET_LED_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
while(1)
|
||||
{
|
||||
luat_gpio_set(NET_LED_PIN, 1);
|
||||
LUAT_DEBUG_PRINT("net led on");
|
||||
luat_rtos_task_sleep(1000);
|
||||
luat_gpio_set(NET_LED_PIN, 0);
|
||||
LUAT_DEBUG_PRINT("net led off");
|
||||
luat_rtos_task_sleep(1000);
|
||||
}
|
||||
}
|
||||
|
||||
void task_gpio_output_init(void)
|
||||
{
|
||||
luat_rtos_task_handle task_gpio_output_handle;
|
||||
luat_rtos_task_create(&task_gpio_output_handle, 4 * 1204, 50, "gpio_output_test", task_gpio_output_run, NULL, 32);
|
||||
}
|
||||
|
||||
|
||||
//LCD_RST引脚和NET引脚短接
|
||||
//NET引脚:通过task_gpio_output_run函数每隔一秒翻转一次输出高低电平
|
||||
//LCD_RST引脚:每隔一秒读取一次输入电平
|
||||
void task_gpio_input_run(void)
|
||||
{
|
||||
luat_gpio_cfg_t gpio_cfg;
|
||||
luat_gpio_set_default_cfg(&gpio_cfg);
|
||||
|
||||
gpio_cfg.pin = LCD_RST_PIN;
|
||||
gpio_cfg.mode = LUAT_GPIO_INPUT;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
|
||||
int level = 0;
|
||||
|
||||
while(1)
|
||||
{
|
||||
level = luat_gpio_get(LCD_RST_PIN);
|
||||
LUAT_DEBUG_PRINT("get lcd rst pin %d",level);
|
||||
luat_rtos_task_sleep(1000);
|
||||
level = luat_gpio_get(LCD_RST_PIN);
|
||||
LUAT_DEBUG_PRINT("get lcd rst pin %d",level);
|
||||
luat_rtos_task_sleep(1000);
|
||||
}
|
||||
}
|
||||
|
||||
void task_gpio_input_init(void)
|
||||
{
|
||||
luat_rtos_task_handle task_gpio_input_handle;
|
||||
luat_rtos_task_create(&task_gpio_input_handle, 4 * 1204, 50, "gpio_input_test", task_gpio_input_run, NULL, 32);
|
||||
}
|
||||
|
||||
int single_interrupt_cnt = 0;
|
||||
int both_interrupt_cnt = 0;
|
||||
int gpio_irq(int pin, void* args)
|
||||
{
|
||||
if (pin == LCD_CS_PIN)
|
||||
{
|
||||
single_interrupt_cnt++;
|
||||
}
|
||||
else if (pin == DTR_PIN)
|
||||
{
|
||||
both_interrupt_cnt++;
|
||||
}
|
||||
|
||||
//注意:中断服务程序中的一行LUAT_DEBUG_PRINT日志,如果通过Luatools查看,最多仅支持64字节
|
||||
LUAT_DEBUG_PRINT("pin:%d, level:%d,", pin, luat_gpio_get(pin));
|
||||
}
|
||||
|
||||
//GPIO单边沿中断测试
|
||||
void task_gpio_single_interrupt_run(void)
|
||||
{
|
||||
luat_gpio_cfg_t gpio_cfg;
|
||||
|
||||
//配置LCD_CS_PIN为中断引脚
|
||||
luat_gpio_set_default_cfg(&gpio_cfg);
|
||||
gpio_cfg.pin = LCD_CS_PIN;
|
||||
gpio_cfg.mode = LUAT_GPIO_IRQ;
|
||||
|
||||
//LCD_CS_PIN引脚仅支持单边沿或者单电平类型的中断;
|
||||
//此处仅演示单边沿中断,配置为LUAT_GPIO_RISING_IRQ、LUAT_GPIO_FALLING_IRQ
|
||||
//不要配置为LUAT_GPIO_BOTH_IRQ,因为配置为LUAT_GPIO_BOTH_IRQ会被系统自动修改为LUAT_GPIO_RISING_IRQ;
|
||||
gpio_cfg.irq_type = LUAT_GPIO_RISING_IRQ;
|
||||
|
||||
gpio_cfg.pull = LUAT_GPIO_PULLUP;
|
||||
gpio_cfg.irq_cb = gpio_irq;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
|
||||
//配置LCD_RS_PIN为输出引脚
|
||||
luat_gpio_set_default_cfg(&gpio_cfg);
|
||||
gpio_cfg.pin = LCD_RS_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
|
||||
while(1)
|
||||
{
|
||||
luat_gpio_set(LCD_RS_PIN, 1);
|
||||
LUAT_DEBUG_PRINT("LCD_RS output %d, LCD_CS input %d",luat_gpio_get(LCD_RS_PIN), luat_gpio_get(LCD_CS_PIN));
|
||||
luat_rtos_task_sleep(1000);
|
||||
LUAT_DEBUG_PRINT("after high input, number of single interrupts %d", single_interrupt_cnt);
|
||||
|
||||
luat_gpio_set(LCD_RS_PIN, 0);
|
||||
LUAT_DEBUG_PRINT("LCD_RS output %d, LCD_CS input %d",luat_gpio_get(LCD_RS_PIN), luat_gpio_get(LCD_CS_PIN));
|
||||
luat_rtos_task_sleep(1000);
|
||||
LUAT_DEBUG_PRINT("after low input, number of single interrupts %d", single_interrupt_cnt);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
void task_gpio_single_interrupt_init(void)
|
||||
{
|
||||
luat_rtos_task_handle task_gpio_single_interrupt_handle;
|
||||
luat_rtos_task_create(&task_gpio_single_interrupt_handle, 4 * 1204, 50, "gpio_single_interrupt_test", task_gpio_single_interrupt_run, NULL, 32);
|
||||
}
|
||||
|
||||
|
||||
//GPIO双边沿中断测试
|
||||
void task_gpio_both_interrupt_run(void)
|
||||
{
|
||||
luat_gpio_cfg_t gpio_cfg;
|
||||
|
||||
//配置DTR为中断引脚
|
||||
luat_gpio_set_default_cfg(&gpio_cfg);
|
||||
gpio_cfg.pin = DTR_PIN;
|
||||
gpio_cfg.mode = LUAT_GPIO_IRQ;
|
||||
|
||||
//DTR_PIN引脚支持双边沿或者高低电平类型的中断;
|
||||
//此处仅演示双边沿中断,可以配置为LUAT_GPIO_BOTH_IRQ、LUAT_GPIO_RISING_IRQ、LUAT_GPIO_FALLING_IRQ
|
||||
gpio_cfg.irq_type = LUAT_GPIO_BOTH_IRQ;
|
||||
|
||||
gpio_cfg.pull = LUAT_GPIO_PULLUP;
|
||||
gpio_cfg.irq_cb = gpio_irq;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
|
||||
//配置LCD_DATA_PIN为输出引脚
|
||||
luat_gpio_set_default_cfg(&gpio_cfg);
|
||||
gpio_cfg.pin = LCD_DATA_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
|
||||
while(1)
|
||||
{
|
||||
luat_gpio_set(LCD_DATA_PIN, 1);
|
||||
LUAT_DEBUG_PRINT("LCD_DATA output %d, DTR input %d",luat_gpio_get(LCD_DATA_PIN), luat_gpio_get(DTR_PIN));
|
||||
luat_rtos_task_sleep(1000);
|
||||
LUAT_DEBUG_PRINT("after high input, number of both interrupts %d", both_interrupt_cnt);
|
||||
|
||||
luat_gpio_set(LCD_DATA_PIN, 0);
|
||||
LUAT_DEBUG_PRINT("LCD_DATA output %d, DTR input %d",luat_gpio_get(LCD_DATA_PIN), luat_gpio_get(DTR_PIN));
|
||||
luat_rtos_task_sleep(1000);
|
||||
LUAT_DEBUG_PRINT("after low input, number of both interrupts %d", both_interrupt_cnt);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
void task_gpio_both_interrupt_init(void)
|
||||
{
|
||||
luat_rtos_task_handle task_gpio_both_interrupt_handle;
|
||||
luat_rtos_task_create(&task_gpio_both_interrupt_handle, 4 * 1204, 50, "gpio_both_interrupt_test", task_gpio_both_interrupt_run, NULL, 32);
|
||||
}
|
||||
int gpio_level_irq(void *data, void* args)
|
||||
{
|
||||
int pin = (int)data;
|
||||
LUAT_DEBUG_PRINT("pin:%d, level:%d,", pin, luat_gpio_get(pin));
|
||||
luat_gpio_ctrl(DEMO_IRQ_PIN, LUAT_GPIO_CMD_SET_IRQ_MODE, LUAT_GPIO_NO_IRQ);
|
||||
}
|
||||
//GPIO电平中断测试
|
||||
void task_gpio_level_interrupt_run(void)
|
||||
{
|
||||
luat_gpio_cfg_t gpio_cfg;
|
||||
|
||||
//配置HAL_GPIO_20为中断引脚
|
||||
luat_gpio_set_default_cfg(&gpio_cfg);
|
||||
gpio_cfg.pin = DEMO_IRQ_PIN;
|
||||
gpio_cfg.mode = LUAT_GPIO_IRQ;
|
||||
|
||||
//DTR_PIN引脚支持双边沿或者高低电平类型的中断;
|
||||
//所以此处可以配置为LUAT_GPIO_BOTH_IRQ、LUAT_GPIO_RISING_IRQ、LUAT_GPIO_FALLING_IRQ、LUAT_GPIO_HIGH_IRQ、LUAT_GPIO_LOW_IRQ、
|
||||
gpio_cfg.irq_type = LUAT_GPIO_HIGH_IRQ;
|
||||
|
||||
gpio_cfg.pull = LUAT_GPIO_PULLUP;
|
||||
gpio_cfg.irq_cb = gpio_level_irq;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
|
||||
while(1)
|
||||
{
|
||||
if (!luat_gpio_get(DEMO_IRQ_PIN))
|
||||
{
|
||||
LUAT_DEBUG_PRINT("IO已经低电平,可以再次开启高电平中断");
|
||||
luat_gpio_ctrl(DEMO_IRQ_PIN, LUAT_GPIO_CMD_SET_IRQ_MODE, LUAT_GPIO_HIGH_IRQ);
|
||||
}
|
||||
luat_rtos_task_sleep(1000);
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
void task_gpio_level_interrupt_init(void)
|
||||
{
|
||||
luat_rtos_task_handle task_gpio_level_interrupt_handle;
|
||||
luat_rtos_task_create(&task_gpio_level_interrupt_handle, 1024, 50, "gpio_level_interrupt_test", task_gpio_level_interrupt_run, NULL, 0);
|
||||
}
|
||||
|
||||
|
||||
|
||||
INIT_TASK_EXPORT(task_gpio_output_init, "0");
|
||||
INIT_TASK_EXPORT(task_gpio_input_init, "1");
|
||||
INIT_TASK_EXPORT(task_gpio_single_interrupt_init, "2");
|
||||
INIT_TASK_EXPORT(task_gpio_both_interrupt_init, "3");
|
||||
INIT_TASK_EXPORT(task_gpio_level_interrupt_init, "4");
|
||||
@@ -0,0 +1,27 @@
|
||||
local TARGET_NAME = "example_gpio"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
|
||||
-- 按需链接mbedtls
|
||||
-- add_defines("MBEDTLS_CONFIG_FILE=\"config_ec_ssl_comm.h\"")
|
||||
-- add_files(SDK_TOP .. "PLAT/middleware/thirdparty/mbedtls/library/*.c")
|
||||
-- 按需编译httpclient
|
||||
-- add_files(SDK_TOP .. "PLAT/middleware/thirdparty/httpclient/*.c")
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,350 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 1
|
||||
#define RTE_UART1_RTS_PIN_EN 1
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN21}, // 0 : gpio16 / 1 : UART1 RTS / 2 : SPI0 SSn
|
||||
// { PAD_PIN22}, // 0 : gpio11 / 1 : UART1 CTS / 2 : SPI0 MOSI
|
||||
// { PAD_PIN23}, // 0 : gpio14 / 1 : UART1 RXD / 2 : SPI0 MISO
|
||||
// { PAD_PIN24}, // 0 : gpio15 / 1 : UART1 TXD / 2 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 21
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 22
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 23
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 24
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 1
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 0
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 1
|
||||
|
||||
// { PAD_PIN13}, // 0 : gpio2 / 1 : UART0 RTSn / 3 : SPI1 SSn
|
||||
// { PAD_PIN14}, // 0 : gpio3 / 1 : UART0 CTSn / 3 : SPI1 MOSI
|
||||
// { PAD_PIN15}, // 0 : gpio4 / 1 : UART0 RXD / 3 : SPI1 MISO
|
||||
// { PAD_PIN16}, // 0 : gpio5 / 1 : UART0 TXD / 3 : SPI1 SCLK
|
||||
#define RTE_SPI1_SSN_BIT 13
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 14
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 15
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 16
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,189 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
#include "common_api.h"
|
||||
#include "luat_mobile.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_debug.h"
|
||||
|
||||
#include "HTTPClient.h"
|
||||
|
||||
//ciphersuite: TLS-RSA-WITH-AES-128-CBC-SHA msglen = 2609
|
||||
//support session ticket/fragment
|
||||
#define TEST_SERVER_NAME "https://www.howsmyssl.com:443/a/check"
|
||||
|
||||
#define TEST_HOST "https://www.howsmyssl.com:443"
|
||||
#define HTTP_RECV_BUF_SIZE (1501)
|
||||
#define HTTP_HEAD_BUF_SIZE (800)
|
||||
|
||||
static HttpClientContext gHttpClient = {0};
|
||||
|
||||
static const char *testCaCrt = \
|
||||
{
|
||||
\
|
||||
"-----BEGIN CERTIFICATE-----\r\n"
|
||||
"MIIDSjCCAjKgAwIBAgIQRK+wgNajJ7qJMDmGLvhAazANBgkqhkiG9w0BAQUFADA/\r\n" \
|
||||
"MSQwIgYDVQQKExtEaWdpdGFsIFNpZ25hdHVyZSBUcnVzdCBDby4xFzAVBgNVBAMT\r\n" \
|
||||
"DkRTVCBSb290IENBIFgzMB4XDTAwMDkzMDIxMTIxOVoXDTIxMDkzMDE0MDExNVow\r\n" \
|
||||
"PzEkMCIGA1UEChMbRGlnaXRhbCBTaWduYXR1cmUgVHJ1c3QgQ28uMRcwFQYDVQQD\r\n" \
|
||||
"Ew5EU1QgUm9vdCBDQSBYMzCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB\r\n" \
|
||||
"AN+v6ZdQCINXtMxiZfaQguzH0yxrMMpb7NnDfcdAwRgUi+DoM3ZJKuM/IUmTrE4O\r\n" \
|
||||
"rz5Iy2Xu/NMhD2XSKtkyj4zl93ewEnu1lcCJo6m67XMuegwGMoOifooUMM0RoOEq\r\n" \
|
||||
"OLl5CjH9UL2AZd+3UWODyOKIYepLYYHsUmu5ouJLGiifSKOeDNoJjj4XLh7dIN9b\r\n" \
|
||||
"xiqKqy69cK3FCxolkHRyxXtqqzTWMIn/5WgTe1QLyNau7Fqckh49ZLOMxt+/yUFw\r\n" \
|
||||
"7BZy1SbsOFU5Q9D8/RhcQPGX69Wam40dutolucbY38EVAjqr2m7xPi71XAicPNaD\r\n" \
|
||||
"aeQQmxkqtilX4+U9m5/wAl0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNV\r\n" \
|
||||
"HQ8BAf8EBAMCAQYwHQYDVR0OBBYEFMSnsaR7LHH62+FLkHX/xBVghYkQMA0GCSqG\r\n" \
|
||||
"SIb3DQEBBQUAA4IBAQCjGiybFwBcqR7uKGY3Or+Dxz9LwwmglSBd49lZRNI+DT69\r\n" \
|
||||
"ikugdB/OEIKcdBodfpga3csTS7MgROSR6cz8faXbauX+5v3gTt23ADq1cEmv8uXr\r\n" \
|
||||
"AvHRAosZy5Q6XkjEGB5YGV8eAlrwDPGxrancWYaLbumR9YbK+rlmM6pZW87ipxZz\r\n" \
|
||||
"R8srzJmwN0jP41ZL9c8PDHIyh8bwRLtTcm1D9SZImlJnt1ir/md2cXjbDaJWFBM5\r\n" \
|
||||
"JDGFoqgCWjBH4d1QB7wCCZAA62RjYJsWvIjJEubSfZGL+T0yjWW06XyxV3bqxbYo\r\n" \
|
||||
"Ob8VZRzI9neWagqNdwvYkQsEjgfbKbYK7p2CNTUQ\r\n" \
|
||||
"-----END CERTIFICATE-----"
|
||||
};
|
||||
|
||||
/**
|
||||
\fn INT32 httpGetData(CHAR *getUrl, CHAR *buf, UINT32 len)
|
||||
\brief
|
||||
\return
|
||||
*/
|
||||
static INT32 httpGetData(CHAR *getUrl, CHAR *buf, UINT32 len)
|
||||
{
|
||||
HTTPResult result = HTTP_INTERNAL;
|
||||
HttpClientData clientData = {0};
|
||||
UINT32 count = 0;
|
||||
uint16_t headerLen = 0;
|
||||
|
||||
LUAT_DEBUG_ASSERT(buf != NULL,0,0,0);
|
||||
|
||||
clientData.headerBuf = malloc(HTTP_HEAD_BUF_SIZE);
|
||||
clientData.headerBufLen = HTTP_HEAD_BUF_SIZE;
|
||||
clientData.respBuf = buf;
|
||||
clientData.respBufLen = len;
|
||||
|
||||
result = httpSendRequest(&gHttpClient, getUrl, HTTP_GET, &clientData);
|
||||
LUAT_DEBUG_PRINT("send request result=%d", result);
|
||||
if (result != HTTP_OK)
|
||||
goto exit;
|
||||
do {
|
||||
LUAT_DEBUG_PRINT("recvResponse loop.");
|
||||
memset(clientData.headerBuf, 0, clientData.headerBufLen);
|
||||
memset(clientData.respBuf, 0, clientData.respBufLen);
|
||||
result = httpRecvResponse(&gHttpClient, &clientData);
|
||||
if(result == HTTP_OK || result == HTTP_MOREDATA){
|
||||
headerLen = strlen(clientData.headerBuf);
|
||||
if(headerLen > 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("total content length=%d", clientData.recvContentLength);
|
||||
}
|
||||
|
||||
if(clientData.blockContentLen > 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("response content:{%s}", (uint8_t*)clientData.respBuf);
|
||||
}
|
||||
count += clientData.blockContentLen;
|
||||
LUAT_DEBUG_PRINT("has recv=%d", count);
|
||||
}
|
||||
} while (result == HTTP_MOREDATA || result == HTTP_CONN);
|
||||
|
||||
LUAT_DEBUG_PRINT("result=%d", result);
|
||||
if (gHttpClient.httpResponseCode < 200 || gHttpClient.httpResponseCode > 404)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("invalid http response code=%d",gHttpClient.httpResponseCode);
|
||||
} else if (count == 0 || count != clientData.recvContentLength) {
|
||||
LUAT_DEBUG_PRINT("data not receive complete");
|
||||
} else {
|
||||
LUAT_DEBUG_PRINT("receive success");
|
||||
}
|
||||
exit:
|
||||
free(clientData.headerBuf);
|
||||
return result;
|
||||
}
|
||||
|
||||
luat_rtos_semaphore_t net_semaphore_handle;
|
||||
luat_rtos_task_handle https_task_handle;
|
||||
|
||||
void mobile_event_callback(LUAT_MOBILE_EVENT_E event, uint8_t index, uint8_t status){
|
||||
if (event == LUAT_MOBILE_EVENT_NETIF && status == LUAT_MOBILE_NETIF_LINK_ON){
|
||||
LUAT_DEBUG_PRINT("network ready");
|
||||
luat_rtos_semaphore_release(net_semaphore_handle);
|
||||
}
|
||||
}
|
||||
|
||||
static void task_test_https(void *param)
|
||||
{
|
||||
luat_rtos_semaphore_create(&net_semaphore_handle, 1);
|
||||
|
||||
char *recvBuf = malloc(HTTP_RECV_BUF_SIZE);
|
||||
HTTPResult result = HTTP_INTERNAL;
|
||||
|
||||
luat_mobile_event_register_handler(mobile_event_callback);
|
||||
|
||||
gHttpClient.caCert= (char*)testCaCrt;
|
||||
gHttpClient.caCertLen= strlen(testCaCrt)+1;
|
||||
gHttpClient.timeout_s = 2;
|
||||
gHttpClient.timeout_r = 20;
|
||||
gHttpClient.seclevel = 1;
|
||||
gHttpClient.ciphersuite[0] = 0xFFFF;
|
||||
gHttpClient.ignore = 1;
|
||||
luat_rtos_semaphore_take(net_semaphore_handle, LUAT_WAIT_FOREVER);
|
||||
result = httpConnect(&gHttpClient, TEST_HOST);
|
||||
if (result == HTTP_OK)
|
||||
{
|
||||
httpGetData(TEST_SERVER_NAME, recvBuf, HTTP_RECV_BUF_SIZE);
|
||||
httpClose(&gHttpClient);
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("http client connect error");
|
||||
}
|
||||
|
||||
while(1)
|
||||
{
|
||||
luat_rtos_task_sleep(300000);
|
||||
if (luat_mobile_get_register_status()!=1)
|
||||
{
|
||||
luat_rtos_semaphore_take(net_semaphore_handle, LUAT_WAIT_FOREVER);
|
||||
}
|
||||
result = httpConnect(&gHttpClient, TEST_HOST);
|
||||
if (result == HTTP_OK)
|
||||
{
|
||||
httpGetData(TEST_SERVER_NAME, recvBuf, HTTP_RECV_BUF_SIZE);
|
||||
httpClose(&gHttpClient);
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("http client connect error");
|
||||
}
|
||||
}
|
||||
|
||||
luat_rtos_task_delete(https_task_handle);
|
||||
}
|
||||
|
||||
static void task_demo_https(void)
|
||||
{
|
||||
// https所需的栈空间会大很多
|
||||
luat_rtos_task_create(&https_task_handle, 32*1024, 20, "https", task_test_https, NULL, NULL);
|
||||
}
|
||||
|
||||
//启动task_demoF_init,启动位置任务2级
|
||||
INIT_TASK_EXPORT(task_demo_https, "1");
|
||||
|
||||
@@ -0,0 +1,23 @@
|
||||
local TARGET_NAME = "example_https"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
--使用第三方的httpclient
|
||||
includes(SDK_TOP .. "/thirdparty/httpclient")
|
||||
add_deps("httpclient")
|
||||
--加入代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,354 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN13}, // 4 : gpio14 / 2 : I2C0 SCL
|
||||
// { PAD_PIN14}, // 4 : gpio15 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 13 // AUDIO use 13
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 14 // AUDIO use 14
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 0
|
||||
#define RTE_UART1_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN23}, // 0 : gpio8 / 1 : SPI0 SSn
|
||||
// { PAD_PIN24}, // 0 : gpio9 / 1 : SPI0 MOSI
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 1 : SPI0 MISO
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 1 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 23
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 24
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 25
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 26
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 8
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 1 : SPI1 SSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 1 : SPI1 MOSI
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 1 : SPI1 MISO
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 1 : SPI1 SCLK
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 4 : SPI1 SSn1
|
||||
#define RTE_SPI1_SSN_BIT 27
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 28
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 29
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 30
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 12
|
||||
|
||||
#define RTE_SPI1_SSN1_BIT 31
|
||||
#define RTE_SPI1_SSN1_FUNC PAD_MUX_ALT4
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 0
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,78 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
#include "common_api.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_debug.h"
|
||||
|
||||
#include "luat_i2c.h"
|
||||
|
||||
luat_rtos_task_handle i2c_task_handle;
|
||||
|
||||
#define I2C_ID 0
|
||||
#define AHT10_ADDRESS_ADR_LOW 0x38
|
||||
|
||||
#define AHT10_INIT 0xE1 //初始化命令
|
||||
#define AHT10_MEASURE 0xAC //触发测量命令
|
||||
#define AHT10_SOFT_RESET 0xBA
|
||||
#define AHT10_STATE 0x71 //状态字.
|
||||
|
||||
|
||||
static void task_test_i2c(void *param)
|
||||
{
|
||||
char soft_reset[] = {AHT10_SOFT_RESET};
|
||||
char init_cmd[] = {AHT10_INIT,0x08,0x00};
|
||||
char measure_cmd[] = {AHT10_MEASURE, 0x33, 0x00};
|
||||
char read_cmd[] = {AHT10_STATE};
|
||||
char recv_date[7] = {0};
|
||||
luat_i2c_setup(I2C_ID,1);
|
||||
luat_rtos_task_sleep(40);
|
||||
luat_i2c_send(I2C_ID, AHT10_ADDRESS_ADR_LOW, soft_reset, 1, 1);
|
||||
luat_rtos_task_sleep(20);
|
||||
|
||||
luat_i2c_recv(I2C_ID, AHT10_ADDRESS_ADR_LOW, recv_date, 1);
|
||||
|
||||
if (recv_date[0]&(1<<3) == 0){
|
||||
luat_i2c_send(I2C_ID, AHT10_ADDRESS_ADR_LOW, init_cmd, 3, 1);
|
||||
}
|
||||
while (1)
|
||||
{
|
||||
luat_rtos_task_sleep(1000);
|
||||
luat_i2c_send(I2C_ID, AHT10_ADDRESS_ADR_LOW, measure_cmd, 3, 1);
|
||||
luat_rtos_task_sleep(80);
|
||||
luat_i2c_send(I2C_ID, AHT10_ADDRESS_ADR_LOW, read_cmd, 1, 1);
|
||||
luat_i2c_recv(I2C_ID, AHT10_ADDRESS_ADR_LOW, recv_date, 6);
|
||||
|
||||
float cur_temp = ((recv_date[3] & 0xf) << 16 | recv_date[4] << 8 | recv_date[5]) * 200.0 / (1 << 20) - 50;
|
||||
LUAT_DEBUG_PRINT("temp: %f",cur_temp);
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
static void task_demo_i2c(void)
|
||||
{
|
||||
luat_rtos_task_create(&i2c_task_handle, 1024, 20, "i2c", task_test_i2c, NULL, NULL);
|
||||
}
|
||||
|
||||
INIT_TASK_EXPORT(task_demo_i2c,"1");
|
||||
|
||||
|
||||
|
||||
@@ -0,0 +1,21 @@
|
||||
local TARGET_NAME = "example_i2c"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,349 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 1
|
||||
#define RTE_UART1_RTS_PIN_EN 1
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN21}, // 0 : gpio16 / 1 : UART1 RTS / 2 : SPI0 SSn
|
||||
// { PAD_PIN22}, // 0 : gpio11 / 1 : UART1 CTS / 2 : SPI0 MOSI
|
||||
// { PAD_PIN23}, // 0 : gpio14 / 1 : UART1 RXD / 2 : SPI0 MISO
|
||||
// { PAD_PIN24}, // 0 : gpio15 / 1 : UART1 TXD / 2 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 21
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 22
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 23
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 24
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 1
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 0
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 1
|
||||
|
||||
// { PAD_PIN13}, // 0 : gpio2 / 1 : UART0 RTSn / 3 : SPI1 SSn
|
||||
// { PAD_PIN14}, // 0 : gpio3 / 1 : UART0 CTSn / 3 : SPI1 MOSI
|
||||
// { PAD_PIN15}, // 0 : gpio4 / 1 : UART0 RXD / 3 : SPI1 MISO
|
||||
// { PAD_PIN16}, // 0 : gpio5 / 1 : UART0 TXD / 3 : SPI1 SCLK
|
||||
#define RTE_SPI1_SSN_BIT 13
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 14
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 15
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 16
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,77 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
|
||||
#include "common_api.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_mem.h"
|
||||
#include "luat_debug.h"
|
||||
|
||||
#include "iconv.h"
|
||||
#include "luat_iconv.h"
|
||||
|
||||
luat_rtos_task_handle task_handle;
|
||||
|
||||
|
||||
static void demo_init_iconv()
|
||||
{
|
||||
LUAT_DEBUG_PRINT("==================iconv is running==================");
|
||||
|
||||
char input[] = "LuatOS is coming", output[255];
|
||||
memset(output, 0, sizeof(output));
|
||||
|
||||
char* inPtr = input;
|
||||
char* outPtr = output;
|
||||
size_t inlen = strlen(input);
|
||||
size_t outlen = sizeof(output);
|
||||
|
||||
LUAT_DEBUG_PRINT("The convert inlen is %d", inlen);
|
||||
LUAT_DEBUG_PRINT("The convert outlen is %d", outlen);
|
||||
|
||||
luat_iconv_t cd = luat_iconv_open("utf8", "ucs2");
|
||||
int len = luat_iconv_convert(cd, &inPtr, &inlen, &outPtr, &outlen);
|
||||
LUAT_DEBUG_PRINT("The convert num is %d", len);
|
||||
if (len == 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("The convert before: %s", input);
|
||||
LUAT_DEBUG_PRINT("The convert after: %s", outPtr);
|
||||
}
|
||||
luat_iconv_close(cd);
|
||||
}
|
||||
|
||||
static void task(void *param)
|
||||
{
|
||||
while(1)
|
||||
{
|
||||
demo_init_iconv();
|
||||
luat_rtos_task_sleep(1000);
|
||||
LUAT_DEBUG_PRINT("==================iconv is done==================");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
static void task_demoE_init(void)
|
||||
{
|
||||
luat_rtos_task_create(&task_handle, 2*1024, 50, "task", task, NULL, 0);
|
||||
}
|
||||
|
||||
//启动task_demoE_init,启动位置任务1级
|
||||
INIT_TASK_EXPORT(task_demoE_init, "1");
|
||||
@@ -0,0 +1,23 @@
|
||||
local TARGET_NAME = "example_iconv"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
includes(SDK_TOP .. "/thirdparty/iconv")
|
||||
add_deps("iconv")
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,3 @@
|
||||
# 说明
|
||||
|
||||
* fdb kv数据库,掉电不丢,刷机不丢,全清Flash才丢
|
||||
@@ -0,0 +1,350 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 1
|
||||
#define RTE_UART1_RTS_PIN_EN 1
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN21}, // 0 : gpio16 / 1 : UART1 RTS / 2 : SPI0 SSn
|
||||
// { PAD_PIN22}, // 0 : gpio11 / 1 : UART1 CTS / 2 : SPI0 MOSI
|
||||
// { PAD_PIN23}, // 0 : gpio14 / 1 : UART1 RXD / 2 : SPI0 MISO
|
||||
// { PAD_PIN24}, // 0 : gpio15 / 1 : UART1 TXD / 2 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 21
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 22
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 23
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 24
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 1
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 0
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 1
|
||||
|
||||
// { PAD_PIN13}, // 0 : gpio2 / 1 : UART0 RTSn / 3 : SPI1 SSn
|
||||
// { PAD_PIN14}, // 0 : gpio3 / 1 : UART0 CTSn / 3 : SPI1 MOSI
|
||||
// { PAD_PIN15}, // 0 : gpio4 / 1 : UART0 RXD / 3 : SPI1 MISO
|
||||
// { PAD_PIN16}, // 0 : gpio5 / 1 : UART0 TXD / 3 : SPI1 SCLK
|
||||
#define RTE_SPI1_SSN_BIT 13
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 14
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 15
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 16
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,105 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
|
||||
#include "common_api.h"
|
||||
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_debug.h"
|
||||
#include "luat_kv.h"
|
||||
|
||||
static void kv_demo(void *param)
|
||||
{
|
||||
int ret = 0;
|
||||
char value[256];
|
||||
|
||||
luat_rtos_task_sleep(3000);
|
||||
|
||||
LUAT_DEBUG_PRINT("luat_kv demo");
|
||||
|
||||
// 设置一个key-value
|
||||
// key 最大长度是 64
|
||||
// value 最大长度是 255
|
||||
|
||||
// 设置方式, \0结尾的数据,直接来
|
||||
ret = luat_kv_set("my123", "123", strlen("123"));
|
||||
LUAT_DEBUG_PRINT("kv_set my123 ret %d", ret);
|
||||
memset(value, 0x21, 32);
|
||||
ret = luat_kv_set("my456", value, 32);
|
||||
LUAT_DEBUG_PRINT("kv_set my456 ret %d", ret);
|
||||
|
||||
// luat_kv_get("my123", value, 255);
|
||||
// luat_kv_get("my456", value, 255);
|
||||
|
||||
// 同理, 获取value, kv_kv_get
|
||||
ret = luat_kv_get("my123", value, 255); // 注意留一个字节放0x00
|
||||
LUAT_DEBUG_PRINT("kv_get ret %d", ret);
|
||||
if (ret > 0) {
|
||||
value[ret] = 0x00;
|
||||
LUAT_DEBUG_PRINT("kv read value %s", value);
|
||||
// 写进入的值应该等于写出的值
|
||||
if (memcmp("123", value, strlen("123"))) {
|
||||
LUAT_DEBUG_PRINT("kv value NOT match");
|
||||
}
|
||||
}
|
||||
else {
|
||||
// 前面的逻辑写入字符串"123", 获取时肯定大于0,除非底层出错了
|
||||
LUAT_DEBUG_PRINT("kv read failed");
|
||||
}
|
||||
|
||||
luat_rtos_task_sleep(1000);
|
||||
// 清空整个kv数据, 慎用
|
||||
// 这里只是演示有这个API, 并非使用后要调用该API
|
||||
//luat_kv_clear();
|
||||
|
||||
// 演示结束, task退出.
|
||||
while (1) {
|
||||
luat_rtos_task_sleep(1000);
|
||||
}
|
||||
}
|
||||
|
||||
static void task_demo_kv(void)
|
||||
{
|
||||
|
||||
luat_rtos_task_handle handle;
|
||||
luat_rtos_task_create(&handle, 8*1024, 50, "kv", kv_demo, NULL, 0);
|
||||
}
|
||||
|
||||
static void demo_kv_init(void)
|
||||
{
|
||||
int ret = 0;
|
||||
ret = luat_kv_init();
|
||||
LUAT_DEBUG_PRINT("luat_kv_init ret %d", ret);
|
||||
}
|
||||
|
||||
//启动hw_demoA_init,启动位置硬件初始1级
|
||||
// INIT_HW_EXPORT(hw_demoA_init, "1");
|
||||
//启动hw_demoB_init,启动位置硬件初始2级
|
||||
// INIT_HW_EXPORT(hw_demoB_init, "2");
|
||||
// 启动dr_demoC_init,启动位置驱动1级
|
||||
// INIT_DRV_EXPORT(dr_demo_kv_init, "1");
|
||||
//启动dr_demoD_init,启动位置驱动2级
|
||||
INIT_DRV_EXPORT(demo_kv_init, "2");
|
||||
//启动task_demoE_init,启动位置任务1级
|
||||
// INIT_TASK_EXPORT(task_demoE_init, "1");
|
||||
//启动task_demoF_init,启动位置任务2级
|
||||
INIT_TASK_EXPORT(task_demo_kv, "2");
|
||||
|
||||
@@ -0,0 +1,22 @@
|
||||
local TARGET_NAME = "example_kv"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
|
||||
add_defines("LUAT_USE_KV")
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--add_files("../../thirdparty/fal/src/*.c",{public = true})
|
||||
--add_files("../../thirdparty/flashdb/src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,354 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN13}, // 4 : gpio14 / 2 : I2C0 SCL
|
||||
// { PAD_PIN14}, // 4 : gpio15 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 13 // AUDIO use 13
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 14 // AUDIO use 14
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 0
|
||||
#define RTE_UART1_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN23}, // 0 : gpio8 / 1 : SPI0 SSn
|
||||
// { PAD_PIN24}, // 0 : gpio9 / 1 : SPI0 MOSI
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 1 : SPI0 MISO
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 1 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 0xFF
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 24
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 25
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 26
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 8
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 1 : SPI1 SSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 1 : SPI1 MOSI
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 1 : SPI1 MISO
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 1 : SPI1 SCLK
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 4 : SPI1 SSn1
|
||||
#define RTE_SPI1_SSN_BIT 27
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 28
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 29
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 30
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 12
|
||||
|
||||
#define RTE_SPI1_SSN1_BIT 31
|
||||
#define RTE_SPI1_SSN1_FUNC PAD_MUX_ALT4
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,40 @@
|
||||
#ifndef _LBSLOC_H
|
||||
#define _LBSLOC_H
|
||||
|
||||
#include "commontypedef.h"
|
||||
|
||||
#define AM_LOCATION_SERVICE_LOCATION_BCD_LEN 5
|
||||
#define AM_LOCATION_SERVICE_RCV_TIMEOUT 15
|
||||
|
||||
#ifdef PACK_STRUCT_USE_INCLUDES
|
||||
#include "arch/bpstruct.h"
|
||||
#endif
|
||||
PACK_STRUCT_BEGIN
|
||||
struct am_location_service_rsp_data_t
|
||||
{
|
||||
PACK_STRUCT_FLD_8(u8_t result);
|
||||
PACK_STRUCT_FIELD(u8_t latitude[AM_LOCATION_SERVICE_LOCATION_BCD_LEN]);
|
||||
PACK_STRUCT_FIELD(u8_t longitude[AM_LOCATION_SERVICE_LOCATION_BCD_LEN]);
|
||||
PACK_STRUCT_FLD_8(u8_t year);
|
||||
PACK_STRUCT_FLD_8(u8_t month);
|
||||
PACK_STRUCT_FLD_8(u8_t day);
|
||||
PACK_STRUCT_FLD_8(u8_t hour);
|
||||
PACK_STRUCT_FLD_8(u8_t minute);
|
||||
PACK_STRUCT_FLD_8(u8_t second);
|
||||
} PACK_STRUCT_STRUCT;
|
||||
PACK_STRUCT_END
|
||||
#ifdef PACK_STRUCT_USE_INCLUDES
|
||||
#include "arch/epstruct.h"
|
||||
#endif
|
||||
|
||||
|
||||
|
||||
void lbsloc_Init(void);
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#endif
|
||||
@@ -0,0 +1,72 @@
|
||||
#include "common_api.h"
|
||||
#include "luat_debug.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_mobile.h"
|
||||
#include "lbsLoc.h"
|
||||
uint8_t link_UP = 0;
|
||||
static void mobile_event_callback_t(LUAT_MOBILE_EVENT_E event, uint8_t index, uint8_t status)
|
||||
{
|
||||
switch (event)
|
||||
{
|
||||
case LUAT_MOBILE_EVENT_NETIF:
|
||||
switch (status)
|
||||
{
|
||||
case LUAT_MOBILE_NETIF_LINK_ON:
|
||||
link_UP = 1;
|
||||
LUAT_DEBUG_PRINT("网络注册成功\r\n");
|
||||
break;
|
||||
default:
|
||||
LUAT_DEBUG_PRINT("网络未注册成功\r\n");
|
||||
link_UP = 0;
|
||||
break;
|
||||
}
|
||||
case LUAT_MOBILE_EVENT_SIM:
|
||||
switch (status)
|
||||
{
|
||||
case LUAT_MOBILE_SIM_READY:
|
||||
LUAT_DEBUG_PRINT("SIM卡已插入\r\n");
|
||||
break;
|
||||
case LUAT_MOBILE_NO_SIM:
|
||||
default:
|
||||
break;
|
||||
}
|
||||
case LUAT_MOBILE_EVENT_CELL_INFO:
|
||||
switch (status)
|
||||
{
|
||||
case LUAT_MOBILE_CELL_INFO_UPDATE:
|
||||
LUAT_DEBUG_PRINT("周期性搜索小区信息完成一次\r\n");
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
void lbsloc_demo_task(void *param)
|
||||
{
|
||||
while (!link_UP)
|
||||
{
|
||||
luat_rtos_task_sleep(1000);
|
||||
LUAT_DEBUG_PRINT("等待网络注册");
|
||||
}
|
||||
luat_rtos_task_sleep(15000);
|
||||
while (1)
|
||||
{
|
||||
lbsloc_Init();
|
||||
luat_rtos_task_sleep(30000);
|
||||
}
|
||||
}
|
||||
|
||||
void lbsloc_demo_Init(void)
|
||||
{
|
||||
luat_rtos_task_handle lbsloc_demo_task_handle;
|
||||
luat_rtos_task_create(&lbsloc_demo_task_handle, 4 * 2048, 60, "lbsloc_demo_task", lbsloc_demo_task, NULL, NULL);
|
||||
}
|
||||
void mobile_event_task(void)
|
||||
{
|
||||
luat_mobile_event_register_handler(mobile_event_callback_t);
|
||||
}
|
||||
INIT_HW_EXPORT(mobile_event_task, "0");
|
||||
INIT_TASK_EXPORT(lbsloc_demo_Init,"1");
|
||||
@@ -0,0 +1,347 @@
|
||||
#include "common_api.h"
|
||||
#include "sockets.h"
|
||||
#include "dns.h"
|
||||
#include "lwip/ip4_addr.h"
|
||||
#include "netdb.h"
|
||||
#include "luat_debug.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_mobile.h"
|
||||
#include "lbsLoc.h"
|
||||
#include "FreeRTOS.h"
|
||||
#include "task.h"
|
||||
#include "luat_wifiscan.h"
|
||||
|
||||
#define DEMO_SERVER_UDP_IP "bs.openluat.com" // 基站定位网址
|
||||
#define DEMO_SERVER_UDP_PORT 12411 // 端口
|
||||
|
||||
#define WIFI_LOC 0 // 是否开启wifi 定位
|
||||
/// @brief 合宙IOT 项目productkey ,必须加上,否则定位失败
|
||||
static uint8_t *productKey = "Rxw9b8iG96P1W2CnSXa15IwmYDFifNt1";
|
||||
|
||||
extern uint8_t link_UP; // 网络状态指示
|
||||
|
||||
static uint8_t imeiToBcd(uint8_t *arr, uint8_t len, uint8_t *outPut)
|
||||
{
|
||||
if (len % 2 != 0)
|
||||
{
|
||||
arr[len] = 0x0f;
|
||||
}
|
||||
|
||||
uint8_t tmp = 0;
|
||||
|
||||
for (uint8_t j = 0; j < len; j = j + 2)
|
||||
{
|
||||
outPut[tmp] = (arr[j] & 0x0f) << 4 | (arr[j + 1] & 0x0f);
|
||||
tmp++;
|
||||
}
|
||||
for (uint8_t i = 0; i < 8; i++)
|
||||
{
|
||||
outPut[i] = (outPut[i] % 0x10) * 0x10 + (outPut[i] - (outPut[i] % 0x10)) / 0x10;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
/// @brief BCD ->> str
|
||||
/// @param pOutBuffer
|
||||
/// @param pInBuffer
|
||||
/// @param nInLen 长度
|
||||
/// @return
|
||||
static uint32_t location_service_bcd_to_str(uint8_t *pOutBuffer, uint8_t *pInBuffer, uint32_t nInLen)
|
||||
{
|
||||
uint32_t len = 0;
|
||||
uint8_t ch;
|
||||
uint8_t *p = pOutBuffer;
|
||||
uint32_t i = 0;
|
||||
|
||||
if (pOutBuffer == NULL || pInBuffer == NULL || nInLen == 0)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
for (i = 0; i < nInLen; i++)
|
||||
{
|
||||
ch = pInBuffer[i] & 0x0F;
|
||||
if (ch == 0x0F)
|
||||
{
|
||||
break;
|
||||
}
|
||||
*pOutBuffer++ = ch + '0';
|
||||
|
||||
ch = (pInBuffer[i] >> 4) & 0x0F;
|
||||
if (ch == 0x0F)
|
||||
{
|
||||
break;
|
||||
}
|
||||
*pOutBuffer++ = ch + '0';
|
||||
}
|
||||
|
||||
len = pOutBuffer - p;
|
||||
|
||||
return len;
|
||||
}
|
||||
|
||||
static bool location_service_parse_response(struct am_location_service_rsp_data_t *response, uint8_t *latitude, uint8_t *longitude,
|
||||
uint16_t *year, uint8_t *month, uint8_t *day, uint8_t *hour, uint8_t *minute, uint8_t *second)
|
||||
{
|
||||
uint8_t loc[20] = {0};
|
||||
uint32_t len = 0;
|
||||
|
||||
if (response == NULL || latitude == NULL || longitude == NULL || year == NULL || month == NULL || day == NULL || hour == NULL || minute == NULL || second == NULL)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("location_service_parse_response: invalid parameter\r\n");
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
if (!(response->result == 0 || response->result == 0xFF))
|
||||
{
|
||||
LUAT_DEBUG_PRINT("location_service_parse_response: result fail %d\r\n", response->result);
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
// latitude
|
||||
len = location_service_bcd_to_str(loc, response->latitude, AM_LOCATION_SERVICE_LOCATION_BCD_LEN);
|
||||
if (len <= 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("location_service_parse_response: latitude fail\r\n");
|
||||
return FALSE;
|
||||
}
|
||||
strncat((char *)latitude, (char *)loc, 3);
|
||||
strncat((char *)latitude, ".", 2);
|
||||
strncat((char *)latitude, (char *)(loc + 3), len - 3);
|
||||
len = location_service_bcd_to_str(loc, response->longitude, AM_LOCATION_SERVICE_LOCATION_BCD_LEN);
|
||||
if (len <= 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("location_service_parse_response: longitude fail\r\n");
|
||||
return FALSE;
|
||||
}
|
||||
strncat((char *)longitude, (char *)loc, 3);
|
||||
strncat((char *)longitude, (char *)".", 2);
|
||||
strncat((char *)longitude, (char *)(loc + 3), len - 3);
|
||||
*year = response->year + 2000;
|
||||
*month = response->month;
|
||||
*day = response->day;
|
||||
*hour = response->hour;
|
||||
*minute = response->minute;
|
||||
*second = response->second;
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
static void lbsloc_Init_Task(void *param)
|
||||
{
|
||||
ip_addr_t remote_ip;
|
||||
char *txbuf;
|
||||
struct sockaddr_in name;
|
||||
socklen_t sockaddr_t_size = sizeof(name);
|
||||
int ret;
|
||||
struct timeval to;
|
||||
int socket_id = -1;
|
||||
struct hostent dns_result;
|
||||
struct hostent *p_result;
|
||||
int h_errnop, read_len;
|
||||
struct am_location_service_rsp_data_t locationServiceResponse;
|
||||
|
||||
|
||||
uint8_t latitude[20] = {0}; // 经度
|
||||
uint8_t longitude[20] = {0}; // 维度
|
||||
uint16_t year = 0; // 年
|
||||
uint8_t month = 0; // 月
|
||||
uint8_t day = 0; // 日
|
||||
uint8_t hour = 0; // 小时
|
||||
uint8_t minute = 0; // 分钟
|
||||
uint8_t second = 0; // 秒
|
||||
txbuf = malloc(128);
|
||||
ret = lwip_gethostbyname_r(DEMO_SERVER_UDP_IP, &dns_result, txbuf, 128, &p_result, &h_errnop);
|
||||
if (!ret)
|
||||
{
|
||||
remote_ip = *((ip_addr_t *)dns_result.h_addr_list[0]);
|
||||
free(txbuf);
|
||||
}
|
||||
else
|
||||
{
|
||||
free(txbuf);
|
||||
LUAT_DEBUG_PRINT("dns fail\r\n");
|
||||
goto quit;
|
||||
}
|
||||
|
||||
socket_id = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
|
||||
fcntl(socket_id, F_SETFL, O_NONBLOCK);
|
||||
memset(&name, 0, sizeof(name));
|
||||
name.sin_family = AF_INET;
|
||||
name.sin_addr.s_addr = IPADDR_ANY;
|
||||
name.sin_port = 0;
|
||||
bind(socket_id, (const struct sockaddr *)&name, sockaddr_t_size);
|
||||
name.sin_family = AF_INET;
|
||||
name.sin_addr.s_addr = remote_ip.u_addr.ip4.addr;
|
||||
name.sin_port = htons(DEMO_SERVER_UDP_PORT);
|
||||
while (1)
|
||||
{
|
||||
uint8_t lbsLocReqBuf[127] = {0};
|
||||
memset(lbsLocReqBuf, 0, 127);
|
||||
uint8_t sendLen = 0;
|
||||
lbsLocReqBuf[sendLen++] = 32;
|
||||
memcpy(&lbsLocReqBuf[sendLen], (uint8_t*)productKey, 32);
|
||||
sendLen = sendLen + 32;
|
||||
#if WIFI_LOC
|
||||
lbsLocReqBuf[sendLen++] = 0x38;
|
||||
|
||||
#else
|
||||
lbsLocReqBuf[sendLen++] = 0x28;
|
||||
#endif
|
||||
CHAR imeiBuf[16];
|
||||
memset(imeiBuf, 0, sizeof(imeiBuf));
|
||||
luat_mobile_get_imei(0, imeiBuf, 16);
|
||||
uint8_t imeiBcdBuf[8] = {0};
|
||||
imeiToBcd((uint8_t *)imeiBuf, 15, imeiBcdBuf);
|
||||
memcpy(&lbsLocReqBuf[sendLen], (uint8_t*)imeiBcdBuf, 8);
|
||||
sendLen = sendLen + 8;
|
||||
CHAR muidBuf[64];
|
||||
memset(muidBuf, 0, sizeof(muidBuf));
|
||||
luat_mobile_get_muid(muidBuf, sizeof(muidBuf));
|
||||
lbsLocReqBuf[sendLen++] = strlen(muidBuf);
|
||||
memcpy(&lbsLocReqBuf[sendLen], (uint8_t *)muidBuf, strlen(muidBuf));
|
||||
sendLen = sendLen + strlen(muidBuf);
|
||||
luat_mobile_cell_info_t cell_info;
|
||||
memset(&cell_info, 0, sizeof(cell_info));
|
||||
ret=luat_mobile_get_cell_info_async(5);
|
||||
if (ret != 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("cell_info_async false\r\n");
|
||||
goto quit;
|
||||
}
|
||||
luat_rtos_task_sleep(5000);
|
||||
ret=luat_mobile_get_last_notify_cell_info(&cell_info);
|
||||
//ret = luat_mobile_get_cell_info(&cell_info);//同步方式获取cell_info
|
||||
if (ret != 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("get last notify cell_info false\r\n");
|
||||
goto quit;
|
||||
}
|
||||
lbsLocReqBuf[sendLen++] = 0x01;
|
||||
lbsLocReqBuf[sendLen++] = (cell_info.lte_service_info.tac >> 8) & 0xFF;
|
||||
lbsLocReqBuf[sendLen++] = cell_info.lte_service_info.tac & 0xFF;
|
||||
lbsLocReqBuf[sendLen++] = (cell_info.lte_service_info.mcc >> 8) & 0xFF;
|
||||
lbsLocReqBuf[sendLen++] = cell_info.lte_service_info.mcc & 0XFF;
|
||||
uint8_t mnc = cell_info.lte_service_info.mnc;
|
||||
if (mnc > 10)
|
||||
{
|
||||
CHAR buf[3] = {0};
|
||||
snprintf(buf, 3, "%02x", mnc);
|
||||
int ret1 = atoi(buf);
|
||||
lbsLocReqBuf[sendLen++] = ret1;
|
||||
}
|
||||
else
|
||||
{
|
||||
lbsLocReqBuf[sendLen++] = mnc;
|
||||
}
|
||||
int16_t sRssi;
|
||||
uint8_t retRssi;
|
||||
sRssi = cell_info.lte_service_info.rssi;
|
||||
if (sRssi <= -113)
|
||||
{
|
||||
retRssi = 0;
|
||||
}
|
||||
else if (sRssi < -52)
|
||||
{
|
||||
retRssi = (sRssi + 113) >> 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
retRssi = 31;
|
||||
}
|
||||
lbsLocReqBuf[sendLen++] = retRssi;
|
||||
lbsLocReqBuf[sendLen++] = (cell_info.lte_service_info.cid >> 24) & 0xFF;
|
||||
lbsLocReqBuf[sendLen++] = (cell_info.lte_service_info.cid >> 16) & 0xFF;
|
||||
lbsLocReqBuf[sendLen++] = (cell_info.lte_service_info.cid >> 8) & 0xFF;
|
||||
lbsLocReqBuf[sendLen++] = cell_info.lte_service_info.cid & 0xFF;
|
||||
|
||||
#if WIFI_LOC
|
||||
luat_wifiscan_set_info_t wifiscan_set_info;
|
||||
luat_wifisacn_get_info_t wifiscan_get_info;
|
||||
wifiscan_set_info.maxTimeOut = 10000;
|
||||
wifiscan_set_info.round = 1;
|
||||
wifiscan_set_info.maxBssidNum = LUAT_MAX_WIFI_BSSID_NUM;
|
||||
wifiscan_set_info.scanTimeOut = 5;
|
||||
wifiscan_set_info.wifiPriority = LUAT_WIFISCAN_DATA_PERFERRD;
|
||||
|
||||
ret = luat_get_wifiscan_cell_info(&wifiscan_set_info, &wifiscan_get_info);
|
||||
if (ret!=0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("get wifiscan cell info false\r\n");
|
||||
goto quit;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (wifiscan_get_info.bssidNum > 0)
|
||||
{
|
||||
lbsLocReqBuf[sendLen++] = wifiscan_get_info.bssidNum;
|
||||
for (int i = 0; i < wifiscan_get_info.bssidNum; i++)
|
||||
{
|
||||
for (int j = 0; j < 6; j++)
|
||||
{
|
||||
lbsLocReqBuf[sendLen++] = wifiscan_get_info.bssid[i][j];
|
||||
}
|
||||
lbsLocReqBuf[sendLen++] = wifiscan_get_info.rssi[i] + 255;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("get wifiscan cell info wifiscan_get_info.bssidNum %d\r\n",wifiscan_get_info.bssidNum);
|
||||
goto quit;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
ret = sendto(socket_id, lbsLocReqBuf, sendLen, 0, (const struct sockaddr *)&name, sockaddr_t_size);
|
||||
luat_rtos_task_sleep(5000);
|
||||
if (ret == sendLen)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("lbsLocSendRequest send lbsLoc request success\r\n");
|
||||
ret = recv(socket_id, &locationServiceResponse, sizeof(struct am_location_service_rsp_data_t), 0);
|
||||
LUAT_DEBUG_PRINT("lbSloc_result %d\r\n", locationServiceResponse.result);
|
||||
if ((locationServiceResponse.result==0)|| (locationServiceResponse.result==255))
|
||||
{
|
||||
if (sizeof(struct am_location_service_rsp_data_t) == ret)
|
||||
{
|
||||
if (location_service_parse_response(&locationServiceResponse, latitude, longitude, &year, &month, &day, &hour, &minute, &second) == TRUE)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("latitude:%s,longitude:%s,year:%d,month:%d,day:%d,hour:%d,minute:%d,second:%d\r\n", latitude, longitude, year, month, day, hour, minute, second);
|
||||
break;
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
LUAT_DEBUG_PRINT("location_service_task: rcv response, but process fail\r\n");break;
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("lbsLocSendRequest send lbsLoc request fail\r\n");break;
|
||||
}
|
||||
}
|
||||
quit:
|
||||
memset(latitude, 0, 20);
|
||||
memset(longitude, 0, 20);
|
||||
year = 0;
|
||||
month = 0;
|
||||
day = 0;
|
||||
hour = 0;
|
||||
minute = 0;
|
||||
second = 0;
|
||||
LUAT_DEBUG_PRINT("lbsloc init quit\r\n");
|
||||
close(socket_id);
|
||||
socket_id = -1;
|
||||
vTaskDelete(NULL);
|
||||
}
|
||||
|
||||
void lbsloc_Init(void)
|
||||
{
|
||||
luat_rtos_task_handle lbsloc_Init_handle;
|
||||
luat_rtos_task_create(&lbsloc_Init_handle, 4 * 2048, 80, "lbsloc_Init", lbsloc_Init_Task, NULL, NULL);
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
@@ -0,0 +1,27 @@
|
||||
local TARGET_NAME = "example_lbsLoc"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs("./inc",{public = true})
|
||||
add_files("./src/*.c",{public = true})
|
||||
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
|
||||
-- 按需链接mbedtls
|
||||
-- add_defines("MBEDTLS_CONFIG_FILE=\"config_ec_ssl_comm.h\"")
|
||||
-- add_files(SDK_TOP .. "PLAT/middleware/thirdparty/mbedtls/library/*.c")
|
||||
-- 按需编译httpclient
|
||||
-- add_files(SDK_TOP .. "PLAT/middleware/thirdparty/httpclient/*.c")
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,29 @@
|
||||
### 阿里云千里传音演示
|
||||
## 注意事项!!!
|
||||
1 此demo仅供演示阿里云千里传音功能,没有太好的异常处理,请勿用作其他用途
|
||||
2 需要更换为自己的设备三元组
|
||||
3 此demo的金额播报演示音频格式为amr
|
||||
4 此demo未启用tts功能,只有音频文件播报
|
||||
|
||||
## 演示项目
|
||||
1 语料推送和金额播报
|
||||
2 动态音频播报
|
||||
|
||||
## 演示准备
|
||||
# 语料推送和金额播报
|
||||
首先下发金额播报需要的语料,阿里云自带的常用语料,文件需为amr格式
|
||||
1 数字语料包
|
||||
2 量词语料包
|
||||
3 货币单位语料包
|
||||
|
||||
其次通过阿里云千里传音SpeechByCombination API 下发格式为"{$number}",不包括双引号
|
||||
其中number是一个不大于99999999.99的字符串
|
||||
如"{$10000.11}",设备会播报一万点一一元
|
||||
https://help.aliyun.com/document_detail/223764.html
|
||||
|
||||
# 动态音频播报
|
||||
通过里云千里传音SpeechBySynthesis API 动态下发音频文件,设备播放,
|
||||
https://help.aliyun.com/document_detail/369398.html
|
||||
|
||||
|
||||
|
||||
@@ -0,0 +1,350 @@
|
||||
#ifndef __RTE_DEVICE_H
|
||||
#define __RTE_DEVICE_H
|
||||
|
||||
#include "ec618.h"
|
||||
|
||||
/* Peripheral IO Mode Select, Must Configure First !!!
|
||||
Note, when receiver works in DMA_MODE, interrupt is also enabled to transfer tailing bytes.
|
||||
*/
|
||||
|
||||
#define POLLING_MODE 0x1
|
||||
#define DMA_MODE 0x2
|
||||
#define IRQ_MODE 0x3
|
||||
#define UNILOG_MODE 0x4
|
||||
|
||||
#define RTE_UART0_TX_IO_MODE UNILOG_MODE
|
||||
#define RTE_UART0_RX_IO_MODE IRQ_MODE
|
||||
#define USART0_RX_TRIG_LVL (30)
|
||||
|
||||
#define RTE_UART1_TX_IO_MODE DMA_MODE
|
||||
#define RTE_UART1_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_UART2_TX_IO_MODE POLLING_MODE
|
||||
#define RTE_UART2_RX_IO_MODE DMA_MODE
|
||||
|
||||
#define RTE_SPI0_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_SPI1_IO_MODE POLLING_MODE
|
||||
|
||||
#define RTE_I2C0_IO_MODE POLLING_MODE
|
||||
#define RTE_I2C1_IO_MODE POLLING_MODE
|
||||
|
||||
|
||||
// I2C0 (Inter-integrated Circuit Interface) [Driver_I2C0]
|
||||
// Configuration settings for Driver_I2C0 in component ::Drivers:I2C
|
||||
#define RTE_I2C0 1
|
||||
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 2 : I2C0 SCL
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 2 : I2C0 SDA
|
||||
#define RTE_I2C0_SCL_BIT 28 // AUDIO use 28
|
||||
#define RTE_I2C0_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C0_SDA_BIT 27 // AUDIO use 27
|
||||
#define RTE_I2C0_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_TX_EN 0
|
||||
#define RTE_I2C0_DMA_TX_REQID DMA_REQUEST_I2C0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C0_DMA_RX_EN 0
|
||||
#define RTE_I2C0_DMA_RX_REQID DMA_REQUEST_I2C0_RX
|
||||
|
||||
// I2C1 (Inter-integrated Circuit Interface) [Driver_I2C1]
|
||||
// Configuration settings for Driver_I2C1 in component ::Drivers:I2C
|
||||
#define RTE_I2C1 1
|
||||
|
||||
// { PAD_PIN20}, // 0 : gpio5 / 2 : I2C1 SCL
|
||||
// { PAD_PIN19}, // 0 : gpio4 / 2 : I2C1 SDA
|
||||
#define RTE_I2C1_SCL_BIT 20
|
||||
#define RTE_I2C1_SCL_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_I2C1_SDA_BIT 19
|
||||
#define RTE_I2C1_SDA_FUNC PAD_MUX_ALT2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_TX_EN 1
|
||||
#define RTE_I2C1_DMA_TX_REQID DMA_REQUEST_I2C1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_I2C1_DMA_RX_EN 1
|
||||
#define RTE_I2C1_DMA_RX_REQID DMA_REQUEST_I2C1_RX
|
||||
|
||||
|
||||
// UART0 (Universal asynchronous receiver transmitter) [Driver_USART0]
|
||||
// Configuration settings for Driver_USART0 in component ::Drivers:USART
|
||||
#define RTE_UART0_CTS_PIN_EN 0
|
||||
#define RTE_UART0_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN27}, // 0 : gpio12 / 3 : UART0 RTSn
|
||||
// { PAD_PIN28}, // 0 : gpio13 / 3 : UART0 CTSn
|
||||
// { PAD_PIN29}, // 0 : gpio14 / 3 : UART0 RXD
|
||||
// { PAD_PIN30}, // 0 : gpio15 / 3 : UART0 TXD
|
||||
#define RTE_UART0_RTS_BIT 27
|
||||
#define RTE_UART0_RTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_CTS_BIT 28
|
||||
#define RTE_UART0_CTS_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_RX_BIT 29
|
||||
#define RTE_UART0_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART0_TX_BIT 30
|
||||
#define RTE_UART0_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_TX_REQID DMA_REQUEST_USART0_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART0_DMA_RX_REQID DMA_REQUEST_USART0_RX
|
||||
|
||||
// UART1 (Universal asynchronous receiver transmitter) [Driver_USART1]
|
||||
// Configuration settings for Driver_USART1 in component ::Drivers:USART
|
||||
#define RTE_UART1_CTS_PIN_EN 1
|
||||
#define RTE_UART1_RTS_PIN_EN 1
|
||||
|
||||
// { PAD_PIN31}, // 0 : gpio16 / 1 : UART1 RTS
|
||||
// { PAD_PIN32}, // 0 : gpio17 / 1 : UART1 CTS
|
||||
// { PAD_PIN33}, // 0 : gpio18 / 1 : UART1 RXD
|
||||
// { PAD_PIN34}, // 0 : gpio19 / 1 : UART1 TXD
|
||||
#define RTE_UART1_RTS_BIT 31
|
||||
#define RTE_UART1_RTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_CTS_BIT 32
|
||||
#define RTE_UART1_CTS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_RX_BIT 33
|
||||
#define RTE_UART1_RX_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_UART1_TX_BIT 34
|
||||
#define RTE_UART1_TX_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_TX_REQID DMA_REQUEST_USART1_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART1_DMA_RX_REQID DMA_REQUEST_USART1_RX
|
||||
|
||||
// UART2 (Universal asynchronous receiver transmitter) [Driver_USART2]
|
||||
// Configuration settings for Driver_USART2 in component ::Drivers:USART
|
||||
#define RTE_UART2_CTS_PIN_EN 0
|
||||
#define RTE_UART2_RTS_PIN_EN 0
|
||||
|
||||
// { PAD_PIN25}, // 0 : gpio10 / 3 : UART2 RXD
|
||||
// { PAD_PIN26}, // 0 : gpio11 / 3 : UART2 TXD
|
||||
#define RTE_UART2_RX_BIT 25
|
||||
#define RTE_UART2_RX_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_UART2_TX_BIT 26
|
||||
#define RTE_UART2_TX_FUNC PAD_MUX_ALT3
|
||||
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_TX_REQID DMA_REQUEST_USART2_TX
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_UART2_DMA_RX_REQID DMA_REQUEST_USART2_RX
|
||||
|
||||
// SPI0 (Serial Peripheral Interface) [Driver_SPI0]
|
||||
// Configuration settings for Driver_SPI0 in component ::Drivers:SPI
|
||||
#define RTE_SPI0 1
|
||||
|
||||
// { PAD_PIN21}, // 0 : gpio16 / 1 : UART1 RTS / 2 : SPI0 SSn
|
||||
// { PAD_PIN22}, // 0 : gpio11 / 1 : UART1 CTS / 2 : SPI0 MOSI
|
||||
// { PAD_PIN23}, // 0 : gpio14 / 1 : UART1 RXD / 2 : SPI0 MISO
|
||||
// { PAD_PIN24}, // 0 : gpio15 / 1 : UART1 TXD / 2 : SPI0 SCLK
|
||||
#define RTE_SPI0_SSN_BIT 21
|
||||
#define RTE_SPI0_SSN_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MOSI_BIT 22
|
||||
#define RTE_SPI0_MOSI_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_MISO_BIT 23
|
||||
#define RTE_SPI0_MISO_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SCLK_BIT 24
|
||||
#define RTE_SPI0_SCLK_FUNC PAD_MUX_ALT2
|
||||
|
||||
#define RTE_SPI0_SSN_GPIO_INSTANCE 1
|
||||
#define RTE_SPI0_SSN_GPIO_INDEX 0
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_TX_REQID DMA_REQUEST_SPI0_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI0_DMA_RX_REQID DMA_REQUEST_SPI0_RX
|
||||
|
||||
// SPI1 (Serial Peripheral Interface) [Driver_SPI1]
|
||||
// Configuration settings for Driver_SPI1 in component ::Drivers:SPI
|
||||
#define RTE_SPI1 1
|
||||
|
||||
// { PAD_PIN13}, // 0 : gpio2 / 1 : UART0 RTSn / 3 : SPI1 SSn
|
||||
// { PAD_PIN14}, // 0 : gpio3 / 1 : UART0 CTSn / 3 : SPI1 MOSI
|
||||
// { PAD_PIN15}, // 0 : gpio4 / 1 : UART0 RXD / 3 : SPI1 MISO
|
||||
// { PAD_PIN16}, // 0 : gpio5 / 1 : UART0 TXD / 3 : SPI1 SCLK
|
||||
#define RTE_SPI1_SSN_BIT 13
|
||||
#define RTE_SPI1_SSN_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MOSI_BIT 14
|
||||
#define RTE_SPI1_MOSI_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_MISO_BIT 15
|
||||
#define RTE_SPI1_MISO_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SCLK_BIT 16
|
||||
#define RTE_SPI1_SCLK_FUNC PAD_MUX_ALT3
|
||||
|
||||
#define RTE_SPI1_SSN_GPIO_INSTANCE 0
|
||||
#define RTE_SPI1_SSN_GPIO_INDEX 2
|
||||
|
||||
// DMA
|
||||
// Tx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_TX_REQID DMA_REQUEST_SPI1_TX
|
||||
|
||||
// Rx
|
||||
// Channel <0=>0 <1=>1 <2=>2 <3=>3 <4=>4 <5=>5 <6=>6 <7=>7
|
||||
#define RTE_SPI1_DMA_RX_REQID DMA_REQUEST_SPI1_RX
|
||||
|
||||
|
||||
// PWM0 Controller [Driver_PWM0]
|
||||
// Configuration settings for Driver_PWM0 in component ::Drivers:PWM
|
||||
#define RTE_PWM 1
|
||||
|
||||
#define EFUSE_INIT_MODE POLLING_MODE
|
||||
#define L2CTLS_INIT_MODE POLLING_MODE
|
||||
|
||||
#define FLASH_BARE_RW_MODE 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
#define RTE_UART0 1
|
||||
#define RTE_UART1 1
|
||||
#define RTE_UART2 1
|
||||
/* to enable external thermal */
|
||||
#define EXTERNAL_NTC_EXIST 0
|
||||
|
||||
|
||||
#if (RTE_UART1 == 1)
|
||||
#define UART1_DTR_PAD_INDEX 26 // GPIO11
|
||||
#define UART1_DTR_GPIO_INSTANCE 0
|
||||
#define UART1_DTR_GPIO_PIN 11
|
||||
|
||||
#define UART1_RI_PAD_INDEX 44 // AONIO 4 = GPIO24
|
||||
#define UART1_RI_GPIO_INSTANCE 1
|
||||
#define UART1_RI_GPIO_PIN 8
|
||||
#define UART1_RI_PWM_INSTANCE 1
|
||||
#define UART1_RI_PWM_CLK_ID FCLK_TIMER1
|
||||
#define UART1_RI_PWM_CLK_SEL FCLK_TIMER1_SEL_26M
|
||||
|
||||
#define UART1_DCD_PAD_INDEX 45 // AONIO 5 = GPIO25
|
||||
#define UART1_DCD_GPIO_INSTANCE 1
|
||||
#define UART1_DCD_GPIO_PIN 9
|
||||
#endif
|
||||
|
||||
#if (RTE_UART2 == 1)
|
||||
#define UART2_DTR_PAD_INDEX 25 // GPIO10
|
||||
#define UART2_DTR_GPIO_INSTANCE 0
|
||||
#define UART2_DTR_GPIO_PIN 10
|
||||
|
||||
#define UART2_RI_PAD_INDEX 43 // AONIO 3 = GPIO23
|
||||
#define UART2_RI_GPIO_INSTANCE 1
|
||||
#define UART2_RI_GPIO_PIN 7
|
||||
#define UART2_RI_PWM_INSTANCE 0
|
||||
#define UART2_RI_PWM_CLK_ID FCLK_TIMER0
|
||||
#define UART2_RI_PWM_CLK_SEL FCLK_TIMER0_SEL_26M
|
||||
|
||||
#define UART2_DCD_PAD_INDEX 47 // AONIO 7 = GPIO27
|
||||
#define UART2_DCD_GPIO_INSTANCE 1
|
||||
#define UART2_DCD_GPIO_PIN 11
|
||||
#endif
|
||||
|
||||
|
||||
#define NETLIGHT_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define NETLIGHT_PAD_ALT_FUNC PAD_MUX_ALT5
|
||||
#define NETLIGHT_PWM_INSTANCE 3
|
||||
|
||||
//USIM1 OPTION1
|
||||
#define USIM1_URST_OP1_PAD_INDEX 19 // GPIO4
|
||||
#define USIM1_URST_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP1_GPIO_PIN 4
|
||||
#define USIM1_UCLK_OP1_PAD_INDEX 20 // GPIO5
|
||||
#define USIM1_UCLK_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP1_GPIO_PIN 5
|
||||
#define USIM1_UIO_OP1_PAD_INDEX 21 // GPIO6
|
||||
#define USIM1_UIO_OP1_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP1_GPIO_PIN 6
|
||||
|
||||
//USIM1 OPTION2
|
||||
#define USIM1_UIO_OP2_PAD_INDEX 27 // GPIO12
|
||||
#define USIM1_UIO_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UIO_OP2_GPIO_PIN 12
|
||||
#define USIM1_URST_OP2_PAD_INDEX 28 // GPIO13
|
||||
#define USIM1_URST_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_URST_OP2_GPIO_PIN 13
|
||||
#define USIM1_UCLK_OP2_PAD_INDEX 29 // GPIO14
|
||||
#define USIM1_UCLK_OP2_GPIO_INSTANCE 0
|
||||
#define USIM1_UCLK_OP2_GPIO_PIN 14
|
||||
|
||||
//USIM1 clock latched by AONIO, for example, use AONIO-6 test on EVB
|
||||
#define AONIO_6_PAD_INDEX 46 // AONIO 6 = GPIO26
|
||||
#define AONIO_6_GPIO_INSTANCE 1
|
||||
#define AONIO_6_GPIO_PIN 10
|
||||
|
||||
#define RTE_CSPI0 0
|
||||
|
||||
#define RTE_CSPI0_MCLK_PAD_ADDR 39
|
||||
#define RTE_CSPI0_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_PCLK_PAD_ADDR 35
|
||||
#define RTE_CSPI0_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_CS_PAD_ADDR 36
|
||||
#define RTE_CSPI0_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO0_PAD_ADDR 37
|
||||
#define RTE_CSPI0_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI0_SDO1_PAD_ADDR 38
|
||||
#define RTE_CSPI0_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI0 Request ID
|
||||
#define RTE_CSPI0_DMA_RX_REQID DMA_REQUEST_I2S0_RX
|
||||
|
||||
// CSPI1 Configuration
|
||||
#define RTE_CSPI1 1
|
||||
|
||||
#define RTE_CSPI1_MCLK_PAD_ADDR 18
|
||||
#define RTE_CSPI1_MCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_PCLK_PAD_ADDR 19
|
||||
#define RTE_CSPI1_PCLK_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_CS_PAD_ADDR 20
|
||||
#define RTE_CSPI1_CS_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO0_PAD_ADDR 21
|
||||
#define RTE_CSPI1_SDO0_FUNC PAD_MUX_ALT1
|
||||
|
||||
#define RTE_CSPI1_SDO1_PAD_ADDR 22
|
||||
#define RTE_CSPI1_SDO1_FUNC PAD_MUX_ALT1
|
||||
|
||||
// DMA CSPI1 Request ID
|
||||
#define RTE_CSPI1_DMA_RX_REQID DMA_REQUEST_I2S1_RX
|
||||
|
||||
#endif /* __RTE_DEVICE_H */
|
||||
@@ -0,0 +1,19 @@
|
||||
#ifndef __AUDIO_TASK__
|
||||
#define __AUDIO_TASK__
|
||||
#include "luat_audio_play_ec618.h"
|
||||
typedef struct
|
||||
{
|
||||
uint8_t playType;
|
||||
struct
|
||||
{
|
||||
luat_audio_play_info_t *info;
|
||||
uint8_t count;
|
||||
} file;
|
||||
void *userParam;
|
||||
} audioQueueData;
|
||||
typedef enum
|
||||
{
|
||||
SPEECH_BY_SYNTHESIS_PLAY,
|
||||
} AUDIO_PLAY_TYPE;
|
||||
void audio_task_init(void);
|
||||
#endif
|
||||
@@ -0,0 +1,20 @@
|
||||
#ifndef __HTTP_TASK_QUEUE_H__
|
||||
#define __HTTP_TASK_QUEUE_H__
|
||||
|
||||
|
||||
typedef enum
|
||||
{
|
||||
SPEECH_POST,
|
||||
PUSH_SPEECH,
|
||||
SPEECH_BY_SYNTHESIS
|
||||
}SPEECH_TYPE_E;
|
||||
|
||||
typedef struct http_queue
|
||||
{
|
||||
char *url;
|
||||
char *filename;
|
||||
SPEECH_TYPE_E type;
|
||||
}http_queue_t;
|
||||
|
||||
|
||||
#endif
|
||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,138 @@
|
||||
#include "FreeRTOS.h"
|
||||
#include "common_api.h"
|
||||
#include "audio_task.h"
|
||||
#include "bsp_custom.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_audio_play_ec618.h"
|
||||
#include "luat_i2s_ec618.h"
|
||||
#include "luat_gpio.h"
|
||||
#include "luat_debug.h"
|
||||
#include "audio_task.h"
|
||||
#include "power_audio.h"
|
||||
// AIR780E+TM8211开发板配置
|
||||
#define CODEC_PWR_PIN HAL_GPIO_12
|
||||
#define CODEC_PWR_PIN_ALT_FUN 4
|
||||
#define PA_PWR_PIN HAL_GPIO_25
|
||||
#define PA_PWR_PIN_ALT_FUN 0
|
||||
#define CHARGE_EN_PIN HAL_GPIO_2
|
||||
#define CHARGE_EN_PIN_ALT_FUN 0
|
||||
|
||||
#define AUDIO_QUEUE_SIZE 100
|
||||
extern bool http_get_status; // 这只是一个示例,没有对于多次下发动态报文的处理,简单使用一个变量来控制一下
|
||||
|
||||
extern const unsigned char audiopoweron[];
|
||||
static luat_rtos_semaphore_t audio_semaphore_handle;
|
||||
static luat_rtos_task_handle audio_task_handle;
|
||||
|
||||
luat_rtos_queue_t audio_queue_handle;
|
||||
static uint8_t audio_sleep_handler = 0xff;
|
||||
static HANDLE g_s_delay_timer;
|
||||
|
||||
void audio_data_cb(uint8_t *data, uint32_t len, uint8_t bits, uint8_t channels)
|
||||
{
|
||||
HAL_I2sSrcAdjustVolumn(data, len, 10);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task %x,%d,%d,%d,%d", data, len, bits, channels);
|
||||
}
|
||||
void app_pa_on(uint32_t arg)
|
||||
{
|
||||
luat_gpio_set(PA_PWR_PIN, 1); // 如果是780E+音频扩展小板,可以注释掉此行代码,因为PA长开
|
||||
}
|
||||
void audio_event_cb(uint32_t event, void *param)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task event_cb %d", event);
|
||||
switch (event)
|
||||
{
|
||||
case MULTIMEDIA_CB_AUDIO_DECODE_START:
|
||||
luat_gpio_set(CODEC_PWR_PIN, 1);
|
||||
luat_audio_play_write_blank_raw(0, 6, 1);
|
||||
break;
|
||||
case MULTIMEDIA_CB_AUDIO_OUTPUT_START:
|
||||
luat_rtos_timer_start(g_s_delay_timer, 200, 0, app_pa_on, NULL); // 如果是780E+音频扩展小板,可以注释掉此行代码,因为PA长开
|
||||
break;
|
||||
case MULTIMEDIA_CB_TTS_INIT:
|
||||
break;
|
||||
case LUAT_MULTIMEDIA_CB_TTS_DONE:
|
||||
if (!luat_audio_play_get_last_error(0))
|
||||
{
|
||||
luat_audio_play_write_blank_raw(0, 1, 0);
|
||||
}
|
||||
break;
|
||||
case MULTIMEDIA_CB_AUDIO_DONE:
|
||||
luat_rtos_timer_stop(g_s_delay_timer);
|
||||
LUAT_DEBUG_PRINT("audio play done, result=%d!", luat_audio_play_get_last_error(0));
|
||||
luat_gpio_set(PA_PWR_PIN, 0); // 如果是780E+音频扩展小板,可以注释掉此行代码,因为PA长开
|
||||
luat_gpio_set(CODEC_PWR_PIN, 0);
|
||||
luat_rtos_semaphore_release(audio_semaphore_handle);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void audio_task(void *param)
|
||||
{
|
||||
audioQueueData audioQueueRecv = {0};
|
||||
uint32_t result = 0;
|
||||
while (1)
|
||||
{
|
||||
if (luat_rtos_queue_recv(audio_queue_handle, &audioQueueRecv, NULL, portMAX_DELAY) == 0)
|
||||
{
|
||||
|
||||
luat_audio_play_multi_files(0, audioQueueRecv.file.info, audioQueueRecv.file.count);
|
||||
luat_rtos_semaphore_take(audio_semaphore_handle, LUAT_WAIT_FOREVER);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task this is play wait result %d", result);
|
||||
if(audioQueueRecv.playType == SPEECH_BY_SYNTHESIS_PLAY)
|
||||
{
|
||||
http_get_status = false; // 这只是一个示例,没有对于多次下发动态报文的处理,简单使用一个变量来控制一下
|
||||
}
|
||||
if (audioQueueRecv.file.info != NULL)
|
||||
{
|
||||
free(audioQueueRecv.file.info);
|
||||
}
|
||||
|
||||
if (audioQueueRecv.userParam != NULL)
|
||||
{
|
||||
luat_fs_remove(audioQueueRecv.userParam);
|
||||
free(audioQueueRecv.userParam);
|
||||
}
|
||||
}
|
||||
}
|
||||
luat_rtos_task_delete(audio_task_handle);
|
||||
}
|
||||
|
||||
void audio_task_init(void)
|
||||
{
|
||||
luat_rtos_timer_create(&g_s_delay_timer);
|
||||
|
||||
luat_gpio_cfg_t gpio_cfg;
|
||||
luat_gpio_set_default_cfg(&gpio_cfg);
|
||||
|
||||
gpio_cfg.pull = LUAT_GPIO_DEFAULT;
|
||||
|
||||
// 如果是780E+音频扩展小板,可以注释掉下面两行代码,因为PA长开
|
||||
gpio_cfg.pin = PA_PWR_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
|
||||
gpio_cfg.pin = CODEC_PWR_PIN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
gpio_cfg.alt_fun = CODEC_PWR_PIN_ALT_FUN;
|
||||
luat_gpio_open(&gpio_cfg);
|
||||
|
||||
luat_audio_play_global_init(audio_event_cb, audio_data_cb, luat_audio_play_file_default_fun, NULL, NULL);
|
||||
// luat_i2s_base_setup(0, I2S_MODE_I2S, I2S_FRAME_SIZE_16_16); //如果是780E+音频扩展小板,打开这行注释代码,这个配置对应ES7148/ES7149
|
||||
luat_i2s_base_setup(0, I2S_MODE_MSB, I2S_FRAME_SIZE_16_16); // 此处配置对应TM8211
|
||||
luat_rtos_semaphore_create(&audio_semaphore_handle, 1);
|
||||
|
||||
luat_rtos_queue_create(&audio_queue_handle, AUDIO_QUEUE_SIZE, sizeof(audioQueueData));
|
||||
audioQueueData powerOn = {0};
|
||||
powerOn.file.info = (audio_play_info_t *)calloc(1, sizeof(audio_play_info_t));
|
||||
powerOn.file.info->path = NULL;
|
||||
powerOn.file.info->address = Fqdqwer;
|
||||
powerOn.file.info->rom_data_len = sizeof(Fqdqwer);
|
||||
powerOn.file.count = 1;
|
||||
if (-1 == luat_rtos_queue_send(audio_queue_handle, &powerOn, NULL, 0))
|
||||
{
|
||||
free(powerOn.file.info);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task start send audio fail");
|
||||
}
|
||||
int result = luat_rtos_task_create(&audio_task_handle, 2048, 20, "mqtt", audio_task, NULL, NULL);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_audio_task create task result %d", result);
|
||||
}
|
||||
@@ -0,0 +1,738 @@
|
||||
/*
|
||||
* 这个例程适用于`Linux`这类支持task的POSIX设备, 它演示了用SDK配置MQTT参数并建立连接, 之后创建2个线程
|
||||
*
|
||||
* + 一个线程用于保活长连接
|
||||
* + 一个线程用于接收消息, 并在有消息到达时进入默认的数据回调, 在连接状态变化时进入事件回调
|
||||
*
|
||||
* 需要用户关注或修改的部分, 已经用 TODO 在注释中标明
|
||||
*
|
||||
*/
|
||||
#include "common_api.h"
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include "aiot_state_api.h"
|
||||
#include "aiot_sysdep_api.h"
|
||||
#include "aiot_mqtt_api.h"
|
||||
#include "luat_mobile.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_debug.h"
|
||||
#include "cJSON.h"
|
||||
#include "http_queue.h"
|
||||
#include "audio_task.h"
|
||||
|
||||
// 阿里云系统自带数字语料
|
||||
const char *tone_0 = "SYS_TONE_0.amr";
|
||||
const char *tone_1 = "SYS_TONE_1.amr";
|
||||
const char *tone_2 = "SYS_TONE_2.amr";
|
||||
const char *tone_3 = "SYS_TONE_3.amr";
|
||||
const char *tone_4 = "SYS_TONE_4.amr";
|
||||
const char *tone_5 = "SYS_TONE_5.amr";
|
||||
const char *tone_6 = "SYS_TONE_6.amr";
|
||||
const char *tone_7 = "SYS_TONE_7.amr";
|
||||
const char *tone_8 = "SYS_TONE_8.amr";
|
||||
const char *tone_9 = "SYS_TONE_9.amr";
|
||||
|
||||
/* TODO: 替换为自己设备的三元组 */
|
||||
char *product_key = "${YourProductKey}";
|
||||
char *device_name = "${YourDeviceName}";
|
||||
char *device_secret = "${YourDeviceSecret}";
|
||||
extern luat_rtos_queue_t http_queue_handle;
|
||||
extern luat_rtos_queue_t audio_queue_handle;
|
||||
extern bool http_get_status; // 这只是一个示例示例,没有对于多次下发动态报文的处理,简单使用一个变量来控制一下
|
||||
/*
|
||||
TODO: 替换为自己实例的接入点
|
||||
|
||||
对于企业实例, 或者2021年07月30日之后(含当日)开通的物联网平台服务下公共实例
|
||||
mqtt_host的格式为"${YourInstanceId}.mqtt.iothub.aliyuncs.com"
|
||||
其中${YourInstanceId}: 请替换为您企业/公共实例的Id
|
||||
|
||||
对于2021年07月30日之前(不含当日)开通的物联网平台服务下公共实例
|
||||
需要将mqtt_host修改为: mqtt_host = "${YourProductKey}.iot-as-mqtt.${YourRegionId}.aliyuncs.com"
|
||||
其中, ${YourProductKey}:请替换为设备所属产品的ProductKey。可登录物联网平台控制台,在对应实例的设备详情页获取。
|
||||
${YourRegionId}:请替换为您的物联网平台设备所在地域代码, 比如cn-shanghai等
|
||||
该情况下完整mqtt_host举例: a1TTmBPIChA.iot-as-mqtt.cn-shanghai.aliyuncs.com
|
||||
|
||||
详情请见: https://help.aliyun.com/document_detail/147356.html
|
||||
*/
|
||||
char *mqtt_host = "${YourInstanceId}.mqtt.iothub.aliyuncs.com";
|
||||
|
||||
/* 位于portfiles/aiot_port文件夹下的系统适配函数集合 */
|
||||
extern aiot_sysdep_portfile_t g_aiot_sysdep_portfile;
|
||||
|
||||
/* 位于external/ali_ca_cert.c中的服务器证书 */
|
||||
extern const char *ali_ca_cert;
|
||||
|
||||
static luat_rtos_task_handle g_mqtt_process_thread = NULL;
|
||||
static luat_rtos_task_handle g_mqtt_recv_thread = NULL;
|
||||
static uint8_t g_mqtt_process_thread_running = 0;
|
||||
static uint8_t g_mqtt_recv_thread_running = 0;
|
||||
|
||||
luat_rtos_semaphore_t net_semaphore_handle;
|
||||
|
||||
static luat_rtos_task_handle linksdk_task_handle;
|
||||
|
||||
// 将金额字符串格式化为单个文件形式
|
||||
int fomatMoney(int num, audioQueueData *data, int *index, bool flag)
|
||||
{
|
||||
uint32_t audioArray[10] =
|
||||
{
|
||||
tone_0,
|
||||
tone_1,
|
||||
tone_2,
|
||||
tone_3,
|
||||
tone_4,
|
||||
tone_5,
|
||||
tone_6,
|
||||
tone_7,
|
||||
tone_8,
|
||||
tone_9,
|
||||
};
|
||||
int thousand = (num - num % 1000) / 1000;
|
||||
int hundred = ((num % 1000) - ((num % 1000) % 100)) / 100;
|
||||
int ten = ((num % 100) - ((num % 100) % 10)) / 10;
|
||||
int unit = num % 10;
|
||||
if (thousand == 0)
|
||||
{
|
||||
thousand = -1;
|
||||
if (hundred == 0)
|
||||
{
|
||||
hundred = -1;
|
||||
if (ten == 0)
|
||||
{
|
||||
ten = -1;
|
||||
if (unit == 0)
|
||||
{
|
||||
unit = -1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (unit == 0)
|
||||
{
|
||||
unit = -1;
|
||||
if (ten == 0)
|
||||
{
|
||||
ten = -1;
|
||||
if (hundred == 0)
|
||||
{
|
||||
hundred = -1;
|
||||
if (thousand == 0)
|
||||
{
|
||||
thousand = -1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (ten == 0 && hundred == 0)
|
||||
{
|
||||
ten = -1;
|
||||
}
|
||||
if (thousand != -1)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = audioArray[thousand];
|
||||
}
|
||||
*index += 1;
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = "SYS_TONE_MEASURE_WORD_qian.amr";
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
if (hundred != -1)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = audioArray[hundred];
|
||||
}
|
||||
*index += 1;
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = "SYS_TONE_MEASURE_WORD_bai.amr";
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
if (ten != -1)
|
||||
{
|
||||
if (!(ten == 1 && hundred == -1 && thousand == -1))
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = audioArray[ten];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
if (ten != 0)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = "SYS_TONE_MEASURE_WORD_shi.amr";
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
}
|
||||
if (unit != -1)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = audioArray[unit];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
// 将金额字符串格式化为单个文件形式
|
||||
static int strToFile(char *money, audioQueueData *data, int *index, bool flag)
|
||||
{
|
||||
uint32_t audioArray[10] =
|
||||
{
|
||||
tone_0,
|
||||
tone_1,
|
||||
tone_2,
|
||||
tone_3,
|
||||
tone_4,
|
||||
tone_5,
|
||||
tone_6,
|
||||
tone_7,
|
||||
tone_8,
|
||||
tone_9,
|
||||
};
|
||||
int count = 0;
|
||||
int integer = 0;
|
||||
char *str = NULL;
|
||||
char intStr[8] = {0};
|
||||
char decStr[3] = {0};
|
||||
str = strstr(money, ".");
|
||||
if (str != NULL)
|
||||
{
|
||||
memcpy(intStr, money, str - money);
|
||||
str = str + 1;
|
||||
memcpy(decStr, str, 2);
|
||||
integer = atoi(intStr);
|
||||
}
|
||||
else
|
||||
{
|
||||
integer = atoi(money);
|
||||
}
|
||||
if (integer >= 10000)
|
||||
{
|
||||
int filecount = fomatMoney(integer / 10000, data, index, flag);
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = "SYS_TONE_MEASURE_WORD_wan.amr";
|
||||
}
|
||||
*index += 1;
|
||||
if (((integer % 10000) < 1000) && ((integer % 10000) != 0))
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = audioArray[0];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
}
|
||||
if ((integer % 10000) > 0)
|
||||
{
|
||||
int filecount = fomatMoney(integer % 10000, data, index, flag);
|
||||
}
|
||||
if (*index == 1)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = audioArray[0];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
int decial = atoi(decStr);
|
||||
if (decial > 0)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = "SYS_TONE_dian.amr";
|
||||
}
|
||||
*index += 1;
|
||||
if (decial > 10)
|
||||
{
|
||||
|
||||
int ten = decial / 10;
|
||||
int unit = decial % 10;
|
||||
LUAT_DEBUG_PRINT("this is decial %d, %d, %d", decial, ten, unit);
|
||||
if (ten != 0 && unit != 0)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = audioArray[ten];
|
||||
}
|
||||
*index += 1;
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = audioArray[unit];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
else if (ten == 0 && unit != 0)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = audioArray[0];
|
||||
}
|
||||
*index += 1;
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = audioArray[unit];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
else if (ten != 0 && unit == 0)
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = audioArray[0];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = audioArray[decial];
|
||||
}
|
||||
*index += 1;
|
||||
}
|
||||
}
|
||||
if (flag)
|
||||
{
|
||||
data->file.info[*index].path = "SYS_TONE_MONETARY_yuan.amr";
|
||||
}
|
||||
*index += 1;
|
||||
return count;
|
||||
}
|
||||
|
||||
void mobile_event_callback(LUAT_MOBILE_EVENT_E event, uint8_t index, uint8_t status)
|
||||
{
|
||||
if (event == LUAT_MOBILE_EVENT_NETIF && status == LUAT_MOBILE_NETIF_LINK_ON)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("netif acivated");
|
||||
luat_rtos_semaphore_release(net_semaphore_handle);
|
||||
}
|
||||
}
|
||||
|
||||
/* TODO: 如果要关闭日志, 就把这个函数实现为空, 如果要减少日志, 可根据code选择不打印
|
||||
*
|
||||
* 例如: [1577589489.033][LK-0317] mqtt_basic_demo&gb80sFmX7yX
|
||||
*
|
||||
* 上面这条日志的code就是0317(十六进制), code值的定义见core/aiot_state_api.h
|
||||
*
|
||||
*/
|
||||
|
||||
/* 日志回调函数, SDK的日志会从这里输出 */
|
||||
int32_t demo_state_logcb(int32_t code, char *message)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("linksdk message: %s", message);
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* MQTT事件回调函数, 当网络连接/重连/断开时被触发, 事件定义见core/aiot_mqtt_api.h */
|
||||
void demo_mqtt_event_handler(void *handle, const aiot_mqtt_event_t *event, void *userdata)
|
||||
{
|
||||
switch (event->type)
|
||||
{
|
||||
/* SDK因为用户调用了aiot_mqtt_connect()接口, 与mqtt服务器建立连接已成功 */
|
||||
case AIOT_MQTTEVT_CONNECT:
|
||||
{
|
||||
LUAT_DEBUG_PRINT("AIOT_MQTTEVT_CONNECT\n");
|
||||
/* TODO: 处理SDK建连成功, 不可以在这里调用耗时较长的阻塞函数 */
|
||||
}
|
||||
break;
|
||||
|
||||
/* SDK因为网络状况被动断连后, 自动发起重连已成功 */
|
||||
case AIOT_MQTTEVT_RECONNECT:
|
||||
{
|
||||
LUAT_DEBUG_PRINT("AIOT_MQTTEVT_RECONNECT\n");
|
||||
/* TODO: 处理SDK重连成功, 不可以在这里调用耗时较长的阻塞函数 */
|
||||
}
|
||||
break;
|
||||
|
||||
/* SDK因为网络的状况而被动断开了连接, network是底层读写失败, heartbeat是没有按预期得到服务端心跳应答 */
|
||||
case AIOT_MQTTEVT_DISCONNECT:
|
||||
{
|
||||
char *cause = (event->data.disconnect == AIOT_MQTTDISCONNEVT_NETWORK_DISCONNECT) ? ("network disconnect") : ("heartbeat disconnect");
|
||||
LUAT_DEBUG_PRINT("AIOT_MQTTEVT_DISCONNECT: %s\n", cause);
|
||||
/* TODO: 处理SDK被动断连, 不可以在这里调用耗时较长的阻塞函数 */
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
{
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/* MQTT默认消息处理回调, 当SDK从服务器收到MQTT消息时, 且无对应用户回调处理时被调用 */
|
||||
void demo_mqtt_default_recv_handler(void *handle, const aiot_mqtt_recv_t *packet, void *userdata)
|
||||
{
|
||||
switch (packet->type)
|
||||
{
|
||||
case AIOT_MQTTRECV_HEARTBEAT_RESPONSE:
|
||||
{
|
||||
LUAT_DEBUG_PRINT("heartbeat response\n");
|
||||
/* TODO: 处理服务器对心跳的回应, 一般不处理 */
|
||||
}
|
||||
break;
|
||||
|
||||
case AIOT_MQTTRECV_SUB_ACK:
|
||||
{
|
||||
LUAT_DEBUG_PRINT("suback, res: -0x%04X, packet id: %d, max qos: %d\n",
|
||||
-packet->data.sub_ack.res, packet->data.sub_ack.packet_id, packet->data.sub_ack.max_qos);
|
||||
/* TODO: 处理服务器对订阅请求的回应, 一般不处理 */
|
||||
}
|
||||
break;
|
||||
|
||||
case AIOT_MQTTRECV_PUB:
|
||||
{
|
||||
LUAT_DEBUG_PRINT("pub, qos: %d, topic: %.*s\n", packet->data.pub.qos, packet->data.pub.topic_len, packet->data.pub.topic);
|
||||
LUAT_DEBUG_PRINT("pub, payload: %.*s\n", packet->data.pub.payload_len, packet->data.pub.payload);
|
||||
/* 处理服务器下发的业务报文 */
|
||||
// TODO: 换成自己的项目key和设备名
|
||||
// 此主题为语料下载主题,阿里云推送语料会下发一个下载json文件的url,此json中包含语料下载地址
|
||||
if (strcmp("/sys/${YourProductKey}/${YourDeviceName}/thing/service/SpeechPost", packet->data.pub.topic) == 0)
|
||||
{
|
||||
cJSON *boss = NULL;
|
||||
boss = cJSON_Parse((const char *)packet->data.pub.payload);
|
||||
if (boss == NULL)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("PARES FAIL");
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("this is boss type %d", boss->type);
|
||||
cJSON *method = cJSON_GetObjectItem(boss, "method");
|
||||
cJSON *id = cJSON_GetObjectItem(boss, "id");
|
||||
cJSON *version = cJSON_GetObjectItem(boss, "version");
|
||||
cJSON *params = cJSON_GetObjectItem(boss, "params");
|
||||
|
||||
cJSON *url = cJSON_GetObjectItem(params, "url");
|
||||
http_queue_t send_http_url = {0};
|
||||
send_http_url.url = malloc(strlen(url->valuestring) + 1);
|
||||
send_http_url.type = SPEECH_POST;
|
||||
memset(send_http_url.url, 0x00, strlen(url->valuestring) + 1);
|
||||
memcpy(send_http_url.url, url->valuestring, strlen(url->valuestring));
|
||||
if (-1 == luat_rtos_queue_send(http_queue_handle, &send_http_url, NULL, 0))
|
||||
{
|
||||
free(send_http_url.url);
|
||||
LUAT_DEBUG_PRINT("http send requet fail");
|
||||
}
|
||||
LUAT_DEBUG_PRINT("this is url %s", url->valuestring);
|
||||
}
|
||||
cJSON_Delete(boss);
|
||||
}
|
||||
// TODO: 换成自己的项目key和设备名
|
||||
/*
|
||||
此主题为音频播报主题,阿里云推送音频播报会往此主题下发一个报文,这里只对金额做了解析
|
||||
下发的内容需为"{$number}",其中number是一个不大于99999999.99的字符串
|
||||
如"{$10000.11}",设备会播报一万点一一元
|
||||
*/
|
||||
else if (strcmp("/sys/${YourProductKey}/${YourDeviceName}/thing/service/SpeechBroadcast", packet->data.pub.topic) == 0)
|
||||
{
|
||||
cJSON *boss = NULL;
|
||||
boss = cJSON_Parse((const char *)packet->data.pub.payload);
|
||||
if (boss == NULL)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("PARES FAIL");
|
||||
}
|
||||
else
|
||||
{
|
||||
cJSON *method = cJSON_GetObjectItem(boss, "method");
|
||||
cJSON *params = cJSON_GetObjectItem(boss, "params");
|
||||
cJSON *speech = cJSON_GetObjectItem(params, "speechs");
|
||||
int array_cnt = cJSON_GetArraySize(speech);
|
||||
char *head = NULL;
|
||||
char *tail = NULL;
|
||||
for (int i = 0; i < array_cnt; i++)
|
||||
{
|
||||
cJSON *money = cJSON_GetArrayItem(speech, i);
|
||||
head = strstr(money->valuestring, "{$");
|
||||
if (head != NULL)
|
||||
{
|
||||
head++;
|
||||
head++;
|
||||
tail = strstr(head, "}");
|
||||
}
|
||||
}
|
||||
if (tail != NULL)
|
||||
{
|
||||
audioQueueData moneyPlay = {0};
|
||||
int index = 0;
|
||||
char moneyValue[20] = {0};
|
||||
memcpy(moneyValue, head, tail - head);
|
||||
strToFile(moneyValue, &moneyPlay, &index, false);
|
||||
moneyPlay.file.info = (audio_play_info_t *)calloc(index, sizeof(audio_play_info_t));
|
||||
index = 0;
|
||||
strToFile(moneyValue, &moneyPlay, &index, true);
|
||||
moneyPlay.file.count = index;
|
||||
if (-1 == luat_rtos_queue_send(audio_queue_handle, &moneyPlay, NULL, 0))
|
||||
{
|
||||
free(moneyPlay.file.info);
|
||||
LUAT_DEBUG_PRINT("cloud_speaker_mqtt sub queue send error");
|
||||
}
|
||||
}
|
||||
}
|
||||
cJSON_Delete(boss);
|
||||
}
|
||||
// TODO: 换成自己的项目key和设备名
|
||||
/*
|
||||
此主题为动态音频播报主题,阿里云推送音频播报会往此主题下发一个音频下载url
|
||||
这里解析url然后发送到httptask去下载音频
|
||||
此示例播放完毕后会删掉音频
|
||||
*/
|
||||
else if (strcmp("/sys/${YourProductKey}/${YourDeviceName}/thing/service/AudioPlayback", packet->data.pub.topic) == 0)
|
||||
{
|
||||
if (!http_get_status)
|
||||
{
|
||||
cJSON *boss = NULL;
|
||||
boss = cJSON_Parse((const char *)packet->data.pub.payload);
|
||||
if (boss == NULL)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("PARES FAIL");
|
||||
}
|
||||
else
|
||||
{
|
||||
cJSON *params = cJSON_GetObjectItem(boss, "params");
|
||||
cJSON *format = cJSON_GetObjectItem(params, "format");
|
||||
cJSON *id = cJSON_GetObjectItem(params, "id");
|
||||
cJSON *url = cJSON_GetObjectItem(params, "url");
|
||||
http_queue_t send_http_url = {0};
|
||||
send_http_url.type = SPEECH_BY_SYNTHESIS;
|
||||
send_http_url.filename = malloc(strlen(id->valuestring) + strlen(format->valuestring) + 3);
|
||||
memset(send_http_url.filename, 0x00, strlen(id->valuestring) + strlen(format->valuestring) + 3);
|
||||
snprintf(send_http_url.filename, strlen(id->valuestring) + strlen(format->valuestring) + 3, "%s%s%s", id->valuestring, ".", format->valuestring);
|
||||
|
||||
send_http_url.url = malloc(strlen(url->valuestring) + 1);
|
||||
|
||||
memset(send_http_url.url, 0x00, strlen(url->valuestring) + 1);
|
||||
memcpy(send_http_url.url, url->valuestring, strlen(url->valuestring) + 1);
|
||||
|
||||
if (-1 == luat_rtos_queue_send(http_queue_handle, &send_http_url, NULL, 0))
|
||||
{
|
||||
free(send_http_url.filename);
|
||||
free(send_http_url.url);
|
||||
LUAT_DEBUG_PRINT("http send requet fail");
|
||||
}
|
||||
|
||||
LUAT_DEBUG_PRINT("this is url %s", url->valuestring);
|
||||
http_get_status = true;
|
||||
}
|
||||
cJSON_Delete(boss);
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
||||
case AIOT_MQTTRECV_PUB_ACK:
|
||||
{
|
||||
LUAT_DEBUG_PRINT("puback, packet id: %d\n", packet->data.pub_ack.packet_id);
|
||||
/* TODO: 处理服务器对QoS1上报消息的回应, 一般不处理 */
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
{
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/* 执行aiot_mqtt_process的线程, 包含心跳发送和QoS1消息重发 */
|
||||
void *demo_mqtt_process_thread(void *args)
|
||||
{
|
||||
int32_t res = STATE_SUCCESS;
|
||||
|
||||
while (g_mqtt_process_thread_running)
|
||||
{
|
||||
res = aiot_mqtt_process(args);
|
||||
if (res == STATE_USER_INPUT_EXEC_DISABLED)
|
||||
{
|
||||
break;
|
||||
}
|
||||
luat_rtos_task_sleep(1000);
|
||||
}
|
||||
luat_rtos_task_delete(g_mqtt_process_thread);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* 执行aiot_mqtt_recv的线程, 包含网络自动重连和从服务器收取MQTT消息 */
|
||||
void *demo_mqtt_recv_thread(void *args)
|
||||
{
|
||||
int32_t res = STATE_SUCCESS;
|
||||
|
||||
while (g_mqtt_recv_thread_running)
|
||||
{
|
||||
res = aiot_mqtt_recv(args);
|
||||
if (res < STATE_SUCCESS)
|
||||
{
|
||||
if (res == STATE_USER_INPUT_EXEC_DISABLED)
|
||||
{
|
||||
break;
|
||||
}
|
||||
luat_rtos_task_sleep(1);
|
||||
}
|
||||
}
|
||||
luat_rtos_task_delete(g_mqtt_recv_thread);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
int linksdk_mqtt_task(void *param)
|
||||
{
|
||||
int32_t res = STATE_SUCCESS;
|
||||
void *mqtt_handle = NULL;
|
||||
uint16_t port = 443; /* 无论设备是否使用TLS连接阿里云平台, 目的端口都是443 */
|
||||
aiot_sysdep_network_cred_t cred; /* 安全凭据结构体, 如果要用TLS, 这个结构体中配置CA证书等参数 */
|
||||
|
||||
luat_rtos_semaphore_create(&net_semaphore_handle, 1);
|
||||
|
||||
luat_mobile_event_register_handler(mobile_event_callback);
|
||||
|
||||
luat_rtos_semaphore_take(net_semaphore_handle, LUAT_WAIT_FOREVER);
|
||||
/* 配置SDK的底层依赖 */
|
||||
aiot_sysdep_set_portfile(&g_aiot_sysdep_portfile);
|
||||
/* 配置SDK的日志输出 */
|
||||
aiot_state_set_logcb(demo_state_logcb);
|
||||
|
||||
/* 创建SDK的安全凭据, 用于建立TLS连接 */
|
||||
memset(&cred, 0, sizeof(aiot_sysdep_network_cred_t));
|
||||
cred.option = AIOT_SYSDEP_NETWORK_CRED_SVRCERT_CA; /* 使用RSA证书校验MQTT服务端 */
|
||||
cred.max_tls_fragment = 16384; /* 最大的分片长度为16K, 其它可选值还有4K, 2K, 1K, 0.5K */
|
||||
cred.sni_enabled = 1; /* TLS建连时, 支持Server Name Indicator */
|
||||
cred.x509_server_cert = ali_ca_cert; /* 用来验证MQTT服务端的RSA根证书 */
|
||||
cred.x509_server_cert_len = strlen(ali_ca_cert); /* 用来验证MQTT服务端的RSA根证书长度 */
|
||||
|
||||
/* 创建1个MQTT客户端实例并内部初始化默认参数 */
|
||||
mqtt_handle = aiot_mqtt_init();
|
||||
if (mqtt_handle == NULL)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("aiot_mqtt_init failed\n");
|
||||
luat_rtos_task_delete(linksdk_task_handle);
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* TODO: 如果以下代码不被注释, 则例程会用TCP而不是TLS连接云平台 */
|
||||
|
||||
{
|
||||
memset(&cred, 0, sizeof(aiot_sysdep_network_cred_t));
|
||||
cred.option = AIOT_SYSDEP_NETWORK_CRED_NONE;
|
||||
}
|
||||
|
||||
/* 配置MQTT服务器地址 */
|
||||
aiot_mqtt_setopt(mqtt_handle, AIOT_MQTTOPT_HOST, (void *)mqtt_host);
|
||||
/* 配置MQTT服务器端口 */
|
||||
aiot_mqtt_setopt(mqtt_handle, AIOT_MQTTOPT_PORT, (void *)&port);
|
||||
/* 配置设备productKey */
|
||||
aiot_mqtt_setopt(mqtt_handle, AIOT_MQTTOPT_PRODUCT_KEY, (void *)product_key);
|
||||
/* 配置设备deviceName */
|
||||
aiot_mqtt_setopt(mqtt_handle, AIOT_MQTTOPT_DEVICE_NAME, (void *)device_name);
|
||||
/* 配置设备deviceSecret */
|
||||
aiot_mqtt_setopt(mqtt_handle, AIOT_MQTTOPT_DEVICE_SECRET, (void *)device_secret);
|
||||
/* 配置网络连接的安全凭据, 上面已经创建好了 */
|
||||
aiot_mqtt_setopt(mqtt_handle, AIOT_MQTTOPT_NETWORK_CRED, (void *)&cred);
|
||||
/* 配置MQTT默认消息接收回调函数 */
|
||||
aiot_mqtt_setopt(mqtt_handle, AIOT_MQTTOPT_RECV_HANDLER, (void *)demo_mqtt_default_recv_handler);
|
||||
/* 配置MQTT事件回调函数 */
|
||||
aiot_mqtt_setopt(mqtt_handle, AIOT_MQTTOPT_EVENT_HANDLER, (void *)demo_mqtt_event_handler);
|
||||
|
||||
/* 与服务器建立MQTT连接 */
|
||||
res = aiot_mqtt_connect(mqtt_handle);
|
||||
if (res < STATE_SUCCESS)
|
||||
{
|
||||
/* 尝试建立连接失败, 销毁MQTT实例, 回收资源 */
|
||||
aiot_mqtt_deinit(&mqtt_handle);
|
||||
LUAT_DEBUG_PRINT("aiot_mqtt_connect failed: -0x%04X\n\r\n", -res);
|
||||
LUAT_DEBUG_PRINT("please check variables like mqtt_host, produt_key, device_name, device_secret in demo\r\n");
|
||||
luat_rtos_task_delete(linksdk_task_handle);
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* MQTT 订阅topic功能示例, 请根据自己的业务需求进行使用 */
|
||||
/* {
|
||||
char *sub_topic = "/sys/${YourProductKey}/${YourDeviceName}/thing/event/+/post_reply";
|
||||
res = aiot_mqtt_sub(mqtt_handle, sub_topic, NULL, 1, NULL);
|
||||
if (res < 0) {
|
||||
DBG("aiot_mqtt_sub failed, res: -0x%04X\n", -res);
|
||||
vTaskDelete(NULL);
|
||||
return -1;
|
||||
}
|
||||
} */
|
||||
|
||||
/* MQTT 发布消息功能示例, 请根据自己的业务需求进行使用 */
|
||||
/* {
|
||||
char *pub_topic = "/sys/${YourProductKey}/${YourDeviceName}/thing/event/property/post";
|
||||
char *pub_payload = "{\"id\":\"1\",\"version\":\"1.0\",\"params\":{\"LightSwitch\":0}}";
|
||||
res = aiot_mqtt_pub(mqtt_handle, pub_topic, (uint8_t *)pub_payload, (uint32_t)strlen(pub_payload), 0);
|
||||
if (res < 0) {
|
||||
LUAT_DEBUG_PRINT("aiot_mqtt_sub failed, res: -0x%04X\n", -res);
|
||||
luat_rtos_task_delete(linksdk_task_handle);
|
||||
return -1;
|
||||
}
|
||||
} */
|
||||
|
||||
/* 创建一个单独的线程, 专用于执行aiot_mqtt_process, 它会自动发送心跳保活, 以及重发QoS1的未应答报文 */
|
||||
g_mqtt_process_thread_running = 1;
|
||||
luat_rtos_task_create(&g_mqtt_process_thread, 4096, 20, "", demo_mqtt_process_thread, mqtt_handle, NULL);
|
||||
if (g_mqtt_process_thread == NULL)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("task_create demo_mqtt_process_thread failed: %d\n", res);
|
||||
luat_rtos_task_delete(linksdk_task_handle);
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* 创建一个单独的线程用于执行aiot_mqtt_recv, 它会循环收取服务器下发的MQTT消息, 并在断线时自动重连 */
|
||||
g_mqtt_recv_thread_running = 1;
|
||||
luat_rtos_task_create(&g_mqtt_recv_thread, 4096, 20, "", demo_mqtt_recv_thread, mqtt_handle, NULL);
|
||||
if (g_mqtt_recv_thread == NULL)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("task_create demo_mqtt_recv_thread failed: %d\n", res);
|
||||
luat_rtos_task_delete(linksdk_task_handle);
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* 主循环进入休眠 */
|
||||
while (1)
|
||||
{
|
||||
luat_rtos_task_sleep(1000);
|
||||
}
|
||||
|
||||
/* 断开MQTT连接, 一般不会运行到这里 */
|
||||
g_mqtt_process_thread_running = 0;
|
||||
g_mqtt_recv_thread_running = 0;
|
||||
luat_rtos_task_sleep(1);
|
||||
|
||||
res = aiot_mqtt_disconnect(mqtt_handle);
|
||||
if (res < STATE_SUCCESS)
|
||||
{
|
||||
aiot_mqtt_deinit(&mqtt_handle);
|
||||
LUAT_DEBUG_PRINT("aiot_mqtt_disconnect failed: -0x%04X\n", -res);
|
||||
luat_rtos_task_delete(linksdk_task_handle);
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* 销毁MQTT实例, 一般不会运行到这里 */
|
||||
res = aiot_mqtt_deinit(&mqtt_handle);
|
||||
if (res < STATE_SUCCESS)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("aiot_mqtt_deinit failed: -0x%04X\n", -res);
|
||||
luat_rtos_task_delete(linksdk_task_handle);
|
||||
return -1;
|
||||
}
|
||||
luat_rtos_task_delete(linksdk_task_handle);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void task_demo_init(void)
|
||||
{
|
||||
luat_rtos_task_create(&linksdk_task_handle, 4096, 20, "", linksdk_mqtt_task, NULL, NULL);
|
||||
}
|
||||
extern void task_demo_https(void);
|
||||
extern void audio_task_init(void);
|
||||
INIT_TASK_EXPORT(audio_task_init, "1");
|
||||
INIT_TASK_EXPORT(task_demo_init, "1");
|
||||
INIT_TASK_EXPORT(task_demo_https, "1");
|
||||
@@ -0,0 +1,319 @@
|
||||
/*
|
||||
* Copyright (c) 2022 OpenLuat & AirM2M
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||
* this software and associated documentation files (the "Software"), to deal in
|
||||
* the Software without restriction, including without limitation the rights to
|
||||
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||
* subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
#include "common_api.h"
|
||||
#include "luat_mobile.h"
|
||||
#include "luat_rtos.h"
|
||||
#include "luat_debug.h"
|
||||
#include "http_queue.h"
|
||||
#include "luat_fs.h"
|
||||
#include "HTTPClient.h"
|
||||
#include "cJSON.h"
|
||||
#include "audio_task.h"
|
||||
luat_rtos_queue_t http_queue_handle;
|
||||
extern luat_rtos_queue_t audio_queue_handle;
|
||||
|
||||
bool http_get_status = false; // 这只是一个示例,没有对于多次下发动态报文的处理,简单使用一个变量来控制一下
|
||||
// ciphersuite: TLS-RSA-WITH-AES-128-CBC-SHA msglen = 2609
|
||||
// support session ticket/fragment
|
||||
#define HTTP_RECV_BUF_SIZE (5000)
|
||||
#define HTTP_HEAD_BUF_SIZE (800)
|
||||
|
||||
static HttpClientContext gHttpClient = {0};
|
||||
|
||||
/**
|
||||
\fn INT32 httpGetData(CHAR *getUrl, CHAR *buf, UINT32 len)
|
||||
\brief
|
||||
\return
|
||||
*/
|
||||
static INT32 httpGetData(CHAR *getUrl, CHAR *buf, UINT32 len)
|
||||
{
|
||||
HTTPResult result = HTTP_INTERNAL;
|
||||
HttpClientData clientData = {0};
|
||||
UINT32 count = 0;
|
||||
uint16_t headerLen = 0;
|
||||
|
||||
LUAT_DEBUG_ASSERT(buf != NULL, 0, 0, 0);
|
||||
|
||||
clientData.headerBuf = malloc(HTTP_HEAD_BUF_SIZE);
|
||||
clientData.headerBufLen = HTTP_HEAD_BUF_SIZE;
|
||||
clientData.respBuf = buf;
|
||||
clientData.respBufLen = len;
|
||||
|
||||
result = httpSendRequest(&gHttpClient, getUrl, HTTP_GET, &clientData);
|
||||
LUAT_DEBUG_PRINT("send request result=%d", result);
|
||||
if (result != HTTP_OK)
|
||||
goto exit;
|
||||
do
|
||||
{
|
||||
LUAT_DEBUG_PRINT("recvResponse loop.");
|
||||
memset(clientData.headerBuf, 0, clientData.headerBufLen);
|
||||
memset(clientData.respBuf, 0, clientData.respBufLen);
|
||||
result = httpRecvResponse(&gHttpClient, &clientData);
|
||||
if (result == HTTP_OK || result == HTTP_MOREDATA)
|
||||
{
|
||||
headerLen = strlen(clientData.headerBuf);
|
||||
if (headerLen > 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("total content length=%d", clientData.recvContentLength);
|
||||
}
|
||||
|
||||
if (clientData.blockContentLen > 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("response content:{%s}", (uint8_t *)clientData.respBuf);
|
||||
}
|
||||
count += clientData.blockContentLen;
|
||||
LUAT_DEBUG_PRINT("has recv=%d", count);
|
||||
}
|
||||
} while (result == HTTP_MOREDATA || result == HTTP_CONN);
|
||||
|
||||
LUAT_DEBUG_PRINT("result=%d", result);
|
||||
if (gHttpClient.httpResponseCode < 200 || gHttpClient.httpResponseCode > 404)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("invalid http response code=%d", gHttpClient.httpResponseCode);
|
||||
}
|
||||
else if (count == 0 || count != clientData.recvContentLength)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("data not receive complete");
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("receive success");
|
||||
}
|
||||
exit:
|
||||
free(clientData.headerBuf);
|
||||
return result;
|
||||
}
|
||||
|
||||
static INT32 httpGetDataToFile(CHAR *getUrl, CHAR *buf, UINT32 len, char *file) //http下载数据并保存在文件系统
|
||||
{
|
||||
LUAT_DEBUG_PRINT("this wait write filename %s", file);
|
||||
HTTPResult result = HTTP_INTERNAL;
|
||||
HttpClientData clientData = {0};
|
||||
UINT32 count = 0;
|
||||
int status;
|
||||
uint16_t headerLen = 0;
|
||||
|
||||
LUAT_DEBUG_ASSERT(buf != NULL, 0, 0, 0);
|
||||
|
||||
clientData.headerBuf = malloc(HTTP_HEAD_BUF_SIZE);
|
||||
clientData.headerBufLen = HTTP_HEAD_BUF_SIZE;
|
||||
clientData.respBuf = buf;
|
||||
clientData.respBufLen = len;
|
||||
FILE *file_handle = luat_fs_fopen(file, "wb+");
|
||||
|
||||
result = httpSendRequest(&gHttpClient, getUrl, HTTP_GET, &clientData);
|
||||
LUAT_DEBUG_PRINT("send request result=%d", result);
|
||||
if (result != HTTP_OK)
|
||||
goto exit;
|
||||
do
|
||||
{
|
||||
LUAT_DEBUG_PRINT("recvResponse loop.");
|
||||
memset(clientData.headerBuf, 0, clientData.headerBufLen);
|
||||
memset(clientData.respBuf, 0, clientData.respBufLen);
|
||||
result = httpRecvResponse(&gHttpClient, &clientData);
|
||||
if (result == HTTP_OK || result == HTTP_MOREDATA)
|
||||
{
|
||||
headerLen = strlen(clientData.headerBuf);
|
||||
if (headerLen > 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("total content length=%d", clientData.recvContentLength);
|
||||
}
|
||||
|
||||
if (clientData.blockContentLen > 0)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("response content:{%s}", (uint8_t *)clientData.respBuf);
|
||||
}
|
||||
count += clientData.blockContentLen;
|
||||
status = luat_fs_fwrite((uint8_t *)clientData.respBuf, clientData.blockContentLen, 1, file_handle);
|
||||
if (status == 0)
|
||||
{
|
||||
while (1)
|
||||
;
|
||||
}
|
||||
LUAT_DEBUG_PRINT("has recv=%d", count);
|
||||
}
|
||||
} while (result == HTTP_MOREDATA || result == HTTP_CONN);
|
||||
|
||||
LUAT_DEBUG_PRINT("result=%d", result);
|
||||
luat_fs_fclose(file_handle);
|
||||
if (gHttpClient.httpResponseCode < 200 || gHttpClient.httpResponseCode > 404)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("invalid http response code=%d", gHttpClient.httpResponseCode);
|
||||
luat_fs_remove(file);
|
||||
}
|
||||
else if (count == 0 || count != clientData.recvContentLength)
|
||||
{
|
||||
LUAT_DEBUG_PRINT("data not receive complete");
|
||||
luat_fs_remove(file);
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("receive success");
|
||||
}
|
||||
exit:
|
||||
free(clientData.headerBuf);
|
||||
return result;
|
||||
}
|
||||
|
||||
luat_rtos_task_handle https_task_handle;
|
||||
|
||||
static void task_test_https(void *param)
|
||||
{
|
||||
char *recvBuf = malloc(HTTP_RECV_BUF_SIZE);
|
||||
http_queue_t wait_http_request = {0};
|
||||
while (1)
|
||||
{
|
||||
HTTPResult result = HTTP_INTERNAL;
|
||||
if (0 == luat_rtos_queue_recv(http_queue_handle, &wait_http_request, NULL, LUAT_WAIT_FOREVER))
|
||||
{
|
||||
memset(recvBuf, 0x00, HTTP_RECV_BUF_SIZE);
|
||||
memset(&gHttpClient, 0, sizeof(HttpClientContext));
|
||||
gHttpClient.timeout_s = 2;
|
||||
gHttpClient.timeout_r = 20;
|
||||
result = httpConnect(&gHttpClient, wait_http_request.url);
|
||||
if (wait_http_request.type == SPEECH_POST)
|
||||
{
|
||||
if (result == HTTP_OK)
|
||||
{
|
||||
result = httpGetData(wait_http_request.url, recvBuf, HTTP_RECV_BUF_SIZE);
|
||||
httpClose(&gHttpClient);
|
||||
if (result == HTTP_OK)
|
||||
{
|
||||
cJSON *boss = cJSON_Parse(recvBuf);
|
||||
if (boss != NULL)
|
||||
{
|
||||
cJSON *audio = cJSON_GetObjectItem(boss, "audios");
|
||||
|
||||
int arraysize = cJSON_GetArraySize(audio);
|
||||
http_queue_t http_get_file = {0};
|
||||
for (size_t i = 0; i < arraysize; i++)
|
||||
{
|
||||
cJSON *row = cJSON_GetArrayItem(audio, i);
|
||||
if (row == NULL)
|
||||
break;
|
||||
cJSON *format = cJSON_GetObjectItem(row, "format");
|
||||
cJSON *id = cJSON_GetObjectItem(row, "id");
|
||||
cJSON *url = cJSON_GetObjectItem(row, "url");
|
||||
cJSON *size = cJSON_GetObjectItem(row, "size");
|
||||
http_get_file.filename = malloc(strlen(id->valuestring) + strlen(format->valuestring) + 2);
|
||||
memset(http_get_file.filename, 0x00, strlen(id->valuestring) + strlen(format->valuestring) + 2);
|
||||
snprintf(http_get_file.filename, strlen(id->valuestring) + strlen(format->valuestring) + 2, "%s%s%s", id->valuestring, ".", format->valuestring);
|
||||
if (luat_fs_fexist(http_get_file.filename) == 0) //文件不存在的时候才去下载
|
||||
{
|
||||
http_get_file.type = PUSH_SPEECH;
|
||||
http_get_file.url = malloc(strlen(url->valuestring) + 1);
|
||||
memset(http_get_file.url, 0x00, strlen(url->valuestring) + 1);
|
||||
memcpy(http_get_file.url, url->valuestring, strlen(url->valuestring) + 1);
|
||||
|
||||
if (-1 == luat_rtos_queue_send(http_queue_handle, &http_get_file, 0, 0))
|
||||
{
|
||||
free(http_get_file.filename);
|
||||
LUAT_DEBUG_PRINT("queue send fail");
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
free(http_get_file.filename);
|
||||
LUAT_DEBUG_PRINT("file exists");
|
||||
}
|
||||
}
|
||||
}
|
||||
cJSON_Delete(boss);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("http client connect error");
|
||||
}
|
||||
}
|
||||
else if (wait_http_request.type == PUSH_SPEECH) // 下载下发的语料文本,并保存在文件系统
|
||||
{
|
||||
if (result == HTTP_OK)
|
||||
{
|
||||
result = httpGetDataToFile(wait_http_request.url, recvBuf, HTTP_RECV_BUF_SIZE, wait_http_request.filename);
|
||||
httpClose(&gHttpClient);
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("http client connect error");
|
||||
}
|
||||
LUAT_DEBUG_PRINT("this is http get name and size: %s, %d", wait_http_request.filename, luat_fs_fsize(wait_http_request.filename));
|
||||
}
|
||||
else if (wait_http_request.type == SPEECH_BY_SYNTHESIS) // 下载动态下发的音频文件,并且去播放
|
||||
{
|
||||
if (result == HTTP_OK)
|
||||
{
|
||||
result = httpGetDataToFile(wait_http_request.url, recvBuf, HTTP_RECV_BUF_SIZE, wait_http_request.filename);
|
||||
httpClose(&gHttpClient);
|
||||
if (result == HTTP_OK)
|
||||
{
|
||||
audioQueueData data = {0};
|
||||
char *file_name = malloc(strlen(wait_http_request.filename) + 1);
|
||||
memset(file_name, 0x00, strlen(wait_http_request.filename) + 1);
|
||||
memcpy(file_name, wait_http_request.filename, strlen(wait_http_request.filename));
|
||||
data.file.info = (audio_play_info_t *)calloc(1, sizeof(audio_play_info_t));
|
||||
data.file.info[0].path = file_name;
|
||||
data.file.count = 1;
|
||||
data.userParam = (void *)file_name;
|
||||
if (-1 == luat_rtos_queue_send(audio_queue_handle, &data, 0, 0))
|
||||
{
|
||||
free(file_name);
|
||||
free(data.file.info);
|
||||
http_get_status = false; // 这只是一个示例,没有对于多次下发动态报文的处理,简单使用一个变量来控制一下
|
||||
LUAT_DEBUG_PRINT("money send fail");
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
http_get_status = false; // 这只是一个示例,没有对于多次下发动态报文的处理,简单使用一个变量来控制一下
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
LUAT_DEBUG_PRINT("http client connect error");
|
||||
}
|
||||
LUAT_DEBUG_PRINT("this is http get name and size: %s, %d", wait_http_request.filename, luat_fs_fsize(wait_http_request.filename));
|
||||
}
|
||||
|
||||
LUAT_DEBUG_PRINT("this is test result %d", result);
|
||||
|
||||
if (wait_http_request.url != NULL)
|
||||
{
|
||||
free(wait_http_request.url);
|
||||
}
|
||||
if (wait_http_request.filename != NULL)
|
||||
{
|
||||
free(wait_http_request.filename);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
luat_rtos_task_delete(https_task_handle);
|
||||
}
|
||||
|
||||
void task_demo_https(void)
|
||||
{
|
||||
luat_fs_init();
|
||||
if (-1 == luat_rtos_queue_create(&http_queue_handle, 100, sizeof(http_queue_t)))
|
||||
LUAT_DEBUG_PRINT("http queue create fail");
|
||||
luat_rtos_task_create(&https_task_handle, 32 * 1024, 20, "https", task_test_https, NULL, NULL);
|
||||
}
|
||||
|
||||
@@ -0,0 +1,33 @@
|
||||
local TARGET_NAME = "example_link_speech1"
|
||||
local LIB_DIR = "$(buildir)/".. TARGET_NAME .. "/"
|
||||
local LIB_NAME = "lib" .. TARGET_NAME .. ".a "
|
||||
includes(SDK_TOP .. "/thirdparty/audio_decoder")
|
||||
target(TARGET_NAME)
|
||||
set_kind("static")
|
||||
set_targetdir(LIB_DIR)
|
||||
|
||||
--使用第三方的linksdk
|
||||
includes(SDK_TOP .. "/thirdparty/linksdk")
|
||||
add_deps("linksdk")
|
||||
add_deps("audio_decoder")
|
||||
includes(SDK_TOP .. "/thirdparty/httpclient")
|
||||
add_deps("httpclient")
|
||||
|
||||
--加入代码和头文件
|
||||
add_includedirs(SDK_TOP .. "/thirdparty/cJSON",{public = true})
|
||||
add_files(SDK_TOP .. "/thirdparty/cJSON/**.c")
|
||||
add_includedirs("./inc", SDK_TOP .. "/thirdparty/linksdk/core",{public = true})
|
||||
|
||||
add_files("/src/example_mqtt_basic.c",{public = true})
|
||||
add_files("/src/http_task.c",{public = true})
|
||||
add_files("/src/audio_task.c",{public = true})
|
||||
--路径可以随便写,可以加任意路径的代码,下面代码等效上方代码
|
||||
-- add_includedirs(SDK_TOP .. "project/" .. TARGET_NAME .. "/inc",{public = true})
|
||||
-- add_files(SDK_TOP .. "project/" .. TARGET_NAME .. "/src/*.c",{public = true})
|
||||
|
||||
--可以继续增加add_includedirs和add_files
|
||||
--自动链接c
|
||||
|
||||
LIB_USER = LIB_USER .. SDK_TOP .. LIB_DIR .. LIB_NAME .. " "
|
||||
--甚至可以加入自己的库
|
||||
target_end()
|
||||
@@ -0,0 +1,6 @@
|
||||
### 阿里云千里传音SDK演示
|
||||
## 注意事项!!!
|
||||
1 此demo为阿里云千里传音SDK提供的demo,演示千里传音SDK的功能
|
||||
2 未启用tts
|
||||
3 此demo关联的linksdk功能默认未启用,若要启用,需到thirdparty\linksdk\xmake.lua内手动启用
|
||||
|
||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user