From 3cc366d3a2eb39f19b6b333d2765f3ac05dee1b2 Mon Sep 17 00:00:00 2001 From: Elliott Hughes Date: Wed, 16 Nov 2022 21:07:56 +0000 Subject: [PATCH] Implement __memset_chk as a copy & paste of __memcpy_chk. These two will stay behind when we move memcpy()/memmove()/memset() over to arm-optimized-routines (which leaves fortify to us). Test: treehugger Change-Id: Ie683f71a5a141263ce3f4e8811df9eaf667584f4 --- libc/Android.bp | 5 +- libc/arch-arm64/generic/bionic/__memset_chk.S | 47 +++++++++++++++++++ libc/arch-arm64/generic/bionic/memset.S | 13 ----- libc/bionic/fortify.cpp | 4 +- 4 files changed, 52 insertions(+), 17 deletions(-) create mode 100644 libc/arch-arm64/generic/bionic/__memset_chk.S diff --git a/libc/Android.bp b/libc/Android.bp index 604292966..533476364 100644 --- a/libc/Android.bp +++ b/libc/Android.bp @@ -787,7 +787,7 @@ cc_library_static { arch: { arm: { cflags: [ - "-DNO___MEMCPY_CHK", + "-DHAVE_ASSEMBLER___MEMCPY_CHK", "-DRENAME___STRCAT_CHK", "-DRENAME___STRCPY_CHK", ], @@ -814,9 +814,10 @@ cc_library_static { ], }, arm64: { - cflags: ["-DNO___MEMCPY_CHK"], + cflags: ["-DHAVE_ASSEMBLER___MEMCPY_CHK"], srcs: [ "arch-arm64/generic/bionic/__memcpy_chk.S", + "arch-arm64/generic/bionic/__memset_chk.S", ], }, }, diff --git a/libc/arch-arm64/generic/bionic/__memset_chk.S b/libc/arch-arm64/generic/bionic/__memset_chk.S new file mode 100644 index 000000000..e1e29d06c --- /dev/null +++ b/libc/arch-arm64/generic/bionic/__memset_chk.S @@ -0,0 +1,47 @@ +/* + * Copyright (C) 2017 The Android Open Source Project + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in + * the documentation and/or other materials provided with the + * distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS + * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE + * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, + * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, + * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS + * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED + * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, + * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT + * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + */ + +#include + +ENTRY(__memset_chk) + cmp x2, x3 + // Direct b.ls memcpy may not have enough range + b.hi .L_memset_chk_fail + b memset + +.L_memset_chk_fail: + // Preserve for accurate backtrace. + stp x29, x30, [sp, -16]! + .cfi_def_cfa_offset 16 + .cfi_rel_offset x29, 0 + .cfi_rel_offset x30, 8 + + bl __memset_chk_fail +END(__memset_chk) + +NOTE_GNU_PROPERTY() diff --git a/libc/arch-arm64/generic/bionic/memset.S b/libc/arch-arm64/generic/bionic/memset.S index 19d351098..145ae6317 100644 --- a/libc/arch-arm64/generic/bionic/memset.S +++ b/libc/arch-arm64/generic/bionic/memset.S @@ -85,19 +85,6 @@ #define L(l) .L ## l -ENTRY(__memset_chk) - cmp count, dst - bls memset - - // Preserve for accurate backtrace. - stp x29, x30, [sp, -16]! - .cfi_def_cfa_offset 16 - .cfi_rel_offset x29, 0 - .cfi_rel_offset x30, 8 - - bl __memset_chk_fail -END(__memset_chk) - ENTRY(memset) dup v0.16B, valw diff --git a/libc/bionic/fortify.cpp b/libc/bionic/fortify.cpp index 88ae4779e..4317a5628 100644 --- a/libc/bionic/fortify.cpp +++ b/libc/bionic/fortify.cpp @@ -489,14 +489,14 @@ extern "C" char* __STRCPY_CHK(char* dst, const char* src, size_t dst_len) { return strcpy(dst, src); } -#if !defined(NO___MEMCPY_CHK) +#if !defined(HAVE_ASSEMBLER___MEMCPY_CHK) // Runtime implementation of __memcpy_chk (used directly by compiler, not in headers). extern "C" void* __memcpy_chk(void* dst, const void* src, size_t count, size_t dst_len) { __check_count("memcpy", "count", count); __check_buffer_access("memcpy", "write into", count, dst_len); return memcpy(dst, src, count); } -#endif // NO___MEMCPY_CHK +#endif // Runtime implementation of __mempcpy_chk (used directly by compiler, not in headers). extern "C" void* __mempcpy_chk(void* dst, const void* src, size_t count, size_t dst_len) {