4ebef31fa6
* Switched from 64M NOR/64M NAND to 4M NOR/256M NAND. * Full DTM support including critical temperature. * Added POST information. * Removed LED function, moved to new LED driver. * Moved ad7414 to new style I2C initialization. Signed-off-by: Sean MacLennan <smaclennan@pikatech.com> Signed-off-by: Josh Boyer <jwboyer@linux.vnet.ibm.com>
81 lines
1.7 KiB
C
81 lines
1.7 KiB
C
/*
|
|
* Copyright (c) 2008 PIKA Technologies
|
|
* Sean MacLennan <smaclennan@pikatech.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License version 2 as published
|
|
* by the Free Software Foundation.
|
|
*/
|
|
|
|
#include "ops.h"
|
|
#include "4xx.h"
|
|
#include "cuboot.h"
|
|
#include "stdio.h"
|
|
|
|
#define TARGET_4xx
|
|
#define TARGET_44x
|
|
#include "ppcboot.h"
|
|
|
|
static bd_t bd;
|
|
|
|
static void warp_fixup_one_nor(u32 from, u32 to)
|
|
{
|
|
void *devp;
|
|
char name[50];
|
|
u32 v[2];
|
|
|
|
sprintf(name, "/plb/opb/ebc/nor_flash@0,0/partition@%x", from);
|
|
|
|
devp = finddevice(name);
|
|
if (!devp)
|
|
return;
|
|
|
|
if (getprop(devp, "reg", v, sizeof(v)) == sizeof(v)) {
|
|
v[0] = to;
|
|
setprop(devp, "reg", v, sizeof(v));
|
|
|
|
printf("NOR 64M fixup %x -> %x\r\n", from, to);
|
|
}
|
|
}
|
|
|
|
|
|
static void warp_fixups(void)
|
|
{
|
|
ibm440ep_fixup_clocks(66000000, 11059200, 50000000);
|
|
ibm4xx_sdram_fixup_memsize();
|
|
ibm4xx_fixup_ebc_ranges("/plb/opb/ebc");
|
|
dt_fixup_mac_address_by_alias("ethernet0", bd.bi_enetaddr);
|
|
|
|
/* Fixup for 64M flash on Rev A boards. */
|
|
if (bd.bi_flashsize == 0x4000000) {
|
|
void *devp;
|
|
u32 v[3];
|
|
|
|
devp = finddevice("/plb/opb/ebc/nor_flash@0,0");
|
|
if (!devp)
|
|
return;
|
|
|
|
/* Fixup the size */
|
|
if (getprop(devp, "reg", v, sizeof(v)) == sizeof(v)) {
|
|
v[2] = bd.bi_flashsize;
|
|
setprop(devp, "reg", v, sizeof(v));
|
|
}
|
|
|
|
/* Fixup parition offsets */
|
|
warp_fixup_one_nor(0x300000, 0x3f00000);
|
|
warp_fixup_one_nor(0x340000, 0x3f40000);
|
|
warp_fixup_one_nor(0x380000, 0x3f80000);
|
|
}
|
|
}
|
|
|
|
|
|
void platform_init(unsigned long r3, unsigned long r4, unsigned long r5,
|
|
unsigned long r6, unsigned long r7)
|
|
{
|
|
CUBOOT_INIT();
|
|
|
|
platform_ops.fixups = warp_fixups;
|
|
platform_ops.exit = ibm44x_dbcr_reset;
|
|
fdt_init(_dtb_start);
|
|
serial_console_init();
|
|
}
|