Blame SOURCES/redhat-lsb-arm.patch

3f3c6f
--- redhat-lsb-3.2.orig/redhat_lsb_trigger.c	2008-04-16 13:50:14.000000000 -0400
3f3c6f
+++ redhat-lsb-3.2/redhat_lsb_trigger.c	2009-02-03 04:39:06.000000000 -0500
3f3c6f
@@ -223,6 +223,42 @@ register void *__thread_self __asm ("g7"
3f3c6f
 # define ASMFMT_1 , "0" (gpr2)
3f3c6f
 # define ASMFMT_2 , "0" (gpr2), "d" (gpr3)
3f3c6f
 # define ASMFMT_3 , "0" (gpr2), "d" (gpr3), "d" (gpr4)
3f3c6f
+#elif defined __arm__
3f3c6f
+# if defined (__ARM_EABI__)
3f3c6f
+#undef INTERNAL_SYSCALL_DECL
3f3c6f
+#define INTERNAL_SYSCALL_DECL(err) do { } while (0)
3f3c6f
+#undef INTERNAL_SYSCALL_RAW
3f3c6f
+#define INTERNAL_SYSCALL_RAW(name, err, nr, args...)		\
3f3c6f
+  ({								\
3f3c6f
+       register int _a1 asm ("r0"), _nr asm ("r7");		\
3f3c6f
+       LOAD_ARGS_##nr (args)					\
3f3c6f
+       _nr = name;						\
3f3c6f
+       asm volatile ("swi	0x0	@ syscall " #name	\
3f3c6f
+		     : "=r" (_a1)				\
3f3c6f
+		     : "r" (_nr) ASM_ARGS_##nr			\
3f3c6f
+		     : "memory");				\
3f3c6f
+       _a1; })
3f3c6f
+
3f3c6f
+#undef INTERNAL_SYSCALL
3f3c6f
+#define INTERNAL_SYSCALL(name, err, nr, args...)		\
3f3c6f
+	INTERNAL_SYSCALL_RAW(SYS_ify(name), err, nr, args)
3f3c6f
+
3f3c6f
+#define LOAD_ARGS_0()
3f3c6f
+#define ASM_ARGS_0
3f3c6f
+#define LOAD_ARGS_1(a1)				\
3f3c6f
+  int _a1tmp = (int) (a1);			\
3f3c6f
+  LOAD_ARGS_0 ()				\
3f3c6f
+  _a1 = _a1tmp;
3f3c6f
+#define ASM_ARGS_1	ASM_ARGS_0, "r" (_a1)
3f3c6f
+#define LOAD_ARGS_2(a1, a2)			\
3f3c6f
+  int _a2tmp = (int) (a2);			\
3f3c6f
+  LOAD_ARGS_1 (a1)				\
3f3c6f
+  register int _a2 asm ("a2") = _a2tmp;
3f3c6f
+#define ASM_ARGS_2	ASM_ARGS_1, "r" (_a2)
3f3c6f
+#undef SYS_ify
3f3c6f
+#define SWI_BASE  (0x900000)
3f3c6f
+#define SYS_ify(syscall_name)	(__NR_##syscall_name)
3f3c6f
+#endif
3f3c6f
 #elif defined __sparc__
3f3c6f
 # ifndef __arch64__
3f3c6f
 #  define __INTERNAL_SYSCALL_STRING					\