[PATCH 1/1] lib: sign conflict in wake_coldboot_harts()

Anup Patel Anup.Patel at wdc.com
Tue Jun 22 08:00:55 PDT 2021



On 22/06/21, 12:13 PM, "Xiang W" <wxjstz at 126.com> wrote:

    在 2021-06-21星期一的 21:37 +0200,Heinrich Schuchardt写道:
    > Compiling wake_coldboot_harts() with GCC 11 and -Wextra yields:
    > 
    > lib/sbi/sbi_init.c:208:27:
    > error: comparison of integer expressions of different signedness:
    > ‘int’ and ‘u32’ {aka ‘unsigned int’} [-Werror=sign-compare]
    >   208 |         for (int i = 0; i <= sbi_scratch_last_hartid(); i++)
    > {
    >       |                           ^~
    > 
    > Signed-off-by: Heinrich Schuchardt <xypron.glpk at gmx.de>
    > 
    Reviewed-by: Xiang W <wxjstz at 126.com>

Applied this patch to the riscv/opensbi repo.

Regards,
Anup

    > ---
    >  lib/sbi/sbi_init.c | 2 +-
    >  1 file changed, 1 insertion(+), 1 deletion(-)
    > 
    > diff --git a/lib/sbi/sbi_init.c b/lib/sbi/sbi_init.c
    > index b158314..e396d95 100644
    > --- a/lib/sbi/sbi_init.c
    > +++ b/lib/sbi/sbi_init.c
    > @@ -205,7 +205,7 @@ static void wake_coldboot_harts(struct
    > sbi_scratch *scratch, u32 hartid)
    >         spin_lock(&coldboot_lock);
    > 
    >         /* Send an IPI to all HARTs waiting for coldboot */
    > -       for (int i = 0; i <= sbi_scratch_last_hartid(); i++) {
    > +       for (u32 i = 0; i <= sbi_scratch_last_hartid(); i++) {
    >                 if ((i != hartid) &&
    >                     sbi_hartmask_test_hart(i, &coldboot_wait_hmask))
    >                         sbi_ipi_raw_send(i);
    > --
    > 2.30.2
    > 
    > 





More information about the opensbi mailing list