From mboxrd@z Thu Jan 1 00:00:00 1970 From: Juergen Gross Subject: [PATCH v2 2/5] xen: add generic flag to elf_dom_parms indicating support of unmapped initrd Date: Fri, 2 Oct 2015 07:49:44 +0200 Message-ID: <1443764987-23639-3-git-send-email-jgross@suse.com> References: <1443764987-23639-1-git-send-email-jgross@suse.com> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Return-path: In-Reply-To: <1443764987-23639-1-git-send-email-jgross@suse.com> List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Sender: xen-devel-bounces@lists.xen.org Errors-To: xen-devel-bounces@lists.xen.org To: xen-devel@lists.xen.org, Ian.Campbell@citrix.com, ian.jackson@eu.citrix.com, stefano.stabellini@eu.citrix.com, wei.liu2@citrix.com Cc: Juergen Gross , Andrew Cooper , Keir Fraser , Jan Beulich , Tim Deegan List-Id: xen-devel@lists.xenproject.org Support of an unmapped initrd is indicated by the kernel of the domain via elf notes. In order not to have to use raw elf data in the tools for support of an unmapped initrd add a flag to the parsed data area to indicate the kernel supporting this feature. Switch using this flag in the hypervisor domain builder. Cc: Keir Fraser Cc: Jan Beulich Cc: Andrew Cooper Cc: Tim Deegan Suggested-by: Ian Campbell Signed-off-by: Juergen Gross --- xen/arch/x86/domain_build.c | 4 ++-- xen/common/libelf/libelf-dominfo.c | 3 +++ xen/include/xen/libelf.h | 1 + 3 files changed, 6 insertions(+), 2 deletions(-) diff --git a/xen/arch/x86/domain_build.c b/xen/arch/x86/domain_build.c index c2ef87a..a02c9fb 100644 --- a/xen/arch/x86/domain_build.c +++ b/xen/arch/x86/domain_build.c @@ -353,7 +353,7 @@ static unsigned long __init compute_dom0_nr_pages( vstart = parms->virt_base; vend = round_pgup(parms->virt_kend); - if ( !parms->elf_notes[XEN_ELFNOTE_MOD_START_PFN].data.num ) + if ( !parms->mod_start_pfn ) vend += round_pgup(initrd_len); end = vend + nr_pages * sizeof_long; @@ -1037,7 +1037,7 @@ int __init construct_dom0( v_start = parms.virt_base; vkern_start = parms.virt_kstart; vkern_end = parms.virt_kend; - if ( parms.elf_notes[XEN_ELFNOTE_MOD_START_PFN].data.num ) + if ( parms.mod_start_pfn ) { vinitrd_start = vinitrd_end = 0; vphysmap_start = round_pgup(vkern_end); diff --git a/xen/common/libelf/libelf-dominfo.c b/xen/common/libelf/libelf-dominfo.c index 3de1c23..31d8436 100644 --- a/xen/common/libelf/libelf-dominfo.c +++ b/xen/common/libelf/libelf-dominfo.c @@ -190,6 +190,9 @@ elf_errorstatus elf_xen_parse_note(struct elf_binary *elf, case XEN_ELFNOTE_INIT_P2M: parms->p2m_base = val; break; + case XEN_ELFNOTE_MOD_START_PFN: + parms->mod_start_pfn = !!val; + break; case XEN_ELFNOTE_PADDR_OFFSET: parms->elf_paddr_offset = val; break; diff --git a/xen/include/xen/libelf.h b/xen/include/xen/libelf.h index d7045f6..07b96a3 100644 --- a/xen/include/xen/libelf.h +++ b/xen/include/xen/libelf.h @@ -423,6 +423,7 @@ struct elf_dom_parms { char loader[16]; enum xen_pae_type pae; bool bsd_symtab; + bool mod_start_pfn; uint64_t virt_base; uint64_t virt_entry; uint64_t virt_hypercall; -- 2.1.4