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