aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/s3c4510b_uart.h
blob: b06c76d84a7aac1dab5c076c3bfa42b5238439a0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
#ifndef __UART_H
#define __UART_H

/*
 * Copyright (c) 2004	Cucy Systems (http://www.cucy.com)
 * Curt Brune <curt@cucy.com>
 *
 * See file CREDITS for list of people who contributed to this
 * project.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License as
 * published by the Free Software Foundation; either version 2 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
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 * MA 02111-1307 USA
 *
 * Description:   S3C4510B UART register layout
 */

/* UART LINE CONTROL register */
typedef struct __BF_UART_LINE_CTRL {
	u32    wordLen: 2;
	u32      nStop: 1;
	u32     parity: 3;
	u32        clk: 1;
	u32  infra_red: 1;
	u32     unused:24;
} BF_UART_LINE_CTRL;

typedef union _UART_LINE_CTRL {
	u32               ui;
	BF_UART_LINE_CTRL bf;
} UART_LINE_CTRL;

/* UART CONTROL register */
typedef struct __BF_UART_CTRL {
	u32     rxMode: 2;
	u32      rxIrq: 1;
	u32     txMode: 2;
	u32        DSR: 1;
	u32  sendBreak: 1;
	u32   loopBack: 1;
	u32     unused:24;
} BF_UART_CTRL;

typedef union _UART_CTRL {
	u32            ui;
	BF_UART_CTRL   bf;
} UART_CTRL;

/* UART STATUS register */
typedef struct __BF_UART_STAT {
	u32      overrun: 1;
	u32       parity: 1;
	u32        frame: 1;
	u32     breakIrq: 1;
	u32          DTR: 1;
	u32      rxReady: 1;
	u32   txBufEmpty: 1;
	u32   txComplete: 1;
	u32       unused:24;
} BF_UART_STAT;

typedef union _UART_STAT {
	u32            ui;
	BF_UART_STAT   bf;
} UART_STAT;

/* UART BAUD_DIV register */
typedef struct __BF_UART_BAUD_DIV {
	u32      cnt1: 4;
	u32      cnt0:12;
	u32    unused:16;
} BF_UART_BAUD_DIV;

typedef union _UART_BAUD_DIV {
	u32                ui;
	BF_UART_BAUD_DIV   bf;
} UART_BAUD_DIV;

/* UART register block */
typedef struct __UART {
	volatile UART_LINE_CTRL  m_lineCtrl;
	volatile UART_CTRL           m_ctrl;
	volatile UART_STAT           m_stat;
	volatile u32                   m_tx;
	volatile u32                   m_rx;
	volatile UART_BAUD_DIV    m_baudDiv;
	volatile u32              m_baudCnt;
	volatile u32              m_baudClk;
} UART;

#define NL          0x0A
#define CR          0x0D
#define BSP         0x08
#define ESC         0x1B
#define CTRLZ       0x1A
#define RUBOUT      0x7F

#endif