OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [tags/] [stable_0_2_0_rc3/] [or1ksim/] [peripheral/] [16450.h] - Blame information for rev 1778

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 31 lampret
/* 16450.h -- Definition of types and structures for 8250/16450 serial UART
2
   Copyright (C) 2000 Damjan Lampret, lampret@opencores.org
3
 
4
This file is part of OpenRISC 1000 Architectural Simulator.
5
 
6
This program is free software; you can redistribute it and/or modify
7
it under the terms of the GNU General Public License as published by
8
the Free Software Foundation; either version 2 of the License, or
9
(at your option) any later version.
10
 
11
This program is distributed in the hope that it will be useful,
12
but WITHOUT ANY WARRANTY; without even the implied warranty of
13
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
GNU General Public License for more details.
15
 
16
You should have received a copy of the GNU General Public License
17
along with this program; if not, write to the Free Software
18
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
19
 
20
/* Prototypes */
21
void uart_reset();
22 1308 phoenix
void uart_status();
23 31 lampret
 
24 341 markom
/* Definitions */
25 355 markom
#define UART_ADDR_SPACE   (8)         /* UART memory address space size in bytes */
26 341 markom
#define UART_MAX_FIFO_LEN (16)        /* rx FIFO for uart 16550 */
27 355 markom
#define MAX_SKEW          (1)         /* max. clock skew in subclocks */
28 409 markom
#define UART_VAPI_BUF_LEN 128         /* Size of VAPI command buffer - VAPI should not send more
29
                                         that this amout of char before requesting something back */
30
#define UART_CLOCK_DIVIDER 16         /* Uart clock divider */
31 713 markom
#define UART_FGETC_SLOWDOWN     100   /* fgetc slowdown factor */
32 341 markom
 
33 31 lampret
/* Registers */
34
 
35
struct dev_16450 {
36 355 markom
  struct {
37 1504 nogj
    uint8_t txbuf[UART_MAX_FIFO_LEN];
38
    uint16_t rxbuf[UART_MAX_FIFO_LEN]; /* Upper 8-bits is the LCR modifier */
39
    uint8_t dll;
40
    uint8_t dlh;
41
    uint8_t ier;
42
    uint8_t iir;
43
    uint8_t fcr;
44
    uint8_t lcr;
45
    uint8_t mcr;
46
    uint8_t lsr;
47
    uint8_t msr;
48
    uint8_t scr;
49 355 markom
  } regs;   /* Visible registers */
50
  struct {
51 1504 nogj
    uint8_t txser;    /* Character just sending */
52
    uint16_t rxser;    /* Character just receiving */
53
    uint8_t loopback;
54 355 markom
  } iregs;  /* Internal registers */
55
  struct {
56
    int txbuf_head;
57
    int txbuf_tail;
58
    int rxbuf_head;
59
    int rxbuf_tail;
60
    unsigned int txbuf_full;
61
    unsigned int rxbuf_full;
62 1501 nogj
    int receiveing; /* Receiveing a char */
63
    int recv_break; /* Receiveing a break */
64 1502 nogj
    int ints; /* Which interrupts are pending */
65 355 markom
  } istat;  /* Internal status */
66 341 markom
 
67 355 markom
  /* Clocks per char */
68
  unsigned long char_clks;
69 341 markom
 
70 355 markom
  /* VAPI internal registers */
71
  struct {
72
    unsigned long char_clks;
73 1504 nogj
    uint8_t dll, dlh;
74
    uint8_t lcr;
75 355 markom
    int skew;
76
  } vapi;
77
 
78
  /* Required by VAPI - circular buffer */
79 409 markom
 unsigned long vapi_buf[UART_VAPI_BUF_LEN];  /* Buffer to store incoming characters to,
80 355 markom
                                          since we cannot handle them so fast - we
81
                                          are serial */
82 341 markom
  int vapi_buf_head_ptr;               /* Where we write to */
83
  int vapi_buf_tail_ptr;               /* Where we read from */
84
 
85
  /* Length of FIFO, 16 for 16550, 1 for 16450 */
86
  int fifo_len;
87 713 markom
 
88 1367 nogj
  struct channel *channel;
89
 
90
  /* Configuration */
91 1461 nogj
  int enabled;
92 1367 nogj
  int jitter;
93
  oraddr_t baseaddr;
94
  int irq;
95
  unsigned long vapi_id;
96
  int uart16550;
97
  char *channel_str;
98 31 lampret
};
99
 
100
/*
101
 * Addresses of visible registers
102
 *
103
 */
104 355 markom
#define UART_RXBUF  0 /* R: Rx buffer, DLAB=0 */
105
#define UART_TXBUF  0 /* W: Tx buffer, DLAB=0 */
106
#define UART_DLL  0 /* R/W: Divisor Latch Low, DLAB=1 */
107
#define UART_DLH  1 /* R/W: Divisor Latch High, DLAB=1 */
108
#define UART_IER  1 /* R/W: Interrupt Enable Register */
109
#define UART_IIR  2 /* R: Interrupt ID Register */
110 409 markom
#define UART_FCR  2 /* W: FIFO Control Register */
111 355 markom
#define UART_LCR  3 /* R/W: Line Control Register */
112
#define UART_MCR  4 /* W: Modem Control Register */
113
#define UART_LSR  5 /* R: Line Status Register */
114
#define UART_MSR  6 /* R: Modem Status Register */
115
#define UART_SCR  7 /* R/W: Scratch Register */
116 31 lampret
 
117
/*
118
 * R/W masks for valid bits in 8250/16450 (mask out 16550 and later bits)
119
 *
120
 */
121 355 markom
#define UART_VALID_LCR  0xff
122 409 markom
#define UART_VALID_LSR  0xff
123
#define UART_VALID_IIR  0x0f
124
#define UART_VALID_FCR  0xc0
125 355 markom
#define UART_VALID_IER  0x0f
126
#define UART_VALID_MCR  0x1f
127
#define UART_VALID_MSR  0xff
128 31 lampret
 
129
/*
130
 * Bit definitions for the Line Control Register
131
 *
132
 */
133 355 markom
#define UART_LCR_DLAB 0x80  /* Divisor latch access bit */
134
#define UART_LCR_SBC  0x40  /* Set break control */
135
#define UART_LCR_SPAR 0x20  /* Stick parity (?) */
136
#define UART_LCR_EPAR 0x10  /* Even parity select */
137
#define UART_LCR_PARITY 0x08  /* Parity Enable */
138
#define UART_LCR_STOP 0x04  /* Stop bits: 0=1 stop bit, 1= 2 stop bits */
139
#define UART_LCR_WLEN5  0x00  /* Wordlength: 5 bits */
140
#define UART_LCR_WLEN6  0x01  /* Wordlength: 6 bits */
141
#define UART_LCR_WLEN7  0x02  /* Wordlength: 7 bits */
142
#define UART_LCR_WLEN8  0x03  /* Wordlength: 8 bits */
143 344 markom
#define UART_LCR_RESET  0x03
144 31 lampret
/*
145
 * Bit definitions for the Line Status Register
146
 */
147 409 markom
#define UART_LSR_RXERR  0x80  /* Error in rx fifo */
148 355 markom
#define UART_LSR_TXSERE 0x40  /* Transmitter serial register empty */
149
#define UART_LSR_TXBUFE 0x20  /* Transmitter buffer register empty */
150
#define UART_LSR_BREAK  0x10  /* Break interrupt indicator */
151
#define UART_LSR_FRAME  0x08  /* Frame error indicator */
152
#define UART_LSR_PARITY 0x04  /* Parity error indicator */
153
#define UART_LSR_OVRRUN 0x02  /* Overrun error indicator */
154
#define UART_LSR_RDRDY  0x01  /* Receiver data ready */
155 31 lampret
 
156
/*
157
 * Bit definitions for the Interrupt Identification Register
158
 */
159 355 markom
#define UART_IIR_NO_INT 0x01  /* No interrupts pending */
160
#define UART_IIR_ID 0x06  /* Mask for the interrupt ID */
161 31 lampret
 
162 355 markom
#define UART_IIR_MSI  0x00  /* Modem status interrupt (Low priority) */
163
#define UART_IIR_THRI 0x02  /* Transmitter holding register empty */
164
#define UART_IIR_RDI  0x04  /* Receiver data interrupt */
165
#define UART_IIR_RLSI 0x06  /* Receiver line status interrupt (High p.) */
166 409 markom
#define UART_IIR_CTI  0x0c  /* Character timeout */
167 31 lampret
 
168
/*
169 409 markom
 * Bit Definitions for the FIFO Control Register
170
 */
171
#define UART_FCR_FIE  0x01  /* FIFO enable */
172
#define UART_FCR_RRXFI 0x02 /* Reset rx FIFO */
173 411 markom
#define UART_FCR_RTXFI 0x04 /* Reset tx FIFO */
174 409 markom
#define UART_FIFO_TRIGGER(x) /* Trigger values for indexes 0..3 */\
175 423 markom
  ((x) == 0 ? 1\
176
  :(x) == 1 ? 4\
177
  :(x) == 2 ? 8\
178
  :(x) == 3 ? 14 : 0)
179 409 markom
 
180
/*
181 31 lampret
 * Bit definitions for the Interrupt Enable Register
182
 */
183 355 markom
#define UART_IER_MSI  0x08  /* Enable Modem status interrupt */
184
#define UART_IER_RLSI 0x04  /* Enable receiver line status interrupt */
185
#define UART_IER_THRI 0x02  /* Enable Transmitter holding register int. */
186
#define UART_IER_RDI  0x01  /* Enable receiver data interrupt */
187 31 lampret
 
188
/*
189
 * Bit definitions for the Modem Control Register
190
 */
191 355 markom
#define UART_MCR_LOOP 0x10  /* Enable loopback mode */
192
#define UART_MCR_AUX2 0x08  /* Auxilary 2  */
193
#define UART_MCR_AUX1 0x04  /* Auxilary 1 */
194
#define UART_MCR_RTS  0x02  /* Force RTS */
195
#define UART_MCR_DTR  0x01  /* Force DTR */
196 31 lampret
 
197
/*
198
 * Bit definitions for the Modem Status Register
199
 */
200 355 markom
#define UART_MSR_DCD  0x80  /* Data Carrier Detect */
201 385 markom
#define UART_MSR_RI   0x40  /* Ring Indicator */
202 355 markom
#define UART_MSR_DSR  0x20  /* Data Set Ready */
203
#define UART_MSR_CTS  0x10  /* Clear to Send */
204
#define UART_MSR_DDCD 0x08  /* Delta DCD */
205
#define UART_MSR_TERI 0x04  /* Trailing edge ring indicator */
206
#define UART_MSR_DDSR 0x02  /* Delta DSR */
207
#define UART_MSR_DCTS 0x01  /* Delta CTS */
208 31 lampret
 
209 385 markom
/*
210
 * Various definitions
211
 */
212 423 markom
#define UART_BREAK_COUNT  (1) /* # of chars to count when performing break */
213 409 markom
#define UART_CHAR_TIMEOUT (4) /* # of chars to count when performing timeout int. */

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.