Received: by 2002:a25:5b86:0:0:0:0:0 with SMTP id p128csp855909ybb; Thu, 28 Mar 2019 13:37:14 -0700 (PDT) X-Google-Smtp-Source: APXvYqzZ6mYbBCc9RYZ5FweqXt3AYKYatRqGcMHEwR6vt/gxl0mYj7KVvUgsadJRzrbKivwdDyB1 X-Received: by 2002:aa7:82cb:: with SMTP id f11mr36722538pfn.0.1553805434306; Thu, 28 Mar 2019 13:37:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553805434; cv=none; d=google.com; s=arc-20160816; b=eweGJeQHS8EMEXfwmsNLKOcGD8k3X/2L3thnoiNOlDRt3pThp+PIjlY1anTcIsI0fs etOvabedQpAlKGsVw21rVUz4kCE0XYYCa3UeVSS+sXfr7b8qkJkN2bOYwSlbmqdvQ2n0 s9ED/lWX2kv+B3WLRryuKl4Yao1yfU06i1IYAjJgUQI6iquFABhs4ci9/FGe3BXD0u7Y yWaagrYhztdZXbqKA6drHKkadjTdMnNWi3Xs0/h1cVPIo2JtOpPnJRFzyJ0au1f4lHyR CMoBDJE2CndTgBp0YXjdFnAk8wkKaIC0frDjLqHFWE8QqH1XbR84zhJTQrJWXGiZI2nO j44g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:content-disposition :mime-version:message-id:subject:cc:to:from:date; bh=Xk5SUMvCukyZAVY+QaNfGnlzW2OBsZiQ1vmoVvcWcgg=; b=jwsO3h3wenMlmNCeUdzkx8HDK6/tBITfp7SBYQrJe+TnjlfxowU7JubGUpfK7zNYaQ 3tH16KvhIspzfV/M2G6zQI0amhFDpZ50xliEQP12FhRuVyCX7VGW0GbxLkTzkqcZM6+x Qvf+8mHb6WZqzAGBVofh9jS/qc+bEb7Lz2mMRo0Ub5ogd39JXoq44ZDyTPLt3bKXnzFb TTiw+NYhF/AaLEzOMx0AoPgUATq5BK8lc/9pXYsEvocdv5X5OO9U7tWwZzaiph6x7MOY 24KNpcNMDDAeUZAyAd9v9t2ZTnZly+cPo13rr8Yl8y/3xmOgZKaMfMGnYrcOuDcZ3T5+ v/Dg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 134si44827pga.249.2019.03.28.13.36.57; Thu, 28 Mar 2019 13:37:14 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726476AbfC1UgS (ORCPT + 99 others); Thu, 28 Mar 2019 16:36:18 -0400 Received: from gateway31.websitewelcome.com ([192.185.143.5]:35088 "EHLO gateway31.websitewelcome.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726200AbfC1UgS (ORCPT ); Thu, 28 Mar 2019 16:36:18 -0400 Received: from cm14.websitewelcome.com (cm14.websitewelcome.com [100.42.49.7]) by gateway31.websitewelcome.com (Postfix) with ESMTP id 9653114CEF for ; Thu, 28 Mar 2019 15:36:17 -0500 (CDT) Received: from gator4166.hostgator.com ([108.167.133.22]) by cmsmtp with SMTP id 9bl3hr1tJ2qH79bl3hGUh3; Thu, 28 Mar 2019 15:36:17 -0500 X-Authority-Reason: nr=8 Received: from [189.250.117.246] (port=41134 helo=embeddedor) by gator4166.hostgator.com with esmtpa (Exim 4.91) (envelope-from ) id 1h9bl0-000NxI-7j; Thu, 28 Mar 2019 15:36:16 -0500 Date: Thu, 28 Mar 2019 15:36:13 -0500 From: "Gustavo A. R. Silva" To: Jeff Kirsher , "David S. Miller" Cc: intel-wired-lan@lists.osuosl.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, "Gustavo A. R. Silva" Subject: [PATCH][next] iavf: iavf_client: use struct_size() helper Message-ID: <20190328203613.GA23692@embeddedor> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline User-Agent: Mutt/1.9.4 (2018-02-28) X-AntiAbuse: This header was added to track abuse, please include it with any abuse report X-AntiAbuse: Primary Hostname - gator4166.hostgator.com X-AntiAbuse: Original Domain - vger.kernel.org X-AntiAbuse: Originator/Caller UID/GID - [47 12] / [47 12] X-AntiAbuse: Sender Address Domain - embeddedor.com X-BWhitelist: no X-Source-IP: 189.250.117.246 X-Source-L: No X-Exim-ID: 1h9bl0-000NxI-7j X-Source: X-Source-Args: X-Source-Dir: X-Source-Sender: (embeddedor) [189.250.117.246]:41134 X-Source-Auth: gustavo@embeddedor.com X-Email-Count: 5 X-Source-Cap: Z3V6aWRpbmU7Z3V6aWRpbmU7Z2F0b3I0MTY2Lmhvc3RnYXRvci5jb20= X-Local-Domain: yes Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org One of the more common cases of allocation size calculations is finding the size of a structure that has a zero-sized array at the end, along with memory for some number of elements for that array. For example: struct foo { int stuff; struct boo entry[]; }; size = sizeof(struct foo) + count * sizeof(struct boo); Instead of leaving these open-coded and prone to type mistakes, we can now use the new struct_size() helper: size = struct_size(instance, entry, count); This code was detected with the help of Coccinelle. Signed-off-by: Gustavo A. R. Silva --- drivers/net/ethernet/intel/iavf/iavf_client.c | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/drivers/net/ethernet/intel/iavf/iavf_client.c b/drivers/net/ethernet/intel/iavf/iavf_client.c index aea45364fd1c..ab9db7e9f09d 100644 --- a/drivers/net/ethernet/intel/iavf/iavf_client.c +++ b/drivers/net/ethernet/intel/iavf/iavf_client.c @@ -451,7 +451,7 @@ static int iavf_client_setup_qvlist(struct i40e_info *ldev, struct i40e_qv_info *qv_info; iavf_status err; u32 v_idx, i; - u32 msg_size; + size_t msg_size; if (adapter->aq_required) return -EAGAIN; @@ -469,9 +469,8 @@ static int iavf_client_setup_qvlist(struct i40e_info *ldev, } v_qvlist_info = (struct virtchnl_iwarp_qvlist_info *)qvlist_info; - msg_size = sizeof(struct virtchnl_iwarp_qvlist_info) + - (sizeof(struct virtchnl_iwarp_qv_info) * - (v_qvlist_info->num_vectors - 1)); + msg_size = struct_size(v_qvlist_info, qv_info, + v_qvlist_info->num_vectors - 1); adapter->client_pending |= BIT(VIRTCHNL_OP_CONFIG_IWARP_IRQ_MAP); err = iavf_aq_send_msg_to_pf(&adapter->hw, -- 2.21.0