summaryrefslogtreecommitdiff
path: root/src/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'src/drivers')
-rw-r--r--src/drivers/generic/debug/debug_dev.c134
1 files changed, 78 insertions, 56 deletions
diff --git a/src/drivers/generic/debug/debug_dev.c b/src/drivers/generic/debug/debug_dev.c
index 3eb89176e6..727d4747f5 100644
--- a/src/drivers/generic/debug/debug_dev.c
+++ b/src/drivers/generic/debug/debug_dev.c
@@ -3,85 +3,107 @@
#include <device/pci.h>
#include <device/pci_ids.h>
#include <device/pci_ops.h>
+#include <cpu/x86/msr.h>
#include "chip.h"
static void print_pci_regs(struct device *dev)
{
- uint8_t byte;
- int i;
+ uint8_t byte;
+ int i;
- for (i = 0; i < 256; i++) {
- byte = pci_read_config8(dev, i);
-
- if ((i & 0xf) == 0)
- printk_debug("\n%02x:", i);
- printk_debug(" %02x", byte);
- }
- printk_debug("\n");
+ for(i=0;i<256;i++) {
+ byte = pci_read_config8(dev, i);
+
+ if((i & 0xf)==0) printk_debug("\n%02x:",i);
+ printk_debug(" %02x",byte);
+ }
+ printk_debug("\n");
}
static void print_mem(void)
{
- unsigned int i;
+ unsigned int i;
unsigned int start = 0xfffff000;
- for (i = start; i < 0xffffffff; i++) {
- if ((i & 0xf) == 0)
- printk_debug("\n %08x:", i);
- printk_debug(" %02x ", (unsigned char) *((unsigned char *) i));
- }
- printk_debug(" %02x \n", (unsigned char) *((unsigned char *) i));
+ for(i=start;i<0xffffffff;i++) {
+ if((i & 0xf)==0) printk_debug("\n %08x:",i);
+ printk_debug(" %02x",(unsigned char)*((unsigned char *)i));
+ }
+ printk_debug(" %02x\n",(unsigned char)*((unsigned char *)i));
-}
+ }
static void print_pci_regs_all(void)
{
- struct device *dev;
- unsigned char i, j, k;
+ struct device *dev;
+ unsigned char i,j,k;
- for (i = 0; i <= 15; i++) {
- for (j = 0; j <= 0x1f; j++) {
- for (k = 0; k <= 6; k++) {
+ for(i=0;i<=15;i++) {
+ for(j=0;j<=0x1f;j++) {
+ for (k=0;k<=6;k++){
dev = dev_find_slot(i, PCI_DEVFN(j, k));
- if (!dev) {
+ if(!dev) {
continue;
}
- if (!dev->enabled) {
+ if(!dev->enabled) {
continue;
}
- printk_debug("\n%02x:%02x:%02x aka %s", i,
- j, k, dev_path(dev));
+ printk_debug("\n%02x:%02x:%02x aka %s",i,j,k, dev_path(dev));
print_pci_regs(dev);
}
}
}
+
}
-static void debug_init(device_t dev)
+static void print_msr()
{
- unsigned bus;
- unsigned devfn;
-
-// print_pci_regs_all();
+ msr_t msr;
+ unsigned index;
+ unsigned eax, ebx, ecx, edx;
+ index = 0x80000007;
+ printk_debug("calling cpuid 0x%08x\n", index);
+ asm volatile(
+ "cpuid"
+ : "=a" (eax), "=b" (ebx), "=c" (ecx), "=d" (edx)
+ : "a" (index)
+ );
+ printk_debug("cpuid[%08x]: %08x %08x %08x %08x\n",
+ index, eax, ebx, ecx, edx);
+ if (edx & (3 << 1)) {
+ index = 0xC0010042;
+ printk_debug("Reading msr: 0x%08x\n", index);
+ msr = rdmsr(index);
+ printk_debug("msr[0x%08x]: 0x%08x%08x\n",
+ index, msr.hi, msr.hi);
+ }
- print_mem();
-#if 0
- msr_t msr;
- unsigned index;
- unsigned eax, ebx, ecx, edx;
- index = 0x80000007;
- printk_debug("calling cpuid 0x%08x\n", index);
- asm volatile ("cpuid":"=a" (eax), "=b"(ebx), "=c"(ecx), "=d"(edx)
- :"a"(index)
- );
- printk_debug("cpuid[%08x]: %08x %08x %08x %08x\n",
- index, eax, ebx, ecx, edx);
- if (edx & (3 << 1)) {
- index = 0xC0010042;
- printk_debug("Reading msr: 0x%08x\n", index);
- msr = rdmsr(index);
- printk_debug("msr[0x%08x]: 0x%08x%08x\n",
- index, msr.hi, msr.hi);
- }
+}
+
+static void debug_init(device_t dev)
+{
+ device_t parent;
+ switch(dev->path.u.pnp.device) {
+#if CONFIG_CHIP_NAME
+ case 0:
+ parent = dev->bus->dev;
+ printk_debug("DEBUG: %s", dev_path(parent));
+ if(parent->chip_ops && parent->chip_ops->name) {
+ printk_debug(": %s\n", parent->chip_ops->name);
+ } else {
+ printk_debug("\n");
+ }
+ break;
#endif
+
+ case 1:
+ print_pci_regs_all();
+ break;
+ case 2:
+ print_mem();
+ break;
+ case 3:
+ print_msr();
+ break;
+ }
}
static void debug_noop(device_t dummy)
@@ -89,10 +111,10 @@ static void debug_noop(device_t dummy)
}
static struct device_operations debug_operations = {
- .read_resources = debug_noop,
- .set_resources = debug_noop,
- .enable_resources = debug_noop,
- .init = debug_init,
+ .read_resources = debug_noop,
+ .set_resources = debug_noop,
+ .enable_resources = debug_noop,
+ .init = debug_init,
};
static void enable_dev(struct device *dev)
@@ -102,5 +124,5 @@ static void enable_dev(struct device *dev)
struct chip_operations drivers_generic_debug_ops = {
CHIP_NAME("Debug device")
- .enable_dev = enable_dev,
+ .enable_dev = enable_dev,
};