提交 bd5a1936 编写于 作者: Z Zhen Lei 提交者: Daniel Lezcano

clocksource/drivers/sp804: Add support for Hisilicon sp804 timer

The ARM SP804 supports a maximum of 32-bit counter, but Hisilicon extends
it to 64-bit. That means, the registers: TimerXload, TimerXValue and
TimerXBGLoad are 64bits, all other registers are the same as those in the
SP804. The driver code can be completely reused except that the register
offset is different.

Use compatible = "hisilicon,sp804" mark as Hisilicon sp804 timer.
Signed-off-by: NZhen Lei <thunder.leizhen@huawei.com>
Signed-off-by: NDaniel Lezcano <daniel.lezcano@linaro.org>
Link: https://lore.kernel.org/r/20200918132237.3552-8-thunder.leizhen@huawei.com
上级 23c788cd
...@@ -20,6 +20,18 @@ ...@@ -20,6 +20,18 @@
#include "timer-sp.h" #include "timer-sp.h"
/* Hisilicon 64-bit timer(a variant of ARM SP804) */
#define HISI_TIMER_1_BASE 0x00
#define HISI_TIMER_2_BASE 0x40
#define HISI_TIMER_LOAD 0x00
#define HISI_TIMER_VALUE 0x08
#define HISI_TIMER_CTRL 0x10
#define HISI_TIMER_INTCLR 0x14
#define HISI_TIMER_RIS 0x18
#define HISI_TIMER_MIS 0x1c
#define HISI_TIMER_BGLOAD 0x20
struct sp804_timer __initdata arm_sp804_timer = { struct sp804_timer __initdata arm_sp804_timer = {
.load = TIMER_LOAD, .load = TIMER_LOAD,
.value = TIMER_VALUE, .value = TIMER_VALUE,
...@@ -29,6 +41,15 @@ struct sp804_timer __initdata arm_sp804_timer = { ...@@ -29,6 +41,15 @@ struct sp804_timer __initdata arm_sp804_timer = {
.width = 32, .width = 32,
}; };
struct sp804_timer __initdata hisi_sp804_timer = {
.load = HISI_TIMER_LOAD,
.value = HISI_TIMER_VALUE,
.ctrl = HISI_TIMER_CTRL,
.intclr = HISI_TIMER_INTCLR,
.timer_base = {HISI_TIMER_1_BASE, HISI_TIMER_2_BASE},
.width = 64,
};
static struct sp804_clkevt sp804_clkevt[NR_TIMERS]; static struct sp804_clkevt sp804_clkevt[NR_TIMERS];
static long __init sp804_get_clock_rate(struct clk *clk, const char *name) static long __init sp804_get_clock_rate(struct clk *clk, const char *name)
...@@ -315,6 +336,12 @@ static int __init arm_sp804_of_init(struct device_node *np) ...@@ -315,6 +336,12 @@ static int __init arm_sp804_of_init(struct device_node *np)
} }
TIMER_OF_DECLARE(sp804, "arm,sp804", arm_sp804_of_init); TIMER_OF_DECLARE(sp804, "arm,sp804", arm_sp804_of_init);
static int __init hisi_sp804_of_init(struct device_node *np)
{
return sp804_of_init(np, &hisi_sp804_timer);
}
TIMER_OF_DECLARE(hisi_sp804, "hisilicon,sp804", hisi_sp804_of_init);
static int __init integrator_cp_of_init(struct device_node *np) static int __init integrator_cp_of_init(struct device_node *np)
{ {
static int init_count = 0; static int init_count = 0;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册