Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
wwsmg1
rt-thread
提交
59653699
R
rt-thread
项目概览
wwsmg1
/
rt-thread
与 Fork 源项目一致
Fork自
RT-Thread / rt-thread
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rt-thread
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
59653699
编写于
10月 30, 2015
作者:
B
Bernard Xiong
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Update uart.c
上级
bb5f57f9
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
251 addition
and
250 deletion
+251
-250
bsp/lpc176x/drivers/uart.c
bsp/lpc176x/drivers/uart.c
+251
-250
未找到文件。
bsp/lpc176x/drivers/uart.c
浏览文件 @
59653699
...
...
@@ -17,308 +17,309 @@
#include <rtthread.h>
#include "LPC17xx.h"
#define IER_RBR
0x01
#define IER_THRE
0x02
#define IER_RLS
0x04
#define IIR_PEND
0x01
#define IIR_RLS
0x03
#define IIR_RDA
0x02
#define IIR_CTI
0x06
#define IIR_THRE
0x01
#define LSR_RDR
0x01
#define LSR_OE
0x02
#define LSR_PE
0x04
#define LSR_FE
0x08
#define LSR_BI
0x10
#define LSR_THRE
0x20
#define LSR_TEMT
0x40
#define LSR_RXFE
0x80
#define IER_RBR
0x01
#define IER_THRE
0x02
#define IER_RLS
0x04
#define IIR_PEND
0x01
#define IIR_RLS
0x03
#define IIR_RDA
0x02
#define IIR_CTI
0x06
#define IIR_THRE
0x01
#define LSR_RDR
0x01
#define LSR_OE
0x02
#define LSR_PE
0x04
#define LSR_FE
0x08
#define LSR_BI
0x10
#define LSR_THRE
0x20
#define LSR_TEMT
0x40
#define LSR_RXFE
0x80
/**
* @addtogroup LPC1
1x
x
* @addtogroup LPC1
76
x
*/
/*@{*/
#if defined(RT_USING_UART0) && defined(RT_USING_DEVICE)
#define UART_BAUDRATE 115200
#define LPC_UART
LPC_UART0
#define UART_IRQn
UART0_IRQn
#define LPC_UART
LPC_UART0
#define UART_IRQn
UART0_IRQn
struct
rt_uart_lpc
{
struct
rt_device
parent
;
struct
rt_device
parent
;
/* buffer for reception */
rt_uint8_t
read_index
,
save_index
;
rt_uint8_t
rx_buffer
[
RT_UART_RX_BUFFER_SIZE
];
}
uart_device
;
/* buffer for reception */
rt_uint8_t
read_index
,
save_index
;
rt_uint8_t
rx_buffer
[
RT_UART_RX_BUFFER_SIZE
];
}
uart_device
;
void
UART0_IRQHandler
(
void
)
{
rt_ubase_t
level
,
iir
;
struct
rt_uart_lpc
*
uart
=
&
uart_device
;
rt_ubase_t
level
,
iir
;
struct
rt_uart_lpc
*
uart
=
&
uart_device
;
/* read IIR and clear it */
iir
=
LPC_UART
->
IIR
;
iir
=
LPC_UART
->
IIR
;
iir
>>=
1
;
/* skip pending bit in IIR */
iir
&=
0x07
;
/* check bit 1~3, interrupt identification */
iir
>>=
1
;
/* skip pending bit in IIR */
iir
&=
0x07
;
/* check bit 1~3, interrupt identification */
if
(
iir
==
IIR_RDA
)
/* Receive Data Available */
{
/* Receive Data Available */
if
(
iir
==
IIR_RDA
)
/* Receive Data Available */
{
/* Receive Data Available */
uart
->
rx_buffer
[
uart
->
save_index
]
=
LPC_UART
->
RBR
;
level
=
rt_hw_interrupt_disable
();
uart
->
save_index
++
;
uart
->
save_index
++
;
if
(
uart
->
save_index
>=
RT_UART_RX_BUFFER_SIZE
)
uart
->
save_index
=
0
;
rt_hw_interrupt_enable
(
level
);
/* invoke callback */
if
(
uart
->
parent
.
rx_indicate
!=
RT_NULL
)
{
rt_size_t
length
;
if
(
uart
->
read_index
>
uart
->
save_index
)
/* invoke callback */
if
(
uart
->
parent
.
rx_indicate
!=
RT_NULL
)
{
rt_size_t
length
;
if
(
uart
->
read_index
>
uart
->
save_index
)
length
=
RT_UART_RX_BUFFER_SIZE
-
uart
->
read_index
+
uart
->
save_index
;
else
length
=
uart
->
save_index
-
uart
->
read_index
;
uart
->
parent
.
rx_indicate
(
&
uart
->
parent
,
length
);
}
}
else
if
(
iir
==
IIR_RLS
)
{
iir
=
LPC_Uart
->
LSR
;
//oe pe fe oe read for clear interrupt
}
return
;
}
}
else
if
(
iir
==
IIR_RLS
)
{
iir
=
LPC_UART
->
LSR
;
//oe pe fe oe read for clear interrupt
}
return
;
}
static
rt_err_t
rt_uart_init
(
rt_device_t
dev
)
static
rt_err_t
rt_uart_init
(
rt_device_t
dev
)
{
rt_uint32_t
Fdiv
;
rt_uint32_t
pclkdiv
,
pclk
;
/* Init UART Hardware */
if
(
LPC_UART
==
LPC_UART0
)
{
LPC_PINCON
->
PINSEL0
&=
~
0x000000F0
;
LPC_PINCON
->
PINSEL0
|=
0x00000050
;
/* RxD0 is P0.3 and TxD0 is P0.2 */
/* By default, the PCLKSELx value is zero, thus, the PCLK for
all the peripherals is 1/4 of the SystemFrequency. */
/* Bit 6~7 is for UART0 */
pclkdiv
=
(
LPC_SC
->
PCLKSEL0
>>
6
)
&
0x03
;
switch
(
pclkdiv
)
{
case
0x00
:
default:
pclk
=
SystemCoreClock
/
4
;
break
;
case
0x01
:
pclk
=
SystemCoreClock
;
break
;
case
0x02
:
pclk
=
SystemCoreClock
/
2
;
break
;
case
0x03
:
pclk
=
SystemCoreClock
/
8
;
break
;
}
LPC_UART0
->
LCR
=
0x83
;
/* 8 bits, no Parity, 1 Stop bit */
Fdiv
=
(
pclk
/
16
)
/
UART_BAUDRATE
;
/*baud rate */
LPC_UART0
->
DLM
=
Fdiv
/
256
;
LPC_UART0
->
DLL
=
Fdiv
%
256
;
LPC_UART0
->
LCR
=
0x03
;
/* DLAB = 0 */
LPC_UART0
->
FCR
=
0x07
;
/* Enable and reset TX and RX FIFO. */
}
else
if
((
LPC_UART1_TypeDef
*
)
LPC_UART
==
LPC_UART1
)
{
LPC_PINCON
->
PINSEL4
&=
~
0x0000000F
;
LPC_PINCON
->
PINSEL4
|=
0x0000000A
;
/* Enable RxD1 P2.1, TxD1 P2.0 */
/* By default, the PCLKSELx value is zero, thus, the PCLK for
all the peripherals is 1/4 of the SystemFrequency. */
/* Bit 8,9 are for UART1 */
pclkdiv
=
(
LPC_SC
->
PCLKSEL0
>>
8
)
&
0x03
;
switch
(
pclkdiv
)
{
case
0x00
:
default:
pclk
=
SystemCoreClock
/
4
;
break
;
case
0x01
:
pclk
=
SystemCoreClock
;
break
;
case
0x02
:
pclk
=
SystemCoreClock
/
2
;
break
;
case
0x03
:
pclk
=
SystemCoreClock
/
8
;
break
;
}
LPC_UART1
->
LCR
=
0x83
;
/* 8 bits, no Parity, 1 Stop bit */
Fdiv
=
(
pclk
/
16
)
/
UART_BAUDRATE
;
/*baud rate */
LPC_UART1
->
DLM
=
Fdiv
/
256
;
LPC_UART1
->
DLL
=
Fdiv
%
256
;
LPC_UART1
->
LCR
=
0x03
;
/* DLAB = 0 */
LPC_UART1
->
FCR
=
0x07
;
/* Enable and reset TX and RX FIFO. */
}
/* Ensure a clean start, no data in either TX or RX FIFO. */
while
((
LPC_UART
->
LSR
&
(
LSR_THRE
|
LSR_TEMT
))
!=
(
LSR_THRE
|
LSR_TEMT
)
);
while
(
LPC_UART
->
LSR
&
LSR_RDR
)
{
Fdiv
=
LPC_UART
->
RBR
;
/* Dump data from RX FIFO */
}
LPC_UART
->
IER
=
IER_RBR
|
IER_THRE
|
IER_RLS
;
/* Enable UART interrupt */
return
RT_EOK
;
rt_uint32_t
Fdiv
;
rt_uint32_t
pclkdiv
,
pclk
;
/* Init UART Hardware */
if
(
LPC_UART
==
LPC_UART0
)
{
LPC_PINCON
->
PINSEL0
&=
~
0x000000F0
;
LPC_PINCON
->
PINSEL0
|=
0x00000050
;
/* RxD0 is P0.3 and TxD0 is P0.2 */
/* By default, the PCLKSELx value is zero, thus, the PCLK for
all the peripherals is 1/4 of the SystemFrequency. */
/* Bit 6~7 is for UART0 */
pclkdiv
=
(
LPC_SC
->
PCLKSEL0
>>
6
)
&
0x03
;
switch
(
pclkdiv
)
{
case
0x00
:
default:
pclk
=
SystemCoreClock
/
4
;
break
;
case
0x01
:
pclk
=
SystemCoreClock
;
break
;
case
0x02
:
pclk
=
SystemCoreClock
/
2
;
break
;
case
0x03
:
pclk
=
SystemCoreClock
/
8
;
break
;
}
LPC_UART0
->
LCR
=
0x83
;
/* 8 bits, no Parity, 1 Stop bit */
Fdiv
=
(
pclk
/
16
)
/
UART_BAUDRATE
;
/*baud rate */
LPC_UART0
->
DLM
=
Fdiv
/
256
;
LPC_UART0
->
DLL
=
Fdiv
%
256
;
LPC_UART0
->
LCR
=
0x03
;
/* DLAB = 0 */
LPC_UART0
->
FCR
=
0x07
;
/* Enable and reset TX and RX FIFO. */
}
else
if
((
LPC_UART1_TypeDef
*
)
LPC_UART
==
LPC_UART1
)
{
LPC_PINCON
->
PINSEL4
&=
~
0x0000000F
;
LPC_PINCON
->
PINSEL4
|=
0x0000000A
;
/* Enable RxD1 P2.1, TxD1 P2.0 */
/* By default, the PCLKSELx value is zero, thus, the PCLK for
all the peripherals is 1/4 of the SystemFrequency. */
/* Bit 8,9 are for UART1 */
pclkdiv
=
(
LPC_SC
->
PCLKSEL0
>>
8
)
&
0x03
;
switch
(
pclkdiv
)
{
case
0x00
:
default:
pclk
=
SystemCoreClock
/
4
;
break
;
case
0x01
:
pclk
=
SystemCoreClock
;
break
;
case
0x02
:
pclk
=
SystemCoreClock
/
2
;
break
;
case
0x03
:
pclk
=
SystemCoreClock
/
8
;
break
;
}
LPC_UART1
->
LCR
=
0x83
;
/* 8 bits, no Parity, 1 Stop bit */
Fdiv
=
(
pclk
/
16
)
/
UART_BAUDRATE
;
/*baud rate */
LPC_UART1
->
DLM
=
Fdiv
/
256
;
LPC_UART1
->
DLL
=
Fdiv
%
256
;
LPC_UART1
->
LCR
=
0x03
;
/* DLAB = 0 */
LPC_UART1
->
FCR
=
0x07
;
/* Enable and reset TX and RX FIFO. */
}
/* Ensure a clean start, no data in either TX or RX FIFO. */
while
((
LPC_UART
->
LSR
&
(
LSR_THRE
|
LSR_TEMT
))
!=
(
LSR_THRE
|
LSR_TEMT
)
);
while
(
LPC_UART
->
LSR
&
LSR_RDR
)
{
Fdiv
=
LPC_UART
->
RBR
;
/* Dump data from RX FIFO */
}
LPC_UART
->
IER
=
IER_RBR
|
IER_THRE
|
IER_RLS
;
/* Enable UART interrupt */
return
RT_EOK
;
}
static
rt_err_t
rt_uart_open
(
rt_device_t
dev
,
rt_uint16_t
oflag
)
{
RT_ASSERT
(
dev
!=
RT_NULL
);
if
(
dev
->
flag
&
RT_DEVICE_FLAG_INT_RX
)
{
/* Enable the UART Interrupt */
NVIC_EnableIRQ
(
UART_IRQn
);
}
return
RT_EOK
;
RT_ASSERT
(
dev
!=
RT_NULL
);
if
(
dev
->
flag
&
RT_DEVICE_FLAG_INT_RX
)
{
/* Enable the UART Interrupt */
NVIC_EnableIRQ
(
UART_IRQn
);
}
return
RT_EOK
;
}
static
rt_err_t
rt_uart_close
(
rt_device_t
dev
)
{
RT_ASSERT
(
dev
!=
RT_NULL
);
if
(
dev
->
flag
&
RT_DEVICE_FLAG_INT_RX
)
{
/* Disable the UART Interrupt */
NVIC_DisableIRQ
(
UART_IRQn
);
}
return
RT_EOK
;
RT_ASSERT
(
dev
!=
RT_NULL
);
if
(
dev
->
flag
&
RT_DEVICE_FLAG_INT_RX
)
{
/* Disable the UART Interrupt */
NVIC_DisableIRQ
(
UART_IRQn
);
}
return
RT_EOK
;
}
static
rt_size_t
rt_uart_read
(
rt_device_t
dev
,
rt_off_t
pos
,
void
*
buffer
,
rt_size_t
size
)
static
rt_size_t
rt_uart_read
(
rt_device_t
dev
,
rt_off_t
pos
,
void
*
buffer
,
rt_size_t
size
)
{
rt_uint8_t
*
ptr
;
struct
rt_uart_lpc
*
uart
=
(
struct
rt_uart_lpc
*
)
dev
;
RT_ASSERT
(
uart
!=
RT_NULL
);
/* point to buffer */
ptr
=
(
rt_uint8_t
*
)
buffer
;
if
(
dev
->
flag
&
RT_DEVICE_FLAG_INT_RX
)
{
while
(
size
)
{
/* interrupt receive */
rt_base_t
level
;
/* disable interrupt */
level
=
rt_hw_interrupt_disable
();
if
(
uart
->
read_index
!=
uart
->
save_index
)
{
*
ptr
=
uart
->
rx_buffer
[
uart
->
read_index
];
uart
->
read_index
++
;
if
(
uart
->
read_index
>=
RT_UART_RX_BUFFER_SIZE
)
uart
->
read_index
=
0
;
}
else
{
/* no data in rx buffer */
/* enable interrupt */
rt_hw_interrupt_enable
(
level
);
break
;
}
/* enable interrupt */
rt_hw_interrupt_enable
(
level
);
ptr
++
;
size
--
;
}
return
(
rt_uint32_t
)
ptr
-
(
rt_uint32_t
)
buffer
;
}
return
0
;
rt_uint8_t
*
ptr
;
struct
rt_uart_lpc
*
uart
=
(
struct
rt_uart_lpc
*
)
dev
;
RT_ASSERT
(
uart
!=
RT_NULL
);
/* point to buffer */
ptr
=
(
rt_uint8_t
*
)
buffer
;
if
(
dev
->
flag
&
RT_DEVICE_FLAG_INT_RX
)
{
while
(
size
)
{
/* interrupt receive */
rt_base_t
level
;
/* disable interrupt */
level
=
rt_hw_interrupt_disable
();
if
(
uart
->
read_index
!=
uart
->
save_index
)
{
*
ptr
=
uart
->
rx_buffer
[
uart
->
read_index
];
uart
->
read_index
++
;
if
(
uart
->
read_index
>=
RT_UART_RX_BUFFER_SIZE
)
uart
->
read_index
=
0
;
}
else
{
/* no data in rx buffer */
/* enable interrupt */
rt_hw_interrupt_enable
(
level
);
break
;
}
/* enable interrupt */
rt_hw_interrupt_enable
(
level
);
ptr
++
;
size
--
;
}
return
(
rt_uint32_t
)
ptr
-
(
rt_uint32_t
)
buffer
;
}
return
0
;
}
static
rt_size_t
rt_uart_write
(
rt_device_t
dev
,
rt_off_t
pos
,
const
void
*
buffer
,
rt_size_t
size
)
static
rt_size_t
rt_uart_write
(
rt_device_t
dev
,
rt_off_t
pos
,
const
void
*
buffer
,
rt_size_t
size
)
{
char
*
ptr
;
ptr
=
(
char
*
)
buffer
;
if
(
dev
->
flag
&
RT_DEVICE_FLAG_STREAM
)
{
/* stream mode */
while
(
size
)
{
if
(
*
ptr
==
'\n'
)
{
/* THRE status, contain valid data */
while
(
!
(
LPC_UART
->
LSR
&
LSR_THRE
)
);
/* write data */
LPC_UART
->
THR
=
'\r'
;
}
/* THRE status, contain valid data */
while
(
!
(
LPC_UART
->
LSR
&
LSR_THRE
)
);
/* write data */
LPC_UART
->
THR
=
*
ptr
;
ptr
++
;
size
--
;
}
}
else
{
while
(
size
!=
0
)
{
/* THRE status, contain valid data */
while
(
!
(
LPC_UART
->
LSR
&
LSR_THRE
)
);
/* write data */
LPC_UART
->
THR
=
*
ptr
;
ptr
++
;
size
--
;
}
}
return
(
rt_size_t
)
ptr
-
(
rt_size_t
)
buffer
;
char
*
ptr
;
ptr
=
(
char
*
)
buffer
;
if
(
dev
->
flag
&
RT_DEVICE_FLAG_STREAM
)
{
/* stream mode */
while
(
size
)
{
if
(
*
ptr
==
'\n'
)
{
/* THRE status, contain valid data */
while
(
!
(
LPC_UART
->
LSR
&
LSR_THRE
)
);
/* write data */
LPC_UART
->
THR
=
'\r'
;
}
/* THRE status, contain valid data */
while
(
!
(
LPC_UART
->
LSR
&
LSR_THRE
));
/* write data */
LPC_UART
->
THR
=
*
ptr
;
ptr
++
;
size
--
;
}
}
else
{
while
(
size
!=
0
)
{
/* THRE status, contain valid data */
while
(
!
(
LPC_UART
->
LSR
&
LSR_THRE
)
);
/* write data */
LPC_UART
->
THR
=
*
ptr
;
ptr
++
;
size
--
;
}
}
return
(
rt_size_t
)
ptr
-
(
rt_size_t
)
buffer
;
}
void
rt_hw_uart_init
(
void
)
{
struct
rt_uart_lpc
*
uart
;
/* get uart device */
uart
=
&
uart_device
;
/* device initialization */
uart
->
parent
.
type
=
RT_Device_Class_Char
;
rt_memset
(
uart
->
rx_buffer
,
0
,
sizeof
(
uart
->
rx_buffer
));
uart
->
read_index
=
uart
->
save_index
=
0
;
/* device interface */
uart
->
parent
.
init
=
rt_uart_init
;
uart
->
parent
.
open
=
rt_uart_open
;
uart
->
parent
.
close
=
rt_uart_close
;
uart
->
parent
.
read
=
rt_uart_read
;
uart
->
parent
.
write
=
rt_uart_write
;
uart
->
parent
.
control
=
RT_NULL
;
uart
->
parent
.
user_data
=
RT_NULL
;
rt_device_register
(
&
uart
->
parent
,
"uart0"
,
RT_DEVICE_FLAG_RDWR
|
RT_DEVICE_FLAG_STREAM
|
RT_DEVICE_FLAG_INT_RX
);
struct
rt_uart_lpc
*
uart
;
/* get uart device */
uart
=
&
uart_device
;
/* device initialization */
uart
->
parent
.
type
=
RT_Device_Class_Char
;
rt_memset
(
uart
->
rx_buffer
,
0
,
sizeof
(
uart
->
rx_buffer
));
uart
->
read_index
=
uart
->
save_index
=
0
;
/* device interface */
uart
->
parent
.
init
=
rt_uart_init
;
uart
->
parent
.
open
=
rt_uart_open
;
uart
->
parent
.
close
=
rt_uart_close
;
uart
->
parent
.
read
=
rt_uart_read
;
uart
->
parent
.
write
=
rt_uart_write
;
uart
->
parent
.
control
=
RT_NULL
;
uart
->
parent
.
user_data
=
RT_NULL
;
rt_device_register
(
&
uart
->
parent
,
"uart0"
,
RT_DEVICE_FLAG_RDWR
|
RT_DEVICE_FLAG_STREAM
|
RT_DEVICE_FLAG_INT_RX
);
}
#endif
/* end of UART */
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录