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
b20e4ab5
Commit
b20e4ab5
authored
Nov 25, 2002
by
Alan Cox
Committed by
Linus Torvalds
Nov 25, 2002
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] clean up promise IDE, ifdefs, unused code etc
parent
e70156eb
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
5 additions
and
90 deletions
+5
-90
drivers/ide/pci/pdc202xx_new.c
drivers/ide/pci/pdc202xx_new.c
+1
-29
drivers/ide/pci/pdc202xx_new.h
drivers/ide/pci/pdc202xx_new.h
+0
-35
drivers/ide/pci/pdc202xx_old.c
drivers/ide/pci/pdc202xx_old.c
+4
-26
No files found.
drivers/ide/pci/pdc202xx_new.c
View file @
b20e4ab5
...
@@ -165,7 +165,6 @@ static int pdcnew_tune_chipset (ide_drive_t *drive, u8 xferspeed)
...
@@ -165,7 +165,6 @@ static int pdcnew_tune_chipset (ide_drive_t *drive, u8 xferspeed)
pci_read_config_byte
(
dev
,
(
drive_pci
),
&
AP
);
pci_read_config_byte
(
dev
,
(
drive_pci
),
&
AP
);
pci_read_config_byte
(
dev
,
(
drive_pci
)
|
0x01
,
&
BP
);
pci_read_config_byte
(
dev
,
(
drive_pci
)
|
0x01
,
&
BP
);
}
}
#ifdef CONFIG_BLK_DEV_IDEDMA
}
else
{
}
else
{
if
((
BP
&
0xF0
)
&&
(
CP
&
0x0F
))
{
if
((
BP
&
0xF0
)
&&
(
CP
&
0x0F
))
{
/* clear DMA modes of upper 842 bits of B Register */
/* clear DMA modes of upper 842 bits of B Register */
...
@@ -177,7 +176,6 @@ static int pdcnew_tune_chipset (ide_drive_t *drive, u8 xferspeed)
...
@@ -177,7 +176,6 @@ static int pdcnew_tune_chipset (ide_drive_t *drive, u8 xferspeed)
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
CP
&~
0x0F
);
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
CP
&~
0x0F
);
pci_read_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
&
CP
);
pci_read_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
&
CP
);
}
}
#endif
/* CONFIG_BLK_DEV_IDEDMA */
}
}
pci_read_config_byte
(
dev
,
(
drive_pci
),
&
AP
);
pci_read_config_byte
(
dev
,
(
drive_pci
),
&
AP
);
...
@@ -185,7 +183,6 @@ static int pdcnew_tune_chipset (ide_drive_t *drive, u8 xferspeed)
...
@@ -185,7 +183,6 @@ static int pdcnew_tune_chipset (ide_drive_t *drive, u8 xferspeed)
pci_read_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
&
CP
);
pci_read_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
&
CP
);
switch
(
speed
)
{
switch
(
speed
)
{
#ifdef CONFIG_BLK_DEV_IDEDMA
case
XFER_UDMA_6
:
speed
=
XFER_UDMA_5
;
case
XFER_UDMA_6
:
speed
=
XFER_UDMA_5
;
case
XFER_UDMA_5
:
case
XFER_UDMA_5
:
case
XFER_UDMA_4
:
TB
=
0x20
;
TC
=
0x01
;
break
;
case
XFER_UDMA_4
:
TB
=
0x20
;
TC
=
0x01
;
break
;
...
@@ -199,7 +196,6 @@ static int pdcnew_tune_chipset (ide_drive_t *drive, u8 xferspeed)
...
@@ -199,7 +196,6 @@ static int pdcnew_tune_chipset (ide_drive_t *drive, u8 xferspeed)
case
XFER_SW_DMA_2
:
TB
=
0x60
;
TC
=
0x05
;
break
;
case
XFER_SW_DMA_2
:
TB
=
0x60
;
TC
=
0x05
;
break
;
case
XFER_SW_DMA_1
:
TB
=
0x80
;
TC
=
0x06
;
break
;
case
XFER_SW_DMA_1
:
TB
=
0x80
;
TC
=
0x06
;
break
;
case
XFER_SW_DMA_0
:
TB
=
0xC0
;
TC
=
0x0B
;
break
;
case
XFER_SW_DMA_0
:
TB
=
0xC0
;
TC
=
0x0B
;
break
;
#endif
/* CONFIG_BLK_DEV_IDEDMA */
case
XFER_PIO_4
:
TA
=
0x01
;
TB
=
0x04
;
break
;
case
XFER_PIO_4
:
TA
=
0x01
;
TB
=
0x04
;
break
;
case
XFER_PIO_3
:
TA
=
0x02
;
TB
=
0x06
;
break
;
case
XFER_PIO_3
:
TA
=
0x02
;
TB
=
0x06
;
break
;
case
XFER_PIO_2
:
TA
=
0x03
;
TB
=
0x08
;
break
;
case
XFER_PIO_2
:
TA
=
0x03
;
TB
=
0x08
;
break
;
...
@@ -211,11 +207,9 @@ static int pdcnew_tune_chipset (ide_drive_t *drive, u8 xferspeed)
...
@@ -211,11 +207,9 @@ static int pdcnew_tune_chipset (ide_drive_t *drive, u8 xferspeed)
if
(
speed
<
XFER_SW_DMA_0
)
{
if
(
speed
<
XFER_SW_DMA_0
)
{
pci_write_config_byte
(
dev
,
(
drive_pci
),
AP
|
TA
);
pci_write_config_byte
(
dev
,
(
drive_pci
),
AP
|
TA
);
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x01
,
BP
|
TB
);
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x01
,
BP
|
TB
);
#ifdef CONFIG_BLK_DEV_IDEDMA
}
else
{
}
else
{
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x01
,
BP
|
TB
);
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x01
,
BP
|
TB
);
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
CP
|
TC
);
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
CP
|
TC
);
#endif
/* CONFIG_BLK_DEV_IDEDMA */
}
}
#if PDC202XX_DECODE_REGISTER_INFO
#if PDC202XX_DECODE_REGISTER_INFO
...
@@ -243,28 +237,18 @@ static int pdcnew_tune_chipset (ide_drive_t *drive, u8 xferspeed)
...
@@ -243,28 +237,18 @@ static int pdcnew_tune_chipset (ide_drive_t *drive, u8 xferspeed)
static
int
pdcnew_new_tune_chipset
(
ide_drive_t
*
drive
,
u8
xferspeed
)
static
int
pdcnew_new_tune_chipset
(
ide_drive_t
*
drive
,
u8
xferspeed
)
{
{
ide_hwif_t
*
hwif
=
HWIF
(
drive
);
ide_hwif_t
*
hwif
=
HWIF
(
drive
);
#ifdef CONFIG_BLK_DEV_IDEDMA
u32
indexreg
=
hwif
->
dma_vendor1
;
u32
indexreg
=
hwif
->
dma_vendor1
;
u32
datareg
=
hwif
->
dma_vendor3
;
u32
datareg
=
hwif
->
dma_vendor3
;
#else
/* !CONFIG_BLK_DEV_IDEDMA */
struct
pci_dev
*
dev
=
hwif
->
pci_dev
;
u32
high_16
=
pci_resource_start
(
dev
,
4
);
u32
indexreg
=
high_16
+
(
hwif
->
channel
?
0x09
:
0x01
);
u32
datareg
=
(
indexreg
+
2
);
#endif
/* CONFIG_BLK_DEV_IDEDMA */
u8
thold
=
0x10
;
u8
thold
=
0x10
;
u8
adj
=
(
drive
->
dn
%
2
)
?
0x08
:
0x00
;
u8
adj
=
(
drive
->
dn
%
2
)
?
0x08
:
0x00
;
u8
speed
=
ide_rate_filter
(
pdcnew_ratemask
(
drive
),
xferspeed
);
u8
speed
=
ide_rate_filter
(
pdcnew_ratemask
(
drive
),
xferspeed
);
#ifdef CONFIG_BLK_DEV_IDEDMA
if
(
speed
==
XFER_UDMA_2
)
{
if
(
speed
==
XFER_UDMA_2
)
{
hwif
->
OUTB
((
thold
+
adj
),
indexreg
);
hwif
->
OUTB
((
thold
+
adj
),
indexreg
);
hwif
->
OUTB
((
hwif
->
INB
(
datareg
)
&
0x7f
),
datareg
);
hwif
->
OUTB
((
hwif
->
INB
(
datareg
)
&
0x7f
),
datareg
);
}
}
#endif
/* CONFIG_BLK_DEV_IDEDMA */
switch
(
speed
)
{
switch
(
speed
)
{
#ifdef CONFIG_BLK_DEV_IDEDMA
case
XFER_UDMA_7
:
case
XFER_UDMA_7
:
speed
=
XFER_UDMA_6
;
speed
=
XFER_UDMA_6
;
case
XFER_UDMA_6
:
set_ultra
(
0x1a
,
0x01
,
0xcb
);
break
;
case
XFER_UDMA_6
:
set_ultra
(
0x1a
,
0x01
,
0xcb
);
break
;
...
@@ -277,7 +261,6 @@ static int pdcnew_new_tune_chipset (ide_drive_t *drive, u8 xferspeed)
...
@@ -277,7 +261,6 @@ static int pdcnew_new_tune_chipset (ide_drive_t *drive, u8 xferspeed)
case
XFER_MW_DMA_2
:
set_ata2
(
0x69
,
0x25
);
break
;
case
XFER_MW_DMA_2
:
set_ata2
(
0x69
,
0x25
);
break
;
case
XFER_MW_DMA_1
:
set_ata2
(
0x6b
,
0x27
);
break
;
case
XFER_MW_DMA_1
:
set_ata2
(
0x6b
,
0x27
);
break
;
case
XFER_MW_DMA_0
:
set_ata2
(
0xdf
,
0x5f
);
break
;
case
XFER_MW_DMA_0
:
set_ata2
(
0xdf
,
0x5f
);
break
;
#endif
/* CONFIG_BLK_DEV_IDEDMA */
case
XFER_PIO_4
:
set_pio
(
0x23
,
0x09
,
0x25
);
break
;
case
XFER_PIO_4
:
set_pio
(
0x23
,
0x09
,
0x25
);
break
;
case
XFER_PIO_3
:
set_pio
(
0x27
,
0x0d
,
0x35
);
break
;
case
XFER_PIO_3
:
set_pio
(
0x27
,
0x0d
,
0x35
);
break
;
case
XFER_PIO_2
:
set_pio
(
0x23
,
0x26
,
0x64
);
break
;
case
XFER_PIO_2
:
set_pio
(
0x23
,
0x26
,
0x64
);
break
;
...
@@ -301,7 +284,7 @@ static int config_chipset_for_pio (ide_drive_t *drive, u8 pio)
...
@@ -301,7 +284,7 @@ static int config_chipset_for_pio (ide_drive_t *drive, u8 pio)
{
{
u8
speed
=
0
;
u8
speed
=
0
;
pio
=
(
pio
==
5
)
?
4
:
pio
;
if
(
pio
==
5
)
pio
=
4
;
speed
=
XFER_PIO_0
+
ide_get_best_pio_mode
(
drive
,
255
,
pio
,
NULL
);
speed
=
XFER_PIO_0
+
ide_get_best_pio_mode
(
drive
,
255
,
pio
,
NULL
);
return
((
int
)
pdcnew_tune_chipset
(
drive
,
speed
));
return
((
int
)
pdcnew_tune_chipset
(
drive
,
speed
));
...
@@ -312,8 +295,6 @@ static void pdcnew_tune_drive (ide_drive_t *drive, u8 pio)
...
@@ -312,8 +295,6 @@ static void pdcnew_tune_drive (ide_drive_t *drive, u8 pio)
(
void
)
config_chipset_for_pio
(
drive
,
pio
);
(
void
)
config_chipset_for_pio
(
drive
,
pio
);
}
}
#ifdef CONFIG_BLK_DEV_IDEDMA
static
u8
pdcnew_new_cable_detect
(
ide_hwif_t
*
hwif
)
static
u8
pdcnew_new_cable_detect
(
ide_hwif_t
*
hwif
)
{
{
hwif
->
OUTB
(
0x0b
,
hwif
->
dma_vendor1
);
hwif
->
OUTB
(
0x0b
,
hwif
->
dma_vendor1
);
...
@@ -458,8 +439,6 @@ static int pdcnew_ide_dma_timeout(ide_drive_t *drive)
...
@@ -458,8 +439,6 @@ static int pdcnew_ide_dma_timeout(ide_drive_t *drive)
return
__ide_dma_timeout
(
drive
);
return
__ide_dma_timeout
(
drive
);
}
}
#endif
/* CONFIG_BLK_DEV_IDEDMA */
static
void
pdcnew_new_reset
(
ide_drive_t
*
drive
)
static
void
pdcnew_new_reset
(
ide_drive_t
*
drive
)
{
{
/*
/*
...
@@ -471,12 +450,8 @@ static void pdcnew_new_reset (ide_drive_t *drive)
...
@@ -471,12 +450,8 @@ static void pdcnew_new_reset (ide_drive_t *drive)
static
void
pdcnew_reset_host
(
ide_hwif_t
*
hwif
)
static
void
pdcnew_reset_host
(
ide_hwif_t
*
hwif
)
{
{
#ifdef CONFIG_BLK_DEV_IDEDMA
// unsigned long high_16 = hwif->dma_base - (8*(hwif->channel));
// unsigned long high_16 = hwif->dma_base - (8*(hwif->channel));
unsigned
long
high_16
=
hwif
->
dma_master
;
unsigned
long
high_16
=
hwif
->
dma_master
;
#else
/* !CONFIG_BLK_DEV_IDEDMA */
unsigned
long
high_16
=
pci_resource_start
(
hwif
->
pci_dev
,
4
);
#endif
/* CONFIG_BLK_DEV_IDEDMA */
u8
udma_speed_flag
=
hwif
->
INB
(
high_16
|
0x001f
);
u8
udma_speed_flag
=
hwif
->
INB
(
high_16
|
0x001f
);
hwif
->
OUTB
((
udma_speed_flag
|
0x10
),
(
high_16
|
0x001f
));
hwif
->
OUTB
((
udma_speed_flag
|
0x10
),
(
high_16
|
0x001f
));
...
@@ -571,8 +546,6 @@ static void __init init_hwif_pdc202new (ide_hwif_t *hwif)
...
@@ -571,8 +546,6 @@ static void __init init_hwif_pdc202new (ide_hwif_t *hwif)
hwif
->
ultra_mask
=
0x7f
;
hwif
->
ultra_mask
=
0x7f
;
hwif
->
mwdma_mask
=
0x07
;
hwif
->
mwdma_mask
=
0x07
;
#ifdef CONFIG_BLK_DEV_IDEDMA
hwif
->
ide_dma_check
=
&
pdcnew_config_drive_xfer_rate
;
hwif
->
ide_dma_check
=
&
pdcnew_config_drive_xfer_rate
;
hwif
->
ide_dma_lostirq
=
&
pdcnew_ide_dma_lostirq
;
hwif
->
ide_dma_lostirq
=
&
pdcnew_ide_dma_lostirq
;
hwif
->
ide_dma_timeout
=
&
pdcnew_ide_dma_timeout
;
hwif
->
ide_dma_timeout
=
&
pdcnew_ide_dma_timeout
;
...
@@ -581,7 +554,6 @@ static void __init init_hwif_pdc202new (ide_hwif_t *hwif)
...
@@ -581,7 +554,6 @@ static void __init init_hwif_pdc202new (ide_hwif_t *hwif)
if
(
!
noautodma
)
if
(
!
noautodma
)
hwif
->
autodma
=
1
;
hwif
->
autodma
=
1
;
hwif
->
drives
[
0
].
autodma
=
hwif
->
drives
[
1
].
autodma
=
hwif
->
autodma
;
hwif
->
drives
[
0
].
autodma
=
hwif
->
drives
[
1
].
autodma
=
hwif
->
autodma
;
#endif
/* CONFIG_BLK_DEV_IDEDMA */
#if PDC202_DEBUG_CABLE
#if PDC202_DEBUG_CABLE
printk
(
"%s: %s-pin cable
\n
"
,
printk
(
"%s: %s-pin cable
\n
"
,
hwif
->
name
,
hwif
->
udma_four
?
"80"
:
"40"
);
hwif
->
name
,
hwif
->
udma_four
?
"80"
:
"40"
);
...
...
drivers/ide/pci/pdc202xx_new.h
View file @
b20e4ab5
...
@@ -26,41 +26,6 @@ const static char *pdc_quirk_drives[] = {
...
@@ -26,41 +26,6 @@ const static char *pdc_quirk_drives[] = {
NULL
NULL
};
};
static
inline
u8
*
pdcnew_pio_verbose
(
u32
drive_pci
)
{
if
((
drive_pci
&
0x000ff000
)
==
0x000ff000
)
return
(
"NOTSET"
);
if
((
drive_pci
&
0x00000401
)
==
0x00000401
)
return
(
"PIO 4"
);
if
((
drive_pci
&
0x00000602
)
==
0x00000602
)
return
(
"PIO 3"
);
if
((
drive_pci
&
0x00000803
)
==
0x00000803
)
return
(
"PIO 2"
);
if
((
drive_pci
&
0x00000C05
)
==
0x00000C05
)
return
(
"PIO 1"
);
if
((
drive_pci
&
0x00001309
)
==
0x00001309
)
return
(
"PIO 0"
);
return
(
"PIO ?"
);
}
static
inline
u8
*
pdcnew_dma_verbose
(
u32
drive_pci
)
{
if
((
drive_pci
&
0x00036000
)
==
0x00036000
)
return
(
"MWDMA 2"
);
if
((
drive_pci
&
0x00046000
)
==
0x00046000
)
return
(
"MWDMA 1"
);
if
((
drive_pci
&
0x00056000
)
==
0x00056000
)
return
(
"MWDMA 0"
);
if
((
drive_pci
&
0x00056000
)
==
0x00056000
)
return
(
"SWDMA 2"
);
if
((
drive_pci
&
0x00068000
)
==
0x00068000
)
return
(
"SWDMA 1"
);
if
((
drive_pci
&
0x000BC000
)
==
0x000BC000
)
return
(
"SWDMA 0"
);
return
(
"PIO---"
);
}
static
inline
u8
*
pdcnew_ultra_verbose
(
u32
drive_pci
,
u16
slow_cable
)
{
if
((
drive_pci
&
0x000ff000
)
==
0x000ff000
)
return
(
"NOTSET"
);
if
((
drive_pci
&
0x00012000
)
==
0x00012000
)
return
((
slow_cable
)
?
"UDMA 2"
:
"UDMA 4"
);
if
((
drive_pci
&
0x00024000
)
==
0x00024000
)
return
((
slow_cable
)
?
"UDMA 1"
:
"UDMA 3"
);
if
((
drive_pci
&
0x00036000
)
==
0x00036000
)
return
(
"UDMA 0"
);
return
(
pdcnew_dma_verbose
(
drive_pci
));
}
/* A Register */
/* A Register */
#define SYNC_ERRDY_EN 0xC0
#define SYNC_ERRDY_EN 0xC0
...
...
drivers/ide/pci/pdc202xx_old.c
View file @
b20e4ab5
...
@@ -264,7 +264,6 @@ static int pdc202xx_tune_chipset (ide_drive_t *drive, u8 xferspeed)
...
@@ -264,7 +264,6 @@ static int pdc202xx_tune_chipset (ide_drive_t *drive, u8 xferspeed)
pci_read_config_byte
(
dev
,
(
drive_pci
),
&
AP
);
pci_read_config_byte
(
dev
,
(
drive_pci
),
&
AP
);
pci_read_config_byte
(
dev
,
(
drive_pci
)
|
0x01
,
&
BP
);
pci_read_config_byte
(
dev
,
(
drive_pci
)
|
0x01
,
&
BP
);
}
}
#ifdef CONFIG_BLK_DEV_IDEDMA
}
else
{
}
else
{
if
((
BP
&
0xF0
)
&&
(
CP
&
0x0F
))
{
if
((
BP
&
0xF0
)
&&
(
CP
&
0x0F
))
{
/* clear DMA modes of upper 842 bits of B Register */
/* clear DMA modes of upper 842 bits of B Register */
...
@@ -276,7 +275,6 @@ static int pdc202xx_tune_chipset (ide_drive_t *drive, u8 xferspeed)
...
@@ -276,7 +275,6 @@ static int pdc202xx_tune_chipset (ide_drive_t *drive, u8 xferspeed)
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
CP
&~
0x0F
);
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
CP
&~
0x0F
);
pci_read_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
&
CP
);
pci_read_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
&
CP
);
}
}
#endif
/* CONFIG_BLK_DEV_IDEDMA */
}
}
pci_read_config_byte
(
dev
,
(
drive_pci
),
&
AP
);
pci_read_config_byte
(
dev
,
(
drive_pci
),
&
AP
);
...
@@ -284,7 +282,6 @@ static int pdc202xx_tune_chipset (ide_drive_t *drive, u8 xferspeed)
...
@@ -284,7 +282,6 @@ static int pdc202xx_tune_chipset (ide_drive_t *drive, u8 xferspeed)
pci_read_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
&
CP
);
pci_read_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
&
CP
);
switch
(
speed
)
{
switch
(
speed
)
{
#ifdef CONFIG_BLK_DEV_IDEDMA
case
XFER_UDMA_6
:
speed
=
XFER_UDMA_5
;
case
XFER_UDMA_6
:
speed
=
XFER_UDMA_5
;
case
XFER_UDMA_5
:
case
XFER_UDMA_5
:
case
XFER_UDMA_4
:
TB
=
0x20
;
TC
=
0x01
;
break
;
case
XFER_UDMA_4
:
TB
=
0x20
;
TC
=
0x01
;
break
;
...
@@ -298,7 +295,6 @@ static int pdc202xx_tune_chipset (ide_drive_t *drive, u8 xferspeed)
...
@@ -298,7 +295,6 @@ static int pdc202xx_tune_chipset (ide_drive_t *drive, u8 xferspeed)
case
XFER_SW_DMA_2
:
TB
=
0x60
;
TC
=
0x05
;
break
;
case
XFER_SW_DMA_2
:
TB
=
0x60
;
TC
=
0x05
;
break
;
case
XFER_SW_DMA_1
:
TB
=
0x80
;
TC
=
0x06
;
break
;
case
XFER_SW_DMA_1
:
TB
=
0x80
;
TC
=
0x06
;
break
;
case
XFER_SW_DMA_0
:
TB
=
0xC0
;
TC
=
0x0B
;
break
;
case
XFER_SW_DMA_0
:
TB
=
0xC0
;
TC
=
0x0B
;
break
;
#endif
/* CONFIG_BLK_DEV_IDEDMA */
case
XFER_PIO_4
:
TA
=
0x01
;
TB
=
0x04
;
break
;
case
XFER_PIO_4
:
TA
=
0x01
;
TB
=
0x04
;
break
;
case
XFER_PIO_3
:
TA
=
0x02
;
TB
=
0x06
;
break
;
case
XFER_PIO_3
:
TA
=
0x02
;
TB
=
0x06
;
break
;
case
XFER_PIO_2
:
TA
=
0x03
;
TB
=
0x08
;
break
;
case
XFER_PIO_2
:
TA
=
0x03
;
TB
=
0x08
;
break
;
...
@@ -310,11 +306,9 @@ static int pdc202xx_tune_chipset (ide_drive_t *drive, u8 xferspeed)
...
@@ -310,11 +306,9 @@ static int pdc202xx_tune_chipset (ide_drive_t *drive, u8 xferspeed)
if
(
speed
<
XFER_SW_DMA_0
)
{
if
(
speed
<
XFER_SW_DMA_0
)
{
pci_write_config_byte
(
dev
,
(
drive_pci
),
AP
|
TA
);
pci_write_config_byte
(
dev
,
(
drive_pci
),
AP
|
TA
);
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x01
,
BP
|
TB
);
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x01
,
BP
|
TB
);
#ifdef CONFIG_BLK_DEV_IDEDMA
}
else
{
}
else
{
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x01
,
BP
|
TB
);
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x01
,
BP
|
TB
);
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
CP
|
TC
);
pci_write_config_byte
(
dev
,
(
drive_pci
)
|
0x02
,
CP
|
TC
);
#endif
/* CONFIG_BLK_DEV_IDEDMA */
}
}
#if PDC202XX_DECODE_REGISTER_INFO
#if PDC202XX_DECODE_REGISTER_INFO
...
@@ -347,23 +341,16 @@ static int pdc202xx_tune_chipset (ide_drive_t *drive, u8 xferspeed)
...
@@ -347,23 +341,16 @@ static int pdc202xx_tune_chipset (ide_drive_t *drive, u8 xferspeed)
* 180, 120, 90, 90, 90, 60, 30
* 180, 120, 90, 90, 90, 60, 30
* 11, 5, 4, 3, 2, 1, 0
* 11, 5, 4, 3, 2, 1, 0
*/
*/
static
int
config_chipset_for_pio
(
ide_drive_t
*
drive
,
u8
pio
)
static
void
config_chipset_for_pio
(
ide_drive_t
*
drive
,
u8
pio
)
{
{
u8
speed
=
0
;
u8
speed
=
0
;
pio
=
(
pio
==
5
)
?
4
:
pio
;
if
(
pio
==
5
)
pio
=
4
;
speed
=
XFER_PIO_0
+
ide_get_best_pio_mode
(
drive
,
255
,
pio
,
NULL
);
speed
=
XFER_PIO_0
+
ide_get_best_pio_mode
(
drive
,
255
,
pio
,
NULL
);
return
((
int
)
pdc202xx_tune_chipset
(
drive
,
speed
)
);
pdc202xx_tune_chipset
(
drive
,
speed
);
}
}
static
void
pdc202xx_tune_drive
(
ide_drive_t
*
drive
,
u8
pio
)
{
(
void
)
config_chipset_for_pio
(
drive
,
pio
);
}
#ifdef CONFIG_BLK_DEV_IDEDMA
static
u8
pdc202xx_old_cable_detect
(
ide_hwif_t
*
hwif
)
static
u8
pdc202xx_old_cable_detect
(
ide_hwif_t
*
hwif
)
{
{
u16
CIS
=
0
,
mask
=
(
hwif
->
channel
)
?
(
1
<<
11
)
:
(
1
<<
10
);
u16
CIS
=
0
,
mask
=
(
hwif
->
channel
)
?
(
1
<<
11
)
:
(
1
<<
10
);
...
@@ -618,8 +605,6 @@ static int pdc202xx_ide_dma_timeout(ide_drive_t *drive)
...
@@ -618,8 +605,6 @@ static int pdc202xx_ide_dma_timeout(ide_drive_t *drive)
return
__ide_dma_timeout
(
drive
);
return
__ide_dma_timeout
(
drive
);
}
}
#endif
/* CONFIG_BLK_DEV_IDEDMA */
static
void
pdc202xx_reset_host
(
ide_hwif_t
*
hwif
)
static
void
pdc202xx_reset_host
(
ide_hwif_t
*
hwif
)
{
{
#ifdef CONFIG_BLK_DEV_IDEDMA
#ifdef CONFIG_BLK_DEV_IDEDMA
...
@@ -692,12 +677,8 @@ void pdc202xx_reset (ide_drive_t *drive)
...
@@ -692,12 +677,8 @@ void pdc202xx_reset (ide_drive_t *drive)
static
int
pdc202xx_tristate
(
ide_drive_t
*
drive
,
int
state
)
static
int
pdc202xx_tristate
(
ide_drive_t
*
drive
,
int
state
)
{
{
ide_hwif_t
*
hwif
=
HWIF
(
drive
);
ide_hwif_t
*
hwif
=
HWIF
(
drive
);
#ifdef CONFIG_BLK_DEV_IDEDMA
// unsigned long high_16 = hwif->dma_base - (8*(hwif->channel));
// unsigned long high_16 = hwif->dma_base - (8*(hwif->channel));
unsigned
long
high_16
=
hwif
->
dma_master
;
unsigned
long
high_16
=
hwif
->
dma_master
;
#else
/* !CONFIG_BLK_DEV_IDEDMA */
unsigned
long
high_16
=
pci_resource_start
(
hwif
->
pci_dev
,
4
);
#endif
/* CONFIG_BLK_DEV_IDEDMA */
u8
sc1f
=
hwif
->
INB
(
high_16
|
0x001f
);
u8
sc1f
=
hwif
->
INB
(
high_16
|
0x001f
);
if
(
!
hwif
)
if
(
!
hwif
)
...
@@ -761,7 +742,7 @@ static unsigned int __init init_chipset_pdc202xx (struct pci_dev *dev, const cha
...
@@ -761,7 +742,7 @@ static unsigned int __init init_chipset_pdc202xx (struct pci_dev *dev, const cha
static
void
__init
init_hwif_pdc202xx
(
ide_hwif_t
*
hwif
)
static
void
__init
init_hwif_pdc202xx
(
ide_hwif_t
*
hwif
)
{
{
hwif
->
autodma
=
0
;
hwif
->
autodma
=
0
;
hwif
->
tuneproc
=
&
pdc202xx_tune_drive
;
hwif
->
tuneproc
=
&
config_chipset_for_pio
;
hwif
->
quirkproc
=
&
pdc202xx_quirkproc
;
hwif
->
quirkproc
=
&
pdc202xx_quirkproc
;
if
(
hwif
->
pci_dev
->
device
==
PCI_DEVICE_ID_PROMISE_20265
)
if
(
hwif
->
pci_dev
->
device
==
PCI_DEVICE_ID_PROMISE_20265
)
...
@@ -783,8 +764,6 @@ static void __init init_hwif_pdc202xx (ide_hwif_t *hwif)
...
@@ -783,8 +764,6 @@ static void __init init_hwif_pdc202xx (ide_hwif_t *hwif)
hwif
->
mwdma_mask
=
0x07
;
hwif
->
mwdma_mask
=
0x07
;
hwif
->
swdma_mask
=
0x07
;
hwif
->
swdma_mask
=
0x07
;
#ifdef CONFIG_BLK_DEV_IDEDMA
hwif
->
ide_dma_check
=
&
pdc202xx_config_drive_xfer_rate
;
hwif
->
ide_dma_check
=
&
pdc202xx_config_drive_xfer_rate
;
hwif
->
ide_dma_lostirq
=
&
pdc202xx_ide_dma_lostirq
;
hwif
->
ide_dma_lostirq
=
&
pdc202xx_ide_dma_lostirq
;
hwif
->
ide_dma_timeout
=
&
pdc202xx_ide_dma_timeout
;
hwif
->
ide_dma_timeout
=
&
pdc202xx_ide_dma_timeout
;
...
@@ -800,7 +779,6 @@ static void __init init_hwif_pdc202xx (ide_hwif_t *hwif)
...
@@ -800,7 +779,6 @@ static void __init init_hwif_pdc202xx (ide_hwif_t *hwif)
if
(
!
noautodma
)
if
(
!
noautodma
)
hwif
->
autodma
=
1
;
hwif
->
autodma
=
1
;
hwif
->
drives
[
0
].
autodma
=
hwif
->
drives
[
1
].
autodma
=
hwif
->
autodma
;
hwif
->
drives
[
0
].
autodma
=
hwif
->
drives
[
1
].
autodma
=
hwif
->
autodma
;
#endif
/* CONFIG_BLK_DEV_IDEDMA */
#if PDC202_DEBUG_CABLE
#if PDC202_DEBUG_CABLE
printk
(
"%s: %s-pin cable
\n
"
,
printk
(
"%s: %s-pin cable
\n
"
,
hwif
->
name
,
hwif
->
udma_four
?
"80"
:
"40"
);
hwif
->
name
,
hwif
->
udma_four
?
"80"
:
"40"
);
...
...
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