Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
RT-Thread
rt-thread
提交
b2b3fa6e
R
rt-thread
项目概览
RT-Thread
/
rt-thread
大约 1 年 前同步成功
通知
774
Star
8911
Fork
4735
代码
文件
提交
分支
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,发现更多精彩内容 >>
提交
b2b3fa6e
编写于
1月 09, 2022
作者:
mysterywolf
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
format codes
上级
f21af836
变更
17
隐藏空白更改
内联
并排
Showing
17 changed file
with
228 addition
and
228 deletion
+228
-228
bsp/CME_M7/drivers/app_phy.c
bsp/CME_M7/drivers/app_phy.c
+67
-67
bsp/CME_M7/drivers/app_phy.h
bsp/CME_M7/drivers/app_phy.h
+8
-8
bsp/CME_M7/drivers/emac.c
bsp/CME_M7/drivers/emac.c
+4
-4
bsp/CME_M7/drivers/uart.c
bsp/CME_M7/drivers/uart.c
+23
-23
bsp/efm32/application.c
bsp/efm32/application.c
+111
-111
bsp/ra6m4-cpk/drivers/drv_gpio.h
bsp/ra6m4-cpk/drivers/drv_gpio.h
+1
-1
bsp/ra6m4-cpk/drivers/drv_rtc.c
bsp/ra6m4-cpk/drivers/drv_rtc.c
+1
-1
bsp/ra6m4-cpk/ra_cfg/fsp_cfg/bsp/bsp_cfg.h
bsp/ra6m4-cpk/ra_cfg/fsp_cfg/bsp/bsp_cfg.h
+1
-1
bsp/ra6m4-cpk/ra_gen/vector_data.c
bsp/ra6m4-cpk/ra_gen/vector_data.c
+1
-1
bsp/ra6m4-cpk/ra_gen/vector_data.h
bsp/ra6m4-cpk/ra_gen/vector_data.h
+1
-1
bsp/ra6m4-cpk/src/hal_entry.c
bsp/ra6m4-cpk/src/hal_entry.c
+1
-1
bsp/zynqmp-r5-axu4ev/drivers/board.h
bsp/zynqmp-r5-axu4ev/drivers/board.h
+1
-1
bsp/zynqmp-r5-axu4ev/drivers/drv_eth.c
bsp/zynqmp-r5-axu4ev/drivers/drv_eth.c
+1
-1
bsp/zynqmp-r5-axu4ev/drivers/drv_sdcard.c
bsp/zynqmp-r5-axu4ev/drivers/drv_sdcard.c
+2
-2
bsp/zynqmp-r5-axu4ev/drivers/drv_timer.c
bsp/zynqmp-r5-axu4ev/drivers/drv_timer.c
+2
-2
bsp/zynqmp-r5-axu4ev/drivers/drv_timer.h
bsp/zynqmp-r5-axu4ev/drivers/drv_timer.h
+1
-1
bsp/zynqmp-r5-axu4ev/drivers/drv_uart.c
bsp/zynqmp-r5-axu4ev/drivers/drv_uart.c
+2
-2
未找到文件。
bsp/CME_M7/drivers/app_phy.c
浏览文件 @
b2b3fa6e
#include <stdio.h>
#include "app_phy.h"
#define PHY_BASE_ADDR
0x7
#define PHY_BASE_ADDR
0x7
#define PHY_REG_CONTROL 0x0
#define PHY_REG_STATUS 0x1
#define PHY_REG_ANE 0x6
#define PHY_REG_SPEC_STATUS 0x11
#define PHY_REG_EXTEND_STATUS
0x1B
#define PHY_REG_EXTEND_STATUS
0x1B
#define PHY_BIT_CONTROL_RESET 0x8000
/*!< Control reg : reset */
#define PHY_BIT_CONTROL_ANEN 0x1000
/*!< Control reg : auto-negotiation enable */
#define PHY_BIT_CONTROL_RSAN 0x0200
/*!< Control reg : auto-negotiation restart */
#define PHY_BIT_CONTROL_RESET 0x8000
/*!< Control reg : reset */
#define PHY_BIT_CONTROL_ANEN 0x1000
/*!< Control reg : auto-negotiation enable */
#define PHY_BIT_CONTROL_RSAN 0x0200
/*!< Control reg : auto-negotiation restart */
#define PHY_BIT_STATUS_ANC 0x0020
/*!< Status reg : auto-negotiation complete */
#define PHY_BIT_STATUS_LINK 0x0004
/*!< Status reg : link is up */
#define PHY_BIT_STATUS_ANC 0x0020
/*!< Status reg : auto-negotiation complete */
#define PHY_BIT_STATUS_LINK 0x0004
/*!< Status reg : link is up */
#define PHY_BIT_ANE_LPAN 0x0001
/*!< ANE reg : link partner can auto-neg */
#define PHY_BIT_ANE_LPAN 0x0001
/*!< ANE reg : link partner can auto-neg */
#define PHY_BIT_SPEED 0xC000
/*!< specific status reg : speed */
#define PHY_BIT_DUPLEX 0x2000
/*!< specific status reg : duplex */
...
...
@@ -25,24 +25,24 @@
#define PHY_BIT_AUTO_MEDIA_REG_DISABLE 0x0200
/*!< extended status reg : auto media register select disable */
void
phy_Reset
()
{
ETH_PhyWrite
(
PHY_BASE_ADDR
,
PHY_REG_CONTROL
,
PHY_BIT_CONTROL_RESET
);
while
(
1
)
{
uint32_t
ret
=
ETH_PhyRead
(
PHY_BASE_ADDR
,
PHY_REG_CONTROL
);
if
((
ret
&
PHY_BIT_CONTROL_RESET
)
==
0
)
{
break
;
}
}
ETH_PhyWrite
(
PHY_BASE_ADDR
,
PHY_REG_CONTROL
,
PHY_BIT_CONTROL_RESET
);
while
(
1
)
{
uint32_t
ret
=
ETH_PhyRead
(
PHY_BASE_ADDR
,
PHY_REG_CONTROL
);
if
((
ret
&
PHY_BIT_CONTROL_RESET
)
==
0
)
{
break
;
}
}
}
void
phy_AutoMediaSelect
()
{
uint32_t
data
;
uint32_t
data
;
// auto media and auto media register selection
data
=
ETH_PhyRead
(
PHY_BASE_ADDR
,
PHY_REG_EXTEND_STATUS
);
data
&=
~
PHY_BIT_AUTO_MEDIA_DISABLE
;
data
&=
~
PHY_BIT_AUTO_MEDIA_REG_DISABLE
;
ETH_PhyWrite
(
PHY_BASE_ADDR
,
PHY_REG_EXTEND_STATUS
,
data
);
// auto media and auto media register selection
data
=
ETH_PhyRead
(
PHY_BASE_ADDR
,
PHY_REG_EXTEND_STATUS
);
data
&=
~
PHY_BIT_AUTO_MEDIA_DISABLE
;
data
&=
~
PHY_BIT_AUTO_MEDIA_REG_DISABLE
;
ETH_PhyWrite
(
PHY_BASE_ADDR
,
PHY_REG_EXTEND_STATUS
,
data
);
}
void
phy_AutoNeg
()
...
...
@@ -65,61 +65,61 @@ void phy_AutoNeg()
}
BOOL
phy_IsLink
()
{
uint32_t
ret
=
ETH_PhyRead
(
PHY_BASE_ADDR
,
PHY_REG_STATUS
);
return
(
ret
&
PHY_BIT_STATUS_LINK
)
?
TRUE
:
FALSE
;
uint32_t
ret
=
ETH_PhyRead
(
PHY_BASE_ADDR
,
PHY_REG_STATUS
);
return
(
ret
&
PHY_BIT_STATUS_LINK
)
?
TRUE
:
FALSE
;
}
BOOL
phy_PartnerCanAutoNeg
()
{
uint32_t
ret
=
ETH_PhyRead
(
PHY_BASE_ADDR
,
PHY_REG_ANE
);
return
(
ret
&
PHY_BIT_ANE_LPAN
)
?
TRUE
:
FALSE
;
uint32_t
ret
=
ETH_PhyRead
(
PHY_BASE_ADDR
,
PHY_REG_ANE
);
return
(
ret
&
PHY_BIT_ANE_LPAN
)
?
TRUE
:
FALSE
;
}
uint32_t
phy_GetSpeed
()
{
uint32_t
ret
=
ETH_PhyRead
(
PHY_BASE_ADDR
,
PHY_REG_SPEC_STATUS
);
return
((
ret
&
PHY_BIT_SPEED
)
>>
14
);
uint32_t
ret
=
ETH_PhyRead
(
PHY_BASE_ADDR
,
PHY_REG_SPEC_STATUS
);
return
((
ret
&
PHY_BIT_SPEED
)
>>
14
);
}
uint32_t
phy_GetDuplex
()
{
uint32_t
ret
=
ETH_PhyRead
(
PHY_BASE_ADDR
,
PHY_REG_SPEC_STATUS
);
return
((
ret
&
PHY_BIT_DUPLEX
)
>>
13
);
uint32_t
ret
=
ETH_PhyRead
(
PHY_BASE_ADDR
,
PHY_REG_SPEC_STATUS
);
return
((
ret
&
PHY_BIT_DUPLEX
)
>>
13
);
}
BOOL
phy_Init
()
{
phy_AutoMediaSelect
();
phy_AutoNeg
();
if
(
!
phy_PartnerCanAutoNeg
())
{
printf
(
"Warning:: PHY's partner can't do auto-negotiation
\n
"
);
}
if
(
!
phy_IsLink
())
{
printf
(
"link is down
\n
"
);
return
FALSE
;
}
{
uint32_t
speed
=
phy_GetSpeed
();
if
(
speed
==
PHY_SPEED_10
)
{
speed
=
10
;
}
else
if
(
speed
==
PHY_SPEED_100
)
{
speed
=
100
;
}
else
if
(
speed
==
PHY_SPEED_1000
)
{
speed
=
1000
;
}
printf
(
"PHY runs in %dM speed %s duplex
\n
"
,
speed
,
(
phy_GetDuplex
()
==
PHY_DUPLEX_HALF
)
?
"half"
:
"full"
);
}
// After auto-negcioation, Mawell PHY need some
// time to initial itself.
// So we have to delay some time since different
// connection way, such as direct wire, hub, switch.
// If not to delay, the first several sent frame
// may be lost.
// Please according to actual environment to tune
// this delay.
udelay
(
200000
);
return
TRUE
;
phy_AutoMediaSelect
();
phy_AutoNeg
();
if
(
!
phy_PartnerCanAutoNeg
())
{
printf
(
"Warning:: PHY's partner can't do auto-negotiation
\n
"
);
}
if
(
!
phy_IsLink
())
{
printf
(
"link is down
\n
"
);
return
FALSE
;
}
{
uint32_t
speed
=
phy_GetSpeed
();
if
(
speed
==
PHY_SPEED_10
)
{
speed
=
10
;
}
else
if
(
speed
==
PHY_SPEED_100
)
{
speed
=
100
;
}
else
if
(
speed
==
PHY_SPEED_1000
)
{
speed
=
1000
;
}
printf
(
"PHY runs in %dM speed %s duplex
\n
"
,
speed
,
(
phy_GetDuplex
()
==
PHY_DUPLEX_HALF
)
?
"half"
:
"full"
);
}
// After auto-negcioation, Mawell PHY need some
// time to initial itself.
// So we have to delay some time since different
// connection way, such as direct wire, hub, switch.
// If not to delay, the first several sent frame
// may be lost.
// Please according to actual environment to tune
// this delay.
udelay
(
200000
);
return
TRUE
;
}
bsp/CME_M7/drivers/app_phy.h
浏览文件 @
b2b3fa6e
...
...
@@ -7,13 +7,13 @@
#include "cmem7_includes.h"
#define PHY_SPEED_10
0x0
/*!< SPEED : 10M */
#define PHY_SPEED_100
0x1
/*!< SPEED : 100M */
#define PHY_SPEED_1000
0x2
/*!< SPEED : 1000M */
#define PHY_DUPLEX_HALF
0x0
/*!< DUPLEX : half */
#define PHY_DUPLEX_FULL
0x1
/*!< DUPLEX : full */
#define PHY_SPEED_10
0x0
/*!< SPEED : 10M */
#define PHY_SPEED_100
0x1
/*!< SPEED : 100M */
#define PHY_SPEED_1000
0x2
/*!< SPEED : 1000M */
#define PHY_DUPLEX_HALF
0x0
/*!< DUPLEX : half */
#define PHY_DUPLEX_FULL
0x1
/*!< DUPLEX : full */
void
phy_Reset
(
void
);
void
phy_AutoNeg
(
void
);
BOOL
phy_IsLink
(
void
);
...
...
@@ -26,7 +26,7 @@ BOOL phy_Init(void);
}
#endif
#endif
#endif
bsp/CME_M7/drivers/emac.c
浏览文件 @
b2b3fa6e
/*
* File : emac.c
* This file is part of RT-Thread RTOS
* COPYRIGHT (C) 2006-20
14
, RT-Thread Develop Team
* COPYRIGHT (C) 2006-20
21
, RT-Thread Develop Team
*
* The license and distribution terms for this file may be
* found in the file LICENSE in this distribution or at
...
...
@@ -38,7 +38,7 @@ struct rt_cme_eth
struct
eth_device
parent
;
/* interface address info. */
rt_uint8_t
dev_addr
[
MAX_ADDR_LEN
];
/* hw address
*/
rt_uint8_t
dev_addr
[
MAX_ADDR_LEN
];
/* hw address
*/
uint32_t
ETH_Speed
;
uint32_t
ETH_Mode
;
...
...
@@ -95,8 +95,8 @@ uint32_t txTotalMemory = 0x2000;
BOOL
isRxNoBuf
=
FALSE
;
#define ETH_MAX_PACKET_SIZE 1520
/* ETH_HEADER + ETH_EXTRA + MAX_ETH_PAYLOAD + ETH_CRC */
#define ETH_RXBUFNB
4
#define ETH_TXBUFNB
2
#define ETH_RXBUFNB
4
#define ETH_TXBUFNB
2
struct
eth_rx_buffer
{
...
...
bsp/CME_M7/drivers/uart.c
浏览文件 @
b2b3fa6e
...
...
@@ -32,23 +32,23 @@ static struct rt_serial_device serial2;
static
rt_err_t
CME_M7_configure
(
struct
rt_serial_device
*
serial
,
struct
serial_configure
*
cfg
)
{
struct
CME_M7_uart
*
uart
;
UART_InitTypeDef
init
;
UART_InitTypeDef
init
;
RT_ASSERT
(
serial
!=
RT_NULL
);
RT_ASSERT
(
cfg
!=
RT_NULL
);
uart
=
(
struct
CME_M7_uart
*
)
serial
->
parent
.
user_data
;
init
.
UART_BaudRate
=
cfg
->
baud_rate
;
init
.
UART_StopBits
=
UART_StopBits_1
;
init
.
UART_BaudRate
=
cfg
->
baud_rate
;
init
.
UART_StopBits
=
UART_StopBits_1
;
init
.
UART_Parity
=
UART_Parity_None
;
init
.
UART_LoopBack
=
FALSE
;
init
.
UART_RxEn
=
TRUE
;
init
.
UART_CtsEn
=
FALSE
;
init
.
UART_LoopBack
=
FALSE
;
init
.
UART_RxEn
=
TRUE
;
init
.
UART_CtsEn
=
FALSE
;
UART_Init
(
uart
->
uart_device
,
&
init
);
uart
->
uart_device
->
RX_RESET
=
1
;
UART_Enable
(
uart
->
uart_device
,
TRUE
);
UART_Enable
(
uart
->
uart_device
,
TRUE
);
uart
->
uart_device
->
RX_RESET
=
0
;
return
RT_EOK
;
...
...
@@ -67,24 +67,24 @@ static rt_err_t CME_M7_control(struct rt_serial_device *serial, int cmd, void *a
case
RT_DEVICE_CTRL_CLR_INT
:
/* disable rx irq */
NVIC_InitStructure
.
NVIC_IRQChannel
=
uart
->
irq
;
NVIC_InitStructure
.
NVIC_IRQChannelPreemptionPriority
=
0
;
NVIC_InitStructure
.
NVIC_IRQChannelSubPriority
=
0
;
NVIC_InitStructure
.
NVIC_IRQChannelCmd
=
FALSE
;
NVIC_Init
(
&
NVIC_InitStructure
);
NVIC_InitStructure
.
NVIC_IRQChannelPreemptionPriority
=
0
;
NVIC_InitStructure
.
NVIC_IRQChannelSubPriority
=
0
;
NVIC_InitStructure
.
NVIC_IRQChannelCmd
=
FALSE
;
NVIC_Init
(
&
NVIC_InitStructure
);
UART_EnableInt
(
uart
->
uart_device
,
UART_Int_RxNotEmpty
,
FALSE
);
UART_EnableInt
(
uart
->
uart_device
,
UART_Int_RxNotEmpty
,
FALSE
);
break
;
case
RT_DEVICE_CTRL_SET_INT
:
/* enable rx irq */
NVIC_InitStructure
.
NVIC_IRQChannel
=
uart
->
irq
;
NVIC_InitStructure
.
NVIC_IRQChannelPreemptionPriority
=
0
;
NVIC_InitStructure
.
NVIC_IRQChannelSubPriority
=
0
;
NVIC_InitStructure
.
NVIC_IRQChannelCmd
=
TRUE
;
NVIC_Init
(
&
NVIC_InitStructure
);
NVIC_InitStructure
.
NVIC_IRQChannelPreemptionPriority
=
0
;
NVIC_InitStructure
.
NVIC_IRQChannelSubPriority
=
0
;
NVIC_InitStructure
.
NVIC_IRQChannelCmd
=
TRUE
;
NVIC_Init
(
&
NVIC_InitStructure
);
UART_ClearInt
(
uart
->
uart_device
,
UART_Int_RxNotEmpty
);
UART_EnableInt
(
uart
->
uart_device
,
UART_Int_RxNotEmpty
,
TRUE
);
UART_ClearInt
(
uart
->
uart_device
,
UART_Int_RxNotEmpty
);
UART_EnableInt
(
uart
->
uart_device
,
UART_Int_RxNotEmpty
,
TRUE
);
break
;
}
...
...
@@ -132,8 +132,8 @@ static const struct rt_uart_ops CME_M7_uart_ops =
int
rt_hw_uart_init
(
void
)
{
struct
CME_M7_uart
*
uart
;
struct
rt_serial_device
*
serial
;
struct
CME_M7_uart
*
uart
;
struct
rt_serial_device
*
serial
;
struct
serial_configure
config
=
RT_SERIAL_CONFIG_DEFAULT
;
#ifdef RT_USING_UART0
...
...
@@ -143,7 +143,7 @@ int rt_hw_uart_init(void)
serial
->
ops
=
&
CME_M7_uart_ops
;
serial
->
config
=
config
;
/* register UART device */
/* register UART device */
rt_hw_serial_register
(
serial
,
"uart0"
,
RT_DEVICE_FLAG_RDWR
|
RT_DEVICE_FLAG_INT_RX
,
...
...
@@ -157,14 +157,14 @@ int rt_hw_uart_init(void)
serial
->
ops
=
&
CME_M7_uart_ops
;
serial
->
config
=
config
;
/* register UART device */
/* register UART device */
rt_hw_serial_register
(
serial
,
"uart2"
,
RT_DEVICE_FLAG_RDWR
|
RT_DEVICE_FLAG_INT_RX
,
uart
);
#endif
/* RT_USING_UART2 */
return
RT_EOK
;
return
RT_EOK
;
}
INIT_BOARD_EXPORT
(
rt_hw_uart_init
);
...
...
bsp/efm32/application.c
浏览文件 @
b2b3fa6e
...
...
@@ -65,7 +65,7 @@
#include <rtgui/widgets/box.h>
#include <rtgui/image.h>
#if defined(RTGUI_USING_DFS_FILERW)
#if defined(RTGUI_USING_DFS_FILERW)
#include <dfs_posix.h>
#define PATH_SEPARATOR '/'
#endif
...
...
@@ -77,8 +77,8 @@ struct photo_event
{
struct
rtgui_event_win
win
;
rt_uint32_t
cmd
;
rt_uint8_t
*
path
;
rt_uint8_t
*
format
;
rt_uint8_t
*
path
;
rt_uint8_t
*
format
;
};
/* Private defines -----------------------------------------------------------*/
...
...
@@ -95,10 +95,10 @@ volatile rt_uint32_t rt_system_status = 0;
#if defined(RT_USING_RTGUI)
static
rt_bool_t
pic_view_event_handler
(
rtgui_object_t
*
object
,
rtgui_event_t
*
event
)
{
rt_bool_t
result
;
rt_bool_t
result
;
rt_bool_t
load
=
RT_FALSE
;
result
=
rtgui_container_event_handler
(
object
,
event
);
result
=
rtgui_container_event_handler
(
object
,
event
);
switch
(
event
->
type
)
{
...
...
@@ -108,27 +108,27 @@ static rt_bool_t pic_view_event_handler(rtgui_object_t *object, rtgui_event_t *e
case
RTGUI_EVENT_MOUSE_BUTTON
:
{
struct
rtgui_event_mouse
*
mouse
=
(
struct
rtgui_event_mouse
*
)
event
;
struct
rtgui_event_mouse
*
mouse
=
(
struct
rtgui_event_mouse
*
)
event
;
if
(
mouse
->
button
==
RTGUI_MOUSE_BUTTON_LEFT
|
RTGUI_MOUSE_BUTTON_UP
)
{
if
(
mouse
->
button
==
RTGUI_MOUSE_BUTTON_LEFT
|
RTGUI_MOUSE_BUTTON_UP
)
{
rt_kprintf
(
"APP: left click (%x)
\n
"
,
mouse
->
button
);
}
}
}
break
;
}
if
(
load
)
{
struct
rtgui_dc
*
dc
;
rtgui_rect_t
rect
;
{
struct
rtgui_dc
*
dc
;
rtgui_rect_t
rect
;
rtgui_image_t
*
image
;
image
=
rtgui_image_create_from_file
(
"jpg"
,
"/test9.jpg"
,
RT_FALSE
);
// image = rtgui_image_create_from_file("bmp", "/test_565.bmp", RT_FALSE);
dc
=
rtgui_dc_begin_drawing
(
RTGUI_WIDGET
(
object
));
if
(
dc
==
RT_NULL
)
dc
=
rtgui_dc_begin_drawing
(
RTGUI_WIDGET
(
object
));
if
(
dc
==
RT_NULL
)
{
return
result
;
}
...
...
@@ -138,9 +138,9 @@ static rt_bool_t pic_view_event_handler(rtgui_object_t *object, rtgui_event_t *e
rect
.
x1
+=
10
;
rect
.
y1
+=
10
;
if
(
image
!=
RT_NULL
)
if
(
image
!=
RT_NULL
)
{
rtgui_image_blit
(
image
,
dc
,
&
rect
);
rtgui_image_blit
(
image
,
dc
,
&
rect
);
rtgui_image_destroy
(
image
);
}
else
...
...
@@ -148,10 +148,10 @@ static rt_bool_t pic_view_event_handler(rtgui_object_t *object, rtgui_event_t *e
rt_kprintf
(
"APP err: no image found!
\n
"
);
}
rtgui_dc_end_drawing
(
dc
,
RT_TRUE
);
}
rtgui_dc_end_drawing
(
dc
,
RT_TRUE
);
}
return
result
;
return
result
;
}
static
void
app_main
(
void
*
parameter
)
...
...
@@ -169,21 +169,21 @@ static void app_main(void *parameter)
lcd
->
control
(
lcd
,
RTGRAPHIC_CTRL_GET_INFO
,
(
void
*
)
&
lcd_info
);
rt_kprintf
(
"LCD size: %dX%d
\n
"
,
lcd_info
.
width
,
lcd_info
.
height
);
/* create application */
struct
rtgui_app
*
app
;
app
=
rtgui_app_create
(
"gui_app"
);
if
(
app
==
RT_NULL
)
/* create application */
struct
rtgui_app
*
app
;
app
=
rtgui_app_create
(
"gui_app"
);
if
(
app
==
RT_NULL
)
{
rt_kprintf
(
"Create application
\"
gui_app
\"
failed!
\n
"
);
return
;
}
struct
rtgui_rect
rect1
,
rect2
,
rect3
;
struct
rtgui_rect
rect1
,
rect2
,
rect3
;
struct
rtgui_win
*
win_info
,
*
win_main
,
*
win_hello
;
struct
rtgui_container
*
container
;
struct
rtgui_container
*
container
;
struct
rtgui_label
*
label
;
rtgui_graphic_driver_get_rect
(
rtgui_graphic_driver_get_default
(),
&
rect1
);
rtgui_graphic_driver_get_rect
(
rtgui_graphic_driver_get_default
(),
&
rect1
);
rect2
.
x1
=
rect1
.
x1
;
rect2
.
y1
=
25
;
rect2
.
x2
=
rect1
.
x2
;
...
...
@@ -191,119 +191,119 @@ static void app_main(void *parameter)
rect1
.
y2
=
25
;
/* create info window */
win_info
=
rtgui_win_create
(
RT_NULL
,
"info"
,
win_info
=
rtgui_win_create
(
RT_NULL
,
"info"
,
&
rect1
,
RTGUI_WIN_STYLE_NO_BORDER
|
RTGUI_WIN_STYLE_NO_TITLE
);
if
(
win_info
==
RT_NULL
)
{
if
(
win_info
==
RT_NULL
)
{
rt_kprintf
(
"Create window
\"
info
\"
failed!
\n
"
);
rtgui_app_destroy
(
app
);
rtgui_app_destroy
(
app
);
return
;
}
}
/* create container in info window */
container
=
rtgui_container_create
();
if
(
container
==
RT_NULL
)
{
container
=
rtgui_container_create
();
if
(
container
==
RT_NULL
)
{
rt_kprintf
(
"Create container failed!
\n
"
);
return
;
}
rtgui_widget_set_rect
(
RTGUI_WIDGET
(
container
),
&
rect1
);
return
;
}
rtgui_widget_set_rect
(
RTGUI_WIDGET
(
container
),
&
rect1
);
rtgui_container_add_child
(
RTGUI_CONTAINER
(
win_info
),
RTGUI_WIDGET
(
container
));
/* create lable in info window */
label
=
rtgui_label_create
(
"RT-Thread & RTGUI"
);
label
=
rtgui_label_create
(
"RT-Thread & RTGUI"
);
if
(
label
==
RT_NULL
)
{
rt_kprintf
(
"Create lable failed!
\n
"
);
return
;
}
RTGUI_WIDGET_TEXTALIGN
(
RTGUI_WIDGET
(
label
))
=
RTGUI_ALIGN_LEFT
;
RTGUI_WIDGET_BACKGROUND
(
RTGUI_WIDGET
(
label
))
=
red
;
RTGUI_WIDGET_TEXTALIGN
(
RTGUI_WIDGET
(
label
))
=
RTGUI_ALIGN_LEFT
;
RTGUI_WIDGET_BACKGROUND
(
RTGUI_WIDGET
(
label
))
=
red
;
RTGUI_WIDGET_FOREGROUND
(
RTGUI_WIDGET
(
label
))
=
white
;
rect3
.
x1
=
rect1
.
x1
+
5
;
rect3
.
y1
=
rect1
.
y1
+
5
;
rect3
.
x2
=
rect1
.
x2
-
5
;
rect3
.
y2
=
rect1
.
y2
-
5
;
rtgui_widget_set_rect
(
RTGUI_WIDGET
(
label
),
&
rect3
);
rtgui_container_add_child
(
container
,
RTGUI_WIDGET
(
label
));
rect3
.
x1
=
rect1
.
x1
+
5
;
rect3
.
y1
=
rect1
.
y1
+
5
;
rect3
.
x2
=
rect1
.
x2
-
5
;
rect3
.
y2
=
rect1
.
y2
-
5
;
rtgui_widget_set_rect
(
RTGUI_WIDGET
(
label
),
&
rect3
);
rtgui_container_add_child
(
container
,
RTGUI_WIDGET
(
label
));
/* create main window */
win_main
=
rtgui_win_create
(
RT_NULL
,
"main"
,
win_main
=
rtgui_win_create
(
RT_NULL
,
"main"
,
&
rect2
,
RTGUI_WIN_STYLE_NO_BORDER
|
RTGUI_WIN_STYLE_NO_TITLE
);
if
(
win_main
==
RT_NULL
)
{
if
(
win_main
==
RT_NULL
)
{
rt_kprintf
(
"Create window
\"
main
\"
failed!
\n
"
);
rtgui_app_destroy
(
app
);
rtgui_app_destroy
(
app
);
return
;
}
}
/* create container in main window */
container
=
rtgui_container_create
();
if
(
container
==
RT_NULL
)
{
container
=
rtgui_container_create
();
if
(
container
==
RT_NULL
)
{
rt_kprintf
(
"Create container failed!
\n
"
);
return
;
}
return
;
}
rtgui_widget_set_rect
(
RTGUI_WIDGET
(
container
),
&
rect2
);
rtgui_widget_set_rect
(
RTGUI_WIDGET
(
container
),
&
rect2
);
rtgui_object_set_event_handler
(
RTGUI_OBJECT
(
container
),
pic_view_event_handler
);
rtgui_container_add_child
(
RTGUI_CONTAINER
(
win_main
),
RTGUI_WIDGET
(
container
));
/* create lable in main window */
label
=
rtgui_label_create
(
"EFM32GG_DK3750 Kit"
);
label
=
rtgui_label_create
(
"EFM32GG_DK3750 Kit"
);
if
(
label
==
RT_NULL
)
{
rt_kprintf
(
"Create lable failed!
\n
"
);
return
;
}
RTGUI_WIDGET_TEXTALIGN
(
RTGUI_WIDGET
(
label
))
=
RTGUI_ALIGN_LEFT
;
RTGUI_WIDGET_BACKGROUND
(
RTGUI_WIDGET
(
label
))
=
white
;
RTGUI_WIDGET_TEXTALIGN
(
RTGUI_WIDGET
(
label
))
=
RTGUI_ALIGN_LEFT
;
RTGUI_WIDGET_BACKGROUND
(
RTGUI_WIDGET
(
label
))
=
white
;
RTGUI_WIDGET_FOREGROUND
(
RTGUI_WIDGET
(
label
))
=
blue
;
rect3
.
x1
=
rect2
.
x1
+
5
;
rect3
.
y1
=
rect2
.
y1
+
5
;
rect3
.
x2
=
rect2
.
x2
-
5
;
rect3
.
y2
=
rect2
.
y1
+
20
;
rtgui_widget_set_rect
(
RTGUI_WIDGET
(
label
),
&
rect3
);
rtgui_container_add_child
(
container
,
RTGUI_WIDGET
(
label
));
rect3
.
x1
=
rect2
.
x1
+
5
;
rect3
.
y1
=
rect2
.
y1
+
5
;
rect3
.
x2
=
rect2
.
x2
-
5
;
rect3
.
y2
=
rect2
.
y1
+
20
;
rtgui_widget_set_rect
(
RTGUI_WIDGET
(
label
),
&
rect3
);
rtgui_container_add_child
(
container
,
RTGUI_WIDGET
(
label
));
/* create hello window */
rect3
.
x1
=
80
;
rect3
.
y1
=
50
;
rect3
.
x2
=
320
-
80
;
rect3
.
y2
=
240
-
50
;
win_hello
=
rtgui_win_create
(
RT_NULL
,
"hello"
,
rect3
.
x1
=
80
;
rect3
.
y1
=
50
;
rect3
.
x2
=
320
-
80
;
rect3
.
y2
=
240
-
50
;
win_hello
=
rtgui_win_create
(
RT_NULL
,
"hello"
,
&
rect3
,
RTGUI_WIN_STYLE_DEFAULT
);
if
(
win_hello
==
RT_NULL
)
{
if
(
win_hello
==
RT_NULL
)
{
rt_kprintf
(
"Create window
\"
hello
\"
failed!
\n
"
);
rtgui_app_destroy
(
app
);
rtgui_app_destroy
(
app
);
return
;
}
}
/* create a box */
rtgui_box_t
*
box
=
rtgui_box_create
(
RTGUI_VERTICAL
,
RT_NULL
);
if
(
box
==
RT_NULL
)
if
(
box
==
RT_NULL
)
{
rt_kprintf
(
"Create box failed!
\n
"
);
return
;
}
// rtgui_win_set_box(win_hello, box);
label
=
rtgui_label_create
(
"
,
!"
);
if
(
label
==
RT_NULL
)
label
=
rtgui_label_create
(
"
哈罗,盹胖
!"
);
if
(
label
==
RT_NULL
)
{
rt_kprintf
(
"Create lable failed!
\n
"
);
return
;
}
RTGUI_WIDGET_BACKGROUND
(
RTGUI_WIDGET
(
label
))
=
white
;
RTGUI_WIDGET_BACKGROUND
(
RTGUI_WIDGET
(
label
))
=
white
;
RTGUI_WIDGET_FOREGROUND
(
RTGUI_WIDGET
(
label
))
=
black
;
RTGUI_WIDGET
(
label
)
->
align
=
RTGUI_ALIGN_CENTER_HORIZONTAL
|
RTGUI_ALIGN_CENTER_VERTICAL
;
rtgui_widget_set_miniwidth
(
RTGUI_WIDGET
(
label
),
130
);
...
...
@@ -322,18 +322,18 @@ static void app_main(void *parameter)
static
rt_bool_t
photo_view_event_handler
(
rtgui_object_t
*
object
,
rtgui_event_t
*
event
)
{
rt_bool_t
result
=
RT_FALSE
;
rt_bool_t
result
=
RT_FALSE
;
struct
photo_event
*
photo_event
=
(
struct
photo_event
*
)
event
;
result
=
rtgui_container_event_handler
(
object
,
event
);
result
=
rtgui_container_event_handler
(
object
,
event
);
rt_kprintf
(
"container event %x
\n
"
,
event
->
type
);
struct
rtgui_event_win
*
wevent
=
(
struct
rtgui_event_win
*
)
event
;
struct
rtgui_event_win
*
wevent
=
(
struct
rtgui_event_win
*
)
event
;
rt_kprintf
(
"wevent->wid %x
\n
"
,
wevent
->
wid
);
if
((
event
->
type
==
RTGUI_EVENT_COMMAND
)
&&
\
(
photo_event
->
cmd
==
APP_CMD_PHOTO_FRAME
))
{
{
rtgui_rect_t
rect
;
rtgui_image_t
*
image
;
struct
rtgui_dc
*
dc
;
...
...
@@ -361,25 +361,25 @@ static rt_bool_t photo_view_event_handler(rtgui_object_t *object, rtgui_event_t
return
RT_TRUE
;
}
return
result
;
return
result
;
}
static
rt_bool_t
photo_lable_event_handler
(
rtgui_object_t
*
object
,
rtgui_event_t
*
event
)
{
rt_bool_t
result
=
RT_FALSE
;
rt_bool_t
result
=
RT_FALSE
;
result
=
rtgui_label_event_handler
(
object
,
event
);
result
=
rtgui_label_event_handler
(
object
,
event
);
rt_kprintf
(
"lable event %x
\n
"
,
event
->
type
);
if
(
event
->
type
==
RTGUI_EVENT_COMMAND
)
{
{
struct
photo_event
*
photo
=
(
struct
photo_event
*
)
event
;
rtgui_label_set_text
((
rtgui_label_t
*
)
object
,
photo
->
path
);
rt_kprintf
(
"path %s
\n
"
,
photo
->
path
);
}
return
result
;
return
result
;
}
static
void
app_photo
(
void
*
parameter
)
...
...
@@ -399,64 +399,64 @@ static void app_photo(void *parameter)
lcd
->
control
(
lcd
,
RTGRAPHIC_CTRL_GET_INFO
,
(
void
*
)
&
lcd_info
);
rt_kprintf
(
"LCD size: %dX%d
\n
"
,
lcd_info
.
width
,
lcd_info
.
height
);
/* create application */
struct
rtgui_app
*
app
;
app
=
rtgui_app_create
(
"pho_app"
);
if
(
app
==
RT_NULL
)
/* create application */
struct
rtgui_app
*
app
;
app
=
rtgui_app_create
(
"pho_app"
);
if
(
app
==
RT_NULL
)
{
rt_kprintf
(
"Create application
\"
pho_app
\"
failed!
\n
"
);
return
;
}
struct
rtgui_rect
rect1
,
rect2
;
struct
rtgui_rect
rect1
,
rect2
;
struct
rtgui_win
*
window
;
struct
rtgui_container
*
container
;
struct
rtgui_container
*
container
;
struct
rtgui_label
*
label
;
rtgui_graphic_driver_get_rect
(
rtgui_graphic_driver_get_default
(),
&
rect1
);
rtgui_graphic_driver_get_rect
(
rtgui_graphic_driver_get_default
(),
&
rect1
);
/* create window */
window
=
rtgui_win_create
(
RT_NULL
,
"photo"
,
window
=
rtgui_win_create
(
RT_NULL
,
"photo"
,
&
rect1
,
RTGUI_WIN_STYLE_NO_BORDER
|
RTGUI_WIN_STYLE_NO_TITLE
);
if
(
window
==
RT_NULL
)
{
if
(
window
==
RT_NULL
)
{
rt_kprintf
(
"Create window
\"
photo
\"
failed!
\n
"
);
rtgui_app_destroy
(
app
);
rtgui_app_destroy
(
app
);
return
;
}
}
event
->
win
.
wid
=
window
;
/* create container */
container
=
rtgui_container_create
();
if
(
container
==
RT_NULL
)
{
container
=
rtgui_container_create
();
if
(
container
==
RT_NULL
)
{
rt_kprintf
(
"Create container failed!
\n
"
);
return
;
}
rtgui_widget_set_rect
(
RTGUI_WIDGET
(
container
),
&
rect1
);
return
;
}
rtgui_widget_set_rect
(
RTGUI_WIDGET
(
container
),
&
rect1
);
rtgui_object_set_event_handler
(
RTGUI_OBJECT
(
container
),
photo_view_event_handler
);
rtgui_container_add_child
(
RTGUI_CONTAINER
(
window
),
RTGUI_WIDGET
(
container
));
/* create lable in info window */
label
=
rtgui_label_create
(
"Photo Frame Demo"
);
label
=
rtgui_label_create
(
"Photo Frame Demo"
);
if
(
label
==
RT_NULL
)
{
rt_kprintf
(
"Create lable failed!
\n
"
);
return
;
}
RTGUI_WIDGET_TEXTALIGN
(
RTGUI_WIDGET
(
label
))
=
RTGUI_ALIGN_LEFT
;
RTGUI_WIDGET_BACKGROUND
(
RTGUI_WIDGET
(
label
))
=
white
;
RTGUI_WIDGET_TEXTALIGN
(
RTGUI_WIDGET
(
label
))
=
RTGUI_ALIGN_LEFT
;
RTGUI_WIDGET_BACKGROUND
(
RTGUI_WIDGET
(
label
))
=
white
;
RTGUI_WIDGET_FOREGROUND
(
RTGUI_WIDGET
(
label
))
=
blue
;
rect2
.
x1
=
rect1
.
x1
;
rect2
.
y1
=
rect1
.
y1
;
rect2
.
x2
=
rect1
.
x2
;
rect2
.
y2
=
15
;
rtgui_widget_set_rect
(
RTGUI_WIDGET
(
label
),
&
rect2
);
rtgui_widget_set_rect
(
RTGUI_WIDGET
(
label
),
&
rect2
);
rtgui_object_set_event_handler
(
RTGUI_OBJECT
(
label
),
photo_lable_event_handler
);
rtgui_container_add_child
(
container
,
RTGUI_WIDGET
(
label
));
rtgui_container_add_child
(
container
,
RTGUI_WIDGET
(
label
));
rtgui_win_show
(
window
,
RT_FALSE
);
...
...
bsp/ra6m4-cpk/drivers/drv_gpio.h
浏览文件 @
b2b3fa6e
...
...
@@ -39,4 +39,4 @@ int rt_hw_pin_init(void);
}
#endif
#endif
/* __DRV_GPIO_H__ */
\ No newline at end of file
#endif
/* __DRV_GPIO_H__ */
bsp/ra6m4-cpk/drivers/drv_rtc.c
浏览文件 @
b2b3fa6e
...
...
@@ -223,4 +223,4 @@ static int rt_hw_rtc_init(void)
return
RT_EOK
;
}
INIT_DEVICE_EXPORT
(
rt_hw_rtc_init
);
#endif
\ No newline at end of file
#endif
bsp/ra6m4-cpk/ra_cfg/fsp_cfg/bsp/bsp_cfg.h
浏览文件 @
b2b3fa6e
...
...
@@ -34,7 +34,7 @@
#ifndef BSP_CLOCK_CFG_MAIN_OSC_POPULATED
#define BSP_CLOCK_CFG_MAIN_OSC_POPULATED (1)
#endif
#ifndef BSP_CLOCK_CFG_MAIN_OSC_CLOCK_SOURCE
#define BSP_CLOCK_CFG_MAIN_OSC_CLOCK_SOURCE (0)
#endif
...
...
bsp/ra6m4-cpk/ra_gen/vector_data.c
浏览文件 @
b2b3fa6e
...
...
@@ -18,4 +18,4 @@
[
3
]
=
BSP_PRV_IELS_ENUM
(
EVENT_SCI7_ERI
),
/* SCI7 ERI (Receive error) */
[
4
]
=
BSP_PRV_IELS_ENUM
(
EVENT_ICU_IRQ0
),
/* ICU IRQ0 (External pin interrupt 0) */
};
#endif
\ No newline at end of file
#endif
bsp/ra6m4-cpk/ra_gen/vector_data.h
浏览文件 @
b2b3fa6e
...
...
@@ -36,4 +36,4 @@
SCI7_ERI_IRQn
=
3
,
/* SCI7 ERI (Receive error) */
ICU_IRQ0_IRQn
=
4
,
/* ICU IRQ0 (External pin interrupt 0) */
}
IRQn_Type
;
#endif
/* VECTOR_DATA_H */
\ No newline at end of file
#endif
/* VECTOR_DATA_H */
bsp/ra6m4-cpk/src/hal_entry.c
浏览文件 @
b2b3fa6e
...
...
@@ -14,7 +14,7 @@
#include <rtdevice.h>
#define LED3_PIN BSP_IO_PORT_01_PIN_06
#define USER_INPUT
"P105"
#define USER_INPUT
"P105"
void
hal_entry
(
void
)
{
...
...
bsp/zynqmp-r5-axu4ev/drivers/board.h
浏览文件 @
b2b3fa6e
...
...
@@ -15,4 +15,4 @@ extern int __bss_end;
void
rt_hw_board_init
();
#endif
\ No newline at end of file
#endif
bsp/zynqmp-r5-axu4ev/drivers/drv_eth.c
浏览文件 @
b2b3fa6e
...
...
@@ -344,4 +344,4 @@ static int rt_hw_zynqmp_eth_init(void)
return
state
;
}
INIT_DEVICE_EXPORT
(
rt_hw_zynqmp_eth_init
);
\ No newline at end of file
INIT_DEVICE_EXPORT
(
rt_hw_zynqmp_eth_init
);
bsp/zynqmp-r5-axu4ev/drivers/drv_sdcard.c
浏览文件 @
b2b3fa6e
/*
* Copyright (c) 2006-20
18
, RT-Thread Development Team
* Copyright (c) 2006-20
21
, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
...
...
@@ -469,4 +469,4 @@ static int rh_hw_emmc_init(void)
return
-
RT_ERROR
;
}
INIT_DEVICE_EXPORT
(
rh_hw_emmc_init
);
#endif
\ No newline at end of file
#endif
bsp/zynqmp-r5-axu4ev/drivers/drv_timer.c
浏览文件 @
b2b3fa6e
/*
* Copyright (c) 2006-202
0
, RT-Thread Development Team
* Copyright (c) 2006-202
1
, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
...
...
@@ -62,4 +62,4 @@ static int rt_hw_timer_init(void)
return
RT_EOK
;
}
INIT_BOARD_EXPORT
(
rt_hw_timer_init
);
\ No newline at end of file
INIT_BOARD_EXPORT
(
rt_hw_timer_init
);
bsp/zynqmp-r5-axu4ev/drivers/drv_timer.h
浏览文件 @
b2b3fa6e
...
...
@@ -45,4 +45,4 @@ extern "C" {
}
#endif
#endif
\ No newline at end of file
#endif
bsp/zynqmp-r5-axu4ev/drivers/drv_uart.c
浏览文件 @
b2b3fa6e
/*
* Copyright (c) 2006-202
0
, RT-Thread Development Team
* Copyright (c) 2006-202
1
, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
...
...
@@ -315,4 +315,4 @@ int rt_hw_uart_init(void)
return
RT_EOK
;
}
INIT_BOARD_EXPORT
(
rt_hw_uart_init
);
\ No newline at end of file
INIT_BOARD_EXPORT
(
rt_hw_uart_init
);
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录