Received: by 2002:a25:ca44:0:0:0:0:0 with SMTP id a65csp878283ybg; Tue, 28 Jul 2020 23:23:16 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx12ya4/UoifaJiM0I+orD6ttD4m6R4Y8aOu7qJUQ+UtOK25lotf83vR5or3nlkcpUccXE+ X-Received: by 2002:a50:a6da:: with SMTP id f26mr19296026edc.4.1596003796745; Tue, 28 Jul 2020 23:23:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1596003796; cv=none; d=google.com; s=arc-20160816; b=FNo+UqnkpSwS7p8ZlMXyyE5HK1Q//1xBra8uszUomIjW0dxutsr/g5SWIjzu498klm A9DToz6XYKHaAeMR2V0djlygoBy6RNq7BMxIR1QWUYkA736B8Qo8sINNi/ycUYMvE/Y+ ASPL+0rdjNlZpKxMxBmjGEyhzB0nDC22TXTloz5F9Q6RKYyJgZB6cORd7Uf5H3XvmFrJ 8IxoM4joNn5T39cieUsE4/TbKKGDUfmZXMpmyNdQcADzDRUHXF+8Yje8xD2udL4GVlP7 POkDXiFH2syAbcnyg+8sQKUQLGulkinMcEmayWnJB9HTBtcMv0z+xNsUaq+90mqbS92H xG1g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:subject:cc:to:from:message-id:date; bh=PJT6VEBc1jL803zU2DjwT84jqXdTBQMttwByXjow0eY=; b=DKJr10N4HuK+CWy406aUQ35SIB4/oGTrTOBH2AhSKKESpuyVv0t0FHde8NsDSouahI YGDRbp2FXZzDbiiDzaIE/jflHUu3YqP58MRPxsIy3xiH1zNJC+Xv0VyANbypI950dMtd CT31e4lkwlNERYZGeY5pChcYgfpf7NLyIbzNUJHZAA5VAh5j8gsgIvupZjfFWD0FQ0Sd iZiQ/501qqyw5kh7r6L4SeLJ5ejxhCF5GvSj3gAuWmUgkyz+XczxTFN7wqcd8ni4eTtq fjw9IOsafIImQyziMfq5I5dKBbkpnP3lvhbSWY6Hoxj/VeNZlz3l1njRPi789vwgesIV dQWw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i23si724757eds.82.2020.07.28.23.22.54; Tue, 28 Jul 2020 23:23:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726967AbgG2GWT (ORCPT + 99 others); Wed, 29 Jul 2020 02:22:19 -0400 Received: from mx2.suse.de ([195.135.220.15]:53878 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726290AbgG2GWT (ORCPT ); Wed, 29 Jul 2020 02:22:19 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 9D71AAB3D; Wed, 29 Jul 2020 06:22:28 +0000 (UTC) Date: Wed, 29 Jul 2020 08:22:17 +0200 Message-ID: From: Takashi Iwai To: Luis Chamberlain Cc: Kees Cook , Greg Kroah-Hartman , Scott Branden , Mimi Zohar , Jessica Yu , SeongJae Park , KP Singh , linux-efi@vger.kernel.org, linux-security-module@vger.kernel.org, linux-integrity@vger.kernel.org, selinux@vger.kernel.org, linux-kselftest@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v3 18/19] firmware: Add request_partial_firmware_into_buf() In-Reply-To: <20200729011739.GL4332@42.do-not-panic.com> References: <20200724213640.389191-1-keescook@chromium.org> <20200724213640.389191-19-keescook@chromium.org> <20200729011739.GL4332@42.do-not-panic.com> User-Agent: Wanderlust/2.15.9 (Almost Unreal) SEMI/1.14.6 (Maruoka) FLIM/1.14.9 (=?UTF-8?B?R29qxY0=?=) APEL/10.8 Emacs/25.3 (x86_64-suse-linux-gnu) MULE/6.0 (HANACHIRUSATO) MIME-Version: 1.0 (generated by SEMI 1.14.6 - "Maruoka") Content-Type: text/plain; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 29 Jul 2020 03:17:39 +0200, Luis Chamberlain wrote: > > Long ago Takashi had some points about this strategy breaking > compressed file use. Was that considered? As long as I read the patch, it tries to skip both the compressed and the fallback loading when FW_OPT_PARTIAL is set, which is good. However... > > @@ -771,18 +805,20 @@ _request_firmware(const struct firmware **firmware_p, const char *name, > > } > > > > ret = _request_firmware_prepare(&fw, name, device, buf, size, > > - opt_flags); > > + offset, opt_flags); > > if (ret <= 0) /* error or already assigned */ > > goto out; > > > > ret = fw_get_filesystem_firmware(device, fw->priv, "", NULL); > > -#ifdef CONFIG_FW_LOADER_COMPRESS > > - if (ret == -ENOENT) > > + > > + /* Only full reads can support decompression, platform, and sysfs. */ > > + if (!(opt_flags & FW_OPT_PARTIAL)) > > + nondirect = true; > > + > > + if (ret == -ENOENT && nondirect) > > ret = fw_get_filesystem_firmware(device, fw->priv, ".xz", > > fw_decompress_xz); > > -#endif ... by dropping this ifdef, the fw loader would try to access *.xz file unnecessarily even if CONFIG_FW_LOADER_COMPRESS is disabled. thanks, Takashi