Received: by 10.213.65.16 with SMTP id m16csp76097imf; Sun, 11 Mar 2018 16:19:27 -0700 (PDT) X-Google-Smtp-Source: AG47ELvvDYX2xgq3O5M+PaNPFHCJzaECCyfsU0977UmSHX/3eoMZg7HeLx3QHEPNNbDyew4+I8QT X-Received: by 10.99.67.1 with SMTP id q1mr4934534pga.365.1520810367862; Sun, 11 Mar 2018 16:19:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1520810367; cv=none; d=google.com; s=arc-20160816; b=T3L6iCWwmeN9UlJsTBK0TMy11lQ4dbS8MmsFju0o6l2DSZL+Cqg/tWfidd44gJzLML NaE46zZ6riOJolGDIxOIkejab3yTQ01ZArAijQNPX7aWW4oPnStTGdua05GkkEaYOi09 ajxrUNIn8nnL7A4PWxW4XAmNqCW+Lb2blIjFea7HN2yBMZvZ7xd/o97FBbAQMPfMvpx3 FWp0mneWqIVly8EDc6s3ImHi9EbUIk9xfH3OvwZW20vYgxR2TTu3GCO4qY+ioWmUCPIH JTZEsp+Xsj4XcXjmeniScdatrBg0qMgnk09WJsoHq969kR5NNDFrFPU8B6uFnxY7hDl9 WAng== 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:in-reply-to :mime-version:user-agent:date:message-id:from:cc:references:to :subject:dkim-signature:arc-authentication-results; bh=AA0fGKndCD23g0aF1N6HA20DXD0xMoEKkPNcS/rceXg=; b=NpvKWOo9rzZlevTdhZyux3RMFPq4JIy2zAnfgoS+0j3dRgvF10Z9R0UOX0vdwkPVii 3ZliFFBpvj9ZGgIMyYNxW/yhzFQwoBUmPpSjaoHf3LZhF8Ds0GTUu+HQSd+IPi8nqGfM SLKBtnTiL6t4NqMGonw3v4aWaXfByCdSOIDkOZmcB5CjFeD0MchptSsxpV7w2UKpwEZ0 h0pt5OKOa7kFYFf8owVmcKnO5AmbjU/g4HD9GM7nvSKwXp4ozVr0+yLiu7jM4IiPzP3g IuVJ/SxTgr8Y1aPM8gL0tcgVkj1rHmkjw64BufQdR/g/r6RZWEvgGFI+dHL9JZD5XQly 6bVQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@broadcom.com header.s=google header.b=dGwnP8rh; 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; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d16-v6si3374293pli.557.2018.03.11.16.19.13; Sun, 11 Mar 2018 16:19:27 -0700 (PDT) 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; dkim=pass header.i=@broadcom.com header.s=google header.b=dGwnP8rh; 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; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=broadcom.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932396AbeCKXSY (ORCPT + 99 others); Sun, 11 Mar 2018 19:18:24 -0400 Received: from mail-wm0-f68.google.com ([74.125.82.68]:51826 "EHLO mail-wm0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932284AbeCKXSX (ORCPT ); Sun, 11 Mar 2018 19:18:23 -0400 Received: by mail-wm0-f68.google.com with SMTP id h21so13065008wmd.1 for ; Sun, 11 Mar 2018 16:18:22 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=broadcom.com; s=google; h=subject:to:references:cc:from:message-id:date:user-agent :mime-version:in-reply-to:content-transfer-encoding; bh=AA0fGKndCD23g0aF1N6HA20DXD0xMoEKkPNcS/rceXg=; b=dGwnP8rhFoUzsrX/fxPwVbGz0/yM9nh5WHe8urb0SW0tR8oat870N5zrmS3t+k6xRy pLY/76aVIkx4YcOfK9m8yU7q0YQU6ppPmHxSo1j/GePbAv95e32MrfvFtmCEv5Yhtli6 lqNDGrn5AFaWwSaPt+oe8RCDsXt85pupYmm4o= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:references:cc:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding; bh=AA0fGKndCD23g0aF1N6HA20DXD0xMoEKkPNcS/rceXg=; b=pCRG5Miza9V3K6sf5gCy57L3p5TOrQ/PdK5EFEMEwHRFdSdSi1XCd86Pxxsilgrr32 MXoK08rUHOFOREnWt0MGzE7vGXYZwccdP4SMs56jo3DbdMPZ1IWHVQhmyslIzWMgU2TZ tt+V13F9wiEID73bCRi0kbWrQHTHLHkBh761pFzPFjDcLaYhk5IakM2DFgpNm3wKcrAa UPRPZJy1BTaTKvFig1vnPy1vmxB8GB887A/w/muX7uZBWl7+qbEIj0tBoV3kpSOoKEHF xnniL+yHGNsdN9geUVaqvp1VUQZyg4PVAfny2lTvjbyerYaZ/rYk7tFK0D6+CRwpeAF4 4+VQ== X-Gm-Message-State: AElRT7GAEIrR+OiweKn1MTJmblbhNf0Iq4t1NYdS0YU4LqwGraKTSvXz 1+NTGPGBGW6qwY/hAksE9rc0YQ== X-Received: by 10.80.144.5 with SMTP id b5mr8238717eda.118.1520810302168; Sun, 11 Mar 2018 16:18:22 -0700 (PDT) Received: from [192.168.178.129] (f140230.upc-f.chello.nl. [80.56.140.230]) by smtp.gmail.com with ESMTPSA id g54sm4154576edc.76.2018.03.11.16.18.21 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Sun, 11 Mar 2018 16:18:21 -0700 (PDT) Subject: Re: [PATCH] firmware: add a function to load optional firmware v2 To: Andres Rodriguez , linux-kernel@vger.kernel.org References: <20180309221243.15489-2-andresx7@gmail.com> <20180309230925.3573-1-andresx7@gmail.com> Cc: gregkh@linuxfoundation.org, mcgrof@kernel.org From: Arend van Spriel Message-ID: <5AA5B93E.2060905@broadcom.com> Date: Mon, 12 Mar 2018 00:18:22 +0100 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:38.0) Gecko/20100101 Thunderbird/38.5.0 MIME-Version: 1.0 In-Reply-To: <20180309230925.3573-1-andresx7@gmail.com> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 3/10/2018 12:09 AM, Andres Rodriguez wrote: > Currently the firmware loader only exposes one silent path for querying > optional firmware, and that is request_firmware_direct(). This function > also disables the usermodehelper fallback which might not always be the > desired behaviour. > > This patch introduces request_firmware_optional(), which will not > produce error/warning messages if the firmware file is not found, but > will still attempt to query the usermodehelper for the optional > firmware. Effectively, FW_OPT_UEVENT | FW_OPT_FALLBACK | FW_OPT_NO_WARN. > > v2: add header prototype, use updated opt_flags > > Signed-off-by: Andres Rodriguez > --- > > Sorry, I messed up the v1 patch and sent the wrong one from before I > rebased. > > drivers/base/firmware_class.c | 26 +++++++++++++++++++++++++- > include/linux/firmware.h | 2 ++ > 2 files changed, 27 insertions(+), 1 deletion(-) > > diff --git a/drivers/base/firmware_class.c b/drivers/base/firmware_class.c > index 7dd36ace6152..4e1eddea241b 100644 > --- a/drivers/base/firmware_class.c > +++ b/drivers/base/firmware_class.c > @@ -1181,7 +1181,7 @@ static int fw_sysfs_fallback(struct firmware *fw, const char *name, > if (!fw_run_sysfs_fallback(opt_flags)) > return ret; > > - dev_warn(device, "Falling back to user helper\n"); > + dev_warn(device, "Falling back to user helper for %s\n", name); Helpful, but not really related to this change. > return fw_load_from_user_helper(fw, name, device, opt_flags); > } > #else /* CONFIG_FW_LOADER_USER_HELPER */ > @@ -1351,6 +1351,30 @@ request_firmware(const struct firmware **firmware_p, const char *name, > } > EXPORT_SYMBOL(request_firmware); > > +/** > + * request_firmware_optional: - request for an optional fw module > + * @firmware_p: pointer to firmware image > + * @name: name of firmware file > + * @device: device for which firmware is being loaded > + * > + * This function is similar in behaviour to request_firmware(), except > + * it doesn't produce warning messages when the file is not found. > + **/ > +int > +request_firmware_optional(const struct firmware **firmware_p, const char *name, > + struct device *device) So it still returns an error code. If it were truly optional I kinda expected a void return type. This is more request_firmware_silent(). Anyway, I guess Luis would call this bike-shedding ;-) Regards, Arend