fix the broken nvidia chipset boards,
remove more 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@5397 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
parent
d4f53738e6
commit
2c0db453b6
9 changed files with 33 additions and 22 deletions
|
@ -1,5 +1,25 @@
|
||||||
|
/*
|
||||||
|
* This file is part of the coreboot project.
|
||||||
|
*
|
||||||
|
* Copyright (C) 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
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __ARCH_STAGES_H
|
||||||
|
#define __ARCH_STAGES_H
|
||||||
void cbfs_and_run_core(const char *filename, unsigned int ebp);
|
void cbfs_and_run_core(const char *filename, unsigned int ebp);
|
||||||
void __attribute__((regparm(0))) copy_and_run(unsigned cpu_reset);
|
void __attribute__((regparm(0))) copy_and_run(unsigned cpu_reset);
|
||||||
void __attribute__((regparm(0))) copy_and_run_ap_code_in_car(unsigned ret_addr);
|
void __attribute__((regparm(0))) copy_and_run_ap_code_in_car(unsigned ret_addr);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -87,8 +87,6 @@ unsigned long write_acpi_tables(unsigned long start)
|
||||||
acpi_srat_t *srat;
|
acpi_srat_t *srat;
|
||||||
acpi_rsdt_t *rsdt;
|
acpi_rsdt_t *rsdt;
|
||||||
acpi_mcfg_t *mcfg;
|
acpi_mcfg_t *mcfg;
|
||||||
acpi_hpet_t *hpet;
|
|
||||||
acpi_madt_t *madt;
|
|
||||||
acpi_fadt_t *fadt;
|
acpi_fadt_t *fadt;
|
||||||
acpi_facs_t *facs;
|
acpi_facs_t *facs;
|
||||||
acpi_header_t *dsdt;
|
acpi_header_t *dsdt;
|
||||||
|
|
|
@ -29,7 +29,6 @@ static void *smp_write_config_table(void *v)
|
||||||
static const char oem[8] = "LNXB ";
|
static const char oem[8] = "LNXB ";
|
||||||
static const char productid[12] = "A8V-E SE ";
|
static const char productid[12] = "A8V-E SE ";
|
||||||
struct mp_config_table *mc;
|
struct mp_config_table *mc;
|
||||||
unsigned int conforms = 0;
|
|
||||||
int bus_isa = 42;
|
int bus_isa = 42;
|
||||||
|
|
||||||
mc = (void *)(((char *)v) + SMP_FLOATING_TABLE_LEN);
|
mc = (void *)(((char *)v) + SMP_FLOATING_TABLE_LEN);
|
||||||
|
|
|
@ -21,8 +21,9 @@
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
#include <device/pci_ids.h>
|
#include <device/pci_ids.h>
|
||||||
#include <boot/tables.h>
|
#include <boot/tables.h>
|
||||||
|
#include <arch/coreboot_tables.h>
|
||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
#include <../../../southbridge/via/k8t890/k8t890.h>
|
#include <southbridge/via/k8t890/k8t890.h>
|
||||||
|
|
||||||
int add_mainboard_resources(struct lb_memory *mem)
|
int add_mainboard_resources(struct lb_memory *mem)
|
||||||
{
|
{
|
||||||
|
|
|
@ -62,7 +62,6 @@ static void *smp_write_config_table(void *v)
|
||||||
/*I/O APICs: APIC ID Version State Address*/
|
/*I/O APICs: APIC ID Version State Address*/
|
||||||
{
|
{
|
||||||
device_t dev = 0;
|
device_t dev = 0;
|
||||||
int i;
|
|
||||||
struct resource *res;
|
struct resource *res;
|
||||||
for(i=0; i<3; i++) {
|
for(i=0; i<3; i++) {
|
||||||
dev = dev_find_device(0x1166, 0x0235, dev);
|
dev = dev_find_device(0x1166, 0x0235, dev);
|
||||||
|
|
|
@ -50,10 +50,10 @@ static void memreset(int controllers, const struct mem_controller *ctrl)
|
||||||
static inline void activate_spd_rom(const struct mem_controller *ctrl)
|
static inline void activate_spd_rom(const struct mem_controller *ctrl)
|
||||||
{
|
{
|
||||||
#define SMBUS_HUB 0x71
|
#define SMBUS_HUB 0x71
|
||||||
int ret,i;
|
|
||||||
unsigned device=(ctrl->channel0[0])>>8;
|
unsigned device=(ctrl->channel0[0])>>8;
|
||||||
smbus_send_byte(SMBUS_HUB, device);
|
smbus_send_byte(SMBUS_HUB, device);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
static inline void change_i2c_mux(unsigned device)
|
static inline void change_i2c_mux(unsigned device)
|
||||||
{
|
{
|
||||||
|
@ -99,10 +99,8 @@ void cache_as_ram_main(unsigned long bist, unsigned long cpu_init_detectedx)
|
||||||
static const uint16_t spd_addr[] = {
|
static const uint16_t spd_addr[] = {
|
||||||
RC0|DIMM0, RC0|DIMM2, 0, 0,
|
RC0|DIMM0, RC0|DIMM2, 0, 0,
|
||||||
RC0|DIMM1, RC0|DIMM3, 0, 0,
|
RC0|DIMM1, RC0|DIMM3, 0, 0,
|
||||||
#if CONFIG_MAX_PHYSICAL_CPUS > 1
|
|
||||||
RC1|DIMM0, RC1|DIMM2, 0, 0,
|
RC1|DIMM0, RC1|DIMM2, 0, 0,
|
||||||
RC1|DIMM1, RC1|DIMM3, 0, 0,
|
RC1|DIMM1, RC1|DIMM3, 0, 0,
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
int needs_reset;
|
int needs_reset;
|
||||||
|
|
|
@ -112,7 +112,7 @@ static void setup_resource_map_x_offset(const unsigned int *register_values, int
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(SOUTHBRIDGE_NVIDIA_MCP55) || defined(SOUTHBRIDGE_NVIDIA_CK804)
|
#if defined(CONFIG_SOUTHBRIDGE_NVIDIA_MCP55) || defined(CONFIG_SOUTHBRIDGE_NVIDIA_CK804)
|
||||||
static void setup_resource_map_x(const unsigned int *register_values, int max)
|
static void setup_resource_map_x(const unsigned int *register_values, int max)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
* by yinghai.lu@amd.com
|
* by yinghai.lu@amd.com
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <reset.h>
|
||||||
static void bcm5785_enable_rom(void)
|
static void bcm5785_enable_rom(void)
|
||||||
{
|
{
|
||||||
unsigned char byte;
|
unsigned char byte;
|
||||||
|
|
|
@ -110,24 +110,21 @@ static int do_smbus_read_byte(unsigned device, unsigned address)
|
||||||
return byte;
|
return byte;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* This function is neither used nor tested by me (Corey Osgood), the author
|
|
||||||
(Yinghai) probably tested/used it on i82801er */
|
|
||||||
static int do_smbus_write_block(unsigned device, unsigned length, unsigned cmd,
|
static int do_smbus_write_block(unsigned device, unsigned length, unsigned cmd,
|
||||||
unsigned data1, unsigned data2)
|
unsigned data1, unsigned data2)
|
||||||
{
|
{
|
||||||
#warning "do_smbus_write_block is commented out"
|
|
||||||
print_err("Untested smbus_write_block called\n");
|
|
||||||
#if 0
|
|
||||||
unsigned char global_control_register;
|
unsigned char global_control_register;
|
||||||
unsigned char global_status_register;
|
unsigned char global_status_register;
|
||||||
unsigned char byte;
|
unsigned char byte;
|
||||||
unsigned char stat;
|
unsigned char stat;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
/* Clear the PM timeout flags, SECOND_TO_STS */
|
print_err("Untested smbus_write_block called\n");
|
||||||
outw(inw(0x0400 + 0x66), 0x0400 + 0x66);
|
|
||||||
|
|
||||||
if (smbus_wait_until_ready(SMBUS_IO_BASE) < 0) {
|
/* Clear the PM timeout flags, SECOND_TO_STS */
|
||||||
|
outw(inw(PMBASE_ADDR + 0x66), PMBASE_ADDR + 0x66);
|
||||||
|
|
||||||
|
if (smbus_wait_until_ready() < 0) {
|
||||||
return -2;
|
return -2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -159,9 +156,8 @@ static int do_smbus_write_block(unsigned device, unsigned length, unsigned cmd,
|
||||||
SMBUS_IO_BASE + SMBHSTCTL);
|
SMBUS_IO_BASE + SMBHSTCTL);
|
||||||
|
|
||||||
for (i = 0; i < length; i++) {
|
for (i = 0; i < length; i++) {
|
||||||
|
|
||||||
/* Poll for transaction completion */
|
/* Poll for transaction completion */
|
||||||
if (smbus_wait_until_blk_done(SMBUS_IO_BASE) < 0) {
|
if (smbus_wait_until_blk_done() < 0) {
|
||||||
return -3;
|
return -3;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -179,5 +175,4 @@ static int do_smbus_write_block(unsigned device, unsigned length, unsigned cmd,
|
||||||
|
|
||||||
print_debug("SMBUS Block complete\n");
|
print_debug("SMBUS Block complete\n");
|
||||||
return 0;
|
return 0;
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue