1 #ifndef _MRST_MAX3110_H
2 #define _MRST_MAX3110_H
4 #define MAX3110_HIGH_CLK 0x1 /* 3.6864 MHZ */
5 #define MAX3110_LOW_CLK 0x0 /* 1.8432 MHZ */
7 /* status bits for all 4 MAX3110 operate modes */
8 #define MAX3110_READ_DATA_AVAILABLE (1 << 15)
9 #define MAX3110_WRITE_BUF_EMPTY (1 << 14)
11 #define WC_TAG (3 << 14)
12 #define RC_TAG (1 << 14)
13 #define WD_TAG (2 << 14)
14 #define RD_TAG (0 << 14)
16 /* bits def for write configuration */
17 #define WC_FIFO_ENABLE_MASK (1 << 13)
18 #define WC_FIFO_ENABLE (0 << 13)
20 #define WC_SW_SHDI (1 << 12)
22 #define WC_IRQ_MASK (0xF << 8)
23 #define WC_TXE_IRQ_ENABLE (1 << 11) /* TX empty irq */
24 #define WC_RXA_IRQ_ENABLE (1 << 10) /* RX availabe irq */
25 #define WC_PAR_HIGH_IRQ_ENABLE (1 << 9)
26 #define WC_REC_ACT_IRQ_ENABLE (1 << 8)
28 #define WC_IRDA_ENABLE (1 << 7)
30 #define WC_STOPBITS_MASK (1 << 6)
31 #define WC_2_STOPBITS (1 << 6)
32 #define WC_1_STOPBITS (0 << 6)
34 #define WC_PARITY_ENABLE_MASK (1 << 5)
35 #define WC_PARITY_ENABLE (1 << 5)
37 #define WC_WORDLEN_MASK (1 << 4)
38 #define WC_7BIT_WORD (1 << 4)
39 #define WC_8BIT_WORD (0 << 4)
41 #define WC_BAUD_DIV_MASK (0xF)
42 #define WC_BAUD_DR1 (0x0)
43 #define WC_BAUD_DR2 (0x1)
44 #define WC_BAUD_DR4 (0x2)
45 #define WC_BAUD_DR8 (0x3)
46 #define WC_BAUD_DR16 (0x4)
47 #define WC_BAUD_DR32 (0x5)
48 #define WC_BAUD_DR64 (0x6)
49 #define WC_BAUD_DR128 (0x7)
50 #define WC_BAUD_DR3 (0x8)
51 #define WC_BAUD_DR6 (0x9)
52 #define WC_BAUD_DR12 (0xA)
53 #define WC_BAUD_DR24 (0xB)
54 #define WC_BAUD_DR48 (0xC)
55 #define WC_BAUD_DR96 (0xD)
56 #define WC_BAUD_DR192 (0xE)
57 #define WC_BAUD_DR384 (0xF)
59 #define M3110_RX_FIFO_DEPTH 8