summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlexey Samsonov <samsonov@google.com>2012-06-08 14:11:12 +0000
committerAlexey Samsonov <samsonov@google.com>2012-06-08 14:11:12 +0000
commit59036d2c06f7a88a68fb3eeadb2e315b5bb0cef2 (patch)
tree5def88e56dad73a442338aa5195f3d685805947f
parent99d58521c5924cb498f079e87af4f63eda758d13 (diff)
downloadbcm5719-llvm-59036d2c06f7a88a68fb3eeadb2e315b5bb0cef2.tar.gz
bcm5719-llvm-59036d2c06f7a88a68fb3eeadb2e315b5bb0cef2.zip
[Sanitizer] add internal_memset and internal_strrchr to sanitizer_common/
llvm-svn: 158202
-rw-r--r--compiler-rt/lib/asan/asan_interceptors.cc13
-rw-r--r--compiler-rt/lib/asan/asan_interceptors.h1
-rw-r--r--compiler-rt/lib/sanitizer_common/sanitizer_libc.cc20
-rw-r--r--compiler-rt/lib/sanitizer_common/sanitizer_libc.h3
-rw-r--r--compiler-rt/lib/tsan/rtl/tsan_defs.h1
-rw-r--r--compiler-rt/lib/tsan/rtl/tsan_interceptors.cc4
6 files changed, 23 insertions, 19 deletions
diff --git a/compiler-rt/lib/asan/asan_interceptors.cc b/compiler-rt/lib/asan/asan_interceptors.cc
index 3ffb5593274..b35cc6bcff5 100644
--- a/compiler-rt/lib/asan/asan_interceptors.cc
+++ b/compiler-rt/lib/asan/asan_interceptors.cc
@@ -251,19 +251,6 @@ int internal_memcmp(const void* s1, const void* s2, uptr n) {
return 0;
}
-// Should not be used in performance-critical places.
-void* internal_memset(void* s, int c, uptr n) {
- // The next line prevents Clang from making a call to memset() instead of the
- // loop below.
- // FIXME: building the runtime with -ffreestanding is a better idea. However
- // there currently are linktime problems due to PR12396.
- char volatile *t = (char*)s;
- for (uptr i = 0; i < n; ++i, ++t) {
- *t = c;
- }
- return s;
-}
-
char *internal_strstr(const char *haystack, const char *needle) {
// This is O(N^2), but we are not using it in hot places.
uptr len1 = internal_strlen(haystack);
diff --git a/compiler-rt/lib/asan/asan_interceptors.h b/compiler-rt/lib/asan/asan_interceptors.h
index e0dab6a07bf..d89e7f68331 100644
--- a/compiler-rt/lib/asan/asan_interceptors.h
+++ b/compiler-rt/lib/asan/asan_interceptors.h
@@ -34,7 +34,6 @@ namespace __asan {
s64 internal_atoll(const char *nptr);
uptr internal_strnlen(const char *s, uptr maxlen);
char* internal_strchr(const char *s, int c);
-void* internal_memset(void *s, int c, uptr n);
int internal_memcmp(const void* s1, const void* s2, uptr n);
char *internal_strstr(const char *haystack, const char *needle);
char *internal_strncat(char *dst, const char *src, uptr n);
diff --git a/compiler-rt/lib/sanitizer_common/sanitizer_libc.cc b/compiler-rt/lib/sanitizer_common/sanitizer_libc.cc
index 6de28c62dfd..3049990a74d 100644
--- a/compiler-rt/lib/sanitizer_common/sanitizer_libc.cc
+++ b/compiler-rt/lib/sanitizer_common/sanitizer_libc.cc
@@ -34,6 +34,18 @@ void *internal_memcpy(void *dest, const void *src, uptr n) {
return dest;
}
+void *internal_memset(void* s, int c, uptr n) {
+ // The next line prevents Clang from making a call to memset() instead of the
+ // loop below.
+ // FIXME: building the runtime with -ffreestanding is a better idea. However
+ // there currently are linktime problems due to PR12396.
+ char volatile *t = (char*)s;
+ for (uptr i = 0; i < n; ++i, ++t) {
+ *t = c;
+ }
+ return s;
+}
+
char* internal_strdup(const char *s) {
uptr len = internal_strlen(s);
char *s2 = (char*)InternalAlloc(len + 1);
@@ -54,6 +66,14 @@ int internal_strcmp(const char *s1, const char *s2) {
return 0;
}
+char *internal_strrchr(const char *s, int c) {
+ const char *res = 0;
+ for (uptr i = 0; s[i]; i++) {
+ if (s[i] == c) res = s + i;
+ }
+ return (char*)res;
+}
+
uptr internal_strlen(const char *s) {
uptr i = 0;
while (s[i]) i++;
diff --git a/compiler-rt/lib/sanitizer_common/sanitizer_libc.h b/compiler-rt/lib/sanitizer_common/sanitizer_libc.h
index cf956f8e2c8..1accc1b543a 100644
--- a/compiler-rt/lib/sanitizer_common/sanitizer_libc.h
+++ b/compiler-rt/lib/sanitizer_common/sanitizer_libc.h
@@ -26,10 +26,13 @@ void MiniLibcStub();
// String functions
void *internal_memchr(const void *s, int c, uptr n);
void *internal_memcpy(void *dest, const void *src, uptr n);
+// Should not be used in performance-critical places.
+void *internal_memset(void *s, int c, uptr n);
int internal_strcmp(const char *s1, const char *s2);
char *internal_strdup(const char *s);
uptr internal_strlen(const char *s);
char *internal_strncpy(char *dst, const char *src, uptr n);
+char *internal_strrchr(const char *s, int c);
// Memory
void *internal_mmap(void *addr, uptr length, int prot, int flags,
diff --git a/compiler-rt/lib/tsan/rtl/tsan_defs.h b/compiler-rt/lib/tsan/rtl/tsan_defs.h
index 5a873d86d02..d2a5ce7d813 100644
--- a/compiler-rt/lib/tsan/rtl/tsan_defs.h
+++ b/compiler-rt/lib/tsan/rtl/tsan_defs.h
@@ -140,7 +140,6 @@ int internal_strncmp(const char *s1, const char *s2, uptr size);
void internal_strcpy(char *s1, const char *s2);
const char *internal_strstr(const char *where, const char *what);
const char *internal_strchr(const char *where, char what);
-const char *internal_strrchr(const char *where, char what);
struct MD5Hash {
u64 hash[2];
diff --git a/compiler-rt/lib/tsan/rtl/tsan_interceptors.cc b/compiler-rt/lib/tsan/rtl/tsan_interceptors.cc
index 95ac1041c2b..9114e76ea65 100644
--- a/compiler-rt/lib/tsan/rtl/tsan_interceptors.cc
+++ b/compiler-rt/lib/tsan/rtl/tsan_interceptors.cc
@@ -1545,10 +1545,6 @@ const char *internal_strchr(const char *where, char what) {
return (const char*)REAL(strchr)((void*)where, what);
}
-const char *internal_strrchr(const char *where, char what) {
- return (const char*)REAL(strrchr)((void*)where, what);
-}
-
void internal_start_thread(void(*func)(void *arg), void *arg) {
void *th;
REAL(pthread_create)(&th, 0, (void*(*)(void *arg))func, arg);
OpenPOWER on IntegriCloud