108 lines
3.6 KiB
C
108 lines
3.6 KiB
C
/****************************************************************************
|
|
|
|
Copyright(c) 2019 by Aerospace C.Power (Chongqing) Microelectronics. ALL RIGHTS RESERVED.
|
|
|
|
This Information is proprietary to Aerospace C.Power (Chongqing) Microelectronics and MAY NOT
|
|
be copied by any method or incorporated into another program without
|
|
the express written consent of Aerospace C.Power. This Information or any portion
|
|
thereof remains the property of Aerospace C.Power. The Information contained herein
|
|
is believed to be accurate and Aerospace C.Power assumes no responsibility or
|
|
liability for its use in any way and conveys no license or title under
|
|
any patent or copyright and makes no representation or warranty that this
|
|
Information is free from patent or copyright infringement.
|
|
|
|
****************************************************************************/
|
|
|
|
#ifndef _APP_UART_H_
|
|
#define _APP_UART_H_
|
|
|
|
#include "app_flash.h"
|
|
#include "app_types.h"
|
|
#include "app_common.h"
|
|
|
|
/* the buffer size for uart receive frame */
|
|
#define UART_RCV_BUF_LEN 1024
|
|
/* cache uart recv buffer */
|
|
#define UART_BUF_MAX_LEN 800
|
|
/* uart recv data timeout, clearn */
|
|
#define UART_RECV_TIMEOUT 1000 /* unit is ms */
|
|
|
|
typedef struct _uart_handle_buffer {
|
|
/* buffer handle */
|
|
uint16_t handle;
|
|
/* buffer length */
|
|
uint16_t buff_len;
|
|
/* run time */
|
|
uint32_t boot_tm;
|
|
/* temp buffer */
|
|
uint8_t * buff_tmp;
|
|
} uart_handle_buffer;
|
|
|
|
/**
|
|
* @brief app_uart_is_valid - check uart param is valid
|
|
* @param [in] baudrate: baud rate
|
|
* @param [in] data_bits: data bits:5,6,7,8
|
|
* @param [in] stop_bits: stop bits:1,1.5,2
|
|
* @param [in] parity: parity,NONE:0, ODD:1,EVEN:2
|
|
* @param [in] thresholdvalue: threshold value,20-1000
|
|
* @return: true-> succeeded, false -> failed
|
|
*/
|
|
uint8_t app_uart_is_valid(uint32_t baudrate, uint8_t data_bits,
|
|
uint8_t stop_bits, uint8_t parity, uint32_t thresholdvalue);
|
|
|
|
/**
|
|
* @brief app_uart_stop_bits_itoa - convert stop bits from integer to string
|
|
* @param [in] value: integer value of stop bits to be converted
|
|
* @param [out] str: string of stop bits
|
|
* @return: true-> succeeded, false -> failed
|
|
*/
|
|
uint8_t app_uart_stop_bits_itoa(uint8_t value, char *str);
|
|
|
|
/**
|
|
* @brief app_uart_stop_bits_atoi - convert stop bits from string to integer
|
|
* @param [in] str: string of stop bits to be converted
|
|
* @param [out] value: integer value of stop bits
|
|
* @return: true-> succeeded, false -> failed
|
|
*/
|
|
uint8_t app_uart_stop_bits_atoi(char *str, uint8_t *value);
|
|
|
|
/**
|
|
* @brief app_uart_tx - send data to uart
|
|
* @param [in] hdl: uart handle
|
|
* @param [in] data: data will be send uart
|
|
* @param [in] data_length: data length
|
|
* @return: 0-> succeeded, others -> failed
|
|
*/
|
|
uint16_t app_uart_tx(iot_uart_h hdl, uint8_t *data, uint16_t data_length);
|
|
|
|
/**
|
|
* @brief app_uart_buf_clear - clearn buffer
|
|
* @param [in] source: app source
|
|
*/
|
|
void app_uart_buf_clear(app_source_e source);
|
|
|
|
/**
|
|
* @brief app_get_uart_buf_info - get golbal uart info
|
|
* @return: uart info, point to g_uart_buffer
|
|
*/
|
|
uart_handle_buffer *app_get_uart_buf_info(void);
|
|
|
|
/**
|
|
* @brief app_uart_reassign_pin - set uart port tx/rx pin before iot_uart_open
|
|
* @param [in] port: open port, see IOT_UART_PORTXXX,as IOT_UART_PORT0
|
|
* @param [in] rx_pin: define uart rx pin
|
|
* @param [in] tx_pin: define uart tx pin
|
|
* @return: 0-> succeeded, others -> failed
|
|
*/
|
|
uint8_t app_uart_reassign_pin(uint8_t port, uint8_t rx_pin, uint8_t tx_pin);
|
|
|
|
/**
|
|
* @brief app_uart_init - uart init
|
|
* @param [out] uart_handle: open uart, return handle
|
|
* @return: 0-> succeeded, others -> failed
|
|
*/
|
|
uint16_t app_uart_init(iot_uart_h *uart_handle);
|
|
|
|
#endif /* _APP_UART_H_ */
|
|
|