From mboxrd@z Thu Jan 1 00:00:00 1970 Return-path: Received: from kirsty.vergenet.net ([202.4.237.240]) by bombadil.infradead.org with esmtp (Exim 4.80.1 #2 (Red Hat Linux)) id 1ZXnZV-0006rH-5l for kexec@lists.infradead.org; Fri, 04 Sep 2015 09:46:13 +0000 Date: Fri, 4 Sep 2015 18:45:44 +0900 From: Simon Horman Subject: Re: [RFC PATCH] kexec: use mmap instead of read for slurp_file() Message-ID: <20150904094541.GA30724@verge.net.au> References: <1439914643-26484-1-git-send-email-holzheu@linux.vnet.ibm.com> <20150902010721.GE30886@verge.net.au> <20150902104839.17674456@holzheu> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <20150902104839.17674456@holzheu> 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" Errors-To: kexec-bounces+dwmw2=infradead.org@lists.infradead.org To: Michael Holzheu Cc: kexec@lists.infradead.org, stefan.roscher@de.ibm.com On Wed, Sep 02, 2015 at 10:48:39AM +0200, Michael Holzheu wrote: > On Wed, 2 Sep 2015 10:07:21 +0900 > Simon Horman wrote: > [snip] > > > The slurp_fd() function allocates memory and uses the read() system call. > > > This results in double memory consumption for image and initrd: > > > > > > 1) Memory allocated in user space by the kexec tool > > > 2) Memory allocated in kernel by the kexec() system call > > > > > > Therefore use mmap() for non-character devices to reduce the memory > > > consumption of the kexec tool. > > > > I'm not opposed to this change but I also don't see a strong motivation for > > it. I would imagine that the memory saving is not that large. And that the > > memory consumption disappears when the presumably short-lived kexec process > > exits. > > Correct it will disappear. > > The reason for the the patch is that we have the following scanario: > > 1) Boot a 4 GB Linux system > 2) Read kernel and 1,5 GB ramdisk from external source into local tmpfs (ram) > 3) kexec the kernel and ramdisk > > So without the mmap patch for the kexec runtime we need: > > 1,5 GB (tmpfs) + 1,5 GB (kexec malloc) + 1,5 GB (kernel memory) = 4,5 GB > > If we use mmap we only need 3 GB memory. Thanks, I am convinced. Could you repost the patch as a non-RFC? _______________________________________________ kexec mailing list kexec@lists.infradead.org http://lists.infradead.org/mailman/listinfo/kexec