KT24-1110_65E-HA-651B/include_lib/driver/device/uart.h
2024-11-10 18:44:17 +08:00

132 lines
2.8 KiB
C

#ifndef DEVICE_UART_H
#define DEVICE_UART_H
#include "typedef.h"
#include "device/device.h"
#include "generic/ioctl.h"
#include "system/task.h"
#define UART_DISABLE 0x00000000
#define UART_DMA_SUPPORT 0x00000001
#define UART_TX_USE_DMA 0x00000003
#define UART_RX_USE_DMA 0x00000005
#define UART_DEBUG 0x00000008
struct uart_outport {
u8 tx_pin;
u8 rx_pin;
u16 value;
};
extern void putbyte(char a);
enum uart_clk_src {
LSB_CLK,
OSC_CLK,
PLL_48M,
};
enum _uart_port_out {
//uart0
PORTC_0_1 = 0x00001000,
PORTG_6_7 = 0x00002000,
PORTH_12_13 = 0x00003000,
PORTB_14_15 = 0x00004000,
//uart1
PORTC_2_3 = 0x00005000,
PORTH_2_5 = 0x00006000,
PORTH_14_15 = 0x00007000,
PORTC_6_7 = 0x00008000,
//uart3
PORTE_0_1 = 0x00009000,
PORTB_4_3 = 0x0000A000,
PORTD_9_10 = 0x0000B000,
PORTD_14_15 = 0x0000C000,
PORT_REMAP = 0x0000D000,
};
struct uart_platform_data {
u8 *name;
u8 irq;
u8 tx_pin;
u8 rx_pin;
u32 flags;
u32 baudrate;
enum _uart_port_out port;
void (*port_remap_func)(void);
u32 max_continue_recv_cnt;
u32 idle_sys_clk_cnt;
enum uart_clk_src clk_src;
};
enum {
UART_CIRCULAR_BUFFER_WRITE_OVERLAY = -1,
UART_RECV_TIMEOUT = -2,
UART_RECV_EXIT = -3,
};
#define UART_MAGIC 'U'
#define UART_FLUSH _IO(UART_MAGIC,1)
#define UART_SET_RECV_ALL _IOW(UART_MAGIC,2,bool)
#define UART_SET_RECV_BLOCK _IOW(UART_MAGIC,3,bool)
#define UART_SET_RECV_TIMEOUT _IOW(UART_MAGIC,4,u32)
#define UART_SET_RECV_TIMEOUT_CB _IOW(UART_MAGIC,5,int (*)(void))
#define UART_GET_RECV_CNT _IOR(UART_MAGIC,6,u32)
#define UART_START _IO(UART_MAGIC,7)
#define UART_SET_CIRCULAR_BUFF_ADDR _IOW(UART_MAGIC,8,void *)
#define UART_SET_CIRCULAR_BUFF_LENTH _IOW(UART_MAGIC,9,u32)
#define UART_PLATFORM_DATA_BEGIN(data) \
static const struct uart_platform_data data = {
#define UART_PLATFORM_DATA_END() \
};
struct uart_device {
char *name;
const struct uart_operations *ops;
struct device dev;
const struct uart_platform_data *priv;
OS_MUTEX mutex;
};
struct uart_operations {
int (*init)(struct uart_device *);
int (*read)(struct uart_device *, void *buf, u32 len);
int (*write)(struct uart_device *, void *buf, u16 len);
int (*ioctl)(struct uart_device *, u32 cmd, u32 arg);
int (*close)(struct uart_device *);
};
#define REGISTER_UART_DEVICE(dev) \
static struct uart_device dev sec(.uart)
extern struct uart_device uart_device_begin[], uart_device_end[];
#define list_for_each_uart_device(p) \
for (p=uart_device_begin; p<uart_device_end; p++)
extern const struct device_operations uart_dev_ops;
#endif