Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp2341055imj; Mon, 11 Feb 2019 00:50:48 -0800 (PST) X-Google-Smtp-Source: AHgI3IbIEcrpM5eptiZ9JnGAVy9MvLf+6WfXry30c1V1vTXV0PJMucjjVjJ2B8GZt61QT8FuF+jK X-Received: by 2002:a62:190e:: with SMTP id 14mr35593287pfz.70.1549875048138; Mon, 11 Feb 2019 00:50:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549875048; cv=none; d=google.com; s=arc-20160816; b=Y60SYW5brzXrkxYbAQmCZDKGUufRTulPl/4hb3evO9f9vPEk0TQ8mMAP/DgHMyyGJn oBqsLnOyLKVYkR1h+LG7kSWKEyh4sRkKKZgIrv6iG1ww+55LnhKUNXlTYTcH8yEUEqJ1 29fgxhPp1qFXIgmHeAJO/QLZp6GUZMVBRUiKSOdQcG9SJcrYf6i+FRBJ5+OELbM1pYxc sVbsasmweL5cIPp4KSV5eIIdtmZUD4z1JjtKRLU0lsorp3d7MzX3ixAp8bVpgbdinUKt vhOr2SFmvwPuKJ85HcY7GmUWxWxn3R0wFpAv17njVnEiY1pfbBmcUcXXBtPW007EPrVF Dk2A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:date:message-id :references:cc:to:from:subject; bh=yYEIoIPktfAVgkfjPhTaEFGjjMfFApW7VuAVDcb0RBc=; b=aOjqXwn8ooZWpNVEx1nCnSF0pWf/hjI++aCtDLz2/btTG/GLssX62lWqzfWWvogNhf Sngl2hx6LCHffPYNxc5Hq1di8kBgVGHbFeD3Bvx8Qd6aDyxcFDdlWXPlwespXGOQ+xh4 +5pUZK3Z1ZT+J+vfwNGsvE7eYZb3N4drWAk09M1ZZmr8Dbv0ChFJiVyFAj2q4SfO7GuE flxVK4IcZnGB1D0Ll7Z+kSiatkpwi30YoVUeM7fGx7OI1TPJL4qLUi2gKbXzdurppH9w HwoQmhwpGTGTarC0lW1iykX7u9KfUOOTagN5XAB/f7dPiBRtsOoRrnNsIXqMmtXb5QA8 9Zpw== 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 c132si9211336pga.597.2019.02.11.00.50.31; Mon, 11 Feb 2019 00:50:48 -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 S1727139AbfBKItz (ORCPT + 99 others); Mon, 11 Feb 2019 03:49:55 -0500 Received: from mail.sysgo.com ([176.9.12.79]:58696 "EHLO mail.sysgo.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726363AbfBKItz (ORCPT ); Mon, 11 Feb 2019 03:49:55 -0500 Subject: Re: [PATCH RESEND] initramfs: cleanup incomplete rootfs From: David Engraf To: Andy Shevchenko , Andrew Morton Cc: Dominik Brodowski , Greg Kroah-Hartman , Philippe Ombredanne , Arnd Bergmann , Luc Van Oostenryck , Linux Kernel Mailing List References: <20181022134048.19693-1-david.engraf@sysgo.com> <20181030151805.5519-1-david.engraf@sysgo.com> <20190208140810.76ef6c25825a5644d9625f0a@linux-foundation.org> <744e7bcb-9315-0283-67c5-c2cb2d094251@sysgo.com> Message-ID: <28139206-7fed-e00e-8f52-47e68655963d@sysgo.com> Date: Mon, 11 Feb 2019 09:49:51 +0100 MIME-Version: 1.0 In-Reply-To: <744e7bcb-9315-0283-67c5-c2cb2d094251@sysgo.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11.02.19 at 08:56, David Engraf wrote: > On 09.02.19 at 11:35, Andy Shevchenko wrote: >> On Sat, Feb 9, 2019 at 12:08 AM Andrew Morton >> wrote: >>> On Fri, 8 Feb 2019 21:45:21 +0200 Andy Shevchenko >>> wrote: >>>> On Tue, Oct 30, 2018 at 5:22 PM David Engraf >>>> wrote: >>>>> >>>>> Unpacking an external initrd may fail e.g. not enough memory. This >>>>> leads >>>>> to an incomplete rootfs because some files might be extracted already. >>>>> Fixed by cleaning the rootfs so the kernel is not using an incomplete >>>>> rootfs. >>>> >>>> This breaks my setup where I have U-boot provided more size of >>>> initramfs than needed. This allows a bit of flexibility to increase or >>>> decrease initramfs compressed image without taking care of bootloader. >>>> The proper solution is to do this if we sure that we didn't get enough >>>> memory, otherwise I can't consider the error fatal to clean up rootfs. >>> >>> OK, thanks.  Maybe David can suggest a fix - I'll queue up a revert >>> meanwhile. >>> >>> I don't really understand the failure.  Why does an oversized initramfs >>> cause unpack_to_rootfs() to fail? >> >> In my case I have got "Junk in compressed archive". I don't know (I >> would check if needed) which exact condition I got  since there are >> three places with this message. The file itself smaller than the size >> passed through bootparam. So, when decomression is finished >> (successfully!) we still have a garbarge in the memory which is not >> related to archive. Message per se is okay to have, though I consider >> this non-fatal. > > I can reproduce this special case. The unpacking decompresses the whole > size instead of checking the archive size. I will have a look how to get > the real archive size. I did some checks and manually increased the initramfs size but I always get the following kernel panic: Kernel panic - not syncing: junk in compressed archive ---[ end Kernel panic - not syncing: junk in compressed archive The panic was not introduced by my patch. Could you please check if you get a panic as well or is your rootfs just empty? I also had a look at the decompression in unpack_to_rootfs(). This function already ensures unpacking only the real size of the archive. But it is called in a loop, thus it unpacks the first archive and then tries to unpack the reset of the data which are garbage in my case. Is it intended to allow extracting multiple archives as rootfs? If not we could remove the loop and unpack only the first archive. Otherwise we could ignore errors when the first archive was extracted without errors. Best regards - David