Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
7a138ede
cloud-kernel
项目概览
openanolis
/
cloud-kernel
大约 1 年 前同步成功
通知
158
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
7a138ede
编写于
8月 29, 2008
作者:
D
David S. Miller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
rtc: Add Sun4V hypervisor RTC driver.
Signed-off-by:
N
David S. Miller
<
davem@davemloft.net
>
上级
29b503f1
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
161 addition
and
0 deletion
+161
-0
drivers/rtc/Kconfig
drivers/rtc/Kconfig
+7
-0
drivers/rtc/Makefile
drivers/rtc/Makefile
+1
-0
drivers/rtc/rtc-sun4v.c
drivers/rtc/rtc-sun4v.c
+153
-0
未找到文件。
drivers/rtc/Kconfig
浏览文件 @
7a138ede
...
...
@@ -592,4 +592,11 @@ config RTC_DRV_PPC
the RTC. This exposes that functionality through the generic RTC
class.
config RTC_DRV_SUN4V
bool "SUN4V Hypervisor RTC"
depends on SPARC64
help
If you say Y here you will get support for the Hypervisor
based RTC on SUN4V systems.
endif # RTC_CLASS
drivers/rtc/Makefile
浏览文件 @
7a138ede
...
...
@@ -39,6 +39,7 @@ obj-$(CONFIG_RTC_DRV_M41T94) += rtc-m41t94.o
obj-$(CONFIG_RTC_DRV_M48T59)
+=
rtc-m48t59.o
obj-$(CONFIG_RTC_DRV_M48T86)
+=
rtc-m48t86.o
obj-$(CONFIG_RTC_DRV_BQ4802)
+=
rtc-bq4802.o
obj-$(CONFIG_RTC_DRV_SUN4V)
+=
rtc-sun4v.o
obj-$(CONFIG_RTC_DRV_MAX6900)
+=
rtc-max6900.o
obj-$(CONFIG_RTC_DRV_MAX6902)
+=
rtc-max6902.o
obj-$(CONFIG_RTC_DRV_OMAP)
+=
rtc-omap.o
...
...
drivers/rtc/rtc-sun4v.c
0 → 100644
浏览文件 @
7a138ede
/* rtc-sun4c.c: Hypervisor based RTC for SUN4V systems.
*
* Copyright (C) 2008 David S. Miller <davem@davemloft.net>
*/
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/delay.h>
#include <linux/init.h>
#include <linux/time.h>
#include <linux/rtc.h>
#include <linux/platform_device.h>
#include <asm/hypervisor.h>
MODULE_AUTHOR
(
"David S. Miller <davem@davemloft.net>"
);
MODULE_DESCRIPTION
(
"SUN4V RTC driver"
);
MODULE_LICENSE
(
"GPL"
);
struct
sun4v_rtc
{
struct
rtc_device
*
rtc
;
spinlock_t
lock
;
};
static
unsigned
long
hypervisor_get_time
(
void
)
{
unsigned
long
ret
,
time
;
int
retries
=
10000
;
retry:
ret
=
sun4v_tod_get
(
&
time
);
if
(
ret
==
HV_EOK
)
return
time
;
if
(
ret
==
HV_EWOULDBLOCK
)
{
if
(
--
retries
>
0
)
{
udelay
(
100
);
goto
retry
;
}
printk
(
KERN_WARNING
"SUN4V: tod_get() timed out.
\n
"
);
return
0
;
}
printk
(
KERN_WARNING
"SUN4V: tod_get() not supported.
\n
"
);
return
0
;
}
static
int
sun4v_read_time
(
struct
device
*
dev
,
struct
rtc_time
*
tm
)
{
struct
sun4v_rtc
*
p
=
dev_get_drvdata
(
dev
);
unsigned
long
flags
,
secs
;
spin_lock_irqsave
(
&
p
->
lock
,
flags
);
secs
=
hypervisor_get_time
();
spin_unlock_irqrestore
(
&
p
->
lock
,
flags
);
rtc_time_to_tm
(
secs
,
tm
);
return
0
;
}
static
int
hypervisor_set_time
(
unsigned
long
secs
)
{
unsigned
long
ret
;
int
retries
=
10000
;
retry:
ret
=
sun4v_tod_set
(
secs
);
if
(
ret
==
HV_EOK
)
return
0
;
if
(
ret
==
HV_EWOULDBLOCK
)
{
if
(
--
retries
>
0
)
{
udelay
(
100
);
goto
retry
;
}
printk
(
KERN_WARNING
"SUN4V: tod_set() timed out.
\n
"
);
return
-
EAGAIN
;
}
printk
(
KERN_WARNING
"SUN4V: tod_set() not supported.
\n
"
);
return
-
EOPNOTSUPP
;
}
static
int
sun4v_set_time
(
struct
device
*
dev
,
struct
rtc_time
*
tm
)
{
struct
sun4v_rtc
*
p
=
dev_get_drvdata
(
dev
);
unsigned
long
flags
,
secs
;
int
err
;
err
=
rtc_tm_to_time
(
tm
,
&
secs
);
if
(
err
)
return
err
;
spin_lock_irqsave
(
&
p
->
lock
,
flags
);
err
=
hypervisor_set_time
(
secs
);
spin_unlock_irqrestore
(
&
p
->
lock
,
flags
);
return
err
;
}
static
const
struct
rtc_class_ops
sun4v_rtc_ops
=
{
.
read_time
=
sun4v_read_time
,
.
set_time
=
sun4v_set_time
,
};
static
int
__devinit
sun4v_rtc_probe
(
struct
platform_device
*
pdev
)
{
struct
sun4v_rtc
*
p
=
kzalloc
(
sizeof
(
*
p
),
GFP_KERNEL
);
if
(
!
p
)
return
-
ENOMEM
;
spin_lock_init
(
&
p
->
lock
);
p
->
rtc
=
rtc_device_register
(
"sun4v"
,
&
pdev
->
dev
,
&
sun4v_rtc_ops
,
THIS_MODULE
);
if
(
IS_ERR
(
p
->
rtc
))
{
int
err
=
PTR_ERR
(
p
->
rtc
);
kfree
(
p
);
return
err
;
}
platform_set_drvdata
(
pdev
,
p
);
return
0
;
}
static
int
__devexit
sun4v_rtc_remove
(
struct
platform_device
*
pdev
)
{
struct
sun4v_rtc
*
p
=
platform_get_drvdata
(
pdev
);
rtc_device_unregister
(
p
->
rtc
);
kfree
(
p
);
return
0
;
}
static
struct
platform_driver
sun4v_rtc_driver
=
{
.
driver
=
{
.
name
=
"rtc-sun4v"
,
.
owner
=
THIS_MODULE
,
},
.
probe
=
sun4v_rtc_probe
,
.
remove
=
__devexit_p
(
sun4v_rtc_remove
),
};
static
int
__init
sun4v_rtc_init
(
void
)
{
return
platform_driver_register
(
&
sun4v_rtc_driver
);
}
static
void
__exit
sun4v_rtc_exit
(
void
)
{
platform_driver_unregister
(
&
sun4v_rtc_driver
);
}
module_init
(
sun4v_rtc_init
);
module_exit
(
sun4v_rtc_exit
);
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录