diff mbox series

[RFC,08/14] lib: sbi: Use csr_read/write_num to read/update PMU counters

Message ID 20210319221305.2138412-9-atish.patra@wdc.com
State Superseded
Headers show
Series SBI PMU extension support | expand

Commit Message

Atish Patra March 19, 2021, 10:12 p.m. UTC
Currently, csr_read/write_num functions are used to read/write PMP related
CSRs where CSR value is decided at runtime. Expand this function to include
PMU related CSRs as well.

Signed-off-by: Atish Patra <atish.patra@wdc.com>
---
 lib/sbi/riscv_asm.c | 35 +++++++++++++++++++++++++++++++++++
 1 file changed, 35 insertions(+)

Comments

Anup Patel April 8, 2021, 3:27 a.m. UTC | #1
> -----Original Message-----
> From: Atish Patra <atish.patra@wdc.com>
> Sent: 20 March 2021 03:43
> To: opensbi@lists.infradead.org
> Cc: Atish Patra <Atish.Patra@wdc.com>; Anup Patel <Anup.Patel@wdc.com>
> Subject: [RFC 08/14] lib: sbi: Use csr_read/write_num to read/update PMU
> counters
> 
> Currently, csr_read/write_num functions are used to read/write PMP
> related CSRs where CSR value is decided at runtime. Expand this function to
> include PMU related CSRs as well.
> 
> Signed-off-by: Atish Patra <atish.patra@wdc.com>

Looks good to me.

Reviewed-by: Anup Patel <anup.patel@wdc.com>

Regards,
Anup

> ---
>  lib/sbi/riscv_asm.c | 35 +++++++++++++++++++++++++++++++++++
>  1 file changed, 35 insertions(+)
> 
> diff --git a/lib/sbi/riscv_asm.c b/lib/sbi/riscv_asm.c index
> 8c54c11147e7..4c24a5132195 100644
> --- a/lib/sbi/riscv_asm.c
> +++ b/lib/sbi/riscv_asm.c
> @@ -118,6 +118,21 @@ unsigned long csr_read_num(int csr_num)
>  	switch (csr_num) {
>  	switchcase_csr_read_16(CSR_PMPCFG0, ret)
>  	switchcase_csr_read_64(CSR_PMPADDR0, ret)
> +	switchcase_csr_read(CSR_MCYCLE, ret)
> +	switchcase_csr_read(CSR_MINSTRET, ret)
> +	switchcase_csr_read(CSR_MHPMCOUNTER3, ret)
> +	switchcase_csr_read_4(CSR_MHPMCOUNTER4, ret)
> +	switchcase_csr_read_8(CSR_MHPMCOUNTER8, ret)
> +	switchcase_csr_read_16(CSR_MHPMCOUNTER16, ret) #if
> __riscv_xlen == 32
> +	switchcase_csr_read(CSR_MCYCLEH, ret)
> +	switchcase_csr_read(CSR_MINSTRETH, ret)
> +	switchcase_csr_read(CSR_MHPMCOUNTER3H, ret)
> +	switchcase_csr_read_4(CSR_MHPMCOUNTER4H, ret)
> +	switchcase_csr_read_8(CSR_MHPMCOUNTER8H, ret)
> +	switchcase_csr_read_16(CSR_MHPMCOUNTER16H, ret) #endif
> +
>  	default:
>  		break;
>  	};
> @@ -161,6 +176,26 @@ void csr_write_num(int csr_num, unsigned long val)
>  	switch (csr_num) {
>  	switchcase_csr_write_16(CSR_PMPCFG0, val)
>  	switchcase_csr_write_64(CSR_PMPADDR0, val)
> +	switchcase_csr_write(CSR_MCYCLE, val)
> +	switchcase_csr_write(CSR_MINSTRET, val)
> +	switchcase_csr_write(CSR_MHPMCOUNTER3, val)
> +	switchcase_csr_write_4(CSR_MHPMCOUNTER4, val)
> +	switchcase_csr_write_8(CSR_MHPMCOUNTER8, val)
> +	switchcase_csr_write_16(CSR_MHPMCOUNTER16, val) #if
> __riscv_xlen == 32
> +	switchcase_csr_write(CSR_MCYCLEH, val)
> +	switchcase_csr_write(CSR_MINSTRETH, val)
> +	switchcase_csr_write(CSR_MHPMCOUNTER3H, val)
> +	switchcase_csr_write_4(CSR_MHPMCOUNTER4H, val)
> +	switchcase_csr_write_8(CSR_MHPMCOUNTER8H, val)
> +	switchcase_csr_write_16(CSR_MHPMCOUNTER16H, val) #endif
> +	switchcase_csr_write(CSR_MCOUNTINHIBIT, val)
> +	switchcase_csr_write(CSR_MHPMEVENT3, val)
> +	switchcase_csr_write_4(CSR_MHPMEVENT4, val)
> +	switchcase_csr_write_8(CSR_MHPMEVENT8, val)
> +	switchcase_csr_write_16(CSR_MHPMEVENT16, val)
> +
>  	default:
>  		break;
>  	};
> --
> 2.25.1
diff mbox series

Patch

diff --git a/lib/sbi/riscv_asm.c b/lib/sbi/riscv_asm.c
index 8c54c11147e7..4c24a5132195 100644
--- a/lib/sbi/riscv_asm.c
+++ b/lib/sbi/riscv_asm.c
@@ -118,6 +118,21 @@  unsigned long csr_read_num(int csr_num)
 	switch (csr_num) {
 	switchcase_csr_read_16(CSR_PMPCFG0, ret)
 	switchcase_csr_read_64(CSR_PMPADDR0, ret)
+	switchcase_csr_read(CSR_MCYCLE, ret)
+	switchcase_csr_read(CSR_MINSTRET, ret)
+	switchcase_csr_read(CSR_MHPMCOUNTER3, ret)
+	switchcase_csr_read_4(CSR_MHPMCOUNTER4, ret)
+	switchcase_csr_read_8(CSR_MHPMCOUNTER8, ret)
+	switchcase_csr_read_16(CSR_MHPMCOUNTER16, ret)
+#if __riscv_xlen == 32
+	switchcase_csr_read(CSR_MCYCLEH, ret)
+	switchcase_csr_read(CSR_MINSTRETH, ret)
+	switchcase_csr_read(CSR_MHPMCOUNTER3H, ret)
+	switchcase_csr_read_4(CSR_MHPMCOUNTER4H, ret)
+	switchcase_csr_read_8(CSR_MHPMCOUNTER8H, ret)
+	switchcase_csr_read_16(CSR_MHPMCOUNTER16H, ret)
+#endif
+
 	default:
 		break;
 	};
@@ -161,6 +176,26 @@  void csr_write_num(int csr_num, unsigned long val)
 	switch (csr_num) {
 	switchcase_csr_write_16(CSR_PMPCFG0, val)
 	switchcase_csr_write_64(CSR_PMPADDR0, val)
+	switchcase_csr_write(CSR_MCYCLE, val)
+	switchcase_csr_write(CSR_MINSTRET, val)
+	switchcase_csr_write(CSR_MHPMCOUNTER3, val)
+	switchcase_csr_write_4(CSR_MHPMCOUNTER4, val)
+	switchcase_csr_write_8(CSR_MHPMCOUNTER8, val)
+	switchcase_csr_write_16(CSR_MHPMCOUNTER16, val)
+#if __riscv_xlen == 32
+	switchcase_csr_write(CSR_MCYCLEH, val)
+	switchcase_csr_write(CSR_MINSTRETH, val)
+	switchcase_csr_write(CSR_MHPMCOUNTER3H, val)
+	switchcase_csr_write_4(CSR_MHPMCOUNTER4H, val)
+	switchcase_csr_write_8(CSR_MHPMCOUNTER8H, val)
+	switchcase_csr_write_16(CSR_MHPMCOUNTER16H, val)
+#endif
+	switchcase_csr_write(CSR_MCOUNTINHIBIT, val)
+	switchcase_csr_write(CSR_MHPMEVENT3, val)
+	switchcase_csr_write_4(CSR_MHPMEVENT4, val)
+	switchcase_csr_write_8(CSR_MHPMEVENT8, val)
+	switchcase_csr_write_16(CSR_MHPMEVENT16, val)
+
 	default:
 		break;
 	};