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
257ac264
Commit
257ac264
authored
Jan 14, 2009
by
Heiko Carstens
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[CVE-2009-0029] System call wrappers part 11
Signed-off-by:
Heiko Carstens
<
heiko.carstens@de.ibm.com
>
parent
bdc480e3
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
14 additions
and
10 deletions
+14
-10
fs/open.c
fs/open.c
+1
-1
fs/stat.c
fs/stat.c
+12
-8
fs/super.c
fs/super.c
+1
-1
No files found.
fs/open.c
View file @
257ac264
...
@@ -174,7 +174,7 @@ SYSCALL_DEFINE2(fstatfs, unsigned int, fd, struct statfs __user *, buf)
...
@@ -174,7 +174,7 @@ SYSCALL_DEFINE2(fstatfs, unsigned int, fd, struct statfs __user *, buf)
return
error
;
return
error
;
}
}
asmlinkage
long
sys_fstatfs64
(
unsigned
int
fd
,
size_t
sz
,
struct
statfs64
__user
*
buf
)
SYSCALL_DEFINE3
(
fstatfs64
,
unsigned
int
,
fd
,
size_t
,
sz
,
struct
statfs64
__user
*
,
buf
)
{
{
struct
file
*
file
;
struct
file
*
file
;
struct
statfs64
tmp
;
struct
statfs64
tmp
;
...
...
fs/stat.c
View file @
257ac264
...
@@ -162,7 +162,8 @@ SYSCALL_DEFINE2(stat, char __user *, filename, struct __old_kernel_stat __user *
...
@@ -162,7 +162,8 @@ SYSCALL_DEFINE2(stat, char __user *, filename, struct __old_kernel_stat __user *
return
error
;
return
error
;
}
}
asmlinkage
long
sys_lstat
(
char
__user
*
filename
,
struct
__old_kernel_stat
__user
*
statbuf
)
SYSCALL_DEFINE2
(
lstat
,
char
__user
*
,
filename
,
struct
__old_kernel_stat
__user
*
,
statbuf
)
{
{
struct
kstat
stat
;
struct
kstat
stat
;
int
error
=
vfs_lstat_fd
(
AT_FDCWD
,
filename
,
&
stat
);
int
error
=
vfs_lstat_fd
(
AT_FDCWD
,
filename
,
&
stat
);
...
@@ -172,7 +173,8 @@ asmlinkage long sys_lstat(char __user * filename, struct __old_kernel_stat __use
...
@@ -172,7 +173,8 @@ asmlinkage long sys_lstat(char __user * filename, struct __old_kernel_stat __use
return
error
;
return
error
;
}
}
asmlinkage
long
sys_fstat
(
unsigned
int
fd
,
struct
__old_kernel_stat
__user
*
statbuf
)
SYSCALL_DEFINE2
(
fstat
,
unsigned
int
,
fd
,
struct
__old_kernel_stat
__user
*
,
statbuf
)
{
{
struct
kstat
stat
;
struct
kstat
stat
;
int
error
=
vfs_fstat
(
fd
,
&
stat
);
int
error
=
vfs_fstat
(
fd
,
&
stat
);
...
@@ -235,7 +237,7 @@ static int cp_new_stat(struct kstat *stat, struct stat __user *statbuf)
...
@@ -235,7 +237,7 @@ static int cp_new_stat(struct kstat *stat, struct stat __user *statbuf)
return
copy_to_user
(
statbuf
,
&
tmp
,
sizeof
(
tmp
))
?
-
EFAULT
:
0
;
return
copy_to_user
(
statbuf
,
&
tmp
,
sizeof
(
tmp
))
?
-
EFAULT
:
0
;
}
}
asmlinkage
long
sys_newstat
(
char
__user
*
filename
,
struct
stat
__user
*
statbuf
)
SYSCALL_DEFINE2
(
newstat
,
char
__user
*
,
filename
,
struct
stat
__user
*
,
statbuf
)
{
{
struct
kstat
stat
;
struct
kstat
stat
;
int
error
=
vfs_stat_fd
(
AT_FDCWD
,
filename
,
&
stat
);
int
error
=
vfs_stat_fd
(
AT_FDCWD
,
filename
,
&
stat
);
...
@@ -246,7 +248,7 @@ asmlinkage long sys_newstat(char __user *filename, struct stat __user *statbuf)
...
@@ -246,7 +248,7 @@ asmlinkage long sys_newstat(char __user *filename, struct stat __user *statbuf)
return
error
;
return
error
;
}
}
asmlinkage
long
sys_newlstat
(
char
__user
*
filename
,
struct
stat
__user
*
statbuf
)
SYSCALL_DEFINE2
(
newlstat
,
char
__user
*
,
filename
,
struct
stat
__user
*
,
statbuf
)
{
{
struct
kstat
stat
;
struct
kstat
stat
;
int
error
=
vfs_lstat_fd
(
AT_FDCWD
,
filename
,
&
stat
);
int
error
=
vfs_lstat_fd
(
AT_FDCWD
,
filename
,
&
stat
);
...
@@ -280,7 +282,7 @@ asmlinkage long sys_newfstatat(int dfd, char __user *filename,
...
@@ -280,7 +282,7 @@ asmlinkage long sys_newfstatat(int dfd, char __user *filename,
}
}
#endif
#endif
asmlinkage
long
sys_newfstat
(
unsigned
int
fd
,
struct
stat
__user
*
statbuf
)
SYSCALL_DEFINE2
(
newfstat
,
unsigned
int
,
fd
,
struct
stat
__user
*
,
statbuf
)
{
{
struct
kstat
stat
;
struct
kstat
stat
;
int
error
=
vfs_fstat
(
fd
,
&
stat
);
int
error
=
vfs_fstat
(
fd
,
&
stat
);
...
@@ -365,7 +367,7 @@ static long cp_new_stat64(struct kstat *stat, struct stat64 __user *statbuf)
...
@@ -365,7 +367,7 @@ static long cp_new_stat64(struct kstat *stat, struct stat64 __user *statbuf)
return
copy_to_user
(
statbuf
,
&
tmp
,
sizeof
(
tmp
))
?
-
EFAULT
:
0
;
return
copy_to_user
(
statbuf
,
&
tmp
,
sizeof
(
tmp
))
?
-
EFAULT
:
0
;
}
}
asmlinkage
long
sys_stat64
(
char
__user
*
filename
,
struct
stat64
__user
*
statbuf
)
SYSCALL_DEFINE2
(
stat64
,
char
__user
*
,
filename
,
struct
stat64
__user
*
,
statbuf
)
{
{
struct
kstat
stat
;
struct
kstat
stat
;
int
error
=
vfs_stat
(
filename
,
&
stat
);
int
error
=
vfs_stat
(
filename
,
&
stat
);
...
@@ -375,7 +377,8 @@ asmlinkage long sys_stat64(char __user * filename, struct stat64 __user * statbu
...
@@ -375,7 +377,8 @@ asmlinkage long sys_stat64(char __user * filename, struct stat64 __user * statbu
return
error
;
return
error
;
}
}
asmlinkage
long
sys_lstat64
(
char
__user
*
filename
,
struct
stat64
__user
*
statbuf
)
SYSCALL_DEFINE2
(
lstat64
,
char
__user
*
,
filename
,
struct
stat64
__user
*
,
statbuf
)
{
{
struct
kstat
stat
;
struct
kstat
stat
;
int
error
=
vfs_lstat
(
filename
,
&
stat
);
int
error
=
vfs_lstat
(
filename
,
&
stat
);
...
@@ -385,7 +388,8 @@ asmlinkage long sys_lstat64(char __user * filename, struct stat64 __user * statb
...
@@ -385,7 +388,8 @@ asmlinkage long sys_lstat64(char __user * filename, struct stat64 __user * statb
return
error
;
return
error
;
}
}
asmlinkage
long
sys_fstat64
(
unsigned
long
fd
,
struct
stat64
__user
*
statbuf
)
SYSCALL_DEFINE2
(
fstat64
,
unsigned
long
,
fd
,
struct
stat64
__user
*
,
statbuf
)
{
{
struct
kstat
stat
;
struct
kstat
stat
;
int
error
=
vfs_fstat
(
fd
,
&
stat
);
int
error
=
vfs_fstat
(
fd
,
&
stat
);
...
...
fs/super.c
View file @
257ac264
...
@@ -544,7 +544,7 @@ struct super_block * user_get_super(dev_t dev)
...
@@ -544,7 +544,7 @@ struct super_block * user_get_super(dev_t dev)
return
NULL
;
return
NULL
;
}
}
asmlinkage
long
sys_ustat
(
unsigned
dev
,
struct
ustat
__user
*
ubuf
)
SYSCALL_DEFINE2
(
ustat
,
unsigned
,
dev
,
struct
ustat
__user
*
,
ubuf
)
{
{
struct
super_block
*
s
;
struct
super_block
*
s
;
struct
ustat
tmp
;
struct
ustat
tmp
;
...
...
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