]> git.ipfire.org Git - thirdparty/glibc.git/commit
aarch64: Optimized memset specific to AmpereComputing emag
authorFeng Xue <fxue@os.amperecomputing.com>
Mon, 30 Jul 2018 06:21:42 +0000 (02:21 -0400)
committerFeng Xue <fxue@os.amperecomputing.com>
Fri, 1 Feb 2019 12:59:18 +0000 (07:59 -0500)
commitc7d3890ff51bceb38fac0947ce1f2bb0c34f6b15
tree2888ed321d26b3c0df7347cf25e0772a41fadf12
parent07c3d1ec03ee3633918afb59213cd1bac2ab276e
aarch64: Optimized memset specific to AmpereComputing emag

This version uses general register based memory store instead of
vector register based, for the former is faster than the latter
in emag.

The fact that DC ZVA size in emag is 64-byte, is used by IFUNC
dispatch to select this memset, so that cost of runtime-check on
DC ZVA size can be saved.

    * sysdeps/aarch64/multiarch/Makefile (sysdep_routines):
    Add memset_emag.
    * sysdeps/aarch64/multiarch/ifunc-impl-list.c
    (__libc_ifunc_impl_list): Add __memset_emag to memset ifunc.
    * sysdeps/aarch64/multiarch/memset.c (libc_ifunc):
    Add IS_EMAG check for ifunc dispatch.
    * sysdeps/aarch64/multiarch/memset_base64.S: New file.
    * sysdeps/aarch64/multiarch/memset_emag.S: New file.
ChangeLog
sysdeps/aarch64/multiarch/Makefile
sysdeps/aarch64/multiarch/ifunc-impl-list.c
sysdeps/aarch64/multiarch/memset.c
sysdeps/aarch64/multiarch/memset_base64.S [new file with mode: 0644]
sysdeps/aarch64/multiarch/memset_emag.S [new file with mode: 0644]