Received: by 10.213.65.68 with SMTP id h4csp1841153imn; Thu, 5 Apr 2018 04:52:51 -0700 (PDT) X-Google-Smtp-Source: AIpwx48b6kGv+lEqD167s1ur6injwHbevRmbnEjBlnU9dAiEDtYfZHGc65KST6Tz5K2P5TcMljvp X-Received: by 2002:a17:902:b10c:: with SMTP id q12-v6mr22345680plr.399.1522929171030; Thu, 05 Apr 2018 04:52:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522929170; cv=none; d=google.com; s=arc-20160816; b=VPWNJ9Ri9ysMMHGlO/UvdvTp+07FvErWlcm0kgw7PwWrL6blgevwDIaHsw4N/x80Ss NwMozImHfKgMugrSxjU/4zv8N3NaD0YUk5zIaAwC/lf347N5b0LJAIpirJhuq+42Qvux fAOha/dJT7YlGsYwEHqtwEj+x9sOexh5/lgKfiWH46FnNHRdQljw/8WT6z/SV0faQ7Su /AjvbeGaEQqFfbe8uzy1jv5luUNLtENKgNVIeXJ3AE/cL0rsuQXeQCmmGnkPdbxv2F8f GYsXZRY3IEoA5ejwiahRLSdapcR+LsU3hLC+wfCEchpTJVr8HfAHM27G395kD03VVPTV y4qw== 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:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=bbaUvJKgBfwFsxHGlQqdojxB1GfqQmrQfZIboIwU8Z0=; b=m28T+hYXaTpulfqI4YUxpR3UvvsW6JR7fbGD85Q06Uuze8FA8emA/cj6xrI0lBqfdc 689N/hd4Pk+wcubuyxsZIdb3alB3XSEiqUq4umDQZj8HQF3e77FspviERDiljTtuEcId PnHtmk1fWmUjo0xPk0Y80mDfli8cx7e6Nuj+5i5ndCO5qhNhwJO8E1z7AClhOT+TdFBC B0USm642YRJy28JUju9h5j34QzQ1BMyxXKEe7mv4xDgY5iyPRZu68JeM6/V8lS7/k81f 2kLFpc/nXamhdozxXLgYRX3VufbOeIXcbH0jTQ1qjQU3gE9dmvYTI2ICLg2+uB+Az1HF FNqA== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m1si5308493pgm.413.2018.04.05.04.52.36; Thu, 05 Apr 2018 04:52:50 -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; 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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751525AbeDELvc (ORCPT + 99 others); Thu, 5 Apr 2018 07:51:32 -0400 Received: from mail-wm0-f42.google.com ([74.125.82.42]:37971 "EHLO mail-wm0-f42.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751262AbeDELva (ORCPT ); Thu, 5 Apr 2018 07:51:30 -0400 Received: by mail-wm0-f42.google.com with SMTP id i3so6213667wmf.3 for ; Thu, 05 Apr 2018 04:51:30 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=bbaUvJKgBfwFsxHGlQqdojxB1GfqQmrQfZIboIwU8Z0=; b=Y4Wio9k2BczcHaYPzRtYGB+jv+yCbGoX2YwEGkWqi/dNPa6GwGrybCRmKRdnrrOLKw qvek6cAShQKoUE5iVQO2suOoLvhmMNzpDz/pCjKk4AVOjuCY05qcctA0hyl7iBVUOQjE TEnj9z9hYEUQ1E9JiL+faCwGzNJiTLbA+uQXwCHWWdbAAAsLnwqyxyPeGglntlHwRxjE KxQFozduHUe9w2zAg+E8fu+TjRFGJXZSQCVJruIRIkLfT+QUoC3zDiSy0pM1na1ALPQr /Zi/w/KQ7U7gYF4Rj9EM6yJfr1OCyt1MilYI4wXKtm+pjqf5cv8gsaChBRiDayvqTx+w Wo+Q== X-Gm-Message-State: ALQs6tAd6r/JIjrZjZzr7363rxDPw/AOEAzCAqBVvGEuTIjIIuiyO21I jsO3N90ul+ZCQwH1MaT835hM2A== X-Received: by 10.80.241.6 with SMTP id w6mr2636244edl.62.1522929089391; Thu, 05 Apr 2018 04:51:29 -0700 (PDT) Received: from shalem.localdomain (546A5441.cm-12-3b.dynamic.ziggo.nl. [84.106.84.65]) by smtp.gmail.com with ESMTPSA id n30sm4967641edd.45.2018.04.05.04.51.28 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 05 Apr 2018 04:51:28 -0700 (PDT) Subject: Re: [PATCH 2/2] efi: Add embedded peripheral firmware support To: Peter Jones Cc: Ard Biesheuvel , "Luis R . Rodriguez" , Greg Kroah-Hartman , Thomas Gleixner , Ingo Molnar , "H . Peter Anvin" , linux-kernel@vger.kernel.org, Dave Olsthoorn , x86@kernel.org, linux-efi@vger.kernel.org References: <20180331121944.8618-1-hdegoede@redhat.com> <20180331121944.8618-2-hdegoede@redhat.com> <20180403195332.tezh6alee26aic2s@redhat.com> From: Hans de Goede Message-ID: Date: Thu, 5 Apr 2018 13:51:28 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: <20180403195332.tezh6alee26aic2s@redhat.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On 03-04-18 21:53, Peter Jones wrote: > On Sat, Mar 31, 2018 at 02:19:44PM +0200, Hans de Goede wrote: >> diff --git a/drivers/firmware/efi/efi.c b/drivers/firmware/efi/efi.c >> index fddc5f706fd2..1a5ea950f58f 100644 >> --- a/drivers/firmware/efi/efi.c >> +++ b/drivers/firmware/efi/efi.c >> @@ -455,6 +455,7 @@ int __init efi_mem_desc_lookup(u64 phys_addr, efi_memory_desc_t *out_md) >> u64 end; >> >> if (!(md->attribute & EFI_MEMORY_RUNTIME) && >> + md->type != EFI_BOOT_SERVICES_CODE && >> md->type != EFI_BOOT_SERVICES_DATA && >> md->type != EFI_RUNTIME_SERVICES_DATA) { >> continue; > > Might be worth adding a comment here to ensure nobody comes along later > and adds something like EFI_BOOT_LOADER_DATA or other stuff that's > allocated later here. I don't want to accidentally patch our way into > having the ability to stumble across a firmware blob somebody dumped > into the middle of a grub config file, especially since you only need to > collide crc32 (within the same length) to pre-alias a match. As discussed elsewhere in the thread, I'm going to switch to doing a kmemdup on the found firmware, so this chunk will go away :) > > ... >> +static int __init efi_check_md_for_embedded_firmware( >> + efi_memory_desc_t *md, const struct embedded_fw_desc *desc) >> +{ > ... >> + if (found_fw_count >= MAX_EMBEDDED_FIRMWARES) { >> + pr_err("Error already have %d embedded firmwares\n", >> + MAX_EMBEDDED_FIRMWARES); >> + return -ENOSPC; >> + } > > Doesn't seem like this needs to be pr_err(); after all we have already > found a valid match, so the firmware vendor has done something > moderately stupid, but we have a firmware that will probably work. Of > course it still needs to return != 0, but pr_warn() or even pr_info() > seems more reasonable. We break from the search loop as soon as a firmware is found, this can only trigger if someone adds a second firmware to the dmi data and then does not update MAX_EMBEDDED_FIRMWARES... But mcgrof wants me to switch to a linked list here, so this is going away too. > Aside from those nits, looks good to me. > > Reviewed-by: Peter Jones Thanks, but v2 is going to have so much changes that I don't feel comfortable bringing this forward to v2. Regards, Hans