59a13c122e
This change creates assembler versions of __memcpy_chk/__memset_chk
that is implemented in the memcpy/memset assembler code. This change
avoids an extra call to memcpy/memset, instead allowing a simple fall
through to occur from the chk code into the body of the real
implementation.
Testing:
- Ran the libc_test on __memcpy_chk/__memset_chk on all nexus devices.
- Wrote a small test executable that has three calls to __memcpy_chk and
three calls to __memset_chk. First call dest_len is length + 1. Second
call dest_len is length. Third call dest_len is length - 1.
Verified that the first two calls pass, and the third fails. Examined
the logcat output on all nexus devices to verify that the fortify
error message was sent properly.
- I benchmarked the new __memcpy_chk and __memset_chk on all systems. For
__memcpy_chk and large copies, the savings is relatively small (about 1%).
For small copies, the savings is large on cortex-a15/krait devices
(between 5% to 30%).
For cortex-a9 and small copies, the speed up is present, but relatively
small (about 3% to 5%).
For __memset_chk and large copies, the savings is also small (about 1%).
However, all processors show larger speed-ups on small copies (about 30% to
100%).
Bug: 9293744
Merge from internal master.
(cherry-picked from
|
||
---|---|---|
.. | ||
__dso_handle_so.h | ||
__dso_handle.h | ||
arpa_nameser_compat.h | ||
arpa_nameser.h | ||
bionic_atomic_arm.h | ||
bionic_atomic_gcc_builtin.h | ||
bionic_atomic_inline.h | ||
bionic_atomic_mips.h | ||
bionic_atomic_x86.h | ||
bionic_auxv.h | ||
bionic_futex.h | ||
bionic_pthread.h | ||
bionic_ssp.h | ||
bionic_time.h | ||
bionic_tls.h | ||
cpuacct.h | ||
ctype_private.h | ||
ErrnoRestorer.h | ||
kernel_sigset_t.h | ||
KernelArgumentBlock.h | ||
libc_events.h | ||
libc_logging.h | ||
nsswitch.h | ||
rand48.h | ||
resolv_cache.h | ||
resolv_iface.h | ||
resolv_private.h | ||
resolv_static.h | ||
ScopedPthreadMutexLocker.h | ||
ScopedReaddir.h | ||
syscommon.h | ||
thread_private.h | ||
ThreadLocalBuffer.h |