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
4e30f812
Commit
4e30f812
authored
Jun 05, 2002
by
Kai Germaschewski
Browse files
Options
Browse Files
Download
Plain Diff
Merge linux-isdn@linux-isdn.bkbits.net:linux-2.5.make
into tp1.ruhr-uni-bochum.de:/home/kai/kernel/v2.5/linux-2.5.make
parents
2cb900d0
50da7d0e
Changes
29
Show whitespace changes
Inline
Side-by-side
Showing
29 changed files
with
166 additions
and
340 deletions
+166
-340
arch/i386/kernel/setup-visws.c
arch/i386/kernel/setup-visws.c
+2
-0
arch/i386/mm/ioremap.c
arch/i386/mm/ioremap.c
+1
-0
arch/i386/pci/acpi.c
arch/i386/pci/acpi.c
+1
-0
arch/i386/pci/common.c
arch/i386/pci/common.c
+1
-0
arch/i386/pci/direct.c
arch/i386/pci/direct.c
+1
-0
arch/i386/pci/fixup.c
arch/i386/pci/fixup.c
+1
-0
arch/i386/pci/legacy.c
arch/i386/pci/legacy.c
+1
-0
arch/i386/pci/numa.c
arch/i386/pci/numa.c
+1
-0
arch/i386/pci/pcbios.c
arch/i386/pci/pcbios.c
+1
-0
drivers/block/ll_rw_blk.c
drivers/block/ll_rw_blk.c
+0
-1
drivers/ide/icside.c
drivers/ide/icside.c
+7
-34
drivers/ide/ide-disk.c
drivers/ide/ide-disk.c
+17
-47
drivers/ide/ide-floppy.c
drivers/ide/ide-floppy.c
+4
-6
drivers/ide/ide-pmac.c
drivers/ide/ide-pmac.c
+4
-3
drivers/ide/ide-taskfile.c
drivers/ide/ide-taskfile.c
+59
-29
drivers/ide/ide.c
drivers/ide/ide.c
+11
-75
drivers/ide/ioctl.c
drivers/ide/ioctl.c
+2
-26
drivers/ide/pcidma.c
drivers/ide/pcidma.c
+4
-8
drivers/ide/tcq.c
drivers/ide/tcq.c
+6
-17
fs/fcntl.c
fs/fcntl.c
+4
-6
fs/inode.c
fs/inode.c
+4
-8
fs/locks.c
fs/locks.c
+25
-63
fs/mpage.c
fs/mpage.c
+1
-0
include/asm-i386/bugs.h
include/asm-i386/bugs.h
+1
-0
include/asm-i386/highmem.h
include/asm-i386/highmem.h
+1
-2
include/asm-i386/system.h
include/asm-i386/system.h
+0
-1
include/linux/blkdev.h
include/linux/blkdev.h
+1
-4
include/linux/fs.h
include/linux/fs.h
+4
-4
include/linux/ide.h
include/linux/ide.h
+1
-6
No files found.
arch/i386/kernel/setup-visws.c
View file @
4e30f812
...
@@ -3,6 +3,8 @@
...
@@ -3,6 +3,8 @@
* Split out from setup.c by davej@suse.de
* Split out from setup.c by davej@suse.de
*/
*/
#include <linux/init.h>
char
visws_board_type
=
-
1
;
char
visws_board_type
=
-
1
;
char
visws_board_rev
=
-
1
;
char
visws_board_rev
=
-
1
;
...
...
arch/i386/mm/ioremap.c
View file @
4e30f812
...
@@ -9,6 +9,7 @@
...
@@ -9,6 +9,7 @@
*/
*/
#include <linux/vmalloc.h>
#include <linux/vmalloc.h>
#include <linux/init.h>
#include <asm/io.h>
#include <asm/io.h>
#include <asm/pgalloc.h>
#include <asm/pgalloc.h>
#include <asm/fixmap.h>
#include <asm/fixmap.h>
...
...
arch/i386/pci/acpi.c
View file @
4e30f812
#include <linux/pci.h>
#include <linux/pci.h>
#include <linux/acpi.h>
#include <linux/acpi.h>
#include <linux/init.h>
#include "pci.h"
#include "pci.h"
static
int
__init
pci_acpi_init
(
void
)
static
int
__init
pci_acpi_init
(
void
)
...
...
arch/i386/pci/common.c
View file @
4e30f812
...
@@ -7,6 +7,7 @@
...
@@ -7,6 +7,7 @@
#include <linux/sched.h>
#include <linux/sched.h>
#include <linux/pci.h>
#include <linux/pci.h>
#include <linux/ioport.h>
#include <linux/ioport.h>
#include <linux/init.h>
#include <asm/segment.h>
#include <asm/segment.h>
#include <asm/io.h>
#include <asm/io.h>
...
...
arch/i386/pci/direct.c
View file @
4e30f812
...
@@ -3,6 +3,7 @@
...
@@ -3,6 +3,7 @@
*/
*/
#include <linux/pci.h>
#include <linux/pci.h>
#include <linux/init.h>
#include "pci.h"
#include "pci.h"
/*
/*
...
...
arch/i386/pci/fixup.c
View file @
4e30f812
...
@@ -3,6 +3,7 @@
...
@@ -3,6 +3,7 @@
*/
*/
#include <linux/pci.h>
#include <linux/pci.h>
#include <linux/init.h>
#include "pci.h"
#include "pci.h"
...
...
arch/i386/pci/legacy.c
View file @
4e30f812
/*
/*
* legacy.c - traditional, old school PCI bus probing
* legacy.c - traditional, old school PCI bus probing
*/
*/
#include <linux/init.h>
#include <linux/pci.h>
#include <linux/pci.h>
#include "pci.h"
#include "pci.h"
...
...
arch/i386/pci/numa.c
View file @
4e30f812
...
@@ -2,6 +2,7 @@
...
@@ -2,6 +2,7 @@
* numa.c - Low-level PCI access for NUMA-Q machines
* numa.c - Low-level PCI access for NUMA-Q machines
*/
*/
#include <linux/pci.h>
#include <linux/pci.h>
#include <linux/init.h>
#include "pci.h"
#include "pci.h"
...
...
arch/i386/pci/pcbios.c
View file @
4e30f812
...
@@ -3,6 +3,7 @@
...
@@ -3,6 +3,7 @@
*/
*/
#include <linux/pci.h>
#include <linux/pci.h>
#include <linux/init.h>
#include "pci.h"
#include "pci.h"
...
...
drivers/block/ll_rw_blk.c
View file @
4e30f812
...
@@ -507,7 +507,6 @@ static char *rq_flags[] = {
...
@@ -507,7 +507,6 @@ static char *rq_flags[] = {
"REQ_STARTED"
,
"REQ_STARTED"
,
"REQ_DONTPREP"
,
"REQ_DONTPREP"
,
"REQ_QUEUED"
,
"REQ_QUEUED"
,
"REQ_DRIVE_ACB"
,
"REQ_PC"
,
"REQ_PC"
,
"REQ_BLOCK_PC"
,
"REQ_BLOCK_PC"
,
"REQ_SENSE"
,
"REQ_SENSE"
,
...
...
drivers/ide/icside.c
View file @
4e30f812
...
@@ -281,7 +281,7 @@ static int ide_build_sglist(struct ata_device *drive, struct request *rq)
...
@@ -281,7 +281,7 @@ static int ide_build_sglist(struct ata_device *drive, struct request *rq)
struct
scatterlist
*
sg
=
ch
->
sg_table
;
struct
scatterlist
*
sg
=
ch
->
sg_table
;
int
nents
;
int
nents
;
if
(
rq
->
flags
&
REQ_
DRIVE_ACB
)
{
if
(
rq
->
flags
&
REQ_
SPECIAL
)
{
struct
ata_taskfile
*
args
=
rq
->
special
;
struct
ata_taskfile
*
args
=
rq
->
special
;
if
(
args
->
command_type
==
IDE_DRIVE_TASK_RAW_WRITE
)
if
(
args
->
command_type
==
IDE_DRIVE_TASK_RAW_WRITE
)
...
@@ -492,7 +492,7 @@ icside_dma_common(struct ata_device *drive, struct request *rq,
...
@@ -492,7 +492,7 @@ icside_dma_common(struct ata_device *drive, struct request *rq,
*/
*/
BUG_ON
(
dma_channel_active
(
ch
->
hw
.
dma
));
BUG_ON
(
dma_channel_active
(
ch
->
hw
.
dma
));
count
=
ch
->
sg_nents
=
ide_build_sglist
(
ch
,
rq
);
count
=
ch
->
sg_nents
=
ide_build_sglist
(
drive
,
rq
);
if
(
!
count
)
if
(
!
count
)
return
1
;
return
1
;
...
@@ -518,33 +518,6 @@ icside_dma_common(struct ata_device *drive, struct request *rq,
...
@@ -518,33 +518,6 @@ icside_dma_common(struct ata_device *drive, struct request *rq,
return
0
;
return
0
;
}
}
static
int
icside_dma_read
(
struct
ata_device
*
drive
,
struct
request
*
rq
)
{
struct
ata_channel
*
ch
=
drive
->
channel
;
unsigned
int
cmd
;
if
(
icside_dma_common
(
drive
,
rq
,
DMA_MODE_READ
))
return
1
;
if
(
drive
->
type
!=
ATA_DISK
)
return
0
;
ide_set_handler
(
drive
,
icside_dmaintr
,
WAIT_CMD
,
NULL
);
if
((
rq
->
flags
&
REQ_DRIVE_ACB
)
&&
drive
->
addressing
==
1
)
{
struct
ata_taskfile
*
args
=
rq
->
special
;
cmd
=
args
->
taskfile
.
command
;
}
else
if
(
drive
->
addressing
)
{
cmd
=
WIN_READDMA_EXT
;
}
else
{
cmd
=
WIN_READDMA
;
}
OUT_BYTE
(
cmd
,
IDE_COMMAND_REG
);
enable_dma
(
ch
->
hw
.
dma
);
return
0
;
}
static
int
icside_dma_init
(
struct
ata_device
*
drive
,
struct
request
*
rq
)
static
int
icside_dma_init
(
struct
ata_device
*
drive
,
struct
request
*
rq
)
{
{
struct
ata_channel
*
ch
=
drive
->
channel
;
struct
ata_channel
*
ch
=
drive
->
channel
;
...
@@ -558,13 +531,13 @@ static int icside_dma_init(struct ata_device *drive, struct request *rq)
...
@@ -558,13 +531,13 @@ static int icside_dma_init(struct ata_device *drive, struct request *rq)
ide_set_handler
(
drive
,
icside_dmaintr
,
WAIT_CMD
,
NULL
);
ide_set_handler
(
drive
,
icside_dmaintr
,
WAIT_CMD
,
NULL
);
if
((
rq
->
flags
&
REQ_
DRIVE_ACB
)
&&
drive
->
addressing
==
1
)
{
if
((
rq
->
flags
&
REQ_
SPECIAL
)
&&
drive
->
addressing
==
1
)
{
struct
ata_taskfile
*
args
=
rq
->
special
;
struct
ata_taskfile
*
args
=
rq
->
special
;
cmd
=
args
->
taskfile
.
comman
d
;
cmd
=
args
->
cm
d
;
}
else
if
(
drive
->
addressing
)
{
}
else
if
(
drive
->
addressing
)
{
cmd
=
WIN_WRITE
DMA_EXT
;
cmd
=
rq_data_dir
(
rq
)
==
WRITE
?
WIN_WRITEDMA_EXT
:
WIN_READ
DMA_EXT
;
}
else
{
}
else
{
cmd
=
WIN_WRITE
DMA
;
cmd
=
rq_data_dir
(
rq
)
==
WRITE
?
WIN_WRITEDMA
:
WIN_READ
DMA
;
}
}
OUT_BYTE
(
cmd
,
IDE_COMMAND_REG
);
OUT_BYTE
(
cmd
,
IDE_COMMAND_REG
);
...
...
drivers/ide/ide-disk.c
View file @
4e30f812
...
@@ -372,9 +372,8 @@ static u8 get_command(struct ata_device *drive, struct ata_taskfile *ar, int cmd
...
@@ -372,9 +372,8 @@ static u8 get_command(struct ata_device *drive, struct ata_taskfile *ar, int cmd
}
}
}
}
}
}
ar
->
handler
=
task_no_data_intr
;
ar
->
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
/* not reached! */
return
WIN_NOP
;
return
WIN_NOP
;
}
}
...
@@ -582,24 +581,22 @@ static int idedisk_open (struct inode *inode, struct file *filp, struct ata_devi
...
@@ -582,24 +581,22 @@ static int idedisk_open (struct inode *inode, struct file *filp, struct ata_devi
{
{
MOD_INC_USE_COUNT
;
MOD_INC_USE_COUNT
;
if
(
drive
->
removable
&&
drive
->
usage
==
1
)
{
if
(
drive
->
removable
&&
drive
->
usage
==
1
)
{
struct
ata_taskfile
args
;
check_disk_change
(
inode
->
i_rdev
);
check_disk_change
(
inode
->
i_rdev
);
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
cmd
=
WIN_DOORLOCK
;
args
.
handler
=
task_no_data_intr
;
args
.
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
/*
/*
* Ignore the return code from door_lock, since the open() has
* Ignore the return code from door_lock, since the open() has
* already succeeded once, and the door_lock is irrelevant at this
* already succeeded once, and the door_lock is irrelevant at this
* time.
* time.
*/
*/
if
(
drive
->
doorlocking
)
{
struct
ata_taskfile
args
;
if
(
drive
->
doorlocking
&&
ide_raw_taskfile
(
drive
,
&
args
))
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
cmd
=
WIN_DOORLOCK
;
if
(
ide_raw_taskfile
(
drive
,
&
args
))
drive
->
doorlocking
=
0
;
drive
->
doorlocking
=
0
;
}
}
}
return
0
;
return
0
;
}
}
...
@@ -613,30 +610,24 @@ static int idedisk_flushcache(struct ata_device *drive)
...
@@ -613,30 +610,24 @@ static int idedisk_flushcache(struct ata_device *drive)
args
.
cmd
=
WIN_FLUSH_CACHE_EXT
;
args
.
cmd
=
WIN_FLUSH_CACHE_EXT
;
else
else
args
.
cmd
=
WIN_FLUSH_CACHE
;
args
.
cmd
=
WIN_FLUSH_CACHE
;
args
.
handler
=
task_no_data_intr
;
args
.
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
return
ide_raw_taskfile
(
drive
,
&
args
);
return
ide_raw_taskfile
(
drive
,
&
args
);
}
}
static
void
idedisk_release
(
struct
inode
*
inode
,
struct
file
*
filp
,
struct
ata_device
*
drive
)
static
void
idedisk_release
(
struct
inode
*
inode
,
struct
file
*
filp
,
struct
ata_device
*
drive
)
{
{
if
(
drive
->
removable
&&
!
drive
->
usage
)
{
if
(
drive
->
removable
&&
!
drive
->
usage
)
{
struct
ata_taskfile
args
;
/* XXX I don't think this is up to the lowlevel drivers.. --hch */
/* XXX I don't think this is up to the lowlevel drivers.. --hch */
invalidate_bdev
(
inode
->
i_bdev
,
0
);
invalidate_bdev
(
inode
->
i_bdev
,
0
);
if
(
drive
->
doorlocking
)
{
struct
ata_taskfile
args
;
memset
(
&
args
,
0
,
sizeof
(
args
));
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
cmd
=
WIN_DOORUNLOCK
;
args
.
cmd
=
WIN_DOORUNLOCK
;
args
.
handler
=
task_no_data_intr
;
if
(
ide_raw_taskfile
(
drive
,
&
args
))
args
.
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
if
(
drive
->
doorlocking
&&
ide_raw_taskfile
(
drive
,
&
args
))
drive
->
doorlocking
=
0
;
drive
->
doorlocking
=
0
;
}
}
}
if
((
drive
->
id
->
cfs_enable_2
&
0x3000
)
&&
drive
->
wcache
)
if
((
drive
->
id
->
cfs_enable_2
&
0x3000
)
&&
drive
->
wcache
)
if
(
idedisk_flushcache
(
drive
))
if
(
idedisk_flushcache
(
drive
))
printk
(
KERN_INFO
"%s: Write Cache FAILED Flushing!
\n
"
,
printk
(
KERN_INFO
"%s: Write Cache FAILED Flushing!
\n
"
,
...
@@ -680,9 +671,6 @@ static int set_multcount(struct ata_device *drive, int arg)
...
@@ -680,9 +671,6 @@ static int set_multcount(struct ata_device *drive, int arg)
memset
(
&
args
,
0
,
sizeof
(
args
));
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
taskfile
.
sector_count
=
arg
;
args
.
taskfile
.
sector_count
=
arg
;
args
.
cmd
=
WIN_SETMULT
;
args
.
cmd
=
WIN_SETMULT
;
args
.
handler
=
task_no_data_intr
;
args
.
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
if
(
!
ide_raw_taskfile
(
drive
,
&
args
))
{
if
(
!
ide_raw_taskfile
(
drive
,
&
args
))
{
/* all went well track this setting as valid */
/* all went well track this setting as valid */
drive
->
mult_count
=
arg
;
drive
->
mult_count
=
arg
;
...
@@ -712,9 +700,6 @@ static int write_cache(struct ata_device *drive, int arg)
...
@@ -712,9 +700,6 @@ static int write_cache(struct ata_device *drive, int arg)
memset
(
&
args
,
0
,
sizeof
(
args
));
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
taskfile
.
feature
=
(
arg
)
?
SETFEATURES_EN_WCACHE
:
SETFEATURES_DIS_WCACHE
;
args
.
taskfile
.
feature
=
(
arg
)
?
SETFEATURES_EN_WCACHE
:
SETFEATURES_DIS_WCACHE
;
args
.
cmd
=
WIN_SETFEATURES
;
args
.
cmd
=
WIN_SETFEATURES
;
args
.
handler
=
task_no_data_intr
;
args
.
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
ide_raw_taskfile
(
drive
,
&
args
);
ide_raw_taskfile
(
drive
,
&
args
);
drive
->
wcache
=
arg
;
drive
->
wcache
=
arg
;
...
@@ -728,9 +713,6 @@ static int idedisk_standby(struct ata_device *drive)
...
@@ -728,9 +713,6 @@ static int idedisk_standby(struct ata_device *drive)
memset
(
&
args
,
0
,
sizeof
(
args
));
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
cmd
=
WIN_STANDBYNOW1
;
args
.
cmd
=
WIN_STANDBYNOW1
;
args
.
handler
=
task_no_data_intr
;
args
.
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
return
ide_raw_taskfile
(
drive
,
&
args
);
return
ide_raw_taskfile
(
drive
,
&
args
);
}
}
...
@@ -742,9 +724,6 @@ static int set_acoustic(struct ata_device *drive, int arg)
...
@@ -742,9 +724,6 @@ static int set_acoustic(struct ata_device *drive, int arg)
args
.
taskfile
.
feature
=
(
arg
)
?
SETFEATURES_EN_AAM
:
SETFEATURES_DIS_AAM
;
args
.
taskfile
.
feature
=
(
arg
)
?
SETFEATURES_EN_AAM
:
SETFEATURES_DIS_AAM
;
args
.
taskfile
.
sector_count
=
arg
;
args
.
taskfile
.
sector_count
=
arg
;
args
.
cmd
=
WIN_SETFEATURES
;
args
.
cmd
=
WIN_SETFEATURES
;
args
.
handler
=
task_no_data_intr
;
args
.
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
ide_raw_taskfile
(
drive
,
&
args
);
ide_raw_taskfile
(
drive
,
&
args
);
drive
->
acoustic
=
arg
;
drive
->
acoustic
=
arg
;
...
@@ -864,9 +843,6 @@ static unsigned long native_max_address(struct ata_device *drive)
...
@@ -864,9 +843,6 @@ static unsigned long native_max_address(struct ata_device *drive)
memset
(
&
args
,
0
,
sizeof
(
args
));
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
taskfile
.
device_head
=
0x40
;
args
.
taskfile
.
device_head
=
0x40
;
args
.
cmd
=
WIN_READ_NATIVE_MAX
;
args
.
cmd
=
WIN_READ_NATIVE_MAX
;
args
.
handler
=
task_no_data_intr
;
/* submit command request */
ide_raw_taskfile
(
drive
,
&
args
);
ide_raw_taskfile
(
drive
,
&
args
);
/* if OK, compute maximum address value */
/* if OK, compute maximum address value */
...
@@ -892,9 +868,6 @@ static u64 native_max_address_ext(struct ata_device *drive)
...
@@ -892,9 +868,6 @@ static u64 native_max_address_ext(struct ata_device *drive)
args
.
taskfile
.
device_head
=
0x40
;
args
.
taskfile
.
device_head
=
0x40
;
args
.
cmd
=
WIN_READ_NATIVE_MAX_EXT
;
args
.
cmd
=
WIN_READ_NATIVE_MAX_EXT
;
args
.
handler
=
task_no_data_intr
;
/* submit command request */
ide_raw_taskfile
(
drive
,
&
args
);
ide_raw_taskfile
(
drive
,
&
args
);
/* if OK, compute maximum address value */
/* if OK, compute maximum address value */
...
@@ -933,9 +906,8 @@ static sector_t set_max_address(struct ata_device *drive, sector_t addr_req)
...
@@ -933,9 +906,8 @@ static sector_t set_max_address(struct ata_device *drive, sector_t addr_req)
args
.
taskfile
.
device_head
=
((
addr_req
>>
24
)
&
0x0f
)
|
0x40
;
args
.
taskfile
.
device_head
=
((
addr_req
>>
24
)
&
0x0f
)
|
0x40
;
args
.
cmd
=
WIN_SET_MAX
;
args
.
cmd
=
WIN_SET_MAX
;
args
.
handler
=
task_no_data_intr
;
/* submit command request */
ide_raw_taskfile
(
drive
,
&
args
);
ide_raw_taskfile
(
drive
,
&
args
);
/* if OK, read new maximum address value */
/* if OK, read new maximum address value */
if
(
!
(
drive
->
status
&
ERR_STAT
))
{
if
(
!
(
drive
->
status
&
ERR_STAT
))
{
addr_set
=
((
args
.
taskfile
.
device_head
&
0x0f
)
<<
24
)
addr_set
=
((
args
.
taskfile
.
device_head
&
0x0f
)
<<
24
)
...
@@ -965,12 +937,10 @@ static u64 set_max_address_ext(struct ata_device *drive, u64 addr_req)
...
@@ -965,12 +937,10 @@ static u64 set_max_address_ext(struct ata_device *drive, u64 addr_req)
args
.
hobfile
.
sector_number
=
(
addr_req
>>=
8
);
args
.
hobfile
.
sector_number
=
(
addr_req
>>=
8
);
args
.
hobfile
.
low_cylinder
=
(
addr_req
>>=
8
);
args
.
hobfile
.
low_cylinder
=
(
addr_req
>>=
8
);
args
.
hobfile
.
high_cylinder
=
(
addr_req
>>=
8
);
args
.
hobfile
.
high_cylinder
=
(
addr_req
>>=
8
);
args
.
hobfile
.
device_head
=
0x40
;
args
.
hobfile
.
device_head
=
0x40
;
args
.
handler
=
task_no_data_intr
;
/* submit command request */
ide_raw_taskfile
(
drive
,
&
args
);
ide_raw_taskfile
(
drive
,
&
args
);
/* if OK, compute maximum address value */
/* if OK, compute maximum address value */
if
(
!
(
drive
->
status
&
ERR_STAT
))
{
if
(
!
(
drive
->
status
&
ERR_STAT
))
{
u32
high
=
(
args
.
hobfile
.
high_cylinder
<<
16
)
|
u32
high
=
(
args
.
hobfile
.
high_cylinder
<<
16
)
|
...
...
drivers/ide/ide-floppy.c
View file @
4e30f812
...
@@ -308,8 +308,6 @@ typedef struct {
...
@@ -308,8 +308,6 @@ typedef struct {
#define IDEFLOPPY_IOCTL_FORMAT_START 0x4602
#define IDEFLOPPY_IOCTL_FORMAT_START 0x4602
#define IDEFLOPPY_IOCTL_FORMAT_GET_PROGRESS 0x4603
#define IDEFLOPPY_IOCTL_FORMAT_GET_PROGRESS 0x4603
#define IDEFLOPPY_RQ (REQ_SPECIAL)
/*
/*
* Error codes which are returned in rq->errors to the higher part
* Error codes which are returned in rq->errors to the higher part
* of the driver.
* of the driver.
...
@@ -633,7 +631,7 @@ static int idefloppy_end_request(struct ata_device *drive, struct request *rq, i
...
@@ -633,7 +631,7 @@ static int idefloppy_end_request(struct ata_device *drive, struct request *rq, i
if
(
!
rq
)
if
(
!
rq
)
return
0
;
return
0
;
if
(
!
(
rq
->
flags
&
IDEFLOPPY_RQ
))
{
if
(
!
(
rq
->
flags
&
REQ_SPECIAL
))
{
ide_end_request
(
drive
,
rq
,
uptodate
);
ide_end_request
(
drive
,
rq
,
uptodate
);
return
0
;
return
0
;
}
}
...
@@ -717,7 +715,7 @@ static void idefloppy_queue_pc_head(struct ata_device *drive,
...
@@ -717,7 +715,7 @@ static void idefloppy_queue_pc_head(struct ata_device *drive,
struct
atapi_packet_command
*
pc
,
struct
request
*
rq
)
struct
atapi_packet_command
*
pc
,
struct
request
*
rq
)
{
{
memset
(
rq
,
0
,
sizeof
(
*
rq
));
memset
(
rq
,
0
,
sizeof
(
*
rq
));
rq
->
flags
=
IDEFLOPPY_RQ
;
rq
->
flags
=
REQ_SPECIAL
;
/* FIXME: --mdcki */
/* FIXME: --mdcki */
rq
->
buffer
=
(
char
*
)
pc
;
rq
->
buffer
=
(
char
*
)
pc
;
(
void
)
ide_do_drive_cmd
(
drive
,
rq
,
ide_preempt
);
(
void
)
ide_do_drive_cmd
(
drive
,
rq
,
ide_preempt
);
...
@@ -1251,7 +1249,7 @@ static ide_startstop_t idefloppy_do_request(struct ata_device *drive, struct req
...
@@ -1251,7 +1249,7 @@ static ide_startstop_t idefloppy_do_request(struct ata_device *drive, struct req
}
}
pc
=
idefloppy_next_pc_storage
(
drive
);
pc
=
idefloppy_next_pc_storage
(
drive
);
idefloppy_create_rw_cmd
(
floppy
,
pc
,
rq
,
block
);
idefloppy_create_rw_cmd
(
floppy
,
pc
,
rq
,
block
);
}
else
if
(
rq
->
flags
&
IDEFLOPPY_RQ
)
{
}
else
if
(
rq
->
flags
&
REQ_SPECIAL
)
{
/* FIXME: --mdcki */
/* FIXME: --mdcki */
pc
=
(
struct
atapi_packet_command
*
)
rq
->
buffer
;
pc
=
(
struct
atapi_packet_command
*
)
rq
->
buffer
;
}
else
{
}
else
{
...
@@ -1274,7 +1272,7 @@ static int idefloppy_queue_pc_tail(struct ata_device *drive, struct atapi_packet
...
@@ -1274,7 +1272,7 @@ static int idefloppy_queue_pc_tail(struct ata_device *drive, struct atapi_packet
memset
(
&
rq
,
0
,
sizeof
(
rq
));
memset
(
&
rq
,
0
,
sizeof
(
rq
));
/* FIXME: --mdcki */
/* FIXME: --mdcki */
rq
.
buffer
=
(
char
*
)
pc
;
rq
.
buffer
=
(
char
*
)
pc
;
rq
.
flags
=
IDEFLOPPY_RQ
;
rq
.
flags
=
REQ_SPECIAL
;
return
ide_do_drive_cmd
(
drive
,
&
rq
,
ide_wait
);
return
ide_do_drive_cmd
(
drive
,
&
rq
,
ide_wait
);
}
}
...
...
drivers/ide/ide-pmac.c
View file @
4e30f812
...
@@ -1126,7 +1126,7 @@ pmac_ide_build_dmatable(struct ata_device *drive, struct request *rq, int ix, in
...
@@ -1126,7 +1126,7 @@ pmac_ide_build_dmatable(struct ata_device *drive, struct request *rq, int ix, in
udelay
(
1
);
udelay
(
1
);
/* Build sglist */
/* Build sglist */
if
(
rq
->
flags
&
REQ_
DRIVE_ACB
)
{
if
(
rq
->
flags
&
REQ_
SPECIAL
)
{
pmac_ide
[
ix
].
sg_nents
=
i
=
pmac_raw_build_sglist
(
ix
,
rq
);
pmac_ide
[
ix
].
sg_nents
=
i
=
pmac_raw_build_sglist
(
ix
,
rq
);
}
else
{
}
else
{
pmac_ide
[
ix
].
sg_nents
=
i
=
pmac_ide_build_sglist
(
ix
,
rq
);
pmac_ide
[
ix
].
sg_nents
=
i
=
pmac_ide_build_sglist
(
ix
,
rq
);
...
@@ -1437,10 +1437,11 @@ static int pmac_udma_init(struct ata_device *drive, struct request *rq)
...
@@ -1437,10 +1437,11 @@ static int pmac_udma_init(struct ata_device *drive, struct request *rq)
if
(
drive
->
type
!=
ATA_DISK
)
if
(
drive
->
type
!=
ATA_DISK
)
return
0
;
return
0
;
ide_set_handler
(
drive
,
ide_dma_intr
,
WAIT_CMD
,
NULL
);
ide_set_handler
(
drive
,
ide_dma_intr
,
WAIT_CMD
,
NULL
);
if
((
rq
->
flags
&
REQ_
DRIVE_ACB
)
&&
if
((
rq
->
flags
&
REQ_
SPECIAL
)
&&
(
drive
->
addressing
==
1
))
{
(
drive
->
addressing
==
1
))
{
struct
ata_taskfile
*
args
=
rq
->
special
;
struct
ata_taskfile
*
args
=
rq
->
special
;
OUT_BYTE
(
args
->
taskfile
.
command
,
IDE_COMMAND_REG
);
/* FIXME: this is never reached */
OUT_BYTE
(
args
->
cmd
,
IDE_COMMAND_REG
);
}
else
if
(
drive
->
addressing
)
{
}
else
if
(
drive
->
addressing
)
{
OUT_BYTE
(
reading
?
WIN_READDMA_EXT
:
WIN_WRITEDMA_EXT
,
IDE_COMMAND_REG
);
OUT_BYTE
(
reading
?
WIN_READDMA_EXT
:
WIN_WRITEDMA_EXT
,
IDE_COMMAND_REG
);
}
else
{
}
else
{
...
...
drivers/ide/ide-taskfile.c
View file @
4e30f812
...
@@ -176,27 +176,6 @@ int drive_is_ready(struct ata_device *drive)
...
@@ -176,27 +176,6 @@ int drive_is_ready(struct ata_device *drive)
return
1
;
/* drive ready: *might* be interrupting */
return
1
;
/* drive ready: *might* be interrupting */
}
}
/*
* Handler for commands without a data phase
*/
ide_startstop_t
task_no_data_intr
(
struct
ata_device
*
drive
,
struct
request
*
rq
)
{
struct
ata_taskfile
*
ar
=
rq
->
special
;
ide__sti
();
/* local CPU only */
if
(
!
ata_status
(
drive
,
READY_STAT
,
BAD_STAT
))
{
/* Keep quiet for NOP because it is expected to fail. */
if
(
ar
&&
ar
->
cmd
!=
WIN_NOP
)
return
ata_error
(
drive
,
rq
,
__FUNCTION__
);
}
if
(
ar
)
ide_end_drive_cmd
(
drive
,
rq
);
return
ide_stopped
;
}
ide_startstop_t
ata_taskfile
(
struct
ata_device
*
drive
,
ide_startstop_t
ata_taskfile
(
struct
ata_device
*
drive
,
struct
ata_taskfile
*
ar
,
struct
request
*
rq
)
struct
ata_taskfile
*
ar
,
struct
request
*
rq
)
{
{
...
@@ -385,21 +364,72 @@ int ide_do_drive_cmd(struct ata_device *drive, struct request *rq, ide_action_t
...
@@ -385,21 +364,72 @@ int ide_do_drive_cmd(struct ata_device *drive, struct request *rq, ide_action_t
}
}
int
ide_raw_taskfile
(
struct
ata_device
*
drive
,
struct
ata_taskfile
*
args
)
/*
* Invoked on completion of a special REQ_SPECIAL command.
*/
ide_startstop_t
ata_special_intr
(
struct
ata_device
*
drive
,
struct
request
*
rq
)
{
struct
ata_taskfile
*
ar
=
rq
->
special
;
ide_startstop_t
ret
=
ide_stopped
;
ide__sti
();
/* local CPU only */
if
(
rq
->
buffer
&&
ar
->
taskfile
.
sector_number
)
{
if
(
!
ata_status
(
drive
,
0
,
DRQ_STAT
)
&&
ar
->
taskfile
.
sector_number
)
{
int
retries
=
10
;
ata_read
(
drive
,
rq
->
buffer
,
ar
->
taskfile
.
sector_number
*
SECTOR_WORDS
);
while
(
!
ata_status
(
drive
,
0
,
BUSY_STAT
)
&&
retries
--
)
udelay
(
100
);
}
}
if
(
!
ata_status
(
drive
,
READY_STAT
,
BAD_STAT
))
{
/* Keep quiet for NOP because it is expected to fail. */
if
(
ar
->
cmd
!=
WIN_NOP
)
ret
=
ata_error
(
drive
,
rq
,
__FUNCTION__
);
rq
->
errors
=
1
;
}
ar
->
taskfile
.
feature
=
IN_BYTE
(
IDE_ERROR_REG
);
ata_in_regfile
(
drive
,
&
ar
->
taskfile
);
ar
->
taskfile
.
device_head
=
IN_BYTE
(
IDE_SELECT_REG
);
if
((
drive
->
id
->
command_set_2
&
0x0400
)
&&
(
drive
->
id
->
cfs_enable_2
&
0x0400
)
&&
(
drive
->
addressing
==
1
))
{
/* The following command goes to the hob file! */
OUT_BYTE
(
0x80
,
drive
->
channel
->
io_ports
[
IDE_CONTROL_OFFSET
]);
ar
->
hobfile
.
feature
=
IN_BYTE
(
IDE_FEATURE_REG
);
ata_in_regfile
(
drive
,
&
ar
->
hobfile
);
}
blkdev_dequeue_request
(
rq
);
drive
->
rq
=
NULL
;
end_that_request_last
(
rq
);
return
ret
;
}
int
ide_raw_taskfile
(
struct
ata_device
*
drive
,
struct
ata_taskfile
*
ar
)
{
{
struct
request
rq
;
struct
request
req
;
ar
->
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
ar
->
handler
=
ata_special_intr
;
memset
(
&
r
q
,
0
,
sizeof
(
r
q
));
memset
(
&
r
eq
,
0
,
sizeof
(
re
q
));
r
q
.
flags
=
REQ_DRIVE_ACB
;
r
eq
.
flags
=
REQ_SPECIAL
;
r
q
.
special
=
args
;
r
eq
.
special
=
ar
;
return
ide_do_drive_cmd
(
drive
,
&
rq
,
ide_wait
);
return
ide_do_drive_cmd
(
drive
,
&
r
e
q
,
ide_wait
);
}
}
EXPORT_SYMBOL
(
drive_is_ready
);
EXPORT_SYMBOL
(
drive_is_ready
);
EXPORT_SYMBOL
(
ide_do_drive_cmd
);
EXPORT_SYMBOL
(
ata_read
);
EXPORT_SYMBOL
(
ata_read
);
EXPORT_SYMBOL
(
ata_write
);
EXPORT_SYMBOL
(
ata_write
);
EXPORT_SYMBOL
(
ata_taskfile
);
EXPORT_SYMBOL
(
ata_taskfile
);
EXPORT_SYMBOL
(
task_no_data_intr
);
EXPORT_SYMBOL
(
ata_special_intr
);
EXPORT_SYMBOL
(
ide_do_drive_cmd
);
EXPORT_SYMBOL
(
ide_raw_taskfile
);
EXPORT_SYMBOL
(
ide_raw_taskfile
);
drivers/ide/ide.c
View file @
4e30f812
...
@@ -389,37 +389,6 @@ static inline u32 read_24(struct ata_device *drive)
...
@@ -389,37 +389,6 @@ static inline u32 read_24(struct ata_device *drive)
IN_BYTE
(
IDE_SECTOR_REG
);
IN_BYTE
(
IDE_SECTOR_REG
);
}
}
/*
* Clean up after success/failure of an explicit drive cmd
*
* Should be called under lock held.
*/
void
ide_end_drive_cmd
(
struct
ata_device
*
drive
,
struct
request
*
rq
)
{
if
(
rq
->
flags
&
REQ_DRIVE_ACB
)
{
struct
ata_taskfile
*
ar
=
rq
->
special
;
rq
->
errors
=
!
ata_status
(
drive
,
READY_STAT
,
BAD_STAT
);
if
(
ar
)
{
ar
->
taskfile
.
feature
=
IN_BYTE
(
IDE_ERROR_REG
);
ata_in_regfile
(
drive
,
&
ar
->
taskfile
);
ar
->
taskfile
.
device_head
=
IN_BYTE
(
IDE_SELECT_REG
);
if
((
drive
->
id
->
command_set_2
&
0x0400
)
&&
(
drive
->
id
->
cfs_enable_2
&
0x0400
)
&&
(
drive
->
addressing
==
1
))
{
/* The following command goes to the hob file! */
OUT_BYTE
(
0x80
,
drive
->
channel
->
io_ports
[
IDE_CONTROL_OFFSET
]);
ar
->
hobfile
.
feature
=
IN_BYTE
(
IDE_FEATURE_REG
);
ata_in_regfile
(
drive
,
&
ar
->
hobfile
);
}
}
}
blkdev_dequeue_request
(
rq
);
drive
->
rq
=
NULL
;
end_that_request_last
(
rq
);
}
#if FANCY_STATUS_DUMPS
#if FANCY_STATUS_DUMPS
struct
ata_bit_messages
{
struct
ata_bit_messages
{
u8
mask
;
u8
mask
;
...
@@ -551,26 +520,12 @@ static void try_to_flush_leftover_data(struct ata_device *drive)
...
@@ -551,26 +520,12 @@ static void try_to_flush_leftover_data(struct ata_device *drive)
# define IS_PDC4030_DRIVE (0)
/* auto-NULLs out pdc4030 code */
# define IS_PDC4030_DRIVE (0)
/* auto-NULLs out pdc4030 code */
#endif
#endif
/*
* This is invoked on completion of a WIN_RESTORE (recalibrate) cmd.
*
* FIXME: Why can't be just use task_no_data_intr here?
*/
static
ide_startstop_t
recal_intr
(
struct
ata_device
*
drive
,
struct
request
*
rq
)
{
if
(
!
ata_status
(
drive
,
READY_STAT
,
BAD_STAT
))
return
ata_error
(
drive
,
rq
,
__FUNCTION__
);
return
ide_stopped
;
}
/*
/*
* We are still on the old request path here so issuing the recalibrate command
* We are still on the old request path here so issuing the recalibrate command
* directly should just work.
* directly should just work.
*/
*/
static
int
do_recalibrate
(
struct
ata_device
*
drive
)
static
int
do_recalibrate
(
struct
ata_device
*
drive
)
{
{
printk
(
KERN_INFO
"%s: recalibrating!
\n
"
,
drive
->
name
);
if
(
drive
->
type
!=
ATA_DISK
)
if
(
drive
->
type
!=
ATA_DISK
)
return
ide_stopped
;
return
ide_stopped
;
...
@@ -578,12 +533,12 @@ static int do_recalibrate(struct ata_device *drive)
...
@@ -578,12 +533,12 @@ static int do_recalibrate(struct ata_device *drive)
if
(
!
IS_PDC4030_DRIVE
)
{
if
(
!
IS_PDC4030_DRIVE
)
{
struct
ata_taskfile
args
;
struct
ata_taskfile
args
;
printk
(
KERN_INFO
"%s: recalibrating...
\n
"
,
drive
->
name
);
memset
(
&
args
,
0
,
sizeof
(
args
));
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
taskfile
.
sector_count
=
drive
->
sect
;
args
.
taskfile
.
sector_count
=
drive
->
sect
;
args
.
cmd
=
WIN_RESTORE
;
args
.
cmd
=
WIN_RESTORE
;
args
.
handler
=
recal_intr
;
ide_raw_taskfile
(
drive
,
&
args
);
args
.
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
printk
(
KERN_INFO
"%s: done!
\n
"
,
drive
->
name
);
ata_taskfile
(
drive
,
&
args
,
NULL
);
}
}
return
IS_PDC4030_DRIVE
?
ide_stopped
:
ide_started
;
return
IS_PDC4030_DRIVE
?
ide_stopped
:
ide_started
;
...
@@ -604,7 +559,6 @@ ide_startstop_t ata_error(struct ata_device *drive, struct request *rq, const ch
...
@@ -604,7 +559,6 @@ ide_startstop_t ata_error(struct ata_device *drive, struct request *rq, const ch
/* retry only "normal" I/O: */
/* retry only "normal" I/O: */
if
(
!
(
rq
->
flags
&
REQ_CMD
))
{
if
(
!
(
rq
->
flags
&
REQ_CMD
))
{
rq
->
errors
=
1
;
rq
->
errors
=
1
;
ide_end_drive_cmd
(
drive
,
rq
);
return
ide_stopped
;
return
ide_stopped
;
}
}
...
@@ -633,6 +587,7 @@ ide_startstop_t ata_error(struct ata_device *drive, struct request *rq, const ch
...
@@ -633,6 +587,7 @@ ide_startstop_t ata_error(struct ata_device *drive, struct request *rq, const ch
OUT_BYTE
(
WIN_IDLEIMMEDIATE
,
IDE_COMMAND_REG
);
/* force an abort */
OUT_BYTE
(
WIN_IDLEIMMEDIATE
,
IDE_COMMAND_REG
);
/* force an abort */
if
(
rq
->
errors
>=
ERROR_MAX
)
{
if
(
rq
->
errors
>=
ERROR_MAX
)
{
printk
(
KERN_ERR
"%s: max number of retries exceeded!
\n
"
,
drive
->
name
);
if
(
ata_ops
(
drive
)
&&
ata_ops
(
drive
)
->
end_request
)
if
(
ata_ops
(
drive
)
&&
ata_ops
(
drive
)
->
end_request
)
ata_ops
(
drive
)
->
end_request
(
drive
,
rq
,
0
);
ata_ops
(
drive
)
->
end_request
(
drive
,
rq
,
0
);
else
else
...
@@ -729,10 +684,10 @@ static ide_startstop_t start_request(struct ata_device *drive, struct request *r
...
@@ -729,10 +684,10 @@ static ide_startstop_t start_request(struct ata_device *drive, struct request *r
/* Strange disk manager remap.
/* Strange disk manager remap.
*/
*/
if
(
(
rq
->
flags
&
REQ_CMD
)
&&
if
(
rq
->
flags
&
REQ_CMD
)
(
drive
->
type
==
ATA_DISK
||
drive
->
type
==
ATA_FLOPPY
))
{
if
(
drive
->
type
==
ATA_DISK
||
drive
->
type
==
ATA_FLOPPY
)
block
+=
drive
->
sect0
;
block
+=
drive
->
sect0
;
}
/* Yecch - this will shift the entire interval, possibly killing some
/* Yecch - this will shift the entire interval, possibly killing some
* innocent following sector.
* innocent following sector.
...
@@ -753,14 +708,8 @@ static ide_startstop_t start_request(struct ata_device *drive, struct request *r
...
@@ -753,14 +708,8 @@ static ide_startstop_t start_request(struct ata_device *drive, struct request *r
/* This issues a special drive command.
/* This issues a special drive command.
*/
*/
if
(
rq
->
flags
&
REQ_DRIVE_ACB
)
{
if
(
rq
->
flags
&
REQ_SPECIAL
)
struct
ata_taskfile
*
ar
=
rq
->
special
;
return
ata_taskfile
(
drive
,
rq
->
special
,
NULL
);
if
(
!
(
ar
))
goto
args_error
;
return
ata_taskfile
(
drive
,
ar
,
NULL
);
}
/* The normal way of execution is to pass and execute the request
/* The normal way of execution is to pass and execute the request
* handler down to the device type driver.
* handler down to the device type driver.
...
@@ -789,19 +738,6 @@ static ide_startstop_t start_request(struct ata_device *drive, struct request *r
...
@@ -789,19 +738,6 @@ static ide_startstop_t start_request(struct ata_device *drive, struct request *r
ide_end_request
(
drive
,
rq
,
0
);
ide_end_request
(
drive
,
rq
,
0
);
return
ide_stopped
;
return
ide_stopped
;
args_error:
/* NULL as arguemnt is used by ioctls as a way of waiting for all
* current requests to be flushed from the queue.
*/
#ifdef DEBUG
printk
(
"%s: DRIVE_CMD (null)
\n
"
,
drive
->
name
);
#endif
ide_end_drive_cmd
(
drive
,
rq
);
return
ide_stopped
;
}
}
ide_startstop_t
restart_request
(
struct
ata_device
*
drive
)
ide_startstop_t
restart_request
(
struct
ata_device
*
drive
)
...
@@ -1485,8 +1421,8 @@ EXPORT_SYMBOL(ata_dump);
...
@@ -1485,8 +1421,8 @@ EXPORT_SYMBOL(ata_dump);
EXPORT_SYMBOL
(
ata_error
);
EXPORT_SYMBOL
(
ata_error
);
EXPORT_SYMBOL
(
ide_wait_stat
);
EXPORT_SYMBOL
(
ide_wait_stat
);
/* FIXME: this is a trully bad name */
EXPORT_SYMBOL
(
restart_request
);
EXPORT_SYMBOL
(
restart_request
);
EXPORT_SYMBOL
(
ide_end_drive_cmd
);
EXPORT_SYMBOL
(
__ide_end_request
);
EXPORT_SYMBOL
(
__ide_end_request
);
EXPORT_SYMBOL
(
ide_end_request
);
EXPORT_SYMBOL
(
ide_end_request
);
EXPORT_SYMBOL
(
ide_stall_queue
);
EXPORT_SYMBOL
(
ide_stall_queue
);
...
...
drivers/ide/ioctl.c
View file @
4e30f812
...
@@ -33,30 +33,6 @@
...
@@ -33,30 +33,6 @@
#include "ioctl.h"
#include "ioctl.h"
/*
* Invoked on completion of a special DRIVE_CMD.
*/
static
ide_startstop_t
drive_cmd_intr
(
struct
ata_device
*
drive
,
struct
request
*
rq
)
{
struct
ata_taskfile
*
ar
=
rq
->
special
;
ide__sti
();
/* local CPU only */
if
(
!
ata_status
(
drive
,
0
,
DRQ_STAT
)
&&
ar
->
taskfile
.
sector_number
)
{
int
retries
=
10
;
ata_read
(
drive
,
rq
->
buffer
,
ar
->
taskfile
.
sector_number
*
SECTOR_WORDS
);
while
(
!
ata_status
(
drive
,
0
,
BUSY_STAT
)
&&
retries
--
)
udelay
(
100
);
}
if
(
!
ata_status
(
drive
,
READY_STAT
,
BAD_STAT
))
return
ata_error
(
drive
,
rq
,
__FUNCTION__
);
/* already calls ide_end_drive_cmd */
ide_end_drive_cmd
(
drive
,
rq
);
return
ide_stopped
;
}
/*
/*
* Implement generic ioctls invoked from userspace to imlpement specific
* Implement generic ioctls invoked from userspace to imlpement specific
* functionality.
* functionality.
...
@@ -79,7 +55,7 @@ static int do_cmd_ioctl(struct ata_device *drive, unsigned long arg)
...
@@ -79,7 +55,7 @@ static int do_cmd_ioctl(struct ata_device *drive, unsigned long arg)
return
-
EFAULT
;
return
-
EFAULT
;
memset
(
&
rq
,
0
,
sizeof
(
rq
));
memset
(
&
rq
,
0
,
sizeof
(
rq
));
rq
.
flags
=
REQ_
DRIVE_ACB
;
rq
.
flags
=
REQ_
SPECIAL
;
memset
(
&
args
,
0
,
sizeof
(
args
));
memset
(
&
args
,
0
,
sizeof
(
args
));
...
@@ -107,7 +83,7 @@ static int do_cmd_ioctl(struct ata_device *drive, unsigned long arg)
...
@@ -107,7 +83,7 @@ static int do_cmd_ioctl(struct ata_device *drive, unsigned long arg)
/* Issue ATA command and wait for completion.
/* Issue ATA command and wait for completion.
*/
*/
args
.
handler
=
drive_cmd
_intr
;
args
.
handler
=
ata_special
_intr
;
rq
.
buffer
=
argbuf
+
4
;
rq
.
buffer
=
argbuf
+
4
;
rq
.
special
=
&
args
;
rq
.
special
=
&
args
;
...
...
drivers/ide/pcidma.c
View file @
4e30f812
...
@@ -64,7 +64,7 @@ static int build_sglist(struct ata_device *drive, struct request *rq)
...
@@ -64,7 +64,7 @@ static int build_sglist(struct ata_device *drive, struct request *rq)
struct
scatterlist
*
sg
=
ch
->
sg_table
;
struct
scatterlist
*
sg
=
ch
->
sg_table
;
int
nents
=
0
;
int
nents
=
0
;
if
(
rq
->
flags
&
REQ_
DRIVE_ACB
)
{
if
(
rq
->
flags
&
REQ_
SPECIAL
)
{
struct
ata_taskfile
*
args
=
rq
->
special
;
struct
ata_taskfile
*
args
=
rq
->
special
;
#if 1
#if 1
unsigned
char
*
virt_addr
=
rq
->
buffer
;
unsigned
char
*
virt_addr
=
rq
->
buffer
;
...
@@ -525,6 +525,7 @@ int udma_pci_init(struct ata_device *drive, struct request *rq)
...
@@ -525,6 +525,7 @@ int udma_pci_init(struct ata_device *drive, struct request *rq)
if
(
ata_start_dma
(
drive
,
rq
))
if
(
ata_start_dma
(
drive
,
rq
))
return
1
;
return
1
;
/* No DMA transfers on ATAPI devices. */
if
(
drive
->
type
!=
ATA_DISK
)
if
(
drive
->
type
!=
ATA_DISK
)
return
0
;
return
0
;
...
@@ -533,13 +534,8 @@ int udma_pci_init(struct ata_device *drive, struct request *rq)
...
@@ -533,13 +534,8 @@ int udma_pci_init(struct ata_device *drive, struct request *rq)
else
else
cmd
=
0x00
;
cmd
=
0x00
;
ide_set_handler
(
drive
,
ide_dma_intr
,
WAIT_CMD
,
dma_timer_expiry
);
/* issue cmd to drive */
ide_set_handler
(
drive
,
ide_dma_intr
,
WAIT_CMD
,
dma_timer_expiry
);
if
((
rq
->
flags
&
REQ_DRIVE_ACB
)
&&
(
drive
->
addressing
==
1
))
{
if
(
drive
->
addressing
)
/* FIXME: this should never happen */
struct
ata_taskfile
*
args
=
rq
->
special
;
outb
(
args
->
cmd
,
IDE_COMMAND_REG
);
}
else
if
(
drive
->
addressing
)
outb
(
cmd
?
WIN_READDMA_EXT
:
WIN_WRITEDMA_EXT
,
IDE_COMMAND_REG
);
outb
(
cmd
?
WIN_READDMA_EXT
:
WIN_WRITEDMA_EXT
,
IDE_COMMAND_REG
);
else
else
outb
(
cmd
?
WIN_READDMA
:
WIN_WRITEDMA
,
IDE_COMMAND_REG
);
outb
(
cmd
?
WIN_READDMA
:
WIN_WRITEDMA
,
IDE_COMMAND_REG
);
...
...
drivers/ide/tcq.c
View file @
4e30f812
...
@@ -60,7 +60,9 @@ static ide_startstop_t tcq_nop_handler(struct ata_device *drive, struct request
...
@@ -60,7 +60,9 @@ static ide_startstop_t tcq_nop_handler(struct ata_device *drive, struct request
struct
ata_taskfile
*
args
=
rq
->
special
;
struct
ata_taskfile
*
args
=
rq
->
special
;
ide__sti
();
ide__sti
();
ide_end_drive_cmd
(
drive
,
rq
);
blkdev_dequeue_request
(
rq
);
drive
->
rq
=
NULL
;
end_that_request_last
(
rq
);
kfree
(
args
);
kfree
(
args
);
return
ide_stopped
;
return
ide_stopped
;
...
@@ -402,18 +404,14 @@ static int check_autopoll(struct ata_device *drive)
...
@@ -402,18 +404,14 @@ static int check_autopoll(struct ata_device *drive)
if
(
drives
<=
1
)
if
(
drives
<=
1
)
return
0
;
return
0
;
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
taskfile
.
feature
=
0x01
;
args
.
cmd
=
WIN_NOP
;
args
.
handler
=
task_no_data_intr
;
args
.
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
/*
/*
* do taskfile and check ABRT bit -- intelligent adapters will not
* do taskfile and check ABRT bit -- intelligent adapters will not
* pass NOP with sub-code 0x01 to device, so the command will not
* pass NOP with sub-code 0x01 to device, so the command will not
* fail there
* fail there
*/
*/
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
taskfile
.
feature
=
0x01
;
args
.
cmd
=
WIN_NOP
;
ide_raw_taskfile
(
drive
,
&
args
);
ide_raw_taskfile
(
drive
,
&
args
);
if
(
args
.
taskfile
.
feature
&
ABRT_ERR
)
if
(
args
.
taskfile
.
feature
&
ABRT_ERR
)
return
1
;
return
1
;
...
@@ -442,9 +440,6 @@ static int configure_tcq(struct ata_device *drive)
...
@@ -442,9 +440,6 @@ static int configure_tcq(struct ata_device *drive)
memset
(
&
args
,
0
,
sizeof
(
args
));
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
taskfile
.
feature
=
SETFEATURES_EN_WCACHE
;
args
.
taskfile
.
feature
=
SETFEATURES_EN_WCACHE
;
args
.
cmd
=
WIN_SETFEATURES
;
args
.
cmd
=
WIN_SETFEATURES
;
args
.
handler
=
task_no_data_intr
;
args
.
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
if
(
ide_raw_taskfile
(
drive
,
&
args
))
{
if
(
ide_raw_taskfile
(
drive
,
&
args
))
{
printk
(
"%s: failed to enable write cache
\n
"
,
drive
->
name
);
printk
(
"%s: failed to enable write cache
\n
"
,
drive
->
name
);
return
1
;
return
1
;
...
@@ -457,9 +452,6 @@ static int configure_tcq(struct ata_device *drive)
...
@@ -457,9 +452,6 @@ static int configure_tcq(struct ata_device *drive)
memset
(
&
args
,
0
,
sizeof
(
args
));
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
taskfile
.
feature
=
SETFEATURES_DIS_RI
;
args
.
taskfile
.
feature
=
SETFEATURES_DIS_RI
;
args
.
cmd
=
WIN_SETFEATURES
;
args
.
cmd
=
WIN_SETFEATURES
;
args
.
handler
=
task_no_data_intr
;
args
.
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
if
(
ide_raw_taskfile
(
drive
,
&
args
))
{
if
(
ide_raw_taskfile
(
drive
,
&
args
))
{
printk
(
"%s: disabling release interrupt fail
\n
"
,
drive
->
name
);
printk
(
"%s: disabling release interrupt fail
\n
"
,
drive
->
name
);
return
1
;
return
1
;
...
@@ -472,9 +464,6 @@ static int configure_tcq(struct ata_device *drive)
...
@@ -472,9 +464,6 @@ static int configure_tcq(struct ata_device *drive)
memset
(
&
args
,
0
,
sizeof
(
args
));
memset
(
&
args
,
0
,
sizeof
(
args
));
args
.
taskfile
.
feature
=
SETFEATURES_EN_SI
;
args
.
taskfile
.
feature
=
SETFEATURES_EN_SI
;
args
.
cmd
=
WIN_SETFEATURES
;
args
.
cmd
=
WIN_SETFEATURES
;
args
.
handler
=
task_no_data_intr
;
args
.
command_type
=
IDE_DRIVE_TASK_NO_DATA
;
if
(
ide_raw_taskfile
(
drive
,
&
args
))
{
if
(
ide_raw_taskfile
(
drive
,
&
args
))
{
printk
(
"%s: enabling service interrupt fail
\n
"
,
drive
->
name
);
printk
(
"%s: enabling service interrupt fail
\n
"
,
drive
->
name
);
return
1
;
return
1
;
...
...
fs/fcntl.c
View file @
4e30f812
...
@@ -300,11 +300,11 @@ static long do_fcntl(unsigned int fd, unsigned int cmd,
...
@@ -300,11 +300,11 @@ static long do_fcntl(unsigned int fd, unsigned int cmd,
unlock_kernel
();
unlock_kernel
();
break
;
break
;
case
F_GETLK
:
case
F_GETLK
:
err
=
fcntl_getlk
(
f
d
,
(
struct
flock
*
)
arg
);
err
=
fcntl_getlk
(
f
ilp
,
(
struct
flock
*
)
arg
);
break
;
break
;
case
F_SETLK
:
case
F_SETLK
:
case
F_SETLKW
:
case
F_SETLKW
:
err
=
fcntl_setlk
(
f
d
,
cmd
,
(
struct
flock
*
)
arg
);
err
=
fcntl_setlk
(
f
ilp
,
cmd
,
(
struct
flock
*
)
arg
);
break
;
break
;
case
F_GETOWN
:
case
F_GETOWN
:
/*
/*
...
@@ -386,13 +386,11 @@ asmlinkage long sys_fcntl64(unsigned int fd, unsigned int cmd, unsigned long arg
...
@@ -386,13 +386,11 @@ asmlinkage long sys_fcntl64(unsigned int fd, unsigned int cmd, unsigned long arg
switch
(
cmd
)
{
switch
(
cmd
)
{
case
F_GETLK64
:
case
F_GETLK64
:
err
=
fcntl_getlk64
(
f
d
,
(
struct
flock64
*
)
arg
);
err
=
fcntl_getlk64
(
f
ilp
,
(
struct
flock64
*
)
arg
);
break
;
break
;
case
F_SETLK64
:
case
F_SETLK64
:
err
=
fcntl_setlk64
(
fd
,
cmd
,
(
struct
flock64
*
)
arg
);
break
;
case
F_SETLKW64
:
case
F_SETLKW64
:
err
=
fcntl_setlk64
(
f
d
,
cmd
,
(
struct
flock64
*
)
arg
);
err
=
fcntl_setlk64
(
f
ilp
,
cmd
,
(
struct
flock64
*
)
arg
);
break
;
break
;
default:
default:
err
=
do_fcntl
(
fd
,
cmd
,
arg
,
filp
);
err
=
do_fcntl
(
fd
,
cmd
,
arg
,
filp
);
...
...
fs/inode.c
View file @
4e30f812
...
@@ -390,8 +390,7 @@ void prune_icache(int goal)
...
@@ -390,8 +390,7 @@ void prune_icache(int goal)
if
(
atomic_read
(
&
inode
->
i_count
))
if
(
atomic_read
(
&
inode
->
i_count
))
continue
;
continue
;
list_del
(
tmp
);
list_del
(
tmp
);
list_del
(
&
inode
->
i_hash
);
list_del_init
(
&
inode
->
i_hash
);
INIT_LIST_HEAD
(
&
inode
->
i_hash
);
list_add
(
tmp
,
freeable
);
list_add
(
tmp
,
freeable
);
inode
->
i_state
|=
I_FREEING
;
inode
->
i_state
|=
I_FREEING
;
count
++
;
count
++
;
...
@@ -777,8 +776,7 @@ void __insert_inode_hash(struct inode *inode, unsigned long hashval)
...
@@ -777,8 +776,7 @@ void __insert_inode_hash(struct inode *inode, unsigned long hashval)
void
remove_inode_hash
(
struct
inode
*
inode
)
void
remove_inode_hash
(
struct
inode
*
inode
)
{
{
spin_lock
(
&
inode_lock
);
spin_lock
(
&
inode_lock
);
list_del
(
&
inode
->
i_hash
);
list_del_init
(
&
inode
->
i_hash
);
INIT_LIST_HEAD
(
&
inode
->
i_hash
);
spin_unlock
(
&
inode_lock
);
spin_unlock
(
&
inode_lock
);
}
}
...
@@ -786,10 +784,8 @@ void generic_delete_inode(struct inode *inode)
...
@@ -786,10 +784,8 @@ void generic_delete_inode(struct inode *inode)
{
{
struct
super_operations
*
op
=
inode
->
i_sb
->
s_op
;
struct
super_operations
*
op
=
inode
->
i_sb
->
s_op
;
list_del
(
&
inode
->
i_hash
);
list_del_init
(
&
inode
->
i_hash
);
INIT_LIST_HEAD
(
&
inode
->
i_hash
);
list_del_init
(
&
inode
->
i_list
);
list_del
(
&
inode
->
i_list
);
INIT_LIST_HEAD
(
&
inode
->
i_list
);
inode
->
i_state
|=
I_FREEING
;
inode
->
i_state
|=
I_FREEING
;
inodes_stat
.
nr_inodes
--
;
inodes_stat
.
nr_inodes
--
;
spin_unlock
(
&
inode_lock
);
spin_unlock
(
&
inode_lock
);
...
...
fs/locks.c
View file @
4e30f812
...
@@ -397,10 +397,8 @@ locks_same_owner(struct file_lock *fl1, struct file_lock *fl2)
...
@@ -397,10 +397,8 @@ locks_same_owner(struct file_lock *fl1, struct file_lock *fl2)
*/
*/
static
void
locks_delete_block
(
struct
file_lock
*
waiter
)
static
void
locks_delete_block
(
struct
file_lock
*
waiter
)
{
{
list_del
(
&
waiter
->
fl_block
);
list_del_init
(
&
waiter
->
fl_block
);
INIT_LIST_HEAD
(
&
waiter
->
fl_block
);
list_del_init
(
&
waiter
->
fl_link
);
list_del
(
&
waiter
->
fl_link
);
INIT_LIST_HEAD
(
&
waiter
->
fl_link
);
waiter
->
fl_next
=
NULL
;
waiter
->
fl_next
=
NULL
;
}
}
...
@@ -1353,9 +1351,8 @@ asmlinkage long sys_flock(unsigned int fd, unsigned int cmd)
...
@@ -1353,9 +1351,8 @@ asmlinkage long sys_flock(unsigned int fd, unsigned int cmd)
/* Report the first existing lock that would conflict with l.
/* Report the first existing lock that would conflict with l.
* This implements the F_GETLK command of fcntl().
* This implements the F_GETLK command of fcntl().
*/
*/
int
fcntl_getlk
(
unsigned
int
fd
,
struct
flock
*
l
)
int
fcntl_getlk
(
struct
file
*
filp
,
struct
flock
*
l
)
{
{
struct
file
*
filp
;
struct
file_lock
*
fl
,
file_lock
;
struct
file_lock
*
fl
,
file_lock
;
struct
flock
flock
;
struct
flock
flock
;
int
error
;
int
error
;
...
@@ -1367,19 +1364,14 @@ int fcntl_getlk(unsigned int fd, struct flock *l)
...
@@ -1367,19 +1364,14 @@ int fcntl_getlk(unsigned int fd, struct flock *l)
if
((
flock
.
l_type
!=
F_RDLCK
)
&&
(
flock
.
l_type
!=
F_WRLCK
))
if
((
flock
.
l_type
!=
F_RDLCK
)
&&
(
flock
.
l_type
!=
F_WRLCK
))
goto
out
;
goto
out
;
error
=
-
EBADF
;
filp
=
fget
(
fd
);
if
(
!
filp
)
goto
out
;
error
=
flock_to_posix_lock
(
filp
,
&
file_lock
,
&
flock
);
error
=
flock_to_posix_lock
(
filp
,
&
file_lock
,
&
flock
);
if
(
error
)
if
(
error
)
goto
out
_putf
;
goto
out
;
if
(
filp
->
f_op
&&
filp
->
f_op
->
lock
)
{
if
(
filp
->
f_op
&&
filp
->
f_op
->
lock
)
{
error
=
filp
->
f_op
->
lock
(
filp
,
F_GETLK
,
&
file_lock
);
error
=
filp
->
f_op
->
lock
(
filp
,
F_GETLK
,
&
file_lock
);
if
(
error
<
0
)
if
(
error
<
0
)
goto
out
_putf
;
goto
out
;
else
if
(
error
==
LOCK_USE_CLNT
)
else
if
(
error
==
LOCK_USE_CLNT
)
/* Bypass for NFS with no locking - 2.0.36 compat */
/* Bypass for NFS with no locking - 2.0.36 compat */
fl
=
posix_test_lock
(
filp
,
&
file_lock
);
fl
=
posix_test_lock
(
filp
,
&
file_lock
);
...
@@ -1399,10 +1391,10 @@ int fcntl_getlk(unsigned int fd, struct flock *l)
...
@@ -1399,10 +1391,10 @@ int fcntl_getlk(unsigned int fd, struct flock *l)
*/
*/
error
=
-
EOVERFLOW
;
error
=
-
EOVERFLOW
;
if
(
fl
->
fl_start
>
OFFT_OFFSET_MAX
)
if
(
fl
->
fl_start
>
OFFT_OFFSET_MAX
)
goto
out
_putf
;
goto
out
;
if
((
fl
->
fl_end
!=
OFFSET_MAX
)
if
((
fl
->
fl_end
!=
OFFSET_MAX
)
&&
(
fl
->
fl_end
>
OFFT_OFFSET_MAX
))
&&
(
fl
->
fl_end
>
OFFT_OFFSET_MAX
))
goto
out
_putf
;
goto
out
;
#endif
#endif
flock
.
l_start
=
fl
->
fl_start
;
flock
.
l_start
=
fl
->
fl_start
;
flock
.
l_len
=
fl
->
fl_end
==
OFFSET_MAX
?
0
:
flock
.
l_len
=
fl
->
fl_end
==
OFFSET_MAX
?
0
:
...
@@ -1414,8 +1406,6 @@ int fcntl_getlk(unsigned int fd, struct flock *l)
...
@@ -1414,8 +1406,6 @@ int fcntl_getlk(unsigned int fd, struct flock *l)
if
(
!
copy_to_user
(
l
,
&
flock
,
sizeof
(
flock
)))
if
(
!
copy_to_user
(
l
,
&
flock
,
sizeof
(
flock
)))
error
=
0
;
error
=
0
;
out_putf:
fput
(
filp
);
out:
out:
return
error
;
return
error
;
}
}
...
@@ -1423,9 +1413,8 @@ int fcntl_getlk(unsigned int fd, struct flock *l)
...
@@ -1423,9 +1413,8 @@ int fcntl_getlk(unsigned int fd, struct flock *l)
/* Apply the lock described by l to an open file descriptor.
/* Apply the lock described by l to an open file descriptor.
* This implements both the F_SETLK and F_SETLKW commands of fcntl().
* This implements both the F_SETLK and F_SETLKW commands of fcntl().
*/
*/
int
fcntl_setlk
(
unsigned
int
fd
,
unsigned
int
cmd
,
struct
flock
*
l
)
int
fcntl_setlk
(
struct
file
*
filp
,
unsigned
int
cmd
,
struct
flock
*
l
)
{
{
struct
file
*
filp
;
struct
file_lock
*
file_lock
=
locks_alloc_lock
(
0
);
struct
file_lock
*
file_lock
=
locks_alloc_lock
(
0
);
struct
flock
flock
;
struct
flock
flock
;
struct
inode
*
inode
;
struct
inode
*
inode
;
...
@@ -1443,13 +1432,6 @@ int fcntl_setlk(unsigned int fd, unsigned int cmd, struct flock *l)
...
@@ -1443,13 +1432,6 @@ int fcntl_setlk(unsigned int fd, unsigned int cmd, struct flock *l)
/* Get arguments and validate them ...
/* Get arguments and validate them ...
*/
*/
error
=
-
EBADF
;
filp
=
fget
(
fd
);
if
(
!
filp
)
goto
out
;
error
=
-
EINVAL
;
inode
=
filp
->
f_dentry
->
d_inode
;
inode
=
filp
->
f_dentry
->
d_inode
;
/* Don't allow mandatory locks on files that may be memory mapped
/* Don't allow mandatory locks on files that may be memory mapped
...
@@ -1461,23 +1443,23 @@ int fcntl_setlk(unsigned int fd, unsigned int cmd, struct flock *l)
...
@@ -1461,23 +1443,23 @@ int fcntl_setlk(unsigned int fd, unsigned int cmd, struct flock *l)
if
(
!
list_empty
(
&
mapping
->
i_mmap_shared
))
{
if
(
!
list_empty
(
&
mapping
->
i_mmap_shared
))
{
error
=
-
EAGAIN
;
error
=
-
EAGAIN
;
goto
out
_putf
;
goto
out
;
}
}
}
}
error
=
flock_to_posix_lock
(
filp
,
file_lock
,
&
flock
);
error
=
flock_to_posix_lock
(
filp
,
file_lock
,
&
flock
);
if
(
error
)
if
(
error
)
goto
out
_putf
;
goto
out
;
error
=
-
EBADF
;
error
=
-
EBADF
;
switch
(
flock
.
l_type
)
{
switch
(
flock
.
l_type
)
{
case
F_RDLCK
:
case
F_RDLCK
:
if
(
!
(
filp
->
f_mode
&
FMODE_READ
))
if
(
!
(
filp
->
f_mode
&
FMODE_READ
))
goto
out
_putf
;
goto
out
;
break
;
break
;
case
F_WRLCK
:
case
F_WRLCK
:
if
(
!
(
filp
->
f_mode
&
FMODE_WRITE
))
if
(
!
(
filp
->
f_mode
&
FMODE_WRITE
))
goto
out
_putf
;
goto
out
;
break
;
break
;
case
F_UNLCK
:
case
F_UNLCK
:
break
;
break
;
...
@@ -1495,23 +1477,21 @@ int fcntl_setlk(unsigned int fd, unsigned int cmd, struct flock *l)
...
@@ -1495,23 +1477,21 @@ int fcntl_setlk(unsigned int fd, unsigned int cmd, struct flock *l)
}
}
}
}
if
(
!
(
filp
->
f_mode
&
3
))
if
(
!
(
filp
->
f_mode
&
3
))
goto
out
_putf
;
goto
out
;
break
;
break
;
#endif
#endif
default:
default:
error
=
-
EINVAL
;
error
=
-
EINVAL
;
goto
out
_putf
;
goto
out
;
}
}
if
(
filp
->
f_op
&&
filp
->
f_op
->
lock
!=
NULL
)
{
if
(
filp
->
f_op
&&
filp
->
f_op
->
lock
!=
NULL
)
{
error
=
filp
->
f_op
->
lock
(
filp
,
cmd
,
file_lock
);
error
=
filp
->
f_op
->
lock
(
filp
,
cmd
,
file_lock
);
if
(
error
<
0
)
if
(
error
<
0
)
goto
out
_putf
;
goto
out
;
}
}
error
=
posix_lock_file
(
filp
,
file_lock
,
cmd
==
F_SETLKW
);
error
=
posix_lock_file
(
filp
,
file_lock
,
cmd
==
F_SETLKW
);
out_putf:
fput
(
filp
);
out:
out:
locks_free_lock
(
file_lock
);
locks_free_lock
(
file_lock
);
return
error
;
return
error
;
...
@@ -1521,9 +1501,8 @@ int fcntl_setlk(unsigned int fd, unsigned int cmd, struct flock *l)
...
@@ -1521,9 +1501,8 @@ int fcntl_setlk(unsigned int fd, unsigned int cmd, struct flock *l)
/* Report the first existing lock that would conflict with l.
/* Report the first existing lock that would conflict with l.
* This implements the F_GETLK command of fcntl().
* This implements the F_GETLK command of fcntl().
*/
*/
int
fcntl_getlk64
(
unsigned
int
fd
,
struct
flock64
*
l
)
int
fcntl_getlk64
(
struct
file
*
filp
,
struct
flock64
*
l
)
{
{
struct
file
*
filp
;
struct
file_lock
*
fl
,
file_lock
;
struct
file_lock
*
fl
,
file_lock
;
struct
flock64
flock
;
struct
flock64
flock
;
int
error
;
int
error
;
...
@@ -1535,19 +1514,14 @@ int fcntl_getlk64(unsigned int fd, struct flock64 *l)
...
@@ -1535,19 +1514,14 @@ int fcntl_getlk64(unsigned int fd, struct flock64 *l)
if
((
flock
.
l_type
!=
F_RDLCK
)
&&
(
flock
.
l_type
!=
F_WRLCK
))
if
((
flock
.
l_type
!=
F_RDLCK
)
&&
(
flock
.
l_type
!=
F_WRLCK
))
goto
out
;
goto
out
;
error
=
-
EBADF
;
filp
=
fget
(
fd
);
if
(
!
filp
)
goto
out
;
error
=
flock64_to_posix_lock
(
filp
,
&
file_lock
,
&
flock
);
error
=
flock64_to_posix_lock
(
filp
,
&
file_lock
,
&
flock
);
if
(
error
)
if
(
error
)
goto
out
_putf
;
goto
out
;
if
(
filp
->
f_op
&&
filp
->
f_op
->
lock
)
{
if
(
filp
->
f_op
&&
filp
->
f_op
->
lock
)
{
error
=
filp
->
f_op
->
lock
(
filp
,
F_GETLK
,
&
file_lock
);
error
=
filp
->
f_op
->
lock
(
filp
,
F_GETLK
,
&
file_lock
);
if
(
error
<
0
)
if
(
error
<
0
)
goto
out
_putf
;
goto
out
;
else
if
(
error
==
LOCK_USE_CLNT
)
else
if
(
error
==
LOCK_USE_CLNT
)
/* Bypass for NFS with no locking - 2.0.36 compat */
/* Bypass for NFS with no locking - 2.0.36 compat */
fl
=
posix_test_lock
(
filp
,
&
file_lock
);
fl
=
posix_test_lock
(
filp
,
&
file_lock
);
...
@@ -1570,8 +1544,6 @@ int fcntl_getlk64(unsigned int fd, struct flock64 *l)
...
@@ -1570,8 +1544,6 @@ int fcntl_getlk64(unsigned int fd, struct flock64 *l)
if
(
!
copy_to_user
(
l
,
&
flock
,
sizeof
(
flock
)))
if
(
!
copy_to_user
(
l
,
&
flock
,
sizeof
(
flock
)))
error
=
0
;
error
=
0
;
out_putf:
fput
(
filp
);
out:
out:
return
error
;
return
error
;
}
}
...
@@ -1579,9 +1551,8 @@ int fcntl_getlk64(unsigned int fd, struct flock64 *l)
...
@@ -1579,9 +1551,8 @@ int fcntl_getlk64(unsigned int fd, struct flock64 *l)
/* Apply the lock described by l to an open file descriptor.
/* Apply the lock described by l to an open file descriptor.
* This implements both the F_SETLK and F_SETLKW commands of fcntl().
* This implements both the F_SETLK and F_SETLKW commands of fcntl().
*/
*/
int
fcntl_setlk64
(
unsigned
int
fd
,
unsigned
int
cmd
,
struct
flock64
*
l
)
int
fcntl_setlk64
(
struct
file
*
filp
,
unsigned
int
cmd
,
struct
flock64
*
l
)
{
{
struct
file
*
filp
;
struct
file_lock
*
file_lock
=
locks_alloc_lock
(
0
);
struct
file_lock
*
file_lock
=
locks_alloc_lock
(
0
);
struct
flock64
flock
;
struct
flock64
flock
;
struct
inode
*
inode
;
struct
inode
*
inode
;
...
@@ -1599,13 +1570,6 @@ int fcntl_setlk64(unsigned int fd, unsigned int cmd, struct flock64 *l)
...
@@ -1599,13 +1570,6 @@ int fcntl_setlk64(unsigned int fd, unsigned int cmd, struct flock64 *l)
/* Get arguments and validate them ...
/* Get arguments and validate them ...
*/
*/
error
=
-
EBADF
;
filp
=
fget
(
fd
);
if
(
!
filp
)
goto
out
;
error
=
-
EINVAL
;
inode
=
filp
->
f_dentry
->
d_inode
;
inode
=
filp
->
f_dentry
->
d_inode
;
/* Don't allow mandatory locks on files that may be memory mapped
/* Don't allow mandatory locks on files that may be memory mapped
...
@@ -1617,23 +1581,23 @@ int fcntl_setlk64(unsigned int fd, unsigned int cmd, struct flock64 *l)
...
@@ -1617,23 +1581,23 @@ int fcntl_setlk64(unsigned int fd, unsigned int cmd, struct flock64 *l)
if
(
!
list_empty
(
&
mapping
->
i_mmap_shared
))
{
if
(
!
list_empty
(
&
mapping
->
i_mmap_shared
))
{
error
=
-
EAGAIN
;
error
=
-
EAGAIN
;
goto
out
_putf
;
goto
out
;
}
}
}
}
error
=
flock64_to_posix_lock
(
filp
,
file_lock
,
&
flock
);
error
=
flock64_to_posix_lock
(
filp
,
file_lock
,
&
flock
);
if
(
error
)
if
(
error
)
goto
out
_putf
;
goto
out
;
error
=
-
EBADF
;
error
=
-
EBADF
;
switch
(
flock
.
l_type
)
{
switch
(
flock
.
l_type
)
{
case
F_RDLCK
:
case
F_RDLCK
:
if
(
!
(
filp
->
f_mode
&
FMODE_READ
))
if
(
!
(
filp
->
f_mode
&
FMODE_READ
))
goto
out
_putf
;
goto
out
;
break
;
break
;
case
F_WRLCK
:
case
F_WRLCK
:
if
(
!
(
filp
->
f_mode
&
FMODE_WRITE
))
if
(
!
(
filp
->
f_mode
&
FMODE_WRITE
))
goto
out
_putf
;
goto
out
;
break
;
break
;
case
F_UNLCK
:
case
F_UNLCK
:
break
;
break
;
...
@@ -1641,18 +1605,16 @@ int fcntl_setlk64(unsigned int fd, unsigned int cmd, struct flock64 *l)
...
@@ -1641,18 +1605,16 @@ int fcntl_setlk64(unsigned int fd, unsigned int cmd, struct flock64 *l)
case
F_EXLCK
:
case
F_EXLCK
:
default:
default:
error
=
-
EINVAL
;
error
=
-
EINVAL
;
goto
out
_putf
;
goto
out
;
}
}
if
(
filp
->
f_op
&&
filp
->
f_op
->
lock
!=
NULL
)
{
if
(
filp
->
f_op
&&
filp
->
f_op
->
lock
!=
NULL
)
{
error
=
filp
->
f_op
->
lock
(
filp
,
cmd
,
file_lock
);
error
=
filp
->
f_op
->
lock
(
filp
,
cmd
,
file_lock
);
if
(
error
<
0
)
if
(
error
<
0
)
goto
out
_putf
;
goto
out
;
}
}
error
=
posix_lock_file
(
filp
,
file_lock
,
cmd
==
F_SETLKW64
);
error
=
posix_lock_file
(
filp
,
file_lock
,
cmd
==
F_SETLKW64
);
out_putf:
fput
(
filp
);
out:
out:
locks_free_lock
(
file_lock
);
locks_free_lock
(
file_lock
);
return
error
;
return
error
;
...
...
fs/mpage.c
View file @
4e30f812
...
@@ -12,6 +12,7 @@
...
@@ -12,6 +12,7 @@
#include <linux/kernel.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/module.h>
#include <linux/kdev_t.h>
#include <linux/bio.h>
#include <linux/bio.h>
#include <linux/fs.h>
#include <linux/fs.h>
#include <linux/buffer_head.h>
#include <linux/buffer_head.h>
...
...
include/asm-i386/bugs.h
View file @
4e30f812
...
@@ -21,6 +21,7 @@
...
@@ -21,6 +21,7 @@
*/
*/
#include <linux/config.h>
#include <linux/config.h>
#include <linux/init.h>
#include <asm/processor.h>
#include <asm/processor.h>
#include <asm/i387.h>
#include <asm/i387.h>
#include <asm/msr.h>
#include <asm/msr.h>
...
...
include/asm-i386/highmem.h
View file @
4e30f812
...
@@ -21,7 +21,6 @@
...
@@ -21,7 +21,6 @@
#ifdef __KERNEL__
#ifdef __KERNEL__
#include <linux/config.h>
#include <linux/config.h>
#include <linux/init.h>
#include <linux/interrupt.h>
#include <linux/interrupt.h>
#include <asm/kmap_types.h>
#include <asm/kmap_types.h>
#include <asm/tlbflush.h>
#include <asm/tlbflush.h>
...
@@ -33,7 +32,7 @@ extern pte_t *kmap_pte;
...
@@ -33,7 +32,7 @@ extern pte_t *kmap_pte;
extern
pgprot_t
kmap_prot
;
extern
pgprot_t
kmap_prot
;
extern
pte_t
*
pkmap_page_table
;
extern
pte_t
*
pkmap_page_table
;
extern
void
kmap_init
(
void
)
__init
;
extern
void
kmap_init
(
void
);
/*
/*
* Right now we initialize only a single pte table. It can be extended
* Right now we initialize only a single pte table. It can be extended
...
...
include/asm-i386/system.h
View file @
4e30f812
...
@@ -3,7 +3,6 @@
...
@@ -3,7 +3,6 @@
#include <linux/config.h>
#include <linux/config.h>
#include <linux/kernel.h>
#include <linux/kernel.h>
#include <linux/init.h>
#include <asm/segment.h>
#include <asm/segment.h>
#include <linux/bitops.h>
/* for LOCK_PREFIX */
#include <linux/bitops.h>
/* for LOCK_PREFIX */
...
...
include/linux/blkdev.h
View file @
4e30f812
...
@@ -81,13 +81,11 @@ enum rq_flag_bits {
...
@@ -81,13 +81,11 @@ enum rq_flag_bits {
/*
/*
* for ATA/ATAPI devices
* for ATA/ATAPI devices
*/
*/
__REQ_DRIVE_ACB
,
__REQ_PC
,
/* packet command (special) */
__REQ_PC
,
/* packet command (special) */
__REQ_BLOCK_PC
,
/* queued down pc from block layer */
__REQ_BLOCK_PC
,
/* queued down pc from block layer */
__REQ_SENSE
,
/* sense retrival */
__REQ_SENSE
,
/* sense retrival */
__REQ_SPECIAL
,
/* driver s
pecial command (currently reset)
*/
__REQ_SPECIAL
,
/* driver s
uplied command
*/
__REQ_NR_BITS
,
/* stops here */
__REQ_NR_BITS
,
/* stops here */
};
};
...
@@ -100,7 +98,6 @@ enum rq_flag_bits {
...
@@ -100,7 +98,6 @@ enum rq_flag_bits {
#define REQ_STARTED (1 << __REQ_STARTED)
#define REQ_STARTED (1 << __REQ_STARTED)
#define REQ_DONTPREP (1 << __REQ_DONTPREP)
#define REQ_DONTPREP (1 << __REQ_DONTPREP)
#define REQ_QUEUED (1 << __REQ_QUEUED)
#define REQ_QUEUED (1 << __REQ_QUEUED)
#define REQ_DRIVE_ACB (1 << __REQ_DRIVE_ACB)
#define REQ_PC (1 << __REQ_PC)
#define REQ_PC (1 << __REQ_PC)
#define REQ_BLOCK_PC (1 << __REQ_BLOCK_PC)
#define REQ_BLOCK_PC (1 << __REQ_BLOCK_PC)
#define REQ_SENSE (1 << __REQ_SENSE)
#define REQ_SENSE (1 << __REQ_SENSE)
...
...
include/linux/fs.h
View file @
4e30f812
...
@@ -576,11 +576,11 @@ extern struct list_head file_lock_list;
...
@@ -576,11 +576,11 @@ extern struct list_head file_lock_list;
#include <linux/fcntl.h>
#include <linux/fcntl.h>
extern
int
fcntl_getlk
(
unsigned
int
,
struct
flock
*
);
extern
int
fcntl_getlk
(
struct
file
*
,
struct
flock
*
);
extern
int
fcntl_setlk
(
unsigned
int
,
unsigned
int
,
struct
flock
*
);
extern
int
fcntl_setlk
(
struct
file
*
,
unsigned
int
,
struct
flock
*
);
extern
int
fcntl_getlk64
(
unsigned
int
,
struct
flock64
*
);
extern
int
fcntl_getlk64
(
struct
file
*
,
struct
flock64
*
);
extern
int
fcntl_setlk64
(
unsigned
int
,
unsigned
int
,
struct
flock64
*
);
extern
int
fcntl_setlk64
(
struct
file
*
,
unsigned
int
,
struct
flock64
*
);
/* fs/locks.c */
/* fs/locks.c */
extern
void
locks_init_lock
(
struct
file_lock
*
);
extern
void
locks_init_lock
(
struct
file_lock
*
);
...
...
include/linux/ide.h
View file @
4e30f812
...
@@ -654,11 +654,6 @@ typedef enum {
...
@@ -654,11 +654,6 @@ typedef enum {
extern
int
ide_do_drive_cmd
(
struct
ata_device
*
,
struct
request
*
,
ide_action_t
);
extern
int
ide_do_drive_cmd
(
struct
ata_device
*
,
struct
request
*
,
ide_action_t
);
/*
* Clean up after success/failure of an explicit drive cmd.
*/
extern
void
ide_end_drive_cmd
(
struct
ata_device
*
,
struct
request
*
);
struct
ata_taskfile
{
struct
ata_taskfile
{
struct
hd_drive_task_hdr
taskfile
;
struct
hd_drive_task_hdr
taskfile
;
struct
hd_drive_task_hdr
hobfile
;
struct
hd_drive_task_hdr
hobfile
;
...
@@ -695,7 +690,7 @@ static inline void ide_unmap_rq(struct request *rq, char *to,
...
@@ -695,7 +690,7 @@ static inline void ide_unmap_rq(struct request *rq, char *to,
bio_kunmap_irq
(
to
,
flags
);
bio_kunmap_irq
(
to
,
flags
);
}
}
extern
ide_startstop_t
task_no_data
_intr
(
struct
ata_device
*
,
struct
request
*
);
extern
ide_startstop_t
ata_special
_intr
(
struct
ata_device
*
,
struct
request
*
);
extern
int
ide_raw_taskfile
(
struct
ata_device
*
,
struct
ata_taskfile
*
);
extern
int
ide_raw_taskfile
(
struct
ata_device
*
,
struct
ata_taskfile
*
);
extern
void
ide_fix_driveid
(
struct
hd_driveid
*
id
);
extern
void
ide_fix_driveid
(
struct
hd_driveid
*
id
);
...
...
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