Andrey Abramov <st5...@yandex.ru> writes:

> Replace relaswap with built-in one, because of relaswap
> does a simple byte to byte swap.
>
> Signed-off-by: Andrey Abramov <st5...@yandex.ru>
> ---
>  arch/powerpc/kernel/module_32.c | 17 +----------------
>  arch/powerpc/kernel/module_64.c | 17 +----------------
>  2 files changed, 2 insertions(+), 32 deletions(-)

This looks OK. It's a bit of a pity to replace the 8-byte-at-a-time copy
with a byte-at-a-time copy, but I suspect it's insignificant compared to
the overhead of calling the comparison and swap functions.

And we could always add a generic 8-byte-at-a-time swap function if it's
a bottleneck.

Acked-by: Michael Ellerman <m...@ellerman.id.au> (powerpc)

cheers

> diff --git a/arch/powerpc/kernel/module_32.c b/arch/powerpc/kernel/module_32.c
> index 88d83771f462..c311e8575d10 100644
> --- a/arch/powerpc/kernel/module_32.c
> +++ b/arch/powerpc/kernel/module_32.c
> @@ -79,21 +79,6 @@ static int relacmp(const void *_x, const void *_y)
>               return 0;
>  }
>  
> -static void relaswap(void *_x, void *_y, int size)
> -{
> -     uint32_t *x, *y, tmp;
> -     int i;
> -
> -     y = (uint32_t *)_x;
> -     x = (uint32_t *)_y;
> -
> -     for (i = 0; i < sizeof(Elf32_Rela) / sizeof(uint32_t); i++) {
> -             tmp = x[i];
> -             x[i] = y[i];
> -             y[i] = tmp;
> -     }
> -}
> -
>  /* Get the potential trampolines size required of the init and
>     non-init sections */
>  static unsigned long get_plt_size(const Elf32_Ehdr *hdr,
> @@ -130,7 +115,7 @@ static unsigned long get_plt_size(const Elf32_Ehdr *hdr,
>                        */
>                       sort((void *)hdr + sechdrs[i].sh_offset,
>                            sechdrs[i].sh_size / sizeof(Elf32_Rela),
> -                          sizeof(Elf32_Rela), relacmp, relaswap);
> +                          sizeof(Elf32_Rela), relacmp, NULL);
>  
>                       ret += count_relocs((void *)hdr
>                                            + sechdrs[i].sh_offset,
> diff --git a/arch/powerpc/kernel/module_64.c b/arch/powerpc/kernel/module_64.c
> index 8661eea78503..0c833d7f36f1 100644
> --- a/arch/powerpc/kernel/module_64.c
> +++ b/arch/powerpc/kernel/module_64.c
> @@ -231,21 +231,6 @@ static int relacmp(const void *_x, const void *_y)
>               return 0;
>  }
>  
> -static void relaswap(void *_x, void *_y, int size)
> -{
> -     uint64_t *x, *y, tmp;
> -     int i;
> -
> -     y = (uint64_t *)_x;
> -     x = (uint64_t *)_y;
> -
> -     for (i = 0; i < sizeof(Elf64_Rela) / sizeof(uint64_t); i++) {
> -             tmp = x[i];
> -             x[i] = y[i];
> -             y[i] = tmp;
> -     }
> -}
> -
>  /* Get size of potential trampolines required. */
>  static unsigned long get_stubs_size(const Elf64_Ehdr *hdr,
>                                   const Elf64_Shdr *sechdrs)
> @@ -269,7 +254,7 @@ static unsigned long get_stubs_size(const Elf64_Ehdr *hdr,
>                        */
>                       sort((void *)sechdrs[i].sh_addr,
>                            sechdrs[i].sh_size / sizeof(Elf64_Rela),
> -                          sizeof(Elf64_Rela), relacmp, relaswap);
> +                          sizeof(Elf64_Rela), relacmp, NULL);
>  
>                       relocs += count_relocs((void *)sechdrs[i].sh_addr,
>                                              sechdrs[i].sh_size
> -- 
> 2.21.0

Reply via email to