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
232cebfb
Commit
232cebfb
authored
Sep 02, 2004
by
David S. Miller
Browse files
Options
Browse Files
Download
Plain Diff
Merge davem@nuts.davemloft.net:/disk1/BK/net-2.6
into kernel.bkbits.net:/home/davem/net-2.6
parents
7511efde
37cbd41d
Changes
28
Hide whitespace changes
Inline
Side-by-side
Showing
28 changed files
with
152 additions
and
176 deletions
+152
-176
arch/i386/kernel/apic.c
arch/i386/kernel/apic.c
+1
-1
arch/i386/kernel/i8259.c
arch/i386/kernel/i8259.c
+1
-1
drivers/block/DAC960.c
drivers/block/DAC960.c
+6
-1
drivers/char/tty_io.c
drivers/char/tty_io.c
+12
-18
drivers/net/wan/pc300_tty.c
drivers/net/wan/pc300_tty.c
+8
-2
drivers/net/wireless/atmel.c
drivers/net/wireless/atmel.c
+3
-2
drivers/pnp/interface.c
drivers/pnp/interface.c
+6
-4
drivers/pnp/isapnp/core.c
drivers/pnp/isapnp/core.c
+3
-1
drivers/pnp/pnpbios/core.c
drivers/pnp/pnpbios/core.c
+3
-1
drivers/pnp/pnpbios/proc.c
drivers/pnp/pnpbios/proc.c
+6
-2
drivers/video/aty/atyfb_base.c
drivers/video/aty/atyfb_base.c
+1
-0
fs/fcntl.c
fs/fcntl.c
+4
-8
fs/isofs/rock.c
fs/isofs/rock.c
+3
-1
fs/proc/base.c
fs/proc/base.c
+2
-3
include/linux/pid.h
include/linux/pid.h
+17
-27
include/linux/sched.h
include/linux/sched.h
+4
-5
kernel/capability.c
kernel/capability.c
+2
-4
kernel/exit.c
kernel/exit.c
+7
-19
kernel/fork.c
kernel/fork.c
+2
-3
kernel/pid.c
kernel/pid.c
+41
-47
kernel/signal.c
kernel/signal.c
+4
-8
kernel/sys.c
kernel/sys.c
+6
-10
lib/zlib_inflate/inflate.c
lib/zlib_inflate/inflate.c
+0
-2
mm/memory.c
mm/memory.c
+2
-0
net/ax25/af_ax25.c
net/ax25/af_ax25.c
+3
-0
sound/oss/emu10k1/midi.c
sound/oss/emu10k1/midi.c
+1
-2
sound/oss/maui.c
sound/oss/maui.c
+1
-2
sound/oss/v_midi.c
sound/oss/v_midi.c
+3
-2
No files found.
arch/i386/kernel/apic.c
View file @
232cebfb
...
...
@@ -1190,7 +1190,7 @@ asmlinkage void smp_error_interrupt(void)
6: Received illegal vector
7: Illegal register address
*/
printk
(
KERN_
INFO
"APIC error on CPU%d: %02lx(%02lx)
\n
"
,
printk
(
KERN_
DEBUG
"APIC error on CPU%d: %02lx(%02lx)
\n
"
,
smp_processor_id
(),
v
,
v1
);
irq_exit
();
}
...
...
arch/i386/kernel/i8259.c
View file @
232cebfb
...
...
@@ -226,7 +226,7 @@ void mask_and_ack_8259A(unsigned int irq)
* lets ACK and report it. [once per IRQ]
*/
if
(
!
(
spurious_irq_mask
&
irqmask
))
{
printk
(
"spurious 8259A interrupt: IRQ%d.
\n
"
,
irq
);
printk
(
KERN_DEBUG
"spurious 8259A interrupt: IRQ%d.
\n
"
,
irq
);
spurious_irq_mask
|=
irqmask
;
}
atomic_inc
(
&
irq_err_count
);
...
...
drivers/block/DAC960.c
View file @
232cebfb
...
...
@@ -288,12 +288,17 @@ static boolean DAC960_CreateAuxiliaryStructures(DAC960_Controller_T *Controller)
Controller
->
PCIDevice
,
DAC960_V2_ScatterGatherLimit
*
sizeof
(
DAC960_V2_ScatterGatherSegment_T
),
sizeof
(
DAC960_V2_ScatterGatherSegment_T
),
0
);
if
(
ScatterGatherPool
==
NULL
)
return
DAC960_Failure
(
Controller
,
"AUXILIARY STRUCTURE CREATION (SG)"
);
RequestSensePool
=
pci_pool_create
(
"DAC960_V2_RequestSense"
,
Controller
->
PCIDevice
,
sizeof
(
DAC960_SCSI_RequestSense_T
),
sizeof
(
int
),
0
);
if
(
ScatterGatherPool
==
NULL
||
RequestSensePool
==
NULL
)
if
(
RequestSensePool
==
NULL
)
{
pci_pool_destroy
(
ScatterGatherPool
);
return
DAC960_Failure
(
Controller
,
"AUXILIARY STRUCTURE CREATION (SG)"
);
}
Controller
->
ScatterGatherPool
=
ScatterGatherPool
;
Controller
->
V2
.
RequestSensePool
=
RequestSensePool
;
}
...
...
drivers/char/tty_io.c
View file @
232cebfb
...
...
@@ -424,7 +424,6 @@ void do_tty_hangup(void *data)
struct
file
*
cons_filp
=
NULL
;
struct
file
*
filp
,
*
f
=
NULL
;
struct
task_struct
*
p
;
struct
pid
*
pid
;
int
closecount
=
0
,
n
;
if
(
!
tty
)
...
...
@@ -495,8 +494,7 @@ void do_tty_hangup(void *data)
read_lock
(
&
tasklist_lock
);
if
(
tty
->
session
>
0
)
{
struct
list_head
*
l
;
for_each_task_pid
(
tty
->
session
,
PIDTYPE_SID
,
p
,
l
,
pid
)
{
do_each_task_pid
(
tty
->
session
,
PIDTYPE_SID
,
p
)
{
if
(
p
->
signal
->
tty
==
tty
)
p
->
signal
->
tty
=
NULL
;
if
(
!
p
->
signal
->
leader
)
...
...
@@ -505,7 +503,7 @@ void do_tty_hangup(void *data)
send_group_sig_info
(
SIGCONT
,
SEND_SIG_PRIV
,
p
);
if
(
tty
->
pgrp
>
0
)
p
->
signal
->
tty_old_pgrp
=
tty
->
pgrp
;
}
}
while_each_task_pid
(
tty
->
session
,
PIDTYPE_SID
,
p
);
}
read_unlock
(
&
tasklist_lock
);
...
...
@@ -577,8 +575,6 @@ void disassociate_ctty(int on_exit)
{
struct
tty_struct
*
tty
;
struct
task_struct
*
p
;
struct
list_head
*
l
;
struct
pid
*
pid
;
int
tty_pgrp
=
-
1
;
lock_kernel
();
...
...
@@ -607,8 +603,9 @@ void disassociate_ctty(int on_exit)
tty
->
pgrp
=
-
1
;
read_lock
(
&
tasklist_lock
);
for_each_task_pid
(
current
->
signal
->
session
,
PIDTYPE_SID
,
p
,
l
,
pid
)
do_each_task_pid
(
current
->
signal
->
session
,
PIDTYPE_SID
,
p
)
{
p
->
signal
->
tty
=
NULL
;
}
while_each_task_pid
(
current
->
signal
->
session
,
PIDTYPE_SID
,
p
);
read_unlock
(
&
tasklist_lock
);
unlock_kernel
();
}
...
...
@@ -1260,15 +1257,15 @@ static void release_dev(struct file * filp)
*/
if
(
tty_closing
||
o_tty_closing
)
{
struct
task_struct
*
p
;
struct
list_head
*
l
;
struct
pid
*
pid
;
read_lock
(
&
tasklist_lock
);
for_each_task_pid
(
tty
->
session
,
PIDTYPE_SID
,
p
,
l
,
pid
)
do_each_task_pid
(
tty
->
session
,
PIDTYPE_SID
,
p
)
{
p
->
signal
->
tty
=
NULL
;
}
while_each_task_pid
(
tty
->
session
,
PIDTYPE_SID
,
p
);
if
(
o_tty
)
for_each_task_pid
(
o_tty
->
session
,
PIDTYPE_SID
,
p
,
l
,
pid
)
do_each_task_pid
(
o_tty
->
session
,
PIDTYPE_SID
,
p
)
{
p
->
signal
->
tty
=
NULL
;
}
while_each_task_pid
(
o_tty
->
session
,
PIDTYPE_SID
,
p
);
read_unlock
(
&
tasklist_lock
);
}
...
...
@@ -1638,8 +1635,6 @@ static int fionbio(struct file *file, int __user *p)
static
int
tiocsctty
(
struct
tty_struct
*
tty
,
int
arg
)
{
struct
list_head
*
l
;
struct
pid
*
pid
;
task_t
*
p
;
if
(
current
->
signal
->
leader
&&
...
...
@@ -1662,8 +1657,9 @@ static int tiocsctty(struct tty_struct *tty, int arg)
*/
read_lock
(
&
tasklist_lock
);
for_each_task_pid
(
tty
->
session
,
PIDTYPE_SID
,
p
,
l
,
pid
)
do_each_task_pid
(
tty
->
session
,
PIDTYPE_SID
,
p
)
{
p
->
signal
->
tty
=
NULL
;
}
while_each_task_pid
(
tty
->
session
,
PIDTYPE_SID
,
p
);
read_unlock
(
&
tasklist_lock
);
}
else
return
-
EPERM
;
...
...
@@ -1970,8 +1966,6 @@ static void __do_SAK(void *arg)
#else
struct
tty_struct
*
tty
=
arg
;
struct
task_struct
*
p
;
struct
list_head
*
l
;
struct
pid
*
pid
;
int
session
;
int
i
;
struct
file
*
filp
;
...
...
@@ -1984,7 +1978,7 @@ static void __do_SAK(void *arg)
if
(
tty
->
driver
->
flush_buffer
)
tty
->
driver
->
flush_buffer
(
tty
);
read_lock
(
&
tasklist_lock
);
for_each_task_pid
(
session
,
PIDTYPE_SID
,
p
,
l
,
pid
)
{
do_each_task_pid
(
session
,
PIDTYPE_SID
,
p
)
{
if
(
p
->
signal
->
tty
==
tty
||
session
>
0
)
{
printk
(
KERN_NOTICE
"SAK: killed process %d"
" (%s): p->signal->session==tty->session
\n
"
,
...
...
@@ -2011,7 +2005,7 @@ static void __do_SAK(void *arg)
spin_unlock
(
&
p
->
files
->
file_lock
);
}
task_unlock
(
p
);
}
}
while_each_task_pid
(
session
,
PIDTYPE_SID
,
p
);
read_unlock
(
&
tasklist_lock
);
#endif
}
...
...
drivers/net/wan/pc300_tty.c
View file @
232cebfb
...
...
@@ -789,6 +789,10 @@ void cpc_tty_receive(pc300dev_t *pc300dev)
cpc_writel
(
card
->
hw
.
scabase
+
DRX_REG
(
EDAL
,
ch
),
RX_BD_ADDR
(
ch
,
pc300chan
->
rx_last_bd
));
}
if
(
new
)
{
kfree
(
new
);
new
=
NULL
;
}
return
;
}
...
...
@@ -834,7 +838,8 @@ void cpc_tty_receive(pc300dev_t *pc300dev)
cpc_tty
->
name
);
cpc_tty_rx_disc_frame
(
pc300chan
);
rx_len
=
0
;
kfree
((
unsigned
char
*
)
new
);
kfree
(
new
);
new
=
NULL
;
break
;
/* read next frame - while(1) */
}
...
...
@@ -843,7 +848,8 @@ void cpc_tty_receive(pc300dev_t *pc300dev)
cpc_tty_rx_disc_frame
(
pc300chan
);
stats
->
rx_dropped
++
;
rx_len
=
0
;
kfree
((
unsigned
char
*
)
new
);
kfree
(
new
);
new
=
NULL
;
break
;
/* read next frame - while(1) */
}
...
...
drivers/net/wireless/atmel.c
View file @
232cebfb
...
...
@@ -2430,12 +2430,13 @@ static int atmel_ioctl(struct net_device *dev, struct ifreq *rq, int cmd)
rc
=
-
ENOMEM
;
break
;
}
if
(
copy_from_user
(
new_firmware
,
com
.
data
,
com
.
len
))
{
kfree
(
new_firmware
);
rc
=
-
EFAULT
;
break
;
}
if
(
priv
->
firmware
)
kfree
(
priv
->
firmware
);
...
...
drivers/pnp/interface.c
View file @
232cebfb
...
...
@@ -240,12 +240,14 @@ static ssize_t pnp_show_current_resources(struct device *dmdev, char *buf)
{
struct
pnp_dev
*
dev
=
to_pnp_dev
(
dmdev
);
int
i
,
ret
;
pnp_info_buffer_t
*
buffer
=
(
pnp_info_buffer_t
*
)
pnp_alloc
(
sizeof
(
pnp_info_buffer_t
));
if
(
!
buffer
)
return
-
ENOMEM
;
pnp_info_buffer_t
*
buffer
;
if
(
!
dev
)
return
-
EINVAL
;
buffer
=
(
pnp_info_buffer_t
*
)
pnp_alloc
(
sizeof
(
pnp_info_buffer_t
));
if
(
!
buffer
)
return
-
ENOMEM
;
buffer
->
len
=
PAGE_SIZE
;
buffer
->
buffer
=
buf
;
buffer
->
curr
=
buffer
->
buffer
;
...
...
drivers/pnp/isapnp/core.c
View file @
232cebfb
...
...
@@ -655,8 +655,10 @@ static int __init isapnp_create_device(struct pnp_card *card,
if
((
dev
=
isapnp_parse_device
(
card
,
size
,
number
++
))
==
NULL
)
return
1
;
option
=
pnp_register_independent_option
(
dev
);
if
(
!
option
)
if
(
!
option
)
{
kfree
(
dev
);
return
1
;
}
pnp_add_card_device
(
card
,
dev
);
while
(
1
)
{
...
...
drivers/pnp/pnpbios/core.c
View file @
232cebfb
...
...
@@ -252,8 +252,10 @@ static int pnpbios_set_resources(struct pnp_dev * dev, struct pnp_resource_table
node
=
pnpbios_kmalloc
(
node_info
.
max_node_size
,
GFP_KERNEL
);
if
(
!
node
)
return
-
1
;
if
(
pnp_bios_get_dev_node
(
&
nodenum
,
(
char
)
PNPMODE_DYNAMIC
,
node
))
if
(
pnp_bios_get_dev_node
(
&
nodenum
,
(
char
)
PNPMODE_DYNAMIC
,
node
))
{
kfree
(
node
);
return
-
ENODEV
;
}
if
(
pnpbios_write_resources_to_node
(
res
,
node
)
<
0
)
{
kfree
(
node
);
return
-
1
;
...
...
drivers/pnp/pnpbios/proc.c
View file @
232cebfb
...
...
@@ -90,8 +90,10 @@ static int proc_read_escd(char *buf, char **start, off_t pos,
tmpbuf
=
pnpbios_kmalloc
(
escd
.
escd_size
,
GFP_KERNEL
);
if
(
!
tmpbuf
)
return
-
ENOMEM
;
if
(
pnp_bios_read_escd
(
tmpbuf
,
escd
.
nv_storage_base
))
if
(
pnp_bios_read_escd
(
tmpbuf
,
escd
.
nv_storage_base
))
{
kfree
(
tmpbuf
);
return
-
EIO
;
}
escd_size
=
(
unsigned
char
)(
tmpbuf
[
0
])
+
(
unsigned
char
)(
tmpbuf
[
1
])
*
256
;
...
...
@@ -168,8 +170,10 @@ static int proc_read_node(char *buf, char **start, off_t pos,
node
=
pnpbios_kmalloc
(
node_info
.
max_node_size
,
GFP_KERNEL
);
if
(
!
node
)
return
-
ENOMEM
;
if
(
pnp_bios_get_dev_node
(
&
nodenum
,
boot
,
node
))
if
(
pnp_bios_get_dev_node
(
&
nodenum
,
boot
,
node
))
{
kfree
(
node
);
return
-
EIO
;
}
len
=
node
->
size
-
sizeof
(
struct
pnp_bios_node
);
memcpy
(
buf
,
node
->
data
,
len
);
kfree
(
node
);
...
...
drivers/video/aty/atyfb_base.c
View file @
232cebfb
...
...
@@ -2374,6 +2374,7 @@ int __init atyfb_init(void)
}
}
#endif
/* CONFIG_ATARI */
kfree
(
info
);
return
0
;
}
...
...
fs/fcntl.c
View file @
232cebfb
...
...
@@ -497,11 +497,9 @@ void send_sigio(struct fown_struct *fown, int fd, int band)
send_sigio_to_task
(
p
,
fown
,
fd
,
band
);
}
}
else
{
struct
list_head
*
l
;
struct
pid
*
pidptr
;
for_each_task_pid
(
-
pid
,
PIDTYPE_PGID
,
p
,
l
,
pidptr
)
{
do_each_task_pid
(
-
pid
,
PIDTYPE_PGID
,
p
)
{
send_sigio_to_task
(
p
,
fown
,
fd
,
band
);
}
}
while_each_task_pid
(
-
pid
,
PIDTYPE_PGID
,
p
);
}
read_unlock
(
&
tasklist_lock
);
out_unlock_fown:
...
...
@@ -534,11 +532,9 @@ int send_sigurg(struct fown_struct *fown)
send_sigurg_to_task
(
p
,
fown
);
}
}
else
{
struct
list_head
*
l
;
struct
pid
*
pidptr
;
for_each_task_pid
(
-
pid
,
PIDTYPE_PGID
,
p
,
l
,
pidptr
)
{
do_each_task_pid
(
-
pid
,
PIDTYPE_PGID
,
p
)
{
send_sigurg_to_task
(
p
,
fown
);
}
}
while_each_task_pid
(
-
pid
,
PIDTYPE_PGID
,
p
);
}
read_unlock
(
&
tasklist_lock
);
out_unlock_fown:
...
...
fs/isofs/rock.c
View file @
232cebfb
...
...
@@ -153,6 +153,7 @@ int get_rock_ridge_filename(struct iso_directory_record * de,
}
}
MAYBE_CONTINUE
(
repeat
,
inode
);
if
(
buffer
)
kfree
(
buffer
);
return
retnamlen
;
/* If 0, this file did not have a NM field */
out:
if
(
buffer
)
kfree
(
buffer
);
...
...
@@ -351,7 +352,6 @@ int parse_rock_ridge_inode_internal(struct iso_directory_record * de,
}
}
MAYBE_CONTINUE
(
repeat
,
inode
);
return
0
;
out:
if
(
buffer
)
kfree
(
buffer
);
return
0
;
...
...
@@ -515,6 +515,8 @@ static int rock_ridge_symlink_readpage(struct file *file, struct page *page)
}
}
MAYBE_CONTINUE
(
repeat
,
inode
);
if
(
buffer
)
kfree
(
buffer
);
if
(
rpnt
==
link
)
goto
fail
;
...
...
fs/proc/base.c
View file @
232cebfb
...
...
@@ -778,10 +778,9 @@ static struct inode_operations proc_pid_link_inode_operations = {
.
follow_link
=
proc_pid_follow_link
};
static
int
pid_alive
(
struct
task_struct
*
p
)
static
in
line
in
t
pid_alive
(
struct
task_struct
*
p
)
{
BUG_ON
(
p
->
pids
[
PIDTYPE_PID
].
pidptr
!=
&
p
->
pids
[
PIDTYPE_PID
].
pid
);
return
atomic_read
(
&
p
->
pids
[
PIDTYPE_PID
].
pid
.
count
);
return
p
->
pids
[
PIDTYPE_PID
].
nr
!=
0
;
}
#define NUMBUF 10
...
...
include/linux/pid.h
View file @
232cebfb
...
...
@@ -12,35 +12,22 @@ enum pid_type
struct
pid
{
/* Try to keep hash_chain in the same cacheline as nr for find_pid */
struct
hlist_node
hash_chain
;
/* Try to keep pid_chain in the same cacheline as nr for find_pid */
int
nr
;
atomic_t
count
;
struct
task_struct
*
task
;
struct
list_head
task_list
;
};
struct
pid_link
{
struct
list_head
pid_chain
;
struct
pid
*
pidptr
;
struct
pid
pid
;
struct
hlist_node
pid_chain
;
/* list of pids with the same nr, only one of them is in the hash */
struct
list_head
pid_list
;
};
#define pid_task(elem, type) \
list_entry(elem, struct task_struct, pids[type].pid_
chain
)
list_entry(elem, struct task_struct, pids[type].pid_
list
)
/*
* attach_pid() and
link
_pid() must be called with the tasklist_lock
* attach_pid() and
detach
_pid() must be called with the tasklist_lock
* write-held.
*/
extern
int
FASTCALL
(
attach_pid
(
struct
task_struct
*
task
,
enum
pid_type
type
,
int
nr
));
extern
void
FASTCALL
(
link_pid
(
struct
task_struct
*
task
,
struct
pid_link
*
link
,
struct
pid
*
pid
));
/*
* detach_pid() must be called with the tasklist_lock write-held.
*/
extern
void
FASTCALL
(
detach_pid
(
struct
task_struct
*
task
,
enum
pid_type
));
/*
...
...
@@ -53,13 +40,16 @@ extern int alloc_pidmap(void);
extern
void
FASTCALL
(
free_pidmap
(
int
));
extern
void
switch_exec_pids
(
struct
task_struct
*
leader
,
struct
task_struct
*
thread
);
#define for_each_task_pid(who, type, task, elem, pid) \
if ((pid = find_pid(type, who))) \
for (elem = pid->task_list.next, \
prefetch(elem->next), \
task = pid_task(elem, type); \
elem != &pid->task_list; \
elem = elem->next, prefetch(elem->next), \
task = pid_task(elem, type))
#define do_each_task_pid(who, type, task) \
if ((task = find_task_by_pid_type(type, who))) { \
prefetch((task)->pids[type].pid_list.next); \
do {
#define while_each_task_pid(who, type, task) \
task = pid_task((task)->pids[type].pid_list.next,\
type); \
prefetch((task)->pids[type].pid_list.next); \
} while (hlist_unhashed(&(task)->pids[type].pid_chain));\
} \
#endif
/* _LINUX_PID_H */
include/linux/sched.h
View file @
232cebfb
...
...
@@ -494,7 +494,7 @@ struct task_struct {
struct
task_struct
*
group_leader
;
/* threadgroup leader */
/* PID/PID hash table linkage. */
struct
pid
_link
pids
[
PIDTYPE_MAX
];
struct
pid
pids
[
PIDTYPE_MAX
];
wait_queue_head_t
wait_chldexit
;
/* for wait4() */
struct
completion
*
vfork_done
;
/* for vfork() */
...
...
@@ -673,7 +673,8 @@ extern struct task_struct init_task;
extern
struct
mm_struct
init_mm
;
extern
struct
task_struct
*
find_task_by_pid
(
int
pid
);
#define find_task_by_pid(nr) find_task_by_pid_type(PIDTYPE_PID, nr)
extern
struct
task_struct
*
find_task_by_pid_type
(
int
type
,
int
pid
);
extern
void
set_special_pids
(
pid_t
session
,
pid_t
pgrp
);
extern
void
__set_special_pids
(
pid_t
session
,
pid_t
pgrp
);
...
...
@@ -876,9 +877,7 @@ extern task_t * FASTCALL(next_thread(const task_t *p));
static
inline
int
thread_group_empty
(
task_t
*
p
)
{
struct
pid
*
pid
=
p
->
pids
[
PIDTYPE_TGID
].
pidptr
;
return
pid
->
task_list
.
next
->
next
==
&
pid
->
task_list
;
return
list_empty
(
&
p
->
pids
[
PIDTYPE_TGID
].
pid_list
);
}
#define delay_group_leader(p) \
...
...
kernel/capability.c
View file @
232cebfb
...
...
@@ -89,14 +89,12 @@ static inline void cap_set_pg(int pgrp, kernel_cap_t *effective,
kernel_cap_t
*
permitted
)
{
task_t
*
g
,
*
target
;
struct
list_head
*
l
;
struct
pid
*
pid
;
for_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
g
,
l
,
pid
)
{
do_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
g
)
{
target
=
g
;
while_each_thread
(
g
,
target
)
security_capset_set
(
target
,
effective
,
inheritable
,
permitted
);
}
}
while_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
g
);
}
/*
...
...
kernel/exit.c
View file @
232cebfb
...
...
@@ -124,16 +124,15 @@ void unhash_process(struct task_struct *p)
int
session_of_pgrp
(
int
pgrp
)
{
struct
task_struct
*
p
;
struct
list_head
*
l
;
struct
pid
*
pid
;
int
sid
=
-
1
;
read_lock
(
&
tasklist_lock
);
for_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
p
,
l
,
pid
)
do_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
p
)
{
if
(
p
->
signal
->
session
>
0
)
{
sid
=
p
->
signal
->
session
;
goto
out
;
}
}
while_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
p
);
p
=
find_task_by_pid
(
pgrp
);
if
(
p
)
sid
=
p
->
signal
->
session
;
...
...
@@ -154,11 +153,9 @@ int session_of_pgrp(int pgrp)
static
int
will_become_orphaned_pgrp
(
int
pgrp
,
task_t
*
ignored_task
)
{
struct
task_struct
*
p
;
struct
list_head
*
l
;
struct
pid
*
pid
;
int
ret
=
1
;
for_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
p
,
l
,
pid
)
{
do_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
p
)
{
if
(
p
==
ignored_task
||
p
->
state
>=
TASK_ZOMBIE
||
p
->
real_parent
->
pid
==
1
)
...
...
@@ -168,7 +165,7 @@ static int will_become_orphaned_pgrp(int pgrp, task_t *ignored_task)
ret
=
0
;
break
;
}
}
}
while_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
p
);
return
ret
;
/* (sighing) "Often!" */
}
...
...
@@ -187,10 +184,8 @@ static inline int has_stopped_jobs(int pgrp)
{
int
retval
=
0
;
struct
task_struct
*
p
;
struct
list_head
*
l
;
struct
pid
*
pid
;
for_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
p
,
l
,
pid
)
{
do_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
p
)
{
if
(
p
->
state
!=
TASK_STOPPED
)
continue
;
...
...
@@ -206,7 +201,7 @@ static inline int has_stopped_jobs(int pgrp)
retval
=
1
;
break
;
}
}
while_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
p
);
return
retval
;
}
...
...
@@ -849,9 +844,6 @@ asmlinkage long sys_exit(int error_code)
task_t
fastcall
*
next_thread
(
const
task_t
*
p
)
{
const
struct
pid_link
*
link
=
p
->
pids
+
PIDTYPE_TGID
;
const
struct
list_head
*
tmp
,
*
head
=
&
link
->
pidptr
->
task_list
;
#ifdef CONFIG_SMP
if
(
!
p
->
sighand
)
BUG
();
...
...
@@ -859,11 +851,7 @@ task_t fastcall *next_thread(const task_t *p)
!
rwlock_is_locked
(
&
tasklist_lock
))
BUG
();
#endif
tmp
=
link
->
pid_chain
.
next
;
if
(
tmp
==
head
)
tmp
=
head
->
next
;
return
pid_task
(
tmp
,
PIDTYPE_TGID
);
return
pid_task
(
p
->
pids
[
PIDTYPE_TGID
].
pid_list
.
next
,
PIDTYPE_TGID
);
}
EXPORT_SYMBOL
(
next_thread
);
...
...
kernel/fork.c
View file @
232cebfb
...
...
@@ -1124,14 +1124,13 @@ static task_t *copy_process(unsigned long clone_flags,
__ptrace_link
(
p
,
current
->
parent
);
attach_pid
(
p
,
PIDTYPE_PID
,
p
->
pid
);
attach_pid
(
p
,
PIDTYPE_TGID
,
p
->
tgid
);
if
(
thread_group_leader
(
p
))
{
attach_pid
(
p
,
PIDTYPE_TGID
,
p
->
tgid
);
attach_pid
(
p
,
PIDTYPE_PGID
,
process_group
(
p
));
attach_pid
(
p
,
PIDTYPE_SID
,
p
->
signal
->
session
);
if
(
p
->
pid
)
__get_cpu_var
(
process_counts
)
++
;
}
else
link_pid
(
p
,
p
->
pids
+
PIDTYPE_TGID
,
&
p
->
group_leader
->
pids
[
PIDTYPE_TGID
].
pid
);
}
nr_threads
++
;
write_unlock_irq
(
&
tasklist_lock
);
...
...
kernel/pid.c
View file @
232cebfb
...
...
@@ -146,74 +146,66 @@ int alloc_pidmap(void)
return
-
1
;
}
fastcall
struct
pid
*
find_pid
(
enum
pid_type
type
,
int
nr
)
struct
pid
*
fastcall
find_pid
(
enum
pid_type
type
,
int
nr
)
{
struct
hlist_node
*
elem
;
struct
pid
*
pid
;
hlist_for_each_entry
(
pid
,
elem
,
&
pid_hash
[
type
][
pid_hashfn
(
nr
)],
hash
_chain
)
{
&
pid_hash
[
type
][
pid_hashfn
(
nr
)],
pid
_chain
)
{
if
(
pid
->
nr
==
nr
)
return
pid
;
}
return
NULL
;
}
void
fastcall
link_pid
(
task_t
*
task
,
struct
pid_link
*
link
,
struct
pid
*
pid
)
{
atomic_inc
(
&
pid
->
count
);
list_add_tail
(
&
link
->
pid_chain
,
&
pid
->
task_list
);
link
->
pidptr
=
pid
;
}
int
fastcall
attach_pid
(
task_t
*
task
,
enum
pid_type
type
,
int
nr
)
{
struct
pid
*
pid
=
find_pid
(
type
,
nr
);
if
(
pid
)
atomic_inc
(
&
pid
->
count
);
else
{
pid
=
&
task
->
pids
[
type
].
pid
;
pid
->
nr
=
nr
;
atomic_set
(
&
pid
->
count
,
1
);
INIT_LIST_HEAD
(
&
pid
->
task_list
);
pid
->
task
=
task
;
get_task_struct
(
task
);
hlist_add_head
(
&
pid
->
hash_chain
,
struct
pid
*
pid
,
*
task_pid
;
task_pid
=
&
task
->
pids
[
type
];
pid
=
find_pid
(
type
,
nr
);
if
(
pid
==
NULL
)
{
hlist_add_head
(
&
task_pid
->
pid_chain
,
&
pid_hash
[
type
][
pid_hashfn
(
nr
)]);
INIT_LIST_HEAD
(
&
task_pid
->
pid_list
);
}
else
{
INIT_HLIST_NODE
(
&
task_pid
->
pid_chain
);
list_add_tail
(
&
task_pid
->
pid_list
,
&
pid
->
pid_list
);
}
list_add_tail
(
&
task
->
pids
[
type
].
pid_chain
,
&
pid
->
task_list
);
task
->
pids
[
type
].
pidptr
=
pid
;
task_pid
->
nr
=
nr
;
return
0
;
}
static
inline
int
__detach_pid
(
task_t
*
task
,
enum
pid_type
type
)
{
struct
pid_link
*
link
=
task
->
pids
+
type
;
struct
pid
*
pid
=
link
->
pidptr
;
struct
pid
*
pid
,
*
pid_next
;
int
nr
;
list_del
(
&
link
->
pid_chain
);
if
(
!
atomic_dec_and_test
(
&
pid
->
count
))
return
0
;
pid
=
&
task
->
pids
[
type
];
if
(
!
hlist_unhashed
(
&
pid
->
pid_chain
))
{
hlist_del
(
&
pid
->
pid_chain
);
if
(
!
list_empty
(
&
pid
->
pid_list
))
{
pid_next
=
list_entry
(
pid
->
pid_list
.
next
,
struct
pid
,
pid_list
);
/* insert next pid from pid_list to hash */
hlist_add_head
(
&
pid_next
->
pid_chain
,
&
pid_hash
[
type
][
pid_hashfn
(
pid_next
->
nr
)]);
}
}
list_del
(
&
pid
->
pid_list
);
nr
=
pid
->
nr
;
hlist_del
(
&
pid
->
hash_chain
);
put_task_struct
(
pid
->
task
);
pid
->
nr
=
0
;
return
nr
;
}
static
void
_detach_pid
(
task_t
*
task
,
enum
pid_type
type
)
{
__detach_pid
(
task
,
type
);
}
void
fastcall
detach_pid
(
task_t
*
task
,
enum
pid_type
type
)
{
int
nr
=
__detach_pid
(
task
,
type
)
;
int
nr
;
nr
=
__detach_pid
(
task
,
type
);
if
(
!
nr
)
return
;
...
...
@@ -223,16 +215,18 @@ void fastcall detach_pid(task_t *task, enum pid_type type)
free_pidmap
(
nr
);
}
task_t
*
find_task_by_pid
(
int
nr
)
task_t
*
find_task_by_pid
_type
(
int
type
,
int
nr
)
{
struct
pid
*
pid
=
find_pid
(
PIDTYPE_PID
,
nr
)
;
struct
pid
*
pid
;
pid
=
find_pid
(
type
,
nr
);
if
(
!
pid
)
return
NULL
;
return
pid_task
(
pid
->
task_list
.
next
,
PIDTYPE_PID
);
return
pid_task
(
&
pid
->
pid_list
,
type
);
}
EXPORT_SYMBOL
(
find_task_by_pid
);
EXPORT_SYMBOL
(
find_task_by_pid
_type
);
/*
* This function switches the PIDs if a non-leader thread calls
...
...
@@ -241,13 +235,13 @@ EXPORT_SYMBOL(find_task_by_pid);
*/
void
switch_exec_pids
(
task_t
*
leader
,
task_t
*
thread
)
{
_detach_pid
(
leader
,
PIDTYPE_PID
);
_detach_pid
(
leader
,
PIDTYPE_TGID
);
_detach_pid
(
leader
,
PIDTYPE_PGID
);
_detach_pid
(
leader
,
PIDTYPE_SID
);
_
_
detach_pid
(
leader
,
PIDTYPE_PID
);
_
_
detach_pid
(
leader
,
PIDTYPE_TGID
);
_
_
detach_pid
(
leader
,
PIDTYPE_PGID
);
_
_
detach_pid
(
leader
,
PIDTYPE_SID
);
_detach_pid
(
thread
,
PIDTYPE_PID
);
_detach_pid
(
thread
,
PIDTYPE_TGID
);
_
_
detach_pid
(
thread
,
PIDTYPE_PID
);
_
_
detach_pid
(
thread
,
PIDTYPE_TGID
);
leader
->
pid
=
leader
->
tgid
=
thread
->
pid
;
thread
->
pid
=
thread
->
tgid
;
...
...
kernel/signal.c
View file @
232cebfb
...
...
@@ -1110,8 +1110,6 @@ int group_send_sig_info(int sig, struct siginfo *info, struct task_struct *p)
int
__kill_pg_info
(
int
sig
,
struct
siginfo
*
info
,
pid_t
pgrp
)
{
struct
task_struct
*
p
;
struct
list_head
*
l
;
struct
pid
*
pid
;
int
retval
,
success
;
if
(
pgrp
<=
0
)
...
...
@@ -1119,11 +1117,11 @@ int __kill_pg_info(int sig, struct siginfo *info, pid_t pgrp)
success
=
0
;
retval
=
-
ESRCH
;
for_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
p
,
l
,
pid
)
{
do_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
p
)
{
int
err
=
group_send_sig_info
(
sig
,
info
,
p
);
success
|=
!
err
;
retval
=
err
;
}
}
while_each_task_pid
(
pgrp
,
PIDTYPE_PGID
,
p
);
return
success
?
0
:
retval
;
}
...
...
@@ -1150,8 +1148,6 @@ int
kill_sl_info
(
int
sig
,
struct
siginfo
*
info
,
pid_t
sid
)
{
int
err
,
retval
=
-
EINVAL
;
struct
pid
*
pid
;
struct
list_head
*
l
;
struct
task_struct
*
p
;
if
(
sid
<=
0
)
...
...
@@ -1159,13 +1155,13 @@ kill_sl_info(int sig, struct siginfo *info, pid_t sid)
retval
=
-
ESRCH
;
read_lock
(
&
tasklist_lock
);
for_each_task_pid
(
sid
,
PIDTYPE_SID
,
p
,
l
,
pid
)
{
do_each_task_pid
(
sid
,
PIDTYPE_SID
,
p
)
{
if
(
!
p
->
signal
->
leader
)
continue
;
err
=
group_send_sig_info
(
sig
,
info
,
p
);
if
(
retval
)
retval
=
err
;
}
}
while_each_task_pid
(
sid
,
PIDTYPE_SID
,
p
);
read_unlock
(
&
tasklist_lock
);
out:
return
retval
;
...
...
kernel/sys.c
View file @
232cebfb
...
...
@@ -310,8 +310,6 @@ asmlinkage long sys_setpriority(int which, int who, int niceval)
{
struct
task_struct
*
g
,
*
p
;
struct
user_struct
*
user
;
struct
pid
*
pid
;
struct
list_head
*
l
;
int
error
=
-
EINVAL
;
if
(
which
>
2
||
which
<
0
)
...
...
@@ -336,8 +334,9 @@ asmlinkage long sys_setpriority(int which, int who, int niceval)
case
PRIO_PGRP
:
if
(
!
who
)
who
=
process_group
(
current
);
for_each_task_pid
(
who
,
PIDTYPE_PGID
,
p
,
l
,
pid
)
do_each_task_pid
(
who
,
PIDTYPE_PGID
,
p
)
{
error
=
set_one_prio
(
p
,
niceval
,
error
);
}
while_each_task_pid
(
who
,
PIDTYPE_PGID
,
p
);
break
;
case
PRIO_USER
:
if
(
!
who
)
...
...
@@ -371,8 +370,6 @@ asmlinkage long sys_setpriority(int which, int who, int niceval)
asmlinkage
long
sys_getpriority
(
int
which
,
int
who
)
{
struct
task_struct
*
g
,
*
p
;
struct
list_head
*
l
;
struct
pid
*
pid
;
struct
user_struct
*
user
;
long
niceval
,
retval
=
-
ESRCH
;
...
...
@@ -394,11 +391,11 @@ asmlinkage long sys_getpriority(int which, int who)
case
PRIO_PGRP
:
if
(
!
who
)
who
=
process_group
(
current
);
for_each_task_pid
(
who
,
PIDTYPE_PGID
,
p
,
l
,
pid
)
{
do_each_task_pid
(
who
,
PIDTYPE_PGID
,
p
)
{
niceval
=
20
-
task_nice
(
p
);
if
(
niceval
>
retval
)
retval
=
niceval
;
}
}
while_each_task_pid
(
who
,
PIDTYPE_PGID
,
p
);
break
;
case
PRIO_USER
:
if
(
!
who
)
...
...
@@ -1044,12 +1041,11 @@ asmlinkage long sys_setpgid(pid_t pid, pid_t pgid)
if
(
pgid
!=
pid
)
{
struct
task_struct
*
p
;
struct
pid
*
pid
;
struct
list_head
*
l
;
for_each_task_pid
(
pgid
,
PIDTYPE_PGID
,
p
,
l
,
pid
)
do_each_task_pid
(
pgid
,
PIDTYPE_PGID
,
p
)
{
if
(
p
->
signal
->
session
==
current
->
signal
->
session
)
goto
ok_pgid
;
}
while_each_task_pid
(
pgid
,
PIDTYPE_PGID
,
p
);
goto
out
;
}
...
...
lib/zlib_inflate/inflate.c
View file @
232cebfb
...
...
@@ -53,8 +53,6 @@ int zlib_inflateInit2_(
return
Z_VERSION_ERROR
;
/* initialize state */
if
(
z
==
NULL
)
return
Z_STREAM_ERROR
;
z
->
msg
=
NULL
;
z
->
state
=
&
WS
(
z
)
->
internal_state
;
z
->
state
->
blocks
=
NULL
;
...
...
mm/memory.c
View file @
232cebfb
...
...
@@ -1744,6 +1744,8 @@ int make_pages_present(unsigned long addr, unsigned long end)
struct
vm_area_struct
*
vma
;
vma
=
find_vma
(
current
->
mm
,
addr
);
if
(
!
vma
)
return
-
1
;
write
=
(
vma
->
vm_flags
&
VM_WRITE
)
!=
0
;
if
(
addr
>=
end
)
BUG
();
...
...
net/ax25/af_ax25.c
View file @
232cebfb
...
...
@@ -1272,6 +1272,9 @@ static int ax25_connect(struct socket *sock, struct sockaddr *uaddr,
sock
->
state
=
SS_CONNECTED
;
if
(
digi
!=
NULL
)
kfree
(
digi
);
err
=
0
;
out:
release_sock
(
sk
);
...
...
sound/oss/emu10k1/midi.c
View file @
232cebfb
...
...
@@ -320,7 +320,6 @@ static ssize_t emu10k1_midi_write(struct file *file, const char __user *buffer,
{
struct
emu10k1_mididevice
*
midi_dev
=
(
struct
emu10k1_mididevice
*
)
file
->
private_data
;
struct
midi_hdr
*
midihdr
;
ssize_t
ret
=
0
;
unsigned
long
flags
;
DPD
(
4
,
"emu10k1_midi_write(), count=%#x
\n
"
,
(
u32
)
count
);
...
...
@@ -344,7 +343,7 @@ static ssize_t emu10k1_midi_write(struct file *file, const char __user *buffer,
if
(
copy_from_user
(
midihdr
->
data
,
buffer
,
count
))
{
kfree
(
midihdr
->
data
);
kfree
(
midihdr
);
return
ret
?
ret
:
-
EFAULT
;
return
-
EFAULT
;
}
spin_lock_irqsave
(
&
midi_spinlock
,
flags
);
...
...
sound/oss/maui.c
View file @
232cebfb
...
...
@@ -383,9 +383,8 @@ static int __init probe_maui(struct address_info *hw_config)
*/
synth
=
midi_devs
[
this_dev
]
->
converter
;
synth
->
id
=
"MAUI"
;
if
(
synth
!=
NULL
)
{
synth
->
id
=
"MAUI"
;
orig_load_patch
=
synth
->
load_patch
;
synth
->
load_patch
=
&
maui_load_patch
;
}
else
...
...
sound/oss/v_midi.c
View file @
232cebfb
...
...
@@ -90,11 +90,12 @@ static void v_midi_close (int dev)
static
int
v_midi_out
(
int
dev
,
unsigned
char
midi_byte
)
{
vmidi_devc
*
devc
=
midi_devs
[
dev
]
->
devc
;
vmidi_devc
*
pdevc
=
midi_devs
[
devc
->
pair_mididev
]
->
devc
;
vmidi_devc
*
pdevc
;
if
(
devc
==
NULL
)
return
-
(
ENXIO
)
;
return
-
ENXIO
;
pdevc
=
midi_devs
[
devc
->
pair_mididev
]
->
devc
;
if
(
pdevc
->
input_opened
>
0
){
if
(
MIDIbuf_avail
(
pdevc
->
my_mididev
)
>
500
)
return
0
;
...
...
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