Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Mozi
rt-thread
提交
a5305c05
R
rt-thread
项目概览
Mozi
/
rt-thread
与 Fork 源项目一致
Fork自
RT-Thread / rt-thread
通知
0
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,发现更多精彩内容 >>
提交
a5305c05
编写于
7月 31, 2017
作者:
z13955633063
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix bug in context_gcc.s and start_gcc.s:
save mie into stack msh running normaly
上级
d9c0bdc7
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
22 addition
and
10 deletion
+22
-10
bsp/risc-v/drivers/usart.c
bsp/risc-v/drivers/usart.c
+0
-1
bsp/risc-v/platform/interrupt.c
bsp/risc-v/platform/interrupt.c
+1
-1
libcpu/risc-v/e310/context_gcc.S
libcpu/risc-v/e310/context_gcc.S
+5
-1
libcpu/risc-v/e310/stack.c
libcpu/risc-v/e310/stack.c
+2
-1
libcpu/risc-v/e310/start_gcc.S
libcpu/risc-v/e310/start_gcc.S
+14
-6
未找到文件。
bsp/risc-v/drivers/usart.c
浏览文件 @
a5305c05
...
...
@@ -17,7 +17,6 @@ static void usart_init(int buard)
static
void
usart_handler
(
int
vector
,
void
*
param
)
{
rt_hw_serial_isr
((
struct
rt_serial_device
*
)
param
,
RT_SERIAL_EVENT_RX_IND
);
UART0_REG
(
UART_REG_IP
)
=
0
;
return
;
}
static
rt_err_t
usart_configure
(
struct
rt_serial_device
*
serial
,
...
...
bsp/risc-v/platform/interrupt.c
浏览文件 @
a5305c05
...
...
@@ -11,7 +11,7 @@ struct rt_irq_desc irq_desc[MAX_HANDLERS];
rt_uint32_t
rt_interrupt_from_thread
;
rt_uint32_t
rt_interrupt_to_thread
;
rt_uint32_t
rt_thread_switch_interrupt_flag
;
plic_instance_t
g_plic
;
volatile
plic_instance_t
g_plic
;
/**
* This function will mask a interrupt.
* @param vector the interrupt number
...
...
libcpu/risc-v/e310/context_gcc.S
浏览文件 @
a5305c05
...
...
@@ -106,9 +106,11 @@ rt_hw_context_switch:
STORE
x26
,
26
*
REGBYTES
(
sp
)
STORE
x27
,
27
*
REGBYTES
(
sp
)
STORE
x28
,
28
*
REGBYTES
(
sp
)
STORE
x1
,
31
*
REGBYTES
(
sp
)
STORE
x10
,
29
*
REGBYTES
(
sp
)
STORE
x1
,
30
*
REGBYTES
(
sp
)
STORE
x1
,
31
*
REGBYTES
(
sp
)
csrr
x10
,
mie
STORE
x10
,
0
*
REGBYTES
(
sp
)
/*
*
Remain
in
M
-
mode
after
mret
*
enable
interrupt
in
M
-
mode
...
...
@@ -147,6 +149,8 @@ rt_hw_context_switch:
LOAD
x28
,
28
*
REGBYTES
(
sp
)
LOAD
x10
,
31
*
REGBYTES
(
sp
)
csrw
mepc
,
x10
LOAD
x10
,
0
*
REGBYTES
(
sp
)
csrw
mie
,
x10
LOAD
x10
,
29
*
REGBYTES
(
sp
)
LOAD
x1
,
30
*
REGBYTES
(
sp
)
...
...
libcpu/risc-v/e310/stack.c
浏览文件 @
a5305c05
...
...
@@ -86,7 +86,8 @@ rt_uint8_t *rt_hw_stack_init(void *tentry, void *parameter,
*
(
--
stk
)
=
0xffffffff
;
/* t6 */
*
(
--
stk
)
=
0xffffffff
;
/* tp */
*
(
--
stk
)
=
0xffffffff
;
/* gp */
*
(
--
stk
)
=
0x880
;
/* mie */
// *(--stk) = (rt_uint32_t)parameter; /* r0 : argument */
/* return task's current stack address */
return
(
rt_uint8_t
*
)
--
stk
;
return
(
rt_uint8_t
*
)
stk
;
}
libcpu/risc-v/e310/start_gcc.S
浏览文件 @
a5305c05
...
...
@@ -176,8 +176,17 @@ trap_entry:
STORE
x1
,
30
*
REGBYTES
(
sp
)
csrr
x10
,
mepc
STORE
x10
,
31
*
REGBYTES
(
sp
)
csrr
x10
,
mie
STORE
x10
,
0
*
REGBYTES
(
sp
)
/*
*
Remain
in
M
-
mode
after
mret
*
enable
interrupt
in
M
-
mode
*/
li
t0
,
MSTATUS_MPP
csrrs
t0
,
mstatus
,
t0
call
rt_interrupt_enter
csrr
a0
,
mcause
lui
a5
,
0x80000
...
...
@@ -189,17 +198,13 @@ trap_entry:
bne
a5
,
a4
,
1
f
call
rt_hw_trap_irq
1
:
/*
Machine
software
interrupt
*/
/*
Machine
timer
interrupt
*/
li
a4
,
7
bne
a5
,
a4
,
2
f
call
rt_systick_handler
2
:
call
rt_interrupt_leave
#
Remain
in
M
-
mode
after
mret
li
t0
,
136
csrrs
t0
,
mstatus
,
t0
la
a0
,
rt_thread_switch_interrupt_flag
lw
a1
,
(
a0
)
bnez
a1
,
rt_hw_context_switch_interrupt_do
...
...
@@ -235,9 +240,10 @@ trap_entry:
LOAD
x28
,
28
*
REGBYTES
(
sp
)
LOAD
x10
,
31
*
REGBYTES
(
sp
)
csrw
mepc
,
x10
LOAD
x10
,
0
*
REGBYTES
(
sp
)
csrw
mie
,
x10
LOAD
x10
,
29
*
REGBYTES
(
sp
)
LOAD
x1
,
30
*
REGBYTES
(
sp
)
addi
sp
,
sp
,
32
*
REGBYTES
mret
...
...
@@ -282,6 +288,8 @@ rt_hw_context_switch_interrupt_do:
LOAD
x28
,
28
*
REGBYTES
(
sp
)
LOAD
x10
,
31
*
REGBYTES
(
sp
)
csrw
mepc
,
x10
LOAD
x10
,
0
*
REGBYTES
(
sp
)
csrw
mie
,
x10
LOAD
x10
,
29
*
REGBYTES
(
sp
)
LOAD
x1
,
30
*
REGBYTES
(
sp
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录