Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp2092449rdb; Thu, 7 Dec 2023 19:21:38 -0800 (PST) X-Google-Smtp-Source: AGHT+IHeHuen9eqGZUySmPpCcmCaaqzr9ruFCBtBREGgLJuEnnIk2c4lWDweaPa2lFoPJqi/wcLu X-Received: by 2002:a17:902:c78c:b0:1d0:9979:7be4 with SMTP id w12-20020a170902c78c00b001d099797be4mr2304172pla.28.1702005698658; Thu, 07 Dec 2023 19:21:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1702005698; cv=none; d=google.com; s=arc-20160816; b=F98THzlLXFen5Fg0ecD3MmV9XmrPY4p4IqLUBk8KVym2kJx82kRbGfcszybfH8tV7K Tz3k7+O3WXSXVlH43xlCAWkEuOWTxY119DQnuZw/84ATl7gfK6OC0YhWI4CLCxq88yhD Oob4kcxUvfmhLrtPjYq89SfPV0g1xaj2efpNdIHzGpei8HHSX8sKULC62QMeB/EYqMXb EgkIpJHwToBmK+AY5QdVwSF96XLua2gL5DnU0X0yQjopkxA6duOGnDAC+PKzT5DMAOSZ jEFXRLXxNt6kc9brHS2labiNGNB6xGqmqNNbY5Tt+MUef4QfKWVJZwjpyDoswacnQLcX zztw== 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; bh=znbwOEBD7aMRW0+wSQwBzMmqLOrxSdCClm0ctLOPNog=; fh=ZvkeHTDsZInbQu9uNcjK5DkyYOVVv0QC3AiFrQZG+b4=; b=DSwhTnRAE0kROSP6TIwBuch+4MrCQ2Rttvw0kL+VmcbbxETIZOXkCPamCFQ9BxcXyf 8MO0S7P1xUkx2DvA2CscZStMj4RBvllgQ3+Z1T7euNuJCFVcI+7vW97pnuH/MOZ772X8 6A0pgy5ttnVYY4wxqY/4uCx1dGdTi9Jlhk637EJ+swjO5BEolpV+FTekw81mXCMpIE8z y9mqXuPV85fJKZzqWcwLm6cL3xTiFjO/zLMqwDqPr6xeEfXosRBBptsI0ORErCWF/f/G 0Xjicgij/M52bXA9sD15R62qyWY9TSO/EkSZyR4s9FS4F/LpIH7vkSPrW+LJme04Ts6u MYGw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from morse.vger.email (morse.vger.email. [2620:137:e000::3:1]) by mx.google.com with ESMTPS id s10-20020a170902ea0a00b001cf7ce5e6e0si812536plg.330.2023.12.07.19.21.38 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 07 Dec 2023 19:21:38 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) client-ip=2620:137:e000::3:1; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by morse.vger.email (Postfix) with ESMTP id 8D543807C867; Thu, 7 Dec 2023 19:20:27 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at morse.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1573050AbjLHDUK (ORCPT + 99 others); Thu, 7 Dec 2023 22:20:10 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52664 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230225AbjLHDUJ (ORCPT ); Thu, 7 Dec 2023 22:20:09 -0500 Received: from mailgw.kylinos.cn (mailgw.kylinos.cn [124.126.103.232]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 56CA610CA; Thu, 7 Dec 2023 19:20:14 -0800 (PST) X-UUID: 521d0d6ba0f34a20a019334226efae8f-20231208 X-CID-P-RULE: Release_Ham X-CID-O-INFO: VERSION:1.1.33,REQID:c3f1ada0-0adb-401e-b9a5-352cbfef47bd,IP:5,U RL:0,TC:0,Content:-25,EDM:0,RT:0,SF:-15,FILE:0,BULK:0,RULE:Release_Ham,ACT ION:release,TS:-35 X-CID-INFO: VERSION:1.1.33,REQID:c3f1ada0-0adb-401e-b9a5-352cbfef47bd,IP:5,URL :0,TC:0,Content:-25,EDM:0,RT:0,SF:-15,FILE:0,BULK:0,RULE:Release_Ham,ACTIO N:release,TS:-35 X-CID-META: VersionHash:364b77b,CLOUDID:4d908b73-1bd3-4f48-b671-ada88705968c,B ulkID:231208112000PIRN4KGJ,BulkQuantity:0,Recheck:0,SF:38|24|17|19|44|66|1 02,TC:nil,Content:0,EDM:-3,IP:-2,URL:0,File:nil,Bulk:nil,QS:nil,BEC:nil,CO L:0,OSI:0,OSA:0,AV:0,LES:1,SPR:NO,DKR:0,DKP:0,BRR:0,BRE:0 X-CID-BVR: 0,NGT X-CID-BAS: 0,NGT,0,_ X-CID-FACTOR: TF_CID_SPAM_SNR,TF_CID_SPAM_FAS,TF_CID_SPAM_FSD,TF_CID_SPAM_FSI X-UUID: 521d0d6ba0f34a20a019334226efae8f-20231208 X-User: chentao@kylinos.cn Received: from vt.. [(116.128.244.169)] by mailgw (envelope-from ) (Generic MTA with TLSv1.2 ECDHE-RSA-AES256-GCM-SHA384 256/256) with ESMTP id 1129089617; Fri, 08 Dec 2023 11:19:57 +0800 From: Kunwu Chan To: jesse.brandeburg@intel.com, anthony.l.nguyen@intel.com, davem@davemloft.net, edumazet@google.com, kuba@kernel.org, pabeni@redhat.com, jeffrey.t.kirsher@intel.com, shannon.nelson@amd.com Cc: intel-wired-lan@lists.osuosl.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Kunwu Chan , Simon Horman , Alexander Lobakin , Kunwu Chan Subject: [PATCH v5 iwl-next] i40e: Use correct buffer size in i40e_dbg_command_read Date: Fri, 8 Dec 2023 11:19:50 +0800 Message-Id: <20231208031950.47410-1-chentao@kylinos.cn> X-Mailer: git-send-email 2.39.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-0.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE, UNPARSEABLE_RELAY autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on morse.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (morse.vger.email [0.0.0.0]); Thu, 07 Dec 2023 19:20:27 -0800 (PST) The size of "i40e_dbg_command_buf" is 256, the size of "name" depends on "IFNAMSIZ", plus a null character and format size, the total size is more than 256. Improve readability and maintainability by replacing a hardcoded string allocation and formatting by the use of the kasprintf() helper. Fixes: 02e9c290814c ("i40e: debugfs interface") Suggested-by: Simon Horman Suggested-by: Alexander Lobakin Suggested-by: Tony Nguyen Cc: Kunwu Chan Signed-off-by: Kunwu Chan --- v2 - Update the size calculation with IFNAMSIZ and sizeof(i40e_dbg_command_buf) v3 - Use kasprintf to improve readability and maintainability v4 - Fix memory leak in error path v5 - Change the order of labels --- .../net/ethernet/intel/i40e/i40e_debugfs.c | 20 ++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/drivers/net/ethernet/intel/i40e/i40e_debugfs.c b/drivers/net/ethernet/intel/i40e/i40e_debugfs.c index 88240571721a..78a7200211b2 100644 --- a/drivers/net/ethernet/intel/i40e/i40e_debugfs.c +++ b/drivers/net/ethernet/intel/i40e/i40e_debugfs.c @@ -72,29 +72,31 @@ static ssize_t i40e_dbg_command_read(struct file *filp, char __user *buffer, { struct i40e_pf *pf = filp->private_data; int bytes_not_copied; - int buf_size = 256; char *buf; int len; /* don't allow partial reads */ if (*ppos != 0) return 0; - if (count < buf_size) - return -ENOSPC; - buf = kzalloc(buf_size, GFP_KERNEL); + buf = kasprintf(GFP_KERNEL, "%s: %s\n", + pf->vsi[pf->lan_vsi]->netdev->name, + i40e_dbg_command_buf); if (!buf) return -ENOSPC; - len = snprintf(buf, buf_size, "%s: %s\n", - pf->vsi[pf->lan_vsi]->netdev->name, - i40e_dbg_command_buf); + len = strlen(buf) + 1; + if (count < len) + bytes_not_copied = -ENOSPC; + else if (copy_to_user(buffer, buf, len)) + bytes_not_copied = -EFAULT; + else + bytes_not_copied = 0; - bytes_not_copied = copy_to_user(buffer, buf, len); kfree(buf); if (bytes_not_copied) - return -EFAULT; + return bytes_not_copied; *ppos = len; return len; -- 2.39.2