2005-04-16 15:20:36 -07:00
/*
* Copyright ( C ) 2001 - 2002 Andre Hedrick < andre @ linux - ide . org >
* Portions ( C ) Copyright 2002 Red Hat Inc < alan @ redhat . com >
*
* This program is free software ; you can redistribute it and / or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation ; either version 2 , or ( at your option ) any
* later version .
*
* This program is distributed in the hope that it will be useful , but
* WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* General Public License for more details .
*
* For the avoidance of doubt the " preferred form " of this code is one which
* is in an open non patent encumbered format . Where cryptographic key signing
* forms part of the process of creating an executable the information
* including keys needed to generate an equivalently functional executable
* are deemed to be part of the source code .
*/
# include <linux/types.h>
# include <linux/module.h>
# include <linux/kernel.h>
# include <linux/hdreg.h>
# include <linux/pci.h>
# include <linux/ide.h>
# include <linux/init.h>
2005-06-27 15:24:26 -07:00
static int ide_generic_all ; /* Set to claim all devices */
2006-10-03 01:14:34 -07:00
module_param_named ( all_generic_ide , ide_generic_all , bool , 0444 ) ;
MODULE_PARM_DESC ( all_generic_ide , " IDE generic will claim all unknown PCI IDE storage controllers. " ) ;
2005-06-27 15:24:26 -07:00
2007-10-20 00:32:30 +02:00
# define IDE_HFLAGS_UMC (IDE_HFLAG_NO_DMA | IDE_HFLAG_FORCE_LEGACY_IRQS)
2005-04-16 15:20:36 -07:00
2007-10-20 00:32:30 +02:00
# define DECLARE_GENERIC_PCI_DEV(name_str, extra_flags) \
2007-10-19 00:30:06 +02:00
{ \
. name = name_str , \
2007-10-19 00:30:06 +02:00
. host_flags = IDE_HFLAG_TRUST_BIOS_FOR_DMA | \
2008-04-26 17:36:35 +02:00
extra_flags , \
2007-10-19 00:30:07 +02:00
. swdma_mask = ATA_SWDMA2 , \
. mwdma_mask = ATA_MWDMA2 , \
. udma_mask = ATA_UDMA6 , \
2005-04-16 15:20:36 -07:00
}
2007-10-20 00:32:34 +02:00
static const struct ide_port_info generic_chipsets [ ] __devinitdata = {
2007-10-19 00:30:06 +02:00
/* 0 */ DECLARE_GENERIC_PCI_DEV ( " Unknown " , 0 ) ,
2007-10-19 00:30:06 +02:00
{ /* 1 */
2005-04-16 15:20:36 -07:00
. name = " NS87410 " ,
2008-04-26 17:36:40 +02:00
. enablebits = { { 0x43 , 0x08 , 0x08 } , { 0x47 , 0x08 , 0x08 } } ,
2008-04-26 17:36:35 +02:00
. host_flags = IDE_HFLAG_TRUST_BIOS_FOR_DMA ,
2007-10-19 00:30:07 +02:00
. swdma_mask = ATA_SWDMA2 ,
. mwdma_mask = ATA_MWDMA2 ,
. udma_mask = ATA_UDMA6 ,
2007-10-19 00:30:06 +02:00
} ,
2007-10-19 00:30:06 +02:00
/* 2 */ DECLARE_GENERIC_PCI_DEV ( " SAMURAI " , 0 ) ,
/* 3 */ DECLARE_GENERIC_PCI_DEV ( " HT6565 " , 0 ) ,
2007-10-20 00:32:30 +02:00
/* 4 */ DECLARE_GENERIC_PCI_DEV ( " UM8673F " , IDE_HFLAGS_UMC ) ,
/* 5 */ DECLARE_GENERIC_PCI_DEV ( " UM8886A " , IDE_HFLAGS_UMC ) ,
/* 6 */ DECLARE_GENERIC_PCI_DEV ( " UM8886BF " , IDE_HFLAGS_UMC ) ,
2007-10-19 00:30:06 +02:00
/* 7 */ DECLARE_GENERIC_PCI_DEV ( " HINT_IDE " , 0 ) ,
/* 8 */ DECLARE_GENERIC_PCI_DEV ( " VIA_IDE " , IDE_HFLAG_NO_AUTODMA ) ,
/* 9 */ DECLARE_GENERIC_PCI_DEV ( " OPTI621V " , IDE_HFLAG_NO_AUTODMA ) ,
2007-10-19 00:30:06 +02:00
{ /* 10 */
2005-04-16 15:20:36 -07:00
. name = " VIA8237SATA " ,
2007-10-19 00:30:06 +02:00
. host_flags = IDE_HFLAG_TRUST_BIOS_FOR_DMA |
IDE_HFLAG_OFF_BOARD ,
2007-10-19 00:30:07 +02:00
. swdma_mask = ATA_SWDMA2 ,
. mwdma_mask = ATA_MWDMA2 ,
. udma_mask = ATA_UDMA6 ,
2007-10-19 00:30:06 +02:00
} ,
2007-10-19 00:30:06 +02:00
/* 11 */ DECLARE_GENERIC_PCI_DEV ( " Piccolo0102 " , IDE_HFLAG_NO_AUTODMA ) ,
/* 12 */ DECLARE_GENERIC_PCI_DEV ( " Piccolo0103 " , IDE_HFLAG_NO_AUTODMA ) ,
/* 13 */ DECLARE_GENERIC_PCI_DEV ( " Piccolo0105 " , IDE_HFLAG_NO_AUTODMA ) ,
2007-10-19 00:30:06 +02:00
{ /* 14 */
2005-08-18 22:27:07 +02:00
. name = " Revolution " ,
2008-02-01 23:09:30 +01:00
. host_flags = IDE_HFLAG_CLEAR_SIMPLEX |
IDE_HFLAG_TRUST_BIOS_FOR_DMA |
2007-10-19 00:30:06 +02:00
IDE_HFLAG_OFF_BOARD ,
2007-10-19 00:30:07 +02:00
. swdma_mask = ATA_SWDMA2 ,
. mwdma_mask = ATA_MWDMA2 ,
. udma_mask = ATA_UDMA6 ,
2005-04-16 15:20:36 -07:00
}
} ;
/**
* generic_init_one - called when a PIIX is found
* @ dev : the generic device
* @ id : the matching pci id
*
* Called when the PCI registration layer ( or the IDE initialization )
* finds a device matching our IDE device tables .
*/
2008-04-26 17:36:40 +02:00
2005-04-16 15:20:36 -07:00
static int __devinit generic_init_one ( struct pci_dev * dev , const struct pci_device_id * id )
{
2007-10-20 00:32:34 +02:00
const struct ide_port_info * d = & generic_chipsets [ id - > driver_data ] ;
2005-04-16 15:20:36 -07:00
int ret = - ENODEV ;
2005-06-27 15:24:26 -07:00
/* Don't use the generic entry unless instructed to do so */
if ( id - > driver_data = = 0 & & ide_generic_all = = 0 )
goto out ;
2007-06-08 15:14:31 +02:00
switch ( dev - > vendor ) {
case PCI_VENDOR_ID_UMC :
if ( dev - > device = = PCI_DEVICE_ID_UMC_UM8886A & &
! ( PCI_FUNC ( dev - > devfn ) & 1 ) )
goto out ; /* UM8886A/BF pair */
break ;
case PCI_VENDOR_ID_OPTI :
if ( dev - > device = = PCI_DEVICE_ID_OPTI_82C558 & &
! ( PCI_FUNC ( dev - > devfn ) & 1 ) )
goto out ;
break ;
case PCI_VENDOR_ID_JMICRON :
if ( dev - > device ! = PCI_DEVICE_ID_JMICRON_JMB368 & &
PCI_FUNC ( dev - > devfn ) ! = 1 )
goto out ;
break ;
case PCI_VENDOR_ID_NS :
if ( dev - > device = = PCI_DEVICE_ID_NS_87410 & &
( dev - > class > > 8 ) ! = PCI_CLASS_STORAGE_IDE )
2006-10-28 10:38:57 -07:00
goto out ;
2007-06-08 15:14:31 +02:00
break ;
2006-10-28 10:38:57 -07:00
}
2006-07-12 15:05:41 +01:00
2006-10-11 01:21:47 -07:00
if ( dev - > vendor ! = PCI_VENDOR_ID_JMICRON ) {
2007-06-08 15:14:31 +02:00
u16 command ;
2006-10-11 01:21:47 -07:00
pci_read_config_word ( dev , PCI_COMMAND , & command ) ;
if ( ! ( command & PCI_COMMAND_IO ) ) {
2007-06-08 15:14:31 +02:00
printk ( KERN_INFO " Skipping disabled %s IDE "
" controller. \n " , d - > name ) ;
2006-10-11 01:21:47 -07:00
goto out ;
}
2005-04-16 15:20:36 -07:00
}
ret = ide_setup_pci_device ( dev , d ) ;
out :
return ret ;
}
2007-10-16 22:29:56 +02:00
static const struct pci_device_id generic_pci_tbl [ ] = {
{ PCI_VDEVICE ( NS , PCI_DEVICE_ID_NS_87410 ) , 1 } ,
{ PCI_VDEVICE ( PCTECH , PCI_DEVICE_ID_PCTECH_SAMURAI_IDE ) , 2 } ,
{ PCI_VDEVICE ( HOLTEK , PCI_DEVICE_ID_HOLTEK_6565 ) , 3 } ,
{ PCI_VDEVICE ( UMC , PCI_DEVICE_ID_UMC_UM8673F ) , 4 } ,
{ PCI_VDEVICE ( UMC , PCI_DEVICE_ID_UMC_UM8886A ) , 5 } ,
{ PCI_VDEVICE ( UMC , PCI_DEVICE_ID_UMC_UM8886BF ) , 6 } ,
{ PCI_VDEVICE ( HINT , PCI_DEVICE_ID_HINT_VXPROII_IDE ) , 7 } ,
{ PCI_VDEVICE ( VIA , PCI_DEVICE_ID_VIA_82C561 ) , 8 } ,
{ PCI_VDEVICE ( OPTI , PCI_DEVICE_ID_OPTI_82C558 ) , 9 } ,
2005-04-16 15:20:36 -07:00
# ifdef CONFIG_BLK_DEV_IDE_SATA
2007-10-16 22:29:56 +02:00
{ PCI_VDEVICE ( VIA , PCI_DEVICE_ID_VIA_8237_SATA ) , 10 } ,
2005-04-16 15:20:36 -07:00
# endif
2007-10-16 22:29:56 +02:00
{ PCI_VDEVICE ( TOSHIBA , PCI_DEVICE_ID_TOSHIBA_PICCOLO ) , 11 } ,
{ PCI_VDEVICE ( TOSHIBA , PCI_DEVICE_ID_TOSHIBA_PICCOLO_1 ) , 12 } ,
{ PCI_VDEVICE ( TOSHIBA , PCI_DEVICE_ID_TOSHIBA_PICCOLO_2 ) , 13 } ,
{ PCI_VDEVICE ( NETCELL , PCI_DEVICE_ID_REVOLUTION ) , 14 } ,
/*
* Must come last . If you add entries adjust
* this table and generic_chipsets [ ] appropriately .
*/
{ PCI_ANY_ID , PCI_ANY_ID , PCI_ANY_ID , PCI_ANY_ID , PCI_CLASS_STORAGE_IDE < < 8 , 0xFFFFFF00UL , 0 } ,
2005-04-16 15:20:36 -07:00
{ 0 , } ,
} ;
MODULE_DEVICE_TABLE ( pci , generic_pci_tbl ) ;
static struct pci_driver driver = {
. name = " PCI_IDE " ,
. id_table = generic_pci_tbl ,
. probe = generic_init_one ,
} ;
2007-01-27 13:46:56 +01:00
static int __init generic_ide_init ( void )
2005-04-16 15:20:36 -07:00
{
return ide_pci_register_driver ( & driver ) ;
}
module_init ( generic_ide_init ) ;
MODULE_AUTHOR ( " Andre Hedrick " ) ;
MODULE_DESCRIPTION ( " PCI driver module for generic PCI IDE " ) ;
MODULE_LICENSE ( " GPL " ) ;