122 lines
4.5 KiB
Diff
122 lines
4.5 KiB
Diff
|
diff -Nur libaio-0.3.106/src/libaio.h libaio-0.3.106-avr32/src/libaio.h
|
||
|
--- libaio-0.3.106/src/libaio.h 2007-11-27 11:07:20.000000000 +0100
|
||
|
+++ libaio-0.3.106-avr32/src/libaio.h 2007-06-21 15:26:26.000000000 +0200
|
||
|
@@ -106,6 +106,10 @@
|
||
|
# else
|
||
|
# error "neither mipseb nor mipsel?"
|
||
|
# endif
|
||
|
+#elif defined(__avr32__) /* big endian, 32 bits */
|
||
|
+#define PADDED(x, y) unsigned y; x
|
||
|
+#define PADDEDptr(x, y) unsigned y; x
|
||
|
+#define PADDEDul(x, y) unsigned y; unsigned long x;
|
||
|
#else
|
||
|
#error endian?
|
||
|
#endif
|
||
|
diff -Nur libaio-0.3.106/src/syscall-avr32.h libaio-0.3.106-avr32/src/syscall-avr32.h
|
||
|
--- libaio-0.3.106/src/syscall-avr32.h 1970-01-01 01:00:00.000000000 +0100
|
||
|
+++ libaio-0.3.106-avr32/src/syscall-avr32.h 2007-06-21 15:26:26.000000000 +0200
|
||
|
@@ -0,0 +1,91 @@
|
||
|
+/*
|
||
|
+ * Copyright (C) 2007 Atmel Corporation
|
||
|
+ *
|
||
|
+ * This program is free software; you can redistribute it and/or modify
|
||
|
+ * it under the terms of the GNU General Public License version 2 as
|
||
|
+ * published by the Free Software Foundation.
|
||
|
+ */
|
||
|
+
|
||
|
+#define __NR_io_setup 197
|
||
|
+#define __NR_io_destroy 198
|
||
|
+#define __NR_io_getevents 199
|
||
|
+#define __NR_io_submit 200
|
||
|
+#define __NR_io_cancel 201
|
||
|
+
|
||
|
+#define io_syscall1(type,fname,sname,type1,arg1) \
|
||
|
+type fname(type1 arg1) \
|
||
|
+{ \
|
||
|
+ register long __r12 __asm__("r12") = (long)arg1; \
|
||
|
+ register long __res_r12 __asm__("r12"); \
|
||
|
+ register long __scno __asm__("r8") = __NR_##sname; \
|
||
|
+ __asm__ __volatile__("scall" \
|
||
|
+ : "=r"(__res_r12) \
|
||
|
+ : "0"(__r12), "r"(__scno) \
|
||
|
+ : "memory"); \
|
||
|
+ return (type) __res_r12; \
|
||
|
+}
|
||
|
+
|
||
|
+#define io_syscall2(type,fname,sname,type1,arg1,type2,arg2) \
|
||
|
+type fname(type1 arg1, type2 arg2) \
|
||
|
+{ \
|
||
|
+ register long __r12 __asm__("r12") = (long)arg1; \
|
||
|
+ register long __r11 __asm__("r11") = (long)arg2; \
|
||
|
+ register long __res_r12 __asm__("r12"); \
|
||
|
+ register long __scno __asm__("r8") = __NR_##sname; \
|
||
|
+ __asm__ __volatile__("scall" \
|
||
|
+ : "=r"(__res_r12) \
|
||
|
+ : "0"(__r12), "r"(__r11), "r"(__scno) \
|
||
|
+ : "memory"); \
|
||
|
+ return (type) __res_r12; \
|
||
|
+}
|
||
|
+
|
||
|
+#define io_syscall3(type,fname,sname,type1,arg1,type2,arg2,type3,arg3) \
|
||
|
+type fname(type1 arg1, type2 arg2, type3 arg3) \
|
||
|
+{ \
|
||
|
+ register long __r12 __asm__("r12") = (long)arg1; \
|
||
|
+ register long __r11 __asm__("r11") = (long)arg2; \
|
||
|
+ register long __r10 __asm__("r10") = (long)arg3; \
|
||
|
+ register long __res_r12 __asm__("r12"); \
|
||
|
+ register long __scno __asm__("r8") = __NR_##sname; \
|
||
|
+ __asm__ __volatile__("scall" \
|
||
|
+ : "=r"(__res_r12) \
|
||
|
+ : "0"(__r12), "r"(__r11), "r"(__r10), \
|
||
|
+ "r"(__scno) \
|
||
|
+ : "memory"); \
|
||
|
+ return (type) __res_r12; \
|
||
|
+}
|
||
|
+
|
||
|
+#define io_syscall4(type,fname,sname,type1,arg1,type2,arg2,type3,arg3,type4,arg4) \
|
||
|
+type fname(type1 arg1, type2 arg2, type3 arg3, type4 arg4) \
|
||
|
+{ \
|
||
|
+ register long __r12 __asm__("r12") = (long)arg1; \
|
||
|
+ register long __r11 __asm__("r11") = (long)arg2; \
|
||
|
+ register long __r10 __asm__("r10") = (long)arg3; \
|
||
|
+ register long __r9 __asm__("r9") = (long)arg4; \
|
||
|
+ register long __res_r12 __asm__("r12"); \
|
||
|
+ register long __scno __asm__("r8") = __NR_##sname; \
|
||
|
+ __asm__ __volatile__("scall" \
|
||
|
+ : "=r"(__res_r12) \
|
||
|
+ : "0"(__r12), "r"(__r11), "r"(__r10), \
|
||
|
+ "r"(__r9), "r"(__scno) \
|
||
|
+ : "memory"); \
|
||
|
+ return (type) __res_r12; \
|
||
|
+}
|
||
|
+
|
||
|
+#define io_syscall5(type,fname,sname,type1,arg1,type2,arg2,type3,arg3,type4,arg4,type5,arg5) \
|
||
|
+type fname(type1 arg1, type2 arg2, type3 arg3, type4 arg4, type5 arg5) \
|
||
|
+{ \
|
||
|
+ register long __r12 __asm__("r12") = (long)arg1; \
|
||
|
+ register long __r11 __asm__("r11") = (long)arg2; \
|
||
|
+ register long __r10 __asm__("r10") = (long)arg3; \
|
||
|
+ register long __r9 __asm__("r9") = (long)arg4; \
|
||
|
+ register long __r5 __asm__("r5") = (long)arg5; \
|
||
|
+ register long __res_r12 __asm__("r12"); \
|
||
|
+ register long __scno __asm__("r8") = __NR_##sname; \
|
||
|
+ __asm__ __volatile__("scall" \
|
||
|
+ : "=r"(__res_r12) \
|
||
|
+ : "0"(__r12), "r"(__r11), "r"(__r10), \
|
||
|
+ "r"(__r9), "r"(__r5), "r"(__scno) \
|
||
|
+ : "memory"); \
|
||
|
+ return (type) __res_r12; \
|
||
|
+}
|
||
|
diff -Nur libaio-0.3.106/src/syscall.h libaio-0.3.106-avr32/src/syscall.h
|
||
|
--- libaio-0.3.106/src/syscall.h 2007-11-27 11:07:20.000000000 +0100
|
||
|
+++ libaio-0.3.106-avr32/src/syscall.h 2007-06-21 15:26:26.000000000 +0200
|
||
|
@@ -32,6 +32,8 @@
|
||
|
#include "syscall-parisc.h"
|
||
|
#elif defined(__mips__)
|
||
|
#include "syscall-mips.h"
|
||
|
+#elif defined(__avr32__)
|
||
|
+#include "syscall-avr32.h"
|
||
|
#else
|
||
|
#error "add syscall-arch.h"
|
||
|
#endif
|