Statistics
| Branch: | Revision:

root / hw / collie.c @ 84dfb926

History | View | Annotate | Download (2 kB)

1 c64b21d5 Dmitry Eremin-Solenikov
/*
2 c64b21d5 Dmitry Eremin-Solenikov
 * SA-1110-based Sharp Zaurus SL-5500 platform.
3 c64b21d5 Dmitry Eremin-Solenikov
 *
4 c64b21d5 Dmitry Eremin-Solenikov
 * Copyright (C) 2011 Dmitry Eremin-Solenikov
5 c64b21d5 Dmitry Eremin-Solenikov
 *
6 c64b21d5 Dmitry Eremin-Solenikov
 * This code is licensed under GNU GPL v2.
7 c64b21d5 Dmitry Eremin-Solenikov
 */
8 c64b21d5 Dmitry Eremin-Solenikov
#include "hw.h"
9 c64b21d5 Dmitry Eremin-Solenikov
#include "sysbus.h"
10 c64b21d5 Dmitry Eremin-Solenikov
#include "boards.h"
11 c64b21d5 Dmitry Eremin-Solenikov
#include "devices.h"
12 c64b21d5 Dmitry Eremin-Solenikov
#include "strongarm.h"
13 c64b21d5 Dmitry Eremin-Solenikov
#include "arm-misc.h"
14 c64b21d5 Dmitry Eremin-Solenikov
#include "flash.h"
15 c64b21d5 Dmitry Eremin-Solenikov
#include "blockdev.h"
16 c64b21d5 Dmitry Eremin-Solenikov
17 c64b21d5 Dmitry Eremin-Solenikov
static struct arm_boot_info collie_binfo = {
18 c64b21d5 Dmitry Eremin-Solenikov
    .loader_start = SA_SDCS0,
19 c64b21d5 Dmitry Eremin-Solenikov
    .ram_size = 0x20000000,
20 c64b21d5 Dmitry Eremin-Solenikov
};
21 c64b21d5 Dmitry Eremin-Solenikov
22 c64b21d5 Dmitry Eremin-Solenikov
static void collie_init(ram_addr_t ram_size,
23 c64b21d5 Dmitry Eremin-Solenikov
                const char *boot_device,
24 c64b21d5 Dmitry Eremin-Solenikov
                const char *kernel_filename, const char *kernel_cmdline,
25 c64b21d5 Dmitry Eremin-Solenikov
                const char *initrd_filename, const char *cpu_model)
26 c64b21d5 Dmitry Eremin-Solenikov
{
27 c64b21d5 Dmitry Eremin-Solenikov
    StrongARMState *s;
28 c64b21d5 Dmitry Eremin-Solenikov
    DriveInfo *dinfo;
29 c8a50e59 Avi Kivity
    MemoryRegion *phys_flash = g_new(MemoryRegion, 2);
30 c64b21d5 Dmitry Eremin-Solenikov
31 c64b21d5 Dmitry Eremin-Solenikov
    if (!cpu_model) {
32 c64b21d5 Dmitry Eremin-Solenikov
        cpu_model = "sa1110";
33 c64b21d5 Dmitry Eremin-Solenikov
    }
34 c64b21d5 Dmitry Eremin-Solenikov
35 c64b21d5 Dmitry Eremin-Solenikov
    s = sa1110_init(collie_binfo.ram_size, cpu_model);
36 c64b21d5 Dmitry Eremin-Solenikov
37 c8a50e59 Avi Kivity
    memory_region_init_rom_device(&phys_flash[0], &pflash_cfi01_ops_le,
38 c8a50e59 Avi Kivity
                                  NULL, "collie.fl1", 0x02000000);
39 c64b21d5 Dmitry Eremin-Solenikov
    dinfo = drive_get(IF_PFLASH, 0, 0);
40 c8a50e59 Avi Kivity
    pflash_cfi01_register(SA_CS0, &phys_flash[0],
41 c64b21d5 Dmitry Eremin-Solenikov
                    dinfo ? dinfo->bdrv : NULL, (64 * 1024),
42 c8a50e59 Avi Kivity
                    512, 4, 0x00, 0x00, 0x00, 0x00);
43 c64b21d5 Dmitry Eremin-Solenikov
44 c8a50e59 Avi Kivity
    memory_region_init_rom_device(&phys_flash[1], &pflash_cfi01_ops_le,
45 c8a50e59 Avi Kivity
                                  NULL, "collie.fl2", 0x02000000);
46 c64b21d5 Dmitry Eremin-Solenikov
    dinfo = drive_get(IF_PFLASH, 0, 1);
47 c8a50e59 Avi Kivity
    pflash_cfi01_register(SA_CS1, &phys_flash[1],
48 c64b21d5 Dmitry Eremin-Solenikov
                    dinfo ? dinfo->bdrv : NULL, (64 * 1024),
49 c8a50e59 Avi Kivity
                    512, 4, 0x00, 0x00, 0x00, 0x00);
50 c64b21d5 Dmitry Eremin-Solenikov
51 c64b21d5 Dmitry Eremin-Solenikov
    sysbus_create_simple("scoop", 0x40800000, NULL);
52 c64b21d5 Dmitry Eremin-Solenikov
53 c64b21d5 Dmitry Eremin-Solenikov
    collie_binfo.kernel_filename = kernel_filename;
54 c64b21d5 Dmitry Eremin-Solenikov
    collie_binfo.kernel_cmdline = kernel_cmdline;
55 c64b21d5 Dmitry Eremin-Solenikov
    collie_binfo.initrd_filename = initrd_filename;
56 c64b21d5 Dmitry Eremin-Solenikov
    collie_binfo.board_id = 0x208;
57 c64b21d5 Dmitry Eremin-Solenikov
    arm_load_kernel(s->env, &collie_binfo);
58 c64b21d5 Dmitry Eremin-Solenikov
}
59 c64b21d5 Dmitry Eremin-Solenikov
60 c64b21d5 Dmitry Eremin-Solenikov
static QEMUMachine collie_machine = {
61 c64b21d5 Dmitry Eremin-Solenikov
    .name = "collie",
62 c64b21d5 Dmitry Eremin-Solenikov
    .desc = "Collie PDA (SA-1110)",
63 c64b21d5 Dmitry Eremin-Solenikov
    .init = collie_init,
64 c64b21d5 Dmitry Eremin-Solenikov
};
65 c64b21d5 Dmitry Eremin-Solenikov
66 c64b21d5 Dmitry Eremin-Solenikov
static void collie_machine_init(void)
67 c64b21d5 Dmitry Eremin-Solenikov
{
68 c64b21d5 Dmitry Eremin-Solenikov
    qemu_register_machine(&collie_machine);
69 c64b21d5 Dmitry Eremin-Solenikov
}
70 c64b21d5 Dmitry Eremin-Solenikov
71 c64b21d5 Dmitry Eremin-Solenikov
machine_init(collie_machine_init)