[PATCHv3] lib: Delete redundant `ulong`

Anup Patel anup at brainfault.org
Sat Aug 24 02:20:23 PDT 2024


On Wed, Aug 14, 2024 at 6:53 PM Zhang Runmin <runmin.zhang at ingenic.com> wrote:
>
> From: Zhang RunMin <runmin.zhang at ingenic.com>
>
> In `csr_read_allowed` and `csr_write_allowed` macros, has already
> converted second param to `ulong`. So delete redundant `ulong`
> where uses csr_read/write_allowed macros.
>
> Signed-off-by: Zhang RunMin <runmin.zhang at ingenic.com>
> ---
> v3:
> - Fix the formatting problems caused by deleting ulong
> v2:
> - Fix similar problems in:
>   lib/sbi/sbi_hart.c
>   lib/utils/irqchip/imsic.c
> v1:
> - Delete redundant ulong in:
>   lib/sbi/sbi_dbtr.c
> ---
>  lib/sbi/sbi_dbtr.c        |  9 +++++----
>  lib/sbi/sbi_hart.c        | 28 ++++++++++++++--------------
>  lib/utils/irqchip/imsic.c |  2 +-
>  3 files changed, 20 insertions(+), 19 deletions(-)
>
> diff --git a/lib/sbi/sbi_dbtr.c b/lib/sbi/sbi_dbtr.c
> index 27a8b91..60c37b4 100644
> --- a/lib/sbi/sbi_dbtr.c
> +++ b/lib/sbi/sbi_dbtr.c
> @@ -167,11 +167,12 @@ int sbi_dbtr_init(struct sbi_scratch *scratch, bool coldboot)
>                 goto _probed;
>
>         for (i = 0; i < RV_MAX_TRIGGERS; i++) {
> -               csr_write_allowed(CSR_TSELECT, (ulong)&trap, i);
> +               // CSR_TESLECT 0x7a0

Unrelated change.

> +               csr_write_allowed(CSR_TSELECT, &trap, i);
>                 if (trap.cause)
>                         break;
>
> -               val = csr_read_allowed(CSR_TSELECT, (ulong)&trap);
> +               val = csr_read_allowed(CSR_TSELECT, &trap);
>                 if (trap.cause)
>                         break;
>
> @@ -182,7 +183,7 @@ int sbi_dbtr_init(struct sbi_scratch *scratch, bool coldboot)
>                 if (val != i)
>                         break;
>
> -               val = csr_read_allowed(CSR_TINFO, (ulong)&trap);
> +               val = csr_read_allowed(CSR_TINFO, &trap);
>                 if (trap.cause) {
>                         /*
>                          * If reading tinfo caused an exception, the
> @@ -190,7 +191,7 @@ int sbi_dbtr_init(struct sbi_scratch *scratch, bool coldboot)
>                          * type.
>                          */
>                         tdata1 = csr_read_allowed(CSR_TDATA1,
> -                                                 (ulong)&trap);
> +                                                 &trap);
>                         if (trap.cause)
>                                 break;
>
> diff --git a/lib/sbi/sbi_hart.c b/lib/sbi/sbi_hart.c
> index c366701..cc364fa 100644
> --- a/lib/sbi/sbi_hart.c
> +++ b/lib/sbi/sbi_hart.c
> @@ -723,13 +723,13 @@ static unsigned long hart_pmp_get_allowed_addr(void)
>         unsigned long val = 0;
>         struct sbi_trap_info trap = {0};
>
> -       csr_write_allowed(CSR_PMPCFG0, (ulong)&trap, 0);
> +       csr_write_allowed(CSR_PMPCFG0, &trap, 0);
>         if (trap.cause)
>                 return 0;
>
> -       csr_write_allowed(CSR_PMPADDR0, (ulong)&trap, PMP_ADDR_MASK);
> +       csr_write_allowed(CSR_PMPADDR0, &trap, PMP_ADDR_MASK);
>         if (!trap.cause) {
> -               val = csr_read_allowed(CSR_PMPADDR0, (ulong)&trap);
> +               val = csr_read_allowed(CSR_PMPADDR0, &trap);
>                 if (trap.cause)
>                         val = 0;
>         }
> @@ -747,17 +747,17 @@ static int hart_mhpm_get_allowed_bits(void)
>          * It is assumed that platforms will implement same number of bits for
>          * all the performance counters including mcycle/minstret.
>          */
> -       csr_write_allowed(CSR_MHPMCOUNTER3, (ulong)&trap, val);
> +       csr_write_allowed(CSR_MHPMCOUNTER3, &trap, val);
>         if (!trap.cause) {
> -               val = csr_read_allowed(CSR_MHPMCOUNTER3, (ulong)&trap);
> +               val = csr_read_allowed(CSR_MHPMCOUNTER3, &trap);
>                 if (trap.cause)
>                         return 0;
>         }
>         num_bits = sbi_fls(val) + 1;
>  #if __riscv_xlen == 32
> -       csr_write_allowed(CSR_MHPMCOUNTER3H, (ulong)&trap, val);
> +       csr_write_allowed(CSR_MHPMCOUNTER3H, &trap, val);
>         if (!trap.cause) {
> -               val = csr_read_allowed(CSR_MHPMCOUNTER3H, (ulong)&trap);
> +               val = csr_read_allowed(CSR_MHPMCOUNTER3H, &trap);
>                 if (trap.cause)
>                         return num_bits;
>         }
> @@ -788,9 +788,9 @@ static int hart_detect_features(struct sbi_scratch *scratch)
>         hfeatures->priv_version = SBI_HART_PRIV_VER_UNKNOWN;
>
>  #define __check_hpm_csr(__csr, __mask)                                           \
> -       oldval = csr_read_allowed(__csr, (ulong)&trap);                   \
> +       oldval = csr_read_allowed(__csr, &trap);                          \
>         if (!trap.cause) {                                                \
> -               csr_write_allowed(__csr, (ulong)&trap, 1UL);              \
> +               csr_write_allowed(__csr, &trap, 1UL);                     \
>                 if (!trap.cause && csr_swap(__csr, oldval) == 1UL) {      \
>                         (hfeatures->__mask) |= 1 << (__csr - CSR_MCYCLE); \
>                 }                                                         \
> @@ -809,13 +809,13 @@ static int hart_detect_features(struct sbi_scratch *scratch)
>         __check_hpm_csr_8(__csr + 0, __mask)                      \
>         __check_hpm_csr_8(__csr + 8, __mask)
>
> -#define __check_csr(__csr, __rdonly, __wrval, __field, __skip) \
> -       oldval = csr_read_allowed(__csr, (ulong)&trap);                 \
> +#define __check_csr(__csr, __rdonly, __wrval, __field, __skip)         \
> +       oldval = csr_read_allowed(__csr, &trap);                        \
>         if (!trap.cause) {                                              \
>                 if (__rdonly) {                                         \
>                         (hfeatures->__field)++;                         \
>                 } else {                                                \
> -                       csr_write_allowed(__csr, (ulong)&trap, __wrval);\
> +                       csr_write_allowed(__csr, &trap, __wrval);       \
>                         if (!trap.cause) {                              \
>                                 if (csr_swap(__csr, oldval) == __wrval) \
>                                         (hfeatures->__field)++;         \
> @@ -880,7 +880,7 @@ __pmp_skip:
>
>
>  #define __check_priv(__csr, __base_priv, __priv)                       \
> -       val = csr_read_allowed(__csr, (ulong)&trap);                    \
> +       val = csr_read_allowed(__csr, &trap);                           \
>         if (!trap.cause && (hfeatures->priv_version >= __base_priv)) {  \
>                 hfeatures->priv_version = __priv;                       \
>         }
> @@ -899,7 +899,7 @@ __pmp_skip:
>
>  #define __check_ext_csr(__base_priv, __csr, __ext)                     \
>         if (hfeatures->priv_version >= __base_priv) {                   \
> -               csr_read_allowed(__csr, (ulong)&trap);                  \
> +               csr_read_allowed(__csr, &trap);                         \
>                 if (!trap.cause)                                        \
>                         __sbi_hart_update_extension(hfeatures,          \
>                                                     __ext, true);       \
> diff --git a/lib/utils/irqchip/imsic.c b/lib/utils/irqchip/imsic.c
> index 7d6993e..bac72d2 100644
> --- a/lib/utils/irqchip/imsic.c
> +++ b/lib/utils/irqchip/imsic.c
> @@ -241,7 +241,7 @@ void imsic_local_irqchip_init(void)
>          */
>
>         /* If Smaia not available then do nothing */
> -       csr_read_allowed(CSR_MTOPI, (ulong)&trap);
> +       csr_read_allowed(CSR_MTOPI, &trap);
>         if (trap.cause)
>                 return;
>
> --
> 2.25.1
>
>
> --
> opensbi mailing list
> opensbi at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/opensbi

Otherwise, looks good to me. I have dropped the unrelated change
at the time of merging this patch.

Reviewed-by: Anup Patel <anup at brainfault.org>

Applied this patch to the riscv/opensbi repo.

Thanks,
Anup



More information about the opensbi mailing list