From mboxrd@z Thu Jan 1 00:00:00 1970 Return-path: Received: from terminus.zytor.com ([2001:1868:205::10] helo=mail.zytor.com) by merlin.infradead.org with esmtps (Exim 4.76 #1 (Red Hat Linux)) id 1TbGPW-0000WB-RO for kexec@lists.infradead.org; Wed, 21 Nov 2012 19:56:39 +0000 Message-ID: <50AD31ED.3020202@zytor.com> Date: Wed, 21 Nov 2012 11:56:29 -0800 From: "H. Peter Anvin" MIME-Version: 1.0 Subject: Re: [PATCH v3 4/4] kexec, x86_64: Load bzImage64 above 4G References: <1353483098-14883-1-git-send-email-yinghai@kernel.org> <1353483098-14883-5-git-send-email-yinghai@kernel.org> <20121121143729.GC13114@redhat.com> In-Reply-To: List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: kexec-bounces@lists.infradead.org Errors-To: kexec-bounces+dwmw2=infradead.org@lists.infradead.org To: Yinghai Lu Cc: Haren Myneni , Simon Horman , kexec@lists.infradead.org, "Eric W. Biederman" , Vivek Goyal On 11/21/2012 11:54 AM, Yinghai Lu wrote: > On Wed, Nov 21, 2012 at 6:37 AM, Vivek Goyal wrote: >> On Tue, Nov 20, 2012 at 11:31:38PM -0800, Yinghai Lu wrote: >> >> [..] >>> + /* avoid cross GB boundary */ >>> + align = real_mode->kernel_alignment; >>> + addr = locate_hole(info, size, align, 0x100000, -1, -1); >>> + if (addr == ULONG_MAX) >>> + die("can not load bzImage64"); >>> + /* same GB ? */ >>> + while ((addr >> 30) != ((addr + size - 1) >> 30)) { >>> + addr = locate_hole(info, size, align, 0x100000, >>> + round_down(addr + size - 1, (1UL<<30)), -1); >>> + if (addr == ULONG_MAX) >>> + die("can not load bzImage64"); >>> + } >>> + dbgprintf("Found kernel buffer at %lx size %lx\n", addr, size); >> >> Where does this limitation of not loading kernel across GB boundary come >> from? > > in kernel arch/x86/kernel/head_64.S > > it only set first 1G ident mapping. and if it find that code is above > 1G, it will set extra ident mapping > for new _text.._end. > To make checking and add extra mapping simple and also save two extra > pages for mapping. > Limit that _text.._end in them same GB range. > No, this is backwards. We should fix that limitation instead. -hpa _______________________________________________ kexec mailing list kexec@lists.infradead.org http://lists.infradead.org/mailman/listinfo/kexec