tools/perf/build: Clean up various testcases
authorIngo Molnar <mingo@kernel.org>
Wed, 2 Oct 2013 13:48:49 +0000 (15:48 +0200)
committerIngo Molnar <mingo@kernel.org>
Wed, 9 Oct 2013 06:48:58 +0000 (08:48 +0200)
Prepare to include them into test-all.c directly, by making sure
that they build cleanly and without warnings.

Also make sure they make a certain amount of sense and don't crash
when executed.

Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: David Ahern <dsahern@gmail.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Link: http://lkml.kernel.org/n/tip-Mn9gsdutzopoowk3xurqpsxE@git.kernel.org
Signed-off-by: Ingo Molnar <mingo@kernel.org>
tools/perf/config/feature-checks/test-backtrace.c
tools/perf/config/feature-checks/test-cplus-demangle.c
tools/perf/config/feature-checks/test-gtk2-infobar.c
tools/perf/config/feature-checks/test-gtk2.c
tools/perf/config/feature-checks/test-libaudit.c
tools/perf/config/feature-checks/test-libbfd.c
tools/perf/config/feature-checks/test-libunwind.c
tools/perf/config/feature-checks/test-on-exit.c

index 5b79468bea2a6685bb7935e0e488d1c6aebf3f59..5b33bcf12c27d064128d1f3ab56314132af6a713 100644 (file)
@@ -3,8 +3,12 @@
 
 int main(void)
 {
-       backtrace(NULL, 0);
-       backtrace_symbols(NULL, 0);
+       void *backtrace_fns[10];
+       size_t entries;
+
+       entries = backtrace(backtrace_fns, 10);
+       backtrace_symbols_fd(backtrace_fns, entries, 1);
 
        return 0;
 }
+
index 5202f5038ad8cb37ef68254b972036a8dc26174f..ab29f80570afd697d7c64884c5eddbc5d00ecf2a 100644 (file)
@@ -1,9 +1,14 @@
-
+extern int printf(const char *format, ...);
 extern char *cplus_demangle(const char *, int);
 
 int main(void)
 {
-       cplus_demangle(0, 0);
+       char symbol[4096] = "FieldName__9ClassNameFd";
+       char *tmp;
+
+       tmp = cplus_demangle(symbol, 0);
+
+       printf("demangled symbol: {%s}\n", tmp);
 
        return 0;
 }
index eebcfbc45120a050c52acb911a08900d687b5e89..397b4646d066144d1db1f6bd2842b9f1af5bf617 100644 (file)
@@ -2,8 +2,9 @@
 #include <gtk/gtk.h>
 #pragma GCC diagnostic error "-Wstrict-prototypes"
 
-int main(void)
+int main(int argc, char *argv[])
 {
+       gtk_init(&argc, &argv);
        gtk_info_bar_new();
 
        return 0;
index 1ac6d8a1fb149a1a75c13aaf38964398c12fea29..6bd80e5094391f10e03abeb24d6c02953ba74a2c 100644 (file)
@@ -4,7 +4,7 @@
 
 int main(int argc, char *argv[])
 {
-        gtk_init(&argc, &argv);
+       gtk_init(&argc, &argv);
 
         return 0;
 }
index 854a65d3cc780cce11ffbd40da87c2c78473877d..f7e791efa6d100762d80b60241c98ab0cff0b07b 100644 (file)
@@ -1,5 +1,7 @@
 #include <libaudit.h>
 
+extern int printf(const char *format, ...);
+
 int main(void)
 {
        printf("error message: %s\n", audit_errno_to_name(0));
index d03339c995d768207fc0bbe09be4ee6662ed5bd2..1886c78c30e742226fff19203405dff5eca6d4ca 100644 (file)
@@ -1,7 +1,16 @@
 #include <bfd.h>
 
+extern int printf(const char *format, ...);
+
 int main(void)
 {
-       bfd_demangle(0, 0, 0);
+       char symbol[4096] = "FieldName__9ClassNameFd";
+       char *tmp;
+
+       tmp = bfd_demangle(0, symbol, 0);
+
+       printf("demangled symbol: {%s}\n", tmp);
+
        return 0;
 }
+
index 562274695c7626bbf174248feffa7e528cf59157..43b9369bcab7d03125e19d6f4001080a6b92987f 100644 (file)
@@ -10,11 +10,18 @@ extern int UNW_OBJ(dwarf_search_unwind_table) (unw_addr_space_t as,
 
 #define dwarf_search_unwind_table UNW_OBJ(dwarf_search_unwind_table)
 
+static unw_accessors_t accessors;
+
 int main(void)
 {
        unw_addr_space_t addr_space;
-       addr_space = unw_create_addr_space(NULL, 0);
+
+       addr_space = unw_create_addr_space(&accessors, 0);
+       if (addr_space)
+               return 0;
+
        unw_init_remote(NULL, addr_space, NULL);
        dwarf_search_unwind_table(addr_space, 0, NULL, NULL, 0, NULL);
+
        return 0;
 }
index 473f1dea5316808b94eaa5a16fc23bee6389da49..8f64ed3a58d9aed014500dc4895922229dde4939 100644 (file)
@@ -1,6 +1,15 @@
 #include <stdio.h>
 
+static void exit_fn(int status, void *__data)
+{
+       printf("exit status: %d, data: %d\n", status, *(int *)__data);
+}
+
+static int data = 123;
+
 int main(void)
 {
-       return on_exit(NULL, NULL);
+       on_exit(exit_fn, &data);
+
+       return 321;
 }