Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(597)

Unified Diff: third_party/android_crazy_linker/src/tests/test_relocated_shared_relro.cpp

Issue 322433006: Fork of the Android NDK crazy linker. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Add a required license header to a cpp module, missing in the original. Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/android_crazy_linker/src/tests/test_relocated_shared_relro.cpp
diff --git a/third_party/android_crazy_linker/src/tests/test_relocated_shared_relro.cpp b/third_party/android_crazy_linker/src/tests/test_relocated_shared_relro.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..14e130f1e8a26dad927c3cd795f2de730cf81ede
--- /dev/null
+++ b/third_party/android_crazy_linker/src/tests/test_relocated_shared_relro.cpp
@@ -0,0 +1,104 @@
+// Copyright (c) 2013 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include <errno.h>
+#include <stdarg.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <sys/socket.h>
+#include <sys/uio.h>
+#include <sys/wait.h>
+#include <unistd.h>
+
+#include <crazy_linker.h>
+
+#include "test_util.h"
+
+#define PARENT_ADDRESS 0x20000000
+#define CHILD_ADDRESS 0x20134000
+
+typedef void (*FunctionPtr)();
+
+int main() {
+
+ if (!crazy_system_can_share_relro()) {
+ fprintf(stderr, "WARNING: Test ignored due to broken kernel!!\n");
+ return 0;
+ }
+
+ crazy_context_t* context = crazy_context_create();
+
+ RelroLibrary foo;
+
+ int pipes[2];
+ if (socketpair(AF_UNIX, SOCK_STREAM, 0, pipes) < 0)
+ Panic("Could not create socket pair: %s", strerror(errno));
+
+ pid_t child = fork();
+ if (child < 0)
+ Panic("Could not fork test program!");
+
+ if (child == 0) {
+ // In the child.
+ crazy_context_set_load_address(context, CHILD_ADDRESS);
+ foo.Init("libfoo_with_relro.so", context);
+
+ printf("Child waiting for foo relro fd\n");
+
+ foo.ReceiveRelroInfo(pipes[0]);
+ foo.UseSharedRelro(context);
+
+ printf("RELRO used in child process\n");
+
+ CheckRelroMaps(1);
+
+ FunctionPtr foo_func;
+ if (!crazy_library_find_symbol(
+ foo.library, "Foo", reinterpret_cast<void**>(&foo_func)))
+ Panic("Could not find 'Foo' in library");
+
+ printf("Calling Foo()\n");
+ (*foo_func)();
+
+ printf("Foo called, exiting\n");
+
+ exit(0);
+
+ } else {
+ // In the parent.
+
+ // Load at fixed address to simplify testing.
+ crazy_context_set_load_address(context, PARENT_ADDRESS);
+ foo.Init("libfoo_with_relro.so", context);
+
+ printf("Library loaded\n");
+
+ printf("Parent enabling foo RELRO sharing\n");
+
+ foo.CreateSharedRelro(context, CHILD_ADDRESS);
+ foo.SendRelroInfo(pipes[1]);
+
+ printf("Relocated RELRO sent to child\n");
+
+ CheckRelroMaps(0);
+
+ printf("Parent waiting for child\n");
+
+ // Wait for child to complete.
+ int status;
+ waitpid(child, &status, 0);
+
+ if (WIFSIGNALED(status))
+ Panic("Child terminated by signal!!\n");
+ else if (WIFEXITED(status)) {
+ int child_status = WEXITSTATUS(status);
+ if (child_status != 0)
+ Panic("Child terminated with status=%d\n", child_status);
+ } else
+ Panic("Child exited for unknown reason!!\n");
+ }
+
+ crazy_context_destroy(context);
+ return 0;
+}

Powered by Google App Engine
This is Rietveld 408576698