Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
rt-thread
提交
1257e5d3
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
1257e5d3
编写于
3月 18, 2018
作者:
B
balanceTWK
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
del usart.c usart.h
上级
0cbd9dc8
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
0 addition
and
406 deletion
+0
-406
bsp/imxrt1052-evk/drivers/usart.c
bsp/imxrt1052-evk/drivers/usart.c
+0
-383
bsp/imxrt1052-evk/drivers/usart.h
bsp/imxrt1052-evk/drivers/usart.h
+0
-23
未找到文件。
bsp/imxrt1052-evk/drivers/usart.c
已删除
100644 → 0
浏览文件 @
0cbd9dc8
/*
* File : usart.c
* This file is part of RT-Thread RTOS
* COPYRIGHT (C) 2006-2013, RT-Thread Development Team
*
* The license and distribution terms for this file may be
* found in the file LICENSE in this distribution or at
* http://www.rt-thread.org/license/LICENSE
*
* Change Logs:
* Date Author Notes
* 2017-10-10 Tanek the first version
*/
#include <rtthread.h>
#include "usart.h"
#include "fsl_common.h"
#include "fsl_lpuart.h"
#include "fsl_iomuxc.h"
#ifdef RT_USING_SERIAL
#if !defined(RT_USING_UART0) && !defined(RT_USING_UART1) && \
!defined(RT_USING_UART2) && !defined(RT_USING_UART3) && \
!defined(RT_USING_UART4) && !defined(RT_USING_UART5) && \
!defined(RT_USING_UART6) && !defined(RT_USING_UART7)
#error "Please define at least one UARTx"
#endif
#include <rtdevice.h>
/* imxrt uart driver */
struct
imxrt_uart
{
LPUART_Type
*
uart_base
;
IRQn_Type
irqn
;
struct
rt_serial_device
*
serial
;
char
*
device_name
;
};
static
void
uart_isr
(
struct
rt_serial_device
*
serial
);
#if defined(RT_USING_UART1)
struct
rt_serial_device
serial1
;
void
LPUART1_IRQHandler
(
void
)
{
uart_isr
(
&
serial1
);
}
#endif
/* RT_USING_UART1 */
#if defined(RT_USING_UART2)
struct
rt_serial_device
serial2
;
void
USART2_IRQHandler
(
void
)
{
uart_isr
(
&
serial2
);
}
#endif
/* RT_USING_UART2 */
#if defined(RT_USING_UART3)
struct
rt_serial_device
serial3
;
void
UART3_IRQHandler
(
void
)
{
uart_isr
(
&
serial3
);
}
#endif
/* RT_USING_UART3 */
#if defined(RT_USING_UART4)
struct
rt_serial_device
serial4
;
void
UART4_IRQHandler
(
void
)
{
uart_isr
(
&
serial4
);
}
#endif
/* RT_USING_UART4 */
#if defined(RT_USING_UART5)
struct
rt_serial_device
serial5
;
void
USART5_IRQHandler
(
void
)
{
uart_isr
(
&
serial5
);
}
#endif
/* RT_USING_UART5 */
#if defined(RT_USING_UART6)
struct
rt_serial_device
serial6
;
void
UART6_IRQHandler
(
void
)
{
uart_isr
(
&
serial6
);
}
#endif
/* RT_USING_UART6 */
#if defined(RT_USING_UART7)
struct
rt_serial_device
serial7
;
void
UART7_IRQHandler
(
void
)
{
uart_isr
(
&
serial7
);
}
#endif
/* RT_USING_UART7 */
#if defined(RT_USING_UART8)
struct
rt_serial_device
serial8
;
void
UART8_IRQHandler
(
void
)
{
uart_isr
(
&
serial8
);
}
#endif
/* RT_USING_UART8 */
static
const
struct
imxrt_uart
uarts
[]
=
{
#ifdef RT_USING_UART1
{
LPUART1
,
LPUART1_IRQn
,
&
serial1
,
"uart1"
,
},
#endif
};
/* Get debug console frequency. */
uint32_t
BOARD_DebugConsoleSrcFreq
(
void
)
{
uint32_t
freq
;
/* To make it simple, we assume default PLL and divider settings, and the only variable
from application is use PLL3 source or OSC source */
if
(
CLOCK_GetMux
(
kCLOCK_UartMux
)
==
0
)
/* PLL3 div6 80M */
{
freq
=
(
CLOCK_GetPllFreq
(
kCLOCK_PllUsb1
)
/
6U
)
/
(
CLOCK_GetDiv
(
kCLOCK_UartDiv
)
+
1U
);
}
else
{
freq
=
CLOCK_GetOscFreq
()
/
(
CLOCK_GetDiv
(
kCLOCK_UartDiv
)
+
1U
);
}
return
freq
;
}
/**
* @brief UART MSP Initialization
* This function configures the hardware resources used in this example:
* - Peripheral's clock enable
* - Peripheral's GPIO Configuration
* - NVIC configuration for UART interrupt request enable
* @param huart: UART handle pointer
* @retval None
*/
void
imxrt_uart_gpio_init
(
struct
imxrt_uart
*
uart
)
{
if
(
uart
->
uart_base
==
LPUART1
)
{
CLOCK_EnableClock
(
kCLOCK_Iomuxc
);
/* iomuxc clock (iomuxc_clk_enable): 0x03u */
IOMUXC_SetPinMux
(
IOMUXC_GPIO_AD_B0_12_LPUART1_TX
,
/* GPIO_AD_B0_12 is configured as LPUART1_TX */
0U
);
/* Software Input On Field: Input Path is determined by functionality */
IOMUXC_SetPinMux
(
IOMUXC_GPIO_AD_B0_13_LPUART1_RX
,
/* GPIO_AD_B0_13 is configured as LPUART1_RX */
0U
);
/* Software Input On Field: Input Path is determined by functionality */
IOMUXC_SetPinConfig
(
IOMUXC_GPIO_AD_B0_12_LPUART1_TX
,
/* GPIO_AD_B0_12 PAD functional properties : */
0x10B0u
);
/* Slew Rate Field: Slow Slew Rate
Drive Strength Field: R0/6
Speed Field: medium(100MHz)
Open Drain Enable Field: Open Drain Disabled
Pull / Keep Enable Field: Pull/Keeper Enabled
Pull / Keep Select Field: Keeper
Pull Up / Down Config. Field: 100K Ohm Pull Down
Hyst. Enable Field: Hysteresis Disabled */
IOMUXC_SetPinConfig
(
IOMUXC_GPIO_AD_B0_13_LPUART1_RX
,
/* GPIO_AD_B0_13 PAD functional properties : */
0x10B0u
);
/* Slew Rate Field: Slow Slew Rate
Drive Strength Field: R0/6
Speed Field: medium(100MHz)
Open Drain Enable Field: Open Drain Disabled
Pull / Keep Enable Field: Pull/Keeper Enabled
Pull / Keep Select Field: Keeper
Pull Up / Down Config. Field: 100K Ohm Pull Down
Hyst. Enable Field: Hysteresis Disabled */
}
else
{
RT_ASSERT
(
RT_NULL
);
}
}
static
rt_err_t
imxrt_configure
(
struct
rt_serial_device
*
serial
,
struct
serial_configure
*
cfg
)
{
struct
imxrt_uart
*
uart
;
lpuart_config_t
config
;
RT_ASSERT
(
serial
!=
RT_NULL
);
RT_ASSERT
(
cfg
!=
RT_NULL
);
uart
=
(
struct
imxrt_uart
*
)
serial
->
parent
.
user_data
;
imxrt_uart_gpio_init
(
uart
);
LPUART_GetDefaultConfig
(
&
config
);
config
.
baudRate_Bps
=
cfg
->
baud_rate
;
switch
(
cfg
->
data_bits
)
{
case
DATA_BITS_7
:
config
.
dataBitsCount
=
kLPUART_SevenDataBits
;
break
;
default:
config
.
dataBitsCount
=
kLPUART_EightDataBits
;
break
;
}
switch
(
cfg
->
stop_bits
)
{
case
STOP_BITS_2
:
config
.
stopBitCount
=
kLPUART_TwoStopBit
;
break
;
default:
config
.
stopBitCount
=
kLPUART_OneStopBit
;
break
;
}
switch
(
cfg
->
parity
)
{
case
PARITY_ODD
:
config
.
parityMode
=
kLPUART_ParityOdd
;
break
;
case
PARITY_EVEN
:
config
.
parityMode
=
kLPUART_ParityEven
;
break
;
default:
config
.
parityMode
=
kLPUART_ParityDisabled
;
break
;
}
config
.
enableTx
=
true
;
config
.
enableRx
=
true
;
LPUART_Init
(
uart
->
uart_base
,
&
config
,
BOARD_DebugConsoleSrcFreq
());
return
RT_EOK
;
}
static
rt_err_t
imxrt_control
(
struct
rt_serial_device
*
serial
,
int
cmd
,
void
*
arg
)
{
struct
imxrt_uart
*
uart
;
RT_ASSERT
(
serial
!=
RT_NULL
);
uart
=
(
struct
imxrt_uart
*
)
serial
->
parent
.
user_data
;
switch
(
cmd
)
{
case
RT_DEVICE_CTRL_CLR_INT
:
/* disable interrupt */
LPUART_DisableInterrupts
(
uart
->
uart_base
,
kLPUART_RxDataRegFullInterruptEnable
);
/* disable rx irq */
DisableIRQ
(
uart
->
irqn
);
break
;
case
RT_DEVICE_CTRL_SET_INT
:
/* enable interrupt */
LPUART_EnableInterrupts
(
uart
->
uart_base
,
kLPUART_RxDataRegFullInterruptEnable
);
/* enable rx irq */
EnableIRQ
(
uart
->
irqn
);
break
;
}
return
RT_EOK
;
}
static
int
imxrt_putc
(
struct
rt_serial_device
*
serial
,
char
ch
)
{
struct
imxrt_uart
*
uart
;
RT_ASSERT
(
serial
!=
RT_NULL
);
uart
=
(
struct
imxrt_uart
*
)
serial
->
parent
.
user_data
;
LPUART_WriteByte
(
uart
->
uart_base
,
ch
);
while
(
!
(
LPUART_GetStatusFlags
(
uart
->
uart_base
)
&
kLPUART_TxDataRegEmptyFlag
));
return
1
;
}
static
int
imxrt_getc
(
struct
rt_serial_device
*
serial
)
{
int
ch
;
struct
imxrt_uart
*
uart
;
RT_ASSERT
(
serial
!=
RT_NULL
);
uart
=
(
struct
imxrt_uart
*
)
serial
->
parent
.
user_data
;
ch
=
-
1
;
if
(
LPUART_GetStatusFlags
(
uart
->
uart_base
)
&
kLPUART_RxDataRegFullFlag
)
ch
=
LPUART_ReadByte
(
uart
->
uart_base
);
return
ch
;
}
/**
* Uart common interrupt process. This need add to uart ISR.
*
* @param serial serial device
*/
static
void
uart_isr
(
struct
rt_serial_device
*
serial
)
{
struct
imxrt_uart
*
uart
;
LPUART_Type
*
base
;
RT_ASSERT
(
serial
!=
RT_NULL
);
uart
=
(
struct
imxrt_uart
*
)
serial
->
parent
.
user_data
;
RT_ASSERT
(
uart
!=
RT_NULL
);
base
=
uart
->
uart_base
;
RT_ASSERT
(
base
!=
RT_NULL
);
/* enter interrupt */
rt_interrupt_enter
();
/* UART in mode Receiver -------------------------------------------------*/
if
(
LPUART_GetStatusFlags
(
base
)
&
kLPUART_RxDataRegFullFlag
)
{
rt_hw_serial_isr
(
serial
,
RT_SERIAL_EVENT_RX_IND
);
}
/* If RX overrun. */
if
(
LPUART_STAT_OR_MASK
&
base
->
STAT
)
{
/* Clear overrun flag, otherwise the RX does not work. */
base
->
STAT
=
((
base
->
STAT
&
0x3FE00000U
)
|
LPUART_STAT_OR_MASK
);
}
/* leave interrupt */
rt_interrupt_leave
();
}
static
const
struct
rt_uart_ops
imxrt_uart_ops
=
{
imxrt_configure
,
imxrt_control
,
imxrt_putc
,
imxrt_getc
,
};
int
imxrt_hw_usart_init
(
void
)
{
struct
serial_configure
config
=
RT_SERIAL_CONFIG_DEFAULT
;
int
i
;
for
(
i
=
0
;
i
<
sizeof
(
uarts
)
/
sizeof
(
uarts
[
0
]);
i
++
)
{
uarts
[
i
].
serial
->
ops
=
&
imxrt_uart_ops
;
uarts
[
i
].
serial
->
config
=
config
;
/* register UART1 device */
rt_hw_serial_register
(
uarts
[
i
].
serial
,
uarts
[
i
].
device_name
,
RT_DEVICE_FLAG_RDWR
|
RT_DEVICE_FLAG_INT_RX
,
(
void
*
)
&
uarts
[
i
]);
}
return
0
;
}
INIT_BOARD_EXPORT
(
imxrt_hw_usart_init
);
#endif
/*RT_USING_SERIAL */
bsp/imxrt1052-evk/drivers/usart.h
已删除
100644 → 0
浏览文件 @
0cbd9dc8
/*
* File : usart.h
* This file is part of RT-Thread RTOS
* COPYRIGHT (C) 2009, RT-Thread Development Team
*
* The license and distribution terms for this file may be
* found in the file LICENSE in this distribution or at
* http://www.rt-thread.org/license/LICENSE
*
* Change Logs:
* Date Author Notes
* 2017-10-10 Tanek the first version
*/
#ifndef __USART_H__
#define __USART_H__
#include <rthw.h>
#include <rtthread.h>
int
rt_hw_usart_init
(
void
);
#endif
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录