[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH 5/5] hw/arm: add cubieboard support
From: |
Andreas Färber |
Subject: |
Re: [Qemu-devel] [PATCH 5/5] hw/arm: add cubieboard support |
Date: |
Tue, 03 Dec 2013 15:44:36 +0100 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:24.0) Gecko/20100101 Thunderbird/24.1.0 |
Am 03.12.2013 13:01, schrieb Peter Crosthwaite:
> On Tue, Dec 3, 2013 at 7:11 PM, liguang <address@hidden> wrote:
>> Signed-off-by: liguang <address@hidden>
>> ---
>> hw/arm/Makefile.objs | 2 +-
>> hw/arm/cubieboard.c | 33 +++++++++++++++++++++++++++++++++
>> 2 files changed, 34 insertions(+), 1 deletions(-)
>> create mode 100644 hw/arm/cubieboard.c
>>
>> diff --git a/hw/arm/Makefile.objs b/hw/arm/Makefile.objs
>> index b9e5983..8be8d8e 100644
>> --- a/hw/arm/Makefile.objs
>> +++ b/hw/arm/Makefile.objs
>> @@ -4,4 +4,4 @@ obj-y += omap_sx1.o palm.o realview.o spitz.o stellaris.o
>> obj-y += tosa.o versatilepb.o vexpress.o xilinx_zynq.o z2.o
>>
>> obj-y += armv7m.o exynos4210.o pxa2xx.o pxa2xx_gpio.o pxa2xx_pic.o
>> -obj-y += omap1.o omap2.o strongarm.o allwinner-a10.o
>> +obj-y += omap1.o omap2.o strongarm.o allwinner-a10.o cubieboard.o
>> diff --git a/hw/arm/cubieboard.c b/hw/arm/cubieboard.c
>> new file mode 100644
>> index 0000000..a5be21c
>> --- /dev/null
>> +++ b/hw/arm/cubieboard.c
>> @@ -0,0 +1,33 @@
>> +#include "hw/sysbus.h"
>> +#include "hw/devices.h"
>> +#include "hw/boards.h"
>> +#include "hw/arm/allwinner-a10.h"
>> +
>> +
>> +static struct arm_boot_info cubieboard_binfo = {
>> + .loader_start = A10_SDRAM_BASE,
>> + .board_id = 0x1008,
>> +};
>> +
>> +static void cubieboard_init(QEMUMachineInitArgs *args)
>> +{
>> + A10State *s = a10_init(get_system_memory(), args->ram_size);
>> +
>> + cubieboard_binfo.ram_size = args->ram_size;
>> + cubieboard_binfo.kernel_filename = args->kernel_filename;
>> + cubieboard_binfo.kernel_cmdline = args->kernel_cmdline;
>
> I cant help but think that serial attachment needs to happen on the
> board level. but im not sure how this can be made to work with the
> un-qomified serial_mm_init, so no block from me unless Andreas has a
> better idea.
I don't have an immediate solution, same problem in Tegra2 code.
If someone is willing to convert serial_mm into QOM-friendly form that
would be nice but I will be unavailable for review the next ~two weeks.
What I do wonder here is why this is calling a new a10_init() rather
than object_new() and related QOM APIs. get_system_memory() can without
problems be called inside the device. If RAM is really on the SoC (it is
for Tegra2/3) then it could become a property of the device with
MemoryRegion initialization in realize - that is still unclean in my
code IIRC.
>> + arm_load_kernel(s->cpu, &cubieboard_binfo);
>> +}
[...]
>> +machine_init(cubieboard_machine_init);
No semicolon here please, it's a function.
Regards,
Andreas
--
SUSE LINUX Products GmbH, Maxfeldstr. 5, 90409 Nürnberg, Germany
GF: Jeff Hawn, Jennifer Guild, Felix Imendörffer; HRB 16746 AG Nürnberg
- [Qemu-devel] [PATCH 0/5] add allwinner A10 SoC support, liguang, 2013/12/03
- [Qemu-devel] [PATCH 1/5] vmstate: add VMSTATE_PTIMER_ARRAY, liguang, 2013/12/03
- [Qemu-devel] [PATCH 3/5] hw/intc: add allwinner A10 interrupt controller, liguang, 2013/12/03
- [Qemu-devel] [PATCH 2/5] hw/timer: add allwinner a10 timer, liguang, 2013/12/03
- [Qemu-devel] [PATCH 5/5] hw/arm: add cubieboard support, liguang, 2013/12/03
- [Qemu-devel] [PATCH 4/5] hw/arm: add allwinner a10 SoC support, liguang, 2013/12/03