s390: convert to generic kernel_execve()
same situation as with alpha and arm - only massage needed Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
f9a7e025df
commit
f322220d61
|
@ -416,6 +416,7 @@
|
||||||
# define __ARCH_WANT_COMPAT_SYS_RT_SIGSUSPEND
|
# define __ARCH_WANT_COMPAT_SYS_RT_SIGSUSPEND
|
||||||
# endif
|
# endif
|
||||||
#define __ARCH_WANT_SYS_EXECVE
|
#define __ARCH_WANT_SYS_EXECVE
|
||||||
|
#define __ARCH_WANT_KERNEL_EXECVE
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* "Conditional" syscalls
|
* "Conditional" syscalls
|
||||||
|
|
|
@ -355,30 +355,13 @@ ENTRY(kernel_thread_starter)
|
||||||
# kernel_execve function needs to deal with pt_regs that is not
|
# kernel_execve function needs to deal with pt_regs that is not
|
||||||
# at the usual place
|
# at the usual place
|
||||||
#
|
#
|
||||||
ENTRY(kernel_execve)
|
ENTRY(ret_from_kernel_execve)
|
||||||
stm %r12,%r15,48(%r15)
|
ssm __LC_PGM_NEW_PSW # disable I/O and ext. interrupts
|
||||||
lr %r14,%r15
|
lr %r15,%r2
|
||||||
l %r13,__LC_SVC_NEW_PSW+4
|
lr %r11,%r2
|
||||||
ahi %r15,-(STACK_FRAME_OVERHEAD + __PT_SIZE)
|
ahi %r15,-STACK_FRAME_OVERHEAD
|
||||||
st %r14,__SF_BACKCHAIN(%r15)
|
|
||||||
la %r12,STACK_FRAME_OVERHEAD(%r15)
|
|
||||||
xc 0(__PT_SIZE,%r12),0(%r12)
|
|
||||||
l %r1,BASED(.Ldo_execve)
|
|
||||||
lr %r5,%r12
|
|
||||||
basr %r14,%r1 # call do_execve
|
|
||||||
ltr %r2,%r2
|
|
||||||
je 0f
|
|
||||||
ahi %r15,(STACK_FRAME_OVERHEAD + __PT_SIZE)
|
|
||||||
lm %r12,%r15,48(%r15)
|
|
||||||
br %r14
|
|
||||||
# execve succeeded.
|
|
||||||
0: ssm __LC_PGM_NEW_PSW # disable I/O and ext. interrupts
|
|
||||||
l %r15,__LC_KERNEL_STACK # load ksp
|
|
||||||
ahi %r15,-(STACK_FRAME_OVERHEAD + __PT_SIZE)
|
|
||||||
la %r11,STACK_FRAME_OVERHEAD(%r15)
|
|
||||||
mvc 0(__PT_SIZE,%r11),0(%r12) # copy pt_regs
|
|
||||||
l %r12,__LC_THREAD_INFO
|
|
||||||
xc __SF_BACKCHAIN(4,%r15),__SF_BACKCHAIN(%r15)
|
xc __SF_BACKCHAIN(4,%r15),__SF_BACKCHAIN(%r15)
|
||||||
|
l %r12,__LC_THREAD_INFO
|
||||||
ssm __LC_SVC_NEW_PSW # reenable interrupts
|
ssm __LC_SVC_NEW_PSW # reenable interrupts
|
||||||
j sysc_return
|
j sysc_return
|
||||||
|
|
||||||
|
@ -941,7 +924,6 @@ cleanup_idle_wait:
|
||||||
.Ldo_signal: .long do_signal
|
.Ldo_signal: .long do_signal
|
||||||
.Ldo_notify_resume: .long do_notify_resume
|
.Ldo_notify_resume: .long do_notify_resume
|
||||||
.Ldo_per_trap: .long do_per_trap
|
.Ldo_per_trap: .long do_per_trap
|
||||||
.Ldo_execve: .long do_execve
|
|
||||||
.Ljump_table: .long pgm_check_table
|
.Ljump_table: .long pgm_check_table
|
||||||
.Lschedule: .long schedule
|
.Lschedule: .long schedule
|
||||||
#ifdef CONFIG_PREEMPT
|
#ifdef CONFIG_PREEMPT
|
||||||
|
|
|
@ -369,32 +369,13 @@ ENTRY(kernel_thread_starter)
|
||||||
la %r2,0
|
la %r2,0
|
||||||
br %r11 # do_exit
|
br %r11 # do_exit
|
||||||
|
|
||||||
#
|
ENTRY(ret_from_kernel_execve)
|
||||||
# kernel_execve function needs to deal with pt_regs that is not
|
ssm __LC_PGM_NEW_PSW # disable I/O and ext. interrupts
|
||||||
# at the usual place
|
lgr %r15,%r2
|
||||||
#
|
lgr %r11,%r2
|
||||||
ENTRY(kernel_execve)
|
aghi %r15,-STACK_FRAME_OVERHEAD
|
||||||
stmg %r12,%r15,96(%r15)
|
|
||||||
lgr %r14,%r15
|
|
||||||
aghi %r15,-(STACK_FRAME_OVERHEAD + __PT_SIZE)
|
|
||||||
stg %r14,__SF_BACKCHAIN(%r15)
|
|
||||||
la %r12,STACK_FRAME_OVERHEAD(%r15)
|
|
||||||
xc 0(__PT_SIZE,%r12),0(%r12)
|
|
||||||
lgr %r5,%r12
|
|
||||||
brasl %r14,do_execve
|
|
||||||
ltgfr %r2,%r2
|
|
||||||
je 0f
|
|
||||||
aghi %r15,(STACK_FRAME_OVERHEAD + __PT_SIZE)
|
|
||||||
lmg %r12,%r15,96(%r15)
|
|
||||||
br %r14
|
|
||||||
# execve succeeded.
|
|
||||||
0: ssm __LC_PGM_NEW_PSW # disable I/O and ext. interrupts
|
|
||||||
lg %r15,__LC_KERNEL_STACK # load ksp
|
|
||||||
aghi %r15,-(STACK_FRAME_OVERHEAD + __PT_SIZE)
|
|
||||||
la %r11,STACK_FRAME_OVERHEAD(%r15)
|
|
||||||
mvc 0(__PT_SIZE,%r11),0(%r12) # copy pt_regs
|
|
||||||
lg %r12,__LC_THREAD_INFO
|
|
||||||
xc __SF_BACKCHAIN(8,%r15),__SF_BACKCHAIN(%r15)
|
xc __SF_BACKCHAIN(8,%r15),__SF_BACKCHAIN(%r15)
|
||||||
|
lg %r12,__LC_THREAD_INFO
|
||||||
ssm __LC_SVC_NEW_PSW # reenable interrupts
|
ssm __LC_SVC_NEW_PSW # reenable interrupts
|
||||||
j sysc_return
|
j sysc_return
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue