|  | @@ -106,100 +106,55 @@ return (type) (INLINE_SYSCALL(name, 7, arg1, arg2, arg3, arg4, arg5, arg6, arg7)
 | 
	
		
			
				|  |  |  #define INTERNAL_SYSCALL_DECL(err) do { } while (0)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #undef INTERNAL_SYSCALL
 | 
	
		
			
				|  |  | -#if defined(__ARM_EABI__)
 | 
	
		
			
				|  |  |  #if !defined(__thumb__)
 | 
	
		
			
				|  |  | +#if defined(__ARM_EABI__)
 | 
	
		
			
				|  |  |  #define INTERNAL_SYSCALL(name, err, nr, args...)			\
 | 
	
		
			
				|  |  |    ({unsigned int __sys_result;						\
 | 
	
		
			
				|  |  |       {									\
 | 
	
		
			
				|  |  | -       register int _a1 __asm__ ("r0"), _nr __asm__ ("r7");			\
 | 
	
		
			
				|  |  | +       register int _a1 __asm__ ("r0"), _nr __asm__ ("r7");		\
 | 
	
		
			
				|  |  |         LOAD_ARGS_##nr (args)						\
 | 
	
		
			
				|  |  |         _nr = SYS_ify(name);						\
 | 
	
		
			
				|  |  | -       __asm__ volatile ("swi	0x0	@ syscall " #name		\
 | 
	
		
			
				|  |  | +       __asm__ __volatile__ ("swi	0x0	@ syscall " #name	\
 | 
	
		
			
				|  |  | +			     : "=r" (_a1)				\
 | 
	
		
			
				|  |  | +			     : "r" (_nr) ASM_ARGS_##nr			\
 | 
	
		
			
				|  |  | +			     : "memory");				\
 | 
	
		
			
				|  |  | +	       __sys_result = _a1;					\
 | 
	
		
			
				|  |  | +     }									\
 | 
	
		
			
				|  |  | +     (int) __sys_result; })
 | 
	
		
			
				|  |  | +#else /* defined(__ARM_EABI__) */
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +#define INTERNAL_SYSCALL(name, err, nr, args...)			\
 | 
	
		
			
				|  |  | +  ({ unsigned int __sys_result;						\
 | 
	
		
			
				|  |  | +     {									\
 | 
	
		
			
				|  |  | +       register int _a1 __asm__ ("a1");					\
 | 
	
		
			
				|  |  | +       LOAD_ARGS_##nr (args)						\
 | 
	
		
			
				|  |  | +       __asm__ __volatile__ ("swi	%1	@ syscall " #name	\
 | 
	
		
			
				|  |  |  		     : "=r" (_a1)					\
 | 
	
		
			
				|  |  | -		     : "r" (_nr) ASM_ARGS_##nr				\
 | 
	
		
			
				|  |  | +		     : "i" (SYS_ify(name)) ASM_ARGS_##nr		\
 | 
	
		
			
				|  |  |  		     : "memory");					\
 | 
	
		
			
				|  |  |         __sys_result = _a1;						\
 | 
	
		
			
				|  |  |       }									\
 | 
	
		
			
				|  |  |       (int) __sys_result; })
 | 
	
		
			
				|  |  | +#endif
 | 
	
		
			
				|  |  |  #else /* !defined(__thumb__) */
 | 
	
		
			
				|  |  | -/* So hide the use of r7 from the compiler, this would be a lot
 | 
	
		
			
				|  |  | - * easier but for the fact that the syscalls can exceed 255.
 | 
	
		
			
				|  |  | - * For the moment the LOAD_ARG_7 is sacrificed.
 | 
	
		
			
				|  |  | - */
 | 
	
		
			
				|  |  | -#define INTERNAL_SYSCALL(name, err, nr, args...)                \
 | 
	
		
			
				|  |  | -  ({ unsigned int __sys_result;                                  \
 | 
	
		
			
				|  |  | -    {                                                           \
 | 
	
		
			
				|  |  | -      register int _a1 asm ("a1");                              \
 | 
	
		
			
				|  |  | -      LOAD_ARGS_##nr (args)                                     \
 | 
	
		
			
				|  |  | -        register int _v3 asm ("v3") = (int) (SYS_ify(name));    \
 | 
	
		
			
				|  |  | -      asm volatile ("push       {r7}\n"                         \
 | 
	
		
			
				|  |  | -                    "\tmov      r7, v3\n"                       \
 | 
	
		
			
				|  |  | -                    "\tswi      0       @ syscall " #name "\n"  \
 | 
	
		
			
				|  |  | -                    "\tpop      {r7}"                           \
 | 
	
		
			
				|  |  | -                   : "=r" (_a1)                                 \
 | 
	
		
			
				|  |  | -                    : "r" (_v3) ASM_ARGS_##nr                   \
 | 
	
		
			
				|  |  | -                    : "memory");                                \
 | 
	
		
			
				|  |  | -      __sys_result = _a1;                                        \
 | 
	
		
			
				|  |  | -    }                                                           \
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +#define INTERNAL_SYSCALL(name, err, nr, args...)			\
 | 
	
		
			
				|  |  | +  ({ unsigned int __sys_result;						\
 | 
	
		
			
				|  |  | +    {									\
 | 
	
		
			
				|  |  | +      register int _a1 __asm__ ("a1");					\
 | 
	
		
			
				|  |  | +      LOAD_ARGS_##nr (args)						\
 | 
	
		
			
				|  |  | +      register int _v3 __asm__ ("v3") = (int) (SYS_ify(name));		\
 | 
	
		
			
				|  |  | +      __asm__ __volatile__ ("push       {r7}\n"				\
 | 
	
		
			
				|  |  | +			    "\tmov      r7, v3\n"			\
 | 
	
		
			
				|  |  | +			    "\tswi      0       @ syscall " #name "\n"	\
 | 
	
		
			
				|  |  | +			    "\tpop      {r7}"				\
 | 
	
		
			
				|  |  | +		    : "=r" (_a1)					\
 | 
	
		
			
				|  |  | +		    : "r" (_v3) ASM_ARGS_##nr				\
 | 
	
		
			
				|  |  | +                    : "memory");					\
 | 
	
		
			
				|  |  | +	__sys_result = _a1;						\
 | 
	
		
			
				|  |  | +    }									\
 | 
	
		
			
				|  |  |      (int) __sys_result; })
 | 
	
		
			
				|  |  |  #endif /*!defined(__thumb__)*/
 | 
	
		
			
				|  |  | -#else /* !defined(__ARM_EABI__) */ 
 | 
	
		
			
				|  |  | -#if !defined(__thumb__)
 | 
	
		
			
				|  |  | -#define INTERNAL_SYSCALL(name, err, nr, args...)		\
 | 
	
		
			
				|  |  | -  ({ unsigned int __sys_result;					\
 | 
	
		
			
				|  |  | -     {								\
 | 
	
		
			
				|  |  | -       register int _a1 __asm__ ("a1");				\
 | 
	
		
			
				|  |  | -       LOAD_ARGS_##nr (args)					\
 | 
	
		
			
				|  |  | -       __asm__ volatile ("swi	%1	@ syscall " #name	\
 | 
	
		
			
				|  |  | -		     : "=r" (_a1)				\
 | 
	
		
			
				|  |  | -		     : "i" (SYS_ify(name)) ASM_ARGS_##nr	\
 | 
	
		
			
				|  |  | -		     : "memory");				\
 | 
	
		
			
				|  |  | -       __sys_result = _a1;					\
 | 
	
		
			
				|  |  | -     }								\
 | 
	
		
			
				|  |  | -     (int) __sys_result; })
 | 
	
		
			
				|  |  | -#else
 | 
	
		
			
				|  |  | -#if 0
 | 
	
		
			
				|  |  | -/* This doesn't work because GCC uses r7 as a frame pointer in
 | 
	
		
			
				|  |  | - * some cases and doesn't notice that the _r7 value changes
 | 
	
		
			
				|  |  | - * it, resulting in mysterious crashes after the SWI.
 | 
	
		
			
				|  |  | - */
 | 
	
		
			
				|  |  | -#define INTERNAL_SYSCALL(name, err, nr, args...)		\
 | 
	
		
			
				|  |  | -  ({ unsigned int __sys_result;					\
 | 
	
		
			
				|  |  | -     {								\
 | 
	
		
			
				|  |  | -       register int _a1 __asm__ ("a1");				\
 | 
	
		
			
				|  |  | -       LOAD_ARGS_##nr (args)					\
 | 
	
		
			
				|  |  | -       register int _r7 __asm__ ("r7") = (int) (SYS_ify(name));	\
 | 
	
		
			
				|  |  | -       __asm__ volatile ("swi	0	@ syscall " #name	\
 | 
	
		
			
				|  |  | -		     : "=r" (_a1)				\
 | 
	
		
			
				|  |  | -		     : "r" (_r7) ASM_ARGS_##nr			\
 | 
	
		
			
				|  |  | -		     : "memory");				\
 | 
	
		
			
				|  |  | -       __sys_result = _a1;					\
 | 
	
		
			
				|  |  | -     }								\
 | 
	
		
			
				|  |  | -     (int) __sys_result; })
 | 
	
		
			
				|  |  | -#else
 | 
	
		
			
				|  |  | -/* So hide the use of r7 from the compiler, this would be a lot
 | 
	
		
			
				|  |  | - * easier but for the fact that the syscalls can exceed 255.
 | 
	
		
			
				|  |  | - * For the moment the LOAD_ARG_7 is sacrificed.
 | 
	
		
			
				|  |  | - */
 | 
	
		
			
				|  |  | -#define INTERNAL_SYSCALL(name, err, nr, args...)		\
 | 
	
		
			
				|  |  | -  ({ unsigned int __sys_result;					\
 | 
	
		
			
				|  |  | -     {								\
 | 
	
		
			
				|  |  | -       register int _a1 __asm__ ("a1");				\
 | 
	
		
			
				|  |  | -       LOAD_ARGS_##nr (args)					\
 | 
	
		
			
				|  |  | -       register int _v3 __asm__ ("v3") = (int) (SYS_ify(name));	\
 | 
	
		
			
				|  |  | -       __asm__ volatile ("push	{r7}\n"				\
 | 
	
		
			
				|  |  | -	       	     "\tmov	r7, v3\n"			\
 | 
	
		
			
				|  |  | -	       	     "\tswi	0	@ syscall " #name "\n"	\
 | 
	
		
			
				|  |  | -		     "\tpop	{r7}"				\
 | 
	
		
			
				|  |  | -		     : "=r" (_a1)				\
 | 
	
		
			
				|  |  | -		     : "r" (_v3) ASM_ARGS_##nr			\
 | 
	
		
			
				|  |  | -		     : "memory");				\
 | 
	
		
			
				|  |  | -       __sys_result = _a1;					\
 | 
	
		
			
				|  |  | -     }								\
 | 
	
		
			
				|  |  | -     (int) __sys_result; })
 | 
	
		
			
				|  |  | -#endif
 | 
	
		
			
				|  |  | -#endif
 | 
	
		
			
				|  |  | -#endif /* !defined(__ARM_EABI__) */
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  #undef INTERNAL_SYSCALL_ERROR_P
 | 
	
		
			
				|  |  |  #define INTERNAL_SYSCALL_ERROR_P(val, err) \
 |