Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp635665pxj; Thu, 17 Jun 2021 10:16:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyVPFY25aOBHIHUo0FxYiGDhNCvz5e7NaqzREGcZXg+Zuk5y5XSRjx4dBQ18iwH+JLnwSKV X-Received: by 2002:a05:6602:2c47:: with SMTP id x7mr4748500iov.145.1623950173221; Thu, 17 Jun 2021 10:16:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623950173; cv=none; d=google.com; s=arc-20160816; b=ZAEuPJ+YhdRfMfO1312zv5HEMnOtBBeuVOsKrgt+i6B86pIyWtUO7vM3GBQkJo7eCP X1eDO11vFOYxcvSt4VKSzXNNPAhIHC6TN2q9fK4bmUG/7McmNcyQb0wi7MeNRjYkRgJF 08Zo7/aHa8bcqW7ZwN84lo394ZQTCYSfpLNdbJmEAqcyhaZ4lyrbkdJY7XfMS3JDLUuf XJO30mMNmdjX7xg7VZQdHDHXxDScw0+3/If9wuvtj3DRjK1NKhTO3GpYXhQkvUcSpL+5 bCO0YDYq1nodpCteTFvaqqenvObMytx5jPKjubNehpLFXXMd6sQZ7Ed84mMAW8Y9Dlh6 V5tQ== 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=1zD+T81jZZgZpyjFh0xFUsdQjL/HhqmGe6jBuS5LlYM=; b=y3aa5WP43yUC54jNgAYiZoNzZ6dYy69mXlFUwpXs/EwLtXbFsqzL1xNej7j5OwJe+H y22DwLrIGPmOvInPTiEanUOE3KSMjLVBGYoxtlq7A3qVJTdpxDunWColWnS27mM9sl+O d/jmJ/DqfQE90iqoWm2gTxU7/xDhmVaEaTOk7JHPDw3ZLePNldxU+dFJ3conUyJMSiNl TQt1QzQpBzYaVGSJ6z3zNffolv2bApX+SKYBoBeZS0kqq9ObIC5929MK+rO5HlOyPdGr CWSU/5+hdsmEY15mhcYKmLJQPp8F6iDBkC5kg3ue+HTApEsotLzJYd2MgfQM7DI2invo NnTg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=VNTKhE5c; 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 g1si7905329ild.63.2021.06.17.10.15.42; Thu, 17 Jun 2021 10:16:13 -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=VNTKhE5c; 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 S232173AbhFQRRe (ORCPT + 99 others); Thu, 17 Jun 2021 13:17:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45544 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232144AbhFQRRd (ORCPT ); Thu, 17 Jun 2021 13:17:33 -0400 Received: from mail-pg1-x52b.google.com (mail-pg1-x52b.google.com [IPv6:2607:f8b0:4864:20::52b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 45F7FC061767 for ; Thu, 17 Jun 2021 10:15:25 -0700 (PDT) Received: by mail-pg1-x52b.google.com with SMTP id w31so5484698pga.6 for ; Thu, 17 Jun 2021 10:15:25 -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=1zD+T81jZZgZpyjFh0xFUsdQjL/HhqmGe6jBuS5LlYM=; b=VNTKhE5cST2J0ZnjsR5r3QutKIJAPxdYyKrH0WhAhImj92y8rywVUrDhn5E6UvCEVs jnF1hD2ZBj/+9soV3yLKupEXB/gCaqaptyKZ21N5+glwJDNV3wZyO1x4mJqmk61zA06g 7ijTYSH+TXIBumKzmNqYu2FWwdSDsDboZTmT0= 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=1zD+T81jZZgZpyjFh0xFUsdQjL/HhqmGe6jBuS5LlYM=; b=cpDQJOkSzldypnJzJTCTV8x40ZSgUArpUys/Ey8+vkhK+8IWj8SOXoCnkuNnBNIlJw XsBnTXRXJDJ22xMG3rZQY/wngVueYPS87RTt+bNvc2/uMNs42vlyZfcQJxwsm1DhdoxM 9sIl1ptiEcNsHUUordIVg5pngJtGWS2BS3V9gbO7vFUx9pckUHkMNDgrW757bvHca2lD BiRjGHZQC7yZdufIq5qRqJlkfTse4ZhXNBzPgDV5KRtPfa/FA97H7AvV8kx5/OWC2+Lt 3roNqa0YYC8FKSd2ONPRDoM818C8Bm30Nl4QWHFAnj5XsA3CII7luSiFFPdaPfCpJptN DqiQ== X-Gm-Message-State: AOAM532HD7Z3+iwQ2Ddd/yYPklMM1idcI4nDl56QzCwQYiE921oDGJCK 3a1PZD8d/gPcGJuo90O6ARgvOQ== X-Received: by 2002:a63:c112:: with SMTP id w18mr5792064pgf.375.1623950124830; Thu, 17 Jun 2021 10:15:24 -0700 (PDT) Received: from www.outflux.net (smtp.outflux.net. [198.145.64.163]) by smtp.gmail.com with ESMTPSA id q21sm6146371pfn.81.2021.06.17.10.15.24 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 17 Jun 2021 10:15:24 -0700 (PDT) From: Kees Cook To: Kalle Valo Cc: Kees Cook , Amitkumar Karwar , Ganapathi Bhat , Sharvari Harisangam , Xinming Hu , "David S. Miller" , Jakub Kicinski , linux-kernel@vger.kernel.org, linux-wireless@vger.kernel.org, netdev@vger.kernel.org, linux-hardening@vger.kernel.org Subject: [PATCH] mwifiex: Avoid memset() over-write of WEP key_material Date: Thu, 17 Jun 2021 10:15:22 -0700 Message-Id: <20210617171522.3410951-1-keescook@chromium.org> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 X-Patch-Hashes: v=1; h=sha256; g=8ee66baceadd27f658a8dfa2fe3397021a28ad22; i=BArkIcxklEnQKmH2E0CxJuEpf2GPz0bKINbIuaIaeGg=; m=QhaE3cdmOtrz4D6MWzL5ksVjqyQuqa6XFh/VF/68Fns=; p=0XEJ9f86jVziXDyuQV+SK180J33uce0FHTOpZ2MXGNU= X-Patch-Sig: m=pgp; i=keescook@chromium.org; s=0x0x8972F4DFDC6DC026; b=iQIzBAABCgAdFiEEpcP2jyKd1g9yPm4TiXL039xtwCYFAmDLgykACgkQiXL039xtwCZAaQ//VPH Acw4YzlV6FoySvgPI2F9hIrqIUecqEJLuZXlKbEO/+XVh/E+asMJRVYfC8aixmaMj6xJGj+PKKpZL Qrk94z5tRQ12XIVKK+5/EOykBXLcclyyn+JsVbXH51ofvofhAHUw6MldFBCNgWVH0NIJe9zWdpwdx DORMsA2AjLkCAjNXBaiWktvfyy+PWhR7bqZwYK8Bhhz76nmlRsWR1tDb8lQUfD5Kpk9ohIBpuXMpj cey5gKDWIc+ri9vCGuF6P/Vq+3/jSvmB0mn0BdiWeito+OxIETfM4rOjwTBCKRmgT93Mn56Qg5S+h wWM+thXDZ78dKqiFlhgzeMjHM5k7nrMaMb5sLB00j9Pvu289BTmS8I8Nl4UJDQpMwGNmqgcqkkAKv c52rJ7yMm3w6VW7e1J3AEGNT8G2WH+VmebmyIGkJgjkZErnFrS4GgAqwZT3IdrHfcTTehxJ1gPOa7 1oL6gBBsos0Qx0bi9/dz7WNFYo6XCL52zVjGtJ8bZ7jHbnwmZ41fwJ/Bfi+GYTPJDTKKz5/vXh1gf 8q+hJIBNOd7tM6eY+BM9zwrD0GZVuDRHZvk+Dkt/rQe5RJ7gGnHWFmJJ/E4MxuBetyxVM4LORtedk 71BXhfbgPNN1AMJeYNwRTL4T6u2r7FgjFMUFbo3wY+ezV1dW71gAD/NSOyez5KcM= 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 memset(), avoid intentionally writing across neighboring array fields. When preparing to call mwifiex_set_keyparamset_wep(), key_material is treated very differently from its structure layout (which has only a single struct mwifiex_ie_type_key_param_set). Instead, add a new type to the union so memset() can correctly reason about the size of the structure. Note that the union ("params", 196 bytes) containing key_material was not large enough to hold the target of this memset(): sizeof(struct mwifiex_ie_type_key_param_set) == 60, NUM_WEP_KEYS = 4, so 240 bytes, or 44 bytes past the end of "params". The good news is that it appears that the command buffer, as allocated, is 2048 bytes (MWIFIEX_SIZE_OF_CMD_BUFFER), so no neighboring memory appears to be getting clobbered. Signed-off-by: Kees Cook --- drivers/net/wireless/marvell/mwifiex/fw.h | 6 ++++++ drivers/net/wireless/marvell/mwifiex/sta_cmd.c | 11 ++++++----- 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/drivers/net/wireless/marvell/mwifiex/fw.h b/drivers/net/wireless/marvell/mwifiex/fw.h index 470d669c7f14..2ff23ab259ab 100644 --- a/drivers/net/wireless/marvell/mwifiex/fw.h +++ b/drivers/net/wireless/marvell/mwifiex/fw.h @@ -995,6 +995,11 @@ struct host_cmd_ds_802_11_key_material { struct mwifiex_ie_type_key_param_set key_param_set; } __packed; +struct host_cmd_ds_802_11_key_material_wep { + __le16 action; + struct mwifiex_ie_type_key_param_set key_param_set[NUM_WEP_KEYS]; +} __packed; + struct host_cmd_ds_gen { __le16 command; __le16 size; @@ -2347,6 +2352,7 @@ struct host_cmd_ds_command { struct host_cmd_ds_wmm_get_status get_wmm_status; struct host_cmd_ds_802_11_key_material key_material; struct host_cmd_ds_802_11_key_material_v2 key_material_v2; + struct host_cmd_ds_802_11_key_material_wep key_material_wep; struct host_cmd_ds_version_ext verext; struct host_cmd_ds_mgmt_frame_reg reg_mask; struct host_cmd_ds_remain_on_chan roc_cfg; diff --git a/drivers/net/wireless/marvell/mwifiex/sta_cmd.c b/drivers/net/wireless/marvell/mwifiex/sta_cmd.c index d3a968ef21ef..48ea00da1fc9 100644 --- a/drivers/net/wireless/marvell/mwifiex/sta_cmd.c +++ b/drivers/net/wireless/marvell/mwifiex/sta_cmd.c @@ -840,14 +840,15 @@ mwifiex_cmd_802_11_key_material_v1(struct mwifiex_private *priv, } if (!enc_key) { - memset(&key_material->key_param_set, 0, - (NUM_WEP_KEYS * - sizeof(struct mwifiex_ie_type_key_param_set))); + struct host_cmd_ds_802_11_key_material_wep *key_material_wep = + (struct host_cmd_ds_802_11_key_material_wep *)key_material; + memset(key_material_wep->key_param_set, 0, + sizeof(key_material_wep->key_param_set)); ret = mwifiex_set_keyparamset_wep(priv, - &key_material->key_param_set, + &key_material_wep->key_param_set[0], &key_param_len); cmd->size = cpu_to_le16(key_param_len + - sizeof(key_material->action) + S_DS_GEN); + sizeof(key_material_wep->action) + S_DS_GEN); return ret; } else memset(&key_material->key_param_set, 0, -- 2.25.1