Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp3792098pxb; Tue, 19 Apr 2022 09:54:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJylGHFYNsZK0oVOmq6EE/RfBLzrHNGVt9ekIwws8x9O0NuHClGWqKw7sQABPrExSRxrx6ZF X-Received: by 2002:a17:90b:e8f:b0:1cb:a308:5ee5 with SMTP id fv15-20020a17090b0e8f00b001cba3085ee5mr19493966pjb.147.1650387249289; Tue, 19 Apr 2022 09:54:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650387249; cv=none; d=google.com; s=arc-20160816; b=G+J27scZmXZBMJ6TY4lxs1XWg/zQUqSTpx/oJ1phrQgrKVrpkA9TCZw76X/q251tZ8 61LCsp3esYKYLb5Lc7EnynbzLyROcovcB0cWFXWh2Z3+5XITv5STQVjH5NdWBpNwNoOK LbLfofUr8w+wmVC4H+QEtjJyVFCFMc+orP63inq+YAXwnHl/vXJb/7xP9NYEPUtjBPjm HdtMa0BC0OYgMNRUIDy80HoOGUsPVXTXe/SBk8Sc7lHvVh4NKimFrtJanmXam09mlZtU Sm9IbOeXfBMzLQKaSsHFO7yo6gvtJbTWO7EggEGQJAIiwzmQnkb4KpQKbBHYdXY409FS R8Vg== 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=Ua3DWHoWYRZ0Hj18kv0a4L5TFGQ8YVkye6cMbl2VF6s=; b=RLngNppME1I3lLBv2osHs/P1wAEfCYLHNG0D2gPdqeF+Z5UUtm5HZnqi+KC37l+Yn8 OFXldmQ36S9kduAbyOe3bTus8AxWfD/wLABQg2XNrf90u20dmq4lO4HQV+s5XUf+e+W9 rOuIru5n31PCG4m2pstZl9vzuEDxPE0nZtnzM418I64DEJN94yucCrg+NwU8+e8VXvuc Prpn+TrgZurCV70dU5g2Zg5eojrAIVYyD+7k4KUl8D6f3GUzoBrPvky6QUr3Ox4KYGOd VaTiUCKbbMgGfyAw9IFdD1uEXuJRlAI2P5SSKgLc3OG3AYkLZhj6x4EGRjLOpg9O4z7v JO2Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=YyIlytPr; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id k13-20020a634b4d000000b003aa13bbf60bsi5054152pgl.614.2022.04.19.09.53.52; Tue, 19 Apr 2022 09:54:09 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=YyIlytPr; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-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 S1348193AbiDSEU2 (ORCPT + 99 others); Tue, 19 Apr 2022 00:20:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42146 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230042AbiDSEU1 (ORCPT ); Tue, 19 Apr 2022 00:20:27 -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 C4E492BB0D for ; Mon, 18 Apr 2022 21:17:46 -0700 (PDT) Received: by mail-pg1-x52b.google.com with SMTP id t4so22673559pgc.1 for ; Mon, 18 Apr 2022 21:17:46 -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=Ua3DWHoWYRZ0Hj18kv0a4L5TFGQ8YVkye6cMbl2VF6s=; b=YyIlytPr7dhGhZh1n4740x8jTXToacvwiuTjRhl7OryQkWqeaG4t9xBbEXMJhWhGiC m1Cq5gcWdtSctAcUnt83MwRhiXBJ+a94dBQ6qGS4tuqqY9RyN8+RbAn8Tl+U55POKAuB D9wVkDFJdg8rIbtS5hisU04sNYtpwd+4rgebs= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=Ua3DWHoWYRZ0Hj18kv0a4L5TFGQ8YVkye6cMbl2VF6s=; b=ZXpdGwygS8Jz3OsGTjA7rTlpicmE3taD4q/WN+I3rVfIrW19SlOR2817cSeg2KDBK4 hVcZ6bHI5nm+GWYZ8RMR2GRvF0+8p1InCqmlW0V596fM6L7syLcvlXp4JHFnz4LC/Yzo iW+R8siZADV1422haG9yVcPEQfFgzsLQVG+qjZqeEqQelxEzVTP5O6LAHvtmdIWFgKh9 DyaCCr1ziXehhl3+Hr36WFKpmpDa0pBN6HGgtvxz3eoGJFnsrxEexdQwjUcUjgQFcBWj 1TxCk+xhPvR225uMV6aN/fhmYs/NoFKz5/Dr/8kLxoFZ4HBC+DumzrIpPyGUgqryAacK MO7A== X-Gm-Message-State: AOAM533SX4QVxoqMCIzbsqU9vzetb1Gy8cw4sUb/KGrII5ZnmsgyTcRG T5ljtS+55aI7CcOqctsYW7jsXA== X-Received: by 2002:a63:fd53:0:b0:386:66d:b40c with SMTP id m19-20020a63fd53000000b00386066db40cmr12741689pgj.266.1650341866296; Mon, 18 Apr 2022 21:17:46 -0700 (PDT) Received: from www.outflux.net (smtp.outflux.net. [198.145.64.163]) by smtp.gmail.com with ESMTPSA id k5-20020a17090ac50500b001cd5ffcca96sm16726552pjt.27.2022.04.18.21.17.45 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 18 Apr 2022 21:17:45 -0700 (PDT) From: Kees Cook To: Johan Hovold Cc: Kees Cook , kernel test robot , Greg Kroah-Hartman , linux-usb@vger.kernel.org, stable@vger.kernel.org, linux-kernel@vger.kernel.org, linux-hardening@vger.kernel.org Subject: [PATCH] USB: serial: Fix heap overflow in WHITEHEAT_GET_DTR_RTS Date: Mon, 18 Apr 2022 21:17:42 -0700 Message-Id: <20220419041742.4117026-1-keescook@chromium.org> X-Mailer: git-send-email 2.32.0 MIME-Version: 1.0 X-Developer-Signature: v=1; a=openpgp-sha256; l=2631; h=from:subject; bh=gIgxtgBXPkDpXaGP7aAQI8PBhl9DxARQALU32sCb0HQ=; b=owEBbQKS/ZANAwAKAYly9N/cbcAmAcsmYgBiXjfmXFgU+SMJsQUdOjA7WslYjSoG7qjHLuLjYkEv G8abkvKJAjMEAAEKAB0WIQSlw/aPIp3WD3I+bhOJcvTf3G3AJgUCYl435gAKCRCJcvTf3G3AJp63D/ 4u5P63EDXyGqn9YU26NnZ4oNbGN5YfchlZolAZ5r7qKja5KmvCpyan3HLHJQzoovP5H6CWwbwM4QTY XjQ/LVQaTjZRVaCncCJssE5JSCjhPD90lGAE2pmRQOSfFmcE7v9ehLPv19DYz8Ie1aCTB2DNzkhjlB QmThEiUSrtoskck4SemCz6ln0JlndvsjvGiP7VKxkfb2HWvSo5ay0G1PH90uIcsQcKMRjM2b/Iurk5 4UTUTTzZ32raGPjjCsk5FM9t9av+wz0+NgIX3UGlRKDCy0dusVFy+S9sMziYi7mcBrtpCYK5rD/tuz NeKbQLIcojtNN0dCK7KqqR3HNovH2IflWaQHcwkMCsU32I77BFPLuVUX/jIKdCovAxxYBZZGU2XSyq FEqxXjkXhrAOmTzwuSbBrACNI+l/5VvYdPtVEVqxByueJB0CGu9wPwMR7LGbcnrAVFNQG1oxUcUKCr RQF9gxiXS4zAAatKoYWtc3GZbs1bVuj4GmAEioGA+suoeWzzqFtxjqi8utTGTyME41Qap3JHar7H60 gCxE+RDQqwhIpf5GJmbKhtjIhv/rH0zv+Uq/sjQa9ALXM2I0nc2CRCTNpu54amWZOksJmqEqLiPdC5 cqrFa981hQyEKx3L91aZUiGHEmA5huIG90V2xEdEG0CteJipVqv3KQ9tJSgw== X-Developer-Key: i=keescook@chromium.org; a=openpgp; fpr=A5C3F68F229DD60F723E6E138972F4DFDC6DC026 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.7 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This looks like it's harmless, as both the source and the destinations are currently the same allocation size (4 bytes) and don't use their padding, but if anything were to ever be added after the "mcr" member in "struct whiteheat_private", it would be overwritten. The structs both have a single u8 "mcr" member, but are 4 bytes in padded size. The memcpy() destination was explicitly targeting the u8 member (size 1) with the length of the whole structure (size 4), triggering the memcpy buffer overflow warning: In file included from include/linux/string.h:253, from include/linux/bitmap.h:11, from include/linux/cpumask.h:12, from include/linux/smp.h:13, from include/linux/lockdep.h:14, from include/linux/spinlock.h:62, from include/linux/mmzone.h:8, from include/linux/gfp.h:6, from include/linux/slab.h:15, from drivers/usb/serial/whiteheat.c:17: In function 'fortify_memcpy_chk', inlined from 'firm_send_command' at drivers/usb/serial/whiteheat.c:587:4: include/linux/fortify-string.h:328:25: warning: call to '__write_overflow_field' declared with attribute warning: detected write beyond size of field (1st parameter); maybe use struct_group()? [-Wattribute-warning] 328 | __write_overflow_field(p_size_field, size); | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Expand the memcpy() to the entire structure, though perhaps the correct solution is to mark all the USB command structures as "__packed". Reported-by: kernel test robot Link: https://lore.kernel.org/lkml/202204142318.vDqjjSFn-lkp@intel.com Cc: Johan Hovold Cc: Greg Kroah-Hartman Cc: linux-usb@vger.kernel.org Cc: stable@vger.kernel.org Signed-off-by: Kees Cook --- drivers/usb/serial/whiteheat.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/usb/serial/whiteheat.c b/drivers/usb/serial/whiteheat.c index da65d14c9ed5..6e00498843fb 100644 --- a/drivers/usb/serial/whiteheat.c +++ b/drivers/usb/serial/whiteheat.c @@ -584,7 +584,7 @@ static int firm_send_command(struct usb_serial_port *port, __u8 command, switch (command) { case WHITEHEAT_GET_DTR_RTS: info = usb_get_serial_port_data(port); - memcpy(&info->mcr, command_info->result_buffer, + memcpy(info, command_info->result_buffer, sizeof(struct whiteheat_dr_info)); break; } -- 2.32.0