Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
7e7e2f03
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
7e7e2f03
编写于
8月 27, 2008
作者:
D
David S. Miller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
sparc32: Convert apc to OF driver.
Signed-off-by:
N
David S. Miller
<
davem@davemloft.net
>
上级
4b1c5df2
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
38 addition
and
34 deletion
+38
-34
arch/sparc/kernel/apc.c
arch/sparc/kernel/apc.c
+38
-34
未找到文件。
arch/sparc/kernel/apc.c
浏览文件 @
7e7e2f03
...
@@ -12,9 +12,10 @@
...
@@ -12,9 +12,10 @@
#include <linux/miscdevice.h>
#include <linux/miscdevice.h>
#include <linux/smp_lock.h>
#include <linux/smp_lock.h>
#include <linux/pm.h>
#include <linux/pm.h>
#include <linux/of.h>
#include <linux/of_device.h>
#include <asm/io.h>
#include <asm/io.h>
#include <asm/sbus.h>
#include <asm/oplib.h>
#include <asm/oplib.h>
#include <asm/uaccess.h>
#include <asm/uaccess.h>
#include <asm/auxio.h>
#include <asm/auxio.h>
...
@@ -29,11 +30,10 @@
...
@@ -29,11 +30,10 @@
#define APC_OBPNAME "power-management"
#define APC_OBPNAME "power-management"
#define APC_DEVNAME "apc"
#define APC_DEVNAME "apc"
volatile
static
u8
__iomem
*
regs
;
static
u8
__iomem
*
regs
;
static
int
apc_regsize
;
static
int
apc_no_idle
__initdata
=
0
;
static
int
apc_no_idle
__initdata
=
0
;
#define apc_readb(offs)
(sbus_readb(regs+offs))
#define apc_readb(offs) (sbus_readb(regs+offs))
#define apc_writeb(val, offs) (sbus_writeb(val, regs+offs))
#define apc_writeb(val, offs) (sbus_writeb(val, regs+offs))
/* Specify "apc=noidle" on the kernel command line to
/* Specify "apc=noidle" on the kernel command line to
...
@@ -69,9 +69,9 @@ static void apc_swift_idle(void)
...
@@ -69,9 +69,9 @@ static void apc_swift_idle(void)
#endif
#endif
}
}
static
inline
void
apc_free
(
void
)
static
inline
void
apc_free
(
struct
of_device
*
op
)
{
{
sbus_iounmap
(
regs
,
apc_regsize
);
of_iounmap
(
&
op
->
resource
[
0
],
regs
,
resource_size
(
&
op
->
resource
[
0
])
);
}
}
static
int
apc_open
(
struct
inode
*
inode
,
struct
file
*
f
)
static
int
apc_open
(
struct
inode
*
inode
,
struct
file
*
f
)
...
@@ -153,52 +153,56 @@ static const struct file_operations apc_fops = {
...
@@ -153,52 +153,56 @@ static const struct file_operations apc_fops = {
static
struct
miscdevice
apc_miscdev
=
{
APC_MINOR
,
APC_DEVNAME
,
&
apc_fops
};
static
struct
miscdevice
apc_miscdev
=
{
APC_MINOR
,
APC_DEVNAME
,
&
apc_fops
};
static
int
__init
apc_probe
(
void
)
static
int
__devinit
apc_probe
(
struct
of_device
*
op
,
const
struct
of_device_id
*
match
)
{
{
struct
sbus_bus
*
sbus
=
NULL
;
int
err
;
struct
sbus_dev
*
sdev
=
NULL
;
int
iTmp
=
0
;
for_each_sbus
(
sbus
)
{
for_each_sbusdev
(
sdev
,
sbus
)
{
if
(
!
strcmp
(
sdev
->
prom_name
,
APC_OBPNAME
))
{
goto
sbus_done
;
}
}
}
sbus_done:
regs
=
of_ioremap
(
&
op
->
resource
[
0
],
0
,
if
(
!
sdev
)
{
resource_size
(
&
op
->
resource
[
0
]),
APC_OBPNAME
);
return
-
ENODEV
;
if
(
!
regs
)
{
}
apc_regsize
=
sdev
->
reg_addrs
[
0
].
reg_size
;
regs
=
sbus_ioremap
(
&
sdev
->
resource
[
0
],
0
,
apc_regsize
,
APC_OBPNAME
);
if
(
!
regs
)
{
printk
(
KERN_ERR
"%s: unable to map registers
\n
"
,
APC_DEVNAME
);
printk
(
KERN_ERR
"%s: unable to map registers
\n
"
,
APC_DEVNAME
);
return
-
ENODEV
;
return
-
ENODEV
;
}
}
iTmp
=
misc_register
(
&
apc_miscdev
);
err
=
misc_register
(
&
apc_miscdev
);
if
(
iTmp
!=
0
)
{
if
(
err
)
{
printk
(
KERN_ERR
"%s: unable to register device
\n
"
,
APC_DEVNAME
);
printk
(
KERN_ERR
"%s: unable to register device
\n
"
,
APC_DEVNAME
);
apc_free
();
apc_free
(
op
);
return
-
ENODEV
;
return
-
ENODEV
;
}
}
/* Assign power management IDLE handler */
/* Assign power management IDLE handler */
if
(
!
apc_no_idle
)
if
(
!
apc_no_idle
)
pm_idle
=
apc_swift_idle
;
pm_idle
=
apc_swift_idle
;
printk
(
KERN_INFO
"%s: power management initialized%s
\n
"
,
printk
(
KERN_INFO
"%s: power management initialized%s
\n
"
,
APC_DEVNAME
,
apc_no_idle
?
" (CPU idle disabled)"
:
""
);
APC_DEVNAME
,
apc_no_idle
?
" (CPU idle disabled)"
:
""
);
return
0
;
return
0
;
}
}
static
struct
of_device_id
apc_match
[]
=
{
{
.
name
=
APC_OBPNAME
,
},
{},
};
MODULE_DEVICE_TABLE
(
of
,
apc_match
);
static
struct
of_platform_driver
apc_driver
=
{
.
name
=
"apc"
,
.
match_table
=
apc_match
,
.
probe
=
apc_probe
,
};
static
int
__init
apc_init
(
void
)
{
return
of_register_driver
(
&
apc_driver
,
&
of_bus_type
);
}
/* This driver is not critical to the boot process
/* This driver is not critical to the boot process
* and is easiest to ioremap when SBus is already
* and is easiest to ioremap when SBus is already
* initialized, so we install ourselves thusly:
* initialized, so we install ourselves thusly:
*/
*/
__initcall
(
apc_probe
);
__initcall
(
apc_init
);
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录