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
5023a3cb
Commit
5023a3cb
authored
Sep 11, 2002
by
Jens Axboe
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
new pci init code
parent
edc5903b
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
948 additions
and
992 deletions
+948
-992
drivers/ide/ide-pci.c
drivers/ide/ide-pci.c
+0
-992
drivers/ide/setup-pci.c
drivers/ide/setup-pci.c
+948
-0
No files found.
drivers/ide/ide-pci.c
deleted
100644 → 0
View file @
edc5903b
/*
* linux/drivers/ide/ide-pci.c Version 1.05 June 9, 2000
*
* Copyright (c) 1998-2000 Andre Hedrick <andre@linux-ide.org>
*
* Copyright (c) 1995-1998 Mark Lord
* May be copied or modified under the terms of the GNU General Public License
*/
/*
* This module provides support for automatic detection and
* configuration of all PCI IDE interfaces present in a system.
*/
/*
* Chipsets that are on the IDE_IGNORE list because of problems of not being
* set at compile time.
*
* CONFIG_BLK_DEV_PDC202XX
*/
#include <linux/config.h>
#include <linux/types.h>
#include <linux/kernel.h>
#include <linux/timer.h>
#include <linux/mm.h>
#include <linux/interrupt.h>
#include <linux/pci.h>
#include <linux/init.h>
#include <linux/ide.h>
#include <asm/io.h>
#include <asm/irq.h>
#define DEVID_PIIXa ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82371FB_0})
#define DEVID_PIIXb ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82371FB_1})
#define DEVID_MPIIX ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82371MX})
#define DEVID_PIIX3 ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82371SB_1})
#define DEVID_PIIX4 ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82371AB})
#define DEVID_PIIX4E ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801AB_1})
#define DEVID_PIIX4E2 ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82443MX_1})
#define DEVID_PIIX4U ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801AA_1})
#define DEVID_PIIX4U2 ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82372FB_1})
#define DEVID_PIIX4NX ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82451NX})
#define DEVID_PIIX4U3 ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801BA_9})
#define DEVID_PIIX4U4 ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801BA_8})
#define DEVID_PIIX4U5 ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801CA_10})
#define DEVID_PIIX4U6 ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801CA_11})
#define DEVID_PIIX4U7 ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801E_11})
#define DEVID_PIIX4U8 ((ide_pci_devid_t){PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801DB_11})
#define DEVID_VIA_IDE ((ide_pci_devid_t){PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C561})
#define DEVID_MR_IDE ((ide_pci_devid_t){PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C576_1})
#define DEVID_VP_IDE ((ide_pci_devid_t){PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C586_1})
#define DEVID_PDC20246 ((ide_pci_devid_t){PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20246})
#define DEVID_PDC20262 ((ide_pci_devid_t){PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20262})
#define DEVID_PDC20263 ((ide_pci_devid_t){PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20263})
#define DEVID_PDC20265 ((ide_pci_devid_t){PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20265})
#define DEVID_PDC20267 ((ide_pci_devid_t){PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20267})
#define DEVID_PDC20268 ((ide_pci_devid_t){PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20268})
#define DEVID_PDC20268R ((ide_pci_devid_t){PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20268R})
#define DEVID_PDC20269 ((ide_pci_devid_t){PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20269})
#define DEVID_PDC20271 ((ide_pci_devid_t){PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20271})
#define DEVID_PDC20275 ((ide_pci_devid_t){PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20275})
#define DEVID_PDC20276 ((ide_pci_devid_t){PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20276})
#define DEVID_PDC20277 ((ide_pci_devid_t){PCI_VENDOR_ID_PROMISE, PCI_DEVICE_ID_PROMISE_20277})
#define DEVID_RZ1000 ((ide_pci_devid_t){PCI_VENDOR_ID_PCTECH, PCI_DEVICE_ID_PCTECH_RZ1000})
#define DEVID_RZ1001 ((ide_pci_devid_t){PCI_VENDOR_ID_PCTECH, PCI_DEVICE_ID_PCTECH_RZ1001})
#define DEVID_SAMURAI ((ide_pci_devid_t){PCI_VENDOR_ID_PCTECH, PCI_DEVICE_ID_PCTECH_SAMURAI_IDE})
#define DEVID_CMD640 ((ide_pci_devid_t){PCI_VENDOR_ID_CMD, PCI_DEVICE_ID_CMD_640})
#define DEVID_CMD643 ((ide_pci_devid_t){PCI_VENDOR_ID_CMD, PCI_DEVICE_ID_CMD_643})
#define DEVID_CMD646 ((ide_pci_devid_t){PCI_VENDOR_ID_CMD, PCI_DEVICE_ID_CMD_646})
#define DEVID_CMD648 ((ide_pci_devid_t){PCI_VENDOR_ID_CMD, PCI_DEVICE_ID_CMD_648})
#define DEVID_CMD649 ((ide_pci_devid_t){PCI_VENDOR_ID_CMD, PCI_DEVICE_ID_CMD_649})
#define DEVID_CMD680 ((ide_pci_devid_t){PCI_VENDOR_ID_CMD, PCI_DEVICE_ID_CMD_680})
#define DEVID_SIS5513 ((ide_pci_devid_t){PCI_VENDOR_ID_SI, PCI_DEVICE_ID_SI_5513})
#define DEVID_OPTI621 ((ide_pci_devid_t){PCI_VENDOR_ID_OPTI, PCI_DEVICE_ID_OPTI_82C621})
#define DEVID_OPTI621V ((ide_pci_devid_t){PCI_VENDOR_ID_OPTI, PCI_DEVICE_ID_OPTI_82C558})
#define DEVID_OPTI621X ((ide_pci_devid_t){PCI_VENDOR_ID_OPTI, PCI_DEVICE_ID_OPTI_82C825})
#define DEVID_TRM290 ((ide_pci_devid_t){PCI_VENDOR_ID_TEKRAM, PCI_DEVICE_ID_TEKRAM_DC290})
#define DEVID_NS87410 ((ide_pci_devid_t){PCI_VENDOR_ID_NS, PCI_DEVICE_ID_NS_87410})
#define DEVID_NS87415 ((ide_pci_devid_t){PCI_VENDOR_ID_NS, PCI_DEVICE_ID_NS_87415})
#define DEVID_HT6565 ((ide_pci_devid_t){PCI_VENDOR_ID_HOLTEK, PCI_DEVICE_ID_HOLTEK_6565})
#define DEVID_AEC6210 ((ide_pci_devid_t){PCI_VENDOR_ID_ARTOP, PCI_DEVICE_ID_ARTOP_ATP850UF})
#define DEVID_AEC6260 ((ide_pci_devid_t){PCI_VENDOR_ID_ARTOP, PCI_DEVICE_ID_ARTOP_ATP860})
#define DEVID_AEC6260R ((ide_pci_devid_t){PCI_VENDOR_ID_ARTOP, PCI_DEVICE_ID_ARTOP_ATP860R})
#define DEVID_AEC6280 ((ide_pci_devid_t){PCI_VENDOR_ID_ARTOP, PCI_DEVICE_ID_ARTOP_ATP865})
#define DEVID_AEC6880 ((ide_pci_devid_t){PCI_VENDOR_ID_ARTOP, PCI_DEVICE_ID_ARTOP_ATP865R})
#define DEVID_W82C105 ((ide_pci_devid_t){PCI_VENDOR_ID_WINBOND, PCI_DEVICE_ID_WINBOND_82C105})
#define DEVID_UM8673F ((ide_pci_devid_t){PCI_VENDOR_ID_UMC, PCI_DEVICE_ID_UMC_UM8673F})
#define DEVID_UM8886A ((ide_pci_devid_t){PCI_VENDOR_ID_UMC, PCI_DEVICE_ID_UMC_UM8886A})
#define DEVID_UM8886BF ((ide_pci_devid_t){PCI_VENDOR_ID_UMC, PCI_DEVICE_ID_UMC_UM8886BF})
#define DEVID_HPT34X ((ide_pci_devid_t){PCI_VENDOR_ID_TTI, PCI_DEVICE_ID_TTI_HPT343})
#define DEVID_HPT366 ((ide_pci_devid_t){PCI_VENDOR_ID_TTI, PCI_DEVICE_ID_TTI_HPT366})
#define DEVID_HPT372 ((ide_pci_devid_t){PCI_VENDOR_ID_TTI, PCI_DEVICE_ID_TTI_HPT372})
#define DEVID_HPT302 ((ide_pci_devid_t){PCI_VENDOR_ID_TTI, PCI_DEVICE_ID_TTI_HPT302})
#define DEVID_HPT371 ((ide_pci_devid_t){PCI_VENDOR_ID_TTI, PCI_DEVICE_ID_TTI_HPT371})
#define DEVID_HPT374 ((ide_pci_devid_t){PCI_VENDOR_ID_TTI, PCI_DEVICE_ID_TTI_HPT374})
#define DEVID_ALI15X3 ((ide_pci_devid_t){PCI_VENDOR_ID_AL, PCI_DEVICE_ID_AL_M5229})
#define DEVID_CY82C693 ((ide_pci_devid_t){PCI_VENDOR_ID_CONTAQ, PCI_DEVICE_ID_CONTAQ_82C693})
#define DEVID_HINT ((ide_pci_devid_t){0x3388, 0x8013})
#define DEVID_CS5530 ((ide_pci_devid_t){PCI_VENDOR_ID_CYRIX, PCI_DEVICE_ID_CYRIX_5530_IDE})
#define DEVID_AMD7401 ((ide_pci_devid_t){PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_COBRA_7401})
#define DEVID_AMD7409 ((ide_pci_devid_t){PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_VIPER_7409})
#define DEVID_AMD7411 ((ide_pci_devid_t){PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_VIPER_7411})
#define DEVID_AMD7441 ((ide_pci_devid_t){PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_OPUS_7441})
#define DEVID_PDCADMA ((ide_pci_devid_t){PCI_VENDOR_ID_PDC, PCI_DEVICE_ID_PDC_1841})
#define DEVID_SLC90E66 ((ide_pci_devid_t){PCI_VENDOR_ID_EFAR, PCI_DEVICE_ID_EFAR_SLC90E66_1})
#define DEVID_OSB4 ((ide_pci_devid_t){PCI_VENDOR_ID_SERVERWORKS, PCI_DEVICE_ID_SERVERWORKS_OSB4IDE})
#define DEVID_CSB5 ((ide_pci_devid_t){PCI_VENDOR_ID_SERVERWORKS, PCI_DEVICE_ID_SERVERWORKS_CSB5IDE})
#define DEVID_CSB6 ((ide_pci_devid_t){PCI_VENDOR_ID_SERVERWORKS, PCI_DEVICE_ID_SERVERWORKS_CSB6IDE})
#define DEVID_ITE8172G ((ide_pci_devid_t){PCI_VENDOR_ID_ITE, PCI_DEVICE_ID_ITE_IT8172G})
#define IDE_IGNORE ((void *)-1)
#define IDE_NO_DRIVER ((void *)-2)
#ifdef CONFIG_BLK_DEV_AEC62XX
extern
void
fixup_device_aec6x80
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
unsigned
int
pci_init_aec62xx
(
struct
pci_dev
*
,
const
char
*
);
extern
unsigned
int
ata66_aec62xx
(
ide_hwif_t
*
);
extern
void
ide_init_aec62xx
(
ide_hwif_t
*
);
extern
void
ide_dmacapable_aec62xx
(
ide_hwif_t
*
,
unsigned
long
);
#define FIXUP_AEC62XX &fixup_device_aec6x80
#define PCI_AEC62XX &pci_init_aec62xx
#define ATA66_AEC62XX &ata66_aec62xx
#define INIT_AEC62XX &ide_init_aec62xx
#define DMA_AEC62XX &ide_dmacapable_aec62xx
#else
#define FIXUP_AEC62XX NULL
#define PCI_AEC62XX NULL
#define ATA66_AEC62XX NULL
#define INIT_AEC62XX IDE_NO_DRIVER
#define DMA_AEC62XX NULL
#endif
#ifdef CONFIG_BLK_DEV_ALI15X3
extern
void
fixup_device_ali15x3
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
unsigned
int
pci_init_ali15x3
(
struct
pci_dev
*
,
const
char
*
);
extern
unsigned
int
ata66_ali15x3
(
ide_hwif_t
*
);
extern
void
ide_init_ali15x3
(
ide_hwif_t
*
);
extern
void
ide_dmacapable_ali15x3
(
ide_hwif_t
*
,
unsigned
long
);
#define FIXUP_ALI15X3 &fixup_device_ali15x3
#define PCI_ALI15X3 &pci_init_ali15x3
#define ATA66_ALI15X3 &ata66_ali15x3
#define INIT_ALI15X3 &ide_init_ali15x3
#define DMA_ALI15X3 &ide_dmacapable_ali15x3
#else
#define FIXUP_ALI15X3 NULL
#define PCI_ALI15X3 NULL
#define ATA66_ALI15X3 NULL
#define INIT_ALI15X3 IDE_NO_DRIVER
#define DMA_ALI15X3 NULL
#endif
#ifdef CONFIG_BLK_DEV_AMD74XX
extern
void
fixup_device_amd74xx
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
unsigned
int
pci_init_amd74xx
(
struct
pci_dev
*
,
const
char
*
);
extern
unsigned
int
ata66_amd74xx
(
ide_hwif_t
*
);
extern
void
ide_init_amd74xx
(
ide_hwif_t
*
);
extern
void
ide_dmacapable_amd74xx
(
ide_hwif_t
*
,
unsigned
long
);
#define FIXUP_AMD74XX &fixup_device_amd74xx
#define PCI_AMD74XX &pci_init_amd74xx
#define ATA66_AMD74XX &ata66_amd74xx
#define INIT_AMD74XX &ide_init_amd74xx
#define DMA_AMD74XX &ide_dmacapable_amd74xx
#else
#define FIXUP_AMD74XX NULL
#define PCI_AMD74XX NULL
#define ATA66_AMD74XX NULL
#define INIT_AMD74XX IDE_NO_DRIVER
#define DMA_AMD74XX NULL
#endif
#ifdef CONFIG_BLK_DEV_CMD64X
extern
unsigned
int
pci_init_cmd64x
(
struct
pci_dev
*
,
const
char
*
);
extern
unsigned
int
ata66_cmd64x
(
ide_hwif_t
*
);
extern
void
ide_init_cmd64x
(
ide_hwif_t
*
);
extern
void
ide_dmacapable_cmd64x
(
ide_hwif_t
*
,
unsigned
long
);
#define PCI_CMD64X &pci_init_cmd64x
#define ATA66_CMD64X &ata66_cmd64x
#define INIT_CMD64X &ide_init_cmd64x
#else
#define PCI_CMD64X NULL
#define ATA66_CMD64X NULL
#ifdef __sparc_v9__
#define INIT_CMD64X IDE_IGNORE
#else
#define INIT_CMD64X IDE_NO_DRIVER
#endif
#endif
#ifdef CONFIG_BLK_DEV_CY82C693
extern
void
fixup_device_cy82c693
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
unsigned
int
pci_init_cy82c693
(
struct
pci_dev
*
,
const
char
*
);
extern
void
ide_init_cy82c693
(
ide_hwif_t
*
);
#define FIXUP_CY82C693 &fixup_device_cy82c693
#define PCI_CY82C693 &pci_init_cy82c693
#define INIT_CY82C693 &ide_init_cy82c693
#else
#define FIXUP_CY82C693 NULL
#define PCI_CY82C693 NULL
#define INIT_CY82C693 IDE_NO_DRIVER
#endif
#ifdef CONFIG_BLK_DEV_CS5530
extern
unsigned
int
pci_init_cs5530
(
struct
pci_dev
*
,
const
char
*
);
extern
void
ide_init_cs5530
(
ide_hwif_t
*
);
#define PCI_CS5530 &pci_init_cs5530
#define INIT_CS5530 &ide_init_cs5530
#else
#define PCI_CS5530 NULL
#define INIT_CS5530 IDE_NO_DRIVER
#endif
#ifdef CONFIG_BLK_DEV_HPT34X
extern
void
fixup_device_hpt343
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
unsigned
int
pci_init_hpt34x
(
struct
pci_dev
*
,
const
char
*
);
extern
void
ide_init_hpt34x
(
ide_hwif_t
*
);
#define FIXUP_HPT34X &fixup_device_hpt343
#define PCI_HPT34X &pci_init_hpt34x
#define INIT_HPT34X &ide_init_hpt34x
#else
#define FIXUP_HPT34X NULL
#define PCI_HPT34X NULL
#define INIT_HPT34X IDE_IGNORE
#endif
#ifdef CONFIG_BLK_DEV_HPT366
extern
void
fixup_device_hpt366
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
void
fixup_device_hpt374
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
unsigned
int
pci_init_hpt366
(
struct
pci_dev
*
,
const
char
*
);
extern
unsigned
int
ata66_hpt366
(
ide_hwif_t
*
);
extern
void
ide_init_hpt366
(
ide_hwif_t
*
);
extern
void
ide_dmacapable_hpt366
(
ide_hwif_t
*
,
unsigned
long
);
#define FIXUP_HPT366 &fixup_device_hpt366
#define FIXUP_HPT374 &fixup_device_hpt374
#define PCI_HPT366 &pci_init_hpt366
#define ATA66_HPT366 &ata66_hpt366
#define INIT_HPT366 &ide_init_hpt366
#define DMA_HPT366 &ide_dmacapable_hpt366
#else
#define FIXUP_HPT366 NULL
#define FIXUP_HPT374 NULL
#define PCI_HPT366 NULL
#define ATA66_HPT366 NULL
#define INIT_HPT366 IDE_NO_DRIVER
#define DMA_HPT366 NULL
#endif
#ifdef CONFIG_BLK_DEV_NS87415
extern
void
ide_init_ns87415
(
ide_hwif_t
*
);
#define INIT_NS87415 &ide_init_ns87415
#else
#define INIT_NS87415 IDE_IGNORE
#endif
#ifdef CONFIG_BLK_DEV_OPTI621
extern
void
fixup_device_opti621
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
void
ide_init_opti621
(
ide_hwif_t
*
);
#define FIXUP_OPTI621 &fixup_device_opti621
#define INIT_OPTI621 &ide_init_opti621
#else
#define FIXUP_OPTI621 NULL
#define INIT_OPTI621 IDE_NO_DRIVER
#endif
#ifdef CONFIG_BLK_DEV_PDC_ADMA
extern
unsigned
int
pci_init_pdcadma
(
struct
pci_dev
*
,
const
char
*
);
extern
unsigned
int
ata66_pdcadma
(
ide_hwif_t
*
);
extern
void
ide_init_pdcadma
(
ide_hwif_t
*
);
extern
void
ide_dmacapable_pdcadma
(
ide_hwif_t
*
,
unsigned
long
);
#define PCI_PDCADMA &pci_init_pdcadma
#define ATA66_PDCADMA &ata66_pdcadma
#define INIT_PDCADMA &ide_init_pdcadma
#define DMA_PDCADMA &ide_dmacapable_pdcadma
#else
#define PCI_PDCADMA IDE_IGNORE
#define ATA66_PDCADMA IDE_IGNORE
#define INIT_PDCADMA IDE_IGNORE
#define DMA_PDCADMA IDE_IGNORE
#endif
#ifdef CONFIG_BLK_DEV_PDC202XX
extern
void
fixup_device_pdc20265
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
void
fixup_device_pdc20270
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
unsigned
int
pci_init_pdc202xx
(
struct
pci_dev
*
,
const
char
*
);
extern
unsigned
int
ata66_pdc202xx
(
ide_hwif_t
*
);
extern
void
ide_init_pdc202xx
(
ide_hwif_t
*
);
#define FIXUP_PDC20265 &fixup_device_pdc20265
#define FIXUP_PDC20270 &fixup_device_pdc20270
#define PCI_PDC202XX &pci_init_pdc202xx
#define ATA66_PDC202XX &ata66_pdc202xx
#define INIT_PDC202XX &ide_init_pdc202xx
#else
#define FIXUP_PDC20265 IDE_IGNORE
#define FIXUP_PDC20270 IDE_IGNORE
#define PCI_PDC202XX IDE_IGNORE
#define ATA66_PDC202XX IDE_IGNORE
#define INIT_PDC202XX IDE_IGNORE
#endif
#ifdef CONFIG_BLK_DEV_PIIX
extern
void
fixup_device_piix
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
unsigned
int
pci_init_piix
(
struct
pci_dev
*
,
const
char
*
);
extern
unsigned
int
ata66_piix
(
ide_hwif_t
*
);
extern
void
ide_init_piix
(
ide_hwif_t
*
);
#define FIXUP_PIIX &fixup_device_piix
#define PCI_PIIX &pci_init_piix
#define ATA66_PIIX &ata66_piix
#define INIT_PIIX &ide_init_piix
#else
#define FIXUP_PIIX NULL
#define PCI_PIIX NULL
#define ATA66_PIIX NULL
#define INIT_PIIX IDE_NO_DRIVER
#endif
#ifdef CONFIG_BLK_DEV_IT8172
extern
void
fixup_device_it8172
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
unsigned
int
pci_init_it8172
(
struct
pci_dev
*
,
const
char
*
);
extern
unsigned
int
ata66_it8172
(
ide_hwif_t
*
);
extern
void
ide_init_it8172
(
ide_hwif_t
*
);
#define FIXUP_IT8172 &fixup_device_it8172
#define PCI_IT8172 &pci_init_it8172
#define ATA66_IT8172 &ata66_it8172
#define INIT_IT8172 &ide_init_it8172
#else
#define FIXUP_IT8172 NULL
#define PCI_IT8172 NULL
#define ATA66_IT8172 NULL
#define INIT_IT8172 IDE_NO_DRIVER
#endif
#ifdef CONFIG_BLK_DEV_RZ1000
extern
void
ide_init_rz1000
(
ide_hwif_t
*
);
#define INIT_RZ1000 &ide_init_rz1000
#else
#define INIT_RZ1000 IDE_IGNORE
#endif
#define INIT_SAMURAI NULL
#ifdef CONFIG_BLK_DEV_SVWKS
extern
void
fixup_device_csb6
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
unsigned
int
pci_init_svwks
(
struct
pci_dev
*
,
const
char
*
);
extern
unsigned
int
ata66_svwks
(
ide_hwif_t
*
);
extern
void
ide_init_svwks
(
ide_hwif_t
*
);
extern
void
ide_dmacapable_svwks
(
ide_hwif_t
*
,
unsigned
long
);
#define FIXUP_CSB6 &fixup_device_csb6
#define PCI_SVWKS &pci_init_svwks
#define ATA66_SVWKS &ata66_svwks
#define INIT_SVWKS &ide_init_svwks
#define DMA_SVWKS &ide_dmacapable_svwks
#else
#define FIXUP_CSB6 NULL
#define PCI_SVWKS NULL
#define ATA66_SVWKS NULL
#define INIT_SVWKS IDE_NO_DRIVER
#define DMA_SVWKS NULL
#endif
#ifdef CONFIG_BLK_DEV_SIS5513
extern
void
fixup_device_sis5513
(
struct
pci_dev
*
,
ide_pci_device_t
*
);
extern
unsigned
int
pci_init_sis5513
(
struct
pci_dev
*
,
const
char
*
);
extern
unsigned
int
ata66_sis5513
(
ide_hwif_t
*
);
extern
void
ide_init_sis5513
(
ide_hwif_t
*
);
#define FIXUP_SIS5513 &fixup_device_sis5513
#define PCI_SIS5513 &pci_init_sis5513
#define ATA66_SIS5513 &ata66_sis5513
#define INIT_SIS5513 &ide_init_sis5513
#else
#define FIXUP_SIS5513 NULL
#define PCI_SIS5513 NULL
#define ATA66_SIS5513 NULL
#define INIT_SIS5513 IDE_NO_DRIVER
#endif
#ifdef CONFIG_BLK_DEV_SLC90E66
extern
unsigned
int
pci_init_slc90e66
(
struct
pci_dev
*
,
const
char
*
);
extern
unsigned
int
ata66_slc90e66
(
ide_hwif_t
*
);
extern
void
ide_init_slc90e66
(
ide_hwif_t
*
);
#define PCI_SLC90E66 &pci_init_slc90e66
#define ATA66_SLC90E66 &ata66_slc90e66
#define INIT_SLC90E66 &ide_init_slc90e66
#else
#define PCI_SLC90E66 NULL
#define ATA66_SLC90E66 NULL
#define INIT_SLC90E66 IDE_NO_DRIVER
#endif
#ifdef CONFIG_BLK_DEV_SL82C105
extern
unsigned
int
pci_init_sl82c105
(
struct
pci_dev
*
,
const
char
*
);
extern
void
dma_init_sl82c105
(
ide_hwif_t
*
,
unsigned
long
);
extern
void
ide_init_sl82c105
(
ide_hwif_t
*
);
#define PCI_W82C105 &pci_init_sl82c105
#define DMA_W82C105 &dma_init_sl82c105
#define INIT_W82C105 &ide_init_sl82c105
#else
#define PCI_W82C105 NULL
#define DMA_W82C105 NULL
#define INIT_W82C105 IDE_IGNORE
#endif
#ifdef CONFIG_BLK_DEV_TRM290
extern
void
ide_init_trm290
(
ide_hwif_t
*
);
#define INIT_TRM290 &ide_init_trm290
#else
#define INIT_TRM290 IDE_IGNORE
#endif
#ifdef CONFIG_BLK_DEV_VIA82CXXX
extern
unsigned
int
pci_init_via82cxxx
(
struct
pci_dev
*
,
const
char
*
);
extern
unsigned
int
ata66_via82cxxx
(
ide_hwif_t
*
);
extern
void
ide_init_via82cxxx
(
ide_hwif_t
*
);
extern
void
ide_dmacapable_via82cxxx
(
ide_hwif_t
*
,
unsigned
long
);
#define PCI_VIA82CXXX &pci_init_via82cxxx
#define ATA66_VIA82CXXX &ata66_via82cxxx
#define INIT_VIA82CXXX &ide_init_via82cxxx
#define DMA_VIA82CXXX &ide_dmacapable_via82cxxx
#else
#define PCI_VIA82CXXX NULL
#define ATA66_VIA82CXXX NULL
#define INIT_VIA82CXXX IDE_NO_DRIVER
#define DMA_VIA82CXXX NULL
#endif
static
ide_pci_device_t
ide_pci_chipsets
[]
__initdata
=
{
{
DEVID_PIIXa
,
"PIIX"
,
FIXUP_PIIX
,
PCI_PIIX
,
NULL
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIXb
,
"PIIX"
,
FIXUP_PIIX
,
PCI_PIIX
,
NULL
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_MPIIX
,
"MPIIX"
,
FIXUP_PIIX
,
NULL
,
NULL
,
INIT_PIIX
,
NULL
,
{{
0x6D
,
0x80
,
0x80
},
{
0x6F
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIX3
,
"PIIX3"
,
FIXUP_PIIX
,
PCI_PIIX
,
NULL
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIX4
,
"PIIX4"
,
FIXUP_PIIX
,
PCI_PIIX
,
NULL
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIX4E
,
"PIIX4"
,
FIXUP_PIIX
,
PCI_PIIX
,
NULL
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIX4E2
,
"PIIX4"
,
FIXUP_PIIX
,
PCI_PIIX
,
NULL
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIX4U
,
"PIIX4"
,
FIXUP_PIIX
,
PCI_PIIX
,
ATA66_PIIX
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIX4U2
,
"PIIX4"
,
FIXUP_PIIX
,
PCI_PIIX
,
ATA66_PIIX
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIX4NX
,
"PIIX4"
,
FIXUP_PIIX
,
PCI_PIIX
,
NULL
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIX4U3
,
"PIIX4"
,
FIXUP_PIIX
,
PCI_PIIX
,
ATA66_PIIX
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIX4U4
,
"PIIX4"
,
FIXUP_PIIX
,
PCI_PIIX
,
ATA66_PIIX
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIX4U5
,
"PIIX4"
,
FIXUP_PIIX
,
PCI_PIIX
,
ATA66_PIIX
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIX4U6
,
"PIIX4"
,
FIXUP_PIIX
,
PCI_PIIX
,
ATA66_PIIX
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIX4U7
,
"PIIX4"
,
FIXUP_PIIX
,
PCI_PIIX
,
ATA66_PIIX
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_PIIX4U8
,
"PIIX4"
,
FIXUP_PIIX
,
PCI_PIIX
,
ATA66_PIIX
,
INIT_PIIX
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_VIA_IDE
,
"VIA_IDE"
,
NULL
,
NULL
,
NULL
,
NULL
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_MR_IDE
,
"VP_IDE"
,
NULL
,
PCI_VIA82CXXX
,
ATA66_VIA82CXXX
,
INIT_VIA82CXXX
,
DMA_VIA82CXXX
,
{{
0x40
,
0x02
,
0x02
},
{
0x40
,
0x01
,
0x01
}},
ON_BOARD
,
0
},
{
DEVID_VP_IDE
,
"VP_IDE"
,
NULL
,
PCI_VIA82CXXX
,
ATA66_VIA82CXXX
,
INIT_VIA82CXXX
,
DMA_VIA82CXXX
,
{{
0x40
,
0x02
,
0x02
},
{
0x40
,
0x01
,
0x01
}},
ON_BOARD
,
0
},
#ifdef CONFIG_PDC202XX_FORCE
{
DEVID_PDC20246
,
"PDC20246"
,
NULL
,
PCI_PDC202XX
,
NULL
,
INIT_PDC202XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
16
},
{
DEVID_PDC20262
,
"PDC20262"
,
NULL
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
48
},
{
DEVID_PDC20263
,
"PDC20263"
,
NULL
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
48
},
{
DEVID_PDC20265
,
"PDC20265"
,
FIXUP_PDC20265
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
48
},
{
DEVID_PDC20267
,
"PDC20267"
,
NULL
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
48
},
#else
/* !CONFIG_PDC202XX_FORCE */
{
DEVID_PDC20246
,
"PDC20246"
,
NULL
,
PCI_PDC202XX
,
NULL
,
INIT_PDC202XX
,
NULL
,
{{
0x50
,
0x02
,
0x02
},
{
0x50
,
0x04
,
0x04
}},
OFF_BOARD
,
16
},
{
DEVID_PDC20262
,
"PDC20262"
,
NULL
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x50
,
0x02
,
0x02
},
{
0x50
,
0x04
,
0x04
}},
OFF_BOARD
,
48
},
{
DEVID_PDC20263
,
"PDC20263"
,
NULL
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x50
,
0x02
,
0x02
},
{
0x50
,
0x04
,
0x04
}},
OFF_BOARD
,
48
},
{
DEVID_PDC20265
,
"PDC20265"
,
FIXUP_PDC20265
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x50
,
0x02
,
0x02
},
{
0x50
,
0x04
,
0x04
}},
OFF_BOARD
,
48
},
{
DEVID_PDC20267
,
"PDC20267"
,
NULL
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x50
,
0x02
,
0x02
},
{
0x50
,
0x04
,
0x04
}},
OFF_BOARD
,
48
},
#endif
{
DEVID_PDC20268
,
"PDC20268"
,
NULL
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
0
},
/*
* Promise used a different PCI ident for the raid card apparently
* to try and prevent Linux detecting it and using our own raid code.
* We want to detect it for the ataraid drivers, so we have to list
* both here..
*/
{
DEVID_PDC20268R
,
"PDC20270"
,
FIXUP_PDC20270
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
0
},
{
DEVID_PDC20269
,
"PDC20269"
,
NULL
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
0
},
{
DEVID_PDC20271
,
"PDC20271"
,
NULL
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
0
},
{
DEVID_PDC20275
,
"PDC20275"
,
NULL
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
0
},
{
DEVID_PDC20276
,
"PDC20276"
,
NULL
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
0
},
{
DEVID_PDC20277
,
"PDC20277"
,
NULL
,
PCI_PDC202XX
,
ATA66_PDC202XX
,
INIT_PDC202XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
0
},
{
DEVID_RZ1000
,
"RZ1000"
,
NULL
,
NULL
,
NULL
,
INIT_RZ1000
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_RZ1001
,
"RZ1001"
,
NULL
,
NULL
,
NULL
,
INIT_RZ1000
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_SAMURAI
,
"SAMURAI"
,
NULL
,
NULL
,
NULL
,
INIT_SAMURAI
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_CMD640
,
"CMD640"
,
NULL
,
NULL
,
NULL
,
IDE_IGNORE
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_NS87410
,
"NS87410"
,
NULL
,
NULL
,
NULL
,
NULL
,
NULL
,
{{
0x43
,
0x08
,
0x08
},
{
0x47
,
0x08
,
0x08
}},
ON_BOARD
,
0
},
{
DEVID_SIS5513
,
"SIS5513"
,
FIXUP_SIS5513
,
PCI_SIS5513
,
ATA66_SIS5513
,
INIT_SIS5513
,
NULL
,
{{
0x4a
,
0x02
,
0x02
},
{
0x4a
,
0x04
,
0x04
}},
ON_BOARD
,
0
},
{
DEVID_CMD643
,
"CMD643"
,
NULL
,
PCI_CMD64X
,
NULL
,
INIT_CMD64X
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_CMD646
,
"CMD646"
,
NULL
,
PCI_CMD64X
,
NULL
,
INIT_CMD64X
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x51
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_CMD648
,
"CMD648"
,
NULL
,
PCI_CMD64X
,
ATA66_CMD64X
,
INIT_CMD64X
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_CMD649
,
"CMD649"
,
NULL
,
PCI_CMD64X
,
ATA66_CMD64X
,
INIT_CMD64X
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_CMD680
,
"CMD680"
,
NULL
,
PCI_CMD64X
,
ATA66_CMD64X
,
INIT_CMD64X
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_HT6565
,
"HT6565"
,
NULL
,
NULL
,
NULL
,
NULL
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_OPTI621
,
"OPTI621"
,
FIXUP_OPTI621
,
NULL
,
NULL
,
INIT_OPTI621
,
NULL
,
{{
0x45
,
0x80
,
0x00
},
{
0x40
,
0x08
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_OPTI621X
,
"OPTI621X"
,
FIXUP_OPTI621
,
NULL
,
NULL
,
INIT_OPTI621
,
NULL
,
{{
0x45
,
0x80
,
0x00
},
{
0x40
,
0x08
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_TRM290
,
"TRM290"
,
NULL
,
NULL
,
NULL
,
INIT_TRM290
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_NS87415
,
"NS87415"
,
NULL
,
NULL
,
NULL
,
INIT_NS87415
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_AEC6210
,
"AEC6210"
,
NULL
,
PCI_AEC62XX
,
NULL
,
INIT_AEC62XX
,
DMA_AEC62XX
,
{{
0x4a
,
0x02
,
0x02
},
{
0x4a
,
0x04
,
0x04
}},
OFF_BOARD
,
0
},
{
DEVID_AEC6260
,
"AEC6260"
,
NULL
,
PCI_AEC62XX
,
ATA66_AEC62XX
,
INIT_AEC62XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
NEVER_BOARD
,
0
},
{
DEVID_AEC6260R
,
"AEC6260R"
,
NULL
,
PCI_AEC62XX
,
ATA66_AEC62XX
,
INIT_AEC62XX
,
NULL
,
{{
0x4a
,
0x02
,
0x02
},
{
0x4a
,
0x04
,
0x04
}},
OFF_BOARD
,
0
},
{
DEVID_AEC6280
,
"AEC6X80"
,
FIXUP_AEC62XX
,
PCI_AEC62XX
,
ATA66_AEC62XX
,
INIT_AEC62XX
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
NEVER_BOARD
,
0
},
{
DEVID_AEC6880
,
"AEC6X80R"
,
FIXUP_AEC62XX
,
PCI_AEC62XX
,
ATA66_AEC62XX
,
INIT_AEC62XX
,
NULL
,
{{
0x4a
,
0x02
,
0x02
},
{
0x4a
,
0x04
,
0x04
}},
OFF_BOARD
,
0
},
{
DEVID_W82C105
,
"W82C105"
,
NULL
,
PCI_W82C105
,
NULL
,
INIT_W82C105
,
DMA_W82C105
,
{{
0x40
,
0x01
,
0x01
},
{
0x40
,
0x10
,
0x10
}},
ON_BOARD
,
0
},
{
DEVID_UM8673F
,
"UM8673F"
,
NULL
,
NULL
,
NULL
,
NULL
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_UM8886A
,
"UM8886A"
,
NULL
,
NULL
,
NULL
,
NULL
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_UM8886BF
,
"UM8886BF"
,
NULL
,
NULL
,
NULL
,
NULL
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_HPT34X
,
"HPT34X"
,
FIXUP_HPT34X
,
PCI_HPT34X
,
NULL
,
INIT_HPT34X
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
NEVER_BOARD
,
16
},
{
DEVID_HPT366
,
"HPT366"
,
FIXUP_HPT366
,
PCI_HPT366
,
ATA66_HPT366
,
INIT_HPT366
,
DMA_HPT366
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
240
},
{
DEVID_HPT372
,
"HPT372A"
,
NULL
,
PCI_HPT366
,
ATA66_HPT366
,
INIT_HPT366
,
DMA_HPT366
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
0
},
{
DEVID_HPT302
,
"HPT302"
,
NULL
,
PCI_HPT366
,
ATA66_HPT366
,
INIT_HPT366
,
DMA_HPT366
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
0
},
{
DEVID_HPT371
,
"HPT371"
,
NULL
,
PCI_HPT366
,
ATA66_HPT366
,
INIT_HPT366
,
DMA_HPT366
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
0
},
{
DEVID_HPT374
,
"HPT374"
,
FIXUP_HPT374
,
PCI_HPT366
,
ATA66_HPT366
,
INIT_HPT366
,
DMA_HPT366
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
0
},
{
DEVID_ALI15X3
,
"ALI15X3"
,
FIXUP_ALI15X3
,
PCI_ALI15X3
,
ATA66_ALI15X3
,
INIT_ALI15X3
,
DMA_ALI15X3
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_CY82C693
,
"CY82C693"
,
FIXUP_CY82C693
,
PCI_CY82C693
,
NULL
,
INIT_CY82C693
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_HINT
,
"HINT_IDE"
,
NULL
,
NULL
,
NULL
,
NULL
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_CS5530
,
"CS5530"
,
NULL
,
PCI_CS5530
,
NULL
,
INIT_CS5530
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_AMD7401
,
"AMD7401"
,
FIXUP_AMD74XX
,
NULL
,
NULL
,
NULL
,
DMA_AMD74XX
,
{{
0x40
,
0x01
,
0x01
},
{
0x40
,
0x02
,
0x02
}},
ON_BOARD
,
0
},
{
DEVID_AMD7409
,
"AMD7409"
,
FIXUP_AMD74XX
,
PCI_AMD74XX
,
ATA66_AMD74XX
,
INIT_AMD74XX
,
DMA_AMD74XX
,
{{
0x40
,
0x01
,
0x01
},
{
0x40
,
0x02
,
0x02
}},
ON_BOARD
,
0
},
{
DEVID_AMD7411
,
"AMD7411"
,
FIXUP_AMD74XX
,
PCI_AMD74XX
,
ATA66_AMD74XX
,
INIT_AMD74XX
,
DMA_AMD74XX
,
{{
0x40
,
0x01
,
0x01
},
{
0x40
,
0x02
,
0x02
}},
ON_BOARD
,
0
},
{
DEVID_AMD7441
,
"AMD7441"
,
FIXUP_AMD74XX
,
PCI_AMD74XX
,
ATA66_AMD74XX
,
INIT_AMD74XX
,
DMA_AMD74XX
,
{{
0x40
,
0x01
,
0x01
},
{
0x40
,
0x02
,
0x02
}},
ON_BOARD
,
0
},
{
DEVID_PDCADMA
,
"PDCADMA"
,
NULL
,
PCI_PDCADMA
,
ATA66_PDCADMA
,
INIT_PDCADMA
,
DMA_PDCADMA
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
OFF_BOARD
,
0
},
{
DEVID_SLC90E66
,
"SLC90E66"
,
NULL
,
PCI_SLC90E66
,
ATA66_SLC90E66
,
INIT_SLC90E66
,
NULL
,
{{
0x41
,
0x80
,
0x80
},
{
0x43
,
0x80
,
0x80
}},
ON_BOARD
,
0
},
{
DEVID_OSB4
,
"SvrWks OSB4"
,
NULL
,
PCI_SVWKS
,
ATA66_SVWKS
,
INIT_SVWKS
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_CSB5
,
"SvrWks CSB5"
,
NULL
,
PCI_SVWKS
,
ATA66_SVWKS
,
INIT_SVWKS
,
DMA_SVWKS
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_CSB6
,
"SvrWks CSB6"
,
FIXUP_CSB6
,
PCI_SVWKS
,
ATA66_SVWKS
,
INIT_SVWKS
,
DMA_SVWKS
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
},
{
DEVID_ITE8172G
,
"IT8172G"
,
FIXUP_IT8172
,
PCI_IT8172
,
NULL
,
INIT_IT8172
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x40
,
0x00
,
0x01
}},
ON_BOARD
,
0
},
{
IDE_PCI_DEVID_NULL
,
"PCI_IDE"
,
NULL
,
NULL
,
NULL
,
NULL
,
NULL
,
{{
0x00
,
0x00
,
0x00
},
{
0x00
,
0x00
,
0x00
}},
ON_BOARD
,
0
}};
/*
* This allows offboard ide-pci cards the enable a BIOS, verify interrupt
* settings of split-mirror pci-config space, place chipset into init-mode,
* and/or preserve an interrupt if the card is not native ide support.
*/
static
unsigned
int
__init
ide_special_settings
(
struct
pci_dev
*
dev
,
const
char
*
name
)
{
switch
(
dev
->
device
)
{
case
PCI_DEVICE_ID_TTI_HPT366
:
case
PCI_DEVICE_ID_TTI_HPT372
:
case
PCI_DEVICE_ID_TTI_HPT302
:
case
PCI_DEVICE_ID_TTI_HPT371
:
case
PCI_DEVICE_ID_TTI_HPT374
:
case
PCI_DEVICE_ID_PROMISE_20246
:
case
PCI_DEVICE_ID_PROMISE_20262
:
case
PCI_DEVICE_ID_PROMISE_20263
:
case
PCI_DEVICE_ID_PROMISE_20265
:
case
PCI_DEVICE_ID_PROMISE_20267
:
case
PCI_DEVICE_ID_PROMISE_20268
:
case
PCI_DEVICE_ID_PROMISE_20268R
:
case
PCI_DEVICE_ID_PROMISE_20269
:
case
PCI_DEVICE_ID_PROMISE_20271
:
case
PCI_DEVICE_ID_PROMISE_20275
:
case
PCI_DEVICE_ID_PROMISE_20276
:
case
PCI_DEVICE_ID_PROMISE_20277
:
/*
* case PCI_DEVICE_ID_ARTOP_ATP850UF:
* same device ID value as PCI_DEVICE_ID_TTI_HPT372
* case PCI_DEVICE_ID_ARTOP_ATP860:
* same device ID value as PCI_DEVICE_ID_TTI_HPT302
* case PCI_DEVICE_ID_ARTOP_ATP860R:
* same device ID value as PCI_DEVICE_ID_TTI_HPT371
* case PCI_DEVICE_ID_ARTOP_ATP865:
* same device ID value as PCI_DEVICE_ID_TTI_HPT374
*/
case
PCI_DEVICE_ID_ARTOP_ATP865R
:
return
dev
->
irq
;
default:
break
;
}
return
0
;
}
/*
* Match a PCI IDE port against an entry in ide_hwifs[],
* based on io_base port if possible.
*/
static
ide_hwif_t
__init
*
ide_match_hwif
(
unsigned
long
io_base
,
byte
bootable
,
const
char
*
name
)
{
int
h
;
ide_hwif_t
*
hwif
;
/*
* Look for a hwif with matching io_base specified using
* parameters to ide_setup().
*/
for
(
h
=
0
;
h
<
MAX_HWIFS
;
++
h
)
{
hwif
=
&
ide_hwifs
[
h
];
if
(
hwif
->
io_ports
[
IDE_DATA_OFFSET
]
==
io_base
)
{
if
(
hwif
->
chipset
==
ide_generic
)
return
hwif
;
/* a perfect match */
}
}
/*
* Look for a hwif with matching io_base default value.
* If chipset is "ide_unknown", then claim that hwif slot.
* Otherwise, some other chipset has already claimed it.. :(
*/
for
(
h
=
0
;
h
<
MAX_HWIFS
;
++
h
)
{
hwif
=
&
ide_hwifs
[
h
];
if
(
hwif
->
io_ports
[
IDE_DATA_OFFSET
]
==
io_base
)
{
if
(
hwif
->
chipset
==
ide_unknown
)
return
hwif
;
/* match */
printk
(
"%s: port 0x%04lx already claimed by %s
\n
"
,
name
,
io_base
,
hwif
->
name
);
return
NULL
;
/* already claimed */
}
}
/*
* Okay, there is no hwif matching our io_base,
* so we'll just claim an unassigned slot.
* Give preference to claiming other slots before claiming ide0/ide1,
* just in case there's another interface yet-to-be-scanned
* which uses ports 1f0/170 (the ide0/ide1 defaults).
*
* Unless there is a bootable card that does not use the standard
* ports 1f0/170 (the ide0/ide1 defaults). The (bootable) flag.
*/
if
(
bootable
)
{
for
(
h
=
0
;
h
<
MAX_HWIFS
;
++
h
)
{
hwif
=
&
ide_hwifs
[
h
];
if
(
hwif
->
chipset
==
ide_unknown
)
return
hwif
;
/* pick an unused entry */
}
}
else
{
for
(
h
=
2
;
h
<
MAX_HWIFS
;
++
h
)
{
hwif
=
ide_hwifs
+
h
;
if
(
hwif
->
chipset
==
ide_unknown
)
return
hwif
;
/* pick an unused entry */
}
}
for
(
h
=
0
;
h
<
2
;
++
h
)
{
hwif
=
ide_hwifs
+
h
;
if
(
hwif
->
chipset
==
ide_unknown
)
return
hwif
;
/* pick an unused entry */
}
printk
(
"%s: too many IDE interfaces, no room in table
\n
"
,
name
);
return
NULL
;
}
static
int
__init
ide_setup_pci_baseregs
(
struct
pci_dev
*
dev
,
const
char
*
name
)
{
byte
reg
,
progif
=
0
;
/*
* Place both IDE interfaces into PCI "native" mode:
*/
if
(
pci_read_config_byte
(
dev
,
PCI_CLASS_PROG
,
&
progif
)
||
(
progif
&
5
)
!=
5
)
{
if
((
progif
&
0xa
)
!=
0xa
)
{
printk
(
"%s: device not capable of full "
"native PCI mode
\n
"
,
name
);
return
1
;
}
printk
(
"%s: placing both ports into native PCI mode
\n
"
,
name
);
(
void
)
pci_write_config_byte
(
dev
,
PCI_CLASS_PROG
,
progif
|
5
);
if
(
pci_read_config_byte
(
dev
,
PCI_CLASS_PROG
,
&
progif
)
||
(
progif
&
5
)
!=
5
)
{
printk
(
"%s: rewrite of PROGIF failed, wanted 0x%04x, got 0x%04x
\n
"
,
name
,
progif
|
5
,
progif
);
return
1
;
}
}
/*
* Setup base registers for IDE command/control spaces for each interface:
*/
for
(
reg
=
0
;
reg
<
4
;
reg
++
)
{
struct
resource
*
res
=
dev
->
resource
+
reg
;
if
((
res
->
flags
&
IORESOURCE_IO
)
==
0
)
continue
;
if
(
!
res
->
start
)
{
printk
(
"%s: Missing I/O address #%d
\n
"
,
name
,
reg
);
return
1
;
}
}
return
0
;
}
/*
* ide_setup_pci_device() looks at the primary/secondary interfaces
* on a PCI IDE device and, if they are enabled, prepares the IDE driver
* for use with them. This generic code works for most PCI chipsets.
*
* One thing that is not standardized is the location of the
* primary/secondary interface "enable/disable" bits. For chipsets that
* we "know" about, this information is in the ide_pci_device_t struct;
* for all other chipsets, we just assume both interfaces are enabled.
*/
void
__init
ide_setup_pci_device
(
struct
pci_dev
*
dev
,
ide_pci_device_t
*
d
)
{
unsigned
int
port
,
at_least_one_hwif_enabled
=
0
,
autodma
=
0
,
pciirq
=
0
;
unsigned
short
pcicmd
=
0
,
tried_config
=
0
;
byte
tmp
=
0
;
ide_hwif_t
*
hwif
,
*
mate
=
NULL
;
unsigned
int
class_rev
;
static
int
secondpdc
=
0
;
#ifdef CONFIG_IDEDMA_AUTO
if
(
!
noautodma
)
autodma
=
1
;
#endif
if
(
d
->
init_hwif
==
IDE_NO_DRIVER
)
{
printk
(
KERN_WARNING
"%s: detected chipset, "
"but driver not compiled in!
\n
"
,
d
->
name
);
d
->
init_hwif
=
NULL
;
}
if
(
pci_enable_device
(
dev
))
{
printk
(
KERN_WARNING
"%s: (ide_setup_pci_device:) "
"Could not enable device.
\n
"
,
d
->
name
);
return
;
}
check_if_enabled:
if
(
pci_read_config_word
(
dev
,
PCI_COMMAND
,
&
pcicmd
))
{
printk
(
"%s: error accessing PCI regs
\n
"
,
d
->
name
);
return
;
}
if
(
!
(
pcicmd
&
PCI_COMMAND_IO
))
{
/* is device disabled? */
/*
* PnP BIOS was *supposed* to have set this device up for us,
* but we can do it ourselves, so long as the BIOS has assigned an IRQ
* (or possibly the device is using a "legacy header" for IRQs).
* Maybe the user deliberately *disabled* the device,
* but we'll eventually ignore it again if no drives respond.
*/
if
(
tried_config
++
||
ide_setup_pci_baseregs
(
dev
,
d
->
name
)
||
pci_write_config_word
(
dev
,
PCI_COMMAND
,
pcicmd
|
PCI_COMMAND_IO
))
{
printk
(
"%s: device disabled (BIOS)
\n
"
,
d
->
name
);
return
;
}
autodma
=
0
;
/* default DMA off if we had to configure it here */
goto
check_if_enabled
;
}
if
(
tried_config
)
printk
(
"%s: device enabled (Linux)
\n
"
,
d
->
name
);
pci_read_config_dword
(
dev
,
PCI_CLASS_REVISION
,
&
class_rev
);
class_rev
&=
0xff
;
printk
(
"%s: chipset revision %d
\n
"
,
d
->
name
,
class_rev
);
/*
* Can we trust the reported IRQ?
*/
pciirq
=
dev
->
irq
;
if
((
dev
->
class
&
~
(
0xfa
))
!=
((
PCI_CLASS_STORAGE_IDE
<<
8
)
|
5
))
{
printk
(
"%s: not 100%% native mode: "
"will probe irqs later
\n
"
,
d
->
name
);
/*
* This allows offboard ide-pci cards the enable a BIOS,
* verify interrupt settings of split-mirror pci-config
* space, place chipset into init-mode, and/or preserve
* an interrupt if the card is not native ide support.
*/
pciirq
=
(
d
->
init_chipset
)
?
d
->
init_chipset
(
dev
,
d
->
name
)
:
ide_special_settings
(
dev
,
d
->
name
);
}
else
if
(
tried_config
)
{
printk
(
"%s: will probe irqs later
\n
"
,
d
->
name
);
pciirq
=
0
;
}
else
if
(
!
pciirq
)
{
printk
(
"%s: bad irq (%d): will probe later
\n
"
,
d
->
name
,
pciirq
);
pciirq
=
0
;
}
else
{
if
(
d
->
init_chipset
)
(
void
)
d
->
init_chipset
(
dev
,
d
->
name
);
#ifdef __sparc__
printk
(
"%s: 100%% native mode on irq %s
\n
"
,
d
->
name
,
__irq_itoa
(
pciirq
));
#else
printk
(
"%s: 100%% native mode on irq %d
\n
"
,
d
->
name
,
pciirq
);
#endif
}
/*
* Set up the IDE ports
*/
for
(
port
=
0
;
port
<=
1
;
++
port
)
{
unsigned
long
base
=
0
,
ctl
=
0
;
ide_pci_enablebit_t
*
e
=
&
(
d
->
enablebits
[
port
]);
/*
* If this is a Promise FakeRaid controller,
* the 2nd controller will be marked as
* disabled while it is actually there and enabled
* by the bios for raid purposes.
* Skip the normal "is it enabled" test for those.
*/
if
((
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20265
))
&&
(
secondpdc
++==
1
)
&&
(
port
==
1
))
goto
controller_ok
;
if
((
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20262
))
&&
(
secondpdc
++==
1
)
&&
(
port
==
1
))
goto
controller_ok
;
if
(
e
->
reg
&&
(
pci_read_config_byte
(
dev
,
e
->
reg
,
&
tmp
)
||
(
tmp
&
e
->
mask
)
!=
e
->
val
))
continue
;
/* port not enabled */
controller_ok:
if
(
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_HPT366
)
&&
(
port
)
&&
(
class_rev
<
0x03
))
return
;
if
(
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_HPT302
)
&&
(
port
))
return
;
if
(
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_CSB6
)
&&
(
port
)
&&
(
!
(
PCI_FUNC
(
dev
->
devfn
)
&
1
)))
return
;
if
((
dev
->
class
>>
8
)
!=
PCI_CLASS_STORAGE_IDE
||
(
dev
->
class
&
(
port
?
4
:
1
))
!=
0
)
{
ctl
=
dev
->
resource
[(
2
*
port
)
+
1
].
start
;
base
=
dev
->
resource
[
2
*
port
].
start
;
if
(
!
(
ctl
&
PCI_BASE_ADDRESS_IO_MASK
)
||
!
(
base
&
PCI_BASE_ADDRESS_IO_MASK
))
{
printk
(
"%s: IO baseregs (BIOS) are reported "
"as MEM, report to "
"<andre@linux-ide.org>.
\n
"
,
d
->
name
);
#if 0
/*
* FIXME! This really should check that
* it really gets the IO/MEM part right!
*/
continue;
#endif
}
}
if
((
ctl
&&
!
base
)
||
(
base
&&
!
ctl
))
{
printk
(
"%s: inconsistent baseregs (BIOS) "
"for port %d, skipping
\n
"
,
d
->
name
,
port
);
continue
;
}
if
(
!
ctl
)
ctl
=
port
?
0x374
:
0x3f4
;
/* use default value */
if
(
!
base
)
base
=
port
?
0x170
:
0x1f0
;
/* use default value */
if
((
hwif
=
ide_match_hwif
(
base
,
d
->
bootable
,
d
->
name
))
==
NULL
)
continue
;
/* no room in ide_hwifs[] */
if
(
hwif
->
io_ports
[
IDE_DATA_OFFSET
]
!=
base
)
{
ide_init_hwif_ports
(
&
hwif
->
hw
,
base
,
(
ctl
|
2
),
NULL
);
memcpy
(
hwif
->
io_ports
,
hwif
->
hw
.
io_ports
,
sizeof
(
hwif
->
io_ports
));
hwif
->
noprobe
=
!
hwif
->
io_ports
[
IDE_DATA_OFFSET
];
}
hwif
->
chipset
=
ide_pci
;
hwif
->
pci_dev
=
dev
;
hwif
->
pci_devid
=
d
->
devid
;
hwif
->
channel
=
port
;
if
(
!
hwif
->
irq
)
hwif
->
irq
=
pciirq
;
if
(
mate
)
{
hwif
->
mate
=
mate
;
mate
->
mate
=
hwif
;
if
(
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_AEC6210
))
{
hwif
->
serialized
=
1
;
mate
->
serialized
=
1
;
}
}
if
(
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_UM8886A
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_UM8886BF
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_UM8673F
))
{
hwif
->
irq
=
hwif
->
channel
?
15
:
14
;
goto
bypass_umc_dma
;
}
if
(
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_MPIIX
))
goto
bypass_piix_dma
;
if
(
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDCADMA
))
goto
bypass_legacy_dma
;
if
(
hwif
->
udma_four
)
{
printk
(
"%s: ATA-66/100 forced bit set (WARNING)!!
\n
"
,
d
->
name
);
}
else
{
hwif
->
udma_four
=
(
d
->
ata66_check
)
?
d
->
ata66_check
(
hwif
)
:
0
;
}
#ifdef CONFIG_BLK_DEV_IDEDMA
if
(
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_SIS5513
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_AEC6260
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PIIX4NX
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_HPT34X
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_VIA_IDE
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_MR_IDE
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_VP_IDE
))
autodma
=
0
;
if
(
autodma
)
hwif
->
autodma
=
1
;
if
(
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20246
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20262
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20263
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20265
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20267
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20268
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20268R
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20269
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20271
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20275
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20276
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_PDC20277
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_AEC6210
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_AEC6260
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_AEC6260R
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_AEC6280
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_AEC6880
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_HPT34X
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_HPT366
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_HPT372
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_HPT302
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_HPT371
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_HPT374
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_CS5530
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_CY82C693
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_CMD646
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_CMD648
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_CMD649
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_CMD680
)
||
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_OSB4
)
||
((
dev
->
class
>>
8
)
==
PCI_CLASS_STORAGE_IDE
&&
(
dev
->
class
&
0x80
)))
{
unsigned
long
dma_base
=
ide_get_or_set_dma_base
(
hwif
,
(
!
mate
&&
d
->
extra
)
?
d
->
extra
:
0
,
d
->
name
);
if
(
dma_base
&&
!
(
pcicmd
&
PCI_COMMAND_MASTER
))
{
/*
* Set up BM-DMA capability (PnP BIOS should have done this)
*/
if
(
!
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_CS5530
))
hwif
->
autodma
=
0
;
/* default DMA off if we had to configure it here */
(
void
)
pci_write_config_word
(
dev
,
PCI_COMMAND
,
pcicmd
|
PCI_COMMAND_MASTER
);
if
(
pci_read_config_word
(
dev
,
PCI_COMMAND
,
&
pcicmd
)
||
!
(
pcicmd
&
PCI_COMMAND_MASTER
))
{
printk
(
"%s: %s error updating PCICMD
\n
"
,
hwif
->
name
,
d
->
name
);
dma_base
=
0
;
}
}
if
(
dma_base
)
{
if
(
d
->
dma_init
)
{
d
->
dma_init
(
hwif
,
dma_base
);
}
else
{
ide_setup_dma
(
hwif
,
dma_base
,
8
);
}
}
else
{
printk
(
"%s: %s Bus-Master DMA disabled (BIOS)
\n
"
,
hwif
->
name
,
d
->
name
);
}
}
#endif
/* CONFIG_BLK_DEV_IDEDMA */
bypass_legacy_dma:
bypass_piix_dma:
bypass_umc_dma:
if
(
d
->
init_hwif
)
/* Call chipset-specific routine for each enabled hwif */
d
->
init_hwif
(
hwif
);
mate
=
hwif
;
at_least_one_hwif_enabled
=
1
;
}
if
(
!
at_least_one_hwif_enabled
)
printk
(
"%s: neither IDE port enabled (BIOS)
\n
"
,
d
->
name
);
}
/*
* ide_scan_pcibus() gets invoked at boot time from ide.c.
* It finds all PCI IDE controllers and calls ide_setup_pci_device for them.
*/
void
__init
ide_scan_pcidev
(
struct
pci_dev
*
dev
)
{
ide_pci_devid_t
devid
;
ide_pci_device_t
*
d
;
devid
.
vid
=
dev
->
vendor
;
devid
.
did
=
dev
->
device
;
for
(
d
=
ide_pci_chipsets
;
d
->
devid
.
vid
&&
!
IDE_PCI_DEVID_EQ
(
d
->
devid
,
devid
);
++
d
);
if
(
d
->
init_hwif
==
IDE_IGNORE
)
printk
(
"%s: ignored by ide_scan_pci_device() "
"(uses own driver)
\n
"
,
d
->
name
);
else
if
(
d
->
fixup_device
)
d
->
fixup_device
(
dev
,
d
);
#if 0
else if (((dev->class >> 8) != PCI_CLASS_STORAGE_IDE) &&
(!(PCI_FUNC(dev->devfn) & 1)))
return;
#endif
else
if
(
IDE_PCI_DEVID_EQ
(
d
->
devid
,
DEVID_UM8886A
)
&&
(
!
(
PCI_FUNC
(
dev
->
devfn
)
&
1
)))
return
;
/* UM8886A/BF pair */
else
if
(
!
IDE_PCI_DEVID_EQ
(
d
->
devid
,
IDE_PCI_DEVID_NULL
)
||
(
dev
->
class
>>
8
)
==
PCI_CLASS_STORAGE_IDE
)
{
if
(
IDE_PCI_DEVID_EQ
(
d
->
devid
,
IDE_PCI_DEVID_NULL
))
printk
(
"%s: unknown IDE controller on PCI bus "
"%02x device %02x, VID=%04x, DID=%04x
\n
"
,
d
->
name
,
dev
->
bus
->
number
,
dev
->
devfn
,
devid
.
vid
,
devid
.
did
);
else
printk
(
"%s: IDE controller on PCI bus %02x dev %02x
\n
"
,
d
->
name
,
dev
->
bus
->
number
,
dev
->
devfn
);
ide_setup_pci_device
(
dev
,
d
);
}
}
void
__init
ide_scan_pcibus
(
int
scan_direction
)
{
struct
pci_dev
*
dev
;
if
(
!
scan_direction
)
{
pci_for_each_dev
(
dev
)
{
ide_scan_pcidev
(
dev
);
}
}
else
{
pci_for_each_dev_reverse
(
dev
)
{
ide_scan_pcidev
(
dev
);
}
}
}
drivers/ide/setup-pci.c
0 → 100644
View file @
5023a3cb
/*
* linux/drivers/ide/setup-pci.c Version 1.10 2002/08/19
*
* Copyright (c) 1998-2000 Andre Hedrick <andre@linux-ide.org>
*
* Copyright (c) 1995-1998 Mark Lord
* May be copied or modified under the terms of the GNU General Public License
*
* Recent Changes
* Split the set up function into multiple functions
* Use pci_set_master
* Fix misreporting of I/O v MMIO problems
*/
/*
* This module provides support for automatic detection and
* configuration of all PCI IDE interfaces present in a system.
*/
#include <linux/config.h>
#include <linux/module.h>
#include <linux/types.h>
#include <linux/kernel.h>
#include <linux/pci.h>
#include <linux/init.h>
#include <linux/timer.h>
#include <linux/mm.h>
#include <linux/interrupt.h>
#include <linux/ide.h>
#include <asm/io.h>
#include <asm/irq.h>
/**
* ide_match_hwif - match a PCI IDE against an ide_hwif
* @io_base: I/O base of device
* @bootable: set if its bootable
* @name: name of device
*
* Match a PCI IDE port against an entry in ide_hwifs[],
* based on io_base port if possible. Return the matching hwif,
* or a new hwif. If we find an error (clashing, out of devices, etc)
* return NULL
*/
static
ide_hwif_t
*
ide_match_hwif
(
unsigned
long
io_base
,
u8
bootable
,
const
char
*
name
)
{
int
h
;
ide_hwif_t
*
hwif
;
/*
* Look for a hwif with matching io_base specified using
* parameters to ide_setup().
*/
for
(
h
=
0
;
h
<
MAX_HWIFS
;
++
h
)
{
hwif
=
&
ide_hwifs
[
h
];
if
(
hwif
->
io_ports
[
IDE_DATA_OFFSET
]
==
io_base
)
{
if
(
hwif
->
chipset
==
ide_generic
)
return
hwif
;
/* a perfect match */
}
}
/*
* Look for a hwif with matching io_base default value.
* If chipset is "ide_unknown", then claim that hwif slot.
* Otherwise, some other chipset has already claimed it.. :(
*/
for
(
h
=
0
;
h
<
MAX_HWIFS
;
++
h
)
{
hwif
=
&
ide_hwifs
[
h
];
if
(
hwif
->
io_ports
[
IDE_DATA_OFFSET
]
==
io_base
)
{
if
(
hwif
->
chipset
==
ide_unknown
)
return
hwif
;
/* match */
printk
(
KERN_ERR
"%s: port 0x%04lx already claimed by %s
\n
"
,
name
,
io_base
,
hwif
->
name
);
return
NULL
;
/* already claimed */
}
}
/*
* Okay, there is no hwif matching our io_base,
* so we'll just claim an unassigned slot.
* Give preference to claiming other slots before claiming ide0/ide1,
* just in case there's another interface yet-to-be-scanned
* which uses ports 1f0/170 (the ide0/ide1 defaults).
*
* Unless there is a bootable card that does not use the standard
* ports 1f0/170 (the ide0/ide1 defaults). The (bootable) flag.
*/
if
(
bootable
)
{
for
(
h
=
0
;
h
<
MAX_HWIFS
;
++
h
)
{
hwif
=
&
ide_hwifs
[
h
];
if
(
hwif
->
chipset
==
ide_unknown
)
return
hwif
;
/* pick an unused entry */
}
}
else
{
for
(
h
=
2
;
h
<
MAX_HWIFS
;
++
h
)
{
hwif
=
ide_hwifs
+
h
;
if
(
hwif
->
chipset
==
ide_unknown
)
return
hwif
;
/* pick an unused entry */
}
}
for
(
h
=
0
;
h
<
2
;
++
h
)
{
hwif
=
ide_hwifs
+
h
;
if
(
hwif
->
chipset
==
ide_unknown
)
return
hwif
;
/* pick an unused entry */
}
printk
(
KERN_ERR
"%s: too many IDE interfaces, no room in table
\n
"
,
name
);
return
NULL
;
}
/**
* ide_setup_pci_baseregs - place a PCI IDE controller native
* @dev: PCI device of interface to switch native
* @name: Name of interface
*
* We attempt to place the PCI interface into PCI native mode. If
* we succeed the BARs are ok and the controller is in PCI mode.
* Returns 0 on success or an errno code.
*
* FIXME: if we program the interface and then fail to set the BARS
* we don't switch it back to legacy mode. Do we actually care ??
*/
static
int
ide_setup_pci_baseregs
(
struct
pci_dev
*
dev
,
const
char
*
name
)
{
u8
progif
=
0
;
/*
* Place both IDE interfaces into PCI "native" mode:
*/
if
(
pci_read_config_byte
(
dev
,
PCI_CLASS_PROG
,
&
progif
)
||
(
progif
&
5
)
!=
5
)
{
if
((
progif
&
0xa
)
!=
0xa
)
{
printk
(
KERN_INFO
"%s: device not capable of full "
"native PCI mode
\n
"
,
name
);
return
-
EOPNOTSUPP
;
}
printk
(
"%s: placing both ports into native PCI mode
\n
"
,
name
);
(
void
)
pci_write_config_byte
(
dev
,
PCI_CLASS_PROG
,
progif
|
5
);
if
(
pci_read_config_byte
(
dev
,
PCI_CLASS_PROG
,
&
progif
)
||
(
progif
&
5
)
!=
5
)
{
printk
(
KERN_ERR
"%s: rewrite of PROGIF failed, wanted "
"0x%04x, got 0x%04x
\n
"
,
name
,
progif
|
5
,
progif
);
return
-
EOPNOTSUPP
;
}
}
#if 0
/*
* At this point we have enabled the device, but may previously
* have done a BAR4 enable alone. We should be prepared to assign
* resources here.
*/
/*
* Setup base registers for IDE command/control
* spaces for each interface:
*/
for (reg = 0; reg < 4; reg++) {
struct resource *res = dev->resource + reg;
if ((res->flags & IORESOURCE_IO) == 0)
continue;
if (!res->start) {
if(pci_assign_resource(dev, reg)) {
printk(KERN_ERR "%s: Missing I/O address #%d\n", name, reg);
return -ENXIO;
}
}
}
#endif
return
0
;
}
#ifdef CONFIG_BLK_DEV_IDEDMA
#ifdef CONFIG_BLK_DEV_IDEDMA_FORCED
/*
* Long lost data from 2.0.34 that is now in 2.0.39
*
* This was used in ./drivers/block/triton.c to do DMA Base address setup
* when PnP failed. Oh the things we forget. I believe this was part
* of SFF-8038i that has been withdrawn from public access... :-((
*/
#define DEFAULT_BMIBA 0xe800
/* in case BIOS did not init it */
#define DEFAULT_BMCRBA 0xcc00
/* VIA's default value */
#define DEFAULT_BMALIBA 0xd400
/* ALI's default value */
#endif
/* CONFIG_BLK_DEV_IDEDMA_FORCED */
/**
* ide_get_or_set_dma_base - setup BMIBA
* @hwif: Interface
*
* Fetch the DMA Bus-Master-I/O-Base-Address (BMIBA) from PCI space:
* If need be we set up the DMA base. Where a device has a partner that
* is already in DMA mode we check and enforce IDE simplex rules.
*
* FIXME: currently we are sometimes enforicng simplex when it is not
* needed. We fail the safe way but why is it occurring ??
*/
static
unsigned
long
__init
ide_get_or_set_dma_base
(
ide_hwif_t
*
hwif
)
{
unsigned
long
dma_base
=
0
;
struct
pci_dev
*
dev
=
hwif
->
pci_dev
;
#ifdef CONFIG_BLK_DEV_IDEDMA_FORCED
int
second_chance
=
0
;
second_chance_to_dma:
#endif
/* CONFIG_BLK_DEV_IDEDMA_FORCED */
if
((
hwif
->
mmio
)
&&
(
hwif
->
dma_base
))
return
hwif
->
dma_base
;
if
(
hwif
->
mate
&&
hwif
->
mate
->
dma_base
)
{
dma_base
=
hwif
->
mate
->
dma_base
-
(
hwif
->
channel
?
0
:
8
);
}
else
{
dma_base
=
(
hwif
->
mmio
)
?
((
unsigned
long
)
hwif
->
hwif_data
)
:
(
pci_resource_start
(
dev
,
4
));
if
(
!
dma_base
)
{
printk
(
KERN_ERR
"%s: dma_base is invalid (0x%04lx)
\n
"
,
hwif
->
cds
->
name
,
dma_base
);
dma_base
=
0
;
}
}
#ifdef CONFIG_BLK_DEV_IDEDMA_FORCED
/* FIXME - should use pci_assign_resource surely */
if
((
!
dma_base
)
&&
(
!
second_chance
))
{
unsigned
long
set_bmiba
=
0
;
second_chance
++
;
switch
(
dev
->
vendor
)
{
case
PCI_VENDOR_ID_AL
:
set_bmiba
=
DEFAULT_BMALIBA
;
break
;
case
PCI_VENDOR_ID_VIA
:
set_bmiba
=
DEFAULT_BMCRBA
;
break
;
case
PCI_VENDOR_ID_INTEL
:
set_bmiba
=
DEFAULT_BMIBA
;
break
;
default:
return
dma_base
;
}
pci_write_config_dword
(
dev
,
0x20
,
set_bmiba
|
1
);
goto
second_chance_to_dma
;
}
#endif
/* CONFIG_BLK_DEV_IDEDMA_FORCED */
if
(
dma_base
)
{
u8
simplex_stat
=
0
;
dma_base
+=
hwif
->
channel
?
8
:
0
;
switch
(
dev
->
device
)
{
case
PCI_DEVICE_ID_AL_M5219
:
case
PCI_DEVICE_ID_AMD_VIPER_7409
:
case
PCI_DEVICE_ID_CMD_643
:
case
PCI_DEVICE_ID_SERVERWORKS_CSB5IDE
:
simplex_stat
=
hwif
->
INB
(
dma_base
+
2
);
hwif
->
OUTB
((
simplex_stat
&
0x60
),(
dma_base
+
2
));
simplex_stat
=
hwif
->
INB
(
dma_base
+
2
);
if
(
simplex_stat
&
0x80
)
{
printk
(
KERN_INFO
"%s: simplex device: "
"DMA forced
\n
"
,
hwif
->
cds
->
name
);
}
break
;
default:
/*
* If the device claims "simplex" DMA,
* this means only one of the two interfaces
* can be trusted with DMA at any point in time.
* So we should enable DMA only on one of the
* two interfaces.
*/
simplex_stat
=
hwif
->
INB
(
dma_base
+
2
);
if
(
simplex_stat
&
0x80
)
{
/* simplex device? */
/* Don't enable DMA on a simplex channel with no drives */
if
(
!
hwif
->
drives
[
0
].
present
&&
!
hwif
->
drives
[
1
].
present
)
{
printk
(
KERN_INFO
"%s: simplex device with no drives: DMA disabled
\n
"
,
hwif
->
cds
->
name
);
dma_base
=
0
;
}
/* If our other channel has DMA then we cannot */
else
if
(
hwif
->
mate
&&
hwif
->
mate
->
dma_base
)
{
printk
(
KERN_INFO
"%s: simplex device: "
"DMA disabled
\n
"
,
hwif
->
cds
->
name
);
dma_base
=
0
;
}
}
}
}
return
dma_base
;
}
#endif
/* CONFIG_BLK_DEV_IDEDMA */
static
void
ide_setup_pci_noise
(
struct
pci_dev
*
dev
,
ide_pci_device_t
*
d
)
{
if
((
d
->
vendor
!=
dev
->
vendor
)
&&
(
d
->
device
!=
dev
->
device
))
{
printk
(
KERN_INFO
"%s: unknown IDE controller at PCI slot "
"%s, VID=%04x, DID=%04x
\n
"
,
d
->
name
,
dev
->
slot_name
,
dev
->
vendor
,
dev
->
device
);
}
else
{
printk
(
KERN_INFO
"%s: IDE controller at PCI slot %s
\n
"
,
d
->
name
,
dev
->
slot_name
);
}
}
/**
* ide_pci_enable - do PCI enables
* @dev: PCI device
* @d: IDE pci device data
*
* Enable the IDE PCI device. We attempt to enable the device in full
* but if that fails then we only need BAR4 so we will enable that.
*
* Returns zero on success or an error code
*/
static
int
ide_pci_enable
(
struct
pci_dev
*
dev
,
ide_pci_device_t
*
d
)
{
if
(
pci_enable_device
(
dev
))
{
if
(
pci_enable_device_bars
(
dev
,
1
<<
4
))
{
printk
(
KERN_WARNING
"%s: (ide_setup_pci_device:) "
"Could not enable device.
\n
"
,
d
->
name
);
return
-
EBUSY
;
}
else
printk
(
KERN_WARNING
"%s: Not fully BIOS configured!
\n
"
,
d
->
name
);
}
/* FIXME: Temporary - until we put in the hotplug interface logic
Check that the bits we want are not in use by someone else */
if
(
pci_request_region
(
dev
,
4
,
"ide_tmp"
))
return
-
EBUSY
;
pci_release_region
(
dev
,
4
);
return
0
;
}
/**
* ide_pci_configure - configure an unconfigured device
* @dev: PCI device
* @d: IDE pci device data
*
* Enable and configure the PCI device we have been passed.
* Returns zero on success or an error code.
*/
static
int
ide_pci_configure
(
struct
pci_dev
*
dev
,
ide_pci_device_t
*
d
)
{
u16
pcicmd
=
0
;
/*
* PnP BIOS was *supposed* to have setup this device, but we
* can do it ourselves, so long as the BIOS has assigned an IRQ
* (or possibly the device is using a "legacy header" for IRQs).
* Maybe the user deliberately *disabled* the device,
* but we'll eventually ignore it again if no drives respond.
*/
if
(
ide_setup_pci_baseregs
(
dev
,
d
->
name
)
||
pci_write_config_word
(
dev
,
PCI_COMMAND
,
pcicmd
|
PCI_COMMAND_IO
))
{
printk
(
KERN_INFO
"%s: device disabled (BIOS)
\n
"
,
d
->
name
);
return
-
ENODEV
;
}
if
(
pci_read_config_word
(
dev
,
PCI_COMMAND
,
&
pcicmd
))
{
printk
(
KERN_ERR
"%s: error accessing PCI regs
\n
"
,
d
->
name
);
return
-
EIO
;
}
if
(
!
(
pcicmd
&
PCI_COMMAND_IO
))
{
printk
(
KERN_ERR
"%s: unable to enable IDE controller
\n
"
,
d
->
name
);
return
-
ENXIO
;
}
return
0
;
}
/**
* ide_pci_check_iomem - check a register is I/O
* @dev: pci device
* @d: ide_pci_device
* @bar: bar number
*
* Checks if a BAR is configured and points to MMIO space. If so
* print an error and return an error code. Otherwise return 0
*/
static
int
ide_pci_check_iomem
(
struct
pci_dev
*
dev
,
ide_pci_device_t
*
d
,
int
bar
)
{
ulong
flags
=
pci_resource_flags
(
dev
,
bar
);
/* Unconfigured ? */
if
(
pci_resource_len
(
dev
,
bar
)
==
0
)
return
0
;
/* I/O space */
if
(
flags
&
PCI_BASE_ADDRESS_IO_MASK
)
return
0
;
/* Bad */
printk
(
KERN_ERR
"%s: IO baseregs (BIOS) are reported "
"as MEM, report to "
"<andre@linux-ide.org>.
\n
"
,
d
->
name
);
return
-
EINVAL
;
}
/**
* ide_hwif_configure - configure an IDE interface
* @dev: PCI device holding interface
* @d: IDE pci data
* @mate: Paired interface if any
*
* Perform the initial set up for the hardware interface structure. This
* is done per interface port rather than per PCI device. There may be
* more than one port per device.
*
* Returns the new hardware interface structure, or NULL on a failure
*/
static
ide_hwif_t
*
ide_hwif_configure
(
struct
pci_dev
*
dev
,
ide_pci_device_t
*
d
,
ide_hwif_t
*
mate
,
int
port
,
int
irq
)
{
unsigned
long
ctl
=
0
,
base
=
0
;
ide_hwif_t
*
hwif
;
if
((
dev
->
class
>>
8
)
!=
PCI_CLASS_STORAGE_IDE
||
((
dev
->
class
&
~
(
0xfa
)))
||
(
dev
->
class
&
(
port
?
4
:
1
))
!=
0
)
{
/* Possibly we should fail if these checks report true */
ide_pci_check_iomem
(
dev
,
d
,
2
*
port
);
ide_pci_check_iomem
(
dev
,
d
,
2
*
port
+
1
);
ctl
=
pci_resource_start
(
dev
,
2
*
port
+
1
);
base
=
pci_resource_start
(
dev
,
2
*
port
);
if
((
ctl
&&
!
base
)
||
(
base
&&
!
ctl
))
{
printk
(
KERN_ERR
"%s: inconsistent baseregs (BIOS) "
"for port %d, skipping
\n
"
,
d
->
name
,
port
);
return
NULL
;
}
}
if
(
!
ctl
)
{
/* Use default values */
ctl
=
port
?
0x374
:
0x3f4
;
base
=
port
?
0x170
:
0x1f0
;
}
if
((
hwif
=
ide_match_hwif
(
base
,
d
->
bootable
,
d
->
name
))
==
NULL
)
return
NULL
;
/* no room in ide_hwifs[] */
if
(
hwif
->
io_ports
[
IDE_DATA_OFFSET
]
!=
base
)
{
fixup_address:
ide_init_hwif_ports
(
&
hwif
->
hw
,
base
,
(
ctl
|
2
),
NULL
);
memcpy
(
hwif
->
io_ports
,
hwif
->
hw
.
io_ports
,
sizeof
(
hwif
->
io_ports
));
hwif
->
noprobe
=
!
hwif
->
io_ports
[
IDE_DATA_OFFSET
];
}
else
if
(
hwif
->
io_ports
[
IDE_CONTROL_OFFSET
]
!=
(
ctl
|
2
))
{
goto
fixup_address
;
}
hwif
->
chipset
=
ide_pci
;
hwif
->
pci_dev
=
dev
;
hwif
->
cds
=
(
struct
ide_pci_device_s
*
)
d
;
hwif
->
channel
=
port
;
if
(
!
hwif
->
irq
)
hwif
->
irq
=
irq
;
if
(
mate
)
{
hwif
->
mate
=
mate
;
mate
->
mate
=
hwif
;
}
return
hwif
;
}
/**
* ide_hwif_setup_dma - configure DMA interface
* @dev: PCI device
* @d: IDE pci data
* @hwif: Hardware interface we are configuring
*
* Set up the DMA base for the interface. Enable the master bits as
* neccessary and attempt to bring the device DMA into a ready to use
* state
*/
static
void
ide_hwif_setup_dma
(
struct
pci_dev
*
dev
,
ide_pci_device_t
*
d
,
ide_hwif_t
*
hwif
)
{
u16
pcicmd
;
pci_read_config_word
(
dev
,
PCI_COMMAND
,
&
pcicmd
);
if
((
d
->
autodma
==
AUTODMA
)
||
((
dev
->
class
>>
8
)
==
PCI_CLASS_STORAGE_IDE
&&
(
dev
->
class
&
0x80
)))
{
u32
dma_base
=
ide_get_or_set_dma_base
(
hwif
);
if
(
dma_base
&&
!
(
pcicmd
&
PCI_COMMAND_MASTER
))
{
/*
* Set up BM-DMA capability
* (PnP BIOS should have done this)
*/
if
((
d
->
device
!=
PCI_DEVICE_ID_CYRIX_5530_IDE
)
&&
(
d
->
vendor
!=
PCI_VENDOR_ID_CYRIX
))
{
/*
* default DMA off if we had to
* configure it here
*/
hwif
->
autodma
=
0
;
}
pci_set_master
(
dev
);
if
(
pci_read_config_word
(
dev
,
PCI_COMMAND
,
&
pcicmd
)
||
!
(
pcicmd
&
PCI_COMMAND_MASTER
))
{
printk
(
KERN_ERR
"%s: %s error updating PCICMD
\n
"
,
hwif
->
name
,
d
->
name
);
dma_base
=
0
;
}
}
if
(
dma_base
)
{
if
(
d
->
init_dma
)
{
d
->
init_dma
(
hwif
,
dma_base
);
}
else
{
ide_setup_dma
(
hwif
,
dma_base
,
8
);
}
}
else
{
printk
(
KERN_INFO
"%s: %s Bus-Master DMA disabled "
"(BIOS)
\n
"
,
hwif
->
name
,
d
->
name
);
}
}
}
/**
* ide_setup_pci_controller - set up IDE PCI
* @dev: PCI device
* @d: IDE PCI data
* @noisy: verbose flag
* @config: returned as 1 if we configured the hardware
*
* Set up the PCI and controller side of the IDE interface. This brings
* up the PCI side of the device, checks that the device is enabled
* and enables it if need be
*/
static
int
ide_setup_pci_controller
(
struct
pci_dev
*
dev
,
ide_pci_device_t
*
d
,
int
noisy
,
int
*
config
)
{
int
ret
=
0
;
u32
class_rev
;
u16
pcicmd
;
if
(
!
noautodma
)
ret
=
1
;
if
(
noisy
)
ide_setup_pci_noise
(
dev
,
d
);
if
(
ide_pci_enable
(
dev
,
d
))
return
-
EBUSY
;
if
(
pci_read_config_word
(
dev
,
PCI_COMMAND
,
&
pcicmd
))
{
printk
(
KERN_ERR
"%s: error accessing PCI regs
\n
"
,
d
->
name
);
return
-
EIO
;
}
if
(
!
(
pcicmd
&
PCI_COMMAND_IO
))
{
/* is device disabled? */
if
(
ide_pci_configure
(
dev
,
d
))
return
-
ENODEV
;
/* default DMA off if we had to configure it here */
ret
=
0
;
*
config
=
1
;
printk
(
KERN_INFO
"%s: device enabled (Linux)
\n
"
,
d
->
name
);
}
pci_read_config_dword
(
dev
,
PCI_CLASS_REVISION
,
&
class_rev
);
class_rev
&=
0xff
;
if
(
noisy
)
printk
(
KERN_INFO
"%s: chipset revision %d
\n
"
,
d
->
name
,
class_rev
);
return
ret
;
}
/*
* ide_setup_pci_device() looks at the primary/secondary interfaces
* on a PCI IDE device and, if they are enabled, prepares the IDE driver
* for use with them. This generic code works for most PCI chipsets.
*
* One thing that is not standardized is the location of the
* primary/secondary interface "enable/disable" bits. For chipsets that
* we "know" about, this information is in the ide_pci_device_t struct;
* for all other chipsets, we just assume both interfaces are enabled.
*/
static
ata_index_t
do_ide_setup_pci_device
(
struct
pci_dev
*
dev
,
ide_pci_device_t
*
d
,
u8
noisy
)
{
u32
port
,
at_least_one_hwif_enabled
=
0
,
autodma
=
0
;
int
pciirq
=
0
;
int
tried_config
=
0
;
ata_index_t
index
;
u8
tmp
=
0
;
ide_hwif_t
*
hwif
,
*
mate
=
NULL
;
static
int
secondpdc
=
0
;
index
.
all
=
0xf0f0
;
if
((
autodma
=
ide_setup_pci_controller
(
dev
,
d
,
noisy
,
&
tried_config
))
<
0
)
return
index
;
/*
* Can we trust the reported IRQ?
*/
pciirq
=
dev
->
irq
;
if
((
dev
->
class
&
~
(
0xfa
))
!=
((
PCI_CLASS_STORAGE_IDE
<<
8
)
|
5
))
{
if
(
noisy
)
printk
(
KERN_INFO
"%s: not 100%% native mode: "
"will probe irqs later
\n
"
,
d
->
name
);
/*
* This allows offboard ide-pci cards the enable a BIOS,
* verify interrupt settings of split-mirror pci-config
* space, place chipset into init-mode, and/or preserve
* an interrupt if the card is not native ide support.
*/
pciirq
=
(
d
->
init_chipset
)
?
d
->
init_chipset
(
dev
,
d
->
name
)
:
0
;
}
else
if
(
tried_config
)
{
if
(
noisy
)
printk
(
KERN_INFO
"%s: will probe irqs later
\n
"
,
d
->
name
);
pciirq
=
0
;
}
else
if
(
!
pciirq
)
{
if
(
noisy
)
printk
(
KERN_WARNING
"%s: bad irq (%d): will probe later
\n
"
,
d
->
name
,
pciirq
);
pciirq
=
0
;
}
else
{
if
(
d
->
init_chipset
)
{
if
(
d
->
init_chipset
(
dev
,
d
->
name
)
<
0
)
return
index
;
}
if
(
noisy
)
#ifdef __sparc__
printk
(
KERN_INFO
"%s: 100%% native mode on irq %s
\n
"
,
d
->
name
,
__irq_itoa
(
pciirq
));
#else
printk
(
KERN_INFO
"%s: 100%% native mode on irq %d
\n
"
,
d
->
name
,
pciirq
);
#endif
}
if
(
pciirq
<
0
)
/* Error not an IRQ */
return
index
;
/*
* Set up the IDE ports
*/
for
(
port
=
0
;
port
<=
1
;
++
port
)
{
ide_pci_enablebit_t
*
e
=
&
(
d
->
enablebits
[
port
]);
/*
* If this is a Promise FakeRaid controller,
* the 2nd controller will be marked as
* disabled while it is actually there and enabled
* by the bios for raid purposes.
* Skip the normal "is it enabled" test for those.
*/
if
(((
d
->
vendor
==
PCI_VENDOR_ID_PROMISE
)
&&
((
d
->
device
==
PCI_DEVICE_ID_PROMISE_20262
)
||
(
d
->
device
==
PCI_DEVICE_ID_PROMISE_20265
)))
&&
(
secondpdc
++==
1
)
&&
(
port
==
1
))
goto
controller_ok
;
if
(
e
->
reg
&&
(
pci_read_config_byte
(
dev
,
e
->
reg
,
&
tmp
)
||
(
tmp
&
e
->
mask
)
!=
e
->
val
))
continue
;
/* port not enabled */
controller_ok:
if
(
d
->
channels
<=
port
)
return
index
;
if
((
hwif
=
ide_hwif_configure
(
dev
,
d
,
mate
,
port
,
pciirq
))
==
NULL
)
continue
;
if
(
hwif
->
channel
)
{
index
.
b
.
high
=
hwif
->
index
;
}
else
{
index
.
b
.
low
=
hwif
->
index
;
}
if
(
d
->
init_iops
)
d
->
init_iops
(
hwif
);
#ifdef CONFIG_BLK_DEV_IDEDMA
if
(
d
->
autodma
==
NODMA
)
goto
bypass_legacy_dma
;
if
(
d
->
autodma
==
NOAUTODMA
)
autodma
=
0
;
if
(
autodma
)
hwif
->
autodma
=
1
;
ide_hwif_setup_dma
(
dev
,
d
,
hwif
);
bypass_legacy_dma:
#endif
/* CONFIG_BLK_DEV_IDEDMA */
if
(
d
->
init_hwif
)
/* Call chipset-specific routine
* for each enabled hwif
*/
d
->
init_hwif
(
hwif
);
mate
=
hwif
;
at_least_one_hwif_enabled
=
1
;
}
if
(
!
at_least_one_hwif_enabled
)
printk
(
KERN_INFO
"%s: neither IDE port enabled (BIOS)
\n
"
,
d
->
name
);
return
index
;
}
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
);
if
((
index_list
.
b
.
low
&
0xf0
)
!=
0xf0
)
probe_hwif_init
(
&
ide_hwifs
[
index_list
.
b
.
low
]);
if
((
index_list
.
b
.
high
&
0xf0
)
!=
0xf0
)
probe_hwif_init
(
&
ide_hwifs
[
index_list
.
b
.
high
]);
}
void
ide_setup_pci_devices
(
struct
pci_dev
*
dev
,
struct
pci_dev
*
dev2
,
ide_pci_device_t
*
d
)
{
ata_index_t
index_list
=
do_ide_setup_pci_device
(
dev
,
d
,
1
);
ata_index_t
index_list2
=
do_ide_setup_pci_device
(
dev2
,
d
,
0
);
if
((
index_list
.
b
.
low
&
0xf0
)
!=
0xf0
)
probe_hwif_init
(
&
ide_hwifs
[
index_list
.
b
.
low
]);
if
((
index_list
.
b
.
high
&
0xf0
)
!=
0xf0
)
probe_hwif_init
(
&
ide_hwifs
[
index_list
.
b
.
high
]);
if
((
index_list2
.
b
.
low
&
0xf0
)
!=
0xf0
)
probe_hwif_init
(
&
ide_hwifs
[
index_list2
.
b
.
low
]);
if
((
index_list2
.
b
.
high
&
0xf0
)
!=
0xf0
)
probe_hwif_init
(
&
ide_hwifs
[
index_list2
.
b
.
high
]);
}
/*
* ide_scan_pcibus() gets invoked at boot time from ide.c.
* It finds all PCI IDE controllers and calls ide_setup_pci_device for them.
*/
void
__init
ide_scan_pcidev
(
struct
pci_dev
*
dev
)
{
#if 0
printk(" PCI slot %s, VID=%04x, DID=%04x\n",
dev->slot_name, dev->vendor, dev->device);
#endif
if
((
dev
->
vendor
==
PCI_VENDOR_ID_CMD
)
&&
(
dev
->
device
==
PCI_DEVICE_ID_CMD_640
))
{
return
;
#ifdef CONFIG_BLK_DEV_ALI15X3
}{
extern
int
ali15x3_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
ali15x3_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_ALI15X3 */
#ifdef CONFIG_BLK_DEV_AMD74XX
}{
extern
int
amd74xx_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
amd74xx_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_AMD74XX */
#ifdef CONFIG_BLK_DEV_CS5530
}{
extern
int
cs5530_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
cs5530_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_CS5530 */
#ifdef CONFIG_BLK_DEV_CY82C693
}{
extern
int
cy82c693_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
cy82c693_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_CY82C693 */
#ifdef CONFIG_BLK_DEV_IT8172
}{
extern
int
it8172_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
it8172_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_IT8172 */
#ifdef CONFIG_BLK_DEV_NFORCE
}{
extern
int
nforce_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
nforce_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_NFORCE */
#ifdef CONFIG_BLK_DEV_NS87415
}{
extern
int
ns87415_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
ns87415_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_NS87415 */
#ifdef CONFIG_BLK_DEV_OPTI621
}{
extern
int
opti621_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
opti621_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_OPTI621 */
#ifdef CONFIG_BLK_DEV_PIIX
}{
extern
int
piix_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
piix_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_PIIX */
#ifdef CONFIG_BLK_DEV_RZ1000
}{
extern
int
rz1000_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
rz1000_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_RZ1000 */
#ifdef CONFIG_BLK_DEV_SVWKS
}{
extern
int
serverworks_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
serverworks_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_SVWKS */
#ifdef CONFIG_BLK_DEV_SIS5513
}{
extern
int
sis5513_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
sis5513_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_SIS5513 */
#ifdef CONFIG_BLK_DEV_SLC90E66
}{
extern
int
slc90e66_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
slc90e66_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_SLC90E66 */
#ifdef CONFIG_BLK_DEV_VIA82CXXX
}{
extern
int
via82cxxx_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
via82cxxx_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_VIA82CXXX */
#ifdef CONFIG_BLK_DEV_AEC62XX
}{
extern
int
aec62xx_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
aec62xx_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_AEC62XX */
#ifdef CONFIG_BLK_DEV_CMD64X
}{
extern
int
cmd64x_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
cmd64x_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_CMD64X */
#ifdef CONFIG_BLK_DEV_HPT34X
}{
extern
int
hpt34x_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
hpt34x_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_HPT34X */
#ifdef CONFIG_BLK_DEV_HPT366
}{
extern
int
hpt366_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
hpt366_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_HPT366 */
#ifdef CONFIG_BLK_DEV_PDC202XX_OLD
}{
extern
int
pdc202xx_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
pdc202xx_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_PDC202XX_OLD */
#ifdef CONFIG_BLK_DEV_PDC202XX_NEW
}{
extern
int
pdcnew_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
pdcnew_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_PDC202XX_NEW */
#ifdef CONFIG_BLK_DEV_PDC_ADMA
}{
extern
int
pdcadma_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
pdcadma_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_PDC_ADMA */
#ifdef CONFIG_BLK_DEV_SIIMAGE
}{
extern
int
siimage_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
siimage_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_SIIMAGE */
#ifdef CONFIG_BLK_DEV_SL82C105
}{
extern
int
sl82c105_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
sl82c105_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_SL82C105 */
#ifdef CONFIG_BLK_DEV_TRM290
}{
extern
int
trm290_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
trm290_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_TRM290 */
#ifdef CONFIG_BLK_DEV_GENERIC
}{
extern
int
generic_scan_pcidev
(
struct
pci_dev
*
dev
);
if
(
generic_scan_pcidev
(
dev
))
return
;
#endif
/* CONFIG_BLK_DEV_GENERIC */
}
}
/*
* Module interfaces - not yet functional.
*/
static
int
pre_init
=
1
;
/* Before first ordered IDE scan */
static
LIST_HEAD
(
ide_pci_drivers
);
/*
* ide_register_pci_driver - attach IDE driver
* @driver: pci driver
*
* Registers a driver with the IDE layer. The IDE layer arranges that
* boot time setup is done in the expected device order and then
* hands the controllers off to the core PCI code to do the rest of
* the work.
*
* The driver_data of the driver table must point to an ide_pci_device_t
* describing the interface.
*
* Returns are the same as for pci_register_driver
*/
int
ide_register_pci_driver
(
struct
pci_driver
*
driver
)
{
if
(
!
pre_init
)
return
pci_register_driver
(
driver
);
list_add_tail
(
&
driver
->
node
,
&
ide_pci_drivers
);
return
0
;
}
EXPORT_SYMBOL
(
ide_register_pci_driver
);
/**
* ide_unregister_pci_driver - unregister an IDE driver
* @driver: driver to remove
*
* Unregister a currently installed IDE driver. Returns are the same
* as for pci_unregister_driver
*/
void
ide_unregister_pci_driver
(
struct
pci_driver
*
driver
)
{
if
(
!
pre_init
)
pci_unregister_driver
(
driver
);
else
list_del
(
&
driver
->
node
);
}
EXPORT_SYMBOL
(
ide_unregister_pci_driver
);
/**
* ide_scan_pcibus - perform the initial IDE driver scan
* @scan_direction: set for reverse order scanning
*
* Perform the initial bus rather than driver ordered scan of the
* PCI drivers. After this all IDE pci handling becomes standard
* module ordering not traditionally ordered.
*/
void
__init
ide_scan_pcibus
(
int
scan_direction
)
{
struct
pci_dev
*
dev
;
pre_init
=
0
;
if
(
!
scan_direction
)
{
pci_for_each_dev
(
dev
)
{
ide_scan_pcidev
(
dev
);
}
}
else
{
pci_for_each_dev_reverse
(
dev
)
{
ide_scan_pcidev
(
dev
);
}
}
/* FIXME: now add the drivers list to the real pci probe list */
}
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