blob: b23135bd75e6452a6597f77b341e8ec300b62d90 [file] [log] [blame]
wdenk1f4bb372003-07-27 00:21:01 +00001/*
2 * Copyright (c) Orbacom Systems, Inc <www.orbacom.com>
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms are freely
6 * permitted provided that the above copyright notice and this
7 * paragraph and the following disclaimer are duplicated in all
8 * such forms.
9 *
10 * This software is provided "AS IS" and without any express or
11 * implied warranties, including, without limitation, the implied
12 * warranties of merchantability and fitness for a particular
13 * purpose.
14 */
15
16#include <common.h>
17#include <asm/processor.h>
18#include <image.h>
Wolfgang Denkd2567be2009-03-28 20:16:16 +010019#include <net.h>
wdenk1f4bb372003-07-27 00:21:01 +000020
wdenk1f4bb372003-07-27 00:21:01 +000021#include <lynxkdi.h>
22
Wolfgang Denkd87080b2006-03-31 18:32:53 +020023DECLARE_GLOBAL_DATA_PTR;
24
Stefan Roese846b0dd2005-08-08 12:42:22 +020025#if defined(CONFIG_MPC8260) || defined(CONFIG_440EP) || defined(CONFIG_440GR)
Marian Balakowicz1ee11802008-01-08 18:17:10 +010026void lynxkdi_boot (image_header_t *hdr)
wdenk1f4bb372003-07-27 00:21:01 +000027{
Marian Balakowiczb97a2a02008-01-08 18:14:09 +010028 void (*lynxkdi)(void) = (void(*)(void))image_get_ep (hdr);
wdenk1f4bb372003-07-27 00:21:01 +000029 lynxos_bootparms_t *parms = (lynxos_bootparms_t *)0x0020;
30 bd_t *kbd;
Marian Balakowiczb97a2a02008-01-08 18:14:09 +010031 u32 *psz = (u32 *)(image_get_load (hdr) + 0x0204);
wdenk1f4bb372003-07-27 00:21:01 +000032
Marian Balakowicz1ee11802008-01-08 18:17:10 +010033 memset (parms, 0, sizeof(*parms));
wdenk1f4bb372003-07-27 00:21:01 +000034 kbd = gd->bd;
35 parms->clock_ref = kbd->bi_busfreq;
36 parms->dramsz = kbd->bi_memsize;
Mike Frysinger50135332009-02-11 18:54:07 -050037 eth_getenv_enetaddr("ethaddr", parms->ethaddr);
Marian Balakowicz1ee11802008-01-08 18:17:10 +010038 mtspr (SPRN_SPRG2, 0x0020);
wdenk1f4bb372003-07-27 00:21:01 +000039
40 /* Do a simple check for Bluecat so we can pass the
41 * kernel command line parameters.
42 */
Marian Balakowicz1ee11802008-01-08 18:17:10 +010043 if (le32_to_cpu (*psz) == image_get_data_size (hdr)) { /* FIXME: NOT SURE HERE ! */
44 char *args;
45 char *cmdline = (char *)(image_get_load (hdr) + 0x020c);
46 int len;
wdenk1f4bb372003-07-27 00:21:01 +000047
Marian Balakowicz1ee11802008-01-08 18:17:10 +010048 printf ("Booting Bluecat KDI ...\n");
49 udelay (200*1000); /* Allow serial port to flush */
50 if ((args = getenv ("bootargs")) == NULL)
51 args = "";
52 /* Prepend the cmdline */
53 len = strlen (args);
54 if (len && (len + strlen (cmdline) + 2 < (0x0400 - 0x020c))) {
55 memmove (cmdline + strlen (args) + 1, cmdline, strlen (cmdline));
56 strcpy (cmdline, args);
57 cmdline[len] = ' ';
58 }
wdenk1f4bb372003-07-27 00:21:01 +000059 }
60 else {
Marian Balakowicz1ee11802008-01-08 18:17:10 +010061 printf ("Booting LynxOS KDI ...\n");
wdenk1f4bb372003-07-27 00:21:01 +000062 }
63
Marian Balakowicz1ee11802008-01-08 18:17:10 +010064 lynxkdi ();
wdenk1f4bb372003-07-27 00:21:01 +000065}
66#else
67#error "Lynx KDI support not implemented for configured CPU"
68#endif