- copy_and_run() gets the same calling convention on AMD and on all the others.
- some vx800 Kconfig fixes - remove warnings... Signed-off-by: Stefan Reinauer <stepan@coresystems.de> Acked-by: Stefan Reinauer <stepan@coresystems.de> git-svn-id: svn://svn.coreboot.org/coreboot/trunk@5372 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
parent
eea66b7c35
commit
56a684a2ee
15 changed files with 197 additions and 204 deletions
|
@ -1,17 +1,30 @@
|
||||||
/* by yhlu 6.2005
|
/*
|
||||||
moved from nrv2v.c and some lines from crt0.S
|
* This file is part of the coreboot project.
|
||||||
2006/05/02 - stepan: move nrv2b to an extra file.
|
*
|
||||||
*/
|
* Copyright (C) 2009-2010 coresystems GmbH
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; version 2 of the License.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
|
||||||
void cbfs_and_run_core(const char *filename, unsigned ebp);
|
void cbfs_and_run_core(const char *filename, unsigned ebp);
|
||||||
|
|
||||||
static void copy_and_run(void)
|
static void copy_and_run(unsigned cpu_reset)
|
||||||
{
|
{
|
||||||
cbfs_and_run_core(CONFIG_CBFS_PREFIX "/coreboot_ram", 0);
|
cbfs_and_run_core(CONFIG_CBFS_PREFIX "/coreboot_ram", cpu_reset);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if CONFIG_AP_CODE_IN_CAR == 1
|
#if CONFIG_AP_CODE_IN_CAR == 1
|
||||||
|
|
||||||
static void copy_and_run_ap_code_in_car(unsigned ret_addr)
|
static void copy_and_run_ap_code_in_car(unsigned ret_addr)
|
||||||
{
|
{
|
||||||
cbfs_and_run_core(CONFIG_CBFS_PREFIX "/coreboot_ap", ret_addr);
|
cbfs_and_run_core(CONFIG_CBFS_PREFIX "/coreboot_ap", ret_addr);
|
||||||
|
|
|
@ -112,7 +112,7 @@ static void post_cache_as_ram(void)
|
||||||
// wait_all_core0_mem_trained(sysinfox); // moved to lapic_init_cpus.c
|
// wait_all_core0_mem_trained(sysinfox); // moved to lapic_init_cpus.c
|
||||||
#endif
|
#endif
|
||||||
/*copy and execute coreboot_ram */
|
/*copy and execute coreboot_ram */
|
||||||
copy_and_run();
|
copy_and_run(0);
|
||||||
/* We will not return */
|
/* We will not return */
|
||||||
|
|
||||||
print_debug("should not be here -\n");
|
print_debug("should not be here -\n");
|
||||||
|
|
|
@ -27,5 +27,4 @@ SECTIONS {
|
||||||
. = ALIGN(16);
|
. = ALIGN(16);
|
||||||
_einit = .;
|
_einit = .;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -102,7 +102,7 @@ static inline int spd_read_byte(u32 device, u32 address)
|
||||||
|
|
||||||
#include "northbridge/amd/amdk8/early_ht.c"
|
#include "northbridge/amd/amdk8/early_ht.c"
|
||||||
|
|
||||||
void sio_init(void)
|
static void sio_init(void)
|
||||||
{
|
{
|
||||||
u8 reg;
|
u8 reg;
|
||||||
|
|
||||||
|
|
|
@ -7,12 +7,10 @@
|
||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
|
|
||||||
|
|
||||||
static void irqdump()
|
static void irqdump(void)
|
||||||
{
|
{
|
||||||
volatile unsigned char *irq;
|
volatile unsigned char *irq;
|
||||||
void *mmcr;
|
void *mmcr;
|
||||||
|
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
int irqlist[] = {0xd00, 0xd02, 0xd03, 0xd04, 0xd08, 0xd0a,
|
int irqlist[] = {0xd00, 0xd02, 0xd03, 0xd04, 0xd08, 0xd0a,
|
||||||
0xd14, 0xd18, 0xd1a, 0xd1b, 0xd1c,
|
0xd14, 0xd18, 0xd1a, 0xd1b, 0xd1c,
|
||||||
|
@ -34,8 +32,9 @@ static void irqdump()
|
||||||
/* TODO: finish up mmcr struct in sc520.h, and;
|
/* TODO: finish up mmcr struct in sc520.h, and;
|
||||||
- set ADDDECTL (now done in raminit.c in cpu/amd/sc520
|
- set ADDDECTL (now done in raminit.c in cpu/amd/sc520
|
||||||
*/
|
*/
|
||||||
static void enable_dev(struct device *dev) {
|
static void enable_dev(struct device *dev)
|
||||||
volatile struct mmcrpic *pic = MMCRPIC;
|
{
|
||||||
|
//volatile struct mmcrpic *pic = MMCRPIC;
|
||||||
volatile struct mmcr *mmcr = MMCRDEFAULT;
|
volatile struct mmcr *mmcr = MMCRDEFAULT;
|
||||||
|
|
||||||
/* msm586seg has this register set to a weird value.
|
/* msm586seg has this register set to a weird value.
|
||||||
|
@ -72,15 +71,11 @@ static void enable_dev(struct device *dev) {
|
||||||
mmcr->pic.gp10imap = 0x9;
|
mmcr->pic.gp10imap = 0x9;
|
||||||
mmcr->pic.gp9imap = 0x4;
|
mmcr->pic.gp9imap = 0x4;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
irqdump();
|
irqdump();
|
||||||
printk(BIOS_ERR, "uart 1 ctl is 0x%x\n", *(unsigned char *) 0xfffefcc0);
|
printk(BIOS_ERR, "uart 1 ctl is 0x%x\n", *(unsigned char *) 0xfffefcc0);
|
||||||
|
|
||||||
printk(BIOS_ERR, "0xc20 ctl is 0x%x\n", *(unsigned short *) 0xfffefc20);
|
printk(BIOS_ERR, "0xc20 ctl is 0x%x\n", *(unsigned short *) 0xfffefc20);
|
||||||
printk(BIOS_ERR, "0xc22 0x%x\n", *(unsigned short *) 0xfffefc22b);
|
printk(BIOS_ERR, "0xc22 0x%x\n", *(unsigned short *) 0xfffefc22);
|
||||||
|
|
||||||
/* The following block has NOT proven sufficient to get
|
/* The following block has NOT proven sufficient to get
|
||||||
* the VGA hardware to talk to us
|
* the VGA hardware to talk to us
|
||||||
|
@ -124,7 +119,7 @@ static void enable_dev(struct device *dev) {
|
||||||
/* still not interrupts. */
|
/* still not interrupts. */
|
||||||
/* their IRQ table is wrong. Just hardwire it */
|
/* their IRQ table is wrong. Just hardwire it */
|
||||||
{
|
{
|
||||||
char pciints[4] = {15, 15, 15, 15};
|
unsigned char pciints[4] = {15, 15, 15, 15};
|
||||||
pci_assign_irqs(0, 12, pciints);
|
pci_assign_irqs(0, 12, pciints);
|
||||||
}
|
}
|
||||||
/* the assigned failed but we just noticed -- there is no
|
/* the assigned failed but we just noticed -- there is no
|
||||||
|
@ -133,6 +128,7 @@ static void enable_dev(struct device *dev) {
|
||||||
/* follow fuctory here */
|
/* follow fuctory here */
|
||||||
mmcr->dmacontrol.extchanmapa = 0x3210;
|
mmcr->dmacontrol.extchanmapa = 0x3210;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct chip_operations mainboard_ops = {
|
struct chip_operations mainboard_ops = {
|
||||||
CHIP_NAME("DIGITAL-LOGIC MSM586SEG Mainboard")
|
CHIP_NAME("DIGITAL-LOGIC MSM586SEG Mainboard")
|
||||||
.enable_dev = enable_dev
|
.enable_dev = enable_dev
|
||||||
|
|
|
@ -146,8 +146,6 @@ static inline int spd_read_byte(unsigned device, unsigned address)
|
||||||
|
|
||||||
static void sio_setup(void)
|
static void sio_setup(void)
|
||||||
{
|
{
|
||||||
|
|
||||||
unsigned value;
|
|
||||||
uint32_t dword;
|
uint32_t dword;
|
||||||
uint8_t byte;
|
uint8_t byte;
|
||||||
|
|
||||||
|
@ -175,7 +173,8 @@ void cache_as_ram_main(unsigned long bist, unsigned long cpu_init_detectedx)
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
struct sys_info *sysinfo = (CONFIG_DCACHE_RAM_BASE + CONFIG_DCACHE_RAM_SIZE - CONFIG_DCACHE_RAM_GLOBAL_VAR_SIZE);
|
struct sys_info *sysinfo = (struct sys_info *)(CONFIG_DCACHE_RAM_BASE +
|
||||||
|
CONFIG_DCACHE_RAM_SIZE - CONFIG_DCACHE_RAM_GLOBAL_VAR_SIZE);
|
||||||
|
|
||||||
int needs_reset = 0;
|
int needs_reset = 0;
|
||||||
unsigned bsp_apicid = 0;
|
unsigned bsp_apicid = 0;
|
||||||
|
|
|
@ -44,10 +44,6 @@
|
||||||
#define SERIAL_DEV PNP_DEV(0x2e, F71805F_SP1)
|
#define SERIAL_DEV PNP_DEV(0x2e, F71805F_SP1)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void memreset_setup(void)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int spd_read_byte(unsigned device, unsigned address)
|
static inline int spd_read_byte(unsigned device, unsigned address)
|
||||||
{
|
{
|
||||||
return smbus_read_byte(device, address);
|
return smbus_read_byte(device, address);
|
||||||
|
@ -93,9 +89,6 @@ static const struct mem_controller ctrl = {
|
||||||
|
|
||||||
static void main(unsigned long bist)
|
static void main(unsigned long bist)
|
||||||
{
|
{
|
||||||
unsigned long x;
|
|
||||||
device_t dev;
|
|
||||||
|
|
||||||
/* Enable multifunction for northbridge. */
|
/* Enable multifunction for northbridge. */
|
||||||
pci_write_config8(ctrl.d0f0, 0x4f, 0x01);
|
pci_write_config8(ctrl.d0f0, 0x4f, 0x01);
|
||||||
|
|
||||||
|
|
|
@ -36,8 +36,8 @@ void acpi_create_fadt(acpi_fadt_t *fadt, acpi_facs_t *facs, void *dsdt)
|
||||||
memcpy(header->asl_compiler_id, "LXB", 8);
|
memcpy(header->asl_compiler_id, "LXB", 8);
|
||||||
header->asl_compiler_revision = 0;
|
header->asl_compiler_revision = 0;
|
||||||
|
|
||||||
fadt->firmware_ctrl = facs;
|
fadt->firmware_ctrl = (u32)facs;
|
||||||
fadt->dsdt = dsdt;
|
fadt->dsdt = (u32)dsdt;
|
||||||
fadt->preferred_pm_profile = 0;
|
fadt->preferred_pm_profile = 0;
|
||||||
fadt->sci_int = 0x9;
|
fadt->sci_int = 0x9;
|
||||||
|
|
||||||
|
@ -105,9 +105,9 @@ void acpi_create_fadt(acpi_fadt_t *fadt, acpi_facs_t *facs, void *dsdt)
|
||||||
fadt->reset_reg.addrh = 0x0;
|
fadt->reset_reg.addrh = 0x0;
|
||||||
|
|
||||||
fadt->reset_value = 0;
|
fadt->reset_value = 0;
|
||||||
fadt->x_firmware_ctl_l = facs;
|
fadt->x_firmware_ctl_l = (u32)facs;
|
||||||
fadt->x_firmware_ctl_h = 0;
|
fadt->x_firmware_ctl_h = 0;
|
||||||
fadt->x_dsdt_l = dsdt;
|
fadt->x_dsdt_l = (u32)dsdt;
|
||||||
fadt->x_dsdt_h = 0;
|
fadt->x_dsdt_h = 0;
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = 1;
|
fadt->x_pm1a_evt_blk.space_id = 1;
|
||||||
|
|
|
@ -41,7 +41,6 @@
|
||||||
#include "pc80/udelay_io.c"
|
#include "pc80/udelay_io.c"
|
||||||
#include "lib/delay.c"
|
#include "lib/delay.c"
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "cpu/x86/lapic/boot_cpu.c"
|
|
||||||
|
|
||||||
/* This file contains the board-special SI value for raminit.c. */
|
/* This file contains the board-special SI value for raminit.c. */
|
||||||
#include "driving_clk_phase_data.c"
|
#include "driving_clk_phase_data.c"
|
||||||
|
@ -59,18 +58,6 @@
|
||||||
* This acpi_is_wakeup_early_via_VX800 is from Rudolf's patch on the list:
|
* This acpi_is_wakeup_early_via_VX800 is from Rudolf's patch on the list:
|
||||||
* http://www.coreboot.org/pipermail/coreboot/2008-January/028787.html.
|
* http://www.coreboot.org/pipermail/coreboot/2008-January/028787.html.
|
||||||
*/
|
*/
|
||||||
void jason_tsc_count_car(void)
|
|
||||||
{
|
|
||||||
#if 0
|
|
||||||
unsigned long long start;
|
|
||||||
asm volatile ("rdtsc" : "=A" (start));
|
|
||||||
start >>= 20;
|
|
||||||
print_emerg("jason_tsc_count_car= ");
|
|
||||||
print_emerg_hex32((unsigned long) start);
|
|
||||||
print_emerg("\n");
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int acpi_is_wakeup_early_via_vx800(void)
|
int acpi_is_wakeup_early_via_vx800(void)
|
||||||
{
|
{
|
||||||
device_t dev;
|
device_t dev;
|
||||||
|
@ -431,8 +418,6 @@ void stage1_main(unsigned long bist)
|
||||||
* g) Rx73h = 32h
|
* g) Rx73h = 32h
|
||||||
*/
|
*/
|
||||||
|
|
||||||
jason_tsc_count_car();
|
|
||||||
|
|
||||||
pci_write_config16(PCI_DEV(0, 0xf, 0), 0xBA,
|
pci_write_config16(PCI_DEV(0, 0xf, 0), 0xBA,
|
||||||
PCI_DEVICE_ID_VIA_VX855_IDE);
|
PCI_DEVICE_ID_VIA_VX855_IDE);
|
||||||
pci_write_config16(PCI_DEV(0, 0xf, 0), 0xBE,
|
pci_write_config16(PCI_DEV(0, 0xf, 0), 0xBE,
|
||||||
|
@ -462,7 +447,6 @@ void stage1_main(unsigned long bist)
|
||||||
* written, then this must be a CPU restart (result of OS reboot cmd),
|
* written, then this must be a CPU restart (result of OS reboot cmd),
|
||||||
* so we need a real "cold boot".
|
* so we need a real "cold boot".
|
||||||
*/
|
*/
|
||||||
jason_tsc_count_car();
|
|
||||||
if ((boot_mode != 3)
|
if ((boot_mode != 3)
|
||||||
&& (pci_read_config8(PCI_DEV(0, 0, 3), 0x80) != 0)) {
|
&& (pci_read_config8(PCI_DEV(0, 0, 3), 0x80) != 0)) {
|
||||||
outb(6, 0xcf9);
|
outb(6, 0xcf9);
|
||||||
|
@ -471,7 +455,6 @@ void stage1_main(unsigned long bist)
|
||||||
/* x86 cold boot I/O cmd. */
|
/* x86 cold boot I/O cmd. */
|
||||||
/* These 2 lines are the same with epia-cn port. */
|
/* These 2 lines are the same with epia-cn port. */
|
||||||
enable_smbus();
|
enable_smbus();
|
||||||
jason_tsc_count_car();
|
|
||||||
|
|
||||||
/* This fix does help vx800!, but vx855 doesn't need this. */
|
/* This fix does help vx800!, but vx855 doesn't need this. */
|
||||||
/* smbus_fixup(&ctrl); */
|
/* smbus_fixup(&ctrl); */
|
||||||
|
@ -564,8 +547,6 @@ void stage1_main(unsigned long bist)
|
||||||
/* This line is the same with cx700 port. */
|
/* This line is the same with cx700 port. */
|
||||||
enable_shadow_ram();
|
enable_shadow_ram();
|
||||||
|
|
||||||
jason_tsc_count_car();
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* For coreboot most time of S3 resume is the same as normal boot,
|
* For coreboot most time of S3 resume is the same as normal boot,
|
||||||
* so some memory area under 1M become dirty, so before this happen,
|
* so some memory area under 1M become dirty, so before this happen,
|
||||||
|
@ -801,7 +782,6 @@ cpu_reset_x:
|
||||||
print_debug("\n");
|
print_debug("\n");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
jason_tsc_count_car();
|
|
||||||
/* Copy and execute coreboot_ram. */
|
/* Copy and execute coreboot_ram. */
|
||||||
copy_and_run(new_cpu_reset);
|
copy_and_run(new_cpu_reset);
|
||||||
/* We will not return. */
|
/* We will not return. */
|
||||||
|
|
|
@ -111,9 +111,7 @@ static unsigned char show32[6] = {
|
||||||
|
|
||||||
void acpi_jump_wake(u32 vector)
|
void acpi_jump_wake(u32 vector)
|
||||||
{
|
{
|
||||||
u32 tmp, dwEip;
|
u32 dwEip;
|
||||||
u16 tmpvector;
|
|
||||||
u8 Data;
|
|
||||||
struct Xgt_desc_struct *wake_thunk16_Xgt_desc;
|
struct Xgt_desc_struct *wake_thunk16_Xgt_desc;
|
||||||
|
|
||||||
printk(BIOS_DEBUG, "IN ACPI JUMP WAKE TO %x\n", vector);
|
printk(BIOS_DEBUG, "IN ACPI JUMP WAKE TO %x\n", vector);
|
||||||
|
|
|
@ -75,7 +75,7 @@ static void enable_shadow_ram(void)
|
||||||
pci_write_config8(dev, 0x63, shadowreg);
|
pci_write_config8(dev, 0x63, shadowreg);
|
||||||
}
|
}
|
||||||
|
|
||||||
void main(unsigned long bist)
|
static void main(unsigned long bist)
|
||||||
{
|
{
|
||||||
if (bist == 0) {
|
if (bist == 0) {
|
||||||
early_mtrr_init();
|
early_mtrr_init();
|
||||||
|
|
|
@ -142,7 +142,6 @@ static void pci_domain_set_resources(device_t dev)
|
||||||
* this register's value multiply 64 * 1024 * 1024
|
* this register's value multiply 64 * 1024 * 1024
|
||||||
*/
|
*/
|
||||||
for (rambits = 0, i = 0; i < ARRAY_SIZE(ramregs); i++) {
|
for (rambits = 0, i = 0; i < ARRAY_SIZE(ramregs); i++) {
|
||||||
unsigned char reg;
|
|
||||||
rambits = pci_read_config8(mc_dev, ramregs[i]);
|
rambits = pci_read_config8(mc_dev, ramregs[i]);
|
||||||
if (rambits != 0)
|
if (rambits != 0)
|
||||||
break;
|
break;
|
||||||
|
@ -179,7 +178,7 @@ if register with invalid value we set frame buffer size to 32M for default, but
|
||||||
assign_resources(&dev->link[0]);
|
assign_resources(&dev->link[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct device_operations pci_domain_ops = {
|
static struct device_operations pci_domain_ops = {
|
||||||
.read_resources = pci_domain_read_resources,
|
.read_resources = pci_domain_read_resources,
|
||||||
.set_resources = pci_domain_set_resources,
|
.set_resources = pci_domain_set_resources,
|
||||||
.enable_resources = enable_childrens_resources,
|
.enable_resources = enable_childrens_resources,
|
||||||
|
@ -196,7 +195,7 @@ static void cpu_bus_noop(device_t dev)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct device_operations cpu_bus_ops = {
|
static struct device_operations cpu_bus_ops = {
|
||||||
.read_resources = cpu_bus_noop,
|
.read_resources = cpu_bus_noop,
|
||||||
.set_resources = cpu_bus_noop,
|
.set_resources = cpu_bus_noop,
|
||||||
.enable_resources = cpu_bus_noop,
|
.enable_resources = cpu_bus_noop,
|
||||||
|
|
|
@ -26,243 +26,260 @@
|
||||||
(((SEGBUS) & 0xFFF) << 20) | \
|
(((SEGBUS) & 0xFFF) << 20) | \
|
||||||
(((DEV) & 0x1F) << 15) | \
|
(((DEV) & 0x1F) << 15) | \
|
||||||
(((FN) & 0x07) << 12))
|
(((FN) & 0x07) << 12))
|
||||||
struct VIA_PCI_REG_INIT_TABLE {
|
|
||||||
|
struct VIA_PCI_REG_INIT_TABLE {
|
||||||
u8 ChipRevisionStart;
|
u8 ChipRevisionStart;
|
||||||
u8 ChipRevisionEnd;
|
u8 ChipRevisionEnd;
|
||||||
u8 Bus;
|
u8 Bus;
|
||||||
u8 Device;
|
u8 Device;
|
||||||
u8 Function;
|
u8 Function;
|
||||||
u32 Register;
|
u32 Register;
|
||||||
u8 Mask;
|
u8 Mask;
|
||||||
u8 Value;
|
u8 Value;
|
||||||
};
|
};
|
||||||
typedef unsigned device_t_raw; /* pci and pci_mmio need to have different ways to have dev */
|
typedef unsigned device_t_raw; /* pci and pci_mmio need to have different ways to have dev */
|
||||||
|
|
||||||
/* FIXME: We need to make the coreboot to run at 64bit mode, So when read/write memory above 4G,
|
/* FIXME: We need to make the coreboot to run at 64bit mode, So when read/write memory above 4G,
|
||||||
* We don't need to set %fs, and %gs anymore
|
* We don't need to set %fs, and %gs anymore
|
||||||
* Before that We need to use %gs, and leave %fs to other RAM access
|
* Before that We need to use %gs, and leave %fs to other RAM access
|
||||||
*/
|
*/
|
||||||
uint8_t pci_io_rawread_config8(device_t_raw dev, unsigned where)
|
u8 pci_io_rawread_config8(device_t_raw dev, unsigned where)
|
||||||
{
|
{
|
||||||
unsigned addr;
|
unsigned addr;
|
||||||
#if PCI_IO_CFG_EXT == 0
|
#if CONFIG_PCI_IO_CFG_EXT == 0
|
||||||
addr = (dev>>4) | where;
|
addr = (dev >> 4) | where;
|
||||||
#else
|
#else
|
||||||
addr = (dev>>4) | (where & 0xff) | ((where & 0xf00)<<16); //seg == 0
|
addr = (dev >> 4) | (where & 0xff) | ((where & 0xf00) << 16); //seg == 0
|
||||||
#endif
|
#endif
|
||||||
outl(0x80000000 | (addr & ~3), 0xCF8);
|
outl(0x80000000 | (addr & ~3), 0xCF8);
|
||||||
return inb(0xCFC + (addr & 3));
|
return inb(0xCFC + (addr & 3));
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MMCONF_SUPPORT
|
#if CONFIG_MMCONF_SUPPORT
|
||||||
uint8_t pci_mmio_rawread_config8(device_t_raw dev, unsigned where)
|
u8 pci_mmio_rawread_config8(device_t_raw dev, unsigned where)
|
||||||
{
|
{
|
||||||
unsigned addr;
|
unsigned addr;
|
||||||
addr = dev | where;
|
addr = dev | where;
|
||||||
return read8x(addr);
|
return read8x(addr);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
uint8_t pci_rawread_config8(device_t_raw dev, unsigned where)
|
u8 pci_rawread_config8(device_t_raw dev, unsigned where)
|
||||||
{
|
{
|
||||||
#if MMCONF_SUPPORT
|
#if CONFIG_MMCONF_SUPPORT
|
||||||
return pci_mmio_rawread_config8(dev, where);
|
return pci_mmio_rawread_config8(dev, where);
|
||||||
#else
|
#else
|
||||||
return pci_io_rawread_config8(dev, where);
|
return pci_io_rawread_config8(dev, where);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
uint16_t pci_io_rawread_config16(device_t_raw dev, unsigned where)
|
u16 pci_io_rawread_config16(device_t_raw dev, unsigned where)
|
||||||
{
|
{
|
||||||
unsigned addr;
|
unsigned addr;
|
||||||
#if PCI_IO_CFG_EXT == 0
|
#if CONFIG_PCI_IO_CFG_EXT == 0
|
||||||
addr = (dev>>4) | where;
|
addr = (dev >> 4) | where;
|
||||||
#else
|
#else
|
||||||
addr = (dev>>4) | (where & 0xff) | ((where & 0xf00)<<16);
|
addr = (dev >> 4) | (where & 0xff) | ((where & 0xf00) << 16);
|
||||||
#endif
|
#endif
|
||||||
outl(0x80000000 | (addr & ~3), 0xCF8);
|
outl(0x80000000 | (addr & ~3), 0xCF8);
|
||||||
return inw(0xCFC + (addr & 2));
|
return inw(0xCFC + (addr & 2));
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MMCONF_SUPPORT
|
#if CONFIG_MMCONF_SUPPORT
|
||||||
uint16_t pci_mmio_rawread_config16(device_t_raw dev, unsigned where)
|
u16 pci_mmio_rawread_config16(device_t_raw dev, unsigned where)
|
||||||
{
|
|
||||||
unsigned addr;
|
|
||||||
addr = dev | where;
|
|
||||||
return read16x(addr);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
uint16_t pci_rawread_config16(device_t_raw dev, unsigned where)
|
|
||||||
{
|
|
||||||
#if MMCONF_SUPPORT
|
|
||||||
return pci_mmio_rawread_config16(dev, where);
|
|
||||||
#else
|
|
||||||
return pci_io_rawread_config16(dev, where);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
uint32_t pci_io_rawread_config32(device_t_raw dev, unsigned where)
|
|
||||||
{
|
{
|
||||||
unsigned addr;
|
unsigned addr;
|
||||||
#if PCI_IO_CFG_EXT == 0
|
addr = dev | where;
|
||||||
addr = (dev>>4) | where;
|
return read16x(addr);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
u16 pci_rawread_config16(device_t_raw dev, unsigned where)
|
||||||
|
{
|
||||||
|
#if CONFIG_MMCONF_SUPPORT
|
||||||
|
return pci_mmio_rawread_config16(dev, where);
|
||||||
#else
|
#else
|
||||||
addr = (dev>>4) | (where & 0xff) | ((where & 0xf00)<<16);
|
return pci_io_rawread_config16(dev, where);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 pci_io_rawread_config32(device_t_raw dev, unsigned where)
|
||||||
|
{
|
||||||
|
unsigned addr;
|
||||||
|
#if CONFIG_PCI_IO_CFG_EXT == 0
|
||||||
|
addr = (dev >> 4) | where;
|
||||||
|
#else
|
||||||
|
addr = (dev >> 4) | (where & 0xff) | ((where & 0xf00) << 16);
|
||||||
#endif
|
#endif
|
||||||
outl(0x80000000 | (addr & ~3), 0xCF8);
|
outl(0x80000000 | (addr & ~3), 0xCF8);
|
||||||
return inl(0xCFC);
|
return inl(0xCFC);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MMCONF_SUPPORT
|
#if CONFIG_MMCONF_SUPPORT
|
||||||
uint32_t pci_mmio_rawread_config32(device_t_raw dev, unsigned where)
|
u32 pci_mmio_rawread_config32(device_t_raw dev, unsigned where)
|
||||||
{
|
|
||||||
unsigned addr;
|
|
||||||
addr = dev | where;
|
|
||||||
return read32x(addr);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
uint32_t pci_rawread_config32(device_t_raw dev, unsigned where)
|
|
||||||
{
|
|
||||||
#if MMCONF_SUPPORT
|
|
||||||
return pci_mmio_rawread_config32(dev, where);
|
|
||||||
#else
|
|
||||||
return pci_io_rawread_config32(dev, where);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void pci_io_rawwrite_config8(device_t_raw dev, unsigned where, uint8_t value)
|
|
||||||
{
|
{
|
||||||
unsigned addr;
|
unsigned addr;
|
||||||
#if PCI_IO_CFG_EXT == 0
|
addr = dev | where;
|
||||||
addr = (dev>>4) | where;
|
return read32x(addr);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
u32 pci_rawread_config32(device_t_raw dev, unsigned where)
|
||||||
|
{
|
||||||
|
#if CONFIG_MMCONF_SUPPORT
|
||||||
|
return pci_mmio_rawread_config32(dev, where);
|
||||||
#else
|
#else
|
||||||
addr = (dev>>4) | (where & 0xff) | ((where & 0xf00)<<16);
|
return pci_io_rawread_config32(dev, where);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void pci_io_rawwrite_config8(device_t_raw dev, unsigned where, u8 value)
|
||||||
|
{
|
||||||
|
unsigned addr;
|
||||||
|
#if CONFIG_PCI_IO_CFG_EXT == 0
|
||||||
|
addr = (dev >> 4) | where;
|
||||||
|
#else
|
||||||
|
addr = (dev >> 4) | (where & 0xff) | ((where & 0xf00) << 16);
|
||||||
#endif
|
#endif
|
||||||
outl(0x80000000 | (addr & ~3), 0xCF8);
|
outl(0x80000000 | (addr & ~3), 0xCF8);
|
||||||
outb(value, 0xCFC + (addr & 3));
|
outb(value, 0xCFC + (addr & 3));
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MMCONF_SUPPORT
|
#if CONFIG_MMCONF_SUPPORT
|
||||||
void pci_mmio_rawwrite_config8(device_t_raw dev, unsigned where, uint8_t value)
|
void pci_mmio_rawwrite_config8(device_t_raw dev, unsigned where, u8 value)
|
||||||
{
|
{
|
||||||
unsigned addr;
|
unsigned addr;
|
||||||
addr = dev | where;
|
addr = dev | where;
|
||||||
write8x(addr, value);
|
write8x(addr, value);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void pci_rawwrite_config8(device_t_raw dev, unsigned where, uint8_t value)
|
void pci_rawwrite_config8(device_t_raw dev, unsigned where, u8 value)
|
||||||
{
|
{
|
||||||
#if MMCONF_SUPPORT
|
#if CONFIG_MMCONF_SUPPORT
|
||||||
pci_mmio_rawwrite_config8(dev, where, value);
|
pci_mmio_rawwrite_config8(dev, where, value);
|
||||||
#else
|
#else
|
||||||
pci_io_rawwrite_config8(dev, where, value);
|
pci_io_rawwrite_config8(dev, where, value);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void pci_io_rawwrite_config16(device_t_raw dev, unsigned where, u16 value)
|
||||||
void pci_io_rawwrite_config16(device_t_raw dev, unsigned where, uint16_t value)
|
|
||||||
{
|
{
|
||||||
unsigned addr;
|
unsigned addr;
|
||||||
#if PCI_IO_CFG_EXT == 0
|
#if CONFIG_PCI_IO_CFG_EXT == 0
|
||||||
addr = (dev>>4) | where;
|
addr = (dev >> 4) | where;
|
||||||
#else
|
#else
|
||||||
addr = (dev>>4) | (where & 0xff) | ((where & 0xf00)<<16);
|
addr = (dev >> 4) | (where & 0xff) | ((where & 0xf00) << 16);
|
||||||
#endif
|
#endif
|
||||||
outl(0x80000000 | (addr & ~3), 0xCF8);
|
outl(0x80000000 | (addr & ~3), 0xCF8);
|
||||||
outw(value, 0xCFC + (addr & 2));
|
outw(value, 0xCFC + (addr & 2));
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MMCONF_SUPPORT
|
#if CONFIG_MMCONF_SUPPORT
|
||||||
void pci_mmio_rawwrite_config16(device_t_raw dev, unsigned where, uint16_t value)
|
void pci_mmio_rawwrite_config16(device_t_raw dev, unsigned where,
|
||||||
|
u16 value)
|
||||||
{
|
{
|
||||||
unsigned addr;
|
unsigned addr;
|
||||||
addr = dev | where;
|
addr = dev | where;
|
||||||
write16x(addr, value);
|
write16x(addr, value);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void pci_rawwrite_config16(device_t_raw dev, unsigned where, uint16_t value)
|
void pci_rawwrite_config16(device_t_raw dev, unsigned where, u16 value)
|
||||||
{
|
{
|
||||||
#if MMCONF_SUPPORT
|
#if CONFIG_MMCONF_SUPPORT
|
||||||
pci_mmio_rawwrite_config16(dev, where, value);
|
pci_mmio_rawwrite_config16(dev, where, value);
|
||||||
#else
|
#else
|
||||||
pci_io_rawwrite_config16(dev, where, value);
|
pci_io_rawwrite_config16(dev, where, value);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void pci_io_rawwrite_config32(device_t_raw dev, unsigned where, u32 value)
|
||||||
void pci_io_rawwrite_config32(device_t_raw dev, unsigned where, uint32_t value)
|
|
||||||
{
|
{
|
||||||
unsigned addr;
|
unsigned addr;
|
||||||
#if PCI_IO_CFG_EXT == 0
|
#if CONFIG_PCI_IO_CFG_EXT == 0
|
||||||
addr = (dev>>4) | where;
|
addr = (dev >> 4) | where;
|
||||||
#else
|
#else
|
||||||
addr = (dev>>4) | (where & 0xff) | ((where & 0xf00)<<16);
|
addr = (dev >> 4) | (where & 0xff) | ((where & 0xf00) << 16);
|
||||||
#endif
|
#endif
|
||||||
outl(0x80000000 | (addr & ~3), 0xCF8);
|
outl(0x80000000 | (addr & ~3), 0xCF8);
|
||||||
outl(value, 0xCFC);
|
outl(value, 0xCFC);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MMCONF_SUPPORT
|
#if CONFIG_MMCONF_SUPPORT
|
||||||
void pci_mmio_rawwrite_config32(device_t_raw dev, unsigned where, uint32_t value)
|
void pci_mmio_rawwrite_config32(device_t_raw dev, unsigned where,
|
||||||
|
u32 value)
|
||||||
{
|
{
|
||||||
unsigned addr;
|
unsigned addr;
|
||||||
addr = dev | where;
|
addr = dev | where;
|
||||||
write32x(addr, value);
|
write32x(addr, value);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void pci_rawwrite_config32(device_t_raw dev, unsigned where, uint32_t value)
|
void pci_rawwrite_config32(device_t_raw dev, unsigned where, u32 value)
|
||||||
{
|
{
|
||||||
#if MMCONF_SUPPORT
|
#if CONFIG_MMCONF_SUPPORT
|
||||||
pci_mmio_rawwrite_config32(dev, where, value);
|
pci_mmio_rawwrite_config32(dev, where, value);
|
||||||
#else
|
#else
|
||||||
pci_io_rawwrite_config32(dev, where, value);
|
pci_io_rawwrite_config32(dev, where, value);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void pci_rawmodify_config8(device_t_raw dev, unsigned where, u8 orval, u8 mask)
|
||||||
void pci_rawmodify_config8(device_t_raw dev, unsigned where, u8 orval,u8 mask)
|
|
||||||
{ u8 data=pci_rawread_config8(dev,where);
|
|
||||||
data&=(~mask);
|
|
||||||
data|=orval;
|
|
||||||
pci_rawwrite_config8(dev,where,data);
|
|
||||||
}
|
|
||||||
void pci_rawmodify_config16(device_t_raw dev, unsigned where, uint16_t orval,uint16_t mask)
|
|
||||||
{ uint16_t data=pci_rawread_config16(dev,where);
|
|
||||||
data&=(~mask);
|
|
||||||
data|=orval;
|
|
||||||
pci_rawwrite_config16(dev,where,data);
|
|
||||||
}
|
|
||||||
void pci_rawmodify_config32(device_t_raw dev, unsigned where, uint32_t orval,uint32_t mask)
|
|
||||||
{ uint32_t data=pci_rawread_config32(dev,where);
|
|
||||||
data&=(~mask);
|
|
||||||
data|=orval;
|
|
||||||
pci_rawwrite_config32(dev,where,data);
|
|
||||||
}
|
|
||||||
|
|
||||||
void io_rawmodify_config8(u16 where, uint8_t orval,uint8_t mask)
|
|
||||||
{
|
{
|
||||||
u8 data=inb(where);
|
u8 data = pci_rawread_config8(dev, where);
|
||||||
data&=(~mask);
|
data &= (~mask);
|
||||||
data|=orval;
|
data |= orval;
|
||||||
outb(data,where);
|
pci_rawwrite_config8(dev, where, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
void via_pci_inittable(u8 chipversion,struct VIA_PCI_REG_INIT_TABLE* initdata)
|
void pci_rawmodify_config16(device_t_raw dev, unsigned where, u16 orval, u16 mask)
|
||||||
{
|
{
|
||||||
u8 i=0;
|
u16 data = pci_rawread_config16(dev, where);
|
||||||
|
data &= (~mask);
|
||||||
|
data |= orval;
|
||||||
|
pci_rawwrite_config16(dev, where, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
void pci_rawmodify_config32(device_t_raw dev, unsigned where, u32 orval, u32 mask)
|
||||||
|
{
|
||||||
|
u32 data = pci_rawread_config32(dev, where);
|
||||||
|
data &= (~mask);
|
||||||
|
data |= orval;
|
||||||
|
pci_rawwrite_config32(dev, where, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
void io_rawmodify_config8(u16 where, u8 orval, u8 mask)
|
||||||
|
{
|
||||||
|
u8 data = inb(where);
|
||||||
|
data &= (~mask);
|
||||||
|
data |= orval;
|
||||||
|
outb(data, where);
|
||||||
|
}
|
||||||
|
|
||||||
|
void via_pci_inittable(u8 chipversion,
|
||||||
|
struct VIA_PCI_REG_INIT_TABLE *initdata)
|
||||||
|
{
|
||||||
|
u8 i = 0;
|
||||||
device_t_raw devbxdxfx;
|
device_t_raw devbxdxfx;
|
||||||
for(i=0;;i++) {
|
for (i = 0;; i++) {
|
||||||
if((initdata[i].Mask==0)&&(initdata[i].Value==0)&&(initdata[i].Bus==0)&&(initdata[i].ChipRevisionEnd==0xff)&&(initdata[i].ChipRevisionStart==0)&&(initdata[i].Device==0)&&(initdata[i].Function==0)&&(initdata[i].Register==0))
|
if ((initdata[i].Mask == 0) && (initdata[i].Value == 0)
|
||||||
break;
|
&& (initdata[i].Bus == 0)
|
||||||
if((chipversion>=initdata[i].ChipRevisionStart)&&(chipversion<=initdata[i].ChipRevisionEnd)){
|
&& (initdata[i].ChipRevisionEnd == 0xff)
|
||||||
devbxdxfx=PCI_RAWDEV(initdata[i].Bus,initdata[i].Device,initdata[i].Function);
|
&& (initdata[i].ChipRevisionStart == 0)
|
||||||
pci_rawmodify_config8(devbxdxfx, initdata[i].Register,initdata[i].Value,initdata[i].Mask);
|
&& (initdata[i].Device == 0)
|
||||||
}
|
&& (initdata[i].Function == 0)
|
||||||
|
&& (initdata[i].Register == 0))
|
||||||
|
break;
|
||||||
|
if ((chipversion >= initdata[i].ChipRevisionStart)
|
||||||
|
&& (chipversion <= initdata[i].ChipRevisionEnd)) {
|
||||||
|
devbxdxfx =
|
||||||
|
PCI_RAWDEV(initdata[i].Bus, initdata[i].Device,
|
||||||
|
initdata[i].Function);
|
||||||
|
pci_rawmodify_config8(devbxdxfx,
|
||||||
|
initdata[i].Register,
|
||||||
|
initdata[i].Value,
|
||||||
|
initdata[i].Mask);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
#include <arch/io.h>
|
#include <arch/io.h>
|
||||||
#include "vx800.h"
|
#include "vx800.h"
|
||||||
|
|
||||||
static const idedevicepcitable[16 * 12] = {
|
static const u8 idedevicepcitable[16 * 12] = {
|
||||||
/*
|
/*
|
||||||
0x02, 0x00, 0x00, 0x00, 0x00, 0x82, 0x00, 0x00,
|
0x02, 0x00, 0x00, 0x00, 0x00, 0x82, 0x00, 0x00,
|
||||||
0x00, 0x00, 0xA8, 0xA8, 0xF0, 0x00, 0x00, 0xB6,
|
0x00, 0x00, 0xA8, 0xA8, 0xF0, 0x00, 0x00, 0xB6,
|
||||||
|
|
|
@ -104,7 +104,7 @@ static void pci_routing_fixup(struct device *dev)
|
||||||
printk(BIOS_SPEW, "%s: DONE\n", __FUNCTION__);
|
printk(BIOS_SPEW, "%s: DONE\n", __FUNCTION__);
|
||||||
}
|
}
|
||||||
|
|
||||||
void setup_pm(device_t dev)
|
static void setup_pm(device_t dev)
|
||||||
{
|
{
|
||||||
u16 tmp;
|
u16 tmp;
|
||||||
/* Debounce LID and PWRBTN# Inputs for 16ms. */
|
/* Debounce LID and PWRBTN# Inputs for 16ms. */
|
||||||
|
@ -198,7 +198,7 @@ void setup_pm(device_t dev)
|
||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
void S3_ps2_kb_ms_wakeup(struct device *dev)
|
static void S3_ps2_kb_ms_wakeup(struct device *dev)
|
||||||
{
|
{
|
||||||
u8 enables;
|
u8 enables;
|
||||||
enables = pci_read_config8(dev, 0x51);
|
enables = pci_read_config8(dev, 0x51);
|
||||||
|
@ -222,12 +222,12 @@ void S3_ps2_kb_ms_wakeup(struct device *dev)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void S3_usb_wakeup(struct device *dev)
|
static void S3_usb_wakeup(struct device *dev)
|
||||||
{
|
{
|
||||||
outw(inw(VX800_ACPI_IO_BASE + 0x22) | 0x4000, VX800_ACPI_IO_BASE + 0x22); //SCI on USB PME
|
outw(inw(VX800_ACPI_IO_BASE + 0x22) | 0x4000, VX800_ACPI_IO_BASE + 0x22); //SCI on USB PME
|
||||||
}
|
}
|
||||||
|
|
||||||
void S3_lid_wakeup(struct device *dev)
|
static void S3_lid_wakeup(struct device *dev)
|
||||||
{
|
{
|
||||||
outw(inw(VX800_ACPI_IO_BASE + 0x22) | 0x800, VX800_ACPI_IO_BASE + 0x22); //SCI on LID PME
|
outw(inw(VX800_ACPI_IO_BASE + 0x22) | 0x800, VX800_ACPI_IO_BASE + 0x22); //SCI on LID PME
|
||||||
}
|
}
|
||||||
|
@ -301,7 +301,7 @@ static void vx800_sb_init(struct device *dev)
|
||||||
|
|
||||||
/* total kludge to get lxb to call our childrens set/enable functions - these are
|
/* total kludge to get lxb to call our childrens set/enable functions - these are
|
||||||
not called unless this device has a resource to set - so set a dummy one */
|
not called unless this device has a resource to set - so set a dummy one */
|
||||||
void vx800_read_resources(device_t dev)
|
static void vx800_read_resources(device_t dev)
|
||||||
{
|
{
|
||||||
|
|
||||||
struct resource *resource;
|
struct resource *resource;
|
||||||
|
@ -312,10 +312,9 @@ void vx800_read_resources(device_t dev)
|
||||||
IORESOURCE_STORED;
|
IORESOURCE_STORED;
|
||||||
resource->size = 2;
|
resource->size = 2;
|
||||||
resource->base = 0x2e;
|
resource->base = 0x2e;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void vx800_set_resources(device_t dev)
|
static void vx800_set_resources(device_t dev)
|
||||||
{
|
{
|
||||||
struct resource *resource;
|
struct resource *resource;
|
||||||
resource = find_resource(dev, 1);
|
resource = find_resource(dev, 1);
|
||||||
|
@ -323,7 +322,7 @@ void vx800_set_resources(device_t dev)
|
||||||
pci_dev_set_resources(dev);
|
pci_dev_set_resources(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
void vx800_enable_resources(device_t dev)
|
static void vx800_enable_resources(device_t dev)
|
||||||
{
|
{
|
||||||
/* vx800 is not a pci bridge and has no resources of its own (other than
|
/* vx800 is not a pci bridge and has no resources of its own (other than
|
||||||
standard PC i/o addresses). however it does control the isa bus and so
|
standard PC i/o addresses). however it does control the isa bus and so
|
||||||
|
|
Loading…
Reference in a new issue