183 lines
5.9 KiB
C
Raw Normal View History

/*
* Copyright : (C) 2022 Phytium Information Technology, Inc.
* All Rights Reserved.
*
* This program is OPEN SOURCE software: you can redistribute it and/or modify it
* under the terms of the Phytium Public License as published by the Phytium Technology Co.,Ltd,
* either version 1.0 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the Phytium Public License for more details.
*
*
* FilePath: fpl011.h
* Date: 2022-02-10 14:53:42
* LastEditTime: 2022-02-18 09:07:38
* Description:  This files is for uart functions
*
* Modify History:
* Ver   Who        Date         Changes
* ----- ------     --------    --------------------------------------
*/
#ifndef BSP_DRIVERS_SERIAL_PL011_UART_H
#define BSP_DRIVERS_SERIAL_PL011_UART_H
#ifdef __cplusplus
extern "C"
{
#endif
/***************************** Include Files *********************************/
#include "ftypes.h"
#include "fassert.h"
#include "fpl011_hw.h"
#include "sdkconfig.h"
/************************** Constant Definitions *****************************/
/**************************** Type Definitions *******************************/
/***************** Macros (Inline Functions) Definitions *********************/
#define FPL011_ERROR_PARAM FT_CODE_ERR(ErrModBsp, ErrBspUart, 0x1u)
#define FPL011_BAUDRATE 115200U
/* Config options */
#define FPL011_OPTION_UARTEN 0x1U
#define FPL011_OPTION_RXEN 0x2U
#define FPL011_OPTION_TXEN 0x4U
#define FPL011_OPTION_FIFOEN 0x8U
#define FPL011_OPTION_CTS 0x10U
#define FPL011_OPTION_RTS 0x20U
#define FPL011_OPTION_DTR 0x40U
#define FPL011_OPTION_RTSEN 0x80U
#define FPL011_OPTION_CTSEN 0x100U
#define FPL011_OPTION_TXDMAEN 0x200U
#define FPL011_OPTION_RXDMAEN 0x400U
/* Channel Operational Mode */
#define FPL011_OPER_MODE_NORMAL (u8)0x00U /* Normal Mode */
#define FPL011_OPER_MODE_LOCAL_LOOP (u8)0x01U /* Local Loop back Mode */
/* Data format values */
#define FPL011_FORMAT_WORDLENGTH_8BIT 0x3
#define FPL011_FORMAT_WORDLENGTH_7BIT 0x2
#define FPL011_FORMAT_WORDLENGTH_6BIT 0x1
#define FPL011_FORMAT_WORDLENGTH_5BIT 0x0
#define FPL011_FORMAT_NO_PARITY 0U /* No parity */
#define FPL011_FORMAT_EN_PARITY 1U /* Enable parity */
#define FPL011_FORMAT_EVEN_PARITY 2U /* Even parity */
#define FPL011_FORMAT_ODD_PARITY 0U /* Odd parity */
#define FPL011_FORMAT_EN_STICK_PARITY 4U /* Stick parity */
#define FPL011_FORMAT_NO_STICK_PARITY 0U /* Stick parity */
#define FPL011_FORMAT_PARITY_MASK 7U /* Format parity mask */
#define FPL011_FORMAT_EVEN_PARITY_SHIFT 1U /* Even parity shift */
#define FPL011_FORMAT_EN_STICK_PARITY_SHIFT 5U /* Stick parity shift */
#define FPL011_FORMAT_2_STOP_BIT 1U
#define FPL011_FORMAT_1_STOP_BIT 0U
/* Callback events */
#define FPL011_EVENT_RECV_DATA 1U /* Data receiving done */
#define FPL011_EVENT_RECV_TOUT 2U /* A receive timeout occurred */
#define FPL011_EVENT_SENT_DATA 3U /* Data transmission done */
#define FPL011_EVENT_RECV_ERROR 4U /* A receive error detected */
#define FPL011_EVENT_MODEM 5U /* Modem status changed */
#define FPL011_EVENT_PARE_FRAME_BRKE 6U /* A receive parity, frame, break \
* error detected */
#define FPL011_EVENT_RECV_ORERR 7U /* A receive overrun error detected */
/**************************** Type Definitions ******************************/
/**
* Keep track of data format setting of a device.
*/
typedef struct
{
u32 baudrate ; /* In bps, ie 1200 */
u32 data_bits ; /* Number of data bits */
u32 parity ; /* Parity */
u8 stopbits ; /* Number of stop bits */
} FPl011Format ;
typedef struct
{
u32 instance_id; /* Id of device*/
u32 base_address;
u32 ref_clock_hz;
u32 irq_num;
u32 baudrate;
} FPl011Config;
typedef struct
{
u8 *byte_p;
u32 requested_bytes;
u32 remaining_bytes;
} FPl011Buffer;
typedef void (*FPl011EventHandler)(void *args, u32 event, u32 event_data);
typedef struct
{
FPl011Config config; /* Configuration data structure */
u32 is_ready; /* Device is ininitialized and ready*/
FPl011Buffer send_buffer;
FPl011Buffer receive_buffer;
FPl011EventHandler handler;
void *args;
uint8_t rxbs_error; /* An error occurs during receiving. 0 has no error and 1 has an error */
} FPl011;
/************************** Function Prototypes ******************************/
/* FPl011_uart_sinit.c */
const FPl011Config *FPl011LookupConfig(u32 instance_id);
/* FPl011_uart.c */
FError FPl011CfgInitialize(FPl011 *uart_p, FPl011Config *config);
void FPl011BlockSend(FPl011 *uart_p, u8 *byte_p, u32 length);
u32 FPl011Send(FPl011 *uart_p, u8 *byte_p, u32 length);
u32 FPl011Receive(FPl011 *uart_p, u8 *byte_p, u32 length);
u8 FPl011BlockReceive(FPl011 *uart_p);
void FPl011ProgramCtlReg(FPl011 *uart_p, u32 ctrl_reg);
/* FPl011_uart_options.c */
void FPl011SetOperMode(FPl011 *uart_p, u8 operation_mode);
void FPl011SetOptions(FPl011 *uart_p, u32 options);
void FPl011SetSpecificOptions(FPl011 *uart_p, u32 options);
void FPl011ClearSpecificOptions(FPl011 *uart_p, u32 options);
FError FPl011SetBaudRate(FPl011 *uart_p, u32 baudrate) ;
void FPl011GetDataFormat(FPl011 *uart_p, FPl011Format *format_p) ;
FError FPl011SetDataFormat(FPl011 *uart_p, FPl011Format *format_p) ;
void FPl011SetTxFifoThreadHold(FPl011 *uart_p, u8 trigger_level) ;
void FPl011SetRxFifoThreadhold(FPl011 *uart_p, u8 trigger_level) ;
/* FPl011_uart_intr.c */
u32 FPl011GetInterruptMask(FPl011 *uart_p) ;
void FPl011InterruptHandler(s32 vector, void *param);
void FPl011SetHandler(FPl011 *uart_p, FPl011EventHandler fun_p, void *args);
void FPl011SetInterruptMask(FPl011 *uart_p, u32 mask);
#ifdef __cplusplus
}
#endif
#endif // !