initial commit
This commit is contained in:
129
lib/amb1_sdk/common/application/xmodem/xmodem.h
Normal file
129
lib/amb1_sdk/common/application/xmodem/xmodem.h
Normal file
@@ -0,0 +1,129 @@
|
||||
/**
|
||||
******************************************************************************
|
||||
* @file xmodem.h
|
||||
* @author
|
||||
* @version
|
||||
* @brief This file provides user interface for xmodem, support Xmode Tx & Rx
|
||||
******************************************************************************
|
||||
* @attention
|
||||
*
|
||||
* This module is a confidential and proprietary property of RealTek and possession or use of this module requires written permission of RealTek.
|
||||
*
|
||||
* Copyright(c) 2016, Realtek Semiconductor Corporation. All rights reserved.
|
||||
******************************************************************************
|
||||
*/
|
||||
|
||||
#ifndef _XMODE_H_
|
||||
#define _XMODE_H_
|
||||
|
||||
/** @addtogroup xmodem XMODEM
|
||||
* @ingroup hal
|
||||
* @brief Xmodem TX & RX function
|
||||
* @{
|
||||
*/
|
||||
|
||||
#include <basic_types.h>
|
||||
#if defined(CONFIG_PLATFORM_8711B)
|
||||
#define xModemRxBuffer _xModemRxBuffer
|
||||
#endif
|
||||
|
||||
/*****************
|
||||
* X-Modem status
|
||||
*****************/
|
||||
#define XMODEM_OK 1
|
||||
#define XMODEM_CANCEL 2
|
||||
#define XMODEM_ACK 3
|
||||
#define XMODEM_NAK 4
|
||||
#define XMODEM_COMPLETE 5
|
||||
#define XMODEM_NO_SESSION 6
|
||||
#define XMODEM_ABORT 7
|
||||
#define XMODEM_TIMEOUT 8
|
||||
|
||||
/****************************
|
||||
* flow control character
|
||||
****************************/
|
||||
#define SOH 0x01 /* Start of header */
|
||||
#define STX 0x02 /* Start of header XModem-1K */
|
||||
#define EOT 0x04 /* End of transmission */
|
||||
#define ACK 0x06 /* Acknowledge */
|
||||
#define NAK 0x15 /* Not acknowledge */
|
||||
#define CAN 0x18 /* Cancel */
|
||||
#define ESC 0x1b /* User Break */
|
||||
|
||||
/****************************
|
||||
* Xmode paramters
|
||||
****************************/
|
||||
#define FRAME_SIZE 132 /* X-modem structure */
|
||||
#define FRAME_SIZE_1K 1028 /* X-modem structure */
|
||||
#define XM_BUFFER_SIZE 1024 /* X-modem buffer */
|
||||
#define TIMEOUT 180 /* max timeout */
|
||||
#define RETRY_COUNT 20 /* Try times */
|
||||
#define xWAITTIME 0x00400000 /* waitiing time */
|
||||
#define WAIT_FRAME_TIME (10000*100) /* 10 sec, wait frame timeout */
|
||||
#define WAIT_CHAR_TIME (1000*100) /* 1 sec, wait char timeout */
|
||||
|
||||
/***********************
|
||||
* frame structure
|
||||
***********************/
|
||||
typedef struct
|
||||
{
|
||||
unsigned char soh;
|
||||
unsigned char recordNo;
|
||||
unsigned char recordNoInverted;
|
||||
unsigned char buffer[XM_BUFFER_SIZE];
|
||||
unsigned char CRC;
|
||||
} XMODEM_FRAME;
|
||||
|
||||
typedef struct _XMODEM_COM_PORT_ {
|
||||
char (*poll) (void);
|
||||
char (*get)(void);
|
||||
void (*put)(char c);
|
||||
}XMODEM_COM_PORT, *PXMODEM_COM_PORT;
|
||||
|
||||
typedef struct _XMODEM_CTRL_ {
|
||||
u16 xMUsing;
|
||||
u16 currentFrame; /* current frame number */
|
||||
u16 previousFrame; /* previous frame number */
|
||||
u16 expected;
|
||||
s16 rStatus;
|
||||
s32 rFinish;
|
||||
u32 total_frame;
|
||||
u32 rx_len;
|
||||
char *pXFrameBuf;
|
||||
u32 (*RxFrameHandler)(char *ptr, u32 frame_num, u32 frame_size);
|
||||
XMODEM_COM_PORT ComPort;
|
||||
}XMODEM_CTRL, *PXMODEM_CTRL;
|
||||
|
||||
typedef u32 (*RxFrameHandler_t)(char *ptr, u32 frame_num, u32 frame_size);
|
||||
|
||||
/**
|
||||
* @brief Initial comport, buffer, buffer handler
|
||||
* @param pXMCtrl : xmodem comport
|
||||
* @param FrameBuf : pointer of RX frame buffer
|
||||
* @param RxFrameHdl : callback of receiving RX frame
|
||||
* @return XMODEM_OK : initial OK
|
||||
XMODEM_NO_SESSION : initial failed, xmodem is using
|
||||
*/
|
||||
extern s16 xModemStart(XMODEM_CTRL *pXMCtrl, char *FrameBuf, RxFrameHandler_t RxFrameHdl);
|
||||
|
||||
/**
|
||||
* @brief Close xmodem comport
|
||||
* @param pXMCtrl : xmodem comport
|
||||
* @return XMODEM_OK : OK
|
||||
* XMODEM_NO_SESSION : Close xmodem failed, xmodem has already closed
|
||||
*/
|
||||
extern s16 xModemEnd(XMODEM_CTRL *pXMCtrl);
|
||||
|
||||
/**
|
||||
* @brief xmodem receive frame
|
||||
* @param pXMCtrl : xmodem comport
|
||||
* @param MaxSize : the maximum size of total RX frame
|
||||
* @return successful : return total RX frame length
|
||||
* failed : return MaxSize+1
|
||||
*/
|
||||
extern s32 xModemRxBuffer(XMODEM_CTRL *pXMCtrl, s32 MaxSize);
|
||||
|
||||
/*\@}*/
|
||||
|
||||
#endif /* _XMODE_H_ */
|
||||
|
||||
Reference in New Issue
Block a user