Received: by 10.223.164.202 with SMTP id h10csp4698069wrb; Wed, 29 Nov 2017 10:20:53 -0800 (PST) X-Google-Smtp-Source: AGs4zMaL1+PdQ6qwX1nQP0TWEPzHFYDXkRFtuvZFdQdan10/ChPqGtHDQ6Pv/67EGCRn1le2Cvbn X-Received: by 10.84.202.194 with SMTP id q2mr3786282plh.19.1511979653045; Wed, 29 Nov 2017 10:20:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1511979653; cv=none; d=google.com; s=arc-20160816; b=0cnGYfRQ1urQ4JMOkW/CQj+8VY03knDMFWgLCp+/2zblwLBzoBAQDElQFizVKMNDgW qkhA0PfTMCpZdQUBUEiKI1hNko3WKJ+nFXw8CxxfDDyl4SF2/ABgK0DITJPba5EObhgt h49FQnNLtu18jH4L7iSCiFKAlXS654mInU6WItZNYZ3zP89z0gXESo7oL6KDvXmVOwLa hnGGecnj70hBPbX7fID0yecdQZ6glF6By5IfFUBbaAC4nIftYnRHScad03zcE4gu+5zU zEvA3FE3O0VccMzL55w9iVWkgWZi0lTHgX3E+UADsXDbtSb4OJdgP8JvUracVKngsQrX y4WA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=dw482HsfwEtLUW77q1RsOKM++fsx3MEX20q6POyraZY=; b=aJpK1f7+D8jCZthGzap1ikA21I4UOgxL90p9hdriN3rOIN9QMb44xlrnhI1zAPCCem jnuIlSt23ZQDKISTWq72Lx50t81POobwd98U1HgnKvXsS2zSjLG86kTzGu3sSvHKCxqt ckydHdl3t3GcWH6mXaRb9RikjXxuikoqktJKCjAd1CC5RHeQYwjTJE87Tr2gpLvCd2B1 dQa5JcVdhUW53pXwdxwJJNj8to2UeoDolvoNfC6xli08elmMqeU/TUMWpIF07RY6JTKx VW+asQ2GoIyQ3ZjYYIcThMckjQfRgDxDIWiviQkfZm6Wt0pgPSlya3HRUHT5Fg618nFN h6AA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e16si1611835pgn.490.2017.11.29.10.20.42; Wed, 29 Nov 2017 10:20:53 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755419AbdK2Owu (ORCPT + 70 others); Wed, 29 Nov 2017 09:52:50 -0500 Received: from smtp.ctxuk.citrix.com ([185.25.65.24]:25349 "EHLO SMTP.EU.CITRIX.COM" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751546AbdK2Ows (ORCPT ); Wed, 29 Nov 2017 09:52:48 -0500 X-IronPort-AV: E=Sophos;i="5.44,473,1505779200"; d="scan'208";a="63911172" Subject: Re: [RFC PATCH] KVM: x86: Allow Qemu/KVM to use PVH entry point To: Juergen Gross , Paolo Bonzini , Boris Ostrovsky , =?UTF-8?Q?Roger_Pau_Monn=c3=a9?= CC: Maran Wilson , , , , , , , , , References: <1511897682-32060-1-git-send-email-maran.wilson@oracle.com> <176188ca-51f9-ef12-6e93-46ab2d8b8cfc@suse.com> <20171129085044.kc3yqqdcw3zmp2k2@MacBook-Pro-de-Roger.local> <4d213199-ea65-4410-5b7a-63038215e380@oracle.com> <0162f2cd-2d9e-1c89-bb8e-7ac0089f0b3a@suse.com> <20171129141810.q3s3xflsflpjovdd@MacBook-Pro-de-Roger.local> <96f9b4a5-7cb6-19c3-227d-8c48916d5969@oracle.com> <25d6db63-a57d-b15c-2d43-e96c506b4824@redhat.com> From: Andrew Cooper Message-ID: <7eeb433d-e72a-68e8-bef6-eb695d55fe79@citrix.com> Date: Wed, 29 Nov 2017 14:52:43 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.4.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="windows-1252" Content-Transfer-Encoding: 8bit Content-Language: en-GB X-ClientProxiedBy: AMSPEX02CAS02.citrite.net (10.69.22.113) To AMSPEX02CL02.citrite.net (10.69.22.126) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 29/11/17 14:47, Juergen Gross wrote: > On 29/11/17 15:44, Paolo Bonzini wrote: >> On 29/11/2017 15:25, Boris Ostrovsky wrote: >>>>>> zeropage is x86/Linux-specific so we'd need some sort of firmware (like >>>>>> grub) between a hypervisor and Linux to convert hvm_start_info to >>>>>> bootparams. >>>>> qemu? >>> I think KVM folks didn't want to do this. I can't find the thread but I >>> believe it was somewhere during Clear Containers discussion. Paolo? >> QEMU is the right place to parse the ELF file and save it in memory. >> You would have to teach QEMU to find the Xen note in ELF-format kernels >> (just like it looks for the multiboot header), and use a different >> option ROM ("pvhboot.c" for example). >> >> However I don't like to bypass the BIOS; for -kernel, KVM starts the >> guest with an option ROM (linuxboot-dma.c or multiboot.S in QEMU >> sources) that takes care of boot. >> >> In either case, you would have a new option ROM. It could either be >> very simple and similar to multiboot.S, or it could be larger and do the >> same task as xen-pvh.S and enlighten_pvh.c (then get the address of >> startup_32 or startup_64 from FW_CFG_KERNEL_ENTRY and jump there). The >> ugly part is that the option ROM would have to know more details about >> what it is going to boot, including for example whether it's 32-bit or >> 64-bit, so I don't really think it is a good idea. > As grub2 doesn't have to know, qemu shouldn't have to know either. An underlying requirement for this boot protocol was to remove the requirement for a priori knowledge of the eventual mode of the guest, which plagues Xen PV guests.� (One way or another, we need to parse the kernel which will end up running to work out how to build the domain for it.) 32bit flat mode is easy to set up, sufficiently large for any reasonable bootstrapping, and provides no restrictions to what the eventual guest wants to do. ~Andrew From 1585425564139361023@xxx Wed Nov 29 18:20:41 +0000 2017 X-GM-THRID: 1585339868639162159 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread