]> git.saurik.com Git - apple/xnu.git/blobdiff - osfmk/libsa/string.h
xnu-7195.101.1.tar.gz
[apple/xnu.git] / osfmk / libsa / string.h
index e6a0baf637852b29c98fa75d4e0352eba242144d..3112f5791fd49c464059cca99a2b1083f9682faa 100644 (file)
@@ -1,17 +1,20 @@
 /*
- * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2000-2006 Apple Computer, Inc. All rights reserved.
+ *
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  *
- * @APPLE_LICENSE_HEADER_START@
- * 
- * Copyright (c) 1999-2003 Apple Computer, Inc.  All Rights Reserved.
- * 
  * 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. Please obtain a copy of the License at
- * http://www.opensource.apple.com/apsl/ and read it before using this
- * file.
- * 
+ * 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,
  * 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_LICENSE_HEADER_END@
+ *
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
  */
 /*
- * @OSF_COPYRIGHT@
+ * NOTICE: This file was modified by McAfee Research in 2004 to introduce
+ * support for mandatory and extensible security protections.  This notice
+ * is included in support of clause 2.2 (b) of the Apple Public License,
+ * Version 2.0.
  */
 /*
  * HISTORY
- * 
- * Revision 1.1.1.1  1998/09/22 21:05:51  wsanchez
- * Import of Mac OS X kernel (~semeria)
- *
- * Revision 1.1.1.1  1998/03/07 02:25:35  wsanchez
- * Import of OSF Mach kernel (~mburg)
- *
- * Revision 1.1.4.1  1997/02/21  15:43:21  barbou
- *     Removed "size_t" definition, include "types.h" instead.
- *     [1997/02/21  15:36:54  barbou]
- *
- * Revision 1.1.2.4  1996/10/10  14:13:33  emcmanus
- *     Added memmove() prototype.
- *     [1996/10/10  14:11:51  emcmanus]
- * 
- * Revision 1.1.2.3  1996/10/07  07:20:26  paire
- *     Added strncat() prototype, since it is defined in libsa_mach.
- *     [96/10/07            paire]
- * 
- * Revision 1.1.2.2  1996/10/04  11:36:07  emcmanus
- *     Added strspn() prototype, since it is defined in libsa_mach.
- *     [1996/10/04  11:31:57  emcmanus]
- * 
- * Revision 1.1.2.1  1996/09/17  16:56:15  bruel
- *     created for standalone mach servers.
- *     [96/09/17            bruel]
- * 
- * $EndLog$
+ * @OSF_COPYRIGHT@
  */
-
-#ifndef        _MACH_STRING_H_
-#define        _MACH_STRING_H_ 1
+#ifndef _STRING_H_
+#define _STRING_H_      1
 
 #ifdef MACH_KERNEL_PRIVATE
 #include <types.h>
 #include <sys/types.h>
 #endif
 
+#if defined(KERNEL)
+#include <sys/cdefs.h>
+#endif
+
 #ifdef __cplusplus
 extern "C" {
 #endif
 
-#ifndef        NULL
-#define NULL   0
+#ifndef NULL
+#if defined (__cplusplus)
+#if __cplusplus >= 201103L
+#define NULL nullptr
+#else
+#define NULL 0
+#endif
+#else
+#define NULL ((void *)0)
+#endif
+#endif
+
+extern void     *memcpy(void *, const void *, size_t);
+extern int      memcmp(const void *, const void *, size_t);
+extern void     *memmove(void *, const void *, size_t);
+extern void     *memset(void *, int, size_t);
+extern int      memset_s(void *, size_t, int, size_t);
+
+#ifdef XNU_KERNEL_PRIVATE
+/* memcmp_zero_ptr_aligned() checks string s of n bytes contains all zeros.
+ * Address and size of the string s must be pointer-aligned.
+ * Return 0 if true, 1 otherwise. Also return 0 if n is 0.
+ */
+extern unsigned long memcmp_zero_ptr_aligned(const void *s, size_t n);
+#endif
+
+extern size_t   strlen(const char *);
+extern size_t   strnlen(const char *, size_t);
+
+/* strcpy() and strncpy() are deprecated. Please use strlcpy() instead. */
+__kpi_deprecated_arm64_macos_unavailable
+extern char     *strcpy(char *, const char *) __deprecated;
+
+__kpi_deprecated_arm64_macos_unavailable
+extern char     *strncpy(char *, const char *, size_t);
+
+/* strcat() and strncat() are deprecated. Please use strlcat() instead. */
+__kpi_deprecated_arm64_macos_unavailable
+extern char     *strcat(char *, const char *) __deprecated;
+
+__kpi_deprecated_arm64_macos_unavailable
+extern char     *strncat(char *, const char *, size_t);
+
+extern int      strcmp(const char *, const char *);
+extern int      strncmp(const char *, const char *, size_t);
+
+extern size_t   strlcpy(char *, const char *, size_t);
+extern size_t   strlcat(char *, const char *, size_t);
+
+extern int      strcasecmp(const char *s1, const char *s2);
+extern int      strncasecmp(const char *s1, const char *s2, size_t n);
+#ifdef XNU_KERNEL_PRIVATE
+extern const char     *strnstr(const char *s, const char *find, size_t slen);
+#else
+extern char     *strnstr(const char *s, const char *find, size_t slen);
+#endif
+extern char     *strchr(const char *s, int c);
+#ifdef XNU_KERNEL_PRIVATE
+extern char     *strrchr(const char *s, int c);
+#endif
+extern char     *STRDUP(const char *, int);
+extern int      strprefix(const char *s1, const char *s2);
+
+extern int      bcmp(const void *, const void *, size_t);
+extern void     bcopy(const void *, void *, size_t);
+extern void     bzero(void *, size_t);
+extern int      timingsafe_bcmp(const void *b1, const void *b2, size_t n);
+
+#ifdef PRIVATE
+#include <san/memintrinsics.h>
+#endif
+
+#if __has_builtin(__builtin_dynamic_object_size)
+#define XNU_BOS __builtin_dynamic_object_size
+#else
+#define XNU_BOS __builtin_object_size
+#endif
+
+
+/* __nochk_ functions for opting out of type 1 bounds checking */
+__attribute__((always_inline)) static inline void *
+__nochk_memcpy(void *dest, const void *src, size_t len)
+{
+       return __builtin___memcpy_chk(dest, src, len, XNU_BOS(dest, 0));
+}
+__attribute__((always_inline)) static inline void *
+__nochk_memmove(void *dest, const void *src, size_t len)
+{
+       return __builtin___memmove_chk(dest, src, len, XNU_BOS(dest, 0));
+}
+__attribute__((always_inline)) static inline void
+__nochk_bcopy(const void *src, void *dest, size_t len)
+{
+       __builtin___memmove_chk(dest, src, len, XNU_BOS(dest, 0));
+}
+
+#if defined(__MAC_OS_X_VERSION_MIN_REQUIRED) && __MAC_OS_X_VERSION_MIN_REQUIRED < __MAC_10_13
+/* older deployment target */
+#elif defined(KASAN) || (defined (_FORTIFY_SOURCE) && _FORTIFY_SOURCE == 0)
+/* _FORTIFY_SOURCE disabled */
+#else /* _chk macros */
+
+#if defined XNU_KERNEL_PRIVATE || defined(_FORTIFY_SOURCE_STRICT)
+/* Stricter checking is optional for kexts. When type is set to 1, __builtin_object_size
+ * returns the size of the closest surrounding sub-object, which would detect copying past
+ * the end of a struct member. */
+#define BOS_COPY_TYPE 1
+#else
+#define BOS_COPY_TYPE 0
 #endif
 
-extern void    *memcpy(void *, const void *, size_t);
-extern void    *memmove(void *, const void *, size_t);
-extern void    *memset(void *, int, size_t);
+#if __has_builtin(__builtin___memcpy_chk)
+#define memcpy(dest, src, len) __builtin___memcpy_chk(dest, src, len, XNU_BOS(dest, BOS_COPY_TYPE))
+#endif
 
-extern size_t  strlen(const char *);
-extern char    *strcpy(char *, const char *);
-extern char    *strncpy(char *, const char *, size_t);
-extern char    *strcat(char *, const char *);
-extern char    *strncat(char *, const char *, size_t);
-extern int     strcmp(const char *, const char *);
-extern int     strncmp(const char *,const char *, size_t);
-extern char    *strchr(const char *s, int c);
-extern size_t  strspn(const char *, const char *);
+#if __has_builtin(__builtin___memmove_chk)
+#define memmove(dest, src, len) __builtin___memmove_chk(dest, src, len, XNU_BOS(dest, BOS_COPY_TYPE))
+#endif
+
+#if __has_builtin(__builtin___strncpy_chk)
+#define strncpy(dest, src, len) __builtin___strncpy_chk(dest, src, len, XNU_BOS(dest, 1))
+#endif
+
+#if __has_builtin(__builtin___strncat_chk)
+#define strncat(dest, src, len) __builtin___strncat_chk(dest, src, len, XNU_BOS(dest, 1))
+#endif
+
+#if __has_builtin(__builtin___strlcat_chk)
+#define strlcat(dest, src, len) __builtin___strlcat_chk(dest, src, len, XNU_BOS(dest, 1))
+#endif
+
+#if __has_builtin(__builtin___strlcpy_chk)
+#define strlcpy(dest, src, len) __builtin___strlcpy_chk(dest, src, len, XNU_BOS(dest, 1))
+#endif
+
+#if __has_builtin(__builtin___strcpy_chk)
+#define strcpy(dest, src, len) __builtin___strcpy_chk(dest, src, XNU_BOS(dest, 1))
+#endif
+
+#if __has_builtin(__builtin___strcat_chk)
+#define strcat(dest, src) __builtin___strcat_chk(dest, src, XNU_BOS(dest, 1))
+#endif
+
+#if __has_builtin(__builtin___memmove_chk)
+#define bcopy(src, dest, len) __builtin___memmove_chk(dest, src, len, XNU_BOS(dest, BOS_COPY_TYPE))
+#endif
 
+#endif /* _chk macros */
 #ifdef __cplusplus
 }
 #endif
 
-#endif /* _MACH_STRING_H_ */
+#endif  /* _STRING_H_ */