sanitizer_libc.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. //===-- sanitizer_libc.h ----------------------------------------*- C++ -*-===//
  2. //
  3. // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
  4. // See https://llvm.org/LICENSE.txt for license information.
  5. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  6. //
  7. //===----------------------------------------------------------------------===//
  8. //
  9. // This file is shared between AddressSanitizer and ThreadSanitizer
  10. // run-time libraries.
  11. // These tools can not use some of the libc functions directly because those
  12. // functions are intercepted. Instead, we implement a tiny subset of libc here.
  13. // FIXME: Some of functions declared in this file are in fact POSIX, not libc.
  14. //===----------------------------------------------------------------------===//
  15. #ifndef SANITIZER_LIBC_H
  16. #define SANITIZER_LIBC_H
  17. // ----------- ATTENTION -------------
  18. // This header should NOT include any other headers from sanitizer runtime.
  19. #include "sanitizer_internal_defs.h"
  20. namespace __sanitizer {
  21. // internal_X() is a custom implementation of X() for use in RTL.
  22. extern "C" {
  23. // These are used as builtin replacements; see sanitizer_redefine_builtins.h.
  24. // In normal runtime code, use the __sanitizer::internal_X() aliases instead.
  25. SANITIZER_INTERFACE_ATTRIBUTE void *__sanitizer_internal_memcpy(void *dest,
  26. const void *src,
  27. uptr n);
  28. SANITIZER_INTERFACE_ATTRIBUTE void *__sanitizer_internal_memmove(
  29. void *dest, const void *src, uptr n);
  30. SANITIZER_INTERFACE_ATTRIBUTE void *__sanitizer_internal_memset(void *s, int c,
  31. uptr n);
  32. } // extern "C"
  33. // String functions
  34. s64 internal_atoll(const char *nptr);
  35. void *internal_memchr(const void *s, int c, uptr n);
  36. void *internal_memrchr(const void *s, int c, uptr n);
  37. int internal_memcmp(const void* s1, const void* s2, uptr n);
  38. ALWAYS_INLINE void *internal_memcpy(void *dest, const void *src, uptr n) {
  39. return __sanitizer_internal_memcpy(dest, src, n);
  40. }
  41. ALWAYS_INLINE void *internal_memmove(void *dest, const void *src, uptr n) {
  42. return __sanitizer_internal_memmove(dest, src, n);
  43. }
  44. // Should not be used in performance-critical places.
  45. ALWAYS_INLINE void *internal_memset(void *s, int c, uptr n) {
  46. return __sanitizer_internal_memset(s, c, n);
  47. }
  48. char* internal_strchr(const char *s, int c);
  49. char *internal_strchrnul(const char *s, int c);
  50. int internal_strcmp(const char *s1, const char *s2);
  51. uptr internal_strcspn(const char *s, const char *reject);
  52. char *internal_strdup(const char *s);
  53. uptr internal_strlen(const char *s);
  54. uptr internal_strlcat(char *dst, const char *src, uptr maxlen);
  55. char *internal_strncat(char *dst, const char *src, uptr n);
  56. int internal_strncmp(const char *s1, const char *s2, uptr n);
  57. uptr internal_strlcpy(char *dst, const char *src, uptr maxlen);
  58. char *internal_strncpy(char *dst, const char *src, uptr n);
  59. uptr internal_strnlen(const char *s, uptr maxlen);
  60. char *internal_strrchr(const char *s, int c);
  61. char *internal_strstr(const char *haystack, const char *needle);
  62. // Works only for base=10 and doesn't set errno.
  63. s64 internal_simple_strtoll(const char *nptr, const char **endptr, int base);
  64. int internal_snprintf(char *buffer, uptr length, const char *format, ...)
  65. FORMAT(3, 4);
  66. uptr internal_wcslen(const wchar_t *s);
  67. uptr internal_wcsnlen(const wchar_t *s, uptr maxlen);
  68. wchar_t *internal_wcscpy(wchar_t *dst, const wchar_t *src);
  69. wchar_t *internal_wcsncpy(wchar_t *dst, const wchar_t *src, uptr maxlen);
  70. // Return true if all bytes in [mem, mem+size) are zero.
  71. // Optimized for the case when the result is true.
  72. bool mem_is_zero(const char *mem, uptr size);
  73. // I/O
  74. // Define these as macros so we can use them in linker initialized global
  75. // structs without dynamic initialization.
  76. #define kInvalidFd ((fd_t)-1)
  77. #define kStdinFd ((fd_t)0)
  78. #define kStdoutFd ((fd_t)1)
  79. #define kStderrFd ((fd_t)2)
  80. uptr internal_ftruncate(fd_t fd, uptr size);
  81. // OS
  82. void NORETURN internal__exit(int exitcode);
  83. void internal_sleep(unsigned seconds);
  84. void internal_usleep(u64 useconds);
  85. uptr internal_getpid();
  86. uptr internal_getppid();
  87. int internal_dlinfo(void *handle, int request, void *p);
  88. // Threading
  89. uptr internal_sched_yield();
  90. // Error handling
  91. bool internal_iserror(uptr retval, int *rverrno = nullptr);
  92. } // namespace __sanitizer
  93. #endif // SANITIZER_LIBC_H