| John Crispin | 171bb2f | 2011-03-30 09:27:47 +0200 | [diff] [blame] | 1 | /* | 
|  | 2 | *  This program is free software; you can redistribute it and/or modify it | 
|  | 3 | *  under the terms of the GNU General Public License version 2 as published | 
|  | 4 | *  by the Free Software Foundation. | 
|  | 5 | * | 
|  | 6 | * Copyright (C) 2010 John Crispin <blogic@openwrt.org> | 
|  | 7 | */ | 
|  | 8 |  | 
|  | 9 | #include <linux/kernel.h> | 
|  | 10 | #include <linux/module.h> | 
|  | 11 | #include <linux/io.h> | 
|  | 12 | #include <linux/ioport.h> | 
|  | 13 | #include <asm/bootinfo.h> | 
|  | 14 |  | 
|  | 15 | #include <lantiq_soc.h> | 
|  | 16 |  | 
| John Crispin | a053ac1 | 2011-03-30 09:27:54 +0200 | [diff] [blame] | 17 | #include "machtypes.h" | 
|  | 18 | #include "devices.h" | 
|  | 19 | #include "prom.h" | 
|  | 20 |  | 
| John Crispin | 171bb2f | 2011-03-30 09:27:47 +0200 | [diff] [blame] | 21 | void __init plat_mem_setup(void) | 
|  | 22 | { | 
|  | 23 | /* assume 16M as default incase uboot fails to pass proper ramsize */ | 
|  | 24 | unsigned long memsize = 16; | 
|  | 25 | char **envp = (char **) KSEG1ADDR(fw_arg2); | 
|  | 26 |  | 
|  | 27 | ioport_resource.start = IOPORT_RESOURCE_START; | 
|  | 28 | ioport_resource.end = IOPORT_RESOURCE_END; | 
|  | 29 | iomem_resource.start = IOMEM_RESOURCE_START; | 
|  | 30 | iomem_resource.end = IOMEM_RESOURCE_END; | 
|  | 31 |  | 
|  | 32 | set_io_port_base((unsigned long) KSEG1); | 
|  | 33 |  | 
|  | 34 | while (*envp) { | 
|  | 35 | char *e = (char *)KSEG1ADDR(*envp); | 
|  | 36 | if (!strncmp(e, "memsize=", 8)) { | 
|  | 37 | e += 8; | 
|  | 38 | if (strict_strtoul(e, 0, &memsize)) | 
|  | 39 | pr_warn("bad memsize specified\n"); | 
|  | 40 | } | 
|  | 41 | envp++; | 
|  | 42 | } | 
|  | 43 | memsize *= 1024 * 1024; | 
|  | 44 | add_memory_region(0x00000000, memsize, BOOT_MEM_RAM); | 
|  | 45 | } | 
| John Crispin | a053ac1 | 2011-03-30 09:27:54 +0200 | [diff] [blame] | 46 |  | 
|  | 47 | static int __init | 
|  | 48 | lantiq_setup(void) | 
|  | 49 | { | 
|  | 50 | ltq_soc_setup(); | 
|  | 51 | mips_machine_setup(); | 
|  | 52 | return 0; | 
|  | 53 | } | 
|  | 54 |  | 
|  | 55 | arch_initcall(lantiq_setup); | 
|  | 56 |  | 
|  | 57 | static void __init | 
|  | 58 | lantiq_generic_init(void) | 
|  | 59 | { | 
|  | 60 | /* Nothing to do */ | 
|  | 61 | } | 
|  | 62 |  | 
|  | 63 | MIPS_MACHINE(LTQ_MACH_GENERIC, | 
|  | 64 | "Generic", | 
|  | 65 | "Generic Lantiq based board", | 
|  | 66 | lantiq_generic_init); |