From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:54238) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1XRPkz-0000jC-57 for qemu-devel@nongnu.org; Tue, 09 Sep 2014 14:03:15 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1XRPkt-0001n2-59 for qemu-devel@nongnu.org; Tue, 09 Sep 2014 14:03:09 -0400 Received: from mail-lb0-f171.google.com ([209.85.217.171]:61834) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1XRPks-0001mo-VH for qemu-devel@nongnu.org; Tue, 09 Sep 2014 14:03:03 -0400 Received: by mail-lb0-f171.google.com with SMTP id 10so10355996lbg.30 for ; Tue, 09 Sep 2014 11:03:02 -0700 (PDT) MIME-Version: 1.0 In-Reply-To: <1409930126-28449-4-git-send-email-ard.biesheuvel@linaro.org> References: <1409930126-28449-1-git-send-email-ard.biesheuvel@linaro.org> <1409930126-28449-4-git-send-email-ard.biesheuvel@linaro.org> From: Peter Maydell Date: Tue, 9 Sep 2014 19:02:42 +0100 Message-ID: Content-Type: text/plain; charset=UTF-8 Subject: Re: [Qemu-devel] [PATCH 3/6] hw/arm/boot: load device tree to base of DRAM if no -kernel option was passed List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Ard Biesheuvel Cc: Fu Wei , QEMU Developers , Christoffer Dall On 5 September 2014 16:15, Ard Biesheuvel wrote: > If we are running the 'virt' machine, we may have a device tree blob but no > kernel to supply it to if no -kernel option was passed. In that case, copy it > to the base of RAM where it can be picked up by a bootloader. > > Signed-off-by: Ard Biesheuvel > --- > hw/arm/boot.c | 10 ++++++++++ > 1 file changed, 10 insertions(+) > > diff --git a/hw/arm/boot.c b/hw/arm/boot.c > index c103a8fdc941..8f5649a250fd 100644 > --- a/hw/arm/boot.c > +++ b/hw/arm/boot.c > @@ -463,6 +463,16 @@ void arm_load_kernel(ARMCPU *cpu, struct arm_boot_info *info) > > /* Load the kernel. */ > if (!info->kernel_filename) { > + > + if (have_dtb(info)) { > + /* If we have a device tree blob, but no kernel to supply it to, > + * copy it to the base of RAM for a bootloader to pick up. > + */ > + if (load_dtb(info->loader_start, info, NULL)) { > + exit(1); > + } > + } > + > /* If no kernel specified, do nothing; we will start from address 0 > * (typically a boot ROM image) in the same way as hardware. > */ > -- > 1.8.3.2 Reviewed-by: Peter Maydell (though obviously if you change the load_dtb() arg/return this will need tweaking slightly). -- PMM