Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
18a65429
Commit
18a65429
authored
Jul 16, 2003
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://ppc.bkbits.net/for-linus-ppc
into home.osdl.org:/home/torvalds/v2.5/linux
parents
300e6521
7c35666d
Changes
11
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
120 additions
and
178 deletions
+120
-178
arch/ppc/kernel/irq.c
arch/ppc/kernel/irq.c
+1
-2
arch/ppc/kernel/misc.S
arch/ppc/kernel/misc.S
+5
-0
arch/ppc/kernel/syscalls.c
arch/ppc/kernel/syscalls.c
+7
-5
arch/ppc/kernel/time.c
arch/ppc/kernel/time.c
+1
-1
arch/ppc/platforms/pmac_cpufreq.c
arch/ppc/platforms/pmac_cpufreq.c
+1
-1
include/asm-ppc/hardirq.h
include/asm-ppc/hardirq.h
+0
-2
include/asm-ppc/ipc.h
include/asm-ppc/ipc.h
+1
-0
include/asm-ppc/pci.h
include/asm-ppc/pci.h
+23
-26
include/asm-ppc/processor.h
include/asm-ppc/processor.h
+1
-0
include/asm-ppc/uaccess.h
include/asm-ppc/uaccess.h
+12
-8
include/asm-ppc/unistd.h
include/asm-ppc/unistd.h
+68
-133
No files found.
arch/ppc/kernel/irq.c
View file @
18a65429
...
@@ -420,10 +420,9 @@ void ppc_irq_dispatch_handler(struct pt_regs *regs, int irq)
...
@@ -420,10 +420,9 @@ void ppc_irq_dispatch_handler(struct pt_regs *regs, int irq)
{
{
int
status
;
int
status
;
struct
irqaction
*
action
;
struct
irqaction
*
action
;
int
cpu
=
smp_processor_id
();
irq_desc_t
*
desc
=
irq_desc
+
irq
;
irq_desc_t
*
desc
=
irq_desc
+
irq
;
kstat_
cpu
(
cpu
)
.
irqs
[
irq
]
++
;
kstat_
this_cpu
.
irqs
[
irq
]
++
;
spin_lock
(
&
desc
->
lock
);
spin_lock
(
&
desc
->
lock
);
ack_irq
(
irq
);
ack_irq
(
irq
);
/*
/*
...
...
arch/ppc/kernel/misc.S
View file @
18a65429
...
@@ -1375,3 +1375,8 @@ _GLOBAL(sys_call_table)
...
@@ -1375,3 +1375,8 @@ _GLOBAL(sys_call_table)
.
long
sys_clock_gettime
.
long
sys_clock_gettime
.
long
sys_clock_getres
.
long
sys_clock_getres
.
long
sys_clock_nanosleep
.
long
sys_clock_nanosleep
.
long
sys_ni_syscall
/*
reserved
for
swapcontext
*/
.
long
sys_tgkill
/*
250
*/
.
long
sys_utimes
.
long
sys_statfs64
.
long
sys_fstatfs64
arch/ppc/kernel/syscalls.c
View file @
18a65429
...
@@ -20,7 +20,6 @@
...
@@ -20,7 +20,6 @@
*
*
*/
*/
#include <linux/config.h>
#include <linux/errno.h>
#include <linux/errno.h>
#include <linux/sched.h>
#include <linux/sched.h>
#include <linux/mm.h>
#include <linux/mm.h>
...
@@ -59,10 +58,15 @@ sys_ipc (uint call, int first, int second, int third, void __user *ptr, long fif
...
@@ -59,10 +58,15 @@ sys_ipc (uint call, int first, int second, int third, void __user *ptr, long fif
version
=
call
>>
16
;
/* hack for backward compatibility */
version
=
call
>>
16
;
/* hack for backward compatibility */
call
&=
0xffff
;
call
&=
0xffff
;
ret
=
-
E
INVAL
;
ret
=
-
E
NOSYS
;
switch
(
call
)
{
switch
(
call
)
{
case
SEMOP
:
case
SEMOP
:
ret
=
sys_semop
(
first
,
(
struct
sembuf
__user
*
)
ptr
,
second
);
ret
=
sys_semtimedop
(
first
,
(
struct
sembuf
__user
*
)
ptr
,
second
,
NULL
);
break
;
case
SEMTIMEDOP
:
ret
=
sys_semtimedop
(
first
,
(
struct
sembuf
__user
*
)
ptr
,
second
,
(
const
struct
timespec
*
)
fifth
);
break
;
break
;
case
SEMGET
:
case
SEMGET
:
ret
=
sys_semget
(
first
,
second
,
third
);
ret
=
sys_semget
(
first
,
second
,
third
);
...
@@ -258,6 +262,4 @@ int sys_olduname(struct oldold_utsname __user * name)
...
@@ -258,6 +262,4 @@ int sys_olduname(struct oldold_utsname __user * name)
return
error
;
return
error
;
}
}
cond_syscall
(
sys_pciconfig_read
);
cond_syscall
(
sys_pciconfig_write
);
cond_syscall
(
sys_pciconfig_iobase
);
cond_syscall
(
sys_pciconfig_iobase
);
arch/ppc/kernel/time.c
View file @
18a65429
...
@@ -244,7 +244,7 @@ int do_settimeofday(struct timespec *tv)
...
@@ -244,7 +244,7 @@ int do_settimeofday(struct timespec *tv)
time_t
wtm_sec
,
new_sec
=
tv
->
tv_sec
;
time_t
wtm_sec
,
new_sec
=
tv
->
tv_sec
;
long
wtm_nsec
,
new_nsec
=
tv
->
tv_nsec
;
long
wtm_nsec
,
new_nsec
=
tv
->
tv_nsec
;
unsigned
long
flags
;
unsigned
long
flags
;
int
tb_delta
,
new_nsec
,
new_sec
;
int
tb_delta
;
if
((
unsigned
long
)
tv
->
tv_nsec
>=
NSEC_PER_SEC
)
if
((
unsigned
long
)
tv
->
tv_nsec
>=
NSEC_PER_SEC
)
return
-
EINVAL
;
return
-
EINVAL
;
...
...
arch/ppc/platforms/pmac_cpufreq.c
View file @
18a65429
...
@@ -176,7 +176,7 @@ do_set_cpu_speed(int speed_mode)
...
@@ -176,7 +176,7 @@ do_set_cpu_speed(int speed_mode)
freqs
.
old
=
cur_freq
;
freqs
.
old
=
cur_freq
;
freqs
.
new
=
(
speed_mode
==
PMAC_CPU_HIGH_SPEED
)
?
hi_freq
:
low_freq
;
freqs
.
new
=
(
speed_mode
==
PMAC_CPU_HIGH_SPEED
)
?
hi_freq
:
low_freq
;
freqs
.
cpu
=
CPUFREQ_ALL_CPUS
;
freqs
.
cpu
=
smp_processor_id
()
;
cpufreq_notify_transition
(
&
freqs
,
CPUFREQ_PRECHANGE
);
cpufreq_notify_transition
(
&
freqs
,
CPUFREQ_PRECHANGE
);
if
(
cpufreq_uses_pmu
)
if
(
cpufreq_uses_pmu
)
...
...
include/asm-ppc/hardirq.h
View file @
18a65429
...
@@ -14,8 +14,6 @@
...
@@ -14,8 +14,6 @@
*/
*/
typedef
struct
{
typedef
struct
{
unsigned
long
__softirq_pending
;
/* set_bit is used on this */
unsigned
long
__softirq_pending
;
/* set_bit is used on this */
unsigned
int
__syscall_count
;
struct
task_struct
*
__ksoftirqd_task
;
unsigned
int
__last_jiffy_stamp
;
unsigned
int
__last_jiffy_stamp
;
}
____cacheline_aligned
irq_cpustat_t
;
}
____cacheline_aligned
irq_cpustat_t
;
...
...
include/asm-ppc/ipc.h
View file @
18a65429
...
@@ -14,6 +14,7 @@ struct ipc_kludge {
...
@@ -14,6 +14,7 @@ struct ipc_kludge {
#define SEMOP 1
#define SEMOP 1
#define SEMGET 2
#define SEMGET 2
#define SEMCTL 3
#define SEMCTL 3
#define SEMTIMEDOP 4
#define MSGSND 11
#define MSGSND 11
#define MSGRCV 12
#define MSGRCV 12
#define MSGGET 13
#define MSGGET 13
...
...
include/asm-ppc/pci.h
View file @
18a65429
...
@@ -53,18 +53,12 @@ extern unsigned long phys_to_bus(unsigned long pa);
...
@@ -53,18 +53,12 @@ extern unsigned long phys_to_bus(unsigned long pa);
extern
unsigned
long
pci_phys_to_bus
(
unsigned
long
pa
,
int
busnr
);
extern
unsigned
long
pci_phys_to_bus
(
unsigned
long
pa
,
int
busnr
);
extern
unsigned
long
pci_bus_to_phys
(
unsigned
int
ba
,
int
busnr
);
extern
unsigned
long
pci_bus_to_phys
(
unsigned
int
ba
,
int
busnr
);
/* Dynamic DMA Mapping stuff, stolen from i386
/*
* ++ajoshi
* Dynamic DMA Mapping stuff
* Originally stolen from i386 by ajoshi and updated by paulus
* Non-consistent cache support by Dan Malek
*/
*/
#include <linux/types.h>
#include <linux/slab.h>
#include <linux/string.h>
#include <asm/scatterlist.h>
#include <asm/io.h>
struct
pci_dev
;
/* The PCI address space does equal the physical memory
/* The PCI address space does equal the physical memory
* address space. The networking and block device layers use
* address space. The networking and block device layers use
* this boolean for bounce buffer decisions.
* this boolean for bounce buffer decisions.
...
@@ -101,8 +95,7 @@ extern void pci_free_consistent(struct pci_dev *hwdev, size_t size,
...
@@ -101,8 +95,7 @@ extern void pci_free_consistent(struct pci_dev *hwdev, size_t size,
static
inline
dma_addr_t
pci_map_single
(
struct
pci_dev
*
hwdev
,
void
*
ptr
,
static
inline
dma_addr_t
pci_map_single
(
struct
pci_dev
*
hwdev
,
void
*
ptr
,
size_t
size
,
int
direction
)
size_t
size
,
int
direction
)
{
{
if
(
direction
==
PCI_DMA_NONE
)
BUG_ON
(
direction
==
PCI_DMA_NONE
);
BUG
();
consistent_sync
(
ptr
,
size
,
direction
);
consistent_sync
(
ptr
,
size
,
direction
);
...
@@ -130,10 +123,11 @@ static inline void pci_unmap_single(struct pci_dev *hwdev, dma_addr_t dma_addr,
...
@@ -130,10 +123,11 @@ static inline void pci_unmap_single(struct pci_dev *hwdev, dma_addr_t dma_addr,
* to pci_map_single, but takes a struct page instead of a virtual address
* to pci_map_single, but takes a struct page instead of a virtual address
*/
*/
static
inline
dma_addr_t
pci_map_page
(
struct
pci_dev
*
hwdev
,
struct
page
*
page
,
static
inline
dma_addr_t
pci_map_page
(
struct
pci_dev
*
hwdev
,
struct
page
*
page
,
unsigned
long
offset
,
size_t
size
,
int
direction
)
unsigned
long
offset
,
size_t
size
,
int
direction
)
{
{
if
(
direction
==
PCI_DMA_NONE
)
BUG_ON
(
direction
==
PCI_DMA_NONE
);
BUG
(
);
consistent_sync_page
(
page
,
offset
,
size
,
direction
);
return
(
page
-
mem_map
)
*
PAGE_SIZE
+
PCI_DRAM_OFFSET
+
offset
;
return
(
page
-
mem_map
)
*
PAGE_SIZE
+
PCI_DRAM_OFFSET
+
offset
;
}
}
...
@@ -171,10 +165,11 @@ static inline int pci_map_sg(struct pci_dev *hwdev, struct scatterlist *sg,
...
@@ -171,10 +165,11 @@ static inline int pci_map_sg(struct pci_dev *hwdev, struct scatterlist *sg,
/*
/*
* temporary 2.4 hack
* temporary 2.4 hack
*/
*/
for
(
i
=
0
;
i
<
nents
;
i
++
)
{
for
(
i
=
0
;
i
<
nents
;
i
++
,
sg
++
)
{
if
(
!
sg
[
i
].
page
)
BUG_ON
(
!
sg
->
page
);
BUG
();
consistent_sync_page
(
sg
->
page
,
sg
->
offset
,
sg
[
i
].
dma_address
=
page_to_bus
(
sg
[
i
].
page
)
+
sg
[
i
].
offset
;
sg
->
length
,
direction
);
sg
->
dma_address
=
page_to_bus
(
sg
->
page
)
+
sg
->
offset
;
}
}
return
nents
;
return
nents
;
...
@@ -187,8 +182,7 @@ static inline int pci_map_sg(struct pci_dev *hwdev, struct scatterlist *sg,
...
@@ -187,8 +182,7 @@ static inline int pci_map_sg(struct pci_dev *hwdev, struct scatterlist *sg,
static
inline
void
pci_unmap_sg
(
struct
pci_dev
*
hwdev
,
struct
scatterlist
*
sg
,
static
inline
void
pci_unmap_sg
(
struct
pci_dev
*
hwdev
,
struct
scatterlist
*
sg
,
int
nents
,
int
direction
)
int
nents
,
int
direction
)
{
{
if
(
direction
==
PCI_DMA_NONE
)
BUG_ON
(
direction
==
PCI_DMA_NONE
);
BUG
();
/* nothing to do */
/* nothing to do */
}
}
...
@@ -205,8 +199,7 @@ static inline void pci_dma_sync_single(struct pci_dev *hwdev,
...
@@ -205,8 +199,7 @@ static inline void pci_dma_sync_single(struct pci_dev *hwdev,
dma_addr_t
dma_handle
,
dma_addr_t
dma_handle
,
size_t
size
,
int
direction
)
size_t
size
,
int
direction
)
{
{
if
(
direction
==
PCI_DMA_NONE
)
BUG_ON
(
direction
==
PCI_DMA_NONE
);
BUG
();
consistent_sync
(
bus_to_virt
(
dma_handle
),
size
,
direction
);
consistent_sync
(
bus_to_virt
(
dma_handle
),
size
,
direction
);
}
}
...
@@ -221,9 +214,13 @@ static inline void pci_dma_sync_sg(struct pci_dev *hwdev,
...
@@ -221,9 +214,13 @@ static inline void pci_dma_sync_sg(struct pci_dev *hwdev,
struct
scatterlist
*
sg
,
struct
scatterlist
*
sg
,
int
nelems
,
int
direction
)
int
nelems
,
int
direction
)
{
{
if
(
direction
==
PCI_DMA_NONE
)
int
i
;
BUG
();
/* nothing to do */
BUG_ON
(
direction
==
PCI_DMA_NONE
);
for
(
i
=
0
;
i
<
nelems
;
i
++
,
sg
++
)
consistent_sync_page
(
sg
->
page
,
sg
->
offset
,
sg
->
length
,
direction
);
}
}
/* Return whether the given PCI device DMA address mask can
/* Return whether the given PCI device DMA address mask can
...
...
include/asm-ppc/processor.h
View file @
18a65429
...
@@ -705,6 +705,7 @@ struct thread_struct {
...
@@ -705,6 +705,7 @@ struct thread_struct {
.ksp = INIT_SP, \
.ksp = INIT_SP, \
.fs = KERNEL_DS, \
.fs = KERNEL_DS, \
.pgdir = swapper_pg_dir, \
.pgdir = swapper_pg_dir, \
.fpexc_mode = MSR_FE0 | MSR_FE1, \
}
}
/*
/*
...
...
include/asm-ppc/uaccess.h
View file @
18a65429
...
@@ -16,10 +16,13 @@
...
@@ -16,10 +16,13 @@
* get_fs() == KERNEL_DS, checking is bypassed.
* get_fs() == KERNEL_DS, checking is bypassed.
*
*
* For historical reasons, these macros are grossly misnamed.
* For historical reasons, these macros are grossly misnamed.
*
* The fs/ds values are now the highest legal address in the "segment".
* This simplifies the checking in the routines below.
*/
*/
#define KERNEL_DS ((mm_segment_t) {
0
})
#define KERNEL_DS ((mm_segment_t) {
~0UL
})
#define USER_DS ((mm_segment_t) { 1 })
#define USER_DS ((mm_segment_t) {
TASK_SIZE -
1 })
#define get_ds() (KERNEL_DS)
#define get_ds() (KERNEL_DS)
#define get_fs() (current->thread.fs)
#define get_fs() (current->thread.fs)
...
@@ -27,14 +30,15 @@
...
@@ -27,14 +30,15 @@
#define segment_eq(a,b) ((a).seg == (b).seg)
#define segment_eq(a,b) ((a).seg == (b).seg)
#define __kernel_ok (segment_eq(get_fs(), KERNEL_DS))
#define __access_ok(addr,size) \
#define __user_ok(addr,size) (((size) <= TASK_SIZE)&&((addr) <= TASK_SIZE-(size)))
((addr) <= current->thread.fs.seg \
#define __access_ok(addr,size) (__kernel_ok || __user_ok((addr),(size)))
&& ((size) == 0 || (size) - 1 <= current->thread.fs.seg - (addr)))
#define access_ok(type,addr,size) __access_ok((unsigned long)(addr),(size))
#define access_ok(type, addr, size) __access_ok((unsigned long)(addr),(size))
extern
inline
int
verify_area
(
int
type
,
const
void
__user
*
addr
,
unsigned
long
size
)
extern
inline
int
verify_area
(
int
type
,
const
void
__user
*
addr
,
unsigned
long
size
)
{
{
return
access_ok
(
type
,
addr
,
size
)
?
0
:
-
EFAULT
;
return
access_ok
(
type
,
addr
,
size
)
?
0
:
-
EFAULT
;
}
}
...
@@ -303,7 +307,7 @@ extern int __strnlen_user(const char __user *str, long len, unsigned long top);
...
@@ -303,7 +307,7 @@ extern int __strnlen_user(const char __user *str, long len, unsigned long top);
*/
*/
extern
__inline__
int
strnlen_user
(
const
char
__user
*
str
,
long
len
)
extern
__inline__
int
strnlen_user
(
const
char
__user
*
str
,
long
len
)
{
{
unsigned
long
top
=
__kernel_ok
?
~
0UL
:
TASK_SIZE
-
1
;
unsigned
long
top
=
current
->
thread
.
fs
.
seg
;
if
((
unsigned
long
)
str
>
top
)
if
((
unsigned
long
)
str
>
top
)
return
0
;
return
0
;
...
...
include/asm-ppc/unistd.h
View file @
18a65429
...
@@ -253,177 +253,112 @@
...
@@ -253,177 +253,112 @@
#define __NR_clock_gettime 246
#define __NR_clock_gettime 246
#define __NR_clock_getres 247
#define __NR_clock_getres 247
#define __NR_clock_nanosleep 248
#define __NR_clock_nanosleep 248
#define __NR_swapcontext 249
#define __NR_tgkill 250
#define __NR_utimes 251
#define __NR_statfs64 252
#define __NR_fstatfs64 253
#define __NR_syscalls 2
49
#define __NR_syscalls 2
54
#define __NR(n) #n
#define __NR(n) #n
#define __syscall_return(type) \
/* On powerpc a system call basically clobbers the same registers like a
return (__sc_err & 0x10000000 ? errno = __sc_ret, __sc_ret = -1 : 0), \
* function call, with the exception of LR (which is needed for the
(type) __sc_ret
* "sc; bnslr" sequence) and CR (where only CR0.SO is clobbered to signal
* an error return status).
#define __syscall_clobbers \
*/
"r4", "r5", "r6", "r7", "r8", "r9", "r10", "r11", "r12"
#define _syscall0(type,name) \
#define __syscall_nr(nr, type, name, args...) \
type name(void) \
{ \
unsigned long __sc_ret, __sc_err; \
unsigned long __sc_ret, __sc_err; \
{ \
{ \
register unsigned long __sc_0 __asm__ ("r0"); \
register unsigned long __sc_0 __asm__ ("r0"); \
register unsigned long __sc_3 __asm__ ("r3"); \
register unsigned long __sc_3 __asm__ ("r3"); \
register unsigned long __sc_4 __asm__ ("r4"); \
register unsigned long __sc_5 __asm__ ("r5"); \
register unsigned long __sc_6 __asm__ ("r6"); \
register unsigned long __sc_7 __asm__ ("r7"); \
\
\
__sc_
0 = __NR_##name;
\
__sc_
loadargs_##nr(name, args);
\
__asm__ __volatile__ \
__asm__ __volatile__ \
("sc \n\t" \
("sc \n\t" \
"mfcr %1 " \
"mfcr %0 " \
: "=&r" (__sc_3), "=&r" (__sc_0) \
: "=&r" (__sc_0), \
: "0" (__sc_3), "1" (__sc_0) \
"=&r" (__sc_3), "=&r" (__sc_4), \
: __syscall_clobbers); \
"=&r" (__sc_5), "=&r" (__sc_6), \
"=&r" (__sc_7) \
: __sc_asm_input_##nr \
: "cr0", "ctr", "memory", \
"r8", "r9", "r10","r11", "r12"); \
__sc_ret = __sc_3; \
__sc_ret = __sc_3; \
__sc_err = __sc_0; \
__sc_err = __sc_0; \
} \
} \
__syscall_return (type); \
if (__sc_err & 0x10000000) \
{ \
errno = __sc_ret; \
__sc_ret = -1; \
} \
return (type) __sc_ret
#define __sc_loadargs_0(name, dummy...) \
__sc_0 = __NR_##name
#define __sc_loadargs_1(name, arg1) \
__sc_loadargs_0(name); \
__sc_3 = (unsigned long) (arg1)
#define __sc_loadargs_2(name, arg1, arg2) \
__sc_loadargs_1(name, arg1); \
__sc_4 = (unsigned long) (arg2)
#define __sc_loadargs_3(name, arg1, arg2, arg3) \
__sc_loadargs_2(name, arg1, arg2); \
__sc_5 = (unsigned long) (arg3)
#define __sc_loadargs_4(name, arg1, arg2, arg3, arg4) \
__sc_loadargs_3(name, arg1, arg2, arg3); \
__sc_6 = (unsigned long) (arg4)
#define __sc_loadargs_5(name, arg1, arg2, arg3, arg4, arg5) \
__sc_loadargs_4(name, arg1, arg2, arg3, arg4); \
__sc_7 = (unsigned long) (arg5)
#define __sc_asm_input_0 "0" (__sc_0)
#define __sc_asm_input_1 __sc_asm_input_0, "1" (__sc_3)
#define __sc_asm_input_2 __sc_asm_input_1, "2" (__sc_4)
#define __sc_asm_input_3 __sc_asm_input_2, "3" (__sc_5)
#define __sc_asm_input_4 __sc_asm_input_3, "4" (__sc_6)
#define __sc_asm_input_5 __sc_asm_input_4, "5" (__sc_7)
#define _syscall0(type,name) \
type name(void) \
{ \
__syscall_nr(0, type, name); \
}
}
#define _syscall1(type,name,type1,arg1) \
#define _syscall1(type,name,type1,arg1) \
type name(type1 arg1) \
type name(type1 arg1) \
{ \
{ \
unsigned long __sc_ret, __sc_err; \
__syscall_nr(1, type, name, arg1); \
{ \
register unsigned long __sc_0 __asm__ ("r0"); \
register unsigned long __sc_3 __asm__ ("r3"); \
\
__sc_3 = (unsigned long) (arg1); \
__sc_0 = __NR_##name; \
__asm__ __volatile__ \
("sc \n\t" \
"mfcr %1 " \
: "=&r" (__sc_3), "=&r" (__sc_0) \
: "0" (__sc_3), "1" (__sc_0) \
: __syscall_clobbers); \
__sc_ret = __sc_3; \
__sc_err = __sc_0; \
} \
__syscall_return (type); \
}
}
#define _syscall2(type,name,type1,arg1,type2,arg2) \
#define _syscall2(type,name,type1,arg1,type2,arg2) \
type name(type1 arg1, type2 arg2) \
type name(type1 arg1, type2 arg2) \
{ \
{ \
unsigned long __sc_ret, __sc_err; \
__syscall_nr(2, type, name, arg1, arg2); \
{ \
register unsigned long __sc_0 __asm__ ("r0"); \
register unsigned long __sc_3 __asm__ ("r3"); \
register unsigned long __sc_4 __asm__ ("r4"); \
\
__sc_3 = (unsigned long) (arg1); \
__sc_4 = (unsigned long) (arg2); \
__sc_0 = __NR_##name; \
__asm__ __volatile__ \
("sc \n\t" \
"mfcr %1 " \
: "=&r" (__sc_3), "=&r" (__sc_0) \
: "0" (__sc_3), "1" (__sc_0), \
"r" (__sc_4) \
: __syscall_clobbers); \
__sc_ret = __sc_3; \
__sc_err = __sc_0; \
} \
__syscall_return (type); \
}
}
#define _syscall3(type,name,type1,arg1,type2,arg2,type3,arg3) \
#define _syscall3(type,name,type1,arg1,type2,arg2,type3,arg3) \
type name(type1 arg1, type2 arg2, type3 arg3) \
type name(type1 arg1, type2 arg2, type3 arg3) \
{ \
{ \
unsigned long __sc_ret, __sc_err; \
__syscall_nr(3, type, name, arg1, arg2, arg3); \
{ \
register unsigned long __sc_0 __asm__ ("r0"); \
register unsigned long __sc_3 __asm__ ("r3"); \
register unsigned long __sc_4 __asm__ ("r4"); \
register unsigned long __sc_5 __asm__ ("r5"); \
\
__sc_3 = (unsigned long) (arg1); \
__sc_4 = (unsigned long) (arg2); \
__sc_5 = (unsigned long) (arg3); \
__sc_0 = __NR_##name; \
__asm__ __volatile__ \
("sc \n\t" \
"mfcr %1 " \
: "=&r" (__sc_3), "=&r" (__sc_0) \
: "0" (__sc_3), "1" (__sc_0), \
"r" (__sc_4), \
"r" (__sc_5) \
: __syscall_clobbers); \
__sc_ret = __sc_3; \
__sc_err = __sc_0; \
} \
__syscall_return (type); \
}
}
#define _syscall4(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4) \
#define _syscall4(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4) \
type name(type1 arg1, type2 arg2, type3 arg3, type4 arg4) \
type name(type1 arg1, type2 arg2, type3 arg3, type4 arg4) \
{ \
{ \
unsigned long __sc_ret, __sc_err; \
__syscall_nr(4, type, name, arg1, arg2, arg3, arg4); \
{ \
register unsigned long __sc_0 __asm__ ("r0"); \
register unsigned long __sc_3 __asm__ ("r3"); \
register unsigned long __sc_4 __asm__ ("r4"); \
register unsigned long __sc_5 __asm__ ("r5"); \
register unsigned long __sc_6 __asm__ ("r6"); \
\
__sc_3 = (unsigned long) (arg1); \
__sc_4 = (unsigned long) (arg2); \
__sc_5 = (unsigned long) (arg3); \
__sc_6 = (unsigned long) (arg4); \
__sc_0 = __NR_##name; \
__asm__ __volatile__ \
("sc \n\t" \
"mfcr %1 " \
: "=&r" (__sc_3), "=&r" (__sc_0) \
: "0" (__sc_3), "1" (__sc_0), \
"r" (__sc_4), \
"r" (__sc_5), \
"r" (__sc_6) \
: __syscall_clobbers); \
__sc_ret = __sc_3; \
__sc_err = __sc_0; \
} \
__syscall_return (type); \
}
}
#define _syscall5(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4,type5,arg5) \
#define _syscall5(type,name,type1,arg1,type2,arg2,type3,arg3,type4,arg4,type5,arg5) \
type name(type1 arg1, type2 arg2, type3 arg3, type4 arg4, type5 arg5) \
type name(type1 arg1, type2 arg2, type3 arg3, type4 arg4, type5 arg5) \
{ \
{ \
unsigned long __sc_ret, __sc_err; \
__syscall_nr(5, type, name, arg1, arg2, arg3, arg4, arg5); \
{ \
register unsigned long __sc_0 __asm__ ("r0"); \
register unsigned long __sc_3 __asm__ ("r3"); \
register unsigned long __sc_4 __asm__ ("r4"); \
register unsigned long __sc_5 __asm__ ("r5"); \
register unsigned long __sc_6 __asm__ ("r6"); \
register unsigned long __sc_7 __asm__ ("r7"); \
\
__sc_3 = (unsigned long) (arg1); \
__sc_4 = (unsigned long) (arg2); \
__sc_5 = (unsigned long) (arg3); \
__sc_6 = (unsigned long) (arg4); \
__sc_7 = (unsigned long) (arg5); \
__sc_0 = __NR_##name; \
__asm__ __volatile__ \
("sc \n\t" \
"mfcr %1 " \
: "=&r" (__sc_3), "=&r" (__sc_0) \
: "0" (__sc_3), "1" (__sc_0), \
"r" (__sc_4), \
"r" (__sc_5), \
"r" (__sc_6), \
"r" (__sc_7) \
: __syscall_clobbers); \
__sc_ret = __sc_3; \
__sc_err = __sc_0; \
} \
__syscall_return (type); \
}
}
#ifdef __KERNEL__
#ifdef __KERNEL__
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment