summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAutomerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>2020-02-03 19:13:58 +0000
committerAutomerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>2020-02-03 19:13:58 +0000
commite3f939e4a321b8c07d5d1149bf7dd29efe34b88b (patch)
tree2cca7f6783582c75f0bed794ae2e8f4b65368021
parent3f592af72905540ad78b2655707b515a7febc06e (diff)
parent6dc0cc21fea69df79f50daf62fb1376fe1db0652 (diff)
downloadextras-e3f939e4a321b8c07d5d1149bf7dd29efe34b88b.tar.gz
Wrap getenv and append euid to GCOV_PREFIX am: 6dc0cc21fe
Change-Id: I9b5c1db209c3aed9aafd5015108679e8be41392e
-rw-r--r--toolchain-extras/Android.bp5
-rw-r--r--toolchain-extras/profile-globals.c42
2 files changed, 47 insertions, 0 deletions
diff --git a/toolchain-extras/Android.bp b/toolchain-extras/Android.bp
index 727f9795..5c839a1e 100644
--- a/toolchain-extras/Android.bp
+++ b/toolchain-extras/Android.bp
@@ -2,6 +2,7 @@ cc_defaults {
name: "libprofile-defaults",
srcs: [
"profile-extras.cpp",
+ "profile-globals.c",
],
native_coverage: false,
}
@@ -24,6 +25,10 @@ cc_library_static {
cc_library_static {
name: "libprofile-extras_ndk",
defaults: ["libprofile-defaults",],
+ vendor_available: true,
+ vndk: {
+ enabled: true,
+ },
sdk_version: "minimum",
}
diff --git a/toolchain-extras/profile-globals.c b/toolchain-extras/profile-globals.c
new file mode 100644
index 00000000..95bd46dd
--- /dev/null
+++ b/toolchain-extras/profile-globals.c
@@ -0,0 +1,42 @@
+/*
+ * Copyright (C) 2019 The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+#include <sys/types.h>
+
+// This file provides a wrapper for getenv that appends the userid (geteuid())
+// of the current process to GCOV_PREFIX. This avoids conflicts and permissions
+// issues when different processes try to create/access the same directories and
+// files under $GCOV_PREFIX.
+//
+// When this file is linked to a binary, the -Wl,--wrap,getenv flag must be
+// used. The linker redirects calls to getenv to __wrap_getenv and sets
+// __real_getenv to point to libc's getenv.
+
+char *__real_getenv(const char *name);
+
+static char modified_gcov_prefix[128];
+
+__attribute__((weak)) char *__wrap_getenv(const char *name) {
+ if (strcmp(name, "GCOV_PREFIX") != 0) {
+ return __real_getenv(name);
+ }
+
+ sprintf(modified_gcov_prefix, "%s/%u", __real_getenv(name), geteuid());
+ return modified_gcov_prefix;
+}