--- /dev/null
+From 71471cb1d05f3877c8fb935fbf70a6bae789ac49 Mon Sep 17 00:00:00 2001
+From: Jens Axboe <axboe@fb.com>
+Date: Thu, 10 Mar 2016 08:09:41 -0700
+Subject: [PATCH] Fix compile of test programs on archs that use arch_flags at
+ runtime
+
+SuperH compile currently fails with:
+
+gettime.o: In function fio_gettime':
+/home/thomas/projets/buildroot/output/build/fio-fio-2.7/gettime.c:163: undefined reference to arch_flags'
+gettime.o: In function utime_since_now':
+/home/thomas/projets/buildroot/output/build/fio-fio-2.7/gettime.c:164: undefined reference to arch_flags'
+gettime.o: In function mtime_since_now':
+/home/thomas/projets/buildroot/output/build/fio-fio-2.7/gettime.c:164: undefined reference to arch_flags'
+gettime.o: In function time_since_now':
+/home/thomas/projets/buildroot/output/build/fio-fio-2.7/gettime.c:164: undefined reference to arch_flags'
+mutex.o: In function fio_mutex_up':
+/home/thomas/projets/buildroot/output/build/fio-fio-2.7/mutex.c:189: undefined reference to arch_flags'
+collect2: error: ld returned 1 exit status
+Makefile:375: recipe for target 't/stest' failed
+make[2]: *** [t/stest] Error 1
+make[2]: *** Waiting for unfinished jobs....
+
+Fix that by ensuring we have a stub arch.o with the necessary arch flags
+for the standalone test programs.
+
+Signed-off-by: Jens Axboe <axboe@fb.com>
+---
+ Makefile | 6 +++---
+ t/arch.c | 5 +++++
+ t/dedupe.c | 1 +
+ t/lfsr-test.c | 2 ++
+ t/stest.c | 2 ++
+ 5 files changed, 13 insertions(+), 3 deletions(-)
+ create mode 100644 t/arch.c
+
+diff --git a/Makefile b/Makefile
+index 6b4c9db..a2502dc 100644
+--- a/Makefile
++++ b/Makefile
+@@ -191,7 +191,7 @@ endif
+ -include $(OBJS:.o=.d)
+
+ T_SMALLOC_OBJS = t/stest.o
+-T_SMALLOC_OBJS += gettime.o mutex.o smalloc.o t/log.o t/debug.o
++T_SMALLOC_OBJS += gettime.o mutex.o smalloc.o t/log.o t/debug.o t/arch.o
+ T_SMALLOC_PROGS = t/stest
+
+ T_IEEE_OBJS = t/ieee754.o
+@@ -208,7 +208,7 @@ T_AXMAP_OBJS += lib/lfsr.o lib/axmap.o
+ T_AXMAP_PROGS = t/axmap
+
+ T_LFSR_TEST_OBJS = t/lfsr-test.o
+-T_LFSR_TEST_OBJS += lib/lfsr.o gettime.o t/log.o t/debug.o
++T_LFSR_TEST_OBJS += lib/lfsr.o gettime.o t/log.o t/debug.o t/arch.o
+ T_LFSR_TEST_PROGS = t/lfsr-test
+
+ T_GEN_RAND_OBJS = t/gen-rand.o
+@@ -223,7 +223,7 @@ endif
+
+ T_DEDUPE_OBJS = t/dedupe.o
+ T_DEDUPE_OBJS += lib/rbtree.o t/log.o mutex.o smalloc.o gettime.o crc/md5.o \
+- lib/memalign.o lib/bloom.o t/debug.o crc/xxhash.o \
++ lib/memalign.o lib/bloom.o t/debug.o crc/xxhash.o t/arch.o \
+ crc/murmur3.o crc/crc32c.o crc/crc32c-intel.o crc/fnv.o
+ T_DEDUPE_PROGS = t/fio-dedupe
+
+diff --git a/t/arch.c b/t/arch.c
+new file mode 100644
+index 0000000..befb7c7
+--- /dev/null
++++ b/t/arch.c
+@@ -0,0 +1,5 @@
++#include "../arch/arch.h"
++
++unsigned long arch_flags = 0;
++int tsc_reliable;
++int arch_random;
+diff --git a/t/dedupe.c b/t/dedupe.c
+index 3a66820..7856da1 100644
+--- a/t/dedupe.c
++++ b/t/dedupe.c
+@@ -537,6 +537,7 @@ int main(int argc, char *argv[])
+ uint64_t nextents = 0, nchunks = 0;
+ int c, ret;
+
++ arch_init(argv);
+ debug_init();
+
+ while ((c = getopt(argc, argv, "b:t:d:o:c:p:B:")) != -1) {
+diff --git a/t/lfsr-test.c b/t/lfsr-test.c
+index 4352b89..bad5097 100644
+--- a/t/lfsr-test.c
++++ b/t/lfsr-test.c
+@@ -38,6 +38,8 @@ int main(int argc, char *argv[])
+ void *v = NULL, *v_start;
+ double total, mean;
+
++ arch_init(argv);
++
+ /* Read arguments */
+ switch (argc) {
+ case 5: if (strncmp(argv[4], "verify", 7) == 0)
+diff --git a/t/stest.c b/t/stest.c
+index fb51989..0e0d8b0 100644
+--- a/t/stest.c
++++ b/t/stest.c
+@@ -4,6 +4,7 @@
+
+ #include "../smalloc.h"
+ #include "../flist.h"
++#include "../arch/arch.h"
+ #include "debug.h"
+
+ #define MAGIC1 0xa9b1c8d2
+@@ -69,6 +70,7 @@ static int do_specific_alloc(unsigned long size)
+
+ int main(int argc, char *argv[])
+ {
++ arch_init(argv);
+ sinit();
+ debug_init();
+
+--
+2.6.4
+