[LinuxBIOS] r2775 - trunk/LinuxBIOSv2/src/southbridge/amd/cs5530

svn at openbios.org svn at openbios.org
Fri Sep 14 02:09:29 CEST 2007


Author: uwe
Date: 2007-09-14 02:09:29 +0200 (Fri, 14 Sep 2007)
New Revision: 2775

Added:
   trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530_isa.c
Modified:
   trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/Config.lb
   trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/chip.h
   trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530.c
   trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530.h
   trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530_ide.c
Log:
This is a full rewrite of all the CS5530/CS5530A code. The previous code was
mostly undocumented, had a broken coding style, contained lots of dead
code and had several other problems, e.g. it enabled write access to the
ROM (why?), it unconditionally enabled primary/secondary IDE (which should
have a config option) and that even _twice_ (which is um... wrong).

The new code

 - has 'ide0_enable' and 'ide1_enable' config options (which actually
   work) to enable/disable the primary/secondary IDE interface in
   Config.lb.

 - Does _not_ enable write access to the ROM (or is there some good
   reason to do that? If so, it should at least have a config option).

 - Contains a bit more documentation.

 - Uses readable (and documented) #defines instead of hardcoded magic values.

 - aaand... it actually compiles ;-) Yep, that's right. The previous code
   wouldn't even build, as it hadn't been fully ported from v1 (still used
   v1 functions which are simply not available in v2).

Signed-off-by: Uwe Hermann <uwe at hermann-uwe.de>
Acked-by: Ronald G. Minnich <rminnich at gmail.com>



Modified: trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/Config.lb
===================================================================
--- trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/Config.lb	2007-09-13 13:47:02 UTC (rev 2774)
+++ trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/Config.lb	2007-09-14 00:09:29 UTC (rev 2775)
@@ -1,4 +1,24 @@
-#config chip.h
+##
+## This file is part of the LinuxBIOS project.
+##
+## Copyright (C) 2007 Uwe Hermann <uwe at hermann-uwe.de>
+##
+## 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; either version 2 of the License, or
+## (at your option) any later version.
+##
+## 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
+##
+
+config chip.h
 driver cs5530.o
-#driver cs5530_pci.o
+driver cs5530_isa.o
 driver cs5530_ide.o

Modified: trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/chip.h
===================================================================
--- trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/chip.h	2007-09-13 13:47:02 UTC (rev 2774)
+++ trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/chip.h	2007-09-14 00:09:29 UTC (rev 2775)
@@ -1,12 +1,31 @@
-#ifndef _SOUTHBRIDGE_AMD_CS5530
-#define _SOUTHBRIDGE_AMD_CS5530
+/*
+ * This file is part of the LinuxBIOS project.
+ *
+ * Copyright (C) 2007 Uwe Hermann <uwe at hermann-uwe.de>
+ *
+ * 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; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * 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 SOUTHBRIDGE_AMD_CS5530_CHIP_H
+#define SOUTHBRIDGE_AMD_CS5530_CHIP_H
+
 extern struct chip_operations southbridge_amd_cs5530_ops;
 
 struct southbridge_amd_cs5530_config {
-	/* PCI function enables so the pci scan bus finds the devices */
-	int enable_ide;
-	int enable_nvram;
+	int ide0_enable:1;
+	int ide1_enable:1;
 };
 
-#endif	/* _SOUTHBRIDGE_AMD_CS5530 */
+#endif				/* SOUTHBRIDGE_AMD_CS5530_CHIP_H */

Modified: trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530.c
===================================================================
--- trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530.c	2007-09-13 13:47:02 UTC (rev 2774)
+++ trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530.c	2007-09-14 00:09:29 UTC (rev 2775)
@@ -1,92 +1,59 @@
+/*
+ * This file is part of the LinuxBIOS project.
+ *
+ * Copyright (C) 2007 Uwe Hermann <uwe at hermann-uwe.de>
+ *
+ * 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; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * 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
+ */
 
-#include <arch/io.h>
-#include <device/device.h>
-#include <device/pci.h>
-#include <device/pci_ops.h>
-#include <device/pci_ids.h>
-#include <console/console.h>
-#include "cs5530.h"
+/* Datasheet:
+ *   - Name: Geode CS5530A I/O Companion Multi-Function South Bridge
+ *   - URL: http://www.national.com/pf/CS/CS5530A.html
+ *   - PDF: http://www.national.com/ds.cgi/CS/CS5530A.pdf
+ *   - Revision: 1.1 (May 2001)
+ */
 
-static void nvram_on(struct device *dev)
-{
-#if 0
-	volatile char *flash = (volatile unsigned char *)0xFFFc0000;
-	unsigned char id1, id2;
-#endif
-	unsigned char reg;
+/* Datasheet:
+ *   - Name: AMD Geode CS5530A Companion Device Data Book
+ *   - URL: http://www.amd.com/us-en/ConnectivitySolutions/ProductInformation/0,,50_2330_9863_9919,00.html
+ *   - PDF: http://www.amd.com/files/connectivitysolutions/geode/5530a_db_v11.pdf
+ *   - Date: October 2003
+ *   - Publication ID: May 2001, Revision 1.1
+ */
 
-	/* Enable writes to flash at top of memory */
-	pci_write_config8(dev, 0x52, 0xee);
+/* Datasheet:
+ *   - Name: AMD Geode Solutions
+ *           Integrated Processors, Companion Devices, and System Platforms
+ *           (Geode CS5530 I/O Companion Multi-Function South Bridge)
+ *   - URL: http://www.amd.com/us-en/ConnectivitySolutions/ProductInformation/0,,50_2330_9863_9919,00.html
+ *   - PDF: http://www.amd.com/files/connectivitysolutions/geode/5530_db_v41.pdf
+ *   - Date: September 2004
+ */
 
-	/* Set positive decode on ROM */
-	/* Also, there is no apparent reason to turn off the devoce on the */
-	/* IDE devices */
-	
-	reg = pci_read_config8(dev, 0x5b);
-	reg |= 1 << 5;	/* ROM Decode */
-	reg |= 1 << 3;	/* Primary IDE decode */
-	reg |= 1 << 4;	/* Secondary IDE decode */
+/* Note: The CS3350 / CS3350A are mostly identical. This code handles both. */
 
-	pci_write_config8(dev, 0x5b, reg);
+#include <console/console.h>
+#include <device/device.h>
+#include <device/pci.h>
+#include "cs5530.h"
 
-#if 0		// just to test if the flash is accessible!
-	*(flash + 0x555) = 0xaa;
-	*(flash + 0x2aa) = 0x55;
-	*(flash + 0x555) = 0x90;
-
-	id1 = *(volatile unsigned char *) flash;
-	id2 = *(volatile unsigned char *) (flash + 1);
-
-	*flash = 0xf0;
-
-	printk_debug("Flash device: MFGID %02x, DEVID %02x\n", id1, id2);
-#endif
-}
-
-	
-static void southbridge_init(struct device *dev)
+void cs5530_enable(device_t dev)
 {
-	printk_spew("cs5530: %s\n", __FUNCTION__);
-	nvram_on(dev);
 }
 
-/*
-static void dump_south(struct device *dev)
-{
-	int i, j;
-
-	for(i=0; i<256; i+=16) {
-		printk_debug("0x%02x: ", i);
-		for(j=0; j<16; j++)
-			printk_debug("%02x ", pci_read_config8(dev, i+j));
-		printk_debug("\n");
-	}
-}
-*/
-
-static void southbridge_enable(struct device *dev)
-{
-	printk_spew("%s: dev is %p\n", __FUNCTION__, dev);
-}
-
-static void cs5530_pci_dev_enable_resources(device_t dev)
-{
-	printk_spew("cs5530.c: %s()\n", __FUNCTION__);
-	pci_dev_enable_resources(dev);
-	enable_childrens_resources(dev);
-}
-
-static struct device_operations southbridge_ops = {
-	.read_resources   = pci_dev_read_resources,
-	.set_resources    = pci_dev_set_resources,
-	.enable_resources = cs5530_pci_dev_enable_resources,
-	.init             = southbridge_init,
-	.enable           = southbridge_enable,
-	.scan_bus         = scan_static_bus,
+struct chip_operations southbridge_amd_cs5530_ops = {
+	CHIP_NAME("AMD Geode CS5530/CS5530A I/O Companion Southbridge")
+	.enable_dev = cs5530_enable,
 };
-
-static struct pci_driver cs5530_pci_driver __pci_driver = {
-	.ops 	= &southbridge_ops,
-	.vendor = PCI_VENDOR_ID_CYRIX,
-	.device = PCI_DEVICE_ID_CYRIX_5530_LEGACY,
-};

Modified: trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530.h
===================================================================
--- trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530.h	2007-09-13 13:47:02 UTC (rev 2774)
+++ trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530.h	2007-09-14 00:09:29 UTC (rev 2775)
@@ -1,4 +1,40 @@
-#ifndef _CS5530_H
-#define _CS5530_H
+/*
+ * This file is part of the LinuxBIOS project.
+ *
+ * Copyright (C) 2007 Uwe Hermann <uwe at hermann-uwe.de>
+ *
+ * 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; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * 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 SOUTHBRIDGE_AMD_CS5530_CS5530_H
+#define SOUTHBRIDGE_AMD_CS5530_CS5530_H
+
+#ifndef __ROMCC__
+#include "chip.h"
+void cs5530_enable(device_t dev);
 #endif
+
+#define DECODE_CONTROL_REG2		0x5b		/* F0 index 0x5b */
+
+/* Selects PCI positive decoding for accesses to the configured ROM space. */
+#define BIOS_ROM_POSITIVE_DECODE	(1 << 5)
+
+/* Primary IDE Controller Positive Decode (i.e., enable it). */
+#define PRIMARY_IDE_ENABLE		(1 << 3)
+
+/* Secondary IDE Controller Positive Decode (i.e., enable it). */
+#define SECONDARY_IDE_ENABLE		(1 << 4)
+
+#endif				/* SOUTHBRIDGE_AMD_CS5530_CS5530_H */

Modified: trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530_ide.c
===================================================================
--- trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530_ide.c	2007-09-13 13:47:02 UTC (rev 2774)
+++ trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530_ide.c	2007-09-14 00:09:29 UTC (rev 2775)
@@ -1,3 +1,23 @@
+/*
+ * This file is part of the LinuxBIOS project.
+ *
+ * Copyright (C) 2007 Uwe Hermann <uwe at hermann-uwe.de>
+ *
+ * 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; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * 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
+ */
+
 #include <console/console.h>
 #include <device/device.h>
 #include <device/pci.h>
@@ -2,25 +22,53 @@
 #include <device/pci_ids.h>
-#include <device/pci_ops.h>
 #include "cs5530.h"
 
+/**
+ * Initialize the IDE controller.
+ *
+ * Depending on the configuration variables 'ide0_enable' and 'ide1_enable'
+ * enable or disable the primary and secondary IDE interface, respectively.
+ *
+ * @param dev The device to use.
+ */
 static void ide_init(struct device *dev)
 {
-	printk_spew("cs5530_ide: %s\n", __FUNCTION__);
-}
+	uint8_t reg8;
+	struct southbridge_amd_cs5530_config *conf = dev->chip_info;
 
-static void ide_enable(struct device *dev)
-{
-	printk_spew("cs5530_ide: %s\n", __FUNCTION__);
+	reg8 = pci_read_config8(dev, DECODE_CONTROL_REG2);
+
+	/* Enable/disable the primary IDE interface. */
+	if (conf->ide0_enable) {
+		reg8 |= PRIMARY_IDE_ENABLE;
+	} else {
+		reg8 &= ~(PRIMARY_IDE_ENABLE);
+	}
+
+	/* Enable/disable the secondary IDE interface. */
+	if (conf->ide1_enable) {
+		reg8 |= SECONDARY_IDE_ENABLE;
+	} else {
+		reg8 &= ~(SECONDARY_IDE_ENABLE);
+	}
+
+	pci_write_config8(dev, DECODE_CONTROL_REG2, reg8);
+
+	printk_info("%s IDE interface %s\n", "Primary",
+		    conf->ide0_enable ? "enabled" : "disabled");
+	printk_info("%s IDE interface %s\n", "Secondary",
+		    conf->ide1_enable ? "enabled" : "disabled");
 }
 
 static struct device_operations ide_ops = {
-	.read_resources   = pci_dev_read_resources,
-	.set_resources    = pci_dev_set_resources,
-	.enable_resources = pci_dev_enable_resources,
-	.init             = ide_init,
-	.enable           = ide_enable,
+	.read_resources		= pci_dev_read_resources,
+	.set_resources		= pci_dev_set_resources,
+	.enable_resources	= pci_dev_enable_resources,
+	.init			= ide_init,
+	.enable			= 0,
+	.scan_bus		= scan_static_bus,
+	.ops_pci		= 0,
 };
 
 static struct pci_driver ide_driver __pci_driver = {
-	.ops 	= &ide_ops,
+	.ops	= &ide_ops,
 	.vendor = PCI_VENDOR_ID_CYRIX,

Added: trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530_isa.c
===================================================================
--- trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530_isa.c	                        (rev 0)
+++ trunk/LinuxBIOSv2/src/southbridge/amd/cs5530/cs5530_isa.c	2007-09-14 00:09:29 UTC (rev 2775)
@@ -0,0 +1,60 @@
+/*
+ * This file is part of the LinuxBIOS project.
+ *
+ * Copyright (C) 2007 Uwe Hermann <uwe at hermann-uwe.de>
+ *
+ * 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; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * 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
+ */
+
+#include <console/console.h>
+#include <arch/io.h>
+#include <device/device.h>
+#include <device/pci.h>
+#include <device/pci_ids.h>
+#include "cs5530.h"
+
+static void isa_init(struct device *dev)
+{
+	uint8_t reg8;
+
+	// TODO: Test if needed, otherwise drop.
+
+	/* Set positive decode on ROM. */
+	reg8 = pci_read_config8(dev, DECODE_CONTROL_REG2);
+	reg8 |= BIOS_ROM_POSITIVE_DECODE;
+	pci_write_config8(dev, DECODE_CONTROL_REG2, reg8);
+}
+
+static void cs5530_pci_dev_enable_resources(device_t dev)
+{
+	// TODO: Needed?
+	pci_dev_enable_resources(dev);
+	enable_childrens_resources(dev);
+}
+
+static struct device_operations isa_ops = {
+	.read_resources		= pci_dev_read_resources,
+	.set_resources		= pci_dev_set_resources,
+	.enable_resources	= cs5530_pci_dev_enable_resources,
+	.init			= isa_init,
+	.enable			= 0,
+	.scan_bus		= scan_static_bus,
+};
+
+static struct pci_driver isa_driver __pci_driver = {
+	.ops	= &isa_ops,
+	.vendor	= PCI_VENDOR_ID_CYRIX,
+	.device	= PCI_DEVICE_ID_CYRIX_5530_LEGACY,
+};





More information about the coreboot mailing list