Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lfmiao0
rt-thread
提交
863c5494
R
rt-thread
项目概览
lfmiao0
/
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,发现更多精彩内容 >>
未验证
提交
863c5494
编写于
8月 21, 2019
作者:
B
Bernard Xiong
提交者:
GitHub
8月 21, 2019
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #2978 from Liufeilong66/master
龙芯1c部分问题
上级
d682c354
ab818cda
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
140 addition
and
113 deletion
+140
-113
bsp/ls1cdev/drivers/drv_gpio.c
bsp/ls1cdev/drivers/drv_gpio.c
+18
-2
bsp/ls1cdev/drivers/drv_spi.c
bsp/ls1cdev/drivers/drv_spi.c
+38
-17
bsp/ls1cdev/drivers/net/synopGMAC.c
bsp/ls1cdev/drivers/net/synopGMAC.c
+9
-19
libcpu/mips/loongson_1c/ls1c.h
libcpu/mips/loongson_1c/ls1c.h
+75
-75
未找到文件。
bsp/ls1cdev/drivers/drv_gpio.c
浏览文件 @
863c5494
...
...
@@ -73,8 +73,24 @@ rt_err_t ls1c_pin_attach_irq(struct rt_device *device, rt_int32_t pin,
{
unsigned
int
gpio
=
pin
;
char
irq_name
[
10
];
rt_uint32_t
type
;
switch
(
mode
)
{
case
PIN_IRQ_MODE_RISING
:
type
=
IRQ_TYPE_EDGE_RISING
;
break
;
case
PIN_IRQ_MODE_FALLING
:
type
=
IRQ_TYPE_EDGE_FALLING
;
break
;
case
PIN_IRQ_MODE_HIGH_LEVEL
:
type
=
IRQ_TYPE_LEVEL_HIGH
;
break
;
case
PIN_IRQ_MODE_LOW_LEVEL
:
type
=
IRQ_TYPE_LEVEL_LOW
;
break
;
}
gpio_set_irq_type
(
gpio
,
type
);
gpio_set_irq_type
(
gpio
,
mode
);
rt_sprintf
(
irq_name
,
"PIN_%d"
,
gpio
);
rt_hw_interrupt_install
(
LS1C_GPIO_TO_IRQ
(
gpio
),
(
rt_isr_handler_t
)
hdr
,
args
,
irq_name
);
...
...
bsp/ls1cdev/drivers/drv_spi.c
浏览文件 @
863c5494
...
...
@@ -25,13 +25,14 @@
#include <rtthread.h>
#include <drivers/spi.h>
#include <rthw.h>
#include "drv_spi.h"
#include "ls1c_public.h"
#include "spi_msd.h"
#include "dfs_fs.h"
#include "../libraries/ls1c_pin.h"
#ifdef RT_USING_SPI
//#define DEBUG
#ifdef DEBUG
#define DEBUG_PRINTF(...) rt_kprintf(__VA_ARGS__)
#else
...
...
@@ -268,10 +269,11 @@ int ls1c_hw_spi_init(void)
static
struct
rt_spi_device
spi_device0
;
static
struct
rt_spi_device
spi_device1
;
static
struct
rt_spi_device
spi_device2
;
static
struct
rt_spi_device
spi_device3
;
static
struct
ls1c_spi_cs
spi_cs0
;
static
struct
ls1c_spi_cs
spi_cs1
;
static
struct
ls1c_spi_cs
spi_cs2
;
static
struct
ls1c_spi_cs
spi_cs3
;
/* spi02: CS2 SD Card*/
spi_cs2
.
cs
=
LS1C_SPI_CS_2
;
rt_spi_bus_attach_device
(
&
spi_device2
,
"spi02"
,
"spi0"
,
(
void
*
)
&
spi_cs2
);
...
...
@@ -279,6 +281,9 @@ int ls1c_hw_spi_init(void)
rt_spi_bus_attach_device
(
&
spi_device1
,
"spi01"
,
"spi0"
,
(
void
*
)
&
spi_cs1
);
spi_cs0
.
cs
=
LS1C_SPI_CS_0
;
rt_spi_bus_attach_device
(
&
spi_device0
,
"spi00"
,
"spi0"
,
(
void
*
)
&
spi_cs0
);
spi_cs3
.
cs
=
LS1C_SPI_CS_3
;
rt_spi_bus_attach_device
(
&
spi_device3
,
"spi03"
,
"spi0"
,
(
void
*
)
&
spi_cs3
);
msd_init
(
"sd0"
,
"spi02"
);
}
#endif
#ifdef RT_USING_SPI1
...
...
@@ -296,5 +301,21 @@ int ls1c_hw_spi_init(void)
INIT_BOARD_EXPORT
(
ls1c_hw_spi_init
);
static
int
board_sd_init
(
void
)
{
#if defined(RT_USING_DFS) && defined(RT_USING_DFS_ELMFAT)
/* mount sd card fat partition 1 as root directory */
if
(
dfs_mount
(
"sd0"
,
"/"
,
"elm"
,
0
,
0
)
==
0
)
{
rt_kprintf
(
"File System initialized!
\n
"
);
}
else
{
rt_kprintf
(
"File System initialzation failed!
\n
"
);
}
#endif
/* RT_USING_DFS && RT_USING_DFS_ELMFAT */
}
INIT_APP_EXPORT
(
board_sd_init
);
#endif
bsp/ls1cdev/drivers/net/synopGMAC.c
浏览文件 @
863c5494
...
...
@@ -572,22 +572,16 @@ struct pbuf *rt_eth_rx(rt_device_t device)
}
/*Handle the Receive Descriptors*/
do
{
desc_index
=
synopGMAC_get_rx_qptr
(
gmacdev
,
&
status
,
&
dma_addr1
,
NULL
,
&
data1
,
&
dma_addr2
,
NULL
,
&
data2
);
if
(
desc_index
>=
0
&&
data1
!=
0
)
{
DEBUG_MES
(
"Received Data at Rx Descriptor %d for skb 0x%08x whose status is %08x
\n
"
,
desc_index
,
dma_addr1
,
status
);
if
(
synopGMAC_is_rx_desc_valid
(
status
)
||
SYNOP_PHY_LOOPBACK
)
{
pbuf
=
pbuf_alloc
(
PBUF_LINK
,
MAX_ETHERNET_PAYLOAD
,
PBUF_RAM
);
if
(
pbuf
==
0
)
rt_kprintf
(
"===error in pbuf_alloc
\n
"
);
dma_addr1
=
plat_dma_map_single
(
gmacdev
,
(
void
*
)
data1
,
RX_BUF_SIZE
);
len
=
synopGMAC_get_rx_desc_frame_length
(
status
);
//Not interested in Ethernet CRC bytes
len
=
synopGMAC_get_rx_desc_frame_length
(
status
)
-
4
;
//Not interested in Ethernet CRC bytes
pbuf
=
pbuf_alloc
(
PBUF_LINK
,
len
,
PBUF_RAM
);
if
(
pbuf
==
0
)
rt_kprintf
(
"===error in pbuf_alloc
\n
"
);
rt_memcpy
(
pbuf
->
payload
,
(
char
*
)
data1
,
len
);
DEBUG_MES
(
"==get pkg len: %d
\n
"
,
len
);
}
...
...
@@ -600,19 +594,15 @@ struct pbuf *rt_eth_rx(rt_device_t device)
adapter
->
synopGMACNetStats
.
rx_frame_errors
+=
synopGMAC_is_frame_dribbling_errors
(
status
);
adapter
->
synopGMACNetStats
.
rx_length_errors
+=
synopGMAC_is_rx_frame_length_errors
(
status
);
}
desc_index
=
synopGMAC_set_rx_qptr
(
gmacdev
,
dma_addr1
,
RX_BUF_SIZE
,
(
u32
)
data1
,
0
,
0
,
0
);
if
(
desc_index
<
0
)
{
#if SYNOP_RX_DEBUG
#if SYNOP_RX_DEBUG
rt_kprintf
(
"Cannot set Rx Descriptor for data1 %08x
\n
"
,
(
u32
)
data1
);
#endif
#endif
plat_free_memory
((
void
*
)
data1
);
}
}
}
while
(
desc_index
>=
0
);
rt_sem_release
(
&
sem_lock
);
DEBUG_MES
(
"%s : before return
\n
"
,
__FUNCTION__
);
return
pbuf
;
...
...
libcpu/mips/loongson_1c/ls1c.h
浏览文件 @
863c5494
...
...
@@ -145,8 +145,8 @@ struct ls1c_cop_regs
/* Watch Dog registers */
#define WDT_EN __REG32(WDT_BASE + 0x00)
#define WDT_SET
__REG32(WDT_BASE + 0x04
)
#define WDT_TIMER
__REG32(WDT_BASE + 0x08
)
#define WDT_SET
__REG32(WDT_BASE + 0x08
)
#define WDT_TIMER
__REG32(WDT_BASE + 0x04
)
#define PLL_FREQ __REG32(0xbfe78030)
#define PLL_DIV_PARAM __REG32(0xbfe78034)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录