Project

General

Profile

Statistics
| Revision:

root / proj / libs / uart / include / uart.h @ 300

History | View | Annotate | Download (1.91 KB)

1 235 up20180642
#ifndef UART_H_INCLUDED
2
#define UART_H_INCLUDED
3
4 249 up20180642
#define COM1_ADDR           0x3F8
5
#define COM2_ADDR           0x2F8
6
#define COM1_IRQ            4
7
#define COM2_IRQ            3
8
#define COM1_VECTOR         0x0C
9
#define COM2_VECTOR         0x0B
10 235 up20180642
11 249 up20180642
typedef enum {
12
    uart_parity_none = 0x0,
13
    uart_parity_odd  = 0x1,
14
    uart_parity_even = 0x3,
15
    uart_parity_par1 = 0x5,
16
    uart_parity_par0 = 0x7
17
} uart_parity;
18
19 235 up20180642
typedef struct {
20 242 up20180642
    int     base_addr               ;
21
    uint8_t lcr                     ;
22
    uint8_t dll                     ;
23
    uint8_t dlm                     ;
24
    uint8_t bits_per_char           ;
25
    uint8_t stop_bits               ;
26 249 up20180642
    uart_parity parity              ;
27 242 up20180642
    uint8_t break_control         :1;
28
    uint8_t dlab                  :1;
29
    uint16_t divisor_latch          ;
30
    uint8_t ier                     ;
31
    uint8_t received_data_int     :1;
32
    uint8_t transmitter_empty_int :1;
33
    uint8_t receiver_line_stat_int:1;
34
    uint8_t modem_stat_int        :1;
35 235 up20180642
} uart_config;
36
37 263 up20180642
int (subscribe_uart_interrupt)(uint8_t interrupt_bit, int *interrupt_id);
38
39 235 up20180642
int uart_get_config(int base_addr, uart_config *config);
40
void uart_print_config(uart_config config);
41
42
int uart_set_bits_per_character(int base_addr, uint8_t     bits_per_char);
43
int uart_set_stop_bits         (int base_addr, uint8_t     stop         );
44
int uart_set_parity            (int base_addr, uart_parity par          );
45
int uart_set_bit_rate          (int base_addr, float       bit_rate     );
46
47 252 up20180642
int uart_enable_int_rx (int base_addr);
48
int uart_disable_int_rx(int base_addr);
49
int uart_enable_int_tx (int base_addr);
50
int uart_disable_int_tx(int base_addr);
51
52 282 up20180642
/// NCTP - Non-critical transmission protocol
53 297 up20180642
int nctp_init(void);
54 298 up20180642
int nctp_dump(void);
55 297 up20180642
int nctp_set_processor(void (*proc_func)(const uint8_t*, const size_t));
56 282 up20180642
int nctp_free(void);
57
58
int nctp_send(size_t num, uint8_t* ptr[], size_t sz[]);
59
60
int nctp_ih_err;
61
void nctp_ih(void);
62
63 235 up20180642
#endif //UART_H_INCLUDED