0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016 #include <stdarg.h>
0017 #include <stddef.h>
0018 #include "types.h"
0019 #include "elf.h"
0020 #include "string.h"
0021 #include "stdio.h"
0022 #include "page.h"
0023 #include "ops.h"
0024 #include "reg.h"
0025 #include "io.h"
0026 #include "dcr.h"
0027 #include "4xx.h"
0028 #include "44x.h"
0029 #include "libfdt.h"
0030
0031 BSS_STACK(4096);
0032
0033 static u32 ibm4xx_memstart;
0034
0035 static void iss_4xx_fixups(void)
0036 {
0037 void *memory;
0038 u32 reg[3];
0039
0040 memory = finddevice("/memory");
0041 if (!memory)
0042 fatal("Can't find memory node\n");
0043
0044 getprop(memory, "reg", reg, sizeof(reg));
0045 if (reg[2])
0046
0047 ibm4xx_memstart = reg[1];
0048 else
0049
0050 ibm4xx_sdram_fixup_memsize();
0051 }
0052
0053 static void *iss_4xx_vmlinux_alloc(unsigned long size)
0054 {
0055 return (void *)ibm4xx_memstart;
0056 }
0057
0058 #define SPRN_PIR 0x11E
0059 void platform_init(void)
0060 {
0061 unsigned long end_of_ram = 0x08000000;
0062 unsigned long avail_ram = end_of_ram - (unsigned long)_end;
0063 u32 pir_reg;
0064
0065 simple_alloc_init(_end, avail_ram, 128, 64);
0066 platform_ops.fixups = iss_4xx_fixups;
0067 platform_ops.vmlinux_alloc = iss_4xx_vmlinux_alloc;
0068 platform_ops.exit = ibm44x_dbcr_reset;
0069 pir_reg = mfspr(SPRN_PIR);
0070 fdt_set_boot_cpuid_phys(_dtb_start, pir_reg);
0071 fdt_init(_dtb_start);
0072 serial_console_init();
0073 }