Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp3703585ybv; Tue, 25 Feb 2020 05:59:12 -0800 (PST) X-Google-Smtp-Source: APXvYqwblmAKEBBrmMHkyCgdOMI1wj8SY59ySWIkL3qs+pI1V6HhxkSjqgKzAC4ilj5+cnM8HGrl X-Received: by 2002:aca:1a05:: with SMTP id a5mr3578499oia.97.1582639152166; Tue, 25 Feb 2020 05:59:12 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582639152; cv=none; d=google.com; s=arc-20160816; b=HC9Dxqw8lqt3rmhaf9EO+HSaIP0xmzkWgtkYRpP0qdrIroSkZECDrHPzUM4X0ruR5m TCNx6U0qzMU1adYuZhfXTb92xZ+fDoxM9NJc344DKpWlXNlAU+4qY2C6xBzC5Lk9nqOv BZZr8/obIvV5ZNtkq7//t8y50Z3Mza4T6bekizUfgUiGAx7ITEzCvTuQywDGLQHa+d1E X3SezRynii3uT9AJ3KI0VH8HK5AJJSv6wuyDhIVvNeX1gyhnh5SB9BlTiXcFkzwwsSUA 7C2yYsiIcdHLbnnuyA31JhMVWPgUhyqQEyYqtD3eUWlweQHKnM/toRJ77xzAd/hf9sJz LE/Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:in-reply-to :content-disposition:mime-version:references:subject:cc:to:from:date; bh=+OEE1sZZTemMxeJ8D/eGHyqeifYo1bszQO4uL29X9Ws=; b=Mao2I9/So3hh0tccF7PVDU/SuGaApkOmBPaGeVpuiKheUZ5wMP5VF+aGxTajf3DT9V 5iib6PbgsdjT6dBjlXjBpP+Fhx/jskT2KFuZXft6WnMttkc0/dU+sPEuTJi/G8Ork27g tjZ88rL3imILlkl/fIvjw1hNaae1C7F3nVC1k+K1VurqKushIxIb0TAyxImA2oEUzdPn 63advXYziYrsR9VC+X9/sm7gayfcvfvNx5TW4fK6j16l8Ifdd1vvCtBLyUFDssE5SYDp dYAHvBeG1ONu6uaplxfEVl+R6zen3jDSyTsXAkcHOXJipI6DYf4PZEDFCdl7k6NVo0ZR i35g== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q189si6848971oic.235.2020.02.25.05.58.59; Tue, 25 Feb 2020 05:59:12 -0800 (PST) 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730278AbgBYN5V (ORCPT + 99 others); Tue, 25 Feb 2020 08:57:21 -0500 Received: from mx0a-001b2d01.pphosted.com ([148.163.156.1]:12198 "EHLO mx0a-001b2d01.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725788AbgBYN5V (ORCPT ); Tue, 25 Feb 2020 08:57:21 -0500 Received: from pps.filterd (m0098404.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id 01PDsswC023046 for ; Tue, 25 Feb 2020 08:57:20 -0500 Received: from e06smtp02.uk.ibm.com (e06smtp02.uk.ibm.com [195.75.94.98]) by mx0a-001b2d01.pphosted.com with ESMTP id 2ycxcxwt0u-1 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=NOT) for ; Tue, 25 Feb 2020 08:57:20 -0500 Received: from localhost by e06smtp02.uk.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Tue, 25 Feb 2020 13:57:18 -0000 Received: from b06avi18878370.portsmouth.uk.ibm.com (9.149.26.194) by e06smtp02.uk.ibm.com (192.168.101.132) with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted; (version=TLSv1/SSLv3 cipher=AES256-GCM-SHA384 bits=256/256) Tue, 25 Feb 2020 13:57:15 -0000 Received: from b06wcsmtp001.portsmouth.uk.ibm.com (b06wcsmtp001.portsmouth.uk.ibm.com [9.149.105.160]) by b06avi18878370.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id 01PDvDMn42271034 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Tue, 25 Feb 2020 13:57:13 GMT Received: from b06wcsmtp001.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id B6BD7A405F; Tue, 25 Feb 2020 13:57:13 +0000 (GMT) Received: from b06wcsmtp001.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 6EDBCA4060; Tue, 25 Feb 2020 13:57:13 +0000 (GMT) Received: from localhost (unknown [9.152.212.204]) by b06wcsmtp001.portsmouth.uk.ibm.com (Postfix) with ESMTPS; Tue, 25 Feb 2020 13:57:13 +0000 (GMT) Date: Tue, 25 Feb 2020 14:57:12 +0100 From: Vasily Gorbik To: "Gustavo A. R. Silva" Cc: Heiko Carstens , Christian Borntraeger , Stefan Haberland , Jan Hoeppner , Sebastian Ott , Peter Oberparleiter , Harald Freudenberger , linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] s390: Replace zero-length array with flexible-array member References: <20200221150612.GA9717@embeddedor> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20200221150612.GA9717@embeddedor> X-TM-AS-GCONF: 00 x-cbid: 20022513-0008-0000-0000-000003564BDD X-IBM-AV-DETECTION: SAVI=unused REMOTE=unused XFE=unused x-cbparentid: 20022513-0009-0000-0000-00004A7767BB Message-Id: X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.138,18.0.572 definitions=2020-02-25_04:2020-02-21,2020-02-25 signatures=0 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 malwarescore=0 bulkscore=0 impostorscore=0 lowpriorityscore=0 adultscore=0 clxscore=1015 suspectscore=0 mlxlogscore=533 phishscore=0 mlxscore=0 priorityscore=1501 spamscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2001150001 definitions=main-2002250109 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Feb 21, 2020 at 09:06:12AM -0600, Gustavo A. R. Silva wrote: > The current codebase makes use of the zero-length array language > extension to the C90 standard, but the preferred mechanism to declare > variable-length types such as these ones is a flexible array member[1][2], > introduced in C99: > > struct foo { > int stuff; > struct boo array[]; > }; > > By making use of the mechanism above, we will get a compiler warning > in case the flexible array does not occur last in the structure, which > will help us prevent some kind of undefined behavior bugs from being > inadvertently introduced[3] to the codebase from now on. > > Also, notice that, dynamic memory allocations won't be affected by > this change: > > "Flexible array members have incomplete type, and so the sizeof operator > may not be applied. As a quirk of the original implementation of > zero-length arrays, sizeof evaluates to zero."[1] > > This issue was found with the help of Coccinelle. > > [1] https://gcc.gnu.org/onlinedocs/gcc/Zero-Length.html > [2] https://github.com/KSPP/linux/issues/21 > [3] commit 76497732932f ("cxgb3/l2t: Fix undefined behaviour") > > Signed-off-by: Gustavo A. R. Silva > --- > arch/s390/appldata/appldata_os.c | 2 +- > drivers/s390/block/dasd_diag.c | 2 +- > drivers/s390/block/dasd_eckd.h | 2 +- > drivers/s390/char/raw3270.h | 2 +- > drivers/s390/char/sclp_pci.c | 2 +- > drivers/s390/cio/idset.c | 2 +- > drivers/s390/crypto/pkey_api.c | 2 +- > drivers/s390/crypto/zcrypt_ccamisc.h | 2 +- > drivers/s390/crypto/zcrypt_msgtype6.c | 2 +- > 9 files changed, 9 insertions(+), 9 deletions(-) > Applied, thanks