2003-07-21 22:13:45 +02:00
|
|
|
#include <console/console.h>
|
|
|
|
#include <device/device.h>
|
2003-08-05 00:13:57 +02:00
|
|
|
#include <device/chip.h>
|
2003-07-21 22:13:45 +02:00
|
|
|
#include <device/pci.h>
|
|
|
|
#include <device/pci_ids.h>
|
|
|
|
#include <device/pci_ops.h>
|
2003-08-05 00:13:57 +02:00
|
|
|
#include "chip.h"
|
2003-07-25 06:32:42 +02:00
|
|
|
//#include <part/mainboard.h>
|
2003-07-21 22:13:45 +02:00
|
|
|
//#include "lsi_scsi.c"
|
|
|
|
unsigned long initial_apicid[MAX_CPUS] =
|
|
|
|
{
|
|
|
|
0,1
|
|
|
|
};
|
|
|
|
/*
|
|
|
|
static void fixup_lsi_53c1030(struct device *pdev)
|
|
|
|
{
|
|
|
|
// uint8_t byte;
|
|
|
|
uint16_t word;
|
|
|
|
|
|
|
|
byte = 1;
|
|
|
|
pci_write_config8(pdev, 0xff, byte);
|
|
|
|
// Set the device id
|
|
|
|
// pci_write_config_word(pdev, PCI_DEVICE_ID, PCI_DEVICE_ID_LSILOGIC_53C1030);
|
|
|
|
// Set the subsytem vendor id
|
|
|
|
// pci_write_config16(pdev, PCI_SUBSYSTEM_VENDOR_ID, PCI_VENDOR_ID_TYAN);
|
|
|
|
word = 0x10f1;
|
|
|
|
pci_write_config16(pdev, PCI_SUBSYSTEM_VENDOR_ID, word);
|
|
|
|
// Set the subsytem id
|
|
|
|
word = 0x2880;
|
|
|
|
pci_write_config16(pdev, PCI_SUBSYSTEM_ID, word);
|
|
|
|
// Disable writes to the device id
|
|
|
|
byte = 0;
|
|
|
|
pci_write_config8(pdev, 0xff, byte);
|
|
|
|
|
|
|
|
// lsi_scsi_init(pdev);
|
|
|
|
|
|
|
|
}
|
2003-08-05 00:13:57 +02:00
|
|
|
*/
|
2003-07-21 22:13:45 +02:00
|
|
|
//extern static void lsi_scsi_init(struct device *dev);
|
2003-08-05 00:13:57 +02:00
|
|
|
/*static void print_pci_regs(struct device *dev)
|
2003-07-21 22:13:45 +02:00
|
|
|
{
|
|
|
|
uint8_t byte;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for(i=0;i<256;i++) {
|
|
|
|
byte = pci_read_config8(dev, i);
|
|
|
|
|
|
|
|
if((i%16)==0) printk_info("\n %02x:",i);
|
|
|
|
printk_debug(" %02x ",byte);
|
|
|
|
}
|
|
|
|
printk_debug("\r\n");
|
|
|
|
|
|
|
|
// pci_write_config8(dev, 0x4, byte);
|
|
|
|
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
static void onboard_scsi_fixup(void)
|
|
|
|
{
|
2003-08-05 00:13:57 +02:00
|
|
|
// struct device *dev;
|
|
|
|
|
|
|
|
/* // Set the scsi device id's
|
2003-07-21 22:13:45 +02:00
|
|
|
printk_debug("%2d:%2d:%2d\n",0,1,0);
|
|
|
|
dev = dev_find_slot(0, PCI_DEVFN(0x1, 0));
|
|
|
|
if (dev) {
|
2003-08-05 00:13:57 +02:00
|
|
|
print_pci_regs(dev);
|
2003-07-21 22:13:45 +02:00
|
|
|
}
|
|
|
|
// Set the scsi device id's
|
|
|
|
printk_debug("%2d:%2d:%2d\n",0,2,0);
|
|
|
|
dev = dev_find_slot(0, PCI_DEVFN(0x2, 0));
|
|
|
|
if (dev) {
|
|
|
|
print_pci_regs(dev);
|
|
|
|
}
|
2003-08-05 00:13:57 +02:00
|
|
|
|
|
|
|
// Set the scsi device id's
|
|
|
|
printk_debug("%2d:%2d:%2d\n",0,3,0);
|
|
|
|
dev = dev_find_slot(0, PCI_DEVFN(0x3, 0));
|
|
|
|
if (dev) {
|
|
|
|
print_pci_regs(dev);
|
|
|
|
}
|
|
|
|
|
2003-07-21 22:13:45 +02:00
|
|
|
// Set the scsi device id's
|
2003-08-05 00:13:57 +02:00
|
|
|
printk_debug("%2d:%2d:%2d\n",1,0x7,0);
|
|
|
|
dev = dev_find_slot(1, PCI_DEVFN(0x7, 0));
|
2003-07-21 22:13:45 +02:00
|
|
|
if (dev) {
|
|
|
|
print_pci_regs(dev);
|
|
|
|
}
|
|
|
|
// Set the scsi device id's
|
2003-08-05 00:13:57 +02:00
|
|
|
printk_debug("%2d:%2d:%2d\n",1,0x8,0);
|
|
|
|
dev = dev_find_slot(1, PCI_DEVFN(0x8, 0));
|
2003-07-21 22:13:45 +02:00
|
|
|
if (dev) {
|
|
|
|
print_pci_regs(dev);
|
|
|
|
}
|
2003-08-05 00:13:57 +02:00
|
|
|
printk_debug("%2d:%2d:%2d\n",2,3,0);
|
|
|
|
dev = dev_find_slot(2, PCI_DEVFN(0x3, 0));
|
2003-07-21 22:13:45 +02:00
|
|
|
if (dev) {
|
|
|
|
print_pci_regs(dev);
|
|
|
|
}
|
|
|
|
// Set the scsi device id's
|
2003-08-05 00:13:57 +02:00
|
|
|
printk_debug("%2d:%2d:%2d\n",2,6,0);
|
|
|
|
dev = dev_find_slot(2, PCI_DEVFN(0x6, 0));
|
|
|
|
if (dev) {
|
|
|
|
print_pci_regs(dev);
|
|
|
|
}
|
|
|
|
// Set the scsi device id's
|
|
|
|
printk_debug("%2d:%2d:%2d\n",3,4,0);
|
|
|
|
dev = dev_find_slot(3, PCI_DEVFN(0x4, 0));
|
2003-07-21 22:13:45 +02:00
|
|
|
if (dev) {
|
|
|
|
print_pci_regs(dev);
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
2003-08-05 00:13:57 +02:00
|
|
|
|
2003-07-21 22:13:45 +02:00
|
|
|
/*
|
|
|
|
dev = dev_find_device(PCI_VENDOR_ID_LSI_LOGIC, PCI_DEVICE_ID_LSI_53C1030,0);
|
|
|
|
if(!dev) {
|
|
|
|
printk_info("LSI_SCSI_FW_FIXUP: No Device Found!");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
lsi_scsi_init(dev);
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
|
2003-08-05 00:13:57 +02:00
|
|
|
|
2003-07-25 06:32:42 +02:00
|
|
|
static void
|
|
|
|
enable(struct chip *chip, enum chip_pass pass)
|
2003-07-21 22:13:45 +02:00
|
|
|
{
|
2003-07-25 06:32:42 +02:00
|
|
|
|
|
|
|
struct mainboard_tyan_s2880_config *conf =
|
|
|
|
(struct mainboard_tyan_s2880_config *)chip->chip_info;
|
|
|
|
|
|
|
|
switch (pass) {
|
|
|
|
default: break;
|
|
|
|
case CONF_PASS_PRE_BOOT:
|
2003-08-05 00:13:57 +02:00
|
|
|
if (conf->fixup_scsi)
|
2003-07-25 06:32:42 +02:00
|
|
|
onboard_scsi_fixup();
|
|
|
|
printk_debug("mainboard fixup pass %d done\r\n",
|
|
|
|
pass);
|
|
|
|
break;
|
|
|
|
}
|
2003-07-21 22:13:45 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
void final_mainboard_fixup(void)
|
|
|
|
{
|
|
|
|
#if 0
|
|
|
|
enable_ide_devices();
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2003-07-25 06:32:42 +02:00
|
|
|
struct chip_control mainboard_tyan_s2880_control = {
|
2003-08-05 00:13:57 +02:00
|
|
|
.enable= enable,
|
|
|
|
.name= "Tyan s2880 mainboard "
|
2003-07-25 06:32:42 +02:00
|
|
|
};
|
2003-08-05 00:13:57 +02:00
|
|
|
|