cregit-Linux how code gets into the kernel

Release 4.11 arch/x86/kernel/reboot_fixups_32.c

Directory: arch/x86/kernel
/*
 * This is a good place to put board specific reboot fixups.
 *
 * List of supported fixups:
 * geode-gx1/cs5530a - Jaya Kumar <jayalk@intworks.biz>
 * geode-gx/lx/cs5536 - Andres Salomon <dilinger@debian.org>
 *
 */

#include <asm/delay.h>
#include <linux/pci.h>
#include <linux/interrupt.h>
#include <asm/reboot_fixups.h>
#include <asm/msr.h>
#include <linux/cs5535.h>


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; }

Contributors

PersonTokensPropCommitsCommitProp
Jaya Kumar28100.00%1100.00%
Total28100.00%1100.00%


static void cs5536_warm_reset(struct pci_dev *dev) { /* writing 1 to the LSB of this MSR causes a hard reset */ wrmsrl(MSR_DIVIL_SOFT_RESET, 1ULL); udelay(50); /* shouldn't get here but be safe and spin a while */ }

Contributors

PersonTokensPropCommitsCommitProp
Andres Salomon25100.00%2100.00%
Total25100.00%2100.00%


static void rdc321x_reset(struct pci_dev *dev) { unsigned i; /* Voluntary reset the watchdog timer */ outl(0x80003840, 0xCF8); /* Generate a CPU reset on next tick */ i = inl(0xCFC); /* Use the minimum timer resolution */ i |= 0x1600; outl(i, 0xCFC); outb(1, 0x92); }

Contributors

PersonTokensPropCommitsCommitProp
Florian Fainelli49100.00%1100.00%
Total49100.00%1100.00%


static void ce4100_reset(struct pci_dev *dev) { int i; for (i = 0; i < 10; i++) { outb(0x2, 0xcf9); udelay(50); } }

Contributors

PersonTokensPropCommitsCommitProp
Dirk Brandewie41100.00%1100.00%
Total41100.00%1100.00%

struct device_fixup { unsigned int vendor; unsigned int device; void (*reboot_fixup)(struct pci_dev *); }; /* * PCI ids solely used for fixups_table go here */ #define PCI_DEVICE_ID_INTEL_CE4100 0x0708 static const struct device_fixup fixups_table[] = { { PCI_VENDOR_ID_CYRIX, PCI_DEVICE_ID_CYRIX_5530_LEGACY, cs5530a_warm_reset }, { PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_CS5536_ISA, cs5536_warm_reset }, { PCI_VENDOR_ID_NS, PCI_DEVICE_ID_NS_SC1100_BRIDGE, cs5530a_warm_reset }, { PCI_VENDOR_ID_RDC, PCI_DEVICE_ID_RDC_R6030, rdc321x_reset }, { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_CE4100, ce4100_reset }, }; /* * 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) { const struct device_fixup *cur; struct pci_dev *dev; int i; /* we can be called from sysrq-B code. In such a case it is * prohibited to dig PCI */ if (in_interrupt()) return; for (i=0; i < ARRAY_SIZE(fixups_table); i++) { cur = &(fixups_table[i]); dev = pci_get_device(cur->vendor, cur->device, NULL); if (!dev) continue; cur->reboot_fixup(dev); pci_dev_put(dev); } }

Contributors

PersonTokensPropCommitsCommitProp
Jaya Kumar7483.15%116.67%
Denis V. Lunev77.87%116.67%
Xiaotian Feng55.62%116.67%
Randy Dunlap11.12%116.67%
Tobias Klauser11.12%116.67%
Jan Beulich11.12%116.67%
Total89100.00%6100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Jaya Kumar14945.15%16.67%
Florian Fainelli5717.27%16.67%
Dirk Brandewie5416.36%16.67%
Andres Salomon3911.82%320.00%
Denis V. Lunev103.03%16.67%
Denys Fedoryshchenko82.42%16.67%
Xiaotian Feng51.52%16.67%
Jan Beulich20.61%16.67%
Adrian Bunk20.61%16.67%
Dave Jones10.30%16.67%
Jeremy Fitzhardinge10.30%16.67%
Tobias Klauser10.30%16.67%
Randy Dunlap10.30%16.67%
Total330100.00%15100.00%
Directory: arch/x86/kernel
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.