Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp2344662ybc; Wed, 13 Nov 2019 12:58:12 -0800 (PST) X-Google-Smtp-Source: APXvYqzMxJl9LPnNbGUQaK1khfRYTmArRGjFreThxIxK8wnBUlUBFm5Ks+iGoi/sElwmdO3MbpOJ X-Received: by 2002:a17:906:e88:: with SMTP id p8mr4854327ejf.15.1573678692301; Wed, 13 Nov 2019 12:58:12 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573678692; cv=none; d=google.com; s=arc-20160816; b=Hx5WkuFCyy7MiQQCOzXbuspBa1AkqLoFlOpy1iYewvpO25i8qa5mjjpbQuKDwTKRNA X64JzD+SrBsgw2PkOFrpLA9PcIcIYaBKVhEEryyDeuGOc9p92q/Nwo420x5Ia7KihIcs 9CGRlqtW8XlBBf3TrxQprztVHIsdbp54k4oap1Yrc4tnP4w2VCBNPx9rRrGnVp43JRMw qxtghtKFAYz0yyQx2mGgkwqsM8jnYzCnH4Z3qo5c/7yuWb8GDULbjTfin14rJidqH5rH /4cP8fLDOHcDUW6GDYeXZ7KFdZenAjBkyDHK9wAD/bJyO5GqIJUu3o5RjqJjsQuNgvR8 YLAQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=Kzg+cr/dhrJgO1piPaEyuVjoZZjMZrA15PeHen3UdLk=; b=yq1M1PMASikYcfYXnJy4DRdhHA5xlnpoLd8rlLwKK6YJx957zKE4aqeKWjL+f4IYjH lbo1irepN137ivKZ2mh+X1XaO9EhZoXFYLM3SmPG1X8CBlcYzyqDfwORfNV191VgNdSA gupM9TJoXoSc3dQy4NGKXarSbqAdBQL11MguOr4jfTOKDMlNs8DaM+DMJuDgksBBy1mD DYBU1/kTyDyQW8NfwIMvKa5Yq3fNZh0xQYF05FkiMzte+VPoRaZM5eAZQSNUS78aUQZb zrSYr0ENesFaMo6bZoxnKcFUINjt3r6owDzvR2mvNd6ZFWyNw1txxDOXRl53QJ1p6C7G J2eg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=X8mPkt1Z; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c1si1987521ejb.116.2019.11.13.12.57.47; Wed, 13 Nov 2019 12:58:12 -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=@gmail.com header.s=20161025 header.b=X8mPkt1Z; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726291AbfKMU5F (ORCPT + 99 others); Wed, 13 Nov 2019 15:57:05 -0500 Received: from mail-qt1-f194.google.com ([209.85.160.194]:33233 "EHLO mail-qt1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726162AbfKMU5F (ORCPT ); Wed, 13 Nov 2019 15:57:05 -0500 Received: by mail-qt1-f194.google.com with SMTP id y39so4222989qty.0; Wed, 13 Nov 2019 12:57:04 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=Kzg+cr/dhrJgO1piPaEyuVjoZZjMZrA15PeHen3UdLk=; b=X8mPkt1ZPwhWdTiBFBZIdxjOQBH5ouQPaS7ooGnrnQyOJcHvgWpdTF25RTTSiBmSeI VQvje+ClweqXmuLAJydKPlXEmovxHyfJKADlzpJ3yI0gAwdsePObf27dl9woJhiqZB3y bRHDKNqPCbESjmqDXRM4ovcBCqTAbHACj4SEfhMWaByeHMhRaLvHuh3QTRkUONdBxaML 7Wui6zRaOXqphBoI61ggiZLixp3aQDxnIvAElonuD3SnOGcRzSR4qXq4Lcj+71K/ePLN TUm3EfONQYXAIidpZkdvwxE5TXx++6BWhvAfVVeq+sBp7xu68Amfu+y+9JBH8aU/V894 i3yA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=Kzg+cr/dhrJgO1piPaEyuVjoZZjMZrA15PeHen3UdLk=; b=LFHePliU4pJ+OSkK6P6MTFVj+W4hyfTq1Wcmt/W5kmpnUsOZuU0IAN2Gp7X2kq/ZZq rujE44OHM2y0u/pSWdHeQ8YRBi0wAcNQwT6ewUCIvCOuhGd0/mOrVtyAzIvcInbY8BG9 kDSGTQpOOU1R7gx/pWkU4cyYOy1VU3VcMnEajKp1WcO5YLD9CCArfyd18+SuDPb0dahT Q9ktWGzvJWVTeo26kGqZPz72U18LyQ2Cid7r2pX22tz1rQxXy88C6u1PwQqETY+HVhmE ol+F7qh2SvgIT/7RgcN/Ff+5yTe5F2bFGLPiHFd8aHfGu4ztKmvm8Fys/uxrP3iw6B7F Z6Dg== X-Gm-Message-State: APjAAAUnUGM8puxZWDxHPtaqC4BQjt28dkYgdtEAdCbxHJwHgeTx2unJ NX/dtOcCRpJgN9gZOcHE6A== X-Received: by 2002:aed:3282:: with SMTP id z2mr4932353qtd.221.1573678624271; Wed, 13 Nov 2019 12:57:04 -0800 (PST) Received: from gabell.bos.redhat.com (nat-pool-bos-t.redhat.com. [66.187.233.206]) by smtp.gmail.com with ESMTPSA id h12sm1500140qkh.123.2019.11.13.12.57.03 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 13 Nov 2019 12:57:03 -0800 (PST) From: Masayoshi Mizuma To: Ard Biesheuvel , linux-efi@vger.kernel.org Cc: Masayoshi Mizuma , Masayoshi Mizuma , linux-kernel@vger.kernel.org, HATAYAMA Daisuke Subject: [PATCH] efi: sanity check in case memermap() at efi_mem_reserve_persistent() returns NULL Date: Wed, 13 Nov 2019 15:56:30 -0500 Message-Id: <20191113205630.28434-1-msys.mizuma@gmail.com> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Masayoshi Mizuma System may crash as NULL pointer dereference in case memremap() at efi_mem_reserve_persistent() returns NULL. Add a sanity check to avoid that. Signed-off-by: Masayoshi Mizuma Reported-by: HATAYAMA Daisuke --- drivers/firmware/efi/efi.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/drivers/firmware/efi/efi.c b/drivers/firmware/efi/efi.c index 07812d697..1d5ae7b95 100644 --- a/drivers/firmware/efi/efi.c +++ b/drivers/firmware/efi/efi.c @@ -1036,6 +1036,8 @@ int __ref efi_mem_reserve_persistent(phys_addr_t addr, u64 size) /* first try to find a slot in an existing linked list entry */ for (prsv = efi_memreserve_root->next; prsv; prsv = rsv->next) { rsv = memremap(prsv, sizeof(*rsv), MEMREMAP_WB); + if (!rsv) + return -ENOMEM; index = atomic_fetch_add_unless(&rsv->count, 1, rsv->size); if (index < rsv->size) { rsv->entry[index].base = addr; -- 2.21.0