Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
86071b63
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
86071b63
编写于
7月 14, 2005
作者:
R
Ralf Baechle
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Cleanups.
Signed-off-by:
N
Ralf Baechle
<
ralf@linux-mips.org
>
上级
7e35952b
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
12 addition
and
10 deletion
+12
-10
include/asm-mips/hazards.h
include/asm-mips/hazards.h
+12
-10
未找到文件。
include/asm-mips/hazards.h
浏览文件 @
86071b63
...
@@ -148,15 +148,13 @@ __asm__(
...
@@ -148,15 +148,13 @@ __asm__(
#endif
#endif
/*
/*
*
mtc0->mfc0 hazard
*
Interrupt enable/disable hazards
*
The 24K has a 2 cycle mtc0/mfc0 execution hazard.
*
Some processors have hazards when modifying
*
It is a MIPS32R2 processor so ehb will clear the hazard.
*
the status register to change the interrupt state
*/
*/
#ifdef CONFIG_CPU_MIPSR2
#ifdef CONFIG_CPU_MIPSR2
/*
* Use a macro for ehb unless explicit support for MIPSR2 is enabled
*/
__asm__
(
__asm__
(
" .macro
\t
irq_enable_hazard
\n\t
"
" .macro
\t
irq_enable_hazard
\n\t
"
" _ehb
\n\t
"
" _ehb
\n\t
"
...
@@ -164,19 +162,23 @@ __asm__(
...
@@ -164,19 +162,23 @@ __asm__(
"
\n\t
"
"
\n\t
"
" .macro
\t
irq_disable_hazard
\n\t
"
" .macro
\t
irq_disable_hazard
\n\t
"
" _ehb
\n\t
"
" _ehb
\n\t
"
" .endm
\n\t
"
"
\n\t
"
" .macro
\t
back_to_back_c0_hazard
\n\t
"
" _ehb
\n\t
"
" .endm"
);
" .endm"
);
#define irq_enable_hazard() \
#define irq_enable_hazard() \
__asm__ __volatile__( \
__asm__ __volatile__( \
"
_ehb\t\t\t\t#
irq_enable_hazard")
"irq_enable_hazard")
#define irq_disable_hazard() \
#define irq_disable_hazard() \
__asm__ __volatile__( \
__asm__ __volatile__( \
"
_ehb\t\t\t\t#
irq_disable_hazard")
"irq_disable_hazard")
#define back_to_back_c0_hazard() \
#define back_to_back_c0_hazard() \
__asm__ __volatile__( \
__asm__ __volatile__( \
"
_ehb\t\t\t\t#
back_to_back_c0_hazard")
"back_to_back_c0_hazard")
#elif defined(CONFIG_CPU_R10000) || defined(CONFIG_CPU_RM9000)
#elif defined(CONFIG_CPU_R10000) || defined(CONFIG_CPU_RM9000)
...
@@ -218,7 +220,7 @@ __asm__(
...
@@ -218,7 +220,7 @@ __asm__(
#define irq_enable_hazard() do { } while (0)
#define irq_enable_hazard() do { } while (0)
#define irq_disable_hazard() \
#define irq_disable_hazard() \
__asm__ __volatile__( \
__asm__ __volatile__( \
"
_ssnop; _ssnop; _ssnop;\t\t#
irq_disable_hazard")
"irq_disable_hazard")
#define back_to_back_c0_hazard() \
#define back_to_back_c0_hazard() \
__asm__ __volatile__( \
__asm__ __volatile__( \
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录