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
2a3f7d06
Commit
2a3f7d06
authored
Sep 02, 2002
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge home.transmeta.com:/home/torvalds/v2.5/linux
into home.transmeta.com:/home/torvalds/v2.5/sigio
parents
eca56747
1add9f7a
Changes
21
Show whitespace changes
Inline
Side-by-side
Showing
21 changed files
with
147 additions
and
168 deletions
+147
-168
drivers/char/tty_io.c
drivers/char/tty_io.c
+3
-9
drivers/net/tun.c
drivers/net/tun.c
+3
-5
fs/Makefile
fs/Makefile
+2
-1
fs/dnotify.c
fs/dnotify.c
+10
-14
fs/fcntl.c
fs/fcntl.c
+93
-27
fs/file_table.c
fs/file_table.c
+1
-0
fs/locks.c
fs/locks.c
+2
-10
include/linux/fs.h
include/linux/fs.h
+5
-0
include/net/inet_common.h
include/net/inet_common.h
+0
-3
include/net/sock.h
include/net/sock.h
+1
-4
kernel/futex.c
kernel/futex.c
+8
-3
net/core/sock.c
net/core/sock.c
+7
-29
net/econet/af_econet.c
net/econet/af_econet.c
+2
-5
net/ipv4/af_inet.c
net/ipv4/af_inet.c
+2
-6
net/ipv4/tcp_input.c
net/ipv4/tcp_input.c
+1
-7
net/ipv4/tcp_minisocks.c
net/ipv4/tcp_minisocks.c
+0
-1
net/ipv6/af_inet6.c
net/ipv6/af_inet6.c
+2
-7
net/packet/af_packet.c
net/packet/af_packet.c
+2
-6
net/socket.c
net/socket.c
+0
-18
net/wanrouter/af_wanpipe.c
net/wanrouter/af_wanpipe.c
+2
-6
net/x25/x25_in.c
net/x25/x25_in.c
+1
-7
No files found.
drivers/char/tty_io.c
View file @
2a3f7d06
...
@@ -1458,15 +1458,9 @@ static int tty_fasync(int fd, struct file * filp, int on)
...
@@ -1458,15 +1458,9 @@ static int tty_fasync(int fd, struct file * filp, int on)
if
(
on
)
{
if
(
on
)
{
if
(
!
waitqueue_active
(
&
tty
->
read_wait
))
if
(
!
waitqueue_active
(
&
tty
->
read_wait
))
tty
->
minimum_to_wake
=
1
;
tty
->
minimum_to_wake
=
1
;
if
(
filp
->
f_owner
.
pid
==
0
)
{
retval
=
f_setown
(
filp
,
(
-
tty
->
pgrp
)
?
:
current
->
pid
,
0
);
retval
=
security_ops
->
file_set_fowner
(
filp
);
if
(
retval
)
if
(
retval
)
return
retval
;
return
retval
;
filp
->
f_owner
.
pid
=
(
-
tty
->
pgrp
)
?
:
current
->
pid
;
filp
->
f_owner
.
uid
=
current
->
uid
;
filp
->
f_owner
.
euid
=
current
->
euid
;
}
}
else
{
}
else
{
if
(
!
tty
->
fasync
&&
!
waitqueue_active
(
&
tty
->
read_wait
))
if
(
!
tty
->
fasync
&&
!
waitqueue_active
(
&
tty
->
read_wait
))
tty
->
minimum_to_wake
=
N_TTY_BUF_SIZE
;
tty
->
minimum_to_wake
=
N_TTY_BUF_SIZE
;
...
...
drivers/net/tun.c
View file @
2a3f7d06
...
@@ -513,12 +513,10 @@ static int tun_chr_fasync(int fd, struct file *file, int on)
...
@@ -513,12 +513,10 @@ static int tun_chr_fasync(int fd, struct file *file, int on)
return
ret
;
return
ret
;
if
(
on
)
{
if
(
on
)
{
ret
=
f_setown
(
file
,
current
->
pid
,
0
);
if
(
ret
)
return
ret
;
tun
->
flags
|=
TUN_FASYNC
;
tun
->
flags
|=
TUN_FASYNC
;
if
(
!
file
->
f_owner
.
pid
)
{
file
->
f_owner
.
pid
=
current
->
pid
;
file
->
f_owner
.
uid
=
current
->
uid
;
file
->
f_owner
.
euid
=
current
->
euid
;
}
}
else
}
else
tun
->
flags
&=
~
TUN_FASYNC
;
tun
->
flags
&=
~
TUN_FASYNC
;
...
...
fs/Makefile
View file @
2a3f7d06
...
@@ -7,7 +7,8 @@
...
@@ -7,7 +7,8 @@
O_TARGET
:=
fs.o
O_TARGET
:=
fs.o
export-objs
:=
open.o dcache.o buffer.o bio.o inode.o dquot.o mpage.o aio.o
export-objs
:=
open.o dcache.o buffer.o bio.o inode.o dquot.o mpage.o aio.o
\
fcntl.o
obj-y
:=
open.o read_write.o devices.o file_table.o buffer.o
\
obj-y
:=
open.o read_write.o devices.o file_table.o buffer.o
\
bio.o super.o block_dev.o char_dev.o stat.o exec.o pipe.o
\
bio.o super.o block_dev.o char_dev.o stat.o exec.o pipe.o
\
...
...
fs/dnotify.c
View file @
2a3f7d06
...
@@ -68,7 +68,7 @@ int fcntl_dirnotify(int fd, struct file *filp, unsigned long arg)
...
@@ -68,7 +68,7 @@ int fcntl_dirnotify(int fd, struct file *filp, unsigned long arg)
struct
dnotify_struct
**
prev
;
struct
dnotify_struct
**
prev
;
struct
inode
*
inode
;
struct
inode
*
inode
;
fl_owner_t
id
=
current
->
files
;
fl_owner_t
id
=
current
->
files
;
int
error
;
int
error
=
0
;
if
((
arg
&
~
DN_MULTISHOT
)
==
0
)
{
if
((
arg
&
~
DN_MULTISHOT
)
==
0
)
{
dnotify_flush
(
filp
,
id
);
dnotify_flush
(
filp
,
id
);
...
@@ -89,21 +89,15 @@ int fcntl_dirnotify(int fd, struct file *filp, unsigned long arg)
...
@@ -89,21 +89,15 @@ int fcntl_dirnotify(int fd, struct file *filp, unsigned long arg)
odn
->
dn_fd
=
fd
;
odn
->
dn_fd
=
fd
;
odn
->
dn_mask
|=
arg
;
odn
->
dn_mask
|=
arg
;
inode
->
i_dnotify_mask
|=
arg
&
~
DN_MULTISHOT
;
inode
->
i_dnotify_mask
|=
arg
&
~
DN_MULTISHOT
;
kmem_cache_free
(
dn_cache
,
dn
);
goto
out_free
;
goto
out
;
}
}
prev
=
&
odn
->
dn_next
;
prev
=
&
odn
->
dn_next
;
}
}
error
=
security_ops
->
file_set_fowner
(
filp
);
error
=
f_setown
(
filp
,
current
->
pid
,
1
);
if
(
error
)
{
if
(
error
)
write_unlock
(
&
dn_lock
);
goto
out_free
;
return
error
;
}
filp
->
f_owner
.
pid
=
current
->
pid
;
filp
->
f_owner
.
uid
=
current
->
uid
;
filp
->
f_owner
.
euid
=
current
->
euid
;
dn
->
dn_mask
=
arg
;
dn
->
dn_mask
=
arg
;
dn
->
dn_fd
=
fd
;
dn
->
dn_fd
=
fd
;
dn
->
dn_filp
=
filp
;
dn
->
dn_filp
=
filp
;
...
@@ -113,7 +107,10 @@ int fcntl_dirnotify(int fd, struct file *filp, unsigned long arg)
...
@@ -113,7 +107,10 @@ int fcntl_dirnotify(int fd, struct file *filp, unsigned long arg)
inode
->
i_dnotify
=
dn
;
inode
->
i_dnotify
=
dn
;
out:
out:
write_unlock
(
&
dn_lock
);
write_unlock
(
&
dn_lock
);
return
0
;
return
error
;
out_free:
kmem_cache_free
(
dn_cache
,
dn
);
goto
out
;
}
}
void
__inode_dir_notify
(
struct
inode
*
inode
,
unsigned
long
event
)
void
__inode_dir_notify
(
struct
inode
*
inode
,
unsigned
long
event
)
...
@@ -131,7 +128,6 @@ void __inode_dir_notify(struct inode *inode, unsigned long event)
...
@@ -131,7 +128,6 @@ void __inode_dir_notify(struct inode *inode, unsigned long event)
continue
;
continue
;
}
}
fown
=
&
dn
->
dn_filp
->
f_owner
;
fown
=
&
dn
->
dn_filp
->
f_owner
;
if
(
fown
->
pid
)
send_sigio
(
fown
,
dn
->
dn_fd
,
POLL_MSG
);
send_sigio
(
fown
,
dn
->
dn_fd
,
POLL_MSG
);
if
(
dn
->
dn_mask
&
DN_MULTISHOT
)
if
(
dn
->
dn_mask
&
DN_MULTISHOT
)
prev
=
&
dn
->
dn_next
;
prev
=
&
dn
->
dn_next
;
...
...
fs/fcntl.c
View file @
2a3f7d06
...
@@ -11,13 +11,13 @@
...
@@ -11,13 +11,13 @@
#include <linux/smp_lock.h>
#include <linux/smp_lock.h>
#include <linux/slab.h>
#include <linux/slab.h>
#include <linux/iobuf.h>
#include <linux/iobuf.h>
#include <linux/module.h>
#include <linux/security.h>
#include <linux/security.h>
#include <asm/poll.h>
#include <asm/poll.h>
#include <asm/siginfo.h>
#include <asm/siginfo.h>
#include <asm/uaccess.h>
#include <asm/uaccess.h>
extern
int
sock_fcntl
(
struct
file
*
,
unsigned
int
cmd
,
unsigned
long
arg
);
extern
int
fcntl_setlease
(
unsigned
int
fd
,
struct
file
*
filp
,
long
arg
);
extern
int
fcntl_setlease
(
unsigned
int
fd
,
struct
file
*
filp
,
long
arg
);
extern
int
fcntl_getlease
(
struct
file
*
filp
);
extern
int
fcntl_getlease
(
struct
file
*
filp
);
...
@@ -259,6 +259,35 @@ static int setfl(int fd, struct file * filp, unsigned long arg)
...
@@ -259,6 +259,35 @@ static int setfl(int fd, struct file * filp, unsigned long arg)
return
error
;
return
error
;
}
}
static
void
f_modown
(
struct
file
*
filp
,
unsigned
long
pid
,
uid_t
uid
,
uid_t
euid
,
int
force
)
{
write_lock_irq
(
&
filp
->
f_owner
.
lock
);
if
(
force
||
!
filp
->
f_owner
.
pid
)
{
filp
->
f_owner
.
pid
=
pid
;
filp
->
f_owner
.
uid
=
uid
;
filp
->
f_owner
.
euid
=
euid
;
}
write_unlock_irq
(
&
filp
->
f_owner
.
lock
);
}
int
f_setown
(
struct
file
*
filp
,
unsigned
long
arg
,
int
force
)
{
int
err
;
err
=
security_ops
->
file_set_fowner
(
filp
);
if
(
err
)
return
err
;
f_modown
(
filp
,
arg
,
current
->
uid
,
current
->
euid
,
force
);
return
0
;
}
void
f_delown
(
struct
file
*
filp
)
{
f_modown
(
filp
,
0
,
0
,
0
,
1
);
}
static
long
do_fcntl
(
unsigned
int
fd
,
unsigned
int
cmd
,
static
long
do_fcntl
(
unsigned
int
fd
,
unsigned
int
cmd
,
unsigned
long
arg
,
struct
file
*
filp
)
unsigned
long
arg
,
struct
file
*
filp
)
{
{
...
@@ -302,21 +331,7 @@ static long do_fcntl(unsigned int fd, unsigned int cmd,
...
@@ -302,21 +331,7 @@ static long do_fcntl(unsigned int fd, unsigned int cmd,
err
=
filp
->
f_owner
.
pid
;
err
=
filp
->
f_owner
.
pid
;
break
;
break
;
case
F_SETOWN
:
case
F_SETOWN
:
lock_kernel
();
err
=
f_setown
(
filp
,
arg
,
1
);
err
=
security_ops
->
file_set_fowner
(
filp
);
if
(
err
)
{
unlock_kernel
();
break
;
}
filp
->
f_owner
.
pid
=
arg
;
filp
->
f_owner
.
uid
=
current
->
uid
;
filp
->
f_owner
.
euid
=
current
->
euid
;
err
=
0
;
if
(
S_ISSOCK
(
filp
->
f_dentry
->
d_inode
->
i_mode
))
err
=
sock_fcntl
(
filp
,
F_SETOWN
,
arg
);
unlock_kernel
();
break
;
break
;
case
F_GETSIG
:
case
F_GETSIG
:
err
=
filp
->
f_owner
.
signum
;
err
=
filp
->
f_owner
.
signum
;
...
@@ -339,10 +354,6 @@ static long do_fcntl(unsigned int fd, unsigned int cmd,
...
@@ -339,10 +354,6 @@ static long do_fcntl(unsigned int fd, unsigned int cmd,
err
=
fcntl_dirnotify
(
fd
,
filp
,
arg
);
err
=
fcntl_dirnotify
(
fd
,
filp
,
arg
);
break
;
break
;
default:
default:
/* sockets need a few special fcntls. */
err
=
-
EINVAL
;
if
(
S_ISSOCK
(
filp
->
f_dentry
->
d_inode
->
i_mode
))
err
=
sock_fcntl
(
filp
,
cmd
,
arg
);
break
;
break
;
}
}
...
@@ -418,14 +429,20 @@ static long band_table[NSIGPOLL] = {
...
@@ -418,14 +429,20 @@ static long band_table[NSIGPOLL] = {
POLLHUP
|
POLLERR
/* POLL_HUP */
POLLHUP
|
POLLERR
/* POLL_HUP */
};
};
static
inline
int
sigio_perm
(
struct
task_struct
*
p
,
struct
fown_struct
*
fown
)
{
return
((
fown
->
euid
==
0
)
||
(
fown
->
euid
==
p
->
suid
)
||
(
fown
->
euid
==
p
->
uid
)
||
(
fown
->
uid
==
p
->
suid
)
||
(
fown
->
uid
==
p
->
uid
));
}
static
void
send_sigio_to_task
(
struct
task_struct
*
p
,
static
void
send_sigio_to_task
(
struct
task_struct
*
p
,
struct
fown_struct
*
fown
,
struct
fown_struct
*
fown
,
int
fd
,
int
fd
,
int
reason
)
int
reason
)
{
{
if
((
fown
->
euid
!=
0
)
&&
if
(
!
sigio_perm
(
p
,
fown
))
(
fown
->
euid
^
p
->
suid
)
&&
(
fown
->
euid
^
p
->
uid
)
&&
(
fown
->
uid
^
p
->
suid
)
&&
(
fown
->
uid
^
p
->
uid
))
return
;
return
;
if
(
security_ops
->
file_send_sigiotask
(
p
,
fown
,
fd
,
reason
))
if
(
security_ops
->
file_send_sigiotask
(
p
,
fown
,
fd
,
reason
))
...
@@ -464,12 +481,17 @@ static void send_sigio_to_task(struct task_struct *p,
...
@@ -464,12 +481,17 @@ static void send_sigio_to_task(struct task_struct *p,
void
send_sigio
(
struct
fown_struct
*
fown
,
int
fd
,
int
band
)
void
send_sigio
(
struct
fown_struct
*
fown
,
int
fd
,
int
band
)
{
{
struct
task_struct
*
p
;
struct
task_struct
*
p
;
int
pid
=
fown
->
pid
;
int
pid
;
read_lock
(
&
fown
->
lock
);
pid
=
fown
->
pid
;
if
(
!
pid
)
goto
out_unlock_fown
;
read_lock
(
&
tasklist_lock
);
read_lock
(
&
tasklist_lock
);
if
(
(
pid
>
0
)
&&
(
p
=
find_task_by_pid
(
pid
))
)
{
if
(
(
pid
>
0
)
&&
(
p
=
find_task_by_pid
(
pid
))
)
{
send_sigio_to_task
(
p
,
fown
,
fd
,
band
);
send_sigio_to_task
(
p
,
fown
,
fd
,
band
);
goto
out
;
goto
out
_unlock_task
;
}
}
for_each_task
(
p
)
{
for_each_task
(
p
)
{
int
match
=
p
->
pid
;
int
match
=
p
->
pid
;
...
@@ -479,8 +501,49 @@ void send_sigio(struct fown_struct *fown, int fd, int band)
...
@@ -479,8 +501,49 @@ void send_sigio(struct fown_struct *fown, int fd, int band)
continue
;
continue
;
send_sigio_to_task
(
p
,
fown
,
fd
,
band
);
send_sigio_to_task
(
p
,
fown
,
fd
,
band
);
}
}
out:
out_unlock_task:
read_unlock
(
&
tasklist_lock
);
out_unlock_fown:
read_unlock
(
&
fown
->
lock
);
}
static
void
send_sigurg_to_task
(
struct
task_struct
*
p
,
struct
fown_struct
*
fown
)
{
if
(
sigio_perm
(
p
,
fown
))
send_sig
(
SIGURG
,
p
,
1
);
}
int
send_sigurg
(
struct
fown_struct
*
fown
)
{
struct
task_struct
*
p
;
int
pid
,
ret
=
0
;
read_lock
(
&
fown
->
lock
);
pid
=
fown
->
pid
;
if
(
!
pid
)
goto
out_unlock_fown
;
ret
=
1
;
read_lock
(
&
tasklist_lock
);
if
((
pid
>
0
)
&&
(
p
=
find_task_by_pid
(
pid
)))
{
send_sigurg_to_task
(
p
,
fown
);
goto
out_unlock_task
;
}
for_each_task
(
p
)
{
int
match
=
p
->
pid
;
if
(
pid
<
0
)
match
=
-
p
->
pgrp
;
if
(
pid
!=
match
)
continue
;
send_sigurg_to_task
(
p
,
fown
);
}
out_unlock_task:
read_unlock
(
&
tasklist_lock
);
read_unlock
(
&
tasklist_lock
);
out_unlock_fown:
read_unlock
(
&
fown
->
lock
);
return
ret
;
}
}
static
rwlock_t
fasync_lock
=
RW_LOCK_UNLOCKED
;
static
rwlock_t
fasync_lock
=
RW_LOCK_UNLOCKED
;
...
@@ -543,7 +606,7 @@ void __kill_fasync(struct fasync_struct *fa, int sig, int band)
...
@@ -543,7 +606,7 @@ void __kill_fasync(struct fasync_struct *fa, int sig, int band)
/* Don't send SIGURG to processes which have not set a
/* Don't send SIGURG to processes which have not set a
queued signum: SIGURG has its own default signalling
queued signum: SIGURG has its own default signalling
mechanism. */
mechanism. */
if
(
fown
->
pid
&&
!
(
sig
==
SIGURG
&&
fown
->
signum
==
0
))
if
(
!
(
sig
==
SIGURG
&&
fown
->
signum
==
0
))
send_sigio
(
fown
,
fa
->
fa_fd
,
band
);
send_sigio
(
fown
,
fa
->
fa_fd
,
band
);
fa
=
fa
->
fa_next
;
fa
=
fa
->
fa_next
;
}
}
...
@@ -566,3 +629,6 @@ static int __init fasync_init(void)
...
@@ -566,3 +629,6 @@ static int __init fasync_init(void)
}
}
module_init
(
fasync_init
)
module_init
(
fasync_init
)
EXPORT_SYMBOL
(
f_setown
);
EXPORT_SYMBOL
(
f_delown
);
fs/file_table.c
View file @
2a3f7d06
...
@@ -54,6 +54,7 @@ struct file * get_empty_filp(void)
...
@@ -54,6 +54,7 @@ struct file * get_empty_filp(void)
f
->
f_version
=
++
event
;
f
->
f_version
=
++
event
;
f
->
f_uid
=
current
->
fsuid
;
f
->
f_uid
=
current
->
fsuid
;
f
->
f_gid
=
current
->
fsgid
;
f
->
f_gid
=
current
->
fsgid
;
f
->
f_owner
.
lock
=
RW_LOCK_UNLOCKED
;
list_add
(
&
f
->
f_list
,
&
anon_list
);
list_add
(
&
f
->
f_list
,
&
anon_list
);
file_list_unlock
();
file_list_unlock
();
return
f
;
return
f
;
...
...
fs/locks.c
View file @
2a3f7d06
...
@@ -997,9 +997,7 @@ static int lease_modify(struct file_lock **before, int arg)
...
@@ -997,9 +997,7 @@ static int lease_modify(struct file_lock **before, int arg)
if
(
arg
==
F_UNLCK
)
{
if
(
arg
==
F_UNLCK
)
{
struct
file
*
filp
=
fl
->
fl_file
;
struct
file
*
filp
=
fl
->
fl_file
;
filp
->
f_owner
.
pid
=
0
;
f_delown
(
filp
);
filp
->
f_owner
.
uid
=
0
;
filp
->
f_owner
.
euid
=
0
;
filp
->
f_owner
.
signum
=
0
;
filp
->
f_owner
.
signum
=
0
;
locks_delete_lock
(
before
);
locks_delete_lock
(
before
);
}
}
...
@@ -1277,13 +1275,7 @@ int fcntl_setlease(unsigned int fd, struct file *filp, long arg)
...
@@ -1277,13 +1275,7 @@ int fcntl_setlease(unsigned int fd, struct file *filp, long arg)
*
before
=
fl
;
*
before
=
fl
;
list_add
(
&
fl
->
fl_link
,
&
file_lock_list
);
list_add
(
&
fl
->
fl_link
,
&
file_lock_list
);
error
=
security_ops
->
file_set_fowner
(
filp
);
error
=
f_setown
(
filp
,
current
->
pid
,
1
);
if
(
error
)
goto
out_unlock
;
filp
->
f_owner
.
pid
=
current
->
pid
;
filp
->
f_owner
.
uid
=
current
->
uid
;
filp
->
f_owner
.
euid
=
current
->
euid
;
out_unlock:
out_unlock:
unlock_kernel
();
unlock_kernel
();
return
error
;
return
error
;
...
...
include/linux/fs.h
View file @
2a3f7d06
...
@@ -432,6 +432,7 @@ static inline struct inode *SOCK_INODE(struct socket *socket)
...
@@ -432,6 +432,7 @@ static inline struct inode *SOCK_INODE(struct socket *socket)
#include <linux/efs_fs_i.h>
#include <linux/efs_fs_i.h>
struct
fown_struct
{
struct
fown_struct
{
rwlock_t
lock
;
/* protects pid, uid, euid fields */
int
pid
;
/* pid or -pgrp where SIGIO should be sent */
int
pid
;
/* pid or -pgrp where SIGIO should be sent */
uid_t
uid
,
euid
;
/* uid/euid of process setting the owner */
uid_t
uid
,
euid
;
/* uid/euid of process setting the owner */
int
signum
;
/* posix.1b rt signal to be delivered on IO */
int
signum
;
/* posix.1b rt signal to be delivered on IO */
...
@@ -615,6 +616,10 @@ extern void kill_fasync(struct fasync_struct **, int, int);
...
@@ -615,6 +616,10 @@ extern void kill_fasync(struct fasync_struct **, int, int);
/* only for net: no internal synchronization */
/* only for net: no internal synchronization */
extern
void
__kill_fasync
(
struct
fasync_struct
*
,
int
,
int
);
extern
void
__kill_fasync
(
struct
fasync_struct
*
,
int
,
int
);
extern
int
f_setown
(
struct
file
*
filp
,
unsigned
long
arg
,
int
force
);
extern
void
f_delown
(
struct
file
*
filp
);
extern
int
send_sigurg
(
struct
fown_struct
*
fown
);
/*
/*
* Umount options
* Umount options
*/
*/
...
...
include/net/inet_common.h
View file @
2a3f7d06
...
@@ -34,9 +34,6 @@ extern int inet_setsockopt(struct socket *sock, int level,
...
@@ -34,9 +34,6 @@ extern int inet_setsockopt(struct socket *sock, int level,
extern
int
inet_getsockopt
(
struct
socket
*
sock
,
int
level
,
extern
int
inet_getsockopt
(
struct
socket
*
sock
,
int
level
,
int
optname
,
char
*
optval
,
int
optname
,
char
*
optval
,
int
*
optlen
);
int
*
optlen
);
extern
int
inet_fcntl
(
struct
socket
*
sock
,
unsigned
int
cmd
,
unsigned
long
arg
);
extern
int
inet_listen
(
struct
socket
*
sock
,
int
backlog
);
extern
int
inet_listen
(
struct
socket
*
sock
,
int
backlog
);
extern
void
inet_sock_release
(
struct
sock
*
sk
);
extern
void
inet_sock_release
(
struct
sock
*
sk
);
...
...
include/net/sock.h
View file @
2a3f7d06
...
@@ -132,7 +132,6 @@ struct sock {
...
@@ -132,7 +132,6 @@ struct sock {
unsigned
char
rcvtstamp
;
unsigned
char
rcvtstamp
;
unsigned
char
no_largesend
;
unsigned
char
no_largesend
;
int
route_caps
;
int
route_caps
;
int
proc
;
unsigned
long
lingertime
;
unsigned
long
lingertime
;
int
hashent
;
int
hashent
;
...
@@ -292,7 +291,6 @@ static __inline__ void sock_prot_dec_use(struct proto *prot)
...
@@ -292,7 +291,6 @@ static __inline__ void sock_prot_dec_use(struct proto *prot)
#define SOCK_BINDADDR_LOCK 4
#define SOCK_BINDADDR_LOCK 4
#define SOCK_BINDPORT_LOCK 8
#define SOCK_BINDPORT_LOCK 8
#include <linux/fs.h>
/* just for inode - yeuch.*/
/* Used by processes to "lock" a socket state, so that
/* Used by processes to "lock" a socket state, so that
...
@@ -362,6 +360,7 @@ extern struct sk_buff *sock_alloc_send_pskb(struct sock *sk,
...
@@ -362,6 +360,7 @@ extern struct sk_buff *sock_alloc_send_pskb(struct sock *sk,
int
*
errcode
);
int
*
errcode
);
extern
void
*
sock_kmalloc
(
struct
sock
*
sk
,
int
size
,
int
priority
);
extern
void
*
sock_kmalloc
(
struct
sock
*
sk
,
int
size
,
int
priority
);
extern
void
sock_kfree_s
(
struct
sock
*
sk
,
void
*
mem
,
int
size
);
extern
void
sock_kfree_s
(
struct
sock
*
sk
,
void
*
mem
,
int
size
);
extern
void
sk_send_sigurg
(
struct
sock
*
sk
);
/*
/*
* Functions to fill in entries in struct proto_ops when a protocol
* Functions to fill in entries in struct proto_ops when a protocol
...
@@ -388,8 +387,6 @@ extern int sock_no_getsockopt(struct socket *, int , int,
...
@@ -388,8 +387,6 @@ extern int sock_no_getsockopt(struct socket *, int , int,
char
*
,
int
*
);
char
*
,
int
*
);
extern
int
sock_no_setsockopt
(
struct
socket
*
,
int
,
int
,
extern
int
sock_no_setsockopt
(
struct
socket
*
,
int
,
int
,
char
*
,
int
);
char
*
,
int
);
extern
int
sock_no_fcntl
(
struct
socket
*
,
unsigned
int
,
unsigned
long
);
extern
int
sock_no_sendmsg
(
struct
socket
*
,
extern
int
sock_no_sendmsg
(
struct
socket
*
,
struct
msghdr
*
,
int
,
struct
msghdr
*
,
int
,
struct
scm_cookie
*
);
struct
scm_cookie
*
);
...
...
kernel/futex.c
View file @
2a3f7d06
...
@@ -276,9 +276,14 @@ static int futex_fd(struct list_head *head,
...
@@ -276,9 +276,14 @@ static int futex_fd(struct list_head *head,
filp
->
f_dentry
=
dget
(
futex_mnt
->
mnt_root
);
filp
->
f_dentry
=
dget
(
futex_mnt
->
mnt_root
);
if
(
signal
)
{
if
(
signal
)
{
filp
->
f_owner
.
pid
=
current
->
tgid
;
int
ret
;
filp
->
f_owner
.
uid
=
current
->
uid
;
filp
->
f_owner
.
euid
=
current
->
euid
;
ret
=
f_setown
(
filp
,
current
->
tgid
,
1
);
if
(
ret
)
{
put_unused_fd
(
fd
);
put_filp
(
filp
);
return
ret
;
}
filp
->
f_owner
.
signum
=
signal
;
filp
->
f_owner
.
signum
=
signal
;
}
}
...
...
net/core/sock.c
View file @
2a3f7d06
...
@@ -103,7 +103,6 @@
...
@@ -103,7 +103,6 @@
#include <linux/string.h>
#include <linux/string.h>
#include <linux/sockios.h>
#include <linux/sockios.h>
#include <linux/net.h>
#include <linux/net.h>
#include <linux/fcntl.h>
#include <linux/mm.h>
#include <linux/mm.h>
#include <linux/slab.h>
#include <linux/slab.h>
#include <linux/interrupt.h>
#include <linux/interrupt.h>
...
@@ -1048,34 +1047,6 @@ int sock_no_getsockopt(struct socket *sock, int level, int optname,
...
@@ -1048,34 +1047,6 @@ int sock_no_getsockopt(struct socket *sock, int level, int optname,
return
-
EOPNOTSUPP
;
return
-
EOPNOTSUPP
;
}
}
/*
* Note: if you add something that sleeps here then change sock_fcntl()
* to do proper fd locking.
*/
int
sock_no_fcntl
(
struct
socket
*
sock
,
unsigned
int
cmd
,
unsigned
long
arg
)
{
struct
sock
*
sk
=
sock
->
sk
;
switch
(
cmd
)
{
case
F_SETOWN
:
/*
* This is a little restrictive, but it's the only
* way to make sure that you can't send a sigurg to
* another process.
*/
if
(
current
->
pgrp
!=
-
arg
&&
current
->
pid
!=
arg
&&
!
capable
(
CAP_KILL
))
return
(
-
EPERM
);
sk
->
proc
=
arg
;
return
(
0
);
case
F_GETOWN
:
return
(
sk
->
proc
);
default:
return
(
-
EINVAL
);
}
}
int
sock_no_sendmsg
(
struct
socket
*
sock
,
struct
msghdr
*
m
,
int
flags
,
int
sock_no_sendmsg
(
struct
socket
*
sock
,
struct
msghdr
*
m
,
int
flags
,
struct
scm_cookie
*
scm
)
struct
scm_cookie
*
scm
)
{
{
...
@@ -1179,6 +1150,13 @@ void sock_def_destruct(struct sock *sk)
...
@@ -1179,6 +1150,13 @@ void sock_def_destruct(struct sock *sk)
kfree
(
sk
->
protinfo
);
kfree
(
sk
->
protinfo
);
}
}
void
sk_send_sigurg
(
struct
sock
*
sk
)
{
if
(
sk
->
socket
&&
sk
->
socket
->
file
)
if
(
send_sigurg
(
&
sk
->
socket
->
file
->
f_owner
))
sk_wake_async
(
sk
,
3
,
POLL_PRI
);
}
void
sock_init_data
(
struct
socket
*
sock
,
struct
sock
*
sk
)
void
sock_init_data
(
struct
socket
*
sock
,
struct
sock
*
sk
)
{
{
skb_queue_head_init
(
&
sk
->
receive_queue
);
skb_queue_head_init
(
&
sk
->
receive_queue
);
...
...
net/econet/af_econet.c
View file @
2a3f7d06
...
@@ -651,13 +651,10 @@ static int econet_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg
...
@@ -651,13 +651,10 @@ static int econet_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg
case
SIOCSPGRP
:
case
SIOCSPGRP
:
if
(
get_user
(
pid
,
(
int
*
)
arg
))
if
(
get_user
(
pid
,
(
int
*
)
arg
))
return
-
EFAULT
;
return
-
EFAULT
;
if
(
current
->
pid
!=
pid
&&
current
->
pgrp
!=
-
pid
&&
!
capable
(
CAP_NET_ADMIN
))
return
f_setown
(
sock
->
file
,
pid
,
1
);
return
-
EPERM
;
sk
->
proc
=
pid
;
return
(
0
);
case
FIOGETOWN
:
case
FIOGETOWN
:
case
SIOCGPGRP
:
case
SIOCGPGRP
:
return
put_user
(
s
k
->
proc
,
(
int
*
)
arg
);
return
put_user
(
s
ock
->
file
->
f_owner
.
pid
,
(
int
*
)
arg
);
case
SIOCGSTAMP
:
case
SIOCGSTAMP
:
if
(
sk
->
stamp
.
tv_sec
==
0
)
if
(
sk
->
stamp
.
tv_sec
==
0
)
return
-
ENOENT
;
return
-
ENOENT
;
...
...
net/ipv4/af_inet.c
View file @
2a3f7d06
...
@@ -857,16 +857,12 @@ int inet_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg)
...
@@ -857,16 +857,12 @@ int inet_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg)
case
SIOCSPGRP
:
case
SIOCSPGRP
:
if
(
get_user
(
pid
,
(
int
*
)
arg
))
if
(
get_user
(
pid
,
(
int
*
)
arg
))
err
=
-
EFAULT
;
err
=
-
EFAULT
;
else
if
(
current
->
pid
!=
pid
&&
current
->
pgrp
!=
-
pid
&&
!
capable
(
CAP_NET_ADMIN
))
err
=
-
EPERM
;
else
else
sk
->
proc
=
pid
;
err
=
f_setown
(
sock
->
file
,
pid
,
1
)
;
break
;
break
;
case
FIOGETOWN
:
case
FIOGETOWN
:
case
SIOCGPGRP
:
case
SIOCGPGRP
:
err
=
put_user
(
s
k
->
proc
,
(
int
*
)
arg
);
err
=
put_user
(
s
ock
->
file
->
f_owner
.
pid
,
(
int
*
)
arg
);
break
;
break
;
case
SIOCGSTAMP
:
case
SIOCGSTAMP
:
if
(
!
sk
->
stamp
.
tv_sec
)
if
(
!
sk
->
stamp
.
tv_sec
)
...
...
net/ipv4/tcp_input.c
View file @
2a3f7d06
...
@@ -3103,13 +3103,7 @@ static void tcp_check_urg(struct sock * sk, struct tcphdr * th)
...
@@ -3103,13 +3103,7 @@ static void tcp_check_urg(struct sock * sk, struct tcphdr * th)
return
;
return
;
/* Tell the world about our new urgent pointer. */
/* Tell the world about our new urgent pointer. */
if
(
sk
->
proc
!=
0
)
{
sk_send_sigurg
(
sk
);
if
(
sk
->
proc
>
0
)
kill_proc
(
sk
->
proc
,
SIGURG
,
1
);
else
kill_pg
(
-
sk
->
proc
,
SIGURG
,
1
);
sk_wake_async
(
sk
,
3
,
POLL_PRI
);
}
/* We may be adding urgent data when the last byte read was
/* We may be adding urgent data when the last byte read was
* urgent. To do this requires some care. We cannot just ignore
* urgent. To do this requires some care. We cannot just ignore
...
...
net/ipv4/tcp_minisocks.c
View file @
2a3f7d06
...
@@ -676,7 +676,6 @@ struct sock *tcp_create_openreq_child(struct sock *sk, struct open_request *req,
...
@@ -676,7 +676,6 @@ struct sock *tcp_create_openreq_child(struct sock *sk, struct open_request *req,
newsk
->
done
=
0
;
newsk
->
done
=
0
;
newsk
->
userlocks
=
sk
->
userlocks
&
~
SOCK_BINDPORT_LOCK
;
newsk
->
userlocks
=
sk
->
userlocks
&
~
SOCK_BINDPORT_LOCK
;
newsk
->
proc
=
0
;
newsk
->
backlog
.
head
=
newsk
->
backlog
.
tail
=
NULL
;
newsk
->
backlog
.
head
=
newsk
->
backlog
.
tail
=
NULL
;
newsk
->
callback_lock
=
RW_LOCK_UNLOCKED
;
newsk
->
callback_lock
=
RW_LOCK_UNLOCKED
;
skb_queue_head_init
(
&
newsk
->
error_queue
);
skb_queue_head_init
(
&
newsk
->
error_queue
);
...
...
net/ipv6/af_inet6.c
View file @
2a3f7d06
...
@@ -463,15 +463,10 @@ int inet6_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg)
...
@@ -463,15 +463,10 @@ int inet6_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg)
case
SIOCSPGRP
:
case
SIOCSPGRP
:
if
(
get_user
(
pid
,
(
int
*
)
arg
))
if
(
get_user
(
pid
,
(
int
*
)
arg
))
return
-
EFAULT
;
return
-
EFAULT
;
/* see sock_no_fcntl */
return
f_setown
(
sock
->
file
,
pid
,
1
);
if
(
current
->
pid
!=
pid
&&
current
->
pgrp
!=
-
pid
&&
!
capable
(
CAP_NET_ADMIN
))
return
-
EPERM
;
sk
->
proc
=
pid
;
return
(
0
);
case
FIOGETOWN
:
case
FIOGETOWN
:
case
SIOCGPGRP
:
case
SIOCGPGRP
:
return
put_user
(
s
k
->
proc
,
(
int
*
)
arg
);
return
put_user
(
s
ock
->
file
->
f_owner
.
pid
,
(
int
*
)
arg
);
case
SIOCGSTAMP
:
case
SIOCGSTAMP
:
if
(
sk
->
stamp
.
tv_sec
==
0
)
if
(
sk
->
stamp
.
tv_sec
==
0
)
return
-
ENOENT
;
return
-
ENOENT
;
...
...
net/packet/af_packet.c
View file @
2a3f7d06
...
@@ -1463,15 +1463,11 @@ static int packet_ioctl(struct socket *sock, unsigned int cmd,
...
@@ -1463,15 +1463,11 @@ static int packet_ioctl(struct socket *sock, unsigned int cmd,
int
pid
;
int
pid
;
if
(
get_user
(
pid
,
(
int
*
)
arg
))
if
(
get_user
(
pid
,
(
int
*
)
arg
))
return
-
EFAULT
;
return
-
EFAULT
;
if
(
current
->
pid
!=
pid
&&
current
->
pgrp
!=
-
pid
&&
return
f_setown
(
sock
->
file
,
pid
,
1
);
!
capable
(
CAP_NET_ADMIN
))
return
-
EPERM
;
sk
->
proc
=
pid
;
break
;
}
}
case
FIOGETOWN
:
case
FIOGETOWN
:
case
SIOCGPGRP
:
case
SIOCGPGRP
:
return
put_user
(
s
k
->
proc
,
(
int
*
)
arg
);
return
put_user
(
s
ock
->
file
->
f_owner
.
pid
,
(
int
*
)
arg
);
case
SIOCGSTAMP
:
case
SIOCGSTAMP
:
if
(
sk
->
stamp
.
tv_sec
==
0
)
if
(
sk
->
stamp
.
tv_sec
==
0
)
return
-
ENOENT
;
return
-
ENOENT
;
...
...
net/socket.c
View file @
2a3f7d06
...
@@ -1516,24 +1516,6 @@ asmlinkage long sys_recvmsg(int fd, struct msghdr *msg, unsigned int flags)
...
@@ -1516,24 +1516,6 @@ asmlinkage long sys_recvmsg(int fd, struct msghdr *msg, unsigned int flags)
return
err
;
return
err
;
}
}
/*
* Perform a file control on a socket file descriptor.
*
* Doesn't acquire a fd lock, because no network fcntl
* function sleeps currently.
*/
int
sock_fcntl
(
struct
file
*
filp
,
unsigned
int
cmd
,
unsigned
long
arg
)
{
struct
socket
*
sock
;
sock
=
SOCKET_I
(
filp
->
f_dentry
->
d_inode
);
if
(
sock
&&
sock
->
ops
)
return
sock_no_fcntl
(
sock
,
cmd
,
arg
);
return
(
-
EINVAL
);
}
/* Argument list sizes for sys_socketcall */
/* Argument list sizes for sys_socketcall */
#define AL(x) ((x) * sizeof(unsigned long))
#define AL(x) ((x) * sizeof(unsigned long))
static
unsigned
char
nargs
[
18
]
=
{
AL
(
0
),
AL
(
3
),
AL
(
3
),
AL
(
3
),
AL
(
2
),
AL
(
3
),
static
unsigned
char
nargs
[
18
]
=
{
AL
(
0
),
AL
(
3
),
AL
(
3
),
AL
(
3
),
AL
(
2
),
AL
(
3
),
...
...
net/wanrouter/af_wanpipe.c
View file @
2a3f7d06
...
@@ -1876,14 +1876,10 @@ static int wanpipe_ioctl(struct socket *sock, unsigned int cmd, unsigned long ar
...
@@ -1876,14 +1876,10 @@ static int wanpipe_ioctl(struct socket *sock, unsigned int cmd, unsigned long ar
err
=
get_user
(
pid
,
(
int
*
)
arg
);
err
=
get_user
(
pid
,
(
int
*
)
arg
);
if
(
err
)
if
(
err
)
return
err
;
return
err
;
if
(
current
->
pid
!=
pid
&&
current
->
pgrp
!=
-
pid
&&
return
f_setown
(
sock
->
file
,
pid
,
1
);
!
capable
(
CAP_NET_ADMIN
))
return
-
EPERM
;
sk
->
proc
=
pid
;
return
(
0
);
case
FIOGETOWN
:
case
FIOGETOWN
:
case
SIOCGPGRP
:
case
SIOCGPGRP
:
return
put_user
(
s
k
->
proc
,
(
int
*
)
arg
);
return
put_user
(
s
ock
->
file
->
f_owner
.
pid
,
(
int
*
)
arg
);
case
SIOCGSTAMP
:
case
SIOCGSTAMP
:
if
(
sk
->
stamp
.
tv_sec
==
0
)
if
(
sk
->
stamp
.
tv_sec
==
0
)
return
-
ENOENT
;
return
-
ENOENT
;
...
...
net/x25/x25_in.c
View file @
2a3f7d06
...
@@ -283,13 +283,7 @@ static int x25_state3_machine(struct sock *sk, struct sk_buff *skb, int frametyp
...
@@ -283,13 +283,7 @@ static int x25_state3_machine(struct sock *sk, struct sk_buff *skb, int frametyp
skb_queue_tail
(
&
x25
->
interrupt_in_queue
,
skb
);
skb_queue_tail
(
&
x25
->
interrupt_in_queue
,
skb
);
queued
=
1
;
queued
=
1
;
}
}
if
(
sk
->
proc
!=
0
)
{
sk_send_sigurg
(
sk
);
if
(
sk
->
proc
>
0
)
kill_proc
(
sk
->
proc
,
SIGURG
,
1
);
else
kill_pg
(
-
sk
->
proc
,
SIGURG
,
1
);
sock_wake_async
(
sk
->
socket
,
3
,
POLL_PRI
);
}
x25_write_internal
(
sk
,
X25_INTERRUPT_CONFIRMATION
);
x25_write_internal
(
sk
,
X25_INTERRUPT_CONFIRMATION
);
break
;
break
;
...
...
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