2005-04-16 15:20:36 -07:00
/*
* Cobalt Qube / Raq PCI support
*
* This file is subject to the terms and conditions of the GNU General Public
* License . See the file " COPYING " in the main directory of this archive
* for more details .
*
* Copyright ( C ) 1995 , 1996 , 1997 , 2002 , 2003 by Ralf Baechle
* Copyright ( C ) 2001 , 2002 , 2003 by Liam Davies ( ldavies @ agile . tv )
*/
# include <linux/types.h>
# include <linux/pci.h>
# include <linux/kernel.h>
# include <linux/init.h>
# include <asm/pci.h>
# include <asm/io.h>
# include <asm/gt64120.h>
2006-01-18 23:26:43 +00:00
# include <asm/mach-cobalt/cobalt.h>
2005-04-16 15:20:36 -07:00
extern int cobalt_board_id ;
2005-02-21 16:18:36 +00:00
static void qube_raq_galileo_early_fixup ( struct pci_dev * dev )
{
if ( dev - > devfn = = PCI_DEVFN ( 0 , 0 ) & &
( dev - > class > > 8 ) = = PCI_CLASS_MEMORY_OTHER ) {
dev - > class = ( PCI_CLASS_BRIDGE_HOST < < 8 ) | ( dev - > class & 0xff ) ;
printk ( KERN_INFO " Galileo: fixed bridge class \n " ) ;
}
}
DECLARE_PCI_FIXUP_EARLY ( PCI_VENDOR_ID_MARVELL , PCI_DEVICE_ID_MARVELL_GT64111 ,
qube_raq_galileo_early_fixup ) ;
2005-04-16 15:20:36 -07:00
static void qube_raq_via_bmIDE_fixup ( struct pci_dev * dev )
{
unsigned short cfgword ;
unsigned char lt ;
/* Enable Bus Mastering and fast back to back. */
pci_read_config_word ( dev , PCI_COMMAND , & cfgword ) ;
cfgword | = ( PCI_COMMAND_FAST_BACK | PCI_COMMAND_MASTER ) ;
pci_write_config_word ( dev , PCI_COMMAND , cfgword ) ;
/* Enable both ide interfaces. ROM only enables primary one. */
pci_write_config_byte ( dev , 0x40 , 0xb ) ;
/* Set latency timer to reasonable value. */
pci_read_config_byte ( dev , PCI_LATENCY_TIMER , & lt ) ;
if ( lt < 64 )
pci_write_config_byte ( dev , PCI_LATENCY_TIMER , 64 ) ;
2006-01-29 21:33:48 +00:00
pci_write_config_byte ( dev , PCI_CACHE_LINE_SIZE , 8 ) ;
2005-04-16 15:20:36 -07:00
}
DECLARE_PCI_FIXUP_HEADER ( PCI_VENDOR_ID_VIA , PCI_DEVICE_ID_VIA_82C586_1 ,
qube_raq_via_bmIDE_fixup ) ;
static void qube_raq_galileo_fixup ( struct pci_dev * dev )
{
unsigned short galileo_id ;
2005-02-21 16:18:36 +00:00
if ( dev - > devfn ! = PCI_DEVFN ( 0 , 0 ) )
return ;
2005-04-16 15:20:36 -07:00
/* Fix PCI latency-timer and cache-line-size values in Galileo
* host bridge .
*/
pci_write_config_byte ( dev , PCI_LATENCY_TIMER , 64 ) ;
2006-01-29 21:33:48 +00:00
pci_write_config_byte ( dev , PCI_CACHE_LINE_SIZE , 8 ) ;
2005-04-16 15:20:36 -07:00
/*
2005-02-21 16:18:36 +00:00
* The code described by the comment below has been removed
* as it causes bus mastering by the Ethernet controllers
* to break under any kind of network load . We always set
* the retry timeouts to their maximum .
*
* - - x - - x - - x - - x - - x - - x - - x - - x - - x - - x - - x - - x - - x - - x - - x - - x - - x - - x - - x - - x - -
*
2005-04-16 15:20:36 -07:00
* On all machines prior to Q2 , we had the STOP line disconnected
* from Galileo to VIA on PCI . The new Galileo does not function
* correctly unless we have it connected .
*
* Therefore we must set the disconnect / retry cycle values to
* something sensible when using the new Galileo .
*/
pci_read_config_word ( dev , PCI_REVISION_ID , & galileo_id ) ;
galileo_id & = 0xff ; /* mask off class info */
2005-02-21 16:18:36 +00:00
printk ( KERN_INFO " Galileo: revision %u \n " , galileo_id ) ;
#if 0
2005-04-16 15:20:36 -07:00
if ( galileo_id > = 0x10 ) {
/* New Galileo, assumes PCI stop line to VIA is connected. */
GALILEO_OUTL ( 0x4020 , GT_PCI0_TOR_OFS ) ;
2005-02-21 16:18:36 +00:00
} else if ( galileo_id = = 0x1 | | galileo_id = = 0x2 )
# endif
{
2005-04-16 15:20:36 -07:00
signed int timeo ;
/* XXX WE MUST DO THIS ELSE GALILEO LOCKS UP! -DaveM */
timeo = GALILEO_INL ( GT_PCI0_TOR_OFS ) ;
/* Old Galileo, assumes PCI STOP line to VIA is disconnected. */
2005-02-21 16:18:36 +00:00
GALILEO_OUTL (
( 0xff < < 16 ) | /* retry count */
( 0xff < < 8 ) | /* timeout 1 */
0xff , /* timeout 0 */
GT_PCI0_TOR_OFS ) ;
/* enable PCI retry exceeded interrupt */
GALILEO_OUTL ( GALILEO_INTR_RETRY_CTR | GALILEO_INL ( GT_INTRMASK_OFS ) , GT_INTRMASK_OFS ) ;
2005-04-16 15:20:36 -07:00
}
}
2005-02-21 16:18:36 +00:00
DECLARE_PCI_FIXUP_HEADER ( PCI_VENDOR_ID_MARVELL , PCI_DEVICE_ID_MARVELL_GT64111 ,
2005-04-16 15:20:36 -07:00
qube_raq_galileo_fixup ) ;
2005-02-21 16:18:36 +00:00
static char irq_tab_qube1 [ ] __initdata = {
[ COBALT_PCICONF_CPU ] = 0 ,
[ COBALT_PCICONF_ETH0 ] = COBALT_QUBE1_ETH0_IRQ ,
[ COBALT_PCICONF_RAQSCSI ] = COBALT_SCSI_IRQ ,
[ COBALT_PCICONF_VIA ] = 0 ,
[ COBALT_PCICONF_PCISLOT ] = COBALT_QUBE_SLOT_IRQ ,
[ COBALT_PCICONF_ETH1 ] = 0
} ;
2005-04-16 15:20:36 -07:00
static char irq_tab_cobalt [ ] __initdata = {
[ COBALT_PCICONF_CPU ] = 0 ,
[ COBALT_PCICONF_ETH0 ] = COBALT_ETH0_IRQ ,
[ COBALT_PCICONF_RAQSCSI ] = COBALT_SCSI_IRQ ,
[ COBALT_PCICONF_VIA ] = 0 ,
[ COBALT_PCICONF_PCISLOT ] = COBALT_QUBE_SLOT_IRQ ,
[ COBALT_PCICONF_ETH1 ] = COBALT_ETH1_IRQ
} ;
static char irq_tab_raq2 [ ] __initdata = {
[ COBALT_PCICONF_CPU ] = 0 ,
[ COBALT_PCICONF_ETH0 ] = COBALT_ETH0_IRQ ,
[ COBALT_PCICONF_RAQSCSI ] = COBALT_RAQ_SCSI_IRQ ,
[ COBALT_PCICONF_VIA ] = 0 ,
[ COBALT_PCICONF_PCISLOT ] = COBALT_QUBE_SLOT_IRQ ,
[ COBALT_PCICONF_ETH1 ] = COBALT_ETH1_IRQ
} ;
int __init pcibios_map_irq ( struct pci_dev * dev , u8 slot , u8 pin )
{
2005-02-21 16:18:36 +00:00
if ( cobalt_board_id < COBALT_BRD_ID_QUBE2 )
return irq_tab_qube1 [ slot ] ;
2005-04-16 15:20:36 -07:00
if ( cobalt_board_id = = COBALT_BRD_ID_RAQ2 )
return irq_tab_raq2 [ slot ] ;
return irq_tab_cobalt [ slot ] ;
}
/* Do platform specific device initialization at pci_enable_device() time */
int pcibios_plat_dev_init ( struct pci_dev * dev )
{
return 0 ;
}