[PATCH 2/5] powerpc: module_[32|64].c: replace swap function with built-in one

Michael Ellerman mpe at ellerman.id.au
Mon Apr 1 21:11:19 AEDT 2019


Andrey Abramov <st5pub at yandex.ru> writes:

> Replace relaswap with built-in one, because of relaswap
> does a simple byte to byte swap.
>
> Signed-off-by: Andrey Abramov <st5pub at 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 <mpe at 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


More information about the Linuxppc-dev mailing list