This is xnu-12377.1.9. See this file in:
/*
* Copyright (c) 2016-2020 Apple Inc. All rights reserved.
*
* @APPLE_OSREFERENCE_LICENSE_HEADER_START@
*
* This file contains Original Code and/or Modifications of Original Code
* as defined in and that are subject to the Apple Public Source License
* Version 2.0 (the 'License'). You may not use this file except in
* compliance with the License. The rights granted to you under the License
* may not be used to create, or enable the creation or redistribution of,
* unlawful or unlicensed copies of an Apple operating system, or to
* circumvent, violate, or enable the circumvention or violation of, any
* terms of an Apple operating system software license agreement.
*
* Please obtain a copy of the License at
* http://www.opensource.apple.com/apsl/ and read it before using this file.
*
* The Original Code and all software distributed under the License are
* distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
* EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
* INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
* Please see the License for the specific language governing rights and
* limitations under the License.
*
* @APPLE_OSREFERENCE_LICENSE_HEADER_END@
*/
#ifndef _SAN_MEMINTRINSICS_H_
#define _SAN_MEMINTRINSICS_H_
#include <sys/cdefs.h>
/*
* Non-sanitized versions of memory intrinsics
*/
static inline void *
__sized_by(sz)
__nosan_memcpy(void *dst __sized_by(sz), const void *src __sized_by(sz), size_t sz)
{
return memcpy(dst, src, sz);
}
static inline void *
__sized_by(sz)
__nosan_memset(void *dst __sized_by(sz), int c, size_t sz)
{
return memset(dst, c, sz);
}
static inline void *
__sized_by(sz)
__nosan_memmove(void *dst __sized_by(sz), const void *src __sized_by(sz), size_t sz)
{
return memmove(dst, src, sz);
}
static inline int
__nosan_bcmp(const void *a __sized_by(sz), const void *b __sized_by(sz), size_t sz)
{
return bcmp(a, b, sz);
}
static inline void
__nosan_bcopy(const void *src __sized_by(sz), void *dst __sized_by(sz), size_t sz)
{
bcopy(src, dst, sz);
}
static inline int
__nosan_memcmp(const void *a __sized_by(sz), const void *b __sized_by(sz), size_t sz)
{
return memcmp(a, b, sz);
}
static inline void
__nosan_bzero(void *dst __sized_by(sz), size_t sz)
{
bzero(dst, sz);
}
static inline size_t
__nosan_strlcpy(char *__sized_by(sz)dst, const char *__null_terminated src, size_t sz)
{
return strlcpy(dst, src, sz);
}
static inline size_t
__nosan_strlcat(char *__sized_by(sz)dst, const char *__null_terminated src, size_t sz)
{
return strlcat(dst, src, sz);
}
static inline size_t
__nosan_strnlen(const char *__counted_by(sz)src, size_t sz)
{
return strnlen(src, sz);
}
static inline size_t
__nosan_strlen(const char *__null_terminated src)
{
return strlen(src);
}
static inline int
__nosan_strcmp(const char *__null_terminated s1, const char *__null_terminated s2)
{
return strcmp(s1, s2);
}
static inline int
__nosan_strncmp(const char *__unsafe_indexable s1, const char *__unsafe_indexable s2, size_t n)
{
return strbufcmp(__unsafe_forge_bidi_indexable(const char *, s1, n), n, __unsafe_forge_bidi_indexable(const char *, s2, n), n);
}
static inline int
__nosan_strlcmp(const char *__counted_by(n)s1, const char *s2, size_t n)
{
return strlcmp(s1, s2, n);
}
static inline int
__nosan_strbufcmp(const char *__counted_by(s1len)s1, size_t s1len, const char *__counted_by(s2len)s2, size_t s2len)
{
return strbufcmp(s1, s1len, s2, s2len);
}
static inline int
__nosan_strcasecmp(const char *__null_terminated s1, const char *__null_terminated s2)
{
return strcasecmp(s1, s2);
}
static inline int
__nosan_strncasecmp(const char *__unsafe_indexable s1, const char *__unsafe_indexable s2, size_t n)
{
return strbufcasecmp(__unsafe_forge_bidi_indexable(const char *, s1, n), n, __unsafe_forge_bidi_indexable(const char *, s2, n), n);
}
static inline int
__nosan_strlcasecmp(const char *__counted_by(n)s1, const char *s2, size_t n)
{
return strlcasecmp(s1, s2, n);
}
static inline int
__nosan_strbufcasecmp(const char *__counted_by(s1len)s1, size_t s1len, const char *__counted_by(s2len)s2, size_t s2len)
{
return strbufcasecmp(s1, s1len, s2, s2len);
}
#if !__has_ptrcheck && !__has_include(<__xnu_libcxx_sentinel.h>)
static inline char *
__nosan_strncpy(char *dst, const char *src, size_t sz)
{
#ifdef __clang__
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wdeprecated-declarations"
#endif
return strncpy(dst, src, sz);
#ifdef __clang__
#pragma clang diagnostic pop
#endif
}
static inline char *
__nosan_strncat(char *dst, const char *src, size_t sz)
{
#ifdef __clang__
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wdeprecated-declarations"
#endif
return strncat(dst, src, sz);
#ifdef __clang__
#pragma clang diagnostic pop
#endif
}
#endif /* !__has_ptrcheck && !__has_include(<__xnu_libcxx_sentinel.h>) */
#if KASAN
void *__sized_by(sz) __asan_memcpy(void *dst __sized_by(sz), const void *src __sized_by(sz), size_t sz);
void *__sized_by(sz) __asan_memset(void * __sized_by(sz), int c, size_t sz);
void *__sized_by(sz) __asan_memmove(void *dst __sized_by(sz), const void *src __sized_by(sz), size_t sz);
void __asan_bcopy(const void *src __sized_by(sz), void *dst __sized_by(sz), size_t sz);
void __asan_bzero(void *dst __sized_by(sz), size_t sz);
int __asan_bcmp(const void *a __sized_by(sz), const void *b __sized_by(sz), size_t sz) __stateful_pure;
int __asan_memcmp(const void *a __sized_by(sz), const void *b __sized_by(sz), size_t sz) __stateful_pure;
size_t __asan_strlcpy(char *__sized_by(sz) dst, const char *__null_terminated src, size_t sz);
char *__asan_strncpy(char *dst, const char *src, size_t sz);
char *__asan_strncat(char *dst, const char *src, size_t sz);
size_t __asan_strlcat(char *__sized_by(sz) dst, const char *__null_terminated src, size_t sz);
size_t __asan_strnlen(const char *__counted_by(n)s, size_t n) __stateful_pure;
size_t __asan_strlen(const char *__null_terminated src) __stateful_pure;
int __asan_strcmp(const char *__null_terminated s1, const char *__null_terminated s2) __stateful_pure;
__ptrcheck_unavailable_r("strlcmp or strbufcmp")
int __asan_strncmp(const char *__null_terminated s1, const char *__null_terminated s2, size_t n) __stateful_pure;
int __asan_strlcmp(const char *__counted_by(n)s1, const char *s2, size_t n) __stateful_pure;
int __asan_strbufcmp(const char *__counted_by(s1len)s1, size_t s1len, const char *__counted_by(s2len)s2, size_t s2len) __stateful_pure;
int __asan_strcasecmp(const char *__null_terminated s1, const char *__null_terminated s2) __stateful_pure;
__ptrcheck_unavailable_r("strlcasecmp or strbufcasecmp")
int __asan_strncasecmp(const char *__unsafe_indexable s1, const char *__unsafe_indexable s2, size_t n) __stateful_pure;
int __asan_strlcasecmp(const char *__counted_by(n)s1, const char *s2, size_t n) __stateful_pure;
int __asan_strbufcasecmp(const char *__counted_by(s1len)s1, size_t s1len, const char *__counted_by(s2len)s2, size_t s2len) __stateful_pure;
#define memcpy __asan_memcpy
#define memmove __asan_memmove
#define memset __asan_memset
#define bcopy __asan_bcopy
#define bzero __asan_bzero
#define bcmp __asan_bcmp
#define memcmp __asan_memcmp
#define strlcpy __asan_strlcpy
#define strncpy __asan_strncpy
#define strlcat __asan_strlcat
#define strncat __asan_strncat
#define strnlen __asan_strnlen
#define strlen __asan_strlen
#define strcmp __asan_strcmp
#define strncmp __asan_strncmp
#define strlcmp __asan_strlcmp
#define strcasecmp __asan_strcasecmp
#define strncasecmp __asan_strncasecmp
#define strlcasecmp __asan_strlcasecmp
// Previously defined as macros in string.h
#undef strbuflen_1
#undef strbuflen_2
#undef strbuflen
#undef strbufcmp_2
#undef strbufcmp_4
#undef strbufcmp
#undef strbufcasecmp_2
#undef strbufcasecmp_4
#undef strbufcasecmp
#define strbuflen_1(BUF) ({ \
__xnu_assert_is_array(BUF, "argument is not an array"); \
__asan_strnlen((BUF), sizeof(BUF)); \
})
#define strbuflen_2(BUF, LEN) __asan_strnlen(BUF, LEN)
#define strbuflen(...) __xnu_argc_overload(strbuflen, __VA_ARGS__)
#define strbufcmp_2(A, B) ({ \
__xnu_assert_is_array(A, "first argument is not an array"); \
__xnu_assert_is_array(B, "second argument is not an array"); \
(__asan_strbufcmp)((A), sizeof(A), (B), sizeof(B)); \
})
#define strbufcmp_4 (__asan_strbufcmp)
#define strbufcmp(...) __xnu_argc_overload(strbufcmp, __VA_ARGS__)
#define strbufcasecmp_2(A, B) ({ \
__xnu_assert_is_array(A, "first argument is not an array"); \
__xnu_assert_is_array(B, "second argument is not an array"); \
(__asan_strbufcasecmp)((A), sizeof(A), (B), sizeof(B)); \
})
#define strbufcasecmp_4 (__asan_strbufcasecmp)
#define strbufcasecmp(...) __xnu_argc_overload(strbufcasecmp, __VA_ARGS__)
#endif
#endif /* _SAN_MEMINTRINSICS_H_ */