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:
Stefan Reinauer 2010-04-09 15:29:13 +00:00 committed by Stefan Reinauer
parent d4f53738e6
commit 2c0db453b6
9 changed files with 33 additions and 22 deletions

View file

@ -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

View file

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

View file

@ -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);

View file

@ -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)
{ {

View file

@ -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);

View file

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

View file

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

View file

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

View file

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