[U-Boot-Users] [PATCH]ppc_4xx:netstal/common define routines used by all boards
Stefan Roese
sr at denx.de
Mon Jan 14 16:05:02 CET 2008
On Monday 14 January 2008, Niklaus Giger wrote:
> Added some routines used by all Netstal boards nm_show_print and
> common_misc_init_r and the very specific code to handle our SW installation
> procedure (set_params_for_sw_install).
>
> Signed-off-by: Niklaus Giger <niklaus.giger at netstal.com>
> ---
> board/netstal/common/nm_bsp.c | 131
> ++++++++++++++++++++++++++++++++++++----- 1 files changed, 116
> insertions(+), 15 deletions(-)
>
> diff --git a/board/netstal/common/nm_bsp.c b/board/netstal/common/nm_bsp.c
> index a9de45e..2c1d483 100644
> --- a/board/netstal/common/nm_bsp.c
> +++ b/board/netstal/common/nm_bsp.c
> @@ -20,22 +20,123 @@
>
> #include <common.h>
> #include <command.h>
> +#include <net.h>
>
> -#ifdef CONFIG_CMD_BSP
> -/*
> - * Command nm_bsp: Netstal Maschinen BSP specific command
> - */
> -int nm_bsp(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
> +DECLARE_GLOBAL_DATA_PTR;
> +
> +#define DEFAULT_ETH_ADDR "ethaddr"
> +
> +extern void hcu_led_set(u32 value);
> +extern u32 get_serial_number(void);
> +extern u32 hcu_get_slot(void);
> +
> +enum {
> + /* HW_GENERATION_HCU1 is no longer supported */
> + HW_GENERATION_HCU2 = 0x10,
> + HW_GENERATION_HCU3 = 0x10,
> + HW_GENERATION_HCU4 = 0x20,
> + HW_GENERATION_HCU5 = 0x30,
> + HW_GENERATION_MCU = 0x08,
> + HW_GENERATION_MCU20 = 0x0a,
> + HW_GENERATION_MCU25 = 0x09,
> +};
> +
> +
> +void nm_show_print(int generation, int index, int hw_capabilities)
> +{
> + int j;
Empty line after var declaration.
> + /* reset ANSI terminal color mode */
> + printf ("\x1B""[0m""Netstal Maschinen AG: ");
Either use space after the function (here "print") all the time in this file
or never (which is what I prefer).
> + if (generation == HW_GENERATION_HCU3)
> + printf("HCU3: index %d", index);
> + else if (generation == HW_GENERATION_HCU4)
> + printf("HCU4: index %d", index);
> + else if (generation == HW_GENERATION_HCU5)
> + printf("HCU5: index %d", index);
> + else if (generation == HW_GENERATION_MCU25)
> + printf("MCU25: index %d", index);
> + printf(" HW 0x%x\n", hw_capabilities);
> + for (j = 0;j < 6; j++) {
> + hcu_led_set(1 << j);
> + udelay(200 * 1000);
> + }
> +}
> +
> +void set_params_for_sw_install(int install_requested, char *board_name )
> {
> - printf("%s: flag %d, argc %d, argv[0] %s\n", __FUNCTION__,
> - flag, argc, argv[0]);
> - printf("Netstal Maschinen BSP specific command. None at the moment.\n");
> - return 0;
> + if (install_requested) {
> + char string[128];
Newline.
> + printf("\n\n%s SW-Installation: %d patching boot parameters\n",
> + board_name, install_requested);
> + setenv("bootdelay", "0");
> + setenv("loadaddr", "0x01000000");
> + setenv("serverip", "172.25.1.1");
> + setenv("bootcmd", "run install");
> + sprintf(string, "tftp ${loadaddr} admin/sw_on_hd; "
> + "tftp ${loadaddr} installer/%s_sw_inst; "
> + "run boot_sw_inst", board_name);
> + setenv("install", string);
> + sprintf(string, "setenv bootargs emac(0,0)c:%s/%s_sw_inst "
> + "e=${ipaddr} h=${serverip} f=0x1000; bootvx ${loadaddr}\0",
> + board_name, board_name);
> + setenv("boot_sw_inst", string);
> + }
> +}
> +
> +void common_misc_init_r(void)
> +{
> + char *s = getenv(DEFAULT_ETH_ADDR);
> + char *e;
> + int i;
> + u32 serial = get_serial_number();
> +
> + for (i = 0; i < 6; ++i) {
> + gd->bd->bi_enetaddr[i] = s ? simple_strtoul(s, &e, 16) : 0;
> + if (s)
> + s = (*e) ? e + 1 : e;
> + }
> +
> + if (gd->bd->bi_enetaddr[3] == 0 &&
> + gd->bd->bi_enetaddr[4] == 0 &&
> + gd->bd->bi_enetaddr[5] == 0) {
> + char ethaddr[22];
> +
> + /* Must be in sync with CONFIG_ETHADDR */
> + gd->bd->bi_enetaddr[0] = 0x00;
> + gd->bd->bi_enetaddr[1] = 0x60;
> + gd->bd->bi_enetaddr[2] = 0x13;
> + gd->bd->bi_enetaddr[3] = (serial >> 16) & 0xff;
> + gd->bd->bi_enetaddr[4] = (serial >> 8) & 0xff;
> + gd->bd->bi_enetaddr[5] = hcu_get_slot();
> + sprintf(ethaddr, "%02X:%02X:%02X:%02X:%02X:%02X\0",
> + gd->bd->bi_enetaddr[0], gd->bd->bi_enetaddr[1],
> + gd->bd->bi_enetaddr[2], gd->bd->bi_enetaddr[3],
> + gd->bd->bi_enetaddr[4], gd->bd->bi_enetaddr[5]) ;
> + printf("%s: Setting eth %s serial 0x%x\n", __FUNCTION__,
> + ethaddr, serial);
> + setenv(DEFAULT_ETH_ADDR, ethaddr);
> + }
> +
> + /* IP-Adress update */
> + {
Why do you need this "{" here? Doesn't really make sense to me.
Please fix and resubmit.
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
=====================================================================
More information about the U-Boot
mailing list