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
Kirill Smelkov
linux
Commits
324610cf
Commit
324610cf
authored
May 28, 2004
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add __user annotations to ppc64 signal.c
parent
a2e80cf8
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
14 additions
and
14 deletions
+14
-14
arch/ppc64/kernel/signal.c
arch/ppc64/kernel/signal.c
+11
-11
include/asm-ppc64/sigcontext.h
include/asm-ppc64/sigcontext.h
+3
-3
No files found.
arch/ppc64/kernel/signal.c
View file @
324610cf
...
...
@@ -73,7 +73,7 @@ struct rt_sigframe {
/*
* Atomically swap in the new signal mask, and wait for a signal.
*/
long
sys_rt_sigsuspend
(
sigset_t
*
unewset
,
size_t
sigsetsize
,
int
p3
,
int
p4
,
long
sys_rt_sigsuspend
(
sigset_t
__user
*
unewset
,
size_t
sigsetsize
,
int
p3
,
int
p4
,
int
p6
,
int
p7
,
struct
pt_regs
*
regs
)
{
sigset_t
saveset
,
newset
;
...
...
@@ -103,7 +103,7 @@ long sys_rt_sigsuspend(sigset_t *unewset, size_t sigsetsize, int p3, int p4,
}
}
long
sys_sigaltstack
(
const
stack_t
*
uss
,
stack_t
*
uoss
,
unsigned
long
r5
,
long
sys_sigaltstack
(
const
stack_t
__user
*
uss
,
stack_t
__user
*
uoss
,
unsigned
long
r5
,
unsigned
long
r6
,
unsigned
long
r7
,
unsigned
long
r8
,
struct
pt_regs
*
regs
)
{
...
...
@@ -115,7 +115,7 @@ long sys_sigaltstack(const stack_t *uss, stack_t *uoss, unsigned long r5,
* Set up the sigcontext for the signal frame.
*/
static
long
setup_sigcontext
(
struct
sigcontext
*
sc
,
struct
pt_regs
*
regs
,
static
long
setup_sigcontext
(
struct
sigcontext
__user
*
sc
,
struct
pt_regs
*
regs
,
int
signr
,
sigset_t
*
set
,
unsigned
long
handler
)
{
/* When CONFIG_ALTIVEC is set, we _always_ setup v_regs even if the
...
...
@@ -127,7 +127,7 @@ static long setup_sigcontext(struct sigcontext *sc, struct pt_regs *regs,
* v_regs pointer or not
*/
#ifdef CONFIG_ALTIVEC
elf_vrreg_t
*
v_regs
=
(
elf_vrreg_t
*
)(((
unsigned
long
)
sc
->
vmx_reserve
)
&
~
0xful
);
elf_vrreg_t
__user
*
v_regs
=
(
elf_vrreg_t
__user
*
)(((
unsigned
long
)
sc
->
vmx_reserve
)
&
~
0xful
);
#endif
long
err
=
0
;
...
...
@@ -174,10 +174,10 @@ static long setup_sigcontext(struct sigcontext *sc, struct pt_regs *regs,
*/
static
long
restore_sigcontext
(
struct
pt_regs
*
regs
,
sigset_t
*
set
,
int
sig
,
struct
sigcontext
*
sc
)
struct
sigcontext
__user
*
sc
)
{
#ifdef CONFIG_ALTIVEC
elf_vrreg_t
*
v_regs
;
elf_vrreg_t
__user
*
v_regs
;
#endif
unsigned
long
err
=
0
;
unsigned
long
save_r13
;
...
...
@@ -230,7 +230,7 @@ static long restore_sigcontext(struct pt_regs *regs, sigset_t *set, int sig,
/*
* Allocate space for the signal frame
*/
static
inline
void
*
get_sigframe
(
struct
k_sigaction
*
ka
,
struct
pt_regs
*
regs
,
static
inline
void
__user
*
get_sigframe
(
struct
k_sigaction
*
ka
,
struct
pt_regs
*
regs
,
size_t
frame_size
)
{
unsigned
long
newsp
;
...
...
@@ -243,13 +243,13 @@ static inline void * get_sigframe(struct k_sigaction *ka, struct pt_regs *regs,
newsp
=
(
current
->
sas_ss_sp
+
current
->
sas_ss_size
);
}
return
(
void
*
)((
newsp
-
frame_size
)
&
-
8ul
);
return
(
void
__user
*
)((
newsp
-
frame_size
)
&
-
8ul
);
}
/*
* Setup the trampoline code on the stack
*/
static
long
setup_trampoline
(
unsigned
int
syscall
,
unsigned
int
*
tramp
)
static
long
setup_trampoline
(
unsigned
int
syscall
,
unsigned
int
__user
*
tramp
)
{
int
i
;
long
err
=
0
;
...
...
@@ -346,7 +346,7 @@ int sys_rt_sigreturn(unsigned long r3, unsigned long r4, unsigned long r5,
unsigned
long
r6
,
unsigned
long
r7
,
unsigned
long
r8
,
struct
pt_regs
*
regs
)
{
struct
ucontext
*
uc
=
(
struct
ucontext
*
)
regs
->
gpr
[
1
];
struct
ucontext
__user
*
uc
=
(
struct
ucontext
__user
*
)
regs
->
gpr
[
1
];
sigset_t
set
;
/* Always make any pending restarted system calls return -EINTR */
...
...
@@ -385,7 +385,7 @@ static void setup_rt_frame(int signr, struct k_sigaction *ka, siginfo_t *info,
* entry is the TOC value we need to use.
*/
func_descr_t
*
funct_desc_ptr
;
struct
rt_sigframe
*
frame
;
struct
rt_sigframe
__user
*
frame
;
unsigned
long
newsp
=
0
;
long
err
=
0
;
...
...
include/asm-ppc64/sigcontext.h
View file @
324610cf
...
...
@@ -7,7 +7,7 @@
* as published by the Free Software Foundation; either version
* 2 of the License, or (at your option) any later version.
*/
#include <linux/compiler.h>
#include <asm/ptrace.h>
#include <asm/elf.h>
...
...
@@ -18,7 +18,7 @@ struct sigcontext {
int
_pad0
;
unsigned
long
handler
;
unsigned
long
oldmask
;
struct
pt_regs
*
regs
;
struct
pt_regs
__user
*
regs
;
elf_gregset_t
gp_regs
;
elf_fpregset_t
fp_regs
;
/*
...
...
@@ -40,7 +40,7 @@ struct sigcontext {
* The entry with index 33 contains the vrsave as the first word (offset 0)
* within the quadword.
*/
elf_vrreg_t
*
v_regs
;
elf_vrreg_t
__user
*
v_regs
;
long
vmx_reserve
[
ELF_NVRREG
+
ELF_NVRREG
+
1
];
};
...
...
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