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
Kirill Smelkov
linux
Commits
b90f37ea
Commit
b90f37ea
authored
Nov 05, 2004
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://bart.bkbits.net/ide-2.6
into ppc970.osdl.org:/home/torvalds/v2.6/linux
parents
f7776d21
db01db10
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
186 additions
and
98 deletions
+186
-98
drivers/ide/ide-probe.c
drivers/ide/ide-probe.c
+48
-15
drivers/ide/ide.c
drivers/ide/ide.c
+11
-3
drivers/ide/legacy/ide-cs.c
drivers/ide/legacy/ide-cs.c
+1
-1
drivers/ide/pci/cs5520.c
drivers/ide/pci/cs5520.c
+0
-2
drivers/ide/pci/ns87415.c
drivers/ide/pci/ns87415.c
+79
-4
drivers/ide/pci/siimage.c
drivers/ide/pci/siimage.c
+32
-22
drivers/ide/setup-pci.c
drivers/ide/setup-pci.c
+2
-2
include/linux/ata.h
include/linux/ata.h
+6
-2
include/linux/hdreg.h
include/linux/hdreg.h
+2
-21
include/linux/ide.h
include/linux/ide.h
+5
-26
No files found.
drivers/ide/ide-probe.c
View file @
b90f37ea
...
@@ -652,6 +652,43 @@ static int wait_hwif_ready(ide_hwif_t *hwif)
...
@@ -652,6 +652,43 @@ static int wait_hwif_ready(ide_hwif_t *hwif)
return
rc
;
return
rc
;
}
}
/**
* ide_undecoded_slave - look for bad CF adapters
* @hwif: interface
*
* Analyse the drives on the interface and attempt to decide if we
* have the same drive viewed twice. This occurs with crap CF adapters
* and PCMCIA sometimes.
*/
void
ide_undecoded_slave
(
ide_hwif_t
*
hwif
)
{
ide_drive_t
*
drive0
=
&
hwif
->
drives
[
0
];
ide_drive_t
*
drive1
=
&
hwif
->
drives
[
1
];
if
(
drive0
->
present
==
0
||
drive1
->
present
==
0
)
return
;
/* If the models don't match they are not the same product */
if
(
strcmp
(
drive0
->
id
->
model
,
drive1
->
id
->
model
))
return
;
/* Serial numbers do not match */
if
(
strncmp
(
drive0
->
id
->
serial_no
,
drive1
->
id
->
serial_no
,
20
))
return
;
/* No serial number, thankfully very rare for CF */
if
(
drive0
->
id
->
serial_no
[
0
]
==
0
)
return
;
/* Appears to be an IDE flash adapter with decode bugs */
printk
(
KERN_WARNING
"ide-probe: ignoring undecoded slave
\n
"
);
drive1
->
present
=
0
;
}
EXPORT_SYMBOL_GPL
(
ide_undecoded_slave
);
/*
/*
* This routine only knows how to look for drive units 0 and 1
* This routine only knows how to look for drive units 0 and 1
* on an interface, so any setting of MAX_DRIVES > 2 won't work here.
* on an interface, so any setting of MAX_DRIVES > 2 won't work here.
...
@@ -723,20 +760,6 @@ static void probe_hwif(ide_hwif_t *hwif)
...
@@ -723,20 +760,6 @@ static void probe_hwif(ide_hwif_t *hwif)
ide_drive_t
*
drive
=
&
hwif
->
drives
[
unit
];
ide_drive_t
*
drive
=
&
hwif
->
drives
[
unit
];
drive
->
dn
=
(
hwif
->
channel
?
2
:
0
)
+
unit
;
drive
->
dn
=
(
hwif
->
channel
?
2
:
0
)
+
unit
;
(
void
)
probe_for_drive
(
drive
);
(
void
)
probe_for_drive
(
drive
);
if
(
drive
->
present
&&
hwif
->
present
&&
unit
==
1
)
{
if
(
strcmp
(
hwif
->
drives
[
0
].
id
->
model
,
drive
->
id
->
model
)
==
0
&&
/* Don't do this for noprobe or non ATA */
strcmp
(
drive
->
id
->
model
,
"UNKNOWN"
)
&&
/* And beware of confused Maxtor drives that go "M0000000000"
"The SN# is garbage in the ID block..." [Eric] */
strncmp
(
drive
->
id
->
serial_no
,
"M0000000000000000000"
,
20
)
&&
/* Same goes for another set of Maxtor drives that say "D3000000" */
strncmp
(
drive
->
id
->
serial_no
,
"D3000000"
,
8
)
&&
strncmp
(
hwif
->
drives
[
0
].
id
->
serial_no
,
drive
->
id
->
serial_no
,
20
)
==
0
)
{
printk
(
KERN_WARNING
"ide-probe: ignoring undecoded slave
\n
"
);
drive
->
present
=
0
;
}
}
if
(
drive
->
present
&&
!
hwif
->
present
)
{
if
(
drive
->
present
&&
!
hwif
->
present
)
{
hwif
->
present
=
1
;
hwif
->
present
=
1
;
if
(
hwif
->
chipset
!=
ide_4drives
||
if
(
hwif
->
chipset
!=
ide_4drives
||
...
@@ -810,9 +833,14 @@ static void probe_hwif(ide_hwif_t *hwif)
...
@@ -810,9 +833,14 @@ static void probe_hwif(ide_hwif_t *hwif)
}
}
static
int
hwif_init
(
ide_hwif_t
*
hwif
);
static
int
hwif_init
(
ide_hwif_t
*
hwif
);
int
probe_hwif_init
(
ide_hwif_t
*
hwif
)
int
probe_hwif_init_with_fixup
(
ide_hwif_t
*
hwif
,
void
(
*
fixup
)(
ide_hwif_t
*
hwif
))
{
{
probe_hwif
(
hwif
);
probe_hwif
(
hwif
);
if
(
fixup
)
fixup
(
hwif
);
hwif_init
(
hwif
);
hwif_init
(
hwif
);
if
(
hwif
->
present
)
{
if
(
hwif
->
present
)
{
...
@@ -830,6 +858,11 @@ int probe_hwif_init (ide_hwif_t *hwif)
...
@@ -830,6 +858,11 @@ int probe_hwif_init (ide_hwif_t *hwif)
return
0
;
return
0
;
}
}
int
probe_hwif_init
(
ide_hwif_t
*
hwif
)
{
return
probe_hwif_init_with_fixup
(
hwif
,
NULL
);
}
EXPORT_SYMBOL
(
probe_hwif_init
);
EXPORT_SYMBOL
(
probe_hwif_init
);
#if MAX_HWIFS > 1
#if MAX_HWIFS > 1
...
...
drivers/ide/ide.c
View file @
b90f37ea
...
@@ -985,9 +985,10 @@ void ide_setup_ports ( hw_regs_t *hw,
...
@@ -985,9 +985,10 @@ void ide_setup_ports ( hw_regs_t *hw,
}
}
/**
/**
* ide_register_hw
- register IDE interface
* ide_register_hw
_with_fixup
- register IDE interface
* @hw: hardware registers
* @hw: hardware registers
* @hwifp: pointer to returned hwif
* @hwifp: pointer to returned hwif
* @fixup: fixup function
*
*
* Register an IDE interface, specifying exactly the registers etc.
* Register an IDE interface, specifying exactly the registers etc.
* Set init=1 iff calling before probes have taken place.
* Set init=1 iff calling before probes have taken place.
...
@@ -995,7 +996,7 @@ void ide_setup_ports ( hw_regs_t *hw,
...
@@ -995,7 +996,7 @@ void ide_setup_ports ( hw_regs_t *hw,
* Returns -1 on error.
* Returns -1 on error.
*/
*/
int
ide_register_hw
(
hw_regs_t
*
hw
,
ide_hwif_t
**
hwifp
)
int
ide_register_hw
_with_fixup
(
hw_regs_t
*
hw
,
ide_hwif_t
**
hwifp
,
void
(
*
fixup
)(
ide_hwif_t
*
hwif
)
)
{
{
int
index
,
retry
=
1
;
int
index
,
retry
=
1
;
ide_hwif_t
*
hwif
;
ide_hwif_t
*
hwif
;
...
@@ -1034,7 +1035,7 @@ int ide_register_hw (hw_regs_t *hw, ide_hwif_t **hwifp)
...
@@ -1034,7 +1035,7 @@ int ide_register_hw (hw_regs_t *hw, ide_hwif_t **hwifp)
hwif
->
chipset
=
hw
->
chipset
;
hwif
->
chipset
=
hw
->
chipset
;
if
(
!
initializing
)
{
if
(
!
initializing
)
{
probe_hwif_init
(
hwif
);
probe_hwif_init
_with_fixup
(
hwif
,
fixup
);
create_proc_ide_interfaces
();
create_proc_ide_interfaces
();
}
}
...
@@ -1044,6 +1045,13 @@ int ide_register_hw (hw_regs_t *hw, ide_hwif_t **hwifp)
...
@@ -1044,6 +1045,13 @@ int ide_register_hw (hw_regs_t *hw, ide_hwif_t **hwifp)
return
(
initializing
||
hwif
->
present
)
?
index
:
-
1
;
return
(
initializing
||
hwif
->
present
)
?
index
:
-
1
;
}
}
EXPORT_SYMBOL
(
ide_register_hw_with_fixup
);
int
ide_register_hw
(
hw_regs_t
*
hw
,
ide_hwif_t
**
hwifp
)
{
return
ide_register_hw_with_fixup
(
hw
,
hwifp
,
NULL
);
}
EXPORT_SYMBOL
(
ide_register_hw
);
EXPORT_SYMBOL
(
ide_register_hw
);
/*
/*
...
...
drivers/ide/legacy/ide-cs.c
View file @
b90f37ea
...
@@ -206,7 +206,7 @@ static int idecs_register(unsigned long io, unsigned long ctl, unsigned long irq
...
@@ -206,7 +206,7 @@ static int idecs_register(unsigned long io, unsigned long ctl, unsigned long irq
ide_init_hwif_ports
(
&
hw
,
io
,
ctl
,
NULL
);
ide_init_hwif_ports
(
&
hw
,
io
,
ctl
,
NULL
);
hw
.
irq
=
irq
;
hw
.
irq
=
irq
;
hw
.
chipset
=
ide_pci
;
hw
.
chipset
=
ide_pci
;
return
ide_register_hw
(
&
hw
,
NULL
);
return
ide_register_hw
_with_fixup
(
&
hw
,
NULL
,
ide_undecoded_slave
);
}
}
/*======================================================================
/*======================================================================
...
...
drivers/ide/pci/cs5520.c
View file @
b90f37ea
...
@@ -241,8 +241,6 @@ static int __devinit cs5520_init_one(struct pci_dev *dev, const struct pci_devic
...
@@ -241,8 +241,6 @@ static int __devinit cs5520_init_one(struct pci_dev *dev, const struct pci_devic
ide_pci_setup_ports
(
dev
,
d
,
14
,
&
index
);
ide_pci_setup_ports
(
dev
,
d
,
14
,
&
index
);
printk
(
"Index.b %d %d
\n
"
,
index
.
b
.
low
,
index
.
b
.
high
);
mdelay
(
2000
);
if
((
index
.
b
.
low
&
0xf0
)
!=
0xf0
)
if
((
index
.
b
.
low
&
0xf0
)
!=
0xf0
)
probe_hwif_init
(
&
ide_hwifs
[
index
.
b
.
low
]);
probe_hwif_init
(
&
ide_hwifs
[
index
.
b
.
low
]);
if
((
index
.
b
.
high
&
0xf0
)
!=
0xf0
)
if
((
index
.
b
.
high
&
0xf0
)
!=
0xf0
)
...
...
drivers/ide/pci/ns87415.c
View file @
b90f37ea
...
@@ -4,6 +4,7 @@
...
@@ -4,6 +4,7 @@
* Copyright (C) 1997-1998 Mark Lord <mlord@pobox.com>
* Copyright (C) 1997-1998 Mark Lord <mlord@pobox.com>
* Copyright (C) 1998 Eddie C. Dost <ecd@skynet.be>
* Copyright (C) 1998 Eddie C. Dost <ecd@skynet.be>
* Copyright (C) 1999-2000 Andre Hedrick <andre@linux-ide.org>
* Copyright (C) 1999-2000 Andre Hedrick <andre@linux-ide.org>
* Copyright (C) 2004 Grant Grundler <grundler at parisc-linux.org>
*
*
* Inspired by an earlier effort from David S. Miller <davem@redhat.com>
* Inspired by an earlier effort from David S. Miller <davem@redhat.com>
*/
*/
...
@@ -25,6 +26,81 @@
...
@@ -25,6 +26,81 @@
#include <asm/io.h>
#include <asm/io.h>
#ifdef CONFIG_SUPERIO
/* SUPERIO 87560 is a PoS chip that NatSem denies exists.
* Unfortunately, it's built-in on all Astro-based PA-RISC workstations
* which use the integrated NS87514 cell for CD-ROM support.
* i.e we have to support for CD-ROM installs.
* See drivers/parisc/superio.c for more gory details.
*/
#include <asm/superio.h>
static
unsigned
long
superio_ide_status
[
2
];
static
unsigned
long
superio_ide_select
[
2
];
static
unsigned
long
superio_ide_dma_status
[
2
];
#define SUPERIO_IDE_MAX_RETRIES 25
/* Because of a defect in Super I/O, all reads of the PCI DMA status
* registers, IDE status register and the IDE select register need to be
* retried
*/
static
u8
superio_ide_inb
(
unsigned
long
port
)
{
if
(
port
==
superio_ide_status
[
0
]
||
port
==
superio_ide_status
[
1
]
||
port
==
superio_ide_select
[
0
]
||
port
==
superio_ide_select
[
1
]
||
port
==
superio_ide_dma_status
[
0
]
||
port
==
superio_ide_dma_status
[
1
])
{
u8
tmp
;
int
retries
=
SUPERIO_IDE_MAX_RETRIES
;
/* printk(" [ reading port 0x%x with retry ] ", port); */
do
{
tmp
=
inb
(
port
);
if
(
tmp
==
0
)
udelay
(
50
);
}
while
(
tmp
==
0
&&
retries
--
>
0
);
return
tmp
;
}
return
inb
(
port
);
}
static
void
__devinit
superio_ide_init_iops
(
struct
hwif_s
*
hwif
)
{
u32
base
,
dmabase
;
u8
tmp
;
struct
pci_dev
*
pdev
=
hwif
->
pci_dev
;
u8
port
=
hwif
->
channel
;
base
=
pci_resource_start
(
pdev
,
port
*
2
)
&
~
3
;
dmabase
=
pci_resource_start
(
pdev
,
4
)
&
~
3
;
superio_ide_status
[
port
]
=
base
+
IDE_STATUS_OFFSET
;
superio_ide_select
[
port
]
=
base
+
IDE_SELECT_OFFSET
;
superio_ide_dma_status
[
port
]
=
dmabase
+
(
!
port
?
2
:
0xa
);
/* Clear error/interrupt, enable dma */
tmp
=
superio_ide_inb
(
superio_ide_dma_status
[
port
]);
outb
(
tmp
|
0x66
,
superio_ide_dma_status
[
port
]);
/* We need to override inb to workaround a SuperIO errata */
hwif
->
INB
=
superio_ide_inb
;
}
static
void
__devinit
init_iops_ns87415
(
ide_hwif_t
*
hwif
)
{
if
(
PCI_SLOT
(
hwif
->
pci_dev
->
devfn
)
==
0xE
)
{
/* Built-in - assume it's under superio. */
superio_ide_init_iops
(
hwif
);
}
}
#endif
static
unsigned
int
ns87415_count
=
0
,
ns87415_control
[
MAX_HWIFS
]
=
{
0
};
static
unsigned
int
ns87415_count
=
0
,
ns87415_control
[
MAX_HWIFS
]
=
{
0
};
/*
/*
...
@@ -132,10 +208,6 @@ static void __init init_hwif_ns87415 (ide_hwif_t *hwif)
...
@@ -132,10 +208,6 @@ static void __init init_hwif_ns87415 (ide_hwif_t *hwif)
hwif
->
autodma
=
0
;
hwif
->
autodma
=
0
;
hwif
->
selectproc
=
&
ns87415_selectproc
;
hwif
->
selectproc
=
&
ns87415_selectproc
;
/* Set a good latency timer and cache line size value. */
(
void
)
pci_write_config_byte
(
dev
,
PCI_LATENCY_TIMER
,
64
);
/* FIXME: use pci_set_master() to ensure good latency timer value */
/*
/*
* We cannot probe for IRQ: both ports share common IRQ on INTA.
* We cannot probe for IRQ: both ports share common IRQ on INTA.
* Also, leave IRQ masked during drive probing, to prevent infinite
* Also, leave IRQ masked during drive probing, to prevent infinite
...
@@ -205,6 +277,9 @@ static void __init init_hwif_ns87415 (ide_hwif_t *hwif)
...
@@ -205,6 +277,9 @@ static void __init init_hwif_ns87415 (ide_hwif_t *hwif)
static
ide_pci_device_t
ns87415_chipset
__devinitdata
=
{
static
ide_pci_device_t
ns87415_chipset
__devinitdata
=
{
.
name
=
"NS87415"
,
.
name
=
"NS87415"
,
#ifdef CONFIG_SUPERIO
.
init_iops
=
init_iops_ns87415
,
#endif
.
init_hwif
=
init_hwif_ns87415
,
.
init_hwif
=
init_hwif_ns87415
,
.
channels
=
2
,
.
channels
=
2
,
.
autodma
=
AUTODMA
,
.
autodma
=
AUTODMA
,
...
...
drivers/ide/pci/siimage.c
View file @
b90f37ea
...
@@ -871,12 +871,11 @@ static void __devinit init_mmio_iops_siimage(ide_hwif_t *hwif)
...
@@ -871,12 +871,11 @@ static void __devinit init_mmio_iops_siimage(ide_hwif_t *hwif)
* the MMIO layout isnt the same as the the standard port
* the MMIO layout isnt the same as the the standard port
* based I/O
* based I/O
*/
*/
memset
(
&
hw
,
0
,
sizeof
(
hw_regs_t
));
memset
(
&
hw
,
0
,
sizeof
(
hw_regs_t
));
hw
.
priv
=
addr
;
base
=
(
unsigned
long
)
addr
;
base
=
(
unsigned
long
)
addr
;
if
(
ch
)
if
(
ch
)
base
+=
0xC0
;
base
+=
0xC0
;
else
else
base
+=
0x80
;
base
+=
0x80
;
...
@@ -901,16 +900,16 @@ static void __devinit init_mmio_iops_siimage(ide_hwif_t *hwif)
...
@@ -901,16 +900,16 @@ static void __devinit init_mmio_iops_siimage(ide_hwif_t *hwif)
hw
.
io_ports
[
IDE_IRQ_OFFSET
]
=
0
;
hw
.
io_ports
[
IDE_IRQ_OFFSET
]
=
0
;
if
(
pdev_is_sata
(
dev
))
{
if
(
pdev_is_sata
(
dev
))
{
base
=
(
unsigned
long
)
addr
;
base
=
(
unsigned
long
)
addr
;
if
(
ch
)
if
(
ch
)
base
+=
0x80
;
base
+=
0x80
;
hw
.
sata_scr
[
SATA_STATUS_OFFSET
]
=
base
+
0x104
;
hw
if
->
sata_scr
[
SATA_STATUS_OFFSET
]
=
base
+
0x104
;
hw
.
sata_scr
[
SATA_ERROR_OFFSET
]
=
base
+
0x108
;
hw
if
->
sata_scr
[
SATA_ERROR_OFFSET
]
=
base
+
0x108
;
hw
.
sata_scr
[
SATA_CONTROL_OFFSET
]
=
base
+
0x100
;
hw
if
->
sata_scr
[
SATA_CONTROL_OFFSET
]
=
base
+
0x100
;
hw
.
sata_misc
[
SATA_MISC_OFFSET
]
=
base
+
0x140
;
hw
if
->
sata_misc
[
SATA_MISC_OFFSET
]
=
base
+
0x140
;
hw
.
sata_misc
[
SATA_PHY_OFFSET
]
=
base
+
0x144
;
hw
if
->
sata_misc
[
SATA_PHY_OFFSET
]
=
base
+
0x144
;
hw
.
sata_misc
[
SATA_IEN_OFFSET
]
=
base
+
0x148
;
hw
if
->
sata_misc
[
SATA_IEN_OFFSET
]
=
base
+
0x148
;
}
}
hw
.
irq
=
hwif
->
pci_dev
->
irq
;
hw
.
irq
=
hwif
->
pci_dev
->
irq
;
...
@@ -918,11 +917,6 @@ static void __devinit init_mmio_iops_siimage(ide_hwif_t *hwif)
...
@@ -918,11 +917,6 @@ static void __devinit init_mmio_iops_siimage(ide_hwif_t *hwif)
memcpy
(
&
hwif
->
hw
,
&
hw
,
sizeof
(
hw
));
memcpy
(
&
hwif
->
hw
,
&
hw
,
sizeof
(
hw
));
memcpy
(
hwif
->
io_ports
,
hwif
->
hw
.
io_ports
,
sizeof
(
hwif
->
hw
.
io_ports
));
memcpy
(
hwif
->
io_ports
,
hwif
->
hw
.
io_ports
,
sizeof
(
hwif
->
hw
.
io_ports
));
if
(
is_sata
(
hwif
))
{
memcpy
(
hwif
->
sata_scr
,
hwif
->
hw
.
sata_scr
,
sizeof
(
hwif
->
hw
.
sata_scr
));
memcpy
(
hwif
->
sata_misc
,
hwif
->
hw
.
sata_misc
,
sizeof
(
hwif
->
hw
.
sata_misc
));
}
hwif
->
irq
=
hw
.
irq
;
hwif
->
irq
=
hw
.
irq
;
base
=
(
unsigned
long
)
addr
;
base
=
(
unsigned
long
)
addr
;
...
@@ -960,6 +954,22 @@ static int is_dev_seagate_sata(ide_drive_t *drive)
...
@@ -960,6 +954,22 @@ static int is_dev_seagate_sata(ide_drive_t *drive)
return
0
;
return
0
;
}
}
/**
* siimage_fixup - post probe fixups
* @hwif: interface to fix up
*
* Called after drive probe we use this to decide whether the
* Seagate fixup must be applied. This used to be in init_iops but
* that can occur before we know what drives are present.
*/
static
void
__devinit
siimage_fixup
(
ide_hwif_t
*
hwif
)
{
/* Try and raise the rqsize */
if
(
!
is_sata
(
hwif
)
||
!
is_dev_seagate_sata
(
&
hwif
->
drives
[
0
]))
hwif
->
rqsize
=
128
;
}
/**
/**
* init_iops_siimage - set up iops
* init_iops_siimage - set up iops
* @hwif: interface to set up
* @hwif: interface to set up
...
@@ -980,9 +990,8 @@ static void __devinit init_iops_siimage(ide_hwif_t *hwif)
...
@@ -980,9 +990,8 @@ static void __devinit init_iops_siimage(ide_hwif_t *hwif)
hwif
->
hwif_data
=
NULL
;
hwif
->
hwif_data
=
NULL
;
hwif
->
rqsize
=
128
;
/* Pessimal until we finish probing */
if
(
is_sata
(
hwif
)
&&
is_dev_seagate_sata
(
&
hwif
->
drives
[
0
]))
hwif
->
rqsize
=
15
;
hwif
->
rqsize
=
15
;
if
(
pci_get_drvdata
(
dev
)
==
NULL
)
if
(
pci_get_drvdata
(
dev
)
==
NULL
)
return
;
return
;
...
@@ -1070,6 +1079,7 @@ static void __devinit init_hwif_siimage(ide_hwif_t *hwif)
...
@@ -1070,6 +1079,7 @@ static void __devinit init_hwif_siimage(ide_hwif_t *hwif)
.init_chipset = init_chipset_siimage, \
.init_chipset = init_chipset_siimage, \
.init_iops = init_iops_siimage, \
.init_iops = init_iops_siimage, \
.init_hwif = init_hwif_siimage, \
.init_hwif = init_hwif_siimage, \
.fixup = siimage_fixup, \
.channels = 2, \
.channels = 2, \
.autodma = AUTODMA, \
.autodma = AUTODMA, \
.bootable = ON_BOARD, \
.bootable = ON_BOARD, \
...
...
drivers/ide/setup-pci.c
View file @
b90f37ea
...
@@ -707,9 +707,9 @@ void ide_setup_pci_device (struct pci_dev *dev, ide_pci_device_t *d)
...
@@ -707,9 +707,9 @@ void ide_setup_pci_device (struct pci_dev *dev, ide_pci_device_t *d)
ata_index_t
index_list
=
do_ide_setup_pci_device
(
dev
,
d
,
1
);
ata_index_t
index_list
=
do_ide_setup_pci_device
(
dev
,
d
,
1
);
if
((
index_list
.
b
.
low
&
0xf0
)
!=
0xf0
)
if
((
index_list
.
b
.
low
&
0xf0
)
!=
0xf0
)
probe_hwif_init
(
&
ide_hwifs
[
index_list
.
b
.
low
]
);
probe_hwif_init
_with_fixup
(
&
ide_hwifs
[
index_list
.
b
.
low
],
d
->
fixup
);
if
((
index_list
.
b
.
high
&
0xf0
)
!=
0xf0
)
if
((
index_list
.
b
.
high
&
0xf0
)
!=
0xf0
)
probe_hwif_init
(
&
ide_hwifs
[
index_list
.
b
.
high
]
);
probe_hwif_init
_with_fixup
(
&
ide_hwifs
[
index_list
.
b
.
high
],
d
->
fixup
);
create_proc_ide_interfaces
();
create_proc_ide_interfaces
();
}
}
...
...
include/linux/ata.h
View file @
b90f37ea
...
@@ -33,8 +33,6 @@ enum {
...
@@ -33,8 +33,6 @@ enum {
ATA_MAX_DEVICES
=
2
,
/* per bus/port */
ATA_MAX_DEVICES
=
2
,
/* per bus/port */
ATA_MAX_PRD
=
256
,
/* we could make these 256/256 */
ATA_MAX_PRD
=
256
,
/* we could make these 256/256 */
ATA_SECT_SIZE
=
512
,
ATA_SECT_SIZE
=
512
,
ATA_SECT_SIZE_MASK
=
(
ATA_SECT_SIZE
-
1
),
ATA_SECT_DWORDS
=
ATA_SECT_SIZE
/
sizeof
(
u32
),
ATA_ID_WORDS
=
256
,
ATA_ID_WORDS
=
256
,
ATA_ID_PROD_OFS
=
27
,
ATA_ID_PROD_OFS
=
27
,
...
@@ -143,6 +141,12 @@ enum {
...
@@ -143,6 +141,12 @@ enum {
XFER_PIO_1
=
0x09
,
XFER_PIO_1
=
0x09
,
XFER_PIO_0
=
0x08
,
XFER_PIO_0
=
0x08
,
/* legacy IDE 'stuff' */
XFER_SW_DMA_2
=
0x12
,
XFER_SW_DMA_1
=
0x11
,
XFER_SW_DMA_0
=
0x10
,
XFER_PIO_SLOW
=
0x00
,
/* ATAPI stuff */
/* ATAPI stuff */
ATAPI_PKT_DMA
=
(
1
<<
0
),
ATAPI_PKT_DMA
=
(
1
<<
0
),
ATAPI_DMADIR
=
(
1
<<
2
),
/* ATAPI data dir:
ATAPI_DMADIR
=
(
1
<<
2
),
/* ATAPI data dir:
...
...
include/linux/hdreg.h
View file @
b90f37ea
#ifndef _LINUX_HDREG_H
#ifndef _LINUX_HDREG_H
#define _LINUX_HDREG_H
#define _LINUX_HDREG_H
#include <linux/ata.h>
/*
/*
* This file contains some defines for the AT-hd-controller.
* This file contains some defines for the AT-hd-controller.
* Various sources.
* Various sources.
...
@@ -328,27 +330,6 @@ typedef struct hd_drive_hob_hdr {
...
@@ -328,27 +330,6 @@ typedef struct hd_drive_hob_hdr {
/* WIN_SETFEATURES sub-commands */
/* WIN_SETFEATURES sub-commands */
#define SETFEATURES_EN_8BIT 0x01
/* Enable 8-Bit Transfers */
#define SETFEATURES_EN_8BIT 0x01
/* Enable 8-Bit Transfers */
#define SETFEATURES_EN_WCACHE 0x02
/* Enable write cache */
#define SETFEATURES_EN_WCACHE 0x02
/* Enable write cache */
#define SETFEATURES_XFER 0x03
/* Set transfer mode */
# define XFER_UDMA_7 0x47
/* 0100|0111 */
# define XFER_UDMA_6 0x46
/* 0100|0110 */
# define XFER_UDMA_5 0x45
/* 0100|0101 */
# define XFER_UDMA_4 0x44
/* 0100|0100 */
# define XFER_UDMA_3 0x43
/* 0100|0011 */
# define XFER_UDMA_2 0x42
/* 0100|0010 */
# define XFER_UDMA_1 0x41
/* 0100|0001 */
# define XFER_UDMA_0 0x40
/* 0100|0000 */
# define XFER_MW_DMA_2 0x22
/* 0010|0010 */
# define XFER_MW_DMA_1 0x21
/* 0010|0001 */
# define XFER_MW_DMA_0 0x20
/* 0010|0000 */
# define XFER_SW_DMA_2 0x12
/* 0001|0010 */
# define XFER_SW_DMA_1 0x11
/* 0001|0001 */
# define XFER_SW_DMA_0 0x10
/* 0001|0000 */
# define XFER_PIO_4 0x0C
/* 0000|1100 */
# define XFER_PIO_3 0x0B
/* 0000|1011 */
# define XFER_PIO_2 0x0A
/* 0000|1010 */
# define XFER_PIO_1 0x09
/* 0000|1001 */
# define XFER_PIO_0 0x08
/* 0000|1000 */
# define XFER_PIO_SLOW 0x00
/* 0000|0000 */
#define SETFEATURES_DIS_DEFECT 0x04
/* Disable Defect Management */
#define SETFEATURES_DIS_DEFECT 0x04
/* Disable Defect Management */
#define SETFEATURES_EN_APM 0x05
/* Enable advanced power management */
#define SETFEATURES_EN_APM 0x05
/* Enable advanced power management */
#define SETFEATURES_EN_SAME_R 0x22
/* for a region ATA-1 */
#define SETFEATURES_EN_SAME_R 0x22
/* for a region ATA-1 */
...
...
include/linux/ide.h
View file @
b90f37ea
...
@@ -39,7 +39,6 @@
...
@@ -39,7 +39,6 @@
*
*
* REALLY_SLOW_IO can be defined in ide.c and ide-cd.c, if necessary
* REALLY_SLOW_IO can be defined in ide.c and ide-cd.c, if necessary
*/
*/
#define REALLY_FAST_IO
/* define if ide ports are perfect */
#define INITIAL_MULT_COUNT 0
/* off=0; on=2,4,8,16,32, etc.. */
#define INITIAL_MULT_COUNT 0
/* off=0; on=2,4,8,16,32, etc.. */
#ifndef SUPPORT_SLOW_DATA_PORTS
/* 1 to support slow data ports */
#ifndef SUPPORT_SLOW_DATA_PORTS
/* 1 to support slow data ports */
...
@@ -63,18 +62,6 @@
...
@@ -63,18 +62,6 @@
#define IDE_NO_IRQ (-1)
#define IDE_NO_IRQ (-1)
/*
* IDE_DRIVE_CMD is used to implement many features of the hdparm utility
*/
#define IDE_DRIVE_CMD 99
/* (magic) undef to reduce kernel size*/
#define IDE_DRIVE_TASK 98
/*
* IDE_DRIVE_TASKFILE is used to implement many features needed for raw tasks
*/
#define IDE_DRIVE_TASKFILE 97
/*
/*
* "No user-serviceable parts" beyond this point :)
* "No user-serviceable parts" beyond this point :)
*****************************************************************************/
*****************************************************************************/
...
@@ -101,13 +88,6 @@ typedef unsigned char byte; /* used everywhere */
...
@@ -101,13 +88,6 @@ typedef unsigned char byte; /* used everywhere */
#define DMA_PIO_RETRY 1
/* retrying in PIO */
#define DMA_PIO_RETRY 1
/* retrying in PIO */
/*
* Ensure that various configuration flags have compatible settings
*/
#ifdef REALLY_SLOW_IO
#undef REALLY_FAST_IO
#endif
#define HWIF(drive) ((ide_hwif_t *)((drive)->hwif))
#define HWIF(drive) ((ide_hwif_t *)((drive)->hwif))
#define HWGROUP(drive) ((ide_hwgroup_t *)(HWIF(drive)->hwgroup))
#define HWGROUP(drive) ((ide_hwgroup_t *)(HWIF(drive)->hwgroup))
...
@@ -197,10 +177,7 @@ typedef unsigned char byte; /* used everywhere */
...
@@ -197,10 +177,7 @@ typedef unsigned char byte; /* used everywhere */
/*
/*
* Some more useful definitions
* Some more useful definitions
*/
*/
#define IDE_MAJOR_NAME "hd"
/* the same for all i/f; see also genhd.c */
#define MAJOR_NAME IDE_MAJOR_NAME
#define PARTN_BITS 6
/* number of minor dev bits for partitions */
#define PARTN_BITS 6
/* number of minor dev bits for partitions */
#define PARTN_MASK ((1<<PARTN_BITS)-1)
/* a useful bit mask */
#define MAX_DRIVES 2
/* per interface; 2 assumed by lots of code */
#define MAX_DRIVES 2
/* per interface; 2 assumed by lots of code */
#define SECTOR_SIZE 512
#define SECTOR_SIZE 512
#define SECTOR_WORDS (SECTOR_SIZE / 4)
/* number of 32bit words per sector */
#define SECTOR_WORDS (SECTOR_SIZE / 4)
/* number of 32bit words per sector */
...
@@ -256,16 +233,14 @@ typedef struct hw_regs_s {
...
@@ -256,16 +233,14 @@ typedef struct hw_regs_s {
int
irq
;
/* our irq number */
int
irq
;
/* our irq number */
int
dma
;
/* our dma entry */
int
dma
;
/* our dma entry */
ide_ack_intr_t
*
ack_intr
;
/* acknowledge interrupt */
ide_ack_intr_t
*
ack_intr
;
/* acknowledge interrupt */
void
*
priv
;
/* interface specific data */
hwif_chipset_t
chipset
;
hwif_chipset_t
chipset
;
unsigned
long
sata_scr
[
SATA_NR_PORTS
];
unsigned
long
sata_misc
[
SATA_NR_PORTS
];
}
hw_regs_t
;
}
hw_regs_t
;
/*
/*
* Register new hardware with ide
* Register new hardware with ide
*/
*/
int
ide_register_hw
(
hw_regs_t
*
hw
,
struct
hwif_s
**
hwifp
);
int
ide_register_hw
(
hw_regs_t
*
hw
,
struct
hwif_s
**
hwifp
);
int
ide_register_hw_with_fixup
(
hw_regs_t
*
,
struct
hwif_s
**
,
void
(
*
)(
struct
hwif_s
*
));
/*
/*
* Set up hw_regs_t structure before calling ide_register_hw (optional)
* Set up hw_regs_t structure before calling ide_register_hw (optional)
...
@@ -1453,6 +1428,7 @@ typedef struct ide_pci_device_s {
...
@@ -1453,6 +1428,7 @@ typedef struct ide_pci_device_s {
void
(
*
init_iops
)(
ide_hwif_t
*
);
void
(
*
init_iops
)(
ide_hwif_t
*
);
void
(
*
init_hwif
)(
ide_hwif_t
*
);
void
(
*
init_hwif
)(
ide_hwif_t
*
);
void
(
*
init_dma
)(
ide_hwif_t
*
,
unsigned
long
);
void
(
*
init_dma
)(
ide_hwif_t
*
,
unsigned
long
);
void
(
*
fixup
)(
ide_hwif_t
*
);
u8
channels
;
u8
channels
;
u8
autodma
;
u8
autodma
;
ide_pci_enablebit_t
enablebits
[
2
];
ide_pci_enablebit_t
enablebits
[
2
];
...
@@ -1513,6 +1489,9 @@ extern int ide_hwif_request_regions(ide_hwif_t *hwif);
...
@@ -1513,6 +1489,9 @@ extern int ide_hwif_request_regions(ide_hwif_t *hwif);
extern
void
ide_hwif_release_regions
(
ide_hwif_t
*
hwif
);
extern
void
ide_hwif_release_regions
(
ide_hwif_t
*
hwif
);
extern
void
ide_unregister
(
unsigned
int
index
);
extern
void
ide_unregister
(
unsigned
int
index
);
void
ide_undecoded_slave
(
ide_hwif_t
*
);
int
probe_hwif_init_with_fixup
(
ide_hwif_t
*
,
void
(
*
)(
ide_hwif_t
*
));
extern
int
probe_hwif_init
(
ide_hwif_t
*
);
extern
int
probe_hwif_init
(
ide_hwif_t
*
);
static
inline
void
*
ide_get_hwifdata
(
ide_hwif_t
*
hwif
)
static
inline
void
*
ide_get_hwifdata
(
ide_hwif_t
*
hwif
)
...
...
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