Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp766670ybl; Thu, 12 Dec 2019 04:40:06 -0800 (PST) X-Google-Smtp-Source: APXvYqygdjp7HDMfL2/SyMorMYAfVbK5UzU/zcKJULkGZxvhXa1iCi3/vgw0kkIWuyjDbJgZe46p X-Received: by 2002:a9d:7f12:: with SMTP id j18mr8180255otq.17.1576154405926; Thu, 12 Dec 2019 04:40:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1576154405; cv=none; d=google.com; s=arc-20160816; b=B01nVhbDj9r96fRuAyFhuPy/Kg0qcqnVG8OMn0Kf0fRtmDX3hfOMtx4nSoVHgEfO7y WxswwxzkIE3xLnp+MWAlImzwoizKjhTaS/PVVWKd+MyULfV66pojE8A6ztbPyeXu3sfv i/ZNyPTckvaVxPEM783XMCBFUSykK5p4cNeCg7GOMSqcYuKxo6yIx6RRCwklhJc++/e+ LwRFijnn0bZwf3WYfciQwXPS53h+iiWPPd6f3ICaKlKgRbt+pIlstcwuWO9tZtkGQr0O R0ftphx7iNRSIJsZuqa3QudyrgItdbnO9eDIo1Z/kSuMvCF9k2Ol+q6q/aAW+0Gjz/xw mr0w== 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:dkim-signature; bh=HjG13pQnC6z3lipnj2OvOm4bGvR+32WxaKc1DUtleSc=; b=L65bzbhaIEpMyRUCcpikxMjFPcEeVuJO4AQQRnY7DvK8yNwCYe36e4SoG2ROL2yl5U 6YL5G8VSFnUozHe6QQlb+f3CRY/6W3U1mVj72TFkSkHSkruvabdW2evJGwnfKR+Ynk8X e3H8yxP4jLZmw1ptfe+tOlMyvwWZvrkuwxTHpeofALOv9SZMA8fvzctkelWdjibuO165 gpxR9NiQ7BYFWHZ3jTW6+/SD7B/ZmtpYEnTV+UfAL5qi3hiu23X8CoUiLki+tTtPLEv/ D2rq0IbxBeB57pXIyekQrLnJj4OdurHzU/bzrndbkihzrJV7qZDQPgOHl1sZLEwqT8bJ xvWw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=O9o4h16D; 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=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 g7si3154219otq.28.2019.12.12.04.39.51; Thu, 12 Dec 2019 04:40:05 -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; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=O9o4h16D; 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=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729263AbfLLMiq (ORCPT + 99 others); Thu, 12 Dec 2019 07:38:46 -0500 Received: from us-smtp-1.mimecast.com ([205.139.110.61]:28111 "EHLO us-smtp-delivery-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1729092AbfLLMiq (ORCPT ); Thu, 12 Dec 2019 07:38:46 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1576154324; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=HjG13pQnC6z3lipnj2OvOm4bGvR+32WxaKc1DUtleSc=; b=O9o4h16DubQc8yT7OjnZbMOS4BPZAUsk2fEdMLTmfPdECdTfr+tnDbiLa1XoDM65y1mkD9 GL6SYLRC79106CrATCQJe12MNKoAbxco5yP01XGaCTKrzpbYXyeKLFuqeVygMQnNWiSi8E 1EdP9lThpA0gyHG00gClSMNabQLt+MM= Received: from mail-wr1-f70.google.com (mail-wr1-f70.google.com [209.85.221.70]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-74-N9zt1eF6ND-eaFJKNOkRlQ-1; Thu, 12 Dec 2019 07:38:43 -0500 X-MC-Unique: N9zt1eF6ND-eaFJKNOkRlQ-1 Received: by mail-wr1-f70.google.com with SMTP id o6so974035wrp.8 for ; Thu, 12 Dec 2019 04:38:43 -0800 (PST) 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=HjG13pQnC6z3lipnj2OvOm4bGvR+32WxaKc1DUtleSc=; b=gMeg873wPRIgM42fkO0P7QPYnSK+f0o1xspPay9fbuKHWHyawEvaN3WqttPl6XaJ9o v23JPyyFhMERvedS11FhrwXQr6nlqeySvp8ozL6INlWzCn7h0FcdBNSFnUKrLDreRngW dDz7l0N57Gm+eJnbNHHSCgV/c2KgZOojw3EggZPsLYJ8wGkAd+WMeekQNymxCxjjfUnf GNJuT8KBel4m154kUOi8gYTfmqG6sNY7RQSwxrOntuT/h3KXCk7I6C0r75CMKu8yHl6N LB8QGLEX2McVs2/YVEIgBwPs5YcHQG2Zus7uPFh7HDCvdug3lPH9/o41dz/EYjckcTtR dUfg== X-Gm-Message-State: APjAAAXE9C6d/bFSzvHfdEgyJh9xvOT2TxyKkaDzJZ9de2TWXFKk/kJ2 IMf3cMxLS4BDCD0ANM49IKwYxsYeINNu2tWbktGGSVAA91mxDcH633zonC+DbB81FVokYmflqoW yLUVfEMww/2seOWxAJB3bHuIn X-Received: by 2002:a7b:c8d4:: with SMTP id f20mr6672466wml.56.1576154321536; Thu, 12 Dec 2019 04:38:41 -0800 (PST) X-Received: by 2002:a7b:c8d4:: with SMTP id f20mr6672437wml.56.1576154321316; Thu, 12 Dec 2019 04:38:41 -0800 (PST) Received: from shalem.localdomain (2001-1c00-0c0c-fe00-7e79-4dac-39d0-9c14.cable.dynamic.v6.ziggo.nl. [2001:1c00:c0c:fe00:7e79:4dac:39d0:9c14]) by smtp.gmail.com with ESMTPSA id x6sm6440761wmi.44.2019.12.12.04.38.40 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 12 Dec 2019 04:38:40 -0800 (PST) Subject: Re: [PATCH 5.5 regression fix 2/2] efi/libstub/helper: Initialize pointer variables to zero for mixed mode To: Ard Biesheuvel Cc: Thomas Gleixner , Dominik Brodowski , the arch/x86 maintainers , linux-efi , Linux Kernel Mailing List , stable References: <20191212103158.4958-1-hdegoede@redhat.com> <20191212103158.4958-3-hdegoede@redhat.com> From: Hans de Goede Message-ID: <9c5e89d7-7971-a0b4-fa56-fe4832007ca6@redhat.com> Date: Thu, 12 Dec 2019 13:38:40 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.2.2 MIME-Version: 1.0 In-Reply-To: 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 12-12-2019 12:29, Ard Biesheuvel wrote: > On Thu, 12 Dec 2019 at 11:32, Hans de Goede wrote: >> >> When running in EFI mixed mode (running a 64 bit kernel on 32 bit EFI >> firmware), we _must_ initialize any pointers which are returned by >> reference by an EFI call to NULL before making the EFI call. >> >> In mixed mode pointers are 64 bit, but when running on a 32 bit firmware, >> EFI calls which return a pointer value by reference only fill the lower >> 32 bits of the passed pointer, leaving the upper 32 bits uninitialized >> unless we explicitly set them to 0 before the call. >> >> We have had this bug in the efi-stub-helper.c file reading code for >> a while now, but this has likely not been noticed sofar because >> this code only gets triggered when LILO style file=... arguments are >> present on the kernel cmdline. >> >> Cc: stable@vger.kernel.org >> Signed-off-by: Hans de Goede >> --- >> drivers/firmware/efi/libstub/efi-stub-helper.c | 4 ++-- >> 1 file changed, 2 insertions(+), 2 deletions(-) >> >> diff --git a/drivers/firmware/efi/libstub/efi-stub-helper.c b/drivers/firmware/efi/libstub/efi-stub-helper.c >> index e02579907f2e..6ca7d86743af 100644 >> --- a/drivers/firmware/efi/libstub/efi-stub-helper.c >> +++ b/drivers/firmware/efi/libstub/efi-stub-helper.c >> @@ -365,7 +365,7 @@ static efi_status_t efi_file_size(efi_system_table_t *sys_table_arg, void *__fh, >> u64 *file_sz) >> { >> efi_file_handle_t *h, *fh = __fh; > > What about h? Doesn't it suffer from the same problem? > >> - efi_file_info_t *info; >> + efi_file_info_t *info = NULL; >> efi_status_t status; >> efi_guid_t info_guid = EFI_FILE_INFO_ID; >> unsigned long info_sz; > > And info_sz? You are right in both cases. I only checked allocate_pool and locate_protocol callers as those are the usual suspects. Shall I send a v2 of just this patch, or of the entire series, or are you going to fix this up? Regards, Hans > > >> @@ -527,7 +527,7 @@ efi_status_t handle_cmdline_files(efi_system_table_t *sys_table_arg, >> unsigned long *load_addr, >> unsigned long *load_size) >> { >> - struct file_info *files; >> + struct file_info *files = NULL; >> unsigned long file_addr; >> u64 file_size_total; >> efi_file_handle_t *fh = NULL; >> -- >> 2.23.0 >> >