Received: by 2002:a25:ca44:0:0:0:0:0 with SMTP id a65csp1182938ybg; Wed, 29 Jul 2020 07:51:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxH76IktVa3ItHgDscd4d5KLVq2rRlsI2G2oaYU5/BnHmupzT0+Te8tdfdS6/pTxnxhQjQr X-Received: by 2002:a17:906:1f8e:: with SMTP id t14mr24849357ejr.336.1596034315905; Wed, 29 Jul 2020 07:51:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1596034315; cv=none; d=google.com; s=arc-20160816; b=e3TPb7BSAJ2aSigvqPQoBqejkMxKRi2ibOIHcYwFgkeCmiDupub1tIkClAQ7F4tXS/ axsflI9y0c1vqz977vam4ik1FI/S5+kh01yS2ZHRbMxupcmK22Lbj7e1oKIY3rzF4KvQ q4UU4eqB9OgPGCRtvdtBha+jMEPBzZnjXfYn5rr9pFjR+EJie1nm6XinvOC5TkHDG89o CAEMwYXASyYw8Rj6xVcMTHf4p0MZpKACju2UEN+bm+1Je+uUXFh4PPaQTubKe3fCqI8y 1X+ShyuinMSRe8CroWenQ4SeRknhp6hTDoLA1E82sDzb+pojNS6FnLlQj3T4j9Q0aMI3 YZOA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=XgDzWs5LYt7Mkx0UdbPr7BFgEZ8N/ZoZ6ADwKcHkW84=; b=AqEjdIiiNKGdOcIl69bEK3NVsMwvgWxhIN/rsBKVlxtbhD5RcCAGPkDR8keUbTDfuY 4GlBIys3J/4rznDCCRlXuIRV6RtGHD97114u5fs9N4HamdEQaYYQXMQ+UOSr0rmcQdpR PJINO7M6UKOnR2So83E1Q0VB93fuvXC/QtOGtKUcFOPxRzPowErwzq0wIwr5iitol2Pq kO7q9NlZLHgDSagTA4GfMlvUwa29XLfry7TzWTjlygCn5SLQbab8m5BVWhyjVsxnZuvV 1hPW/eWgS00n5i/g6IALh0mgxZVaFHCwH0J82+iRSIcAcK5iwiTCO9T0YC83V4/hzpyt DBjQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Uekz1hDH; 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 k6si1423418edn.299.2020.07.29.07.51.32; Wed, 29 Jul 2020 07:51:55 -0700 (PDT) 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=Uekz1hDH; 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 S1726858AbgG2OuW (ORCPT + 99 others); Wed, 29 Jul 2020 10:50:22 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34784 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726385AbgG2OuV (ORCPT ); Wed, 29 Jul 2020 10:50:21 -0400 Received: from mail-pj1-x1043.google.com (mail-pj1-x1043.google.com [IPv6:2607:f8b0:4864:20::1043]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0DFB9C061794 for ; Wed, 29 Jul 2020 07:50:21 -0700 (PDT) Received: by mail-pj1-x1043.google.com with SMTP id mt12so1967837pjb.4 for ; Wed, 29 Jul 2020 07:50:21 -0700 (PDT) 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=XgDzWs5LYt7Mkx0UdbPr7BFgEZ8N/ZoZ6ADwKcHkW84=; b=Uekz1hDHFE/A9esJhBdVFwm8ohWCgO/OY+8PRW1Bp2rQOpEMNN1vlmW+8ay2DT91cC 7eD39VYxARUX7FoPwiGCEGuKIqd7uzQ0yuRdRsUhVuy+XVqUoytulRJDXGOkjnpk4WIQ /F5R0wumaXINUq/XwS3HWxK+YZttG/FXg/eyuOPSQXavDsp4DE6hVWijJQRb/+g8uEm+ L8z4RGzDZwAonZa3lTaSb5tla73JNC4esECyEUnIvyakAruIZnKlTUP1hUtcwhuosDWz 7kVUbvMUh33slesyNHfEwPykMehktJmKvc8qgzggibg4jyM5K4SDzXd5fhQXDd+zKHKL MG3Q== 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=XgDzWs5LYt7Mkx0UdbPr7BFgEZ8N/ZoZ6ADwKcHkW84=; b=hMalOlnqSm1AGmuo+n9JI+BuoxRH99aSqtIZfduslftazpdWoRSfRcZrTepg3LpRXy vVs5z/ScXOKxGMiJxc6uoOJOdaz/1fE8ZFeZv0VrrlOyrmLi4I/MlFQnYRX3glKXbMQW igz1q+OA7LNcnvQ23ynYsS7OsO5OH96oNSd07pAZbiE5QXmcHKl09fkGiWi12eEL2UkZ uV37ZaSUEPDVw7/mx0YJ1dkbK94St3rkhY8PSN0+sFZjh/h0bO81OR58V2XXnTn6ishS ajpbzoq7Zu4H6G2DjuWlv/p4f0r5nYZo90unK7tnbRdtpg94ZJXq/13GMegio81Tuc94 UYEA== X-Gm-Message-State: AOAM532p+9enxRPWQtif86vbQFvyv5DU9aFpyyJD18dOaX+fimnpofyL 5My1tbK5mYks8NOJAOXjhW0= X-Received: by 2002:a17:902:d303:: with SMTP id b3mr13162508plc.101.1596034220591; Wed, 29 Jul 2020 07:50:20 -0700 (PDT) Received: from builder-PowerEdge-R730xd.mioffice.cn ([43.224.245.179]) by smtp.gmail.com with ESMTPSA id o190sm1251827pfd.194.2020.07.29.07.50.17 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Wed, 29 Jul 2020 07:50:20 -0700 (PDT) From: Qianli Zhao To: cl@linux.com, penberg@kernel.org, rientjes@google.com, iamjoonsoo.kim@lge.com, akpm@linux-foundation.org Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org, clang-built-linux@googlegroups.com, zhaoqianli@xiaomi.com Subject: [PATCH] mm: slab: Avoid the use of one-element array and use struct_size() helper Date: Wed, 29 Jul 2020 22:50:14 +0800 Message-Id: <1596034214-15010-1-git-send-email-zhaoqianligood@gmail.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Qianli Zhao There is a regular need in the kernel to provide a way to declare having a dynamically sized set of trailing elements in a structure. Kernel code should always use “flexible array members”[1] for these cases. The older style of one-element or zero-length arrays should no longer be used[2]. Make use of the struct_size() helper instead of an open-coded version in order to avoid any potential type mistakes. [1] https://en.wikipedia.org/wiki/Flexible_array_member [2] https://github.com/KSPP/linux/issues/21 Signed-off-by: Qianli Zhao --- mm/slab.h | 2 +- mm/slab_common.c | 7 ++----- 2 files changed, 3 insertions(+), 6 deletions(-) diff --git a/mm/slab.h b/mm/slab.h index 74f7e09..c12fb65 100644 --- a/mm/slab.h +++ b/mm/slab.h @@ -34,7 +34,7 @@ struct kmem_cache { struct memcg_cache_array { struct rcu_head rcu; - struct kmem_cache *entries[0]; + struct kmem_cache *entries[]; }; /* diff --git a/mm/slab_common.c b/mm/slab_common.c index fe8b684..56f4818 100644 --- a/mm/slab_common.c +++ b/mm/slab_common.c @@ -166,9 +166,7 @@ static int init_memcg_params(struct kmem_cache *s, if (!memcg_nr_cache_ids) return 0; - arr = kvzalloc(sizeof(struct memcg_cache_array) + - memcg_nr_cache_ids * sizeof(void *), - GFP_KERNEL); + arr = kvzalloc(struct_size(arr, entries, memcg_nr_cache_ids), GFP_KERNEL); if (!arr) return -ENOMEM; @@ -199,8 +197,7 @@ static int update_memcg_params(struct kmem_cache *s, int new_array_size) { struct memcg_cache_array *old, *new; - new = kvzalloc(sizeof(struct memcg_cache_array) + - new_array_size * sizeof(void *), GFP_KERNEL); + new = kvzalloc(struct_size(new, entries, new_array_size), GFP_KERNEL); if (!new) return -ENOMEM; -- 2.7.4