Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp100106pxj; Wed, 16 Jun 2021 21:27:35 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwdbdrKAKjefEdVmKGhrKY7iRVBF730DuGVvwLh+xNb8q9nqYojL7pQO2/7EhMbPkMyaQQo X-Received: by 2002:a05:6602:2145:: with SMTP id y5mr2109695ioy.46.1623904054835; Wed, 16 Jun 2021 21:27:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623904054; cv=none; d=google.com; s=arc-20160816; b=0ZFjCYU6Za2rfKx3R8RBDpai8Hy6zxw3zyXeF62A10tIZLlWWNR2jiw52Dt3qtCaQG K59AOGvVBqatNUSToRHAAFWGLP0NF5RcGkuvbbgSIh6ry1Wm/0hDm15PGuDjr3brbxc5 U2McUaoxD+2F/Brx6IakdflYM+Sbu/cqCgm9/s3VL11+2Ex8d7LwApXX5Jl643Iyt8WM FErhxlp+MpfsDmz2M+AD6SrURcz6lxyBLgl8VGZBUdtzktBBM4spRS/HaXuPlmmJWhYU Fy9d5rn6qpplJsAESvFeO24UT43gcAh/k0ziVwyVgKfQEWdzIuGV3alaM28AUOVzEbMo pSKA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=zuAYjQFtuIQCmO1rMjR+p21Q0Trj1l5ASgWxbkTK9wA=; b=WM/wzRLdsr2w01YRXVf9Lwvo2zinWDCuNNznFp1/YL2uQEGqLTTfxOwciztRudxDnf EkUbO9soQXhpCW5Hqnjk19rdnLBKK0RkY042JyOIGg6aj/WWLignAMBExRN+0fFhtv1U qUIZdOIQ03YL9Lq9IhJoLc7xI+nEwnrk/51Rdhvnvzgn99OjJIUcesjmJlZ7vx86nHEj vtme8NpRn4nA6HpZ3lUXV4jYV9eqUfJ+HYXoXzP3Of7aFUnOoUgxV007XY3pHKn2snn1 UBsBOxzIZtTo2Kpiycp4es9mO5cruDBfDbvIGVvRepUxjt3dsba0AhmZb/Nu3P+Zyt3V iPHA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=Uv2fCei4; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b6si4774592ile.102.2021.06.16.21.27.19; Wed, 16 Jun 2021 21:27:34 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=Uv2fCei4; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229827AbhFQE3T (ORCPT + 99 others); Thu, 17 Jun 2021 00:29:19 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41634 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229551AbhFQE3T (ORCPT ); Thu, 17 Jun 2021 00:29:19 -0400 Received: from mail-pg1-x52c.google.com (mail-pg1-x52c.google.com [IPv6:2607:f8b0:4864:20::52c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 49FCEC061760 for ; Wed, 16 Jun 2021 21:27:12 -0700 (PDT) Received: by mail-pg1-x52c.google.com with SMTP id q15so3850467pgg.12 for ; Wed, 16 Jun 2021 21:27:12 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=zuAYjQFtuIQCmO1rMjR+p21Q0Trj1l5ASgWxbkTK9wA=; b=Uv2fCei424Ypp83aUrHk1FNQtzrzzxcWjmyFu4H68+GAxcC1lRAOT9+abTyzD1hADw NnfALb++pBhrvBW3H4jOX8zOzTkl9Yxam50FmCouTDs6gjvDglX4qj2JdER3MQ55UScC hYzydqWeqWBFbhr0clBEm5KZTNf/PvyhIp1aY= 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:mime-version :content-transfer-encoding; bh=zuAYjQFtuIQCmO1rMjR+p21Q0Trj1l5ASgWxbkTK9wA=; b=O5Dn6zV+/eBMmDi5d6OxdYAv2QB4srQN4RCY4LA6RjkL4FO4zhLghv7/lFCRC/VPE2 AMFQGfRftRUxH1AAd7SZv7kEqatuZcqgwASlG5PubzmCfOl33syZECWPuRFwftCjqjBd 15CctlJcfQZ6FWifBr7EDSOaH7wfnQxSkjgYx1MBp9xYbK3r13ZQr45o/PkZf3N1LdyU KtLpgLrk0dT+rA+ObO+HSF56gJywT1GNoHU7Etk5c0qp0vuuRoDZ+MwwnIkwWjpBxTSZ Gd4TRi20JfFSoGftdXYqv30USylhoWBKM/a/WIAGGPtRujS0piXQvsFxiJtcZIrGE/Wb dHjw== X-Gm-Message-State: AOAM533IknrvpuI/DCkWD5JsGYFaZ/KFyMA1irgipCGASaQSEA4NGhyr TEvves0HVTEEOlZTNW2RmnEFEw== X-Received: by 2002:a63:3d82:: with SMTP id k124mr3049823pga.401.1623904031759; Wed, 16 Jun 2021 21:27:11 -0700 (PDT) Received: from www.outflux.net (smtp.outflux.net. [198.145.64.163]) by smtp.gmail.com with ESMTPSA id p6sm4473754pjh.24.2021.06.16.21.27.11 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 16 Jun 2021 21:27:11 -0700 (PDT) From: Kees Cook To: netdev@vger.kernel.org Cc: Kees Cook , Johannes Berg , "David S. Miller" , Jakub Kicinski , linux-kernel@vger.kernel.org, linux-wireless@vger.kernel.org, linux-hardening@vger.kernel.org Subject: [PATCH] mac80211: Recast pointer for trailing memcpy() Date: Wed, 16 Jun 2021 21:27:09 -0700 Message-Id: <20210617042709.2170111-1-keescook@chromium.org> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 X-Patch-Hashes: v=1; h=sha256; g=a59972a95d22e6cba17e8ca1ef339d3a3ef1b4e5; i=P4B4b65qJuhqVi5i2irgu0AhoblNfL65fECGIen2RpA=; m=ye9VNM2/KkSGCD7iU041Afv+zNGB2BR/2/Lf1/HGmmk=; p=jmhDm1u21oAA6abJCLcWjlq9egIRuBdVv23WaQ1b954= X-Patch-Sig: m=pgp; i=keescook@chromium.org; s=0x0x8972F4DFDC6DC026; b=iQIzBAABCgAdFiEEpcP2jyKd1g9yPm4TiXL039xtwCYFAmDKzxwACgkQiXL039xtwCZKsQ/+KRk qClgQaevJdpMV/HrC1/U+leuhMDzRHQ+71fiVOPofuqUOQVTtWE+ofVrBg5T6/rY7R3yAsr+M6jIl NJ5qwODjOmqe2eIHOtMdAd4junJjRi6O+8K7pH2Y8x7WLob4RubcXcogaPRTWlrcYGQiWAD14hyv2 mOkbE6mK0UWHeNnACpdecukYVYk5r3MTX0P/OlUO/FwEfnEhrM+DaXP/HWV9EbIQNqbEwsDmcTKY8 VtIggri22AUecFKn4TZKZJ7BIr1R7gMabDODg5vQRdnavOQ2LTaYprz+LO34lEaAsxfPU2onkBVet QIQBQS0Ti8XB+PcQuFsuIdTbu/qxP0yTqvwDq+C1bcSDkzsRMkDu/jGJfbA79rAt16c380/hh9eqP T78RVtzSJBOX+FpOA+/cQR5oZPQzKJpOjAIbdfbyazFb/+qaVakoDq6X0lmtF4MQgo0hrbhJg83Nc nQ4xKK6c6WN1Sno8eGF/JZl5GNKNNdolU2hEmyBJc46P/1CWCOqkhxON0XWPJWJVtqvea1i+WUYDn 7e9lU3+RyC8m/7yaBWVHyolrF+zityHQGiJKD0C6HZmACMw9nA/v5du3fLhtjD68HH8PhAdM8IEjt caIQX7Cm+K9rpWZB/2N/l5dXOIMPjx8g9R8DJtnr2znfH5CD4wW1DFjnlLen/Cco= Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org In preparation for FORTIFY_SOURCE performing compile-time and run-time field bounds checking for memcpy(), memmove(), and memset(), avoid intentionally writing across neighboring array fields. Give memcpy() a specific source pointer type so it can correctly calculate the bounds of the copy. Signed-off-by: Kees Cook --- net/mac80211/rx.c | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c index af0ef456eb0f..cb141bb788a8 100644 --- a/net/mac80211/rx.c +++ b/net/mac80211/rx.c @@ -559,6 +559,8 @@ ieee80211_add_rx_radiotap_header(struct ieee80211_local *local, if (status->encoding == RX_ENC_HE && status->flag & RX_FLAG_RADIOTAP_HE) { + struct ieee80211_radiotap_he *he_ptr; + #define HE_PREP(f, val) le16_encode_bits(val, IEEE80211_RADIOTAP_HE_##f) if (status->enc_flags & RX_ENC_FLAG_STBC_MASK) { @@ -626,18 +628,22 @@ ieee80211_add_rx_radiotap_header(struct ieee80211_local *local, while ((pos - (u8 *)rthdr) & 1) pos++; rthdr->it_present |= cpu_to_le32(1 << IEEE80211_RADIOTAP_HE); - memcpy(pos, &he, sizeof(he)); - pos += sizeof(he); + he_ptr = (void *)pos; + memcpy(he_ptr, &he, sizeof(he)); + pos += sizeof(*he_ptr); } if (status->encoding == RX_ENC_HE && status->flag & RX_FLAG_RADIOTAP_HE_MU) { + struct ieee80211_radiotap_he_mu *he_mu_ptr; + /* ensure 2 byte alignment */ while ((pos - (u8 *)rthdr) & 1) pos++; rthdr->it_present |= cpu_to_le32(1 << IEEE80211_RADIOTAP_HE_MU); - memcpy(pos, &he_mu, sizeof(he_mu)); - pos += sizeof(he_mu); + he_mu_ptr = (void *)pos; + memcpy(he_mu_ptr, &he_mu, sizeof(he_mu)); + pos += sizeof(*he_mu_ptr); } if (status->flag & RX_FLAG_NO_PSDU) { @@ -647,12 +653,14 @@ ieee80211_add_rx_radiotap_header(struct ieee80211_local *local, } if (status->flag & RX_FLAG_RADIOTAP_LSIG) { + struct ieee80211_radiotap_lsig *lsig_ptr; /* ensure 2 byte alignment */ while ((pos - (u8 *)rthdr) & 1) pos++; rthdr->it_present |= cpu_to_le32(1 << IEEE80211_RADIOTAP_LSIG); - memcpy(pos, &lsig, sizeof(lsig)); - pos += sizeof(lsig); + lsig_ptr = (void *)pos; + memcpy(lsig_ptr, &lsig, sizeof(lsig)); + pos += sizeof(*lsig_ptr); } for_each_set_bit(chain, &chains, IEEE80211_MAX_CHAINS) { -- 2.25.1