Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
62429e03
cloud-kernel
项目概览
openanolis
/
cloud-kernel
接近 2 年 前同步成功
通知
170
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
62429e03
编写于
10月 01, 2008
作者:
P
Paul Mundt
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
sh: Use __raw_xxx() I/O accessors for INTC and IPR.
Signed-off-by:
N
Paul Mundt
<
lethal@linux-sh.org
>
上级
64c9627c
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
14 addition
and
14 deletion
+14
-14
arch/sh/kernel/cpu/irq/intc.c
arch/sh/kernel/cpu/irq/intc.c
+12
-12
arch/sh/kernel/cpu/irq/ipr.c
arch/sh/kernel/cpu/irq/ipr.c
+2
-2
未找到文件。
arch/sh/kernel/cpu/irq/intc.c
浏览文件 @
62429e03
...
...
@@ -86,24 +86,24 @@ static inline unsigned int set_field(unsigned int value,
static
void
write_8
(
unsigned
long
addr
,
unsigned
long
h
,
unsigned
long
data
)
{
ctrl_out
b
(
set_field
(
0
,
data
,
h
),
addr
);
__raw_write
b
(
set_field
(
0
,
data
,
h
),
addr
);
}
static
void
write_16
(
unsigned
long
addr
,
unsigned
long
h
,
unsigned
long
data
)
{
ctrl_out
w
(
set_field
(
0
,
data
,
h
),
addr
);
__raw_write
w
(
set_field
(
0
,
data
,
h
),
addr
);
}
static
void
write_32
(
unsigned
long
addr
,
unsigned
long
h
,
unsigned
long
data
)
{
ctrl_out
l
(
set_field
(
0
,
data
,
h
),
addr
);
__raw_write
l
(
set_field
(
0
,
data
,
h
),
addr
);
}
static
void
modify_8
(
unsigned
long
addr
,
unsigned
long
h
,
unsigned
long
data
)
{
unsigned
long
flags
;
local_irq_save
(
flags
);
ctrl_outb
(
set_field
(
ctrl_in
b
(
addr
),
data
,
h
),
addr
);
__raw_writeb
(
set_field
(
__raw_read
b
(
addr
),
data
,
h
),
addr
);
local_irq_restore
(
flags
);
}
...
...
@@ -111,7 +111,7 @@ static void modify_16(unsigned long addr, unsigned long h, unsigned long data)
{
unsigned
long
flags
;
local_irq_save
(
flags
);
ctrl_outw
(
set_field
(
ctrl_in
w
(
addr
),
data
,
h
),
addr
);
__raw_writew
(
set_field
(
__raw_read
w
(
addr
),
data
,
h
),
addr
);
local_irq_restore
(
flags
);
}
...
...
@@ -119,7 +119,7 @@ static void modify_32(unsigned long addr, unsigned long h, unsigned long data)
{
unsigned
long
flags
;
local_irq_save
(
flags
);
ctrl_outl
(
set_field
(
ctrl_in
l
(
addr
),
data
,
h
),
addr
);
__raw_writel
(
set_field
(
__raw_read
l
(
addr
),
data
,
h
),
addr
);
local_irq_restore
(
flags
);
}
...
...
@@ -246,16 +246,16 @@ static void intc_mask_ack(unsigned int irq)
addr
=
INTC_REG
(
d
,
_INTC_ADDR_D
(
handle
),
0
);
switch
(
_INTC_FN
(
handle
))
{
case
REG_FN_MODIFY_BASE
+
0
:
/* 8bit */
ctrl_in
b
(
addr
);
ctrl_out
b
(
0xff
^
set_field
(
0
,
1
,
handle
),
addr
);
__raw_read
b
(
addr
);
__raw_write
b
(
0xff
^
set_field
(
0
,
1
,
handle
),
addr
);
break
;
case
REG_FN_MODIFY_BASE
+
1
:
/* 16bit */
ctrl_in
w
(
addr
);
ctrl_out
w
(
0xffff
^
set_field
(
0
,
1
,
handle
),
addr
);
__raw_read
w
(
addr
);
__raw_write
w
(
0xffff
^
set_field
(
0
,
1
,
handle
),
addr
);
break
;
case
REG_FN_MODIFY_BASE
+
3
:
/* 32bit */
ctrl_in
l
(
addr
);
ctrl_out
l
(
0xffffffff
^
set_field
(
0
,
1
,
handle
),
addr
);
__raw_read
l
(
addr
);
__raw_write
l
(
0xffffffff
^
set_field
(
0
,
1
,
handle
),
addr
);
break
;
default:
BUG
();
...
...
arch/sh/kernel/cpu/irq/ipr.c
浏览文件 @
62429e03
...
...
@@ -33,7 +33,7 @@ static void disable_ipr_irq(unsigned int irq)
struct
ipr_data
*
p
=
get_irq_chip_data
(
irq
);
unsigned
long
addr
=
get_ipr_desc
(
irq
)
->
ipr_offsets
[
p
->
ipr_idx
];
/* Set the priority in IPR to 0 */
ctrl_outw
(
ctrl_in
w
(
addr
)
&
(
0xffff
^
(
0xf
<<
p
->
shift
)),
addr
);
__raw_writew
(
__raw_read
w
(
addr
)
&
(
0xffff
^
(
0xf
<<
p
->
shift
)),
addr
);
}
static
void
enable_ipr_irq
(
unsigned
int
irq
)
...
...
@@ -41,7 +41,7 @@ static void enable_ipr_irq(unsigned int irq)
struct
ipr_data
*
p
=
get_irq_chip_data
(
irq
);
unsigned
long
addr
=
get_ipr_desc
(
irq
)
->
ipr_offsets
[
p
->
ipr_idx
];
/* Set priority in IPR back to original value */
ctrl_outw
(
ctrl_in
w
(
addr
)
|
(
p
->
priority
<<
p
->
shift
),
addr
);
__raw_writew
(
__raw_read
w
(
addr
)
|
(
p
->
priority
<<
p
->
shift
),
addr
);
}
/*
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录