Received: by 10.223.185.116 with SMTP id b49csp2251610wrg; Sat, 17 Feb 2018 16:26:03 -0800 (PST) X-Google-Smtp-Source: AH8x227y4WxpdZkbYeBTyrR1iNJnMMCw1MOYv9GZDcC4eEh5Nm9s3NUs6/IPRlV3THUBXwLzsc/O X-Received: by 2002:a17:902:6b87:: with SMTP id p7-v6mr10110647plk.9.1518913562917; Sat, 17 Feb 2018 16:26:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518913562; cv=none; d=google.com; s=arc-20160816; b=GKuNS3Myr391S9+1rt7xrUViMAdtLdAdYzbeQlMMSbThzuGM0E6WUeP3TKxsY6Wj7H Wn5cSOz9uchILtqZm4WURE+wyqqJ8veYsbLPXoS44JtNdKEbI+60DQ0QVtPXrqNYx5Md kAdhCEnroRF6pHXOG+2zmglGYWhiolPLIkWDBUvy4BQbL7hW5HVaYeixhz8XSRdzzHxS 8QEzsHBm/elmbG8ZzGI8N2Y35ihNpAWvzGurc/oZYQfamk2QN5Lj2KFmQJjCe/kkm7YY +I1lDRpDRnTnRLYx+gEg3/6xmvwWArd27m6AgAkE8B5QG9OVJ1Eb5QTRZ9mHCB9TVPOD PSUA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:from:cc:to:subject :content-transfer-encoding:mime-version:references:in-reply-to :user-agent:date:arc-authentication-results; bh=txgD73mdjXorraNIpDKOyb9MZOKjKcpjbL1f/Rj4h+Y=; b=aJHNGDewwZbqGXcxeBZTK45jQqMynYI0o2a/3RSBt3Ry0MxOWyWv9BkfSo2Ly1Id7s j0AujmLa5eXUUHyiRhmltJZ/yePu6Z6pu2oWUfZsVh9EU+KFgfYBLowLrHnu3tsc/9nk XAhnKH1kDOQubb8LNO74+yl2H5pWIdjOygDFYxY07yUKN/VLnFK+C/vByf/hwv9C4Znj OuUGQpBEB0v4zt2fvwALXB1Z+/3MH7ODphaZFZ6C+KySbMB80ubVMdss3c7BFugnHjnl GFquaK9ivga+lVGgxjST4ZkSuixCY2xFRYTeN5fHjWGS2VUl+iWik3ioqA4vayniQE0I smxw== 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 e5si3093460pgn.3.2018.02.17.16.25.48; Sat, 17 Feb 2018 16:26:02 -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 S1751259AbeBRAZE convert rfc822-to-8bit (ORCPT + 99 others); Sat, 17 Feb 2018 19:25:04 -0500 Received: from terminus.zytor.com ([198.137.202.136]:47921 "EHLO mail.zytor.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751083AbeBRAZC (ORCPT ); Sat, 17 Feb 2018 19:25:02 -0500 Received: from [IPv6:2607:fb90:a42c:be15:3116:547e:e9fe:bd33] ([172.58.32.125]) (authenticated bits=0) by mail.zytor.com (8.15.2/8.15.2) with ESMTPSA id w1I0OmIJ010764 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NO); Sat, 17 Feb 2018 16:24:48 -0800 Date: Sat, 17 Feb 2018 16:24:40 -0800 User-Agent: K-9 Mail for Android In-Reply-To: <1518912912.5667.277.camel@linux.vnet.ibm.com> References: <1518813234-5874-1-git-send-email-takondra@cisco.com> <1518813234-5874-2-git-send-email-takondra@cisco.com> <1518912912.5667.277.camel@linux.vnet.ibm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8BIT Subject: Re: [PATCH v3 01/15] Documentation: add newcx initramfs format description To: Mimi Zohar , Taras Kondratiuk , Al Viro , Arnd Bergmann , Rob Landley , Jonathan Corbet , James McMechan CC: initramfs@vger.kernel.org, Victor Kamensky , linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-security-module@vger.kernel.org, xe-linux-external@cisco.com From: hpa@zytor.com Message-ID: <80AFCC79-14B2-4CF2-A601-89B18764C9BC@zytor.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On February 17, 2018 4:15:12 PM PST, Mimi Zohar wrote: >On Fri, 2018-02-16 at 12:59 -0800, H. Peter Anvin wrote: >> On 02/16/18 12:33, Taras Kondratiuk wrote: >> > Many of the Linux security/integrity features are dependent on file >> > metadata, stored as extended attributes (xattrs), for making >decisions. >> > These features need to be initialized during initcall and enabled >as >> > early as possible for complete security coverage. >> > >> > Initramfs (tmpfs) supports xattrs, but newc CPIO archive format >does not >> > support including them into the archive. >> > >> > This patch describes "extended" newc format (newcx) that is based >on >> > newc and has following changes: >> > - extended attributes support >> > - increased size of filesize to support files >4GB >> > - increased mtime field size to have 64 bits of seconds and added a >> > field for nanoseconds >> > - removed unused checksum field >> > >> >> If you are going to implement a new, non-backwards-compatible format, >> you shouldn't replicate the mistakes of the current format. >Specifically: >> >> 1. The use of ASCII-encoded fixed-length numbers is an idiotic legacy >> from an era before there were any portable way of dealing with >numbers >> with prespecified endianness. If you are going to use ASCII, make >them >> delimited so that they don't have fixed limits, or just use binary. >> >> The cpio header isn't fixed size, so that argument goes away, in fact >> the only way to determine the end of the header is to scan forward. >> >> 2. Alignment sensitivity! Because there is no header length >> information, the above scan tells you where the header ends, but >there >> is padding before the data, and the size of that padding is only >defined >> by alignment. >> >> 3. Inband encoding of EOF: if you actually have a filename >"TRAILER!!!" >> you have problems. >> >> But first, before you define a whole new format for which no tools >exist >> (you will have to work with the maintainers of the GNU tools to add >> support) you should see how complex it would be to support the POSIX >> tar/pax format, which already has all the features you are seeking, >and >> by now is well-supported. > >The discussion about including xattrs in the initramfs didn't start >yesterday.  It's been on the list of measurement/appraisal gaps that >need to be closed for years.  Initially I planned on using tar, but at >the 2014 Kernel Summit I spoke with Al at length.  At the time, he was >very clear that tar is unnecessarily overly complicated and >recommended extending CPIO. > >I took his advice.  Unfortunately, as soon as I posted an initial >patch set to include xattrs in CPIO, all of the problems with CPIO had >to be addressed before defining a new CPIO number.  Unfortunately, >this wasn't the only measurement/appraisal gap that needed to be >addressed.  I've been working on closing other gaps. > >I'm really happy that someone has taken the time to work on this. > Instead of derailing their attempt of extending CPIO to include >xattrs, I'd appreciate your making constructive suggestions. > >Mimi I'm not trying to derail anything, but I do want to see it done well if it is going to be done. I have several ideas already, but I may not have a chance to write them down properly until after the weekend due to family obligations. The assessment of pax/tar is useful; it should be added to the patch documentation in a future set. -- Sent from my Android device with K-9 Mail. Please excuse my brevity.