Message ID | 20230612073551.885100-2-bmeng@tinylab.org |
---|---|
State | Superseded |
Delegated to: | Andes |
Headers | show |
Series | riscv: Add ACLINT mtimer and mswi devices support | expand |
Hi Bin, > From: Bin Meng <bmeng@tinylab.org> > Sent: Monday, June 12, 2023 3:36 PM > To: u-boot@lists.denx.de > Cc: Anup Patel <anup@brainfault.org>; Atish Patra <atishp@atishpatra.org>; Bin Meng <bmeng.cn@gmail.com>; Palmer Dabbelt <palmer@dabbelt.com>; Paul Walmsley <paul.walmsley@sifive.com>; Rick Jian-Zhi Chen(陳建志) <rick@andestech.com> > Subject: [PATCH 1/3] riscv: timer: Update the sifive clint timer driver to support aclint > > This RISC-V ACLINT specification [1] defines a set of memory mapped devices which provide inter-processor interrupts (IPI) and timer functionalities for each HART on a multi-HART RISC-V platform. > > The RISC-V ACLINT specification is defined to be backward compatible with the SiFive CLINT specification, however the device tree binding is a new one. This change updates the sifive clint timer driver to support ACLINT mtimer device, using a per-driver data field to hold the mtimer offset to the base address encoded in the mtimer node. > > [1] https://github.com/riscv/riscv-aclint/blob/main/riscv-aclint.adoc > > Signed-off-by: Bin Meng <bmeng@tinylab.org> > --- > > drivers/timer/sifive_clint_timer.c | 16 +++++++++++----- > include/configs/ae350.h | 2 +- > include/configs/qemu-riscv.h | 2 +- > include/configs/sifive-unleashed.h | 2 +- > include/configs/starfive-visionfive2.h | 1 + > 5 files changed, 15 insertions(+), 8 deletions(-) > > diff --git a/drivers/timer/sifive_clint_timer.c b/drivers/timer/sifive_clint_timer.c > index 939b99d937..be45f17ddf 100644 > --- a/drivers/timer/sifive_clint_timer.c > +++ b/drivers/timer/sifive_clint_timer.c > @@ -12,12 +12,16 @@ > #include <dm/device-internal.h> > #include <linux/err.h> > > +#define CLINT_MTIME_OFFSET 0xbff8 > +#define ACLINT_MTIME_OFFSET 0 > + > /* mtime register */ > -#define MTIME_REG(base) ((ulong)(base) + 0xbff8) > +#define MTIME_REG(base, offset) ((ulong)(base) + (offset)) > > static u64 notrace sifive_clint_get_count(struct udevice *dev) { > - return readq((void __iomem *)MTIME_REG(dev_get_priv(dev))); > + return readq((void __iomem *)MTIME_REG(dev_get_priv(dev), > + dev_get_driver_data(dev))); > } > > #if CONFIG_IS_ENABLED(RISCV_MMODE) && IS_ENABLED(CONFIG_TIMER_EARLY) @@ -35,7 +39,8 @@ unsigned long notrace timer_early_get_rate(void) > */ > u64 notrace timer_early_get_count(void) { > - return readq((void __iomem *)MTIME_REG(RISCV_MMODE_TIMERBASE)); > + return readq((void __iomem *)MTIME_REG(RISCV_MMODE_TIMERBASE, > + RISCV_MMODE_TIMEROFF)); > } > #endif > > @@ -53,8 +58,9 @@ static int sifive_clint_probe(struct udevice *dev) } > > static const struct udevice_id sifive_clint_ids[] = { > - { .compatible = "riscv,clint0" }, > - { .compatible = "sifive,clint0" }, > + { .compatible = "riscv,clint0", .data = CLINT_MTIME_OFFSET }, > + { .compatible = "sifive,clint0", .data = CLINT_MTIME_OFFSET }, > + { .compatible = "riscv,aclint-mtimer", .data = ACLINT_MTIME_OFFSET }, > { } > }; > > diff --git a/include/configs/ae350.h b/include/configs/ae350.h index b566ecf296..02c5c80215 100644 > --- a/include/configs/ae350.h > +++ b/include/configs/ae350.h > @@ -8,8 +8,8 @@ > #define __CONFIG_H > > #define RISCV_MMODE_TIMERBASE 0xe6000000 > +#define RISCV_MMODE_TIMEROFF 0xbff8 Why add this for ae350 ? > #define RISCV_MMODE_TIMER_FREQ 60000000 > - > #define RISCV_SMODE_TIMER_FREQ 60000000 > > /* > diff --git a/include/configs/qemu-riscv.h b/include/configs/qemu-riscv.h index 20135f569e..f6d326bda0 100644 > --- a/include/configs/qemu-riscv.h > +++ b/include/configs/qemu-riscv.h > @@ -11,8 +11,8 @@ > #define CFG_SYS_SDRAM_BASE 0x80000000 > > #define RISCV_MMODE_TIMERBASE 0x2000000 > +#define RISCV_MMODE_TIMEROFF 0xbff8 > #define RISCV_MMODE_TIMER_FREQ 1000000 > - > #define RISCV_SMODE_TIMER_FREQ 1000000 > > /* Environment options */ > diff --git a/include/configs/sifive-unleashed.h b/include/configs/sifive-unleashed.h > index de3a0dcdd5..f208f5e20d 100644 > --- a/include/configs/sifive-unleashed.h > +++ b/include/configs/sifive-unleashed.h > @@ -14,8 +14,8 @@ > #define CFG_SYS_SDRAM_BASE 0x80000000 > > #define RISCV_MMODE_TIMERBASE 0x2000000 > +#define RISCV_MMODE_TIMEROFF 0xbff8 > #define RISCV_MMODE_TIMER_FREQ 1000000 > - > #define RISCV_SMODE_TIMER_FREQ 1000000 > > /* Environment options */ > diff --git a/include/configs/starfive-visionfive2.h b/include/configs/starfive-visionfive2.h > index 93dcc22d36..4ee02b8420 100644 > --- a/include/configs/starfive-visionfive2.h > +++ b/include/configs/starfive-visionfive2.h > @@ -9,6 +9,7 @@ > #define _STARFIVE_VISIONFIVE2_H > > #define RISCV_MMODE_TIMERBASE 0x2000000 > +#define RISCV_MMODE_TIMEROFF 0xbff8 > #define RISCV_MMODE_TIMER_FREQ 4000000 > #define RISCV_SMODE_TIMER_FREQ 4000000
Hi Rick, On Tue, Jun 13, 2023 at 9:46 AM Rick Chen <rickchen36@gmail.com> wrote: > > Hi Bin, > > > From: Bin Meng <bmeng@tinylab.org> > > Sent: Monday, June 12, 2023 3:36 PM > > To: u-boot@lists.denx.de > > Cc: Anup Patel <anup@brainfault.org>; Atish Patra <atishp@atishpatra.org>; Bin Meng <bmeng.cn@gmail.com>; Palmer Dabbelt <palmer@dabbelt.com>; Paul Walmsley <paul.walmsley@sifive.com>; Rick Jian-Zhi Chen(陳建志) <rick@andestech.com> > > Subject: [PATCH 1/3] riscv: timer: Update the sifive clint timer driver to support aclint > > > > This RISC-V ACLINT specification [1] defines a set of memory mapped devices which provide inter-processor interrupts (IPI) and timer functionalities for each HART on a multi-HART RISC-V platform. > > > > The RISC-V ACLINT specification is defined to be backward compatible with the SiFive CLINT specification, however the device tree binding is a new one. This change updates the sifive clint timer driver to support ACLINT mtimer device, using a per-driver data field to hold the mtimer offset to the base address encoded in the mtimer node. > > > > [1] https://github.com/riscv/riscv-aclint/blob/main/riscv-aclint.adoc > > > > Signed-off-by: Bin Meng <bmeng@tinylab.org> > > --- > > > > drivers/timer/sifive_clint_timer.c | 16 +++++++++++----- > > include/configs/ae350.h | 2 +- > > include/configs/qemu-riscv.h | 2 +- > > include/configs/sifive-unleashed.h | 2 +- > > include/configs/starfive-visionfive2.h | 1 + > > 5 files changed, 15 insertions(+), 8 deletions(-) > > > > diff --git a/drivers/timer/sifive_clint_timer.c b/drivers/timer/sifive_clint_timer.c > > index 939b99d937..be45f17ddf 100644 > > --- a/drivers/timer/sifive_clint_timer.c > > +++ b/drivers/timer/sifive_clint_timer.c > > @@ -12,12 +12,16 @@ > > #include <dm/device-internal.h> > > #include <linux/err.h> > > > > +#define CLINT_MTIME_OFFSET 0xbff8 > > +#define ACLINT_MTIME_OFFSET 0 > > + > > /* mtime register */ > > -#define MTIME_REG(base) ((ulong)(base) + 0xbff8) > > +#define MTIME_REG(base, offset) ((ulong)(base) + (offset)) > > > > static u64 notrace sifive_clint_get_count(struct udevice *dev) { > > - return readq((void __iomem *)MTIME_REG(dev_get_priv(dev))); > > + return readq((void __iomem *)MTIME_REG(dev_get_priv(dev), > > + dev_get_driver_data(dev))); > > } > > > > #if CONFIG_IS_ENABLED(RISCV_MMODE) && IS_ENABLED(CONFIG_TIMER_EARLY) @@ -35,7 +39,8 @@ unsigned long notrace timer_early_get_rate(void) > > */ > > u64 notrace timer_early_get_count(void) { > > - return readq((void __iomem *)MTIME_REG(RISCV_MMODE_TIMERBASE)); > > + return readq((void __iomem *)MTIME_REG(RISCV_MMODE_TIMERBASE, > > + RISCV_MMODE_TIMEROFF)); > > } > > #endif > > > > @@ -53,8 +58,9 @@ static int sifive_clint_probe(struct udevice *dev) } > > > > static const struct udevice_id sifive_clint_ids[] = { > > - { .compatible = "riscv,clint0" }, > > - { .compatible = "sifive,clint0" }, > > + { .compatible = "riscv,clint0", .data = CLINT_MTIME_OFFSET }, > > + { .compatible = "sifive,clint0", .data = CLINT_MTIME_OFFSET }, > > + { .compatible = "riscv,aclint-mtimer", .data = ACLINT_MTIME_OFFSET }, > > { } > > }; > > > > diff --git a/include/configs/ae350.h b/include/configs/ae350.h index b566ecf296..02c5c80215 100644 > > --- a/include/configs/ae350.h > > +++ b/include/configs/ae350.h > > @@ -8,8 +8,8 @@ > > #define __CONFIG_H > > > > #define RISCV_MMODE_TIMERBASE 0xe6000000 > > +#define RISCV_MMODE_TIMEROFF 0xbff8 > > Why add this for ae350 ? > Will fix this in v2. Regards, Bin
diff --git a/drivers/timer/sifive_clint_timer.c b/drivers/timer/sifive_clint_timer.c index 939b99d937..be45f17ddf 100644 --- a/drivers/timer/sifive_clint_timer.c +++ b/drivers/timer/sifive_clint_timer.c @@ -12,12 +12,16 @@ #include <dm/device-internal.h> #include <linux/err.h> +#define CLINT_MTIME_OFFSET 0xbff8 +#define ACLINT_MTIME_OFFSET 0 + /* mtime register */ -#define MTIME_REG(base) ((ulong)(base) + 0xbff8) +#define MTIME_REG(base, offset) ((ulong)(base) + (offset)) static u64 notrace sifive_clint_get_count(struct udevice *dev) { - return readq((void __iomem *)MTIME_REG(dev_get_priv(dev))); + return readq((void __iomem *)MTIME_REG(dev_get_priv(dev), + dev_get_driver_data(dev))); } #if CONFIG_IS_ENABLED(RISCV_MMODE) && IS_ENABLED(CONFIG_TIMER_EARLY) @@ -35,7 +39,8 @@ unsigned long notrace timer_early_get_rate(void) */ u64 notrace timer_early_get_count(void) { - return readq((void __iomem *)MTIME_REG(RISCV_MMODE_TIMERBASE)); + return readq((void __iomem *)MTIME_REG(RISCV_MMODE_TIMERBASE, + RISCV_MMODE_TIMEROFF)); } #endif @@ -53,8 +58,9 @@ static int sifive_clint_probe(struct udevice *dev) } static const struct udevice_id sifive_clint_ids[] = { - { .compatible = "riscv,clint0" }, - { .compatible = "sifive,clint0" }, + { .compatible = "riscv,clint0", .data = CLINT_MTIME_OFFSET }, + { .compatible = "sifive,clint0", .data = CLINT_MTIME_OFFSET }, + { .compatible = "riscv,aclint-mtimer", .data = ACLINT_MTIME_OFFSET }, { } }; diff --git a/include/configs/ae350.h b/include/configs/ae350.h index b566ecf296..02c5c80215 100644 --- a/include/configs/ae350.h +++ b/include/configs/ae350.h @@ -8,8 +8,8 @@ #define __CONFIG_H #define RISCV_MMODE_TIMERBASE 0xe6000000 +#define RISCV_MMODE_TIMEROFF 0xbff8 #define RISCV_MMODE_TIMER_FREQ 60000000 - #define RISCV_SMODE_TIMER_FREQ 60000000 /* diff --git a/include/configs/qemu-riscv.h b/include/configs/qemu-riscv.h index 20135f569e..f6d326bda0 100644 --- a/include/configs/qemu-riscv.h +++ b/include/configs/qemu-riscv.h @@ -11,8 +11,8 @@ #define CFG_SYS_SDRAM_BASE 0x80000000 #define RISCV_MMODE_TIMERBASE 0x2000000 +#define RISCV_MMODE_TIMEROFF 0xbff8 #define RISCV_MMODE_TIMER_FREQ 1000000 - #define RISCV_SMODE_TIMER_FREQ 1000000 /* Environment options */ diff --git a/include/configs/sifive-unleashed.h b/include/configs/sifive-unleashed.h index de3a0dcdd5..f208f5e20d 100644 --- a/include/configs/sifive-unleashed.h +++ b/include/configs/sifive-unleashed.h @@ -14,8 +14,8 @@ #define CFG_SYS_SDRAM_BASE 0x80000000 #define RISCV_MMODE_TIMERBASE 0x2000000 +#define RISCV_MMODE_TIMEROFF 0xbff8 #define RISCV_MMODE_TIMER_FREQ 1000000 - #define RISCV_SMODE_TIMER_FREQ 1000000 /* Environment options */ diff --git a/include/configs/starfive-visionfive2.h b/include/configs/starfive-visionfive2.h index 93dcc22d36..4ee02b8420 100644 --- a/include/configs/starfive-visionfive2.h +++ b/include/configs/starfive-visionfive2.h @@ -9,6 +9,7 @@ #define _STARFIVE_VISIONFIVE2_H #define RISCV_MMODE_TIMERBASE 0x2000000 +#define RISCV_MMODE_TIMEROFF 0xbff8 #define RISCV_MMODE_TIMER_FREQ 4000000 #define RISCV_SMODE_TIMER_FREQ 4000000
This RISC-V ACLINT specification [1] defines a set of memory mapped devices which provide inter-processor interrupts (IPI) and timer functionalities for each HART on a multi-HART RISC-V platform. The RISC-V ACLINT specification is defined to be backward compatible with the SiFive CLINT specification, however the device tree binding is a new one. This change updates the sifive clint timer driver to support ACLINT mtimer device, using a per-driver data field to hold the mtimer offset to the base address encoded in the mtimer node. [1] https://github.com/riscv/riscv-aclint/blob/main/riscv-aclint.adoc Signed-off-by: Bin Meng <bmeng@tinylab.org> --- drivers/timer/sifive_clint_timer.c | 16 +++++++++++----- include/configs/ae350.h | 2 +- include/configs/qemu-riscv.h | 2 +- include/configs/sifive-unleashed.h | 2 +- include/configs/starfive-visionfive2.h | 1 + 5 files changed, 15 insertions(+), 8 deletions(-)