Received: by 2002:a17:90a:1609:0:0:0:0 with SMTP id n9csp830603pja; Wed, 1 Apr 2020 09:29:21 -0700 (PDT) X-Google-Smtp-Source: ADFU+vtHxFJFv+thVYzpBmqajngEc6Fj4SAcvoMqO2K60Njmf8ox81D3JX7qurgY+1bRFGIEf0we X-Received: by 2002:a4a:d746:: with SMTP id h6mr17475580oot.21.1585758561517; Wed, 01 Apr 2020 09:29:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585758561; cv=none; d=google.com; s=arc-20160816; b=FezZeM+vAbS5zv6gOfi+vq1ftjjo9EXCKR/WycDrEWomHF3ZXWYmlxHM7JA3wwBx6r ix2e0C6F0IBlvDd92/NBTyO598Fj8eigE4kK+X19pDMp6gpE7ByLSqR5UK7+ZM1gE01p L7qfOXz4VRiF7rUugNWeUM9147PdLUvl6qYOO6tlrFAsbTGUC9b+RdUYdEtKwmpQasfL X1c2fnhnYm+j9nVkdnoi7ml0mx3+lHLMvwG96tKn8TjJWx0IVCAVH9K++tIkuMMUFtCH 3TCy4ocBf/q2lzEeyHeFhK0aSKx1qKAucwXmalAu5vYSX7AeWv2h7R0HNtN6VVKvsTxi g0rA== 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:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=ScSsWTM9DrSmg38CjCC3rRKk344VmsHl/Noyn8Pmcuw=; b=oUjKahiu/LhcNJbiMLN8R810AaByEfkJ8UO4rDpmthsCXiHn+ilafVRsyi9W2S1C60 LGJy9ckeUeZ+x/RvHMvP/RkG+G0XrrFOR5wnH67MEuBmf8s9v56pl/hoXC5+mjAr8/88 TkZRUbqN/YZjAb9hi20hHrSMJiqkZbuVlK+3Wk6gvfT2MtMsOzoL7kQus6LoWoNMduZT F11MlxDRMIu22DOiSQDgPTPqOO1jv/NwVZOpPXHWMo/ik+scI5tOdSA00vQ5S6mn1f6F QWRRvYjp9N9cfleitJ2OqP3o4XGrnd1l66PQAONWSnaREsuvg+GM94RIKqoodbvLmK1K Hhlw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=P0rgyp3Q; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i14si936294oov.24.2020.04.01.09.29.08; Wed, 01 Apr 2020 09:29:21 -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=@kernel.org header.s=default header.b=P0rgyp3Q; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388088AbgDAQ2M (ORCPT + 99 others); Wed, 1 Apr 2020 12:28:12 -0400 Received: from mail.kernel.org ([198.145.29.99]:53364 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388078AbgDAQ2J (ORCPT ); Wed, 1 Apr 2020 12:28:09 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 5E18520857; Wed, 1 Apr 2020 16:28:08 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1585758488; bh=aJXSF9To3DwzTZCXEL3zhettvEbM0elzyPobBAlreHg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=P0rgyp3QGgi8agRxn8SwcZG3FBENKRKtymQ9/yWR6wo8VkyAaMWSD0QzZ9OQQ5yns PJ8eWhPBX7qkENupSonsf8bEusEdjHadAV5hFQitYd5CWwRoCP9s4pImrii/uaYOXC 3vHh61gTFnO6wd6xJk+5JtBWjyuxnFNgjgtJboH4= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, =?UTF-8?q?Maciej=20=C5=BBenczykowski?= , John Stultz , Alexander Potapenko , Alistair Delva , Daniel Borkmann , Yonghong Song Subject: [PATCH 4.19 105/116] bpf: Explicitly memset the bpf_attr structure Date: Wed, 1 Apr 2020 18:18:01 +0200 Message-Id: <20200401161555.630698707@linuxfoundation.org> X-Mailer: git-send-email 2.26.0 In-Reply-To: <20200401161542.669484650@linuxfoundation.org> References: <20200401161542.669484650@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Greg Kroah-Hartman commit 8096f229421f7b22433775e928d506f0342e5907 upstream. For the bpf syscall, we are relying on the compiler to properly zero out the bpf_attr union that we copy userspace data into. Unfortunately that doesn't always work properly, padding and other oddities might not be correctly zeroed, and in some tests odd things have been found when the stack is pre-initialized to other values. Fix this by explicitly memsetting the structure to 0 before using it. Reported-by: Maciej Żenczykowski Reported-by: John Stultz Reported-by: Alexander Potapenko Reported-by: Alistair Delva Signed-off-by: Greg Kroah-Hartman Signed-off-by: Daniel Borkmann Acked-by: Yonghong Song Link: https://android-review.googlesource.com/c/kernel/common/+/1235490 Link: https://lore.kernel.org/bpf/20200320094813.GA421650@kroah.com Signed-off-by: Greg Kroah-Hartman --- kernel/bpf/syscall.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) --- a/kernel/bpf/syscall.c +++ b/kernel/bpf/syscall.c @@ -2372,7 +2372,7 @@ out: SYSCALL_DEFINE3(bpf, int, cmd, union bpf_attr __user *, uattr, unsigned int, size) { - union bpf_attr attr = {}; + union bpf_attr attr; int err; if (sysctl_unprivileged_bpf_disabled && !capable(CAP_SYS_ADMIN)) @@ -2384,6 +2384,7 @@ SYSCALL_DEFINE3(bpf, int, cmd, union bpf size = min_t(u32, size, sizeof(attr)); /* copy attributes from user space, may be less than sizeof(bpf_attr) */ + memset(&attr, 0, sizeof(attr)); if (copy_from_user(&attr, uattr, size) != 0) return -EFAULT;