mirror of
				https://github.com/qemu/qemu.git
				synced 2025-10-26 12:03:40 +00:00 
			
		
		
		
	 3cd892daa3
			
		
	
	
		3cd892daa3
		
	
	
	
	
		
			
			The SDRAM is incorrectly created in the SA1110 SoC. Move its creation in the board code, this will later allow the board to have the QOM ownership of the RAM. Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Message-id: 20191021190653.9511-4-philmd@redhat.com Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
		
			
				
	
	
		
			63 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * SA-1110-based Sharp Zaurus SL-5500 platform.
 | |
|  *
 | |
|  * Copyright (C) 2011 Dmitry Eremin-Solenikov
 | |
|  *
 | |
|  * This code is licensed under GNU GPL v2.
 | |
|  *
 | |
|  * Contributions after 2012-01-13 are licensed under the terms of the
 | |
|  * GNU GPL, version 2 or (at your option) any later version.
 | |
|  */
 | |
| #include "qemu/osdep.h"
 | |
| #include "qemu/units.h"
 | |
| #include "hw/sysbus.h"
 | |
| #include "hw/boards.h"
 | |
| #include "strongarm.h"
 | |
| #include "hw/arm/boot.h"
 | |
| #include "hw/block/flash.h"
 | |
| #include "exec/address-spaces.h"
 | |
| #include "cpu.h"
 | |
| 
 | |
| static struct arm_boot_info collie_binfo = {
 | |
|     .loader_start = SA_SDCS0,
 | |
|     .ram_size = 0x20000000,
 | |
| };
 | |
| 
 | |
| static void collie_init(MachineState *machine)
 | |
| {
 | |
|     StrongARMState *s;
 | |
|     DriveInfo *dinfo;
 | |
|     MemoryRegion *sdram = g_new(MemoryRegion, 1);
 | |
| 
 | |
|     s = sa1110_init(machine->cpu_type);
 | |
| 
 | |
|     memory_region_allocate_system_memory(sdram, NULL, "strongarm.sdram",
 | |
|                                          collie_binfo.ram_size);
 | |
|     memory_region_add_subregion(get_system_memory(), SA_SDCS0, sdram);
 | |
| 
 | |
|     dinfo = drive_get(IF_PFLASH, 0, 0);
 | |
|     pflash_cfi01_register(SA_CS0, "collie.fl1", 0x02000000,
 | |
|                     dinfo ? blk_by_legacy_dinfo(dinfo) : NULL,
 | |
|                     64 * KiB, 4, 0x00, 0x00, 0x00, 0x00, 0);
 | |
| 
 | |
|     dinfo = drive_get(IF_PFLASH, 0, 1);
 | |
|     pflash_cfi01_register(SA_CS1, "collie.fl2", 0x02000000,
 | |
|                     dinfo ? blk_by_legacy_dinfo(dinfo) : NULL,
 | |
|                     64 * KiB, 4, 0x00, 0x00, 0x00, 0x00, 0);
 | |
| 
 | |
|     sysbus_create_simple("scoop", 0x40800000, NULL);
 | |
| 
 | |
|     collie_binfo.board_id = 0x208;
 | |
|     arm_load_kernel(s->cpu, machine, &collie_binfo);
 | |
| }
 | |
| 
 | |
| static void collie_machine_init(MachineClass *mc)
 | |
| {
 | |
|     mc->desc = "Sharp SL-5500 (Collie) PDA (SA-1110)";
 | |
|     mc->init = collie_init;
 | |
|     mc->ignore_memory_transaction_failures = true;
 | |
|     mc->default_cpu_type = ARM_CPU_TYPE_NAME("sa1110");
 | |
| }
 | |
| 
 | |
| DEFINE_MACHINE("collie", collie_machine_init)
 |