more warnings gone...
Signed-off-by: Stefan Reinauer <stepan@coresystems.de> Acked-by: Stefan Reinauer <stepan@coresystems.de> git-svn-id: svn://svn.coreboot.org/coreboot/trunk@5254 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
parent
527aedc17b
commit
78b4033584
11 changed files with 65 additions and 77 deletions
|
@ -290,7 +290,7 @@ void do_vsmbios(void)
|
||||||
if ((unsigned int)cbfs_load_stage("vsa") != VSA2_ENTRY_POINT) {
|
if ((unsigned int)cbfs_load_stage("vsa") != VSA2_ENTRY_POINT) {
|
||||||
printk_err("do_vsmbios: Failed to load VSA.\n");
|
printk_err("do_vsmbios: Failed to load VSA.\n");
|
||||||
}
|
}
|
||||||
buf = VSA2_BUFFER;
|
buf = (unsigned char *)VSA2_BUFFER;
|
||||||
printk_debug("buf %p *buf %d buf[256k] %d\n",
|
printk_debug("buf %p *buf %d buf[256k] %d\n",
|
||||||
buf, buf[0], buf[SMM_SIZE * 1024]);
|
buf, buf[0], buf[SMM_SIZE * 1024]);
|
||||||
printk_debug("buf[0x20] signature is %x:%x:%x:%x\n",
|
printk_debug("buf[0x20] signature is %x:%x:%x:%x\n",
|
||||||
|
@ -501,15 +501,15 @@ int biosint(unsigned long intnumber,
|
||||||
printk_debug("biosint: ebp 0x%lx esp 0x%lx edi 0x%lx esi 0x%lx\n",
|
printk_debug("biosint: ebp 0x%lx esp 0x%lx edi 0x%lx esi 0x%lx\n",
|
||||||
ebp, esp, edi, esi);
|
ebp, esp, edi, esi);
|
||||||
printk_debug("biosint: ip 0x%x cs 0x%x flags 0x%x\n",
|
printk_debug("biosint: ip 0x%x cs 0x%x flags 0x%x\n",
|
||||||
ip, cs, flags);
|
(u32)ip, (u32)cs, (u32)flags);
|
||||||
printk_debug("biosint: gs 0x%x fs 0x%x ds 0x%x es 0x%x\n",
|
printk_debug("biosint: gs 0x%x fs 0x%x ds 0x%x es 0x%x\n",
|
||||||
gsfs >> 16, gsfs & 0xffff, dses >> 16, dses & 0xffff);
|
(u16)(gsfs >> 16), (u16)(gsfs & 0xffff), (u16)(dses >> 16), (u16)(dses & 0xffff));
|
||||||
|
|
||||||
// cases in a good compiler are just as good as your own tables.
|
// cases in a good compiler are just as good as your own tables.
|
||||||
switch (intnumber) {
|
switch (intnumber) {
|
||||||
case 0 ... 15:
|
case 0 ... 15:
|
||||||
// These are not BIOS service, but the CPU-generated exceptions
|
// These are not BIOS service, but the CPU-generated exceptions
|
||||||
printk_info("biosint: Oops, exception %u\n", intnumber);
|
printk_info("biosint: Oops, exception 0x%x\n", (u32)intnumber);
|
||||||
if (esp < 0x1000) {
|
if (esp < 0x1000) {
|
||||||
printk_debug("Stack contents: ");
|
printk_debug("Stack contents: ");
|
||||||
while (esp < 0x1000) {
|
while (esp < 0x1000) {
|
||||||
|
@ -537,7 +537,7 @@ int biosint(unsigned long intnumber,
|
||||||
&ebx, &edx, &ecx, &eax, &flags);
|
&ebx, &edx, &ecx, &eax, &flags);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
printk_info("BIOSINT: Unsupport int #0x%x\n", intnumber);
|
printk_info("BIOSINT: Unsupported int #0x%x\n", (u32)intnumber);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (ret)
|
if (ret)
|
||||||
|
@ -617,16 +617,7 @@ pcibios(unsigned long *pedi, unsigned long *pesi, unsigned long *pebp,
|
||||||
unsigned long *pesp, unsigned long *pebx, unsigned long *pedx,
|
unsigned long *pesp, unsigned long *pebx, unsigned long *pedx,
|
||||||
unsigned long *pecx, unsigned long *peax, unsigned long *pflags)
|
unsigned long *pecx, unsigned long *peax, unsigned long *pflags)
|
||||||
{
|
{
|
||||||
unsigned long edi = *pedi;
|
unsigned short func = (unsigned short)*peax;
|
||||||
unsigned long esi = *pesi;
|
|
||||||
unsigned long ebp = *pebp;
|
|
||||||
unsigned long esp = *pesp;
|
|
||||||
unsigned long ebx = *pebx;
|
|
||||||
unsigned long edx = *pedx;
|
|
||||||
unsigned long ecx = *pecx;
|
|
||||||
unsigned long eax = *peax;
|
|
||||||
unsigned long flags = *pflags;
|
|
||||||
unsigned short func = (unsigned short)eax;
|
|
||||||
int retval = 0;
|
int retval = 0;
|
||||||
unsigned short devid, vendorid, devfn;
|
unsigned short devid, vendorid, devfn;
|
||||||
short devindex; /* Use short to get rid of gabage in upper half of 32-bit register */
|
short devindex; /* Use short to get rid of gabage in upper half of 32-bit register */
|
||||||
|
@ -740,7 +731,7 @@ int handleint21(unsigned long *edi, unsigned long *esi, unsigned long *ebp,
|
||||||
unsigned long *ecx, unsigned long *eax, unsigned long *flags)
|
unsigned long *ecx, unsigned long *eax, unsigned long *flags)
|
||||||
{
|
{
|
||||||
int res = -1;
|
int res = -1;
|
||||||
printk_debug("handleint21, eax 0x%x\n", *eax);
|
printk_debug("handleint21, eax 0x%x\n", (u32)*eax);
|
||||||
switch (*eax & 0xffff) {
|
switch (*eax & 0xffff) {
|
||||||
case 0x5f19:
|
case 0x5f19:
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -253,16 +253,16 @@ void print_conf(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
iol = inl(GPIO_IO_BASE + GPIOL_INPUT_ENABLE);
|
iol = inl(GPIO_IO_BASE + GPIOL_INPUT_ENABLE);
|
||||||
printk_debug("IOR 0x%08X is now 0x%08X\n",
|
printk_debug("IOR 0x%08X is now 0x%08lX\n",
|
||||||
GPIO_IO_BASE + GPIOL_INPUT_ENABLE, iol);
|
GPIO_IO_BASE + GPIOL_INPUT_ENABLE, iol);
|
||||||
iol = inl(GPIOL_EVENTS_ENABLE);
|
iol = inl(GPIOL_EVENTS_ENABLE);
|
||||||
printk_debug("IOR 0x%08X is now 0x%08X\n",
|
printk_debug("IOR 0x%08X is now 0x%08lX\n",
|
||||||
GPIO_IO_BASE + GPIOL_EVENTS_ENABLE, iol);
|
GPIO_IO_BASE + GPIOL_EVENTS_ENABLE, iol);
|
||||||
iol = inl(GPIOL_INPUT_INVERT_ENABLE);
|
iol = inl(GPIOL_INPUT_INVERT_ENABLE);
|
||||||
printk_debug("IOR 0x%08X is now 0x%08X\n",
|
printk_debug("IOR 0x%08X is now 0x%08lX\n",
|
||||||
GPIO_IO_BASE + GPIOL_INPUT_INVERT_ENABLE, iol);
|
GPIO_IO_BASE + GPIOL_INPUT_INVERT_ENABLE, iol);
|
||||||
iol = inl(GPIO_MAPPER_X);
|
iol = inl(GPIO_MAPPER_X);
|
||||||
printk_debug("IOR 0x%08X is now 0x%08X\n", GPIO_IO_BASE + GPIO_MAPPER_X,
|
printk_debug("IOR 0x%08X is now 0x%08lX\n", GPIO_IO_BASE + GPIO_MAPPER_X,
|
||||||
iol);
|
iol);
|
||||||
#endif //CONFIG_DEFAULT_CONSOLE_LOGLEVEL >= BIOS_ERR
|
#endif //CONFIG_DEFAULT_CONSOLE_LOGLEVEL >= BIOS_ERR
|
||||||
}
|
}
|
||||||
|
|
|
@ -107,7 +107,7 @@ static void writeglmsr(struct gliutable *gl)
|
||||||
msr.lo = gl->lo;
|
msr.lo = gl->lo;
|
||||||
msr.hi = gl->hi;
|
msr.hi = gl->hi;
|
||||||
wrmsr(gl->desc_name, msr); // MSR - see table above
|
wrmsr(gl->desc_name, msr); // MSR - see table above
|
||||||
printk_debug("%s: MSR 0x%08x, val 0x%08x:0x%08x\n", __func__, gl->desc_name, msr.hi, msr.lo); // GX3
|
printk_debug("%s: MSR 0x%08lx, val 0x%08x:0x%08x\n", __func__, gl->desc_name, msr.hi, msr.lo); // GX3
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ShadowInit(struct gliutable *gl)
|
static void ShadowInit(struct gliutable *gl)
|
||||||
|
@ -147,7 +147,7 @@ static void SysmemInit(struct gliutable *gl)
|
||||||
msr.lo = sizebytes;
|
msr.lo = sizebytes;
|
||||||
|
|
||||||
wrmsr(gl->desc_name, msr); // MSR - see table above
|
wrmsr(gl->desc_name, msr); // MSR - see table above
|
||||||
printk_debug("%s: MSR 0x%08x, val 0x%08x:0x%08x\n", __func__,
|
printk_debug("%s: MSR 0x%08lx, val 0x%08x:0x%08x\n", __func__,
|
||||||
gl->desc_name, msr.hi, msr.lo);
|
gl->desc_name, msr.hi, msr.lo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -173,7 +173,7 @@ static void SMMGL0Init(struct gliutable *gl)
|
||||||
msr.lo |= ((~(SMM_SIZE * 1024) + 1) >> 12) & 0xfffff;
|
msr.lo |= ((~(SMM_SIZE * 1024) + 1) >> 12) & 0xfffff;
|
||||||
|
|
||||||
wrmsr(gl->desc_name, msr); // MSR - See table above
|
wrmsr(gl->desc_name, msr); // MSR - See table above
|
||||||
printk_debug("%s: MSR 0x%08x, val 0x%08x:0x%08x\n", __func__,
|
printk_debug("%s: MSR 0x%08lx, val 0x%08x:0x%08x\n", __func__,
|
||||||
gl->desc_name, msr.hi, msr.lo);
|
gl->desc_name, msr.hi, msr.lo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -190,7 +190,7 @@ static void SMMGL1Init(struct gliutable *gl)
|
||||||
msr.lo |= ((~(SMM_SIZE * 1024) + 1) >> 12) & 0xfffff;
|
msr.lo |= ((~(SMM_SIZE * 1024) + 1) >> 12) & 0xfffff;
|
||||||
|
|
||||||
wrmsr(gl->desc_name, msr); // MSR - See table above
|
wrmsr(gl->desc_name, msr); // MSR - See table above
|
||||||
printk_debug("%s: MSR 0x%08x, val 0x%08x:0x%08x\n", __func__,
|
printk_debug("%s: MSR 0x%08lx, val 0x%08x:0x%08x\n", __func__,
|
||||||
gl->desc_name, msr.hi, msr.lo);
|
gl->desc_name, msr.hi, msr.lo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -27,12 +27,13 @@ static const unsigned char NumColAddr[] = {
|
||||||
0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F
|
0x08, 0x09, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F
|
||||||
};
|
};
|
||||||
|
|
||||||
void banner(char *s)
|
void banner(const char *s)
|
||||||
{
|
{
|
||||||
print_debug("===========================");
|
print_debug("===========================");
|
||||||
print_debug(s);
|
print_debug(s);
|
||||||
print_debug("======================================\r\n");
|
print_debug("======================================\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
void hcf(void)
|
void hcf(void)
|
||||||
{
|
{
|
||||||
print_emerg("DIE\r\n");
|
print_emerg("DIE\r\n");
|
||||||
|
|
|
@ -35,7 +35,7 @@
|
||||||
#include "cs5536.h"
|
#include "cs5536.h"
|
||||||
|
|
||||||
struct msrinit {
|
struct msrinit {
|
||||||
uint32_t msrnum;
|
u32 msrnum;
|
||||||
msr_t msr;
|
msr_t msr;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -61,8 +61,8 @@ struct msrinit CS5536_CLOCK_GATING_TABLE[] = {
|
||||||
};
|
};
|
||||||
|
|
||||||
struct acpiinit {
|
struct acpiinit {
|
||||||
uint16_t ioreg;
|
u16 ioreg;
|
||||||
uint32_t regdata;
|
u32 regdata;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct acpiinit acpi_init_table[] = {
|
struct acpiinit acpi_init_table[] = {
|
||||||
|
@ -95,7 +95,7 @@ struct FLASH_DEVICE FlashInitTable[] = {
|
||||||
|
|
||||||
#define FlashInitTableLen (ARRAY_SIZE(FlashInitTable))
|
#define FlashInitTableLen (ARRAY_SIZE(FlashInitTable))
|
||||||
|
|
||||||
uint32_t FlashPort[] = {
|
u32 FlashPort[] = {
|
||||||
MDD_LBAR_FLSH0,
|
MDD_LBAR_FLSH0,
|
||||||
MDD_LBAR_FLSH1,
|
MDD_LBAR_FLSH1,
|
||||||
MDD_LBAR_FLSH2,
|
MDD_LBAR_FLSH2,
|
||||||
|
@ -111,8 +111,8 @@ uint32_t FlashPort[] = {
|
||||||
/* ***************************************************************************/
|
/* ***************************************************************************/
|
||||||
static void pmChipsetInit(void)
|
static void pmChipsetInit(void)
|
||||||
{
|
{
|
||||||
uint32_t val = 0;
|
u32 val = 0;
|
||||||
uint16_t port;
|
u16 port;
|
||||||
|
|
||||||
port = (PMS_IO_BASE + 0x010);
|
port = (PMS_IO_BASE + 0x010);
|
||||||
val = 0x0E00; /* 1ms */
|
val = 0x0E00; /* 1ms */
|
||||||
|
@ -427,7 +427,7 @@ static void uarts_init(struct southbridge_amd_cs5536_config *sb)
|
||||||
|
|
||||||
static void enable_USB_port4(struct southbridge_amd_cs5536_config *sb)
|
static void enable_USB_port4(struct southbridge_amd_cs5536_config *sb)
|
||||||
{
|
{
|
||||||
uint8_t *bar;
|
u32 bar;
|
||||||
msr_t msr;
|
msr_t msr;
|
||||||
device_t dev;
|
device_t dev;
|
||||||
|
|
||||||
|
@ -443,7 +443,7 @@ static void enable_USB_port4(struct southbridge_amd_cs5536_config *sb)
|
||||||
/* write to clear diag register */
|
/* write to clear diag register */
|
||||||
wrmsr(USB2_SB_GLD_MSR_DIAG, rdmsr(USB2_SB_GLD_MSR_DIAG));
|
wrmsr(USB2_SB_GLD_MSR_DIAG, rdmsr(USB2_SB_GLD_MSR_DIAG));
|
||||||
|
|
||||||
bar = (uint8_t *) pci_read_config32(dev, PCI_BASE_ADDRESS_0);
|
bar = pci_read_config32(dev, PCI_BASE_ADDRESS_0);
|
||||||
|
|
||||||
/* Make HCCPARAMS writeable */
|
/* Make HCCPARAMS writeable */
|
||||||
write32(bar + IPREG04, read32(bar + IPREG04) | USB_HCCPW_SET);
|
write32(bar + IPREG04, read32(bar + IPREG04) | USB_HCCPW_SET);
|
||||||
|
@ -455,7 +455,7 @@ static void enable_USB_port4(struct southbridge_amd_cs5536_config *sb)
|
||||||
dev = dev_find_device(PCI_VENDOR_ID_AMD,
|
dev = dev_find_device(PCI_VENDOR_ID_AMD,
|
||||||
PCI_DEVICE_ID_AMD_CS5536_OTG, 0);
|
PCI_DEVICE_ID_AMD_CS5536_OTG, 0);
|
||||||
if (dev) {
|
if (dev) {
|
||||||
bar = (uint8_t *) pci_read_config32(dev, PCI_BASE_ADDRESS_0);
|
bar = pci_read_config32(dev, PCI_BASE_ADDRESS_0);
|
||||||
|
|
||||||
write32(bar + UOCMUX, read32(bar + UOCMUX) & PUEN_SET);
|
write32(bar + UOCMUX, read32(bar + UOCMUX) & PUEN_SET);
|
||||||
|
|
||||||
|
@ -483,8 +483,7 @@ static void enable_USB_port4(struct southbridge_amd_cs5536_config *sb)
|
||||||
dev = dev_find_device(PCI_VENDOR_ID_AMD,
|
dev = dev_find_device(PCI_VENDOR_ID_AMD,
|
||||||
PCI_DEVICE_ID_AMD_CS5536_UDC, 0);
|
PCI_DEVICE_ID_AMD_CS5536_UDC, 0);
|
||||||
if (dev) {
|
if (dev) {
|
||||||
bar = (uint8_t *) pci_read_config32(dev,
|
bar = pci_read_config32(dev, PCI_BASE_ADDRESS_0);
|
||||||
PCI_BASE_ADDRESS_0);
|
|
||||||
write32(bar + UDCDEVCTL,
|
write32(bar + UDCDEVCTL,
|
||||||
read32(bar + UDCDEVCTL) | UDC_SD_SET);
|
read32(bar + UDCDEVCTL) | UDC_SD_SET);
|
||||||
|
|
||||||
|
@ -493,8 +492,7 @@ static void enable_USB_port4(struct southbridge_amd_cs5536_config *sb)
|
||||||
dev = dev_find_device(PCI_VENDOR_ID_AMD,
|
dev = dev_find_device(PCI_VENDOR_ID_AMD,
|
||||||
PCI_DEVICE_ID_AMD_CS5536_OTG, 0);
|
PCI_DEVICE_ID_AMD_CS5536_OTG, 0);
|
||||||
if (dev) {
|
if (dev) {
|
||||||
bar = (uint8_t *) pci_read_config32(dev,
|
bar = pci_read_config32(dev, PCI_BASE_ADDRESS_0);
|
||||||
PCI_BASE_ADDRESS_0);
|
|
||||||
write32(bar + UOCCTL, read32(bar + UOCCTL) | PADEN_SET);
|
write32(bar + UOCCTL, read32(bar + UOCCTL) | PADEN_SET);
|
||||||
write32(bar + UOCCAP, read32(bar + UOCCAP) | APU_SET);
|
write32(bar + UOCCAP, read32(bar + UOCCAP) | APU_SET);
|
||||||
}
|
}
|
||||||
|
@ -524,7 +522,7 @@ void chipsetinit(void)
|
||||||
{
|
{
|
||||||
device_t dev;
|
device_t dev;
|
||||||
msr_t msr;
|
msr_t msr;
|
||||||
uint32_t msrnum;
|
u32 msrnum;
|
||||||
struct southbridge_amd_cs5536_config *sb =
|
struct southbridge_amd_cs5536_config *sb =
|
||||||
(struct southbridge_amd_cs5536_config *)dev->chip_info;
|
(struct southbridge_amd_cs5536_config *)dev->chip_info;
|
||||||
struct msrinit *csi;
|
struct msrinit *csi;
|
||||||
|
|
|
@ -32,13 +32,11 @@ static void cs5536_setup_extmsr(void)
|
||||||
|
|
||||||
/* forward MSR access to CS5536_GLINK_PORT_NUM to CS5536_DEV_NUM */
|
/* forward MSR access to CS5536_GLINK_PORT_NUM to CS5536_DEV_NUM */
|
||||||
msr.hi = msr.lo = 0x00000000;
|
msr.hi = msr.lo = 0x00000000;
|
||||||
if (CS5536_GLINK_PORT_NUM <= 4) {
|
#if CS5536_GLINK_PORT_NUM <= 4
|
||||||
msr.lo = CS5536_DEV_NUM <<
|
msr.lo = CS5536_DEV_NUM << (unsigned char)((CS5536_GLINK_PORT_NUM - 1) * 8);
|
||||||
(unsigned char)((CS5536_GLINK_PORT_NUM - 1) * 8);
|
#else
|
||||||
} else {
|
msr.hi = CS5536_DEV_NUM << (unsigned char)((CS5536_GLINK_PORT_NUM - 5) * 8);
|
||||||
msr.hi = CS5536_DEV_NUM <<
|
#endif
|
||||||
(unsigned char)((CS5536_GLINK_PORT_NUM - 5) * 8);
|
|
||||||
}
|
|
||||||
wrmsr(GLPCI_ExtMSR, msr);
|
wrmsr(GLPCI_ExtMSR, msr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -30,7 +30,7 @@
|
||||||
#define HDA_ICII_BUSY (1 << 0)
|
#define HDA_ICII_BUSY (1 << 0)
|
||||||
#define HDA_ICII_VALID (1 << 1)
|
#define HDA_ICII_VALID (1 << 1)
|
||||||
|
|
||||||
static int set_bits(u8 * port, u32 mask, u32 val)
|
static int set_bits(u32 port, u32 mask, u32 val)
|
||||||
{
|
{
|
||||||
u32 dword;
|
u32 dword;
|
||||||
int count;
|
int count;
|
||||||
|
@ -59,7 +59,7 @@ static int set_bits(u8 * port, u32 mask, u32 val)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static u32 codec_detect(u8 * base)
|
static u32 codec_detect(u32 base)
|
||||||
{
|
{
|
||||||
u32 dword;
|
u32 dword;
|
||||||
|
|
||||||
|
@ -172,7 +172,7 @@ static u32 find_verb(u32 viddid, u32 ** verb)
|
||||||
* no response would imply that the codec is non-operative
|
* no response would imply that the codec is non-operative
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static int wait_for_ready(u8 *base)
|
static int wait_for_ready(u32 base)
|
||||||
{
|
{
|
||||||
/* Use a 50 usec timeout - the Linux kernel uses the
|
/* Use a 50 usec timeout - the Linux kernel uses the
|
||||||
* same duration */
|
* same duration */
|
||||||
|
@ -195,7 +195,7 @@ static int wait_for_ready(u8 *base)
|
||||||
* is non-operative
|
* is non-operative
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static int wait_for_valid(u8 *base)
|
static int wait_for_valid(u32 base)
|
||||||
{
|
{
|
||||||
/* Use a 50 usec timeout - the Linux kernel uses the
|
/* Use a 50 usec timeout - the Linux kernel uses the
|
||||||
* same duration */
|
* same duration */
|
||||||
|
@ -212,7 +212,7 @@ static int wait_for_valid(u8 *base)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void codec_init(u8 * base, int addr)
|
static void codec_init(u32 base, int addr)
|
||||||
{
|
{
|
||||||
u32 dword;
|
u32 dword;
|
||||||
u32 *verb;
|
u32 *verb;
|
||||||
|
@ -254,7 +254,7 @@ static void codec_init(u8 * base, int addr)
|
||||||
printk_debug("verb loaded!\n");
|
printk_debug("verb loaded!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void codecs_init(u8 * base, u32 codec_mask)
|
static void codecs_init(u32 base, u32 codec_mask)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
for (i = 2; i >= 0; i--) {
|
for (i = 2; i >= 0; i--) {
|
||||||
|
@ -267,7 +267,7 @@ static void hda_init(struct device *dev)
|
||||||
{
|
{
|
||||||
u8 byte;
|
u8 byte;
|
||||||
u32 dword;
|
u32 dword;
|
||||||
u8 *base;
|
u32 base;
|
||||||
struct resource *res;
|
struct resource *res;
|
||||||
u32 codec_mask;
|
u32 codec_mask;
|
||||||
device_t sm_dev;
|
device_t sm_dev;
|
||||||
|
@ -301,8 +301,8 @@ static void hda_init(struct device *dev)
|
||||||
if (!res)
|
if (!res)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
base = (u8 *) ((u32)res->base);
|
base = ((u32)res->base);
|
||||||
printk_debug("base = %p\n", base);
|
printk_debug("base = 0x%x\n", base);
|
||||||
codec_mask = codec_detect(base);
|
codec_mask = codec_detect(base);
|
||||||
|
|
||||||
if (codec_mask) {
|
if (codec_mask) {
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
#include <arch/io.h>
|
#include <arch/io.h>
|
||||||
#include "sb600.h"
|
#include "sb600.h"
|
||||||
|
|
||||||
int sata_drive_detect(int portnum, u16 iobar)
|
static int sata_drive_detect(int portnum, u16 iobar)
|
||||||
{
|
{
|
||||||
u8 byte, byte2;
|
u8 byte, byte2;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
@ -59,7 +59,7 @@ static void sata_init(struct device *dev)
|
||||||
u8 byte;
|
u8 byte;
|
||||||
u16 word;
|
u16 word;
|
||||||
u32 dword;
|
u32 dword;
|
||||||
u8 *sata_bar5;
|
u32 sata_bar5;
|
||||||
u16 sata_bar0, sata_bar1, sata_bar2, sata_bar3, sata_bar4;
|
u16 sata_bar0, sata_bar1, sata_bar2, sata_bar3, sata_bar4;
|
||||||
int i, j;
|
int i, j;
|
||||||
|
|
||||||
|
@ -84,7 +84,7 @@ static void sata_init(struct device *dev)
|
||||||
pci_write_config8(sm_dev, 0xaf, byte);
|
pci_write_config8(sm_dev, 0xaf, byte);
|
||||||
|
|
||||||
/* get base addresss */
|
/* get base addresss */
|
||||||
sata_bar5 = (u8 *) (pci_read_config32(dev, 0x24) & ~0x3FF);
|
sata_bar5 = pci_read_config32(dev, 0x24) & ~0x3FF;
|
||||||
sata_bar0 = pci_read_config16(dev, 0x10) & ~0x7;
|
sata_bar0 = pci_read_config16(dev, 0x10) & ~0x7;
|
||||||
sata_bar1 = pci_read_config16(dev, 0x14) & ~0x3;
|
sata_bar1 = pci_read_config16(dev, 0x14) & ~0x3;
|
||||||
sata_bar2 = pci_read_config16(dev, 0x18) & ~0x7;
|
sata_bar2 = pci_read_config16(dev, 0x18) & ~0x7;
|
||||||
|
@ -96,7 +96,7 @@ static void sata_init(struct device *dev)
|
||||||
printk_spew("sata_bar2=%x\n", sata_bar2); /* 3040 */
|
printk_spew("sata_bar2=%x\n", sata_bar2); /* 3040 */
|
||||||
printk_spew("sata_bar3=%x\n", sata_bar3); /* 3080 */
|
printk_spew("sata_bar3=%x\n", sata_bar3); /* 3080 */
|
||||||
printk_spew("sata_bar4=%x\n", sata_bar4); /* 3000 */
|
printk_spew("sata_bar4=%x\n", sata_bar4); /* 3000 */
|
||||||
printk_spew("sata_bar5=%p\n", sata_bar5); /* e0309000 */
|
printk_spew("sata_bar5=%x\n", sata_bar5); /* e0309000 */
|
||||||
|
|
||||||
/* Program the 2C to 0x43801002 */
|
/* Program the 2C to 0x43801002 */
|
||||||
dword = 0x43801002;
|
dword = 0x43801002;
|
||||||
|
|
|
@ -88,13 +88,13 @@ static void usb_init2(struct device *dev)
|
||||||
u8 byte;
|
u8 byte;
|
||||||
u16 word;
|
u16 word;
|
||||||
u32 dword;
|
u32 dword;
|
||||||
u8 *usb2_bar0;
|
u32 usb2_bar0;
|
||||||
/* dword = pci_read_config32(dev, 0xf8); */
|
/* dword = pci_read_config32(dev, 0xf8); */
|
||||||
/* dword |= 40; */
|
/* dword |= 40; */
|
||||||
/* pci_write_config32(dev, 0xf8, dword); */
|
/* pci_write_config32(dev, 0xf8, dword); */
|
||||||
|
|
||||||
usb2_bar0 = (u8 *) (pci_read_config32(dev, 0x10) & ~0xFF);
|
usb2_bar0 = pci_read_config32(dev, 0x10) & ~0xFF;
|
||||||
printk_info("usb2_bar0=%p\n", usb2_bar0);
|
printk_info("usb2_bar0=0x%x\n", usb2_bar0);
|
||||||
|
|
||||||
/* RPR5.4 Enables the USB PHY auto calibration resister to match 45ohm resistence */
|
/* RPR5.4 Enables the USB PHY auto calibration resister to match 45ohm resistence */
|
||||||
dword = 0x00020F00;
|
dword = 0x00020F00;
|
||||||
|
|
|
@ -30,7 +30,7 @@
|
||||||
#define HDA_ICII_BUSY (1 << 0)
|
#define HDA_ICII_BUSY (1 << 0)
|
||||||
#define HDA_ICII_VALID (1 << 1)
|
#define HDA_ICII_VALID (1 << 1)
|
||||||
|
|
||||||
static int set_bits(u8 * port, u32 mask, u32 val)
|
static int set_bits(u32 port, u32 mask, u32 val)
|
||||||
{
|
{
|
||||||
u32 dword;
|
u32 dword;
|
||||||
int count;
|
int count;
|
||||||
|
@ -59,7 +59,7 @@ static int set_bits(u8 * port, u32 mask, u32 val)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static u32 codec_detect(u8 * base)
|
static u32 codec_detect(u32 base)
|
||||||
{
|
{
|
||||||
u32 dword;
|
u32 dword;
|
||||||
|
|
||||||
|
@ -94,7 +94,7 @@ no_codec:
|
||||||
* Wait 50usec for for the codec to indicate it is ready
|
* Wait 50usec for for the codec to indicate it is ready
|
||||||
* no response would imply that the codec is non-operative
|
* no response would imply that the codec is non-operative
|
||||||
*/
|
*/
|
||||||
static int wait_for_ready(u8 *base)
|
static int wait_for_ready(u32 base)
|
||||||
{
|
{
|
||||||
/* Use a 50 usec timeout - the Linux kernel uses the
|
/* Use a 50 usec timeout - the Linux kernel uses the
|
||||||
* same duration */
|
* same duration */
|
||||||
|
@ -116,7 +116,7 @@ static int wait_for_ready(u8 *base)
|
||||||
* the previous command. No response would imply that the code
|
* the previous command. No response would imply that the code
|
||||||
* is non-operative
|
* is non-operative
|
||||||
*/
|
*/
|
||||||
static int wait_for_valid(u8 *base)
|
static int wait_for_valid(u32 base)
|
||||||
{
|
{
|
||||||
/* Use a 50 usec timeout - the Linux kernel uses the
|
/* Use a 50 usec timeout - the Linux kernel uses the
|
||||||
* same duration */
|
* same duration */
|
||||||
|
@ -133,7 +133,7 @@ static int wait_for_valid(u8 *base)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void codec_init(u8 * base, int addr)
|
static void codec_init(u32 base, int addr)
|
||||||
{
|
{
|
||||||
u32 dword;
|
u32 dword;
|
||||||
|
|
||||||
|
@ -153,7 +153,7 @@ static void codec_init(u8 * base, int addr)
|
||||||
printk_debug("%x(th) codec viddid: %08x\n", addr, dword);
|
printk_debug("%x(th) codec viddid: %08x\n", addr, dword);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void codecs_init(u8 * base, u32 codec_mask)
|
static void codecs_init(u32 base, u32 codec_mask)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
for (i = 2; i >= 0; i--) {
|
for (i = 2; i >= 0; i--) {
|
||||||
|
@ -166,7 +166,7 @@ static void hda_init(struct device *dev)
|
||||||
{
|
{
|
||||||
u8 byte;
|
u8 byte;
|
||||||
u32 dword;
|
u32 dword;
|
||||||
u8 *base;
|
u32 base;
|
||||||
struct resource *res;
|
struct resource *res;
|
||||||
u32 codec_mask;
|
u32 codec_mask;
|
||||||
device_t sm_dev;
|
device_t sm_dev;
|
||||||
|
@ -202,8 +202,8 @@ static void hda_init(struct device *dev)
|
||||||
if (!res)
|
if (!res)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
base = (u8 *) ((u32)res->base);
|
base = (u32)res->base;
|
||||||
printk_debug("base = %p\n", base);
|
printk_debug("base = 0x%x\n", base);
|
||||||
codec_mask = codec_detect(base);
|
codec_mask = codec_detect(base);
|
||||||
|
|
||||||
if (codec_mask) {
|
if (codec_mask) {
|
||||||
|
|
|
@ -34,7 +34,6 @@ static void usb_init(struct device *dev)
|
||||||
{
|
{
|
||||||
u8 byte;
|
u8 byte;
|
||||||
u16 word;
|
u16 word;
|
||||||
u32 dword;
|
|
||||||
|
|
||||||
/* 6.1 Enable OHCI0-4 and EHCI Controllers */
|
/* 6.1 Enable OHCI0-4 and EHCI Controllers */
|
||||||
device_t sm_dev;
|
device_t sm_dev;
|
||||||
|
@ -70,10 +69,8 @@ static void usb_init(struct device *dev)
|
||||||
|
|
||||||
static void usb_init2(struct device *dev)
|
static void usb_init2(struct device *dev)
|
||||||
{
|
{
|
||||||
u8 byte;
|
|
||||||
u16 word;
|
|
||||||
u32 dword;
|
u32 dword;
|
||||||
u8 *usb2_bar0;
|
u32 usb2_bar0;
|
||||||
device_t sm_dev;
|
device_t sm_dev;
|
||||||
u8 rev;
|
u8 rev;
|
||||||
|
|
||||||
|
@ -84,8 +81,8 @@ static void usb_init2(struct device *dev)
|
||||||
/* dword |= 40; */
|
/* dword |= 40; */
|
||||||
/* pci_write_config32(dev, 0xf8, dword); */
|
/* pci_write_config32(dev, 0xf8, dword); */
|
||||||
|
|
||||||
usb2_bar0 = (u8 *) (pci_read_config32(dev, 0x10) & ~0xFF);
|
usb2_bar0 = pci_read_config32(dev, 0x10) & ~0xFF;
|
||||||
printk_info("usb2_bar0=%p\n", usb2_bar0);
|
printk_info("usb2_bar0=0x%x\n", usb2_bar0);
|
||||||
|
|
||||||
/* RPR6.4 Enables the USB PHY auto calibration resister to match 45ohm resistence */
|
/* RPR6.4 Enables the USB PHY auto calibration resister to match 45ohm resistence */
|
||||||
dword = 0x00020F00;
|
dword = 0x00020F00;
|
||||||
|
@ -123,6 +120,9 @@ static void usb_init2(struct device *dev)
|
||||||
/* Each step below causes the linux crashes. Leave them here
|
/* Each step below causes the linux crashes. Leave them here
|
||||||
* for future debugging. */
|
* for future debugging. */
|
||||||
#if 0
|
#if 0
|
||||||
|
u8 byte;
|
||||||
|
u16 word;
|
||||||
|
|
||||||
/* RPR6.16 Disable EHCI MSI support */
|
/* RPR6.16 Disable EHCI MSI support */
|
||||||
byte = pci_read_config8(dev, 0x50);
|
byte = pci_read_config8(dev, 0x50);
|
||||||
byte |= (1 << 6);
|
byte |= (1 << 6);
|
||||||
|
|
Loading…
Reference in a new issue