Received: by 10.192.165.148 with SMTP id m20csp1432995imm; Sat, 21 Apr 2018 08:14:28 -0700 (PDT) X-Google-Smtp-Source: AIpwx49f/RO9yJTMraJs4qcK4QN04YFBU2ioOrrb7C5WRKLcGSkxQDq6ogg/0zVc/8r6iIvdHpIH X-Received: by 10.98.225.20 with SMTP id q20mr13394856pfh.142.1524323668020; Sat, 21 Apr 2018 08:14:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524323667; cv=none; d=google.com; s=arc-20160816; b=fCMbLXqCZmBRqCAbtiq/9mEqlYLjcS+BVIUQouQwMcfqQhuS61ZX/4lm8QDliIg6uk NSCdC1nUlVbMawgbYUjjhXglmhgWVN10RghJPD5y2vtCu6o6kGKz+MuyRtx3PC2oKgHr N11YT6JbphDRheiPUl6L1vteCngoBNzcpnokzWI38v+Nru0ORrxBeF8BmwFP5tx+cGG3 jG2Sw3gR9DE3QiG1ojw43ynEjfQWqUh36BbQrtD4x8fc37O+Ke2Gzw6rcdQpNBCKrRnq F8yZb+6kJo55mFWLh7Vc06xAZegQ/nIcmA5USw0DfVnKahWtjt98aNo2TWYlXI0vwZpq /65w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature:dkim-signature :arc-authentication-results; bh=YkNNVtlK4emrr49enc8cwC4sWfevxbi+yYuUasSKuFg=; b=h8mFxMtTkX0uG7qmtw6VrKtlW8lXCjaVwMcUfeMghNpWg6mVqa2jIKCHfK8RnSq0vp /efZQnScRTqT/GHxEoVvDqBgezukdyFPjiAngcO2HY0/WYMDmd4831l/Yy9748TZq7go rGg7XvPbzLB7jKVvZrljufH8drprMZroP9+WuxcWaPH6k2yk66t5J1a7kq3lPgTFJBsO JheGukgqpqUz3UwFtw7Nhd+BX6VUfMZ30z2j9j2uk90Q3EdO/R3punXw7q8LRXhhTsWn kiAcV04l2WHtHjFLZY7sbg3wLWH9XtHfYiaExze1A5fc/ab+A1yje4TSMA979mfEw4A1 /NhQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@google.com header.s=20161025 header.b=r1ym21/X; dkim=fail header.i=@chromium.org header.s=google header.b=CfaDqP7q; 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=fail (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id az11-v6si7477847plb.81.2018.04.21.08.13.50; Sat, 21 Apr 2018 08:14: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=fail header.i=@google.com header.s=20161025 header.b=r1ym21/X; dkim=fail header.i=@chromium.org header.s=google header.b=CfaDqP7q; 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=fail (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752924AbeDUPLI (ORCPT + 99 others); Sat, 21 Apr 2018 11:11:08 -0400 Received: from mail-ua0-f194.google.com ([209.85.217.194]:42080 "EHLO mail-ua0-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752350AbeDUPLG (ORCPT ); Sat, 21 Apr 2018 11:11:06 -0400 Received: by mail-ua0-f194.google.com with SMTP id f3so1971085uan.9 for ; Sat, 21 Apr 2018 08:11:06 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:sender:in-reply-to:references:from:date:message-id :subject:to:cc; bh=YkNNVtlK4emrr49enc8cwC4sWfevxbi+yYuUasSKuFg=; b=r1ym21/XMTRk0tXCIZKPuWNMVQTmC6h937iNS4vUhfJFyBP6t2XEuiZcNLjSAy1a0p H4fhvlFVvQsxsq13tTBSBSRhwbwZc3AVaayBKvNAgl6KojxvkJzoAqbs7/geQ3qiZqXc mbl+GS/WG6o1yYRHd2f0+wELb9wg4d+cGPkd3Ur+Fr007L+8fxvu4L8x0jSJPdx3avEV x5nFkUYfwIRXiJjXmJxlsO2txkP6aa+4820Unl1co/QEkWWtqXcY2b0a1IxWnFWRQDlL L19zqR6bzPuV9g8QEgyGFiQiKSKrXbx/fHw0IJF7asM7yPODGuafCDNwlpN3hu7Bm8Wo DCnA== DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=mime-version:sender:in-reply-to:references:from:date:message-id :subject:to:cc; bh=YkNNVtlK4emrr49enc8cwC4sWfevxbi+yYuUasSKuFg=; b=CfaDqP7q5tVXQ+dMmAqFiFMxISHd/POs9aDGA3vRHzVzzxnX3xsmFXkvR6RRBhiyKK CkBvDaWfpVkokJJo45lfhPfJda1QZnfAvu4543TMJkwXp4mP1QBwyZs6k/4cpEiALOSy uJLes47zOOQq/iRLZeEoOu/79bY6/d1DFEpjY= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:sender:in-reply-to:references:from :date:message-id:subject:to:cc; bh=YkNNVtlK4emrr49enc8cwC4sWfevxbi+yYuUasSKuFg=; b=YSW4yyvJvh3PdUGVHIVPoe082iR6TD8xqSjCRRbf9IshztH766/HMMqDnRzJ2w7I3h IqS94pBbbam0KrDiH7+yvVeiVrjJwxuMQF7ZuMkt+3cnDrVO84eOIQ7Ze/2DYgY9kBpn WRY2mdeSXcTTpQ4jiksDshB5TQKjgh1HRSPZRQNNGCumY3xuu1rAHDhWTdeUoeNbDLbz eIMa1af2YK7BIhTQ6dIhoMXOPc8jzKL7N88zuGervhCNBu9bQ4+56LX5WGOlPOne2VFv FwOe41+r+/q0Up2Tq04RNhpA9mKS6/ffgGhKSnosdPPODp2LoTlnOqWSUJg6RgJQ1Nyk dADA== X-Gm-Message-State: ALQs6tCnV/4nxd6hfk9/UHjyRq86tPPLh2QUFAls2SFZCrKha0L766gb 6rS8MiCVrPbvUk4fSA+1H2shopmF8Z6lGr8gV4EaOQ== X-Received: by 10.176.76.226 with SMTP id e34mr10988965uag.0.1524323465583; Sat, 21 Apr 2018 08:11:05 -0700 (PDT) MIME-Version: 1.0 Received: by 10.31.164.81 with HTTP; Sat, 21 Apr 2018 08:11:04 -0700 (PDT) In-Reply-To: <20180421144911.GV14440@wotan.suse.de> References: <20180417153307.3693-1-andresx7@gmail.com> <20180417153307.3693-6-andresx7@gmail.com> <20180421143206.GQ14440@wotan.suse.de> <20180421144911.GV14440@wotan.suse.de> From: Kees Cook Date: Sat, 21 Apr 2018 08:11:04 -0700 X-Google-Sender-Auth: zgP2zG_uOHrfUyOb-sJYM3lJ1Q8 Message-ID: Subject: Re: [PATCH 5/9] firmware: add functions to load firmware without warnings v4 To: "Luis R. Rodriguez" Cc: Andres Rodriguez , Greg Kroah-Hartman , Hans de Goede , Linus Torvalds , David Woodhouse , LKML , Alex Deucher , ckoenig.leichtzumerken@gmail.com, Kalle Valo , Arend van Spriel Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Apr 21, 2018 at 7:49 AM, Luis R. Rodriguez wrote: > On Sat, Apr 21, 2018 at 04:32:06PM +0200, Luis R. Rodriguez wrote: >> On Tue, Apr 17, 2018 at 11:33:03AM -0400, Andres Rodriguez wrote: >> > @@ -755,10 +779,11 @@ static void firmware_request_work_func(struct work_struct *work) >> > } >> > >> > /** >> > - * firmware_request_nowait() - asynchronous version of firmware_request >> > + * firmware_request_nowait2() - asynchronous version of firmware_request >> > * @module: module requesting the firmware >> > * @uevent: sends uevent to copy the firmware image if this flag >> > * is non-zero else the firmware copy must be done manually. >> > + * @warn: enable warnings >> > * @name: name of firmware file >> > * @device: device for which firmware is being loaded >> > * @gfp: allocation flags >> > @@ -778,8 +803,8 @@ static void firmware_request_work_func(struct work_struct *work) >> > * - can't sleep at all if @gfp is GFP_ATOMIC. >> > **/ >> > int >> > -firmware_request_nowait( >> > - struct module *module, bool uevent, >> > +firmware_request_nowait2( >> > + struct module *module, bool uevent, bool warn, >> > const char *name, struct device *device, gfp_t gfp, void *context, >> > void (*cont)(const struct firmware *fw, void *context)) >> > { >> > @@ -799,7 +824,8 @@ firmware_request_nowait( >> > fw_work->context = context; >> > fw_work->cont = cont; >> > fw_work->opt_flags = FW_OPT_NOWAIT | >> > - (uevent ? FW_OPT_UEVENT : FW_OPT_USERHELPER); >> > + (uevent ? FW_OPT_UEVENT : FW_OPT_USERHELPER) | >> > + (warn ? 0 : FW_OPT_NO_WARN); >> > >> > if (!uevent && fw_cache_is_setup(device, name)) { >> > kfree_const(fw_work->name); >> > @@ -818,6 +844,24 @@ firmware_request_nowait( >> > schedule_work(&fw_work->work); >> > return 0; >> > } >> > +EXPORT_SYMBOL_GPL(firmware_request_nowait2); >> > + >> > +/** >> > + * firmware_request_nowait() - compatibility version of firmware_request_nowait2 >> > + * >> > + * This is equivalent to calling firmware_request_nowait2 with warnings enabled. >> > + * >> > + * Refer to firmware_request_nowait2 for further details. >> > + **/ >> > +int >> > +firmware_request_nowait( >> > + struct module *module, bool uevent, >> > + const char *name, struct device *device, gfp_t gfp, void *context, >> > + void (*cont)(const struct firmware *fw, void *context)) >> > +{ >> > + return firmware_request_nowait2(module, uevent, true, name, device, >> > + gfp, context, cont); >> > +} >> > EXPORT_SYMBOL(firmware_request_nowait); >> > >> > #ifdef CONFIG_PM_SLEEP >> >> Ugh this is precisely the type of naming issue I predicted *years ago* >> about the unflexibility of the naming scheme we used. Greg, since you had >> sent us this rabbit hole, any name preference here? Please review what is >> proposed and also suggest a scheme which you do prefer. I'm done with >> the bikeshedding and just want to move on, but in a way that scales. > > I'll side for now with Kalle's suggestion of having: > > firmware_request_nowait_nowarn() > > as nasty as it may seem. And this is just because we embarked on > the path to not have parameters passed to modify the calls site. What was the objection to using parameters for this? i.e. something like the gfp flags, but have a behavior flag FW_RQ_NOWAIT, FW_RQ_NOWARN, etc? -Kees -- Kees Cook Pixel Security