2005-05-01 19:58:49 +04:00
/*
* linux / arch / i386 / kernel / reboot_fixups . c
*
* This is a good place to put board specific reboot fixups .
*
* List of supported fixups :
* geode - gx1 / cs5530a - Jaya Kumar < jayalk @ intworks . biz >
2007-07-06 22:17:30 +04:00
* geode - gx / lx / cs5536 - Andres Salomon < dilinger @ debian . org >
2005-05-01 19:58:49 +04:00
*
*/
# include <asm/delay.h>
# include <linux/pci.h>
2007-05-02 21:27:06 +04:00
# include <asm/reboot_fixups.h>
2007-07-06 22:17:30 +04:00
# include <asm/msr.h>
2005-05-01 19:58:49 +04:00
static void cs5530a_warm_reset ( struct pci_dev * dev )
{
/* writing 1 to the reset control register, 0x44 causes the
cs5530a to perform a system warm reset */
pci_write_config_byte ( dev , 0x44 , 0x1 ) ;
udelay ( 50 ) ; /* shouldn't get here but be safe and spin-a-while */
return ;
}
2007-07-06 22:17:30 +04:00
static void cs5536_warm_reset ( struct pci_dev * dev )
{
/*
* 6.6 .2 .12 Soft Reset ( DIVIL_SOFT_RESET )
* writing 1 to the LSB of this MSR causes a hard reset .
*/
wrmsrl ( 0x51400017 , 1ULL ) ;
udelay ( 50 ) ; /* shouldn't get here but be safe and spin a while */
}
2005-05-01 19:58:49 +04:00
struct device_fixup {
unsigned int vendor ;
unsigned int device ;
void ( * reboot_fixup ) ( struct pci_dev * ) ;
} ;
static struct device_fixup fixups_table [ ] = {
{ PCI_VENDOR_ID_CYRIX , PCI_DEVICE_ID_CYRIX_5530_LEGACY , cs5530a_warm_reset } ,
2007-07-06 22:17:30 +04:00
{ PCI_VENDOR_ID_AMD , PCI_DEVICE_ID_AMD_CS5536_ISA , cs5536_warm_reset } ,
2005-05-01 19:58:49 +04:00
} ;
/*
* we see if any fixup is available for our current hardware . if there
* is a fixup , we call it and we expect to never return from it . if we
* do return , we keep looking and then eventually fall back to the
* standard mach_reboot on return .
*/
void mach_reboot_fixups ( void )
{
struct device_fixup * cur ;
struct pci_dev * dev ;
int i ;
2005-11-07 11:58:31 +03:00
for ( i = 0 ; i < ARRAY_SIZE ( fixups_table ) ; i + + ) {
2005-05-01 19:58:49 +04:00
cur = & ( fixups_table [ i ] ) ;
2005-10-31 02:03:29 +03:00
dev = pci_get_device ( cur - > vendor , cur - > device , NULL ) ;
2005-05-01 19:58:49 +04:00
if ( ! dev )
continue ;
cur - > reboot_fixup ( dev ) ;
}
}