public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
* [U-Boot] [PATCH] Add "cpu_config" command for PPC4xx bootstrap configuration
@ 2009-07-17  9:26 Stefan Roese
  2009-07-17  9:32 ` Stefan Roese
  2009-07-17 10:45 ` Wolfgang Denk
  0 siblings, 2 replies; 9+ messages in thread
From: Stefan Roese @ 2009-07-17  9:26 UTC (permalink / raw)
  To: u-boot

From: Dirk Eibach <eibach@gdsys.de>

This patch adds a generic command for programming I2C bootstrap
eeproms on PPC4xx. An implementation for Canyonlands board is
included.

The command name is intentionally chosen not to be PPC4xx specific.
This way other CPU's/SoC's can implement a similar command under
the same name, perhaps with a different syntax.

Usage on Canyonlands:

=> cpu_config
Available configurations:
 600-nor         - NOR  CPU: 600 PLB: 200 OPB: 100 EBC: 100
 600-nand        - NAND CPU: 600 PLB: 200 OPB: 100 EBC: 100
 800-nor         - NOR  CPU: 800 PLB: 200 OPB: 100 EBC: 100
 800-nand        - NAND CPU: 800 PLB: 200 OPB: 100 EBC: 100
 1000-nor        - NOR  CPU:1000 PLB: 200 OPB: 100 EBC: 100
 1000-nand       - NAND CPU:1000 PLB: 200 OPB: 100 EBC: 100
 1066-nor        - NOR  CPU:1066 PLB: 266 OPB:  88 EBC:  88
 1066-nand       - NAND CPU:1066 PLB: 266 OPB:  88 EBC:  88
=> cpu_config 600-nor
Using configuration:
 600-nor         - NOR  CPU: 600 PLB: 200 OPB: 100 EBC: 100
done (dump via 'i2c md 52 0.1 10')
Reset the board for the changes to take effect

Other 4xx boards will be migrated to use this command soon
as well.

Signed-off-by: Stefan Roese <sr@denx.de>
Cc: Dirk Eibach <eibach@gdsys.de>
Cc: Matthias Fuchs <matthias.fuchs@esd.eu>
---
 board/amcc/canyonlands/Makefile     |    5 +-
 board/amcc/canyonlands/bootstrap.c  |  195 -----------------------------------
 board/amcc/canyonlands/cpu_config.c |   71 +++++++++++++
 cpu/ppc4xx/Makefile                 |    3 +
 cpu/ppc4xx/cmd_cpu_config.c         |   92 ++++++++++++++++
 include/asm-ppc/ppc4xx_config.h     |   42 ++++++++
 include/configs/canyonlands.h       |    4 +
 7 files changed, 215 insertions(+), 197 deletions(-)
 delete mode 100644 board/amcc/canyonlands/bootstrap.c
 create mode 100644 board/amcc/canyonlands/cpu_config.c
 create mode 100644 cpu/ppc4xx/cmd_cpu_config.c
 create mode 100644 include/asm-ppc/ppc4xx_config.h

diff --git a/board/amcc/canyonlands/Makefile b/board/amcc/canyonlands/Makefile
index 2aeead6..b1dfb0b 100644
--- a/board/amcc/canyonlands/Makefile
+++ b/board/amcc/canyonlands/Makefile
@@ -25,10 +25,11 @@ include $(TOPDIR)/config.mk
 
 LIB	= $(obj)lib$(BOARD).a
 
-COBJS	:= $(BOARD).o
-COBJS	+= bootstrap.o
+COBJS-y	:= $(BOARD).o
+COBJS-$(CONFIG_CMD_CPU_CONFIG) += cpu_config.o
 SOBJS	:= init.o
 
+COBJS   := $(COBJS-y)
 SRCS	:= $(SOBJS:.o=.S) $(COBJS:.o=.c)
 OBJS	:= $(addprefix $(obj),$(COBJS))
 SOBJS	:= $(addprefix $(obj),$(SOBJS))
diff --git a/board/amcc/canyonlands/bootstrap.c b/board/amcc/canyonlands/bootstrap.c
deleted file mode 100644
index 6dc2cca..0000000
--- a/board/amcc/canyonlands/bootstrap.c
+++ /dev/null
@@ -1,195 +0,0 @@
-/*
- * (C) Copyright 2008
- * Stefan Roese, DENX Software Engineering, sr at denx.de.
- *
- * See file CREDITS for list of people who contributed to this
- * project.
- *
- * 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., 59 Temple Place, Suite 330, Boston,
- * MA 02111-1307 USA
- *
- */
-
-#include <common.h>
-#include <command.h>
-#include <i2c.h>
-#include <asm/io.h>
-
-/*
- * NOR and NAND boot options change bytes 5, 6, 8, 9, 11. The
- * values are independent of the rest of the clock settings.
- */
-
-#define NAND_COMPATIBLE	0x01
-#define NOR_COMPATIBLE  0x02
-
-#define I2C_EEPROM_ADDR 0x52
-
-static char *config_labels[] = {
-	"CPU: 600 PLB: 200 OPB: 100 EBC: 100",
-	"CPU: 800 PLB: 200 OPB: 100 EBC: 100",
-	"CPU:1000 PLB: 200 OPB: 100 EBC: 100",
-	"CPU:1066 PLB: 266 OPB:  88 EBC:  88",
-	NULL
-};
-
-static u8 boot_configs[][17] = {
-	{
-		(NAND_COMPATIBLE | NOR_COMPATIBLE),
-		0x86, 0x80, 0xce, 0x1f, 0x79, 0x80, 0x00, 0xa0, 0x40, 0x08,
-		0x23, 0x50, 0x0d, 0x05, 0x00, 0x00
-	},
-	{
-		(NAND_COMPATIBLE | NOR_COMPATIBLE),
-		0x86, 0x80, 0xba, 0x14, 0x99, 0x80, 0x00, 0xa0, 0x40, 0x08,
-		0x23, 0x50, 0x0d, 0x05, 0x00, 0x00
-	},
-	{
-		(NAND_COMPATIBLE | NOR_COMPATIBLE),
-		0x86, 0x82, 0x96, 0x19, 0xb9, 0x80, 0x00, 0xa0, 0x40, 0x08,
-		0x23, 0x50, 0x0d, 0x05, 0x00, 0x00
-	},
-	{
-		(NAND_COMPATIBLE | NOR_COMPATIBLE),
-		0x86, 0x80, 0xb3, 0x01, 0x9d, 0x80, 0x00, 0xa0, 0x40, 0x08,
-		0x23, 0x50, 0x0d, 0x05, 0x00, 0x00
-	},
-	{
-		0,
-		0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
-	}
-};
-
-/*
- * Bytes 5,6,8,9,11 change for NAND boot
- */
-#if 0
-/*
- * Values for 512 page size NAND chips, not used anymore, just
- * keep them here for reference
- */
-static u8 nand_boot[] = {
-	0x90, 0x01,  0xa0, 0x68, 0x58
-};
-#else
-/*
- * Values for 2k page size NAND chips
- */
-static u8 nand_boot[] = {
-	0x90, 0x01,  0xa0, 0xe8, 0x58
-};
-#endif
-
-static int do_bootstrap(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
-{
-	u8 *buf, b_nand;
-	int x, y, nbytes, selcfg;
-	extern char console_buffer[];
-
-	if (argc < 2) {
-		cmd_usage(cmdtp);
-		return 1;
-	}
-
-	if ((strcmp(argv[1], "nor") != 0) &&
-	    (strcmp(argv[1], "nand") != 0)) {
-		printf("Unsupported boot-device - only nor|nand support\n");
-		return 1;
-	}
-
-	/* set the nand flag based on provided input */
-	if ((strcmp(argv[1], "nand") == 0))
-		b_nand = 1;
-	else
-		b_nand = 0;
-
-	printf("Available configurations: \n\n");
-
-	if (b_nand) {
-		for(x = 0, y = 0; boot_configs[x][0] != 0; x++) {
-			/* filter on nand compatible */
-			if (boot_configs[x][0] & NAND_COMPATIBLE) {
-				printf(" %d - %s\n", (y+1), config_labels[x]);
-				y++;
-			}
-		}
-	} else {
-		for(x = 0, y = 0; boot_configs[x][0] != 0; x++) {
-			/* filter on nor compatible */
-			if (boot_configs[x][0] & NOR_COMPATIBLE) {
-				printf(" %d - %s\n", (y+1), config_labels[x]);
-				y++;
-			}
-		}
-	}
-
-	do {
-		nbytes = readline(" Selection [1-x / quit]: ");
-
-		if (nbytes) {
-			if (strcmp(console_buffer, "quit") == 0)
-				return 0;
-			selcfg = simple_strtol(console_buffer, NULL, 10);
-			if ((selcfg < 1) || (selcfg > y))
-				nbytes = 0;
-		}
-	} while (nbytes == 0);
-
-
-	y = (selcfg - 1);
-
-	for (x = 0; boot_configs[x][0] != 0; x++) {
-		if (b_nand) {
-			if (boot_configs[x][0] & NAND_COMPATIBLE) {
-				if (y > 0)
-					y--;
-				else if (y < 1)
-					break;
-			}
-		} else {
-			if (boot_configs[x][0] & NOR_COMPATIBLE) {
-				if (y > 0)
-					y--;
-				else if (y < 1)
-					break;
-			}
-		}
-	}
-
-	buf = &boot_configs[x][1];
-
-	if (b_nand) {
-		buf[5] = nand_boot[0];
-		buf[6] = nand_boot[1];
-		buf[8] = nand_boot[2];
-		buf[9] = nand_boot[3];
-		buf[11] = nand_boot[4];
-	}
-
-	if (i2c_write(I2C_EEPROM_ADDR, 0, 1, buf, 16) != 0)
-		printf("Error writing to EEPROM@address 0x%x\n", I2C_EEPROM_ADDR);
-	udelay(CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS * 1000);
-
-	printf("Done\n");
-	printf("Please power-cycle the board for the changes to take effect\n");
-
-	return 0;
-}
-
-U_BOOT_CMD(
-	bootstrap,	2,	0,	do_bootstrap,
-	"program the I2C bootstrap EEPROM",
-	"<nand|nor> - strap to boot from NAND or NOR flash"
-);
diff --git a/board/amcc/canyonlands/cpu_config.c b/board/amcc/canyonlands/cpu_config.c
new file mode 100644
index 0000000..15813c4
--- /dev/null
+++ b/board/amcc/canyonlands/cpu_config.c
@@ -0,0 +1,71 @@
+/*
+ * (C) Copyright 2008-2009
+ * Stefan Roese, DENX Software Engineering, sr at denx.de.
+ *
+ * See file CREDITS for list of people who contributed to this
+ * project.
+ *
+ * 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., 59 Temple Place, Suite 330, Boston,
+ * MA 02111-1307 USA
+ *
+ */
+
+#include <common.h>
+#include <asm/ppc4xx_config.h>
+
+struct ppc4xx_config ppc4xx_config_val[] = {
+	{ "600-nor", "NOR  CPU: 600 PLB: 200 OPB: 100 EBC: 100",
+	  {
+		  0x86, 0x80, 0xce, 0x1f, 0x79, 0x80, 0x00, 0xa0,
+		  0x40, 0x08, 0x23, 0x50, 0x0d, 0x05, 0x00, 0x00
+	  } },
+	{ "600-nand", "NAND CPU: 600 PLB: 200 OPB: 100 EBC: 100",
+	  {
+		  0x86, 0x80, 0xce, 0x1f, 0x79, 0x90, 0x01, 0xa0,
+		  0xa0, 0xe8, 0x23, 0x58, 0x0d, 0x05, 0x00, 0x00
+	  } },
+	{ "800-nor", "NOR  CPU: 800 PLB: 200 OPB: 100 EBC: 100",
+	  {
+		  0x86, 0x80, 0xba, 0x14, 0x99, 0x80, 0x00, 0xa0,
+		  0x40, 0x08, 0x23, 0x50, 0x0d, 0x05, 0x00, 0x00
+	  } },
+	{ "800-nand", "NAND CPU: 800 PLB: 200 OPB: 100 EBC: 100",
+	  {
+		  0x86, 0x80, 0xba, 0x14, 0x99, 0x90, 0x01, 0xa0,
+		  0xa0, 0xe8, 0x23, 0x58, 0x0d, 0x05, 0x00, 0x00
+	  } },
+	{ "1000-nor", "NOR  CPU:1000 PLB: 200 OPB: 100 EBC: 100",
+	  {
+		  0x86, 0x82, 0x96, 0x19, 0xb9, 0x80, 0x00, 0xa0,
+		  0x40, 0x08, 0x23, 0x50, 0x0d, 0x05, 0x00, 0x00
+	  } },
+	{ "1000-nand", "NAND CPU:1000 PLB: 200 OPB: 100 EBC: 100",
+	  {
+		  0x86, 0x82, 0x96, 0x19, 0xb9, 0x90, 0x01, 0xa0,
+		  0xa0, 0xe8, 0x23, 0x58, 0x0d, 0x05, 0x00, 0x00
+	  } },
+	{ "1066-nor", "NOR  CPU:1066 PLB: 266 OPB:  88 EBC:  88",
+	  {
+		  0x86, 0x80, 0xb3, 0x01, 0x9d, 0x80, 0x00, 0xa0,
+		  0x40, 0x08, 0x23, 0x50, 0x0d, 0x05, 0x00, 0x00
+	  } },
+	{ "1066-nand", "NAND CPU:1066 PLB: 266 OPB:  88 EBC:  88",
+	  {
+		  0x86, 0x80, 0xb3, 0x01, 0x9d, 0x90, 0x01, 0xa0,
+		  0xa0, 0xe8, 0x23, 0x58, 0x0d, 0x05, 0x00, 0x00
+	  } },
+};
+
+int ppc4xx_config_count = ARRAY_SIZE(ppc4xx_config_val);
diff --git a/cpu/ppc4xx/Makefile b/cpu/ppc4xx/Makefile
index 96ab5c6..c5f22f1 100644
--- a/cpu/ppc4xx/Makefile
+++ b/cpu/ppc4xx/Makefile
@@ -41,6 +41,9 @@ endif
 COBJS	+= 4xx_pci.o
 COBJS	+= 4xx_pcie.o
 COBJS	+= bedbug_405.o
+ifdef CONFIG_CMD_CPU_CONFIG
+COBJS	+= cmd_cpu_config.o
+endif
 COBJS	+= commproc.o
 COBJS	+= cpu.o
 COBJS	+= cpu_init.o
diff --git a/cpu/ppc4xx/cmd_cpu_config.c b/cpu/ppc4xx/cmd_cpu_config.c
new file mode 100644
index 0000000..3c0abc9
--- /dev/null
+++ b/cpu/ppc4xx/cmd_cpu_config.c
@@ -0,0 +1,92 @@
+/*
+ * (C) Copyright 2008-2009
+ * Stefan Roese, DENX Software Engineering, sr at denx.de.
+ *
+ * (C) Copyright 2009
+ * Dirk Eibach,  Guntermann & Drunck GmbH, eibach at gdsys.de
+ *
+ * See file CREDITS for list of people who contributed to this
+ * project.
+ *
+ * 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., 59 Temple Place, Suite 330, Boston,
+ * MA 02111-1307 USA
+ *
+ */
+
+#include <common.h>
+#include <command.h>
+#include <i2c.h>
+#include <asm/ppc4xx_config.h>
+#include <asm/io.h>
+
+static void print_configs(void)
+{
+	int i;
+
+	for (i = 0; i < ppc4xx_config_count; i++) {
+		printf(" %s\t - %s\n", ppc4xx_config_val[i].label,
+		       ppc4xx_config_val[i].description);
+	}
+}
+
+static int do_cpu_config(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
+{
+	int i;
+	int ret;
+
+	if (argc < 2) {
+		printf("Available configurations:\n");
+		print_configs();
+		return 0;
+	}
+
+	for (i = 0; i < ppc4xx_config_count; i++) {
+		/*
+		 * Search for configuration name/label
+		 */
+		if (strcmp(argv[1], ppc4xx_config_val[i].label) == 0) {
+			printf("Using configuration:\n %s\t - %s\n",
+			       ppc4xx_config_val[i].label,
+			       ppc4xx_config_val[i].description);
+
+			ret = i2c_write(CONFIG_4xx_CONFIG_I2C_EEPROM_ADDR, 0, 1,
+					ppc4xx_config_val[i].val,
+					CONFIG_4xx_CONFIG_BLOCKSIZE);
+			udelay(CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS * 1000);
+			if (ret) {
+				printf("Error updating EEPROM at addr 0x%x\n",
+				       CONFIG_4xx_CONFIG_I2C_EEPROM_ADDR);
+				return -1;
+			}
+
+			printf("done (dump via 'i2c md %x 0.1 %x')\n",
+			       CONFIG_4xx_CONFIG_I2C_EEPROM_ADDR,
+			       CONFIG_4xx_CONFIG_BLOCKSIZE);
+			printf("Reset the board for the changes to"
+			       " take effect\n");
+			return 0;
+		}
+	}
+
+	printf("Configuration %s not found!\n", argv[1]);
+	print_configs();
+	return -1;
+}
+
+U_BOOT_CMD(
+	cpu_config,	2,	0,	do_cpu_config,
+	"program the I2C bootstrap EEPROM",
+	"[config-label]"
+);
diff --git a/include/asm-ppc/ppc4xx_config.h b/include/asm-ppc/ppc4xx_config.h
new file mode 100644
index 0000000..4de7468
--- /dev/null
+++ b/include/asm-ppc/ppc4xx_config.h
@@ -0,0 +1,42 @@
+/*
+ * (C) Copyright 2008-2009
+ * Stefan Roese, DENX Software Engineering, sr at denx.de.
+ *
+ * (C) Copyright 2009
+ * Dirk Eibach,  Guntermann & Drunck GmbH, eibach@gdsys.de
+ *
+ * See file CREDITS for list of people who contributed to this
+ * project.
+ *
+ * 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., 59 Temple Place, Suite 330, Boston,
+ * MA 02111-1307 USA
+ *
+ */
+
+#ifndef __PPC4xx_CONFIG_H
+#define __PPC4xx_CONFIG_H
+
+#include <common.h>
+
+struct ppc4xx_config {
+	char label[32];
+	char description[64];
+	u8 val[CONFIG_4xx_CONFIG_BLOCKSIZE];
+};
+
+extern struct ppc4xx_config ppc4xx_config_val[];
+extern int ppc4xx_config_count;
+
+#endif /* __PPC4xx_CONFIG_H */
diff --git a/include/configs/canyonlands.h b/include/configs/canyonlands.h
index 48c5198..41a0755 100644
--- a/include/configs/canyonlands.h
+++ b/include/configs/canyonlands.h
@@ -330,6 +330,9 @@
 #define CONFIG_SYS_EEPROM_PAGE_WRITE_BITS	3
 #define CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS	10
 
+#define CONFIG_4xx_CONFIG_I2C_EEPROM_ADDR	0x52
+#define CONFIG_4xx_CONFIG_BLOCKSIZE		16
+
 /* I2C SYSMON (LM75, AD7414 is almost compatible)			*/
 #define CONFIG_DTT_LM75		1		/* ON Semi's LM75	*/
 #define CONFIG_DTT_AD7414	1		/* use AD7414		*/
@@ -442,6 +445,7 @@
 /*
  * Commands additional to the ones defined in amcc-common.h
  */
+#define CONFIG_CMD_CPU_CONFIG
 #if defined(CONFIG_ARCHES)
 #define CONFIG_CMD_DTT
 #define CONFIG_CMD_PCI
-- 
1.6.3.3

^ permalink raw reply related	[flat|nested] 9+ messages in thread

* [U-Boot] [PATCH] Add "cpu_config" command for PPC4xx bootstrap configuration
  2009-07-17  9:26 [U-Boot] [PATCH] Add "cpu_config" command for PPC4xx bootstrap configuration Stefan Roese
@ 2009-07-17  9:32 ` Stefan Roese
  2009-07-17  9:51   ` Eibach, Dirk
  2009-07-17 10:45 ` Wolfgang Denk
  1 sibling, 1 reply; 9+ messages in thread
From: Stefan Roese @ 2009-07-17  9:32 UTC (permalink / raw)
  To: u-boot

On Friday 17 July 2009 11:26:03 Stefan Roese wrote:
> From: Dirk Eibach <eibach@gdsys.de>

Sorry, but this "From: Dirk..." slipped in by accident. Dirk has provided some 
parts of this framework, but the real command is more complete rewrite from 
myself. I kept Dirk's Copyright's in the header, but this patch version 
shouldn't have the authorship of Dirk.

I'll fix this in the next patch version.

Dirk, if you like I can add you s-o-b to the next patch version, since you 
contributed to this code as well. Just let me know.

Thanks.

Best regards,
Stefan

=====================================================================
DENX Software Engineering GmbH,     MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: +49-8142-66989-0 Fax: +49-8142-66989-80  Email: office at denx.de
=====================================================================

^ permalink raw reply	[flat|nested] 9+ messages in thread

* [U-Boot] [PATCH] Add "cpu_config" command for PPC4xx bootstrap configuration
  2009-07-17  9:32 ` Stefan Roese
@ 2009-07-17  9:51   ` Eibach, Dirk
  0 siblings, 0 replies; 9+ messages in thread
From: Eibach, Dirk @ 2009-07-17  9:51 UTC (permalink / raw)
  To: u-boot


> Dirk, if you like I can add you s-o-b to the next patch 
> version, since you contributed to this code as well. Just let me know.

Sure, you can list me as s-o-b.

Cheers
Dirk

^ permalink raw reply	[flat|nested] 9+ messages in thread

* [U-Boot] [PATCH] Add "cpu_config" command for PPC4xx bootstrap configuration
  2009-07-17  9:26 [U-Boot] [PATCH] Add "cpu_config" command for PPC4xx bootstrap configuration Stefan Roese
  2009-07-17  9:32 ` Stefan Roese
@ 2009-07-17 10:45 ` Wolfgang Denk
  2009-07-17 11:13   ` Stefan Roese
  1 sibling, 1 reply; 9+ messages in thread
From: Wolfgang Denk @ 2009-07-17 10:45 UTC (permalink / raw)
  To: u-boot

Dear Stefan Roese,

In message <1247822763-20761-1-git-send-email-sr@denx.de> you wrote:
> From: Dirk Eibach <eibach@gdsys.de>
> 
> This patch adds a generic command for programming I2C bootstrap
> eeproms on PPC4xx. An implementation for Canyonlands board is
> included.
> 
> The command name is intentionally chosen not to be PPC4xx specific.
> This way other CPU's/SoC's can implement a similar command under
> the same name, perhaps with a different syntax.
> 
> Usage on Canyonlands:
> 
> => cpu_config
> Available configurations:
>  600-nor         - NOR  CPU: 600 PLB: 200 OPB: 100 EBC: 100
>  600-nand        - NAND CPU: 600 PLB: 200 OPB: 100 EBC: 100
>  800-nor         - NOR  CPU: 800 PLB: 200 OPB: 100 EBC: 100
>  800-nand        - NAND CPU: 800 PLB: 200 OPB: 100 EBC: 100
>  1000-nor        - NOR  CPU:1000 PLB: 200 OPB: 100 EBC: 100
>  1000-nand       - NAND CPU:1000 PLB: 200 OPB: 100 EBC: 100
>  1066-nor        - NOR  CPU:1066 PLB: 266 OPB:  88 EBC:  88
>  1066-nand       - NAND CPU:1066 PLB: 266 OPB:  88 EBC:  88

Why are the lines indented by one space?

Would it be possible to also mark the current setting in this output?
Like printing an asterisk befor or after it?

> diff --git a/board/amcc/canyonlands/cpu_config.c b/board/amcc/canyonlands/cpu_config.c
> new file mode 100644
> index 0000000..15813c4
...
> +struct ppc4xx_config ppc4xx_config_val[] = {
> +	{ "600-nor", "NOR  CPU: 600 PLB: 200 OPB: 100 EBC: 100",
> +	  {
> +		  0x86, 0x80, 0xce, 0x1f, 0x79, 0x80, 0x00, 0xa0,
> +		  0x40, 0x08, 0x23, 0x50, 0x0d, 0x05, 0x00, 0x00
> +	  } },

Indentation by TAB, please.


Best regards,

Wolfgang Denk

-- 
DENX Software Engineering GmbH,     MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: (+49)-8142-66989-10 Fax: (+49)-8142-66989-80 Email: wd at denx.de
What is mind?  No matter.  What is matter?  Never mind.
                                      -- Thomas Hewitt Key, 1799-1875

^ permalink raw reply	[flat|nested] 9+ messages in thread

* [U-Boot] [PATCH] Add "cpu_config" command for PPC4xx bootstrap configuration
  2009-07-17 10:45 ` Wolfgang Denk
@ 2009-07-17 11:13   ` Stefan Roese
  2009-07-17 11:20     ` Wolfgang Denk
  0 siblings, 1 reply; 9+ messages in thread
From: Stefan Roese @ 2009-07-17 11:13 UTC (permalink / raw)
  To: u-boot

Hi Wolfgang,

On Friday 17 July 2009 12:45:01 Wolfgang Denk wrote:
> > => cpu_config
> > Available configurations:
> >  600-nor         - NOR  CPU: 600 PLB: 200 OPB: 100 EBC: 100
> >  600-nand        - NAND CPU: 600 PLB: 200 OPB: 100 EBC: 100
> >  800-nor         - NOR  CPU: 800 PLB: 200 OPB: 100 EBC: 100
> >  800-nand        - NAND CPU: 800 PLB: 200 OPB: 100 EBC: 100
> >  1000-nor        - NOR  CPU:1000 PLB: 200 OPB: 100 EBC: 100
> >  1000-nand       - NAND CPU:1000 PLB: 200 OPB: 100 EBC: 100
> >  1066-nor        - NOR  CPU:1066 PLB: 266 OPB:  88 EBC:  88
> >  1066-nand       - NAND CPU:1066 PLB: 266 OPB:  88 EBC:  88
>
> Why are the lines indented by one space?

It was this way in the original bootstrap version. I can remove it if you 
prefer.

> Would it be possible to also mark the current setting in this output?
> Like printing an asterisk befor or after it?

No. Currently the implementation only checks strings and has no idea of 
frequencies. Also, not only PLL frequencies are configured in this I2C 
bootstrap EEPROM but also boot-location (NOR, NAND, PCI) and other things. So 
it's really not trivial to find/search the current configuration in this 
table.

Since 4xx prints the speed's in the bootlog, it shouldn't be too hard to find 
the current setting there (if necessary).

> > +struct ppc4xx_config ppc4xx_config_val[] = {
> > +	{ "600-nor", "NOR  CPU: 600 PLB: 200 OPB: 100 EBC: 100",
> > +	  {
> > +		  0x86, 0x80, 0xce, 0x1f, 0x79, 0x80, 0x00, 0xa0,
> > +		  0x40, 0x08, 0x23, 0x50, 0x0d, 0x05, 0x00, 0x00
> > +	  } },
>
> Indentation by TAB, please.

Ups. Will fix. Thanks.

Best regards,
Stefan

=====================================================================
DENX Software Engineering GmbH,     MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: +49-8142-66989-0 Fax: +49-8142-66989-80  Email: office at denx.de
=====================================================================

^ permalink raw reply	[flat|nested] 9+ messages in thread

* [U-Boot] [PATCH] Add "cpu_config" command for PPC4xx bootstrap configuration
  2009-07-17 11:13   ` Stefan Roese
@ 2009-07-17 11:20     ` Wolfgang Denk
  2009-07-17 11:26       ` Stefan Roese
  0 siblings, 1 reply; 9+ messages in thread
From: Wolfgang Denk @ 2009-07-17 11:20 UTC (permalink / raw)
  To: u-boot

Dear Stefan Roese,

In message <200907171313.37259.sr@denx.de> you wrote:
> 
> > Why are the lines indented by one space?
> 
> It was this way in the original bootstrap version. I can remove it if you 
> prefer.

Please do.

> > Would it be possible to also mark the current setting in this output?
> > Like printing an asterisk befor or after it?
> 
> No. Currently the implementation only checks strings and has no idea of 
> frequencies. Also, not only PLL frequencies are configured in this I2C 
> bootstrap EEPROM but also boot-location (NOR, NAND, PCI) and other things. So 
> it's really not trivial to find/search the current configuration in this 
> table.

Umm.. I think it should be fairly trivial to read the current  EEPROM
settings and compare these against the entries in the table above?

> Since 4xx prints the speed's in the bootlog, it shouldn't be too hard to find 
> the current setting there (if necessary).

But would it not be  useful  to  be  able  to  detect  any  "illegal"
settings,  for  example resulting from accidentyial corruption of the
EEPROM data?

Best regards,

Wolfgang Denk

-- 
DENX Software Engineering GmbH,     MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: (+49)-8142-66989-10 Fax: (+49)-8142-66989-80 Email: wd at denx.de
If you're not part of the solution, then you're part of the  precipi-
tate.

^ permalink raw reply	[flat|nested] 9+ messages in thread

* [U-Boot] [PATCH] Add "cpu_config" command for PPC4xx bootstrap configuration
  2009-07-17 11:20     ` Wolfgang Denk
@ 2009-07-17 11:26       ` Stefan Roese
  2009-07-17 11:40         ` Wolfgang Denk
  0 siblings, 1 reply; 9+ messages in thread
From: Stefan Roese @ 2009-07-17 11:26 UTC (permalink / raw)
  To: u-boot

On Friday 17 July 2009 13:20:17 Wolfgang Denk wrote:
> > > Would it be possible to also mark the current setting in this output?
> > > Like printing an asterisk befor or after it?
> >
> > No. Currently the implementation only checks strings and has no idea of
> > frequencies. Also, not only PLL frequencies are configured in this I2C
> > bootstrap EEPROM but also boot-location (NOR, NAND, PCI) and other
> > things. So it's really not trivial to find/search the current
> > configuration in this table.
>
> Umm.. I think it should be fairly trivial to read the current  EEPROM
> settings and compare these against the entries in the table above?

OK, this could be done. Even if I don't see a real advantage here. But I'll 
add it anyway in the next patch version.

> > Since 4xx prints the speed's in the bootlog, it shouldn't be too hard to
> > find the current setting there (if necessary).
>
> But would it not be  useful  to  be  able  to  detect  any  "illegal"
> settings,  for  example resulting from accidentyial corruption of the
> EEPROM data?

I don't understand this. How should the code detect an "illegal" setting? All 
settings configured in the board specific code are valid.

Best regards,
Stefan

=====================================================================
DENX Software Engineering GmbH,     MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: +49-8142-66989-0 Fax: +49-8142-66989-80  Email: office at denx.de
=====================================================================

^ permalink raw reply	[flat|nested] 9+ messages in thread

* [U-Boot] [PATCH] Add "cpu_config" command for PPC4xx bootstrap configuration
  2009-07-17 11:26       ` Stefan Roese
@ 2009-07-17 11:40         ` Wolfgang Denk
  2009-07-17 11:46           ` Stefan Roese
  0 siblings, 1 reply; 9+ messages in thread
From: Wolfgang Denk @ 2009-07-17 11:40 UTC (permalink / raw)
  To: u-boot

Dear Stefan Roese,

In message <200907171326.25645.sr@denx.de> you wrote:
>
> > But would it not be  useful  to  be  able  to  detect  any  "illegal"
> > settings,  for  example resulting from accidentyial corruption of the
> > EEPROM data?
> 
> I don't understand this. How should the code detect an "illegal" setting? All 
> settings configured in the board specific code are valid.

You  define  a  list  of  ppc4xx_config_count   known   configuration
settings;  the  data read from the EEPROM either matches one of these
then it is a "known" or "legal" setting, or it does  not  -  in  that
case  the  EEPROM contains an "illegal" setting. This should at least
trigger a warning message (probably including the hex values as  read
from the EEPROM).

Best regards,

Wolfgang Denk

-- 
DENX Software Engineering GmbH,     MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: (+49)-8142-66989-10 Fax: (+49)-8142-66989-80 Email: wd at denx.de
The IQ of the group is the lowest IQ of a member of the group divided
by the number of people in the group.

^ permalink raw reply	[flat|nested] 9+ messages in thread

* [U-Boot] [PATCH] Add "cpu_config" command for PPC4xx bootstrap configuration
  2009-07-17 11:40         ` Wolfgang Denk
@ 2009-07-17 11:46           ` Stefan Roese
  0 siblings, 0 replies; 9+ messages in thread
From: Stefan Roese @ 2009-07-17 11:46 UTC (permalink / raw)
  To: u-boot

On Friday 17 July 2009 13:40:50 Wolfgang Denk wrote:
> > > But would it not be  useful  to  be  able  to  detect  any  "illegal"
> > > settings,  for  example resulting from accidentyial corruption of the
> > > EEPROM data?
> >
> > I don't understand this. How should the code detect an "illegal" setting?
> > All settings configured in the board specific code are valid.
>
> You  define  a  list  of  ppc4xx_config_count   known   configuration
> settings;  the  data read from the EEPROM either matches one of these
> then it is a "known" or "legal" setting, or it does  not  -  in  that
> case  the  EEPROM contains an "illegal" setting. This should at least
> trigger a warning message (probably including the hex values as  read
> from the EEPROM).

Ah, yes. Good idea. Will add.

Best regards,
Stefan

=====================================================================
DENX Software Engineering GmbH,     MD: Wolfgang Denk & Detlev Zundel
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: +49-8142-66989-0 Fax: +49-8142-66989-80  Email: office at denx.de
=====================================================================

^ permalink raw reply	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2009-07-17 11:46 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-07-17  9:26 [U-Boot] [PATCH] Add "cpu_config" command for PPC4xx bootstrap configuration Stefan Roese
2009-07-17  9:32 ` Stefan Roese
2009-07-17  9:51   ` Eibach, Dirk
2009-07-17 10:45 ` Wolfgang Denk
2009-07-17 11:13   ` Stefan Roese
2009-07-17 11:20     ` Wolfgang Denk
2009-07-17 11:26       ` Stefan Roese
2009-07-17 11:40         ` Wolfgang Denk
2009-07-17 11:46           ` Stefan Roese

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox