Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
8df3a615
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
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看板
提交
8df3a615
编写于
10月 27, 2010
作者:
P
Paul Mundt
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
sh: IPR IRQs irq_data conversion.
Signed-off-by:
N
Paul Mundt
<
lethal@linux-sh.org
>
上级
0d338071
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
12 addition
and
13 deletion
+12
-13
arch/sh/kernel/cpu/irq/ipr.c
arch/sh/kernel/cpu/irq/ipr.c
+12
-13
未找到文件。
arch/sh/kernel/cpu/irq/ipr.c
浏览文件 @
8df3a615
...
...
@@ -24,25 +24,25 @@
#include <linux/module.h>
#include <linux/topology.h>
static
inline
struct
ipr_desc
*
get_ipr_desc
(
unsigned
int
irq
)
static
inline
struct
ipr_desc
*
get_ipr_desc
(
struct
irq_data
*
data
)
{
struct
irq_chip
*
chip
=
get_irq_chip
(
irq
);
struct
irq_chip
*
chip
=
irq_data_get_irq_chip
(
data
);
return
container_of
(
chip
,
struct
ipr_desc
,
chip
);
}
static
void
disable_ipr_irq
(
unsigned
int
irq
)
static
void
disable_ipr_irq
(
struct
irq_data
*
data
)
{
struct
ipr_data
*
p
=
get_irq_chip_data
(
irq
);
unsigned
long
addr
=
get_ipr_desc
(
irq
)
->
ipr_offsets
[
p
->
ipr_idx
];
struct
ipr_data
*
p
=
irq_data_get_irq_chip_data
(
data
);
unsigned
long
addr
=
get_ipr_desc
(
data
)
->
ipr_offsets
[
p
->
ipr_idx
];
/* Set the priority in IPR to 0 */
__raw_writew
(
__raw_readw
(
addr
)
&
(
0xffff
^
(
0xf
<<
p
->
shift
)),
addr
);
(
void
)
__raw_readw
(
addr
);
/* Read back to flush write posting */
}
static
void
enable_ipr_irq
(
unsigned
int
irq
)
static
void
enable_ipr_irq
(
struct
irq_data
*
data
)
{
struct
ipr_data
*
p
=
get_irq_chip_data
(
irq
);
unsigned
long
addr
=
get_ipr_desc
(
irq
)
->
ipr_offsets
[
p
->
ipr_idx
];
struct
ipr_data
*
p
=
irq_data_get_irq_chip_data
(
data
);
unsigned
long
addr
=
get_ipr_desc
(
data
)
->
ipr_offsets
[
p
->
ipr_idx
];
/* Set priority in IPR back to original value */
__raw_writew
(
__raw_readw
(
addr
)
|
(
p
->
priority
<<
p
->
shift
),
addr
);
}
...
...
@@ -56,9 +56,8 @@ void register_ipr_controller(struct ipr_desc *desc)
{
int
i
;
desc
->
chip
.
mask
=
disable_ipr_irq
;
desc
->
chip
.
unmask
=
enable_ipr_irq
;
desc
->
chip
.
mask_ack
=
disable_ipr_irq
;
desc
->
chip
.
irq_mask
=
disable_ipr_irq
;
desc
->
chip
.
irq_unmask
=
enable_ipr_irq
;
for
(
i
=
0
;
i
<
desc
->
nr_irqs
;
i
++
)
{
struct
ipr_data
*
p
=
desc
->
ipr_data
+
i
;
...
...
@@ -68,7 +67,7 @@ void register_ipr_controller(struct ipr_desc *desc)
BUG_ON
(
!
desc
->
ipr_offsets
[
p
->
ipr_idx
]);
res
=
irq_alloc_desc_at
(
p
->
irq
,
numa_node_id
());
if
(
unlikely
(
res
!=
p
->
irq
&&
res
!=
-
EEXIST
))
if
(
unlikely
(
res
!=
p
->
irq
&&
res
!=
-
EEXIST
))
{
printk
(
KERN_INFO
"can not get irq_desc for %d
\n
"
,
p
->
irq
);
continue
;
...
...
@@ -78,7 +77,7 @@ void register_ipr_controller(struct ipr_desc *desc)
set_irq_chip_and_handler_name
(
p
->
irq
,
&
desc
->
chip
,
handle_level_irq
,
"level"
);
set_irq_chip_data
(
p
->
irq
,
p
);
disable_ipr_irq
(
p
->
irq
);
disable_ipr_irq
(
irq_get_irq_data
(
p
->
irq
)
);
}
}
EXPORT_SYMBOL
(
register_ipr_controller
);
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录