Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
5f010384
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
160
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看板
提交
5f010384
编写于
10月 27, 2010
作者:
P
Paul Mundt
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
sh: mach-systemh: irq_data conversion.
Signed-off-by:
N
Paul Mundt
<
lethal@linux-sh.org
>
上级
949bf166
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
21 addition
and
36 deletion
+21
-36
arch/sh/boards/mach-systemh/irq.c
arch/sh/boards/mach-systemh/irq.c
+21
-36
未找到文件。
arch/sh/boards/mach-systemh/irq.c
浏览文件 @
5f010384
...
...
@@ -23,54 +23,39 @@
static
unsigned
long
*
systemh_irq_mask_register
=
(
unsigned
long
*
)
0xB3F10004
;
static
unsigned
long
*
systemh_irq_request_register
=
(
unsigned
long
*
)
0xB3F10000
;
/* forward declaration */
static
void
enable_systemh_irq
(
unsigned
int
irq
);
static
void
disable_systemh_irq
(
unsigned
int
irq
);
static
void
mask_and_ack_systemh
(
unsigned
int
);
static
struct
irq_chip
systemh_irq_type
=
{
.
name
=
" SystemH Register"
,
.
unmask
=
enable_systemh_irq
,
.
mask
=
disable_systemh_irq
,
.
ack
=
mask_and_ack_systemh
,
};
static
void
disable_systemh_irq
(
unsigned
int
irq
)
static
void
disable_systemh_irq
(
struct
irq_data
*
data
)
{
if
(
systemh_irq_mask_register
)
{
unsigned
long
val
,
mask
=
0x01
<<
1
;
unsigned
long
val
,
mask
=
0x01
<<
1
;
/* Clear the "irq"th bit in the mask and set it in the request */
val
=
__raw_readl
((
unsigned
long
)
systemh_irq_mask_register
);
val
&=
~
mask
;
__raw_writel
(
val
,
(
unsigned
long
)
systemh_irq_mask_register
);
/* Clear the "irq"th bit in the mask and set it in the request */
val
=
__raw_readl
((
unsigned
long
)
systemh_irq_mask_register
);
val
&=
~
mask
;
__raw_writel
(
val
,
(
unsigned
long
)
systemh_irq_mask_register
);
val
=
__raw_readl
((
unsigned
long
)
systemh_irq_request_register
);
val
|=
mask
;
__raw_writel
(
val
,
(
unsigned
long
)
systemh_irq_request_register
);
}
val
=
__raw_readl
((
unsigned
long
)
systemh_irq_request_register
);
val
|=
mask
;
__raw_writel
(
val
,
(
unsigned
long
)
systemh_irq_request_register
);
}
static
void
enable_systemh_irq
(
unsigned
int
irq
)
static
void
enable_systemh_irq
(
struct
irq_data
*
data
)
{
if
(
systemh_irq_mask_register
)
{
unsigned
long
val
,
mask
=
0x01
<<
1
;
unsigned
long
val
,
mask
=
0x01
<<
1
;
/* Set "irq"th bit in the mask register */
val
=
__raw_readl
((
unsigned
long
)
systemh_irq_mask_register
);
val
|=
mask
;
__raw_writel
(
val
,
(
unsigned
long
)
systemh_irq_mask_register
);
}
/* Set "irq"th bit in the mask register */
val
=
__raw_readl
((
unsigned
long
)
systemh_irq_mask_register
);
val
|=
mask
;
__raw_writel
(
val
,
(
unsigned
long
)
systemh_irq_mask_register
);
}
static
void
mask_and_ack_systemh
(
unsigned
int
irq
)
{
disable_systemh_irq
(
irq
);
}
static
struct
irq_chip
systemh_irq_type
=
{
.
name
=
"SystemH Register"
,
.
irq_unmask
=
enable_systemh_irq
,
.
irq_mask
=
disable_systemh_irq
,
};
void
make_systemh_irq
(
unsigned
int
irq
)
{
disable_irq_nosync
(
irq
);
set_irq_chip_and_handler
(
irq
,
&
systemh_irq_type
,
handle_level_irq
);
disable_systemh_irq
(
irq
);
disable_systemh_irq
(
irq
_get_irq_data
(
irq
)
);
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录