Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
rt-thread
提交
ff302f28
R
rt-thread
项目概览
BaiXuePrincess
/
rt-thread
与 Fork 源项目一致
Fork自
RT-Thread / rt-thread
通知
1
Star
0
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看板
提交
ff302f28
编写于
2月 25, 2014
作者:
B
Bernard Xiong
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #227 from RTsien/master
Add supports for UART0 to UART5 of beaglebone(black)
上级
7255137b
d71b86c7
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
249 addition
and
19 deletion
+249
-19
bsp/beaglebone/drivers/serial.c
bsp/beaglebone/drivers/serial.c
+227
-17
bsp/beaglebone/rtconfig.h
bsp/beaglebone/rtconfig.h
+13
-1
libcpu/arm/am335x/am33xx.h
libcpu/arm/am335x/am33xx.h
+9
-1
未找到文件。
bsp/beaglebone/drivers/serial.c
浏览文件 @
ff302f28
...
...
@@ -10,6 +10,7 @@
* Change Logs:
* Date Author Notes
* 2013-07-06 Bernard the first version
* 2014-01-11 RTsien support UART0 to UART5 straightly
*/
#include <rthw.h>
...
...
@@ -162,14 +163,66 @@ static const struct rt_uart_ops am33xx_uart_ops =
am33xx_getc
,
};
/* UART1 device driver structure */
struct
serial_ringbuffer
uart1_int_rx
;
struct
am33xx_uart
uart1
=
/* UART device driver structure */
#ifdef RT_USING_UART0
struct
serial_ringbuffer
uart0_int_rx
;
struct
am33xx_uart
uart0
=
{
UART0_BASE
,
UART0_INT
,
};
struct
rt_serial_device
serial0
;
#endif
#ifdef RT_USING_UART1
struct
serial_ringbuffer
uart1_int_rx
;
struct
am33xx_uart
uart1
=
{
UART1_BASE
,
UART1_INT
,
};
struct
rt_serial_device
serial1
;
#endif
#ifdef RT_USING_UART2
struct
serial_ringbuffer
uart2_int_rx
;
struct
am33xx_uart
uart2
=
{
UART2_BASE
,
UART2_INT
,
};
struct
rt_serial_device
serial2
;
#endif
#ifdef RT_USING_UART3
struct
serial_ringbuffer
uart3_int_rx
;
struct
am33xx_uart
uart3
=
{
UART3_BASE
,
UART3_INT
,
};
struct
rt_serial_device
serial3
;
#endif
#ifdef RT_USING_UART4
struct
serial_ringbuffer
uart4_int_rx
;
struct
am33xx_uart
uart4
=
{
UART4_BASE
,
UART4_INT
,
};
struct
rt_serial_device
serial4
;
#endif
#ifdef RT_USING_UART5
struct
serial_ringbuffer
uart5_int_rx
;
struct
am33xx_uart
uart5
=
{
UART5_BASE
,
UART5_INT
,
};
struct
rt_serial_device
serial5
;
#endif
#define write_reg(base, value) *(int*)(base) = value
#define read_reg(base) *(int*)(base)
...
...
@@ -219,11 +272,41 @@ static void start_uart_clk(void)
;
/* enable uart1 */
#ifdef RT_USING_UART1
CM_PER_UART1_CLKCTRL_REG
(
prcm_base
)
|=
0x2
;
/* wait for uart1 clk */
while
((
CM_PER_UART1_CLKCTRL_REG
(
prcm_base
)
&
(
0x3
<<
16
))
!=
0
)
;
#endif
#ifdef RT_USING_UART2
CM_PER_UART2_CLKCTRL_REG
(
prcm_base
)
|=
0x2
;
/* wait for uart2 clk */
while
((
CM_PER_UART2_CLKCTRL_REG
(
prcm_base
)
&
(
0x3
<<
16
))
!=
0
)
;
#endif
#ifdef RT_USING_UART3
CM_PER_UART3_CLKCTRL_REG
(
prcm_base
)
|=
0x2
;
/* wait for uart3 clk */
while
((
CM_PER_UART3_CLKCTRL_REG
(
prcm_base
)
&
(
0x3
<<
16
))
!=
0
)
;
#endif
#ifdef RT_USING_UART4
CM_PER_UART4_CLKCTRL_REG
(
prcm_base
)
|=
0x2
;
/* wait for uart4 clk */
while
((
CM_PER_UART4_CLKCTRL_REG
(
prcm_base
)
&
(
0x3
<<
16
))
!=
0
)
;
#endif
#ifdef RT_USING_UART5
CM_PER_UART5_CLKCTRL_REG
(
prcm_base
)
|=
0x2
;
/* wait for uart5 clk */
while
((
CM_PER_UART5_CLKCTRL_REG
(
prcm_base
)
&
(
0x3
<<
16
))
!=
0
)
;
#endif
/* Waiting for the L4LS UART clock */
while
(
!
(
CM_PER_L4LS_CLKSTCTRL_REG
(
prcm_base
)
&
(
1
<<
10
)))
;
...
...
@@ -236,46 +319,173 @@ static void config_pinmux(void)
ctlm_base
=
AM33XX_CTLM_REGS
;
/* make sure the pin mux is OK for uart */
#ifdef RT_USING_UART1
REG32
(
ctlm_base
+
0x800
+
0x180
)
=
0x20
;
REG32
(
ctlm_base
+
0x800
+
0x184
)
=
0x00
;
#endif
#ifdef RT_USING_UART2
REG32
(
ctlm_base
+
0x800
+
0x150
)
=
0x20
;
REG32
(
ctlm_base
+
0x800
+
0x154
)
=
0x00
;
#endif
#ifdef RT_USING_UART3
REG32
(
ctlm_base
+
0x800
+
0x164
)
=
0x01
;
#endif
#ifdef RT_USING_UART4
REG32
(
ctlm_base
+
0x800
+
0x070
)
=
0x26
;
REG32
(
ctlm_base
+
0x800
+
0x074
)
=
0x06
;
#endif
#ifdef RT_USING_UART5
REG32
(
ctlm_base
+
0x800
+
0x0C4
)
=
0x24
;
REG32
(
ctlm_base
+
0x800
+
0x0C0
)
=
0x04
;
#endif
}
int
rt_hw_serial_init
(
void
)
{
struct
am33xx_uart
*
uart
;
struct
serial_configure
config
;
uart
=
&
uart1
;
uart
->
base
=
UART1_BASE
;
poweron_per_domain
();
start_uart_clk
();
config_pinmux
();
#ifdef RT_USING_UART0
config
.
baud_rate
=
BAUD_RATE_115200
;
config
.
bit_order
=
BIT_ORDER_LSB
;
config
.
data_bits
=
DATA_BITS_8
;
config
.
parity
=
PARITY_NONE
;
config
.
stop_bits
=
STOP_BITS_1
;
config
.
invert
=
NRZ_NORMAL
;
serial0
.
ops
=
&
am33xx_uart_ops
;
serial0
.
int_rx
=
&
uart0_int_rx
;
serial0
.
config
=
config
;
/* enable RX interrupt */
UART_IER_REG
(
uart0
.
base
)
=
0x01
;
/* install ISR */
rt_hw_interrupt_install
(
uart0
.
irq
,
am33xx_uart_isr
,
&
serial0
,
"uart0"
);
rt_hw_interrupt_control
(
uart0
.
irq
,
0
,
0
);
rt_hw_interrupt_mask
(
uart0
.
irq
);
/* register UART0 device */
rt_hw_serial_register
(
&
serial0
,
"uart0"
,
RT_DEVICE_FLAG_RDWR
|
RT_DEVICE_FLAG_INT_RX
|
RT_DEVICE_FLAG_STREAM
,
&
uart0
);
#endif
#ifdef RT_USING_UART1
config
.
baud_rate
=
BAUD_RATE_115200
;
config
.
bit_order
=
BIT_ORDER_LSB
;
config
.
data_bits
=
DATA_BITS_8
;
config
.
parity
=
PARITY_NONE
;
config
.
stop_bits
=
STOP_BITS_1
;
config
.
invert
=
NRZ_NORMAL
;
serial1
.
ops
=
&
am33xx_uart_ops
;
serial1
.
int_rx
=
&
uart1_int_rx
;
serial1
.
config
=
config
;
/* enable RX interrupt */
UART_IER_REG
(
uart1
.
base
)
=
0x01
;
/* install ISR */
rt_hw_interrupt_install
(
uart1
.
irq
,
am33xx_uart_isr
,
&
serial1
,
"uart1"
);
rt_hw_interrupt_control
(
uart1
.
irq
,
0
,
0
);
rt_hw_interrupt_mask
(
uart1
.
irq
);
/* register UART0 device */
rt_hw_serial_register
(
&
serial1
,
"uart1"
,
RT_DEVICE_FLAG_RDWR
|
RT_DEVICE_FLAG_INT_RX
|
RT_DEVICE_FLAG_STREAM
,
&
uart1
);
#endif
#ifdef RT_USING_UART2
config
.
baud_rate
=
BAUD_RATE_115200
;
config
.
bit_order
=
BIT_ORDER_LSB
;
config
.
data_bits
=
DATA_BITS_8
;
config
.
parity
=
PARITY_NONE
;
config
.
stop_bits
=
STOP_BITS_1
;
config
.
invert
=
NRZ_NORMAL
;
serial2
.
ops
=
&
am33xx_uart_ops
;
serial2
.
int_rx
=
&
uart2_int_rx
;
serial2
.
config
=
config
;
/* enable RX interrupt */
UART_IER_REG
(
uart
->
base
)
=
0x01
;
UART_IER_REG
(
uart
2
.
base
)
=
0x01
;
/* install ISR */
rt_hw_interrupt_install
(
uart
->
irq
,
am33xx_uart_isr
,
&
serial1
,
"uart1"
);
rt_hw_interrupt_control
(
uart
->
irq
,
0
,
0
);
rt_hw_interrupt_mask
(
uart
->
irq
);
rt_hw_interrupt_install
(
uart2
.
irq
,
am33xx_uart_isr
,
&
serial2
,
"uart2"
);
rt_hw_interrupt_control
(
uart2
.
irq
,
0
,
0
);
rt_hw_interrupt_mask
(
uart2
.
irq
);
/* register UART2 device */
rt_hw_serial_register
(
&
serial2
,
"uart2"
,
RT_DEVICE_FLAG_RDWR
|
RT_DEVICE_FLAG_INT_RX
|
RT_DEVICE_FLAG_STREAM
,
&
uart2
);
#endif
/* register UART1 device */
rt_hw_serial_register
(
&
serial1
,
"uart1"
,
#ifdef RT_USING_UART3
config
.
baud_rate
=
BAUD_RATE_115200
;
config
.
bit_order
=
BIT_ORDER_LSB
;
config
.
data_bits
=
DATA_BITS_8
;
config
.
parity
=
PARITY_NONE
;
config
.
stop_bits
=
STOP_BITS_1
;
config
.
invert
=
NRZ_NORMAL
;
serial3
.
ops
=
&
am33xx_uart_ops
;
serial3
.
int_rx
=
&
uart_3_int_rx
;
serial3
.
config
=
config
;
/* enable RX interrupt */
UART_IER_REG
(
uart3
.
base
)
=
0x01
;
/* install ISR */
rt_hw_interrupt_install
(
uart3
.
irq
,
am33xx_uart_isr
,
&
serial3
,
"uart3"
);
rt_hw_interrupt_control
(
uart3
.
irq
,
0
,
0
);
rt_hw_interrupt_mask
(
uart3
.
irq
);
/* register UART3 device */
rt_hw_serial_register
(
&
serial3
,
"uart3"
,
RT_DEVICE_FLAG_RDWR
|
RT_DEVICE_FLAG_INT_RX
|
RT_DEVICE_FLAG_STREAM
,
&
uart3
);
#endif
#ifdef RT_USING_UART4
config
.
baud_rate
=
BAUD_RATE_115200
;
config
.
bit_order
=
BIT_ORDER_LSB
;
config
.
data_bits
=
DATA_BITS_8
;
config
.
parity
=
PARITY_NONE
;
config
.
stop_bits
=
STOP_BITS_1
;
config
.
invert
=
NRZ_NORMAL
;
serial4
.
ops
=
&
am33xx_uart_ops
;
serial4
.
int_rx
=
&
uart4_int_rx
;
serial4
.
config
=
config
;
/* enable RX interrupt */
UART_IER_REG
(
uart4
.
base
)
=
0x01
;
/* install ISR */
rt_hw_interrupt_install
(
uart4
.
irq
,
am33xx_uart_isr
,
&
serial4
,
"uart4"
);
rt_hw_interrupt_control
(
uart4
.
irq
,
0
,
0
);
rt_hw_interrupt_mask
(
uart4
.
irq
);
/* register UART4 device */
rt_hw_serial_register
(
&
serial4
,
"uart4"
,
RT_DEVICE_FLAG_RDWR
|
RT_DEVICE_FLAG_INT_RX
|
RT_DEVICE_FLAG_STREAM
,
uart
);
&
uart4
);
#endif
#ifdef RT_USING_UART5
config
.
baud_rate
=
BAUD_RATE_115200
;
config
.
bit_order
=
BIT_ORDER_LSB
;
config
.
data_bits
=
DATA_BITS_8
;
config
.
parity
=
PARITY_NONE
;
config
.
stop_bits
=
STOP_BITS_1
;
config
.
invert
=
NRZ_NORMAL
;
serial5
.
ops
=
&
am33xx_uart_ops
;
serial5
.
int_rx
=
&
uart5_int_rx
;
serial5
.
config
=
config
;
/* enable RX interrupt */
UART_IER_REG
(
uart5
.
base
)
=
0x01
;
/* install ISR */
rt_hw_interrupt_install
(
uart5
.
irq
,
am33xx_uart_isr
,
&
serial5
,
"uart5"
);
rt_hw_interrupt_control
(
uart5
.
irq
,
0
,
0
);
rt_hw_interrupt_mask
(
uart5
.
irq
);
/* register UART4 device */
rt_hw_serial_register
(
&
serial5
,
"uart5"
,
RT_DEVICE_FLAG_RDWR
|
RT_DEVICE_FLAG_INT_RX
|
RT_DEVICE_FLAG_STREAM
,
&
uart5
);
#endif
return
0
;
}
INIT_BOARD_EXPORT
(
rt_hw_serial_init
);
bsp/beaglebone/rtconfig.h
浏览文件 @
ff302f28
...
...
@@ -73,6 +73,18 @@
#define RT_USING_DEVICE_IPC
// <bool name="RT_USING_SERIAL" description="Using Serial Device Driver Framework" default="true" />
#define RT_USING_SERIAL
// <bool name="RT_USING_UART0" description="Using uart0" default="true" >
#define RT_USING_UART0
// <bool name="RT_USING_UART1" description="Using uart1" default="true" >
#define RT_USING_UART1
// <bool name="RT_USING_UART2" description="Using uart2" default="true" >
#define RT_USING_UART2
// <bool name="RT_USING_UART3" description="Using uart3" default="true" >
//#define RT_USING_UART3
// <bool name="RT_USING_UART4" description="Using uart4" default="true" >
#define RT_USING_UART4
// <bool name="RT_USING_UART5" description="Using uart5" default="true" >
#define RT_USING_UART5
// <integer name="RT_UART_RX_BUFFER_SIZE" description="The buffer size for UART reception" default="64" />
#define RT_UART_RX_BUFFER_SIZE 64
// <bool name=RT_USING_INTERRUPT_INFO description="Using interrupt information description" default="true" />
...
...
@@ -84,7 +96,7 @@
// <integer name="RT_CONSOLEBUF_SIZE" description="The buffer size for console output" default="128" />
#define RT_CONSOLEBUF_SIZE 128
// <string name="RT_CONSOLE_DEVICE_NAME" description="The device name for console" default="uart" />
#define RT_CONSOLE_DEVICE_NAME "uart
1
"
#define RT_CONSOLE_DEVICE_NAME "uart
0
"
// </section>
// <bool name="RT_USING_COMPONENTS_INIT" description="Using RT-Thread components initialization" default="true" />
...
...
libcpu/arm/am335x/am33xx.h
浏览文件 @
ff302f28
...
...
@@ -84,7 +84,11 @@
#define CM_PER(base) ((base) + 0)
#define CM_PER_L4LS_CLKSTCTRL(base) (CM_PER(base) + 0)
#define CM_PER_UART1_CLKCTRL(base) (CM_PER(base) + 0x06C)
#define CM_PER_UART1_CLKCTRL(base) (CM_PER(base) + 0x6C)
#define CM_PER_UART2_CLKCTRL(base) (CM_PER(base) + 0x70)
#define CM_PER_UART3_CLKCTRL(base) (CM_PER(base) + 0x74)
#define CM_PER_UART4_CLKCTRL(base) (CM_PER(base) + 0x78)
#define CM_PER_UART5_CLKCTRL(base) (CM_PER(base) + 0x38)
#define CM_WKUP(base) ((base) + 0x400)
#define CM_DPLL(base) ((base) + 0x500)
#define CM_MPU(base) ((base) + 0x600)
...
...
@@ -171,6 +175,10 @@
/* PRCM registers */
#define CM_PER_L4LS_CLKSTCTRL_REG(base) REG32((base) + 0x0)
#define CM_PER_UART1_CLKCTRL_REG(base) REG32(CM_PER_UART1_CLKCTRL(base))
#define CM_PER_UART2_CLKCTRL_REG(base) REG32(CM_PER_UART2_CLKCTRL(base))
#define CM_PER_UART3_CLKCTRL_REG(base) REG32(CM_PER_UART3_CLKCTRL(base))
#define CM_PER_UART4_CLKCTRL_REG(base) REG32(CM_PER_UART4_CLKCTRL(base))
#define CM_PER_UART5_CLKCTRL_REG(base) REG32(CM_PER_UART5_CLKCTRL(base))
#define CM_PER_TIMER7_CLKCTRL(base) REG32((base) + 0x7C)
#define CM_PER_TIMER2_CLKCTRL(base) REG32((base) + 0x80)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录