00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef _RTAI_ASM_PPC_SRQ_H_
00021 #define _RTAI_ASM_PPC_SRQ_H_
00022
00023 #ifndef __KERNEL__
00024
00025 #include <sys/syscall.h>
00026 #include <unistd.h>
00027
00028 #include <asm/rtai_vectors.h>
00029
00030 #ifdef CONFIG_RTAI_LXRT_USE_LINUX_SYSCALL
00031 #define USE_LINUX_SYSCALL
00032 #else
00033 #undef USE_LINUX_SYSCALL
00034 #endif
00035
00036 #define RTAI_SRQ_SYSCALL_NR 0x70000001
00037
00038
00039 static inline long long rtai_srq(long srq, unsigned long args)
00040 {
00041 long long retval;
00042 #if 1 //def USE_LINUX_SYSCALL
00043 syscall(RTAI_SRQ_SYSCALL_NR, srq, args, &retval);
00044 #else
00045 register unsigned long __sc_0 __asm__ ("r0");
00046 register unsigned long __sc_3 __asm__ ("r3");
00047 register unsigned long __sc_4 __asm__ ("r4");
00048
00049 __sc_0 = (__sc_3 = srq) + (__sc_4 = args);
00050 __asm__ __volatile__
00051 ("trap \n\t"
00052 : "=&r" (__sc_3), "=&r" (__sc_4)
00053 : "0" (__sc_3), "1" (__sc_4),
00054 "r" (__sc_0)
00055 );
00056 ((unsigned long *)(void *)&retval)[0] = __sc_3;
00057 ((unsigned long *)(void *)&retval)[1] = __sc_4;
00058 #endif
00059 return retval;
00060 }
00061
00062 static inline int rtai_open_srq(unsigned int label)
00063 {
00064 return (int)rtai_srq(0, label);
00065 }
00066
00067 #endif
00068
00069 #endif