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
1235b44f
Commit
1235b44f
authored
Nov 23, 2007
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Import 1.1.40
parent
2cfdbda0
Changes
38
Hide whitespace changes
Inline
Side-by-side
Showing
38 changed files
with
129 additions
and
191 deletions
+129
-191
Makefile
Makefile
+1
-1
drivers/char/tty_io.c
drivers/char/tty_io.c
+0
-2
drivers/char/tty_ioctl.c
drivers/char/tty_ioctl.c
+0
-3
drivers/net/8390.c
drivers/net/8390.c
+0
-5
drivers/scsi/NCR5380.c
drivers/scsi/NCR5380.c
+2
-2
drivers/scsi/aha1542.c
drivers/scsi/aha1542.c
+1
-0
drivers/scsi/constants.h
drivers/scsi/constants.h
+1
-1
drivers/scsi/g_NCR5380.c
drivers/scsi/g_NCR5380.c
+1
-1
drivers/scsi/pas16.c
drivers/scsi/pas16.c
+1
-1
drivers/scsi/scsi.c
drivers/scsi/scsi.c
+0
-2
drivers/scsi/sd.c
drivers/scsi/sd.c
+1
-0
drivers/scsi/seagate.c
drivers/scsi/seagate.c
+1
-1
drivers/scsi/sg.c
drivers/scsi/sg.c
+1
-0
drivers/scsi/sr.c
drivers/scsi/sr.c
+1
-0
drivers/scsi/st.c
drivers/scsi/st.c
+1
-0
drivers/sound/pas2_mixer.c
drivers/sound/pas2_mixer.c
+0
-13
fs/Makefile
fs/Makefile
+1
-1
fs/exec.c
fs/exec.c
+0
-2
fs/ext2/super.c
fs/ext2/super.c
+0
-2
fs/isofs/dir.c
fs/isofs/dir.c
+24
-28
fs/isofs/file.c
fs/isofs/file.c
+14
-8
fs/isofs/inode.c
fs/isofs/inode.c
+33
-22
fs/isofs/namei.c
fs/isofs/namei.c
+14
-21
fs/isofs/rock.c
fs/isofs/rock.c
+11
-5
fs/msdos/dir.c
fs/msdos/dir.c
+0
-4
fs/proc/base.c
fs/proc/base.c
+0
-1
fs/proc/fd.c
fs/proc/fd.c
+16
-34
fs/proc/inode.c
fs/proc/inode.c
+0
-1
fs/super.c
fs/super.c
+1
-0
include/linux/iso_fs.h
include/linux/iso_fs.h
+0
-10
include/linux/proc_fs.h
include/linux/proc_fs.h
+0
-1
init/main.c
init/main.c
+0
-1
kernel/bios32.c
kernel/bios32.c
+1
-1
kernel/ksyms.c
kernel/ksyms.c
+2
-12
kernel/panic.c
kernel/panic.c
+0
-2
kernel/printk.c
kernel/printk.c
+0
-1
net/inet/dev.c
net/inet/dev.c
+0
-1
net/inet/icmp.c
net/inet/icmp.c
+0
-1
No files found.
Makefile
View file @
1235b44f
VERSION
=
1
VERSION
=
1
PATCHLEVEL
=
1
PATCHLEVEL
=
1
SUBLEVEL
=
39
SUBLEVEL
=
40
all
:
Version zImage
all
:
Version zImage
...
...
drivers/char/tty_io.c
View file @
1235b44f
...
@@ -439,8 +439,6 @@ int vt_waitactive(void)
...
@@ -439,8 +439,6 @@ int vt_waitactive(void)
#define vt_wake_waitactive() wake_up(&vt_activate_queue)
#define vt_wake_waitactive() wake_up(&vt_activate_queue)
extern
int
kill_proc
(
int
pid
,
int
sig
,
int
priv
);
/*
/*
* Performs the back end of a vt switch
* Performs the back end of a vt switch
*/
*/
...
...
drivers/char/tty_ioctl.c
View file @
1235b44f
...
@@ -31,9 +31,6 @@
...
@@ -31,9 +31,6 @@
# define PRINTK(x)
/**/
# define PRINTK(x)
/**/
#endif
#endif
extern
int
session_of_pgrp
(
int
pgrp
);
extern
int
kill_pg
(
int
pgrp
,
int
sig
,
int
priv
);
void
wait_until_sent
(
struct
tty_struct
*
tty
,
int
timeout
)
void
wait_until_sent
(
struct
tty_struct
*
tty
,
int
timeout
)
{
{
struct
wait_queue
wait
=
{
current
,
NULL
};
struct
wait_queue
wait
=
{
current
,
NULL
};
...
...
drivers/net/8390.c
View file @
1235b44f
...
@@ -85,15 +85,11 @@ int ei_debug = 1;
...
@@ -85,15 +85,11 @@ int ei_debug = 1;
static
int
high_water_mark
=
0
;
static
int
high_water_mark
=
0
;
/* Index to functions. */
/* Index to functions. */
int
ei_open
(
struct
device
*
dev
);
/* Put into the device structure. */
void
ei_interrupt
(
int
reg_ptr
);
/* Installed as the interrupt handler. */
static
void
ei_tx_intr
(
struct
device
*
dev
);
static
void
ei_tx_intr
(
struct
device
*
dev
);
static
void
ei_receive
(
struct
device
*
dev
);
static
void
ei_receive
(
struct
device
*
dev
);
static
void
ei_rx_overrun
(
struct
device
*
dev
);
static
void
ei_rx_overrun
(
struct
device
*
dev
);
/* Routines generic to NS8390-based boards. */
/* Routines generic to NS8390-based boards. */
void
NS8390_init
(
struct
device
*
dev
,
int
startp
);
static
void
NS8390_trigger_send
(
struct
device
*
dev
,
unsigned
int
length
,
static
void
NS8390_trigger_send
(
struct
device
*
dev
,
unsigned
int
length
,
int
start_page
);
int
start_page
);
#ifdef HAVE_MULTICAST
#ifdef HAVE_MULTICAST
...
@@ -288,7 +284,6 @@ void ei_interrupt(int reg_ptr)
...
@@ -288,7 +284,6 @@ void ei_interrupt(int reg_ptr)
if
(
interrupts
&
ENISR_TX
)
{
if
(
interrupts
&
ENISR_TX
)
{
ei_tx_intr
(
dev
);
ei_tx_intr
(
dev
);
}
else
if
(
interrupts
&
ENISR_COUNTERS
)
{
}
else
if
(
interrupts
&
ENISR_COUNTERS
)
{
struct
ei_device
*
ei_local
=
(
struct
ei_device
*
)
dev
->
priv
;
ei_local
->
stat
.
rx_frame_errors
+=
inb_p
(
e8390_base
+
EN0_COUNTER0
);
ei_local
->
stat
.
rx_frame_errors
+=
inb_p
(
e8390_base
+
EN0_COUNTER0
);
ei_local
->
stat
.
rx_crc_errors
+=
inb_p
(
e8390_base
+
EN0_COUNTER1
);
ei_local
->
stat
.
rx_crc_errors
+=
inb_p
(
e8390_base
+
EN0_COUNTER1
);
ei_local
->
stat
.
rx_missed_errors
+=
inb_p
(
e8390_base
+
EN0_COUNTER2
);
ei_local
->
stat
.
rx_missed_errors
+=
inb_p
(
e8390_base
+
EN0_COUNTER2
);
...
...
drivers/scsi/NCR5380.c
View file @
1235b44f
...
@@ -2737,7 +2737,7 @@ int NCR5380_abort (Scsi_Cmnd *cmd) {
...
@@ -2737,7 +2737,7 @@ int NCR5380_abort (Scsi_Cmnd *cmd) {
*
*
* Purpose : reset the SCSI bus.
* Purpose : reset the SCSI bus.
*
*
* Returns :
0
* Returns :
SCSI_RESET_WAKEUP
*
*
*/
*/
...
@@ -2756,6 +2756,6 @@ int NCR5380_reset (Scsi_Cmnd *cmd) {
...
@@ -2756,6 +2756,6 @@ int NCR5380_reset (Scsi_Cmnd *cmd) {
NCR5380_write
(
INITIATOR_COMMAND_REG
,
ICR_BASE
);
NCR5380_write
(
INITIATOR_COMMAND_REG
,
ICR_BASE
);
sti
();
sti
();
return
0
;
return
SCSI_RESET_WAKEUP
;
}
}
drivers/scsi/aha1542.c
View file @
1235b44f
...
@@ -1083,6 +1083,7 @@ int aha1542_reset(Scsi_Cmnd * SCpnt)
...
@@ -1083,6 +1083,7 @@ int aha1542_reset(Scsi_Cmnd * SCpnt)
SCtmp
->
scsi_done
(
SCpnt
);
SCtmp
->
scsi_done
(
SCpnt
);
HOSTDATA
(
SCpnt
->
host
)
->
SCint
[
i
]
=
NULL
;
HOSTDATA
(
SCpnt
->
host
)
->
SCint
[
i
]
=
NULL
;
HOSTDATA
(
SCpnt
->
host
)
->
mb
[
i
].
status
=
0
;
}
}
return
SCSI_RESET_SUCCESS
;
return
SCSI_RESET_SUCCESS
;
#else
#else
...
...
drivers/scsi/constants.h
View file @
1235b44f
...
@@ -3,5 +3,5 @@
...
@@ -3,5 +3,5 @@
extern
void
print_command
(
unsigned
char
*
);
extern
void
print_command
(
unsigned
char
*
);
extern
int
print_msg
(
unsigned
char
*
);
extern
int
print_msg
(
unsigned
char
*
);
extern
void
print_sense
(
char
*
,
Scsi_Cmnd
*
);
extern
void
print_sense
(
char
*
,
Scsi_Cmnd
*
);
extern
void
print_status
(
int
);
;
extern
void
print_status
(
int
);
#endif
/* def _CONSTANTS_H */
#endif
/* def _CONSTANTS_H */
drivers/scsi/g_NCR5380.c
View file @
1235b44f
...
@@ -131,7 +131,7 @@ int generic_NCR5380_detect(Scsi_Host_Template * tpnt) {
...
@@ -131,7 +131,7 @@ int generic_NCR5380_detect(Scsi_Host_Template * tpnt) {
instance
=
scsi_register
(
tpnt
,
sizeof
(
struct
NCR5380_hostdata
));
instance
=
scsi_register
(
tpnt
,
sizeof
(
struct
NCR5380_hostdata
));
instance
->
io_port
=
overrides
[
current_override
].
port
;
instance
->
io_port
=
overrides
[
current_override
].
port
;
NCR5380_init
(
instance
);
NCR5380_init
(
instance
,
0
);
if
(
overrides
[
current_override
].
irq
!=
IRQ_AUTO
)
if
(
overrides
[
current_override
].
irq
!=
IRQ_AUTO
)
instance
->
irq
=
overrides
[
current_override
].
irq
;
instance
->
irq
=
overrides
[
current_override
].
irq
;
...
...
drivers/scsi/pas16.c
View file @
1235b44f
...
@@ -360,7 +360,7 @@ int pas16_detect(Scsi_Host_Template * tpnt) {
...
@@ -360,7 +360,7 @@ int pas16_detect(Scsi_Host_Template * tpnt) {
instance
=
scsi_register
(
tpnt
,
sizeof
(
struct
NCR5380_hostdata
));
instance
=
scsi_register
(
tpnt
,
sizeof
(
struct
NCR5380_hostdata
));
instance
->
io_port
=
io_port
;
instance
->
io_port
=
io_port
;
NCR5380_init
(
instance
);
NCR5380_init
(
instance
,
0
);
if
(
overrides
[
current_override
].
irq
!=
IRQ_AUTO
)
if
(
overrides
[
current_override
].
irq
!=
IRQ_AUTO
)
instance
->
irq
=
overrides
[
current_override
].
irq
;
instance
->
irq
=
overrides
[
current_override
].
irq
;
...
...
drivers/scsi/scsi.c
View file @
1235b44f
...
@@ -384,7 +384,6 @@ static void scan_scsis (struct Scsi_Host * shpnt)
...
@@ -384,7 +384,6 @@ static void scan_scsis (struct Scsi_Host * shpnt)
if
(
type
!=
-
1
)
if
(
type
!=
-
1
)
{
{
struct
Scsi_Device_Template
*
sdtpnt
;
print_inquiry
(
scsi_result
);
print_inquiry
(
scsi_result
);
for
(
sdtpnt
=
scsi_devicelist
;
sdtpnt
;
sdtpnt
=
sdtpnt
->
next
)
for
(
sdtpnt
=
scsi_devicelist
;
sdtpnt
;
sdtpnt
=
sdtpnt
->
next
)
...
@@ -767,7 +766,6 @@ update_timeout(SCpnt, SCpnt->timeout_per_command);
...
@@ -767,7 +766,6 @@ update_timeout(SCpnt, SCpnt->timeout_per_command);
if
(
host
->
hostt
->
can_queue
)
if
(
host
->
hostt
->
can_queue
)
{
{
extern
unsigned
long
intr_count
;
#ifdef DEBUG
#ifdef DEBUG
printk
(
"queuecommand : routine at %08x
\n
"
,
printk
(
"queuecommand : routine at %08x
\n
"
,
host
->
hostt
->
queuecommand
);
host
->
hostt
->
queuecommand
);
...
...
drivers/scsi/sd.c
View file @
1235b44f
...
@@ -1014,6 +1014,7 @@ static void sd_init()
...
@@ -1014,6 +1014,7 @@ static void sd_init()
rscsi_disks
=
(
Scsi_Disk
*
)
rscsi_disks
=
(
Scsi_Disk
*
)
scsi_init_malloc
(
sd_template
.
dev_max
*
sizeof
(
Scsi_Disk
));
scsi_init_malloc
(
sd_template
.
dev_max
*
sizeof
(
Scsi_Disk
));
memset
(
rscsi_disks
,
0
,
sd_template
.
dev_max
*
sizeof
(
Scsi_Disk
));
sd_sizes
=
(
int
*
)
scsi_init_malloc
((
sd_template
.
dev_max
<<
4
)
*
sd_sizes
=
(
int
*
)
scsi_init_malloc
((
sd_template
.
dev_max
<<
4
)
*
sizeof
(
int
));
sizeof
(
int
));
...
...
drivers/scsi/seagate.c
View file @
1235b44f
...
@@ -672,7 +672,7 @@ static int internal_command(unsigned char target, unsigned char lun, const void
...
@@ -672,7 +672,7 @@ static int internal_command(unsigned char target, unsigned char lun, const void
*/
*/
for
(
clock
=
jiffies
+
10
,
temp
=
0
;
(
jiffies
<
clock
)
&&
for
(
clock
=
jiffies
+
10
,
temp
=
0
;
(
jiffies
<
clock
)
&&
!
((
temp
=
STATUS
)
&
STAT_IO
)
||
(
STAT
&
STAT_BSY
););
!
((
temp
=
STATUS
)
&
(
STAT_IO
|
STAT_BSY
)
););
if
(
jiffies
>=
clock
)
if
(
jiffies
>=
clock
)
{
{
...
...
drivers/scsi/sg.c
View file @
1235b44f
...
@@ -340,6 +340,7 @@ static void sg_init()
...
@@ -340,6 +340,7 @@ static void sg_init()
scsi_generics
=
(
struct
scsi_generic
*
)
scsi_generics
=
(
struct
scsi_generic
*
)
scsi_init_malloc
(
sg_template
.
dev_noticed
*
sizeof
(
struct
scsi_generic
));
scsi_init_malloc
(
sg_template
.
dev_noticed
*
sizeof
(
struct
scsi_generic
));
memset
(
scsi_generics
,
0
,
sg_template
.
dev_noticed
*
sizeof
(
struct
scsi_generic
));
sg_template
.
dev_max
=
sg_template
.
dev_noticed
;
sg_template
.
dev_max
=
sg_template
.
dev_noticed
;
}
}
...
...
drivers/scsi/sr.c
View file @
1235b44f
...
@@ -768,6 +768,7 @@ static void sr_init()
...
@@ -768,6 +768,7 @@ static void sr_init()
sr_template
.
dev_max
=
sr_template
.
dev_noticed
;
sr_template
.
dev_max
=
sr_template
.
dev_noticed
;
scsi_CDs
=
(
Scsi_CD
*
)
scsi_init_malloc
(
sr_template
.
dev_max
*
sizeof
(
Scsi_CD
));
scsi_CDs
=
(
Scsi_CD
*
)
scsi_init_malloc
(
sr_template
.
dev_max
*
sizeof
(
Scsi_CD
));
memset
(
scsi_CDs
,
0
,
sr_template
.
dev_max
*
sizeof
(
Scsi_CD
));
sr_sizes
=
(
int
*
)
scsi_init_malloc
(
sr_template
.
dev_max
*
sizeof
(
int
));
sr_sizes
=
(
int
*
)
scsi_init_malloc
(
sr_template
.
dev_max
*
sizeof
(
int
));
memset
(
sr_sizes
,
0
,
sr_template
.
dev_max
*
sizeof
(
int
));
memset
(
sr_sizes
,
0
,
sr_template
.
dev_max
*
sizeof
(
int
));
...
...
drivers/scsi/st.c
View file @
1235b44f
...
@@ -1750,6 +1750,7 @@ static void st_init()
...
@@ -1750,6 +1750,7 @@ static void st_init()
for
(
i
=
0
,
SDp
=
scsi_devices
;
i
<
st_template
.
dev_noticed
;
++
i
)
{
for
(
i
=
0
,
SDp
=
scsi_devices
;
i
<
st_template
.
dev_noticed
;
++
i
)
{
STp
=
&
(
scsi_tapes
[
i
]);
STp
=
&
(
scsi_tapes
[
i
]);
STp
->
device
=
NULL
;
STp
->
capacity
=
0xfffff
;
STp
->
capacity
=
0xfffff
;
STp
->
dirty
=
0
;
STp
->
dirty
=
0
;
STp
->
rw
=
ST_IDLE
;
STp
->
rw
=
ST_IDLE
;
...
...
drivers/sound/pas2_mixer.c
View file @
1235b44f
...
@@ -289,19 +289,6 @@ pas_mixer_set (int whichDev, unsigned int level)
...
@@ -289,19 +289,6 @@ pas_mixer_set (int whichDev, unsigned int level)
/*****/
/*****/
static
int
getmixer
(
int
dev
,
int
chn
)
{
if
(
chn
==
P_M_MV508_RIGHT
)
{
return
(
levels
[
dev
]
>>
8
)
&
0x7f
;
}
else
{
return
levels
[
dev
]
&
0x7f
;
}
}
static
void
static
void
pas_mixer_reset
(
void
)
pas_mixer_reset
(
void
)
{
{
...
...
fs/Makefile
View file @
1235b44f
...
@@ -7,7 +7,7 @@
...
@@ -7,7 +7,7 @@
#
#
# Note 2! The CFLAGS definitions are now in the main makefile...
# Note 2! The CFLAGS definitions are now in the main makefile...
SUBDIRS
=
minix ext ext2 msdos proc isofs nfs xiafs hpfs sysv
SUBDIRS
=
minix ext ext2 msdos proc isofs nfs xiafs
umsdos
hpfs sysv
ifdef
CONFIG_MINIX_FS
ifdef
CONFIG_MINIX_FS
FS_SUBDIRS
:=
$(FS_SUBDIRS)
minix
FS_SUBDIRS
:=
$(FS_SUBDIRS)
minix
...
...
fs/exec.c
View file @
1235b44f
...
@@ -48,8 +48,6 @@
...
@@ -48,8 +48,6 @@
#include <asm/system.h>
#include <asm/system.h>
asmlinkage
int
sys_exit
(
int
exit_code
);
asmlinkage
int
sys_exit
(
int
exit_code
);
asmlinkage
int
sys_close
(
unsigned
fd
);
asmlinkage
int
sys_open
(
const
char
*
,
int
,
int
);
asmlinkage
int
sys_brk
(
unsigned
long
);
asmlinkage
int
sys_brk
(
unsigned
long
);
extern
void
shm_exit
(
void
);
extern
void
shm_exit
(
void
);
...
...
fs/ext2/super.c
View file @
1235b44f
...
@@ -25,8 +25,6 @@
...
@@ -25,8 +25,6 @@
#include <linux/string.h>
#include <linux/string.h>
#include <linux/locks.h>
#include <linux/locks.h>
extern
int
vsprintf
(
char
*
,
const
char
*
,
va_list
);
void
ext2_error
(
struct
super_block
*
sb
,
const
char
*
function
,
void
ext2_error
(
struct
super_block
*
sb
,
const
char
*
function
,
const
char
*
fmt
,
...)
const
char
*
fmt
,
...)
{
{
...
...
fs/isofs/dir.c
View file @
1235b44f
...
@@ -57,12 +57,6 @@ struct inode_operations isofs_dir_inode_operations = {
...
@@ -57,12 +57,6 @@ struct inode_operations isofs_dir_inode_operations = {
NULL
/* permission */
NULL
/* permission */
};
};
/* This is used to speed up lookup. Without this we would need to
make a linear search of the directory to find the file that the
directory read just returned. This is a single element cache. */
struct
lookup_cache
cache
=
{
0
,};
static
int
isofs_readdir
(
struct
inode
*
inode
,
struct
file
*
filp
,
static
int
isofs_readdir
(
struct
inode
*
inode
,
struct
file
*
filp
,
struct
dirent
*
dirent
,
int
count
)
struct
dirent
*
dirent
,
int
count
)
{
{
...
@@ -75,9 +69,10 @@ static int isofs_readdir(struct inode * inode, struct file * filp,
...
@@ -75,9 +69,10 @@ static int isofs_readdir(struct inode * inode, struct file * filp,
void
*
cpnt
=
NULL
;
void
*
cpnt
=
NULL
;
unsigned
int
old_offset
;
unsigned
int
old_offset
;
int
dlen
,
rrflag
;
int
dlen
,
rrflag
;
char
*
dpnt
;
char
*
dpnt
,
*
dpnt1
;
struct
iso_directory_record
*
de
;
struct
iso_directory_record
*
de
;
dpnt1
=
NULL
;
if
(
!
inode
||
!
S_ISDIR
(
inode
->
i_mode
))
if
(
!
inode
||
!
S_ISDIR
(
inode
->
i_mode
))
return
-
EBADF
;
return
-
EBADF
;
...
@@ -124,20 +119,21 @@ static int isofs_readdir(struct inode * inode, struct file * filp,
...
@@ -124,20 +119,21 @@ static int isofs_readdir(struct inode * inode, struct file * filp,
filp
->
f_pos
+=
*
((
unsigned
char
*
)
de
);
filp
->
f_pos
+=
*
((
unsigned
char
*
)
de
);
if
(
offset
>=
bufsize
)
{
if
(
offset
>=
bufsize
)
{
cpnt
=
kmalloc
(
1
<<
ISOFS_BLOCK_BITS
,
GFP_KERNEL
);
unsigned
int
frag1
;
memcpy
(
cpnt
,
bh
->
b_data
,
bufsize
);
frag1
=
bufsize
-
old_offset
;
de
=
(
struct
iso_directory_record
*
)
cpnt
=
kmalloc
(
*
((
unsigned
char
*
)
de
),
GFP_KERNEL
);
((
char
*
)
cpnt
+
old_offset
);
memcpy
(
cpnt
,
bh
->
b_data
+
old_offset
,
frag1
);
de
=
(
struct
iso_directory_record
*
)
((
char
*
)
cpnt
);
brelse
(
bh
);
brelse
(
bh
);
offset
=
filp
->
f_pos
&
(
bufsize
-
1
);
offset
=
filp
->
f_pos
&
(
bufsize
-
1
);
block
=
isofs_bmap
(
inode
,(
filp
->
f_pos
)
>>
bufbits
);
block
=
isofs_bmap
(
inode
,(
filp
->
f_pos
)
>>
bufbits
);
if
(
!
block
if
(
!
block
||
!
(
bh
=
breada
(
inode
->
i_dev
,
block
,
bufsize
,
||
!
(
bh
=
breada
(
inode
->
i_dev
,
block
,
bufsize
,
filp
->
f_pos
,
inode
->
i_size
)))
{
filp
->
f_pos
,
inode
->
i_size
)))
{
kfree
_s
(
cpnt
,
1
<<
ISOFS_BLOCK_BITS
);
kfree
(
cpnt
);
return
0
;
return
0
;
};
};
memcpy
((
char
*
)
cpnt
+
bufsize
,
bh
->
b_data
,
bufsize
);
memcpy
((
char
*
)
cpnt
+
frag1
,
bh
->
b_data
,
offset
);
}
}
/* Handle the case of the '.' directory */
/* Handle the case of the '.' directory */
...
@@ -186,7 +182,7 @@ static int isofs_readdir(struct inode * inode, struct file * filp,
...
@@ -186,7 +182,7 @@ static int isofs_readdir(struct inode * inode, struct file * filp,
if
(
rrflag
)
{
if
(
rrflag
)
{
if
(
rrflag
==
-
1
)
{
/* This is a rock ridge reloc dir */
if
(
rrflag
==
-
1
)
{
/* This is a rock ridge reloc dir */
if
(
cpnt
)
{
if
(
cpnt
)
{
kfree
_s
(
cpnt
,
1
<<
ISOFS_BLOCK_BITS
);
kfree
(
cpnt
);
cpnt
=
NULL
;
cpnt
=
NULL
;
};
};
continue
;
continue
;
...
@@ -194,9 +190,11 @@ static int isofs_readdir(struct inode * inode, struct file * filp,
...
@@ -194,9 +190,11 @@ static int isofs_readdir(struct inode * inode, struct file * filp,
i
=
dlen
;
i
=
dlen
;
}
}
else
else
if
(
inode
->
i_sb
->
u
.
isofs_sb
.
s_mapping
==
'n'
)
if
(
inode
->
i_sb
->
u
.
isofs_sb
.
s_mapping
==
'n'
)
{
dpnt1
=
dpnt
;
dpnt
=
kmalloc
(
dlen
,
GFP_KERNEL
);
for
(
i
=
0
;
i
<
dlen
&&
i
<
NAME_MAX
;
i
++
)
{
for
(
i
=
0
;
i
<
dlen
&&
i
<
NAME_MAX
;
i
++
)
{
if
(
!
(
c
=
dpnt
[
i
]))
break
;
if
(
!
(
c
=
dpnt
1
[
i
]))
break
;
if
(
c
>=
'A'
&&
c
<=
'Z'
)
c
|=
0x20
;
/* lower case */
if
(
c
>=
'A'
&&
c
<=
'Z'
)
c
|=
0x20
;
/* lower case */
if
(
c
==
'.'
&&
i
==
dlen
-
3
&&
de
->
name
[
i
+
1
]
==
';'
&&
de
->
name
[
i
+
2
]
==
'1'
)
if
(
c
==
'.'
&&
i
==
dlen
-
3
&&
de
->
name
[
i
+
1
]
==
';'
&&
de
->
name
[
i
+
2
]
==
'1'
)
break
;
/* Drop trailing '.;1' (ISO9660:1988 7.5.1 requires period) */
break
;
/* Drop trailing '.;1' (ISO9660:1988 7.5.1 requires period) */
...
@@ -204,26 +202,24 @@ static int isofs_readdir(struct inode * inode, struct file * filp,
...
@@ -204,26 +202,24 @@ static int isofs_readdir(struct inode * inode, struct file * filp,
break
;
/* Drop trailing ';1' */
break
;
/* Drop trailing ';1' */
if
(
c
==
';'
)
c
=
'.'
;
/* Convert remaining ';' to '.' */
if
(
c
==
';'
)
c
=
'.'
;
/* Convert remaining ';' to '.' */
dpnt
[
i
]
=
c
;
dpnt
[
i
]
=
c
;
};
}
}
for
(
j
=
0
;
j
<
i
;
j
++
)
for
(
j
=
0
;
j
<
i
;
j
++
)
put_fs_byte
(
dpnt
[
j
],
j
+
dirent
->
d_name
);
/* And save it */
put_fs_byte
(
dpnt
[
j
],
j
+
dirent
->
d_name
);
/* And save it */
if
(
dpnt1
)
{
kfree
(
dpnt
);
dpnt
=
dpnt1
;
}
dcache_add
(
inode
,
dpnt
,
i
,
inode_number
);
};
};
#if 0
#if 0
printk("Nchar: %d\n",i);
printk("Nchar: %d\n",i);
#endif
#endif
if
(
i
&&
i
+
1
<
sizeof
(
cache
.
filename
))
{
cache
.
ino
=
inode_number
;
cache
.
dir
=
inode
->
i_ino
;
cache
.
dev
=
inode
->
i_dev
;
strncpy
(
cache
.
filename
,
dpnt
,
i
);
cache
.
dlen
=
dlen
;
};
if
(
rrflag
)
kfree
(
dpnt
);
if
(
rrflag
)
kfree
(
dpnt
);
if
(
cpnt
)
{
if
(
cpnt
)
{
kfree
_s
(
cpnt
,
1
<<
ISOFS_BLOCK_BITS
);
kfree
(
cpnt
);
cpnt
=
NULL
;
cpnt
=
NULL
;
};
};
...
@@ -239,7 +235,7 @@ static int isofs_readdir(struct inode * inode, struct file * filp,
...
@@ -239,7 +235,7 @@ static int isofs_readdir(struct inode * inode, struct file * filp,
to here at the end of the directory. */
to here at the end of the directory. */
out:
out:
if
(
cpnt
)
if
(
cpnt
)
kfree
_s
(
cpnt
,
1
<<
ISOFS_BLOCK_BITS
);
kfree
(
cpnt
);
brelse
(
bh
);
brelse
(
bh
);
return
0
;
return
0
;
}
}
...
...
fs/isofs/file.c
View file @
1235b44f
...
@@ -72,14 +72,19 @@ struct inode_operations isofs_file_inode_operations = {
...
@@ -72,14 +72,19 @@ struct inode_operations isofs_file_inode_operations = {
* a 0x0a. A control-Z is also turned into a linefeed.
* a 0x0a. A control-Z is also turned into a linefeed.
*/
*/
static
inline
void
unixify_text_buffer
(
char
*
buffer
,
int
chars
,
int
mode
)
static
inline
void
unixify_to_fs
(
char
*
outbuf
,
char
*
buffer
,
int
chars
,
int
mode
)
{
{
char
outchar
;
while
(
chars
--
){
while
(
chars
--
){
if
(
*
buffer
==
0x1a
)
*
buffer
=
0x0a
;
outchar
=
*
buffer
;
if
(
*
buffer
==
0x0d
){
if
(
outchar
==
0x1a
)
outchar
=
0x0a
;
if
(
mode
==
ISOFS_FILE_TEXT_M
)
*
buffer
=
0x0a
;
if
(
outchar
==
0x0d
){
if
(
mode
==
ISOFS_FILE_TEXT
)
*
buffer
=
' '
;
if
(
mode
==
ISOFS_FILE_TEXT_M
)
outchar
=
0x0a
;
if
(
mode
==
ISOFS_FILE_TEXT
)
outchar
=
' '
;
}
}
put_fs_byte
(
outchar
,
outbuf
++
);
buffer
++
;
buffer
++
;
}
}
}
}
...
@@ -210,9 +215,10 @@ static int isofs_file_read(struct inode * inode, struct file * filp, char * buf,
...
@@ -210,9 +215,10 @@ static int isofs_file_read(struct inode * inode, struct file * filp, char * buf,
if
(
*
bhe
)
{
if
(
*
bhe
)
{
if
(
inode
->
u
.
isofs_i
.
i_file_format
==
ISOFS_FILE_TEXT
||
if
(
inode
->
u
.
isofs_i
.
i_file_format
==
ISOFS_FILE_TEXT
||
inode
->
u
.
isofs_i
.
i_file_format
==
ISOFS_FILE_TEXT_M
)
inode
->
u
.
isofs_i
.
i_file_format
==
ISOFS_FILE_TEXT_M
)
unixify_text_buffer
(
offset
+
(
*
bhe
)
->
b_data
,
unixify_to_fs
(
buf
,
offset
+
(
*
bhe
)
->
b_data
,
chars
,
chars
,
inode
->
u
.
isofs_i
.
i_file_format
);
inode
->
u
.
isofs_i
.
i_file_format
);
memcpy_tofs
(
buf
,
offset
+
(
*
bhe
)
->
b_data
,
chars
);
else
memcpy_tofs
(
buf
,
offset
+
(
*
bhe
)
->
b_data
,
chars
);
brelse
(
*
bhe
);
brelse
(
*
bhe
);
buf
+=
chars
;
buf
+=
chars
;
}
else
{
}
else
{
...
...
fs/isofs/inode.c
View file @
1235b44f
...
@@ -346,22 +346,26 @@ void isofs_read_inode(struct inode * inode)
...
@@ -346,22 +346,26 @@ void isofs_read_inode(struct inode * inode)
high_sierra
=
inode
->
i_sb
->
u
.
isofs_sb
.
s_high_sierra
;
high_sierra
=
inode
->
i_sb
->
u
.
isofs_sb
.
s_high_sierra
;
if
((
inode
->
i_ino
&
(
bufsize
-
1
))
+
*
pnt
>
bufsize
){
if
((
inode
->
i_ino
&
(
bufsize
-
1
))
+
*
pnt
>
bufsize
){
cpnt
=
kmalloc
(
1
<<
ISOFS_BLOCK_BITS
,
GFP_KERNEL
);
int
frag1
,
offset
;
offset
=
(
inode
->
i_ino
&
(
bufsize
-
1
));
frag1
=
bufsize
-
offset
;
cpnt
=
kmalloc
(
*
pnt
,
GFP_KERNEL
);
if
(
cpnt
==
NULL
)
{
if
(
cpnt
==
NULL
)
{
printk
(
KERN_INFO
"NoMem ISO inode %lu
\n
"
,
inode
->
i_ino
);
printk
(
KERN_INFO
"NoMem ISO inode %lu
\n
"
,
inode
->
i_ino
);
brelse
(
bh
);
brelse
(
bh
);
goto
fail
;
goto
fail
;
}
}
memcpy
(
cpnt
,
bh
->
b_data
,
bufsize
);
memcpy
(
cpnt
,
bh
->
b_data
+
offset
,
frag1
);
brelse
(
bh
);
brelse
(
bh
);
if
(
!
(
bh
=
bread
(
inode
->
i_dev
,
++
block
,
bufsize
)))
{
if
(
!
(
bh
=
bread
(
inode
->
i_dev
,
++
block
,
bufsize
)))
{
kfree
_s
(
cpnt
,
1
<<
ISOFS_BLOCK_BITS
);
kfree
(
cpnt
);
printk
(
"unable to read i-node block"
);
printk
(
"unable to read i-node block"
);
goto
fail
;
goto
fail
;
}
}
memcpy
((
char
*
)
cpnt
+
bufsize
,
bh
->
b_data
,
bufsize
)
;
offset
+=
*
pnt
-
bufsize
;
pnt
=
((
unsigned
char
*
)
cpnt
memcpy
((
char
*
)
cpnt
+
frag1
,
bh
->
b_data
,
offset
);
+
(
inode
->
i_ino
&
(
bufsize
-
1
))
);
pnt
=
((
unsigned
char
*
)
cpnt
);
raw_inode
=
((
struct
iso_directory_record
*
)
pnt
);
raw_inode
=
((
struct
iso_directory_record
*
)
pnt
);
}
}
...
@@ -370,8 +374,11 @@ void isofs_read_inode(struct inode * inode)
...
@@ -370,8 +374,11 @@ void isofs_read_inode(struct inode * inode)
if
(
raw_inode
->
flags
[
-
high_sierra
]
&
2
)
{
if
(
raw_inode
->
flags
[
-
high_sierra
]
&
2
)
{
inode
->
i_mode
=
S_IRUGO
|
S_IXUGO
|
S_IFDIR
;
inode
->
i_mode
=
S_IRUGO
|
S_IXUGO
|
S_IFDIR
;
inode
->
i_nlink
=
2
;
/* There are always at least 2. It is
inode
->
i_nlink
=
1
;
/* Set to 1. We know there are 2, but
hard to figure out what is correct*/
the find utility tries to optimize
if it is 2, and it screws up. It is
easier to give 1 which tells find to
do it the hard way. */
}
else
{
}
else
{
inode
->
i_mode
=
S_IRUGO
;
/* Everybody gets to read the file. */
inode
->
i_mode
=
S_IRUGO
;
/* Everybody gets to read the file. */
inode
->
i_nlink
=
1
;
inode
->
i_nlink
=
1
;
...
@@ -491,7 +498,7 @@ void isofs_read_inode(struct inode * inode)
...
@@ -491,7 +498,7 @@ void isofs_read_inode(struct inode * inode)
init_fifo
(
inode
);
init_fifo
(
inode
);
}
}
if
(
cpnt
)
{
if
(
cpnt
)
{
kfree
_s
(
cpnt
,
1
<<
ISOFS_BLOCK_BITS
);
kfree
(
cpnt
);
cpnt
=
NULL
;
cpnt
=
NULL
;
}
}
return
;
return
;
...
@@ -536,6 +543,7 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
...
@@ -536,6 +543,7 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
int
old_offset
;
int
old_offset
;
void
*
cpnt
=
NULL
;
void
*
cpnt
=
NULL
;
int
result
;
int
result
;
int
directory_size
;
struct
buffer_head
*
bh
;
struct
buffer_head
*
bh
;
struct
iso_directory_record
*
de
;
struct
iso_directory_record
*
de
;
...
@@ -564,6 +572,7 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
...
@@ -564,6 +572,7 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
if
(
de
->
name_len
[
0
]
==
1
&&
de
->
name
[
0
]
==
1
)
if
(
de
->
name_len
[
0
]
==
1
&&
de
->
name
[
0
]
==
1
)
{
{
parent_dir
=
find_rock_ridge_relocation
(
de
,
parent
);
parent_dir
=
find_rock_ridge_relocation
(
de
,
parent
);
directory_size
=
isonum_733
(
de
->
size
);
brelse
(
bh
);
brelse
(
bh
);
break
;
break
;
}
}
...
@@ -571,9 +580,7 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
...
@@ -571,9 +580,7 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
#ifdef DEBUG
#ifdef DEBUG
printk
(
"Parent dir:%x
\n
"
,
parent_dir
);
printk
(
"Parent dir:%x
\n
"
,
parent_dir
);
#endif
#endif
/* Now we know the extent where the parent dir starts on. We have no
/* Now we know the extent where the parent dir starts on. */
idea how long it is, so we just start reading until we either find
it or we find some kind of unreasonable circumstance. */
result
=
-
1
;
result
=
-
1
;
...
@@ -596,6 +603,8 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
...
@@ -596,6 +603,8 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
brelse
(
bh
);
brelse
(
bh
);
offset
=
0
;
offset
=
0
;
block
++
;
block
++
;
directory_size
-=
bufsize
;
if
(
directory_size
<
0
)
return
-
1
;
if
((
block
&
1
)
&&
(
ISOFS_BLOCK_BITS
-
bufbits
))
if
((
block
&
1
)
&&
(
ISOFS_BLOCK_BITS
-
bufbits
))
return
-
1
;
return
-
1
;
if
(
!
block
if
(
!
block
...
@@ -613,19 +622,21 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
...
@@ -613,19 +622,21 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
if
(
offset
>=
bufsize
)
if
(
offset
>=
bufsize
)
{
{
if
((
block
&
1
)
!=
0
)
return
-
1
;
unsigned
int
frag
1
;
cpnt
=
kmalloc
(
1
<<
ISOFS_BLOCK_BITS
,
GFP_KERNEL
)
;
frag1
=
bufsize
-
old_offset
;
memcpy
(
cpnt
,
bh
->
b_data
,
bufsize
);
cpnt
=
kmalloc
(
*
((
unsigned
char
*
)
de
),
GFP_KERNEL
);
de
=
(
struct
iso_directory_record
*
)
memcpy
(
cpnt
,
bh
->
b_data
+
old_offset
,
frag1
);
((
char
*
)
cpnt
+
old_offse
t
);
de
=
(
struct
iso_directory_record
*
)
((
char
*
)
cpn
t
);
brelse
(
bh
);
brelse
(
bh
);
offset
-=
bufsize
;
offset
-=
bufsize
;
directory_size
-=
bufsize
;
if
(
directory_size
<
0
)
return
-
1
;
block
++
;
block
++
;
if
(
!
(
bh
=
bread
(
parent
->
i_dev
,
block
,
bufsize
)))
{
if
(
!
(
bh
=
bread
(
parent
->
i_dev
,
block
,
bufsize
)))
{
kfree_s
(
cpnt
,
1
<<
ISOFS_BLOCK_BITS
);
kfree
(
cpnt
);
return
-
1
;
return
-
1
;
};
};
memcpy
((
char
*
)
cpnt
+
bufsize
,
bh
->
b_data
,
bufsize
);
memcpy
((
char
*
)
cpnt
+
frag1
,
bh
->
b_data
,
offset
);
}
}
if
(
find_rock_ridge_relocation
(
de
,
parent
)
==
extent
){
if
(
find_rock_ridge_relocation
(
de
,
parent
)
==
extent
){
...
@@ -634,7 +645,7 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
...
@@ -634,7 +645,7 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
}
}
if
(
cpnt
)
{
if
(
cpnt
)
{
kfree
_s
(
cpnt
,
1
<<
ISOFS_BLOCK_BITS
);
kfree
(
cpnt
);
cpnt
=
NULL
;
cpnt
=
NULL
;
}
}
}
}
...
@@ -644,7 +655,7 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
...
@@ -644,7 +655,7 @@ int isofs_lookup_grandparent(struct inode * parent, int extent)
out:
out:
if
(
cpnt
)
{
if
(
cpnt
)
{
kfree
_s
(
cpnt
,
1
<<
ISOFS_BLOCK_BITS
);
kfree
(
cpnt
);
cpnt
=
NULL
;
cpnt
=
NULL
;
}
}
brelse
(
bh
);
brelse
(
bh
);
...
...
fs/isofs/namei.c
View file @
1235b44f
...
@@ -116,18 +116,20 @@ static struct buffer_head * isofs_find_entry(struct inode * dir,
...
@@ -116,18 +116,20 @@ static struct buffer_head * isofs_find_entry(struct inode * dir,
/* Handle case where the directory entry spans two blocks.
/* Handle case where the directory entry spans two blocks.
Usually 1024 byte boundaries */
Usually 1024 byte boundaries */
if
(
offset
>=
bufsize
)
{
if
(
offset
>=
bufsize
)
{
cpnt
=
kmalloc
(
1
<<
ISOFS_BLOCK_BITS
,
GFP_KERNEL
);
unsigned
int
frag1
;
memcpy
(
cpnt
,
bh
->
b_data
,
bufsize
);
frag1
=
bufsize
-
old_offset
;
de
=
(
struct
iso_directory_record
*
)
cpnt
=
kmalloc
(
*
((
unsigned
char
*
)
de
),
GFP_KERNEL
);
((
char
*
)
cpnt
+
old_offset
);
memcpy
(
cpnt
,
bh
->
b_data
+
old_offset
,
frag1
);
de
=
(
struct
iso_directory_record
*
)
cpnt
;
brelse
(
bh
);
brelse
(
bh
);
offset
=
f_pos
&
(
bufsize
-
1
);
offset
=
f_pos
&
(
bufsize
-
1
);
block
=
isofs_bmap
(
dir
,
f_pos
>>
bufbits
);
block
=
isofs_bmap
(
dir
,
f_pos
>>
bufbits
);
if
(
!
block
||
!
(
bh
=
bread
(
dir
->
i_dev
,
block
,
bufsize
)))
{
if
(
!
block
||
!
(
bh
=
bread
(
dir
->
i_dev
,
block
,
bufsize
)))
{
kfree
_s
(
cpnt
,
1
<<
ISOFS_BLOCK_BITS
);
kfree
(
cpnt
);
return
0
;
return
0
;
};
};
memcpy
((
char
*
)
cpnt
+
bufsize
,
bh
->
b_data
,
bufsize
);
memcpy
((
char
*
)
cpnt
+
frag1
,
bh
->
b_data
,
offset
);
}
}
/* Handle the '.' case */
/* Handle the '.' case */
...
@@ -179,7 +181,7 @@ static struct buffer_head * isofs_find_entry(struct inode * dir,
...
@@ -179,7 +181,7 @@ static struct buffer_head * isofs_find_entry(struct inode * dir,
}
}
match
=
isofs_match
(
namelen
,
name
,
dpnt
,
dlen
);
match
=
isofs_match
(
namelen
,
name
,
dpnt
,
dlen
);
if
(
cpnt
)
{
if
(
cpnt
)
{
kfree
_s
(
cpnt
,
1
<<
ISOFS_BLOCK_BITS
);
kfree
(
cpnt
);
cpnt
=
NULL
;
cpnt
=
NULL
;
}
}
...
@@ -203,7 +205,7 @@ static struct buffer_head * isofs_find_entry(struct inode * dir,
...
@@ -203,7 +205,7 @@ static struct buffer_head * isofs_find_entry(struct inode * dir,
}
}
out:
out:
if
(
cpnt
)
if
(
cpnt
)
kfree
_s
(
cpnt
,
1
<<
ISOFS_BLOCK_BITS
);
kfree
(
cpnt
);
brelse
(
bh
);
brelse
(
bh
);
return
NULL
;
return
NULL
;
}
}
...
@@ -227,25 +229,16 @@ int isofs_lookup(struct inode * dir,const char * name, int len,
...
@@ -227,25 +229,16 @@ int isofs_lookup(struct inode * dir,const char * name, int len,
}
}
ino
=
0
;
ino
=
0
;
if
(
dir
->
i_dev
==
cache
.
dev
&&
dir
->
i_ino
==
cache
.
dir
&&
if
(
dcache_lookup
(
dir
,
name
,
len
,
&
ino
))
ino_back
=
dir
->
i_ino
;
len
==
cache
.
dlen
&&
isofs_match
(
len
,
name
,
cache
.
filename
,
cache
.
dlen
))
{
ino
=
cache
.
ino
;
ino_back
=
dir
->
i_ino
;
/* These two cases are special, but since they are at the start
of the directory, we can just as easily search there */
if
(
cache
.
dlen
==
1
&&
cache
.
filename
[
0
]
==
'.'
)
ino
=
0
;
if
(
cache
.
dlen
==
2
&&
cache
.
filename
[
0
]
==
'.'
&&
cache
.
filename
[
1
]
==
'.'
)
ino
=
0
;
};
if
(
!
ino
)
{
if
(
!
ino
)
{
if
(
!
(
bh
=
isofs_find_entry
(
dir
,
name
,
len
,
&
ino
,
&
ino_back
)))
{
if
(
!
(
bh
=
isofs_find_entry
(
dir
,
name
,
len
,
&
ino
,
&
ino_back
)))
{
iput
(
dir
);
iput
(
dir
);
return
-
ENOENT
;
return
-
ENOENT
;
}
}
if
(
ino_back
==
dir
->
i_ino
)
dcache_add
(
dir
,
name
,
len
,
ino
);
brelse
(
bh
);
brelse
(
bh
);
};
};
...
...
fs/isofs/rock.c
View file @
1235b44f
...
@@ -419,16 +419,22 @@ char * get_rock_ridge_symlink(struct inode * inode)
...
@@ -419,16 +419,22 @@ char * get_rock_ridge_symlink(struct inode * inode)
raw_inode
=
((
struct
iso_directory_record
*
)
pnt
);
raw_inode
=
((
struct
iso_directory_record
*
)
pnt
);
if
((
inode
->
i_ino
&
(
bufsize
-
1
))
+
*
pnt
>
bufsize
){
if
((
inode
->
i_ino
&
(
bufsize
-
1
))
+
*
pnt
>
bufsize
){
cpnt
=
kmalloc
(
1
<<
ISOFS_BLOCK_BITS
,
GFP_KERNEL
);
int
frag1
,
offset
;
memcpy
(
cpnt
,
bh
->
b_data
,
bufsize
);
offset
=
(
inode
->
i_ino
&
(
bufsize
-
1
));
frag1
=
bufsize
-
offset
;
cpnt
=
kmalloc
(
*
pnt
,
GFP_KERNEL
);
if
(
!
cpnt
)
return
NULL
;
memcpy
(
cpnt
,
bh
->
b_data
+
offset
,
frag1
);
brelse
(
bh
);
brelse
(
bh
);
if
(
!
(
bh
=
bread
(
inode
->
i_dev
,
++
block
,
bufsize
)))
{
if
(
!
(
bh
=
bread
(
inode
->
i_dev
,
++
block
,
bufsize
)))
{
kfree
_s
(
cpnt
,
1
<<
ISOFS_BLOCK_BITS
);
kfree
(
cpnt
);
printk
(
"unable to read i-node block"
);
printk
(
"unable to read i-node block"
);
return
NULL
;
return
NULL
;
};
};
memcpy
((
char
*
)
cpnt
+
bufsize
,
bh
->
b_data
,
bufsize
);
offset
+=
*
pnt
-
bufsize
;
pnt
=
((
unsigned
char
*
)
cpnt
)
+
(
inode
->
i_ino
&
(
bufsize
-
1
));
memcpy
((
char
*
)
cpnt
+
frag1
,
bh
->
b_data
,
offset
);
pnt
=
((
unsigned
char
*
)
cpnt
);
raw_inode
=
((
struct
iso_directory_record
*
)
pnt
);
raw_inode
=
((
struct
iso_directory_record
*
)
pnt
);
};
};
...
...
fs/msdos/dir.c
View file @
1235b44f
...
@@ -20,10 +20,6 @@ static int msdos_dir_read(struct inode * inode,struct file * filp, char * buf,in
...
@@ -20,10 +20,6 @@ static int msdos_dir_read(struct inode * inode,struct file * filp, char * buf,in
return
-
EISDIR
;
return
-
EISDIR
;
}
}
int
msdos_readdir
(
struct
inode
*
inode
,
struct
file
*
filp
,
struct
dirent
*
dirent
,
int
count
);
static
struct
file_operations
msdos_dir_operations
=
{
static
struct
file_operations
msdos_dir_operations
=
{
NULL
,
/* lseek - default */
NULL
,
/* lseek - default */
msdos_dir_read
,
/* read */
msdos_dir_read
,
/* read */
...
...
fs/proc/base.c
View file @
1235b44f
...
@@ -58,7 +58,6 @@ static struct proc_dir_entry base_dir[] = {
...
@@ -58,7 +58,6 @@ static struct proc_dir_entry base_dir[] = {
{
5
,
4
,
"root"
},
{
5
,
4
,
"root"
},
{
6
,
3
,
"exe"
},
{
6
,
3
,
"exe"
},
{
7
,
2
,
"fd"
},
{
7
,
2
,
"fd"
},
{
8
,
4
,
"mmap"
},
{
9
,
7
,
"environ"
},
{
9
,
7
,
"environ"
},
{
10
,
7
,
"cmdline"
},
{
10
,
7
,
"cmdline"
},
{
11
,
4
,
"stat"
},
{
11
,
4
,
"stat"
},
...
...
fs/proc/fd.c
View file @
1235b44f
...
@@ -66,7 +66,7 @@ static int proc_lookupfd(struct inode * dir,const char * name, int len,
...
@@ -66,7 +66,7 @@ static int proc_lookupfd(struct inode * dir,const char * name, int len,
if
(
!
dir
)
if
(
!
dir
)
return
-
ENOENT
;
return
-
ENOENT
;
sb
=
dir
->
i_sb
;
sb
=
dir
->
i_sb
;
if
(
!
pid
||
ino
>
1
||
!
S_ISDIR
(
dir
->
i_mode
))
{
if
(
!
pid
||
ino
||
!
S_ISDIR
(
dir
->
i_mode
))
{
iput
(
dir
);
iput
(
dir
);
return
-
ENOENT
;
return
-
ENOENT
;
}
}
...
@@ -104,20 +104,12 @@ static int proc_lookupfd(struct inode * dir,const char * name, int len,
...
@@ -104,20 +104,12 @@ static int proc_lookupfd(struct inode * dir,const char * name, int len,
break
;
break
;
if
(
!
pid
||
i
>=
NR_TASKS
)
if
(
!
pid
||
i
>=
NR_TASKS
)
return
-
ENOENT
;
return
-
ENOENT
;
if
(
!
ino
)
{
if
(
fd
>=
NR_OPEN
||
!
p
->
files
->
fd
[
fd
]
||
!
p
->
files
->
fd
[
fd
]
->
f_inode
)
if
(
fd
>=
NR_OPEN
||
!
p
->
files
->
fd
[
fd
]
||
!
p
->
files
->
fd
[
fd
]
->
f_inode
)
return
-
ENOENT
;
return
-
ENOENT
;
ino
=
(
pid
<<
16
)
+
0x100
+
fd
;
}
else
{
ino
=
(
pid
<<
16
)
+
0x100
+
fd
;
int
j
=
0
;
struct
vm_area_struct
*
mpnt
;
for
(
mpnt
=
p
->
mm
->
mmap
;
mpnt
;
mpnt
=
mpnt
->
vm_next
)
if
(
mpnt
->
vm_inode
)
j
++
;
if
(
fd
>=
j
)
return
-
ENOENT
;
ino
=
(
pid
<<
16
)
+
0x200
+
fd
;
}
if
(
!
(
*
result
=
iget
(
sb
,
ino
)))
if
(
!
(
*
result
=
iget
(
sb
,
ino
)))
return
-
ENOENT
;
return
-
ENOENT
;
return
0
;
return
0
;
...
@@ -136,7 +128,7 @@ static int proc_readfd(struct inode * inode, struct file * filp,
...
@@ -136,7 +128,7 @@ static int proc_readfd(struct inode * inode, struct file * filp,
pid
=
ino
>>
16
;
pid
=
ino
>>
16
;
ino
&=
0x0000ffff
;
ino
&=
0x0000ffff
;
ino
-=
7
;
ino
-=
7
;
if
(
ino
>
1
)
if
(
ino
)
return
0
;
return
0
;
while
(
1
)
{
while
(
1
)
{
fd
=
filp
->
f_pos
;
fd
=
filp
->
f_pos
;
...
@@ -160,20 +152,12 @@ static int proc_readfd(struct inode * inode, struct file * filp,
...
@@ -160,20 +152,12 @@ static int proc_readfd(struct inode * inode, struct file * filp,
break
;
break
;
if
(
i
>=
NR_TASKS
)
if
(
i
>=
NR_TASKS
)
return
0
;
return
0
;
if
(
!
ino
)
{
if
(
fd
>=
NR_OPEN
)
if
(
fd
>=
NR_OPEN
)
break
;
break
;
if
(
!
p
->
files
->
fd
[
fd
]
||
!
p
->
files
->
fd
[
fd
]
->
f_inode
)
if
(
!
p
->
files
->
fd
[
fd
]
||
!
p
->
files
->
fd
[
fd
]
->
f_inode
)
continue
;
continue
;
}
else
{
int
j
=
0
;
struct
vm_area_struct
*
mpnt
;
for
(
mpnt
=
p
->
mm
->
mmap
;
mpnt
;
mpnt
=
mpnt
->
vm_next
)
if
(
mpnt
->
vm_inode
)
j
++
;
if
(
fd
>=
j
)
break
;
}
j
=
10
;
j
=
10
;
i
=
1
;
i
=
1
;
while
(
fd
>=
j
)
{
while
(
fd
>=
j
)
{
...
@@ -181,10 +165,8 @@ static int proc_readfd(struct inode * inode, struct file * filp,
...
@@ -181,10 +165,8 @@ static int proc_readfd(struct inode * inode, struct file * filp,
i
++
;
i
++
;
}
}
j
=
i
;
j
=
i
;
if
(
!
ino
)
ino
=
(
pid
<<
16
)
+
0x100
+
fd
;
ino
=
(
pid
<<
16
)
+
0x100
+
fd
;
else
ino
=
(
pid
<<
16
)
+
0x200
+
fd
;
put_fs_long
(
ino
,
&
dirent
->
d_ino
);
put_fs_long
(
ino
,
&
dirent
->
d_ino
);
put_fs_word
(
i
,
&
dirent
->
d_reclen
);
put_fs_word
(
i
,
&
dirent
->
d_reclen
);
put_fs_byte
(
0
,
i
+
dirent
->
d_name
);
put_fs_byte
(
0
,
i
+
dirent
->
d_name
);
...
...
fs/proc/inode.c
View file @
1235b44f
...
@@ -152,7 +152,6 @@ void proc_read_inode(struct inode * inode)
...
@@ -152,7 +152,6 @@ void proc_read_inode(struct inode * inode)
inode
->
i_mode
=
S_IFLNK
|
S_IRWXU
;
inode
->
i_mode
=
S_IFLNK
|
S_IRWXU
;
return
;
return
;
case
7
:
case
7
:
case
8
:
inode
->
i_mode
=
S_IFDIR
|
S_IRUSR
|
S_IXUSR
;
inode
->
i_mode
=
S_IFDIR
|
S_IRUSR
|
S_IXUSR
;
inode
->
i_op
=
&
proc_fd_inode_operations
;
inode
->
i_op
=
&
proc_fd_inode_operations
;
inode
->
i_nlink
=
2
;
inode
->
i_nlink
=
2
;
...
...
fs/super.c
View file @
1235b44f
...
@@ -27,6 +27,7 @@ extern struct file_operations * get_chrfops(unsigned int);
...
@@ -27,6 +27,7 @@ extern struct file_operations * get_chrfops(unsigned int);
extern
void
wait_for_keypress
(
void
);
extern
void
wait_for_keypress
(
void
);
extern
void
fcntl_init_locks
(
void
);
extern
void
fcntl_init_locks
(
void
);
extern
int
floppy_grab_irq_and_dma
(
void
);
extern
int
root_mountflags
;
extern
int
root_mountflags
;
...
...
include/linux/iso_fs.h
View file @
1235b44f
...
@@ -190,16 +190,6 @@ extern struct inode_operations isofs_chrdev_inode_operations;
...
@@ -190,16 +190,6 @@ extern struct inode_operations isofs_chrdev_inode_operations;
extern
struct
inode_operations
isofs_blkdev_inode_operations
;
extern
struct
inode_operations
isofs_blkdev_inode_operations
;
extern
struct
inode_operations
isofs_fifo_inode_operations
;
extern
struct
inode_operations
isofs_fifo_inode_operations
;
struct
lookup_cache
{
unsigned
long
dir
;
/* If this matches... */
dev_t
dev
;
/* And this matches */
unsigned
short
dlen
;
/* and this matches... */
char
filename
[
256
];
/* and this matches... */
unsigned
long
ino
;
/* Then this is the file we are looking for */
};
extern
struct
lookup_cache
cache
;
/* The following macros are used to check for memory leaks. */
/* The following macros are used to check for memory leaks. */
#ifdef LEAK_CHECK
#ifdef LEAK_CHECK
#define free_s leak_check_free_s
#define free_s leak_check_free_s
...
...
include/linux/proc_fs.h
View file @
1235b44f
...
@@ -31,6 +31,5 @@ extern struct inode_operations proc_array_inode_operations;
...
@@ -31,6 +31,5 @@ extern struct inode_operations proc_array_inode_operations;
extern
struct
inode_operations
proc_kmsg_inode_operations
;
extern
struct
inode_operations
proc_kmsg_inode_operations
;
extern
struct
inode_operations
proc_link_inode_operations
;
extern
struct
inode_operations
proc_link_inode_operations
;
extern
struct
inode_operations
proc_fd_inode_operations
;
extern
struct
inode_operations
proc_fd_inode_operations
;
extern
struct
inode_operations
proc_net_inode_operations
;
#endif
#endif
init/main.c
View file @
1235b44f
...
@@ -68,7 +68,6 @@ static char printbuf[1024];
...
@@ -68,7 +68,6 @@ static char printbuf[1024];
extern
int
console_loglevel
;
extern
int
console_loglevel
;
extern
char
empty_zero_page
[
PAGE_SIZE
];
extern
char
empty_zero_page
[
PAGE_SIZE
];
extern
int
vsprintf
(
char
*
,
const
char
*
,
va_list
);
extern
void
init
(
void
);
extern
void
init
(
void
);
extern
void
init_IRQ
(
void
);
extern
void
init_IRQ
(
void
);
extern
void
init_modules
(
void
);
extern
void
init_modules
(
void
);
...
...
kernel/bios32.c
View file @
1235b44f
...
@@ -397,7 +397,7 @@ void NCR53c810_test(void) {
...
@@ -397,7 +397,7 @@ void NCR53c810_test(void) {
}
}
char
*
pcibios_strerror
(
int
error
)
{
char
*
pcibios_strerror
(
int
error
)
{
char
buf
[
80
];
static
char
buf
[
80
];
switch
(
error
)
{
switch
(
error
)
{
case
PCIBIOS_SUCCESFUL
:
case
PCIBIOS_SUCCESFUL
:
return
"SUCCESFUL"
;
return
"SUCCESFUL"
;
...
...
kernel/ksyms.c
View file @
1235b44f
...
@@ -45,26 +45,14 @@ extern void free_dma(unsigned int dmanr);
...
@@ -45,26 +45,14 @@ extern void free_dma(unsigned int dmanr);
extern
int
do_execve
(
char
*
filename
,
char
**
argv
,
char
**
envp
,
extern
int
do_execve
(
char
*
filename
,
char
**
argv
,
char
**
envp
,
struct
pt_regs
*
regs
);
struct
pt_regs
*
regs
);
extern
void
flush_old_exec
(
struct
linux_binprm
*
bprm
);
extern
int
open_inode
(
struct
inode
*
inode
,
int
mode
);
extern
int
read_exec
(
struct
inode
*
inode
,
unsigned
long
offset
,
char
*
addr
,
unsigned
long
count
);
extern
int
do_signal
(
unsigned
long
oldmask
,
struct
pt_regs
*
regs
);
extern
int
do_signal
(
unsigned
long
oldmask
,
struct
pt_regs
*
regs
);
extern
void
(
*
iABI_hook
)(
struct
pt_regs
*
regs
);
extern
void
(
*
iABI_hook
)(
struct
pt_regs
*
regs
);
#ifdef CONFIG_INET
#ifdef CONFIG_INET
extern
int
register_netdev
(
struct
device
*
);
extern
void
unregister_netdev
(
struct
device
*
);
extern
void
ether_setup
(
struct
device
*
);
extern
struct
sk_buff
*
alloc_skb
(
unsigned
int
,
int
);
extern
void
kfree_skb
(
struct
sk_buff
*
,
int
);
extern
void
snarf_region
(
unsigned
int
,
unsigned
int
);
extern
void
snarf_region
(
unsigned
int
,
unsigned
int
);
extern
void
netif_rx
(
struct
sk_buff
*
);
extern
int
dev_rint
(
unsigned
char
*
,
long
,
int
,
struct
device
*
);
extern
void
dev_tint
(
struct
device
*
);
extern
void
dev_tint
(
struct
device
*
);
extern
struct
device
*
irq2dev_map
[];
extern
struct
device
*
irq2dev_map
[];
extern
void
dev_kfree_skb
(
struct
sk_buff
*
,
int
);
#endif
#endif
...
@@ -83,6 +71,8 @@ struct symbol_table symbol_table = { 0, 0, 0, /* for stacked module support */
...
@@ -83,6 +71,8 @@ struct symbol_table symbol_table = { 0, 0, 0, /* for stacked module support */
X
(
do_munmap
),
X
(
do_munmap
),
X
(
zeromap_page_range
),
X
(
zeromap_page_range
),
X
(
unmap_page_range
),
X
(
unmap_page_range
),
X
(
insert_vm_struct
),
X
(
merge_segments
),
/* internal kernel memory management */
/* internal kernel memory management */
X
(
__get_free_pages
),
X
(
__get_free_pages
),
...
...
kernel/panic.c
View file @
1235b44f
...
@@ -15,8 +15,6 @@
...
@@ -15,8 +15,6 @@
asmlinkage
void
sys_sync
(
void
);
/* it's really int */
asmlinkage
void
sys_sync
(
void
);
/* it's really int */
extern
int
vsprintf
(
char
*
buf
,
const
char
*
fmt
,
va_list
args
);
NORET_TYPE
void
panic
(
const
char
*
fmt
,
...)
NORET_TYPE
void
panic
(
const
char
*
fmt
,
...)
{
{
static
char
buf
[
1024
];
static
char
buf
[
1024
];
...
...
kernel/printk.c
View file @
1235b44f
...
@@ -24,7 +24,6 @@
...
@@ -24,7 +24,6 @@
static
char
buf
[
1024
];
static
char
buf
[
1024
];
extern
int
vsprintf
(
char
*
buf
,
const
char
*
fmt
,
va_list
args
);
extern
void
console_print
(
const
char
*
);
extern
void
console_print
(
const
char
*
);
#define DEFAULT_MESSAGE_LOGLEVEL 7
/* KERN_DEBUG */
#define DEFAULT_MESSAGE_LOGLEVEL 7
/* KERN_DEBUG */
...
...
net/inet/dev.c
View file @
1235b44f
...
@@ -468,7 +468,6 @@ void dev_queue_xmit(struct sk_buff *skb, struct device *dev, int pri)
...
@@ -468,7 +468,6 @@ void dev_queue_xmit(struct sk_buff *skb, struct device *dev, int pri)
void
netif_rx
(
struct
sk_buff
*
skb
)
void
netif_rx
(
struct
sk_buff
*
skb
)
{
{
static
int
dropping
=
0
;
static
int
dropping
=
0
;
extern
struct
timeval
xtime
;
/*
/*
* Any received buffers are un-owned and should be discarded
* Any received buffers are un-owned and should be discarded
...
...
net/inet/icmp.c
View file @
1235b44f
...
@@ -423,7 +423,6 @@ static void icmp_timestamp(struct icmphdr *icmph, struct sk_buff *skb, struct de
...
@@ -423,7 +423,6 @@ static void icmp_timestamp(struct icmphdr *icmph, struct sk_buff *skb, struct de
struct
sk_buff
*
skb2
;
struct
sk_buff
*
skb2
;
int
size
,
offset
;
int
size
,
offset
;
unsigned
long
*
timeptr
,
midtime
;
unsigned
long
*
timeptr
,
midtime
;
extern
struct
timeval
xtime
;
/* kernel/time.c */
struct
device
*
ndev
=
NULL
;
struct
device
*
ndev
=
NULL
;
size
=
dev
->
hard_header_len
+
64
+
len
;
size
=
dev
->
hard_header_len
+
64
+
len
;
...
...
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