summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThe Android Open Source Project <initial-contribution@android.com>2009-02-19 10:57:36 -0800
committerThe Android Open Source Project <initial-contribution@android.com>2009-02-19 10:57:36 -0800
commitd6dd2fcf84a73288fbdc5c207ec28ee877a19c9b (patch)
tree7a3d9880023609bde174f4e54b61e0dab8bbec7b
parentd4ccd3f41f4a68276887e88d4618cc93e221361b (diff)
downloadextras-d6dd2fcf84a73288fbdc5c207ec28ee877a19c9b.tar.gz
auto import from //branches/cupcake/...@132276
-rw-r--r--tests/bionic/libc/Android.mk25
-rw-r--r--tests/bionic/libc/bionic/lib_relocs.c19
-rw-r--r--tests/bionic/libc/bionic/test_relocs.c25
-rw-r--r--tests/bionic/libc/common/hello_world.cpp8
-rw-r--r--tests/bionic/libc/other/test_timer_create2.c100
5 files changed, 177 insertions, 0 deletions
diff --git a/tests/bionic/libc/Android.mk b/tests/bionic/libc/Android.mk
index 14ac0c0c..f9b04fde 100644
--- a/tests/bionic/libc/Android.mk
+++ b/tests/bionic/libc/Android.mk
@@ -105,10 +105,35 @@ sources := \
other/test_system.c \
other/test_thread_max.c \
other/test_timer_create.c \
+ other/test_timer_create2.c \
other/test_vfprintf_leak.c \
$(call device-test, $(sources))
+# The relocations test is a bit special, since we need
+# to build one shared object and one executable that depends
+# on it.
+
+include $(CLEAR_VARS)
+LOCAL_SRC_FILES := bionic/lib_relocs.c
+LOCAL_MODULE := libtest_relocs
+LOCAL_PRELINK_MODULE := false
+include $(BUILD_SHARED_LIBRARY)
+
+include $(CLEAR_VARS)
+LOCAL_SRC_FILES := bionic/test_relocs.c
+LOCAL_MODULE := test_relocs
+LOCAL_SHARED_LIBRARIES := libtest_relocs
+include $(BUILD_EXECUTABLE)
+
# TODO: Add a variety of GLibc test programs too...
+# Hello World to test libstdc++ support
+
+sources := \
+ common/hello_world.cpp \
+
+EXTRA_CFLAGS := -mandroid
+#$(call device-test, $(sources))
+
endif # BIONIC_TESTS
diff --git a/tests/bionic/libc/bionic/lib_relocs.c b/tests/bionic/libc/bionic/lib_relocs.c
new file mode 100644
index 00000000..af4cf6f8
--- /dev/null
+++ b/tests/bionic/libc/bionic/lib_relocs.c
@@ -0,0 +1,19 @@
+/* this is part of the test_relocs.c test, which is used to check that
+ * the relocations generated in a shared object are properly handled
+ * by the Bionic dynamic linker
+ */
+
+struct foo { int first, second; };
+struct foo Foo = {1, 2};
+
+int* FooPtr[] = { &Foo.first, &Foo.second };
+
+int func1( void )
+{
+ return *FooPtr[0];
+}
+
+int func2( void )
+{
+ return *FooPtr[1];
+}
diff --git a/tests/bionic/libc/bionic/test_relocs.c b/tests/bionic/libc/bionic/test_relocs.c
new file mode 100644
index 00000000..c42df116
--- /dev/null
+++ b/tests/bionic/libc/bionic/test_relocs.c
@@ -0,0 +1,25 @@
+/* this little test is written to check that the relocations generated
+ * in a shared library are correct. it depends on the content of lib_relocs.c
+ * being compiled as a shared object.
+ */
+#include <stdio.h>
+
+extern int func1(void);
+extern int func2(void);
+
+int
+main( void )
+{
+ int f1, f2, expect1 = 1, expect2 = 2;
+
+ f1 = func1();
+ f2 = func2();
+
+ printf( "func1() returns %d: %s\n", f1, (f1 == expect1) ? "OK" : "FAIL" );
+ printf( "func2() returns %d: %s\n", f2, (f2 == expect2) ? "OK" : "FAIL" );
+
+ if (f1 != expect1 || f2 != expect2)
+ return 1;
+
+ return 0;
+}
diff --git a/tests/bionic/libc/common/hello_world.cpp b/tests/bionic/libc/common/hello_world.cpp
new file mode 100644
index 00000000..0578d7d8
--- /dev/null
+++ b/tests/bionic/libc/common/hello_world.cpp
@@ -0,0 +1,8 @@
+#include <iostream>
+using namespace std;
+
+int main()
+{
+ cout << "Hello World" << endl;
+ return 0;
+}
diff --git a/tests/bionic/libc/other/test_timer_create2.c b/tests/bionic/libc/other/test_timer_create2.c
new file mode 100644
index 00000000..10e95e4e
--- /dev/null
+++ b/tests/bionic/libc/other/test_timer_create2.c
@@ -0,0 +1,100 @@
+/*
+ * Copyright (C) 2008 The Android Open Source Project
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in
+ * the documentation and/or other materials provided with the
+ * distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
+ * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+ * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+#include <stdio.h>
+#include <time.h>
+#include <signal.h>
+#include <pthread.h>
+#include <string.h>
+#include <unistd.h>
+
+void
+handle(int v)
+{
+ time_t t;
+ char p[32];
+
+ time(&t);
+ strftime(p, sizeof(p), "%T", localtime(&t));
+ printf("%s thread %p, val = %d, signal captured.\n",
+ p, pthread_self(), v);
+ return;
+}
+
+int
+create(int seconds, int id)
+{
+ timer_t tid;
+ struct sigevent se;
+ struct itimerspec ts, ots;
+
+ memset(&se, 0, sizeof (se));
+ se.sigev_notify = SIGEV_SIGNAL;
+ se.sigev_signo = SIGUSR1;
+
+ if (timer_create (CLOCK_REALTIME, &se, &tid) < 0)
+ {
+ perror ("timer_creat");
+ return -1;
+ }
+ printf("timer_create successfully = %d.\n", (int)tid);
+ ts.it_value.tv_sec = 3;
+ ts.it_value.tv_nsec = 0;
+ ts.it_interval.tv_sec = seconds;
+ ts.it_interval.tv_nsec = 0;
+ if (timer_settime (tid, TIMER_ABSTIME, &ts, &ots) < 0)
+ {
+ perror ("timer_settime");
+ return -1;
+ }
+ return 0;
+}
+
+int
+main (void)
+{
+ sigset_t mask[1];
+ struct sigaction act[1];
+
+ sigemptyset(mask);
+ sigaddset(mask, SIGUSR1);
+ sigprocmask(SIG_UNBLOCK,mask,NULL);
+
+ memset(act, 0, sizeof(*act));
+ act->sa_handler = handle;
+ sigaction( SIGUSR1, act, NULL );
+
+ printf("main thread is %p\n", pthread_self());
+
+ if (create (3, 1) < 0) return 1;
+ if (create (5, 2) < 0) return 1;
+ for (;;)
+ {
+ sleep (10);
+ }
+ return 0;
+}