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