Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp74397pxb; Tue, 2 Mar 2021 19:42:23 -0800 (PST) X-Google-Smtp-Source: ABdhPJxUbwD/Y/ep/JAgWiEvRyd30NOC9nzp5wDwkRvBBw8OwEnzqxH1//p/6HK2CTlRdw6/4EjL X-Received: by 2002:a05:6402:1517:: with SMTP id f23mr12083869edw.272.1614742943070; Tue, 02 Mar 2021 19:42:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614742943; cv=none; d=google.com; s=arc-20160816; b=NbWb43PifWE3aAvRlEOqUfThFVb0QH2d3BBOecEBAAozXCm4k5hB4QpXhoF6Z3Ma/K +rNY4YsXjOtLqtX+TatAB9mcpLnYBLqBrQuYVPNV0wyfkeJ5cBRK60tQLieKSw1uR7p4 thMoGNP2IYFWQf6BhysaQYn9NkzyVm5kyyNvv9KcmstOS1dxkN6zsgRYZAqwazeCm+Sr AhpWXhGxkmqgA9SH9ICZOrA9fHy/Oy0xSGjj+JdCjLKINEhMnOPc9JkRXs3olZ1uwMrz zg4lvJfgrGgQA/Vd8K70Gb/9d7YKONZrLcWJclEGT+al0rEmt4y4kTE7yj84R5GBEacs laCg== 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=1XTQYvzenTvAy+uzJCG3RPCHtA1WmUP3E0AtneiJNGY=; b=Ytt1LKJILJNjvd2F2KVyWB9QikrnhDpAVxD1yvnCHXFsZJn3kYJ3pwLoxV4x3lvmJx hDoU5BBjl4LUOEgdxPGzvGYGHHH5yzwJXVVLluiYQr+VCnPH2fdHnKzMdarfnyWHnu6z lhwsbSogJn+xNW20IqA8TarhxnuSWyVqVzOKgMhvsUh6OXBrS3xdG5ZFdyZ1XvyvBygz 5wVHHgLs78qdN8nsjjXDOfqHSV0u95BZ2xmeWImpHdw19SV/u+Mrf+QYvcvi/1Q0Q9yy VVFl507pU/h+D9Fc5xjmugwXHuGIUOv4Bwt51SqmmVR72KECpZ/P/6rBYhBzB67ueIWp Se5A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Gmj4Jvo9; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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. [23.128.96.18]) by mx.google.com with ESMTP id v8si14928307ejy.237.2021.03.02.19.42.00; Tue, 02 Mar 2021 19:42:23 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-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=@gmail.com header.s=20161025 header.b=Gmj4Jvo9; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S235725AbhCAN1v (ORCPT + 99 others); Mon, 1 Mar 2021 08:27:51 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54288 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235717AbhCAN1s (ORCPT ); Mon, 1 Mar 2021 08:27:48 -0500 Received: from mail-wr1-x42c.google.com (mail-wr1-x42c.google.com [IPv6:2a00:1450:4864:20::42c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6066BC061756 for ; Mon, 1 Mar 2021 05:27:07 -0800 (PST) Received: by mail-wr1-x42c.google.com with SMTP id l12so16147546wry.2 for ; Mon, 01 Mar 2021 05:27:07 -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:mime-version :content-transfer-encoding; bh=1XTQYvzenTvAy+uzJCG3RPCHtA1WmUP3E0AtneiJNGY=; b=Gmj4Jvo9jICmWc2pFSDtMVB76Lbb8gRC6Ty+B04Dn2d/dk0hbMYQEqJUmHFpt+77q9 Jsn1OOzbczH7qxbGvgSHzIiwHJ0zYmVOUTJsvGM4ShrTn9kq0ZmbEwBXn0I9KCxMpgGZ ccgiTKE1ORTIa54/B+QOm9YqiWNP49LhOhEZ+NMLgZSzmk5mMDiX9OdJbyV1hgw5ySXt X172HtSbHDdHUSfBu76roE/r26QP5OhA49z8PZvZxdQ6PYH7klWR3/Qp8nZg8lIs84Xf 6kUr53onk/MunaCynNOW1Magv5ssOiQA7WbH+lJefpcCHSc5O70fNN/0rP2RpSE72KwE cRiQ== 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=1XTQYvzenTvAy+uzJCG3RPCHtA1WmUP3E0AtneiJNGY=; b=Xwy0k8Eh27HhohC903s+c3Vj2xKmx7Pk4NglgGhwZX4gpYBhYuaZguZXktN9pGzSPk 9DrgXDEbURN6JMSEaMS/QAEovVtUGmbb7Za7fhv7D0QgPT6GA3w2GWAH+VBcpPdry5NI gI3xXIukrD5p9RqryAZAgofRcGYquFJQIsazbIy2Y8AVYKK+ZcZJ3SPzJcp0TSxYebd5 zTvCrvQg61nSy1tUk74oLyjiqCBqP/2C+Yb2HDzE30dGSRHXZVGpeZxOi/KS6XEDhdF4 5NdN2gI4mXOKLyceHv4a1746egnVQrfHJJ/gc773OH8Dk1tr/aK4eJHYuCwc3ndCuAs8 HfoA== X-Gm-Message-State: AOAM5330Lgx0gHzLV9nCg7VgqRqpHe4QYuHQCeSyWmq5b/2gISCDAQOn 97FFVVSbc267qmNvtiophhyqQNzCzbO1gwXm X-Received: by 2002:adf:f2c3:: with SMTP id d3mr17094844wrp.380.1614605226099; Mon, 01 Mar 2021 05:27:06 -0800 (PST) Received: from ubuntudesktop.lan (205.158.32.217.dyn.plus.net. [217.32.158.205]) by smtp.gmail.com with ESMTPSA id p10sm11253288wrw.33.2021.03.01.05.27.05 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 01 Mar 2021 05:27:05 -0800 (PST) From: Lee Gibson To: gregkh@linuxfoundation.org Cc: devel@driverdev.osuosl.org, linux-kernel@vger.kernel.org, Lee Gibson Subject: [PATCH] staging: rtl8712: Fix possible buffer overflow in r8712_sitesurvey_cmd Date: Mon, 1 Mar 2021 13:26:48 +0000 Message-Id: <20210301132648.420296-1-leegib@gmail.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Function r8712_sitesurvey_cmd calls memcpy without checking the length. A user could control that length and trigger a buffer overflow. Fix by checking the length is within the maximum allowed size. Signed-off-by: Lee Gibson --- drivers/staging/rtl8712/rtl871x_cmd.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/drivers/staging/rtl8712/rtl871x_cmd.c b/drivers/staging/rtl8712/rtl871x_cmd.c index 18116469bd31..75716f59044d 100644 --- a/drivers/staging/rtl8712/rtl871x_cmd.c +++ b/drivers/staging/rtl8712/rtl871x_cmd.c @@ -192,8 +192,10 @@ u8 r8712_sitesurvey_cmd(struct _adapter *padapter, psurveyPara->ss_ssidlen = 0; memset(psurveyPara->ss_ssid, 0, IW_ESSID_MAX_SIZE + 1); if (pssid && pssid->SsidLength) { - memcpy(psurveyPara->ss_ssid, pssid->Ssid, pssid->SsidLength); - psurveyPara->ss_ssidlen = cpu_to_le32(pssid->SsidLength); + int len = min_t(int, pssid->SsidLength, IW_ESSID_MAX_SIZE); + + memcpy(psurveyPara->ss_ssid, pssid->Ssid, len); + psurveyPara->ss_ssidlen = cpu_to_le32(len); } set_fwstate(pmlmepriv, _FW_UNDER_SURVEY); r8712_enqueue_cmd(pcmdpriv, ph2c); -- 2.25.1