Received: by 10.223.185.116 with SMTP id b49csp6567285wrg; Thu, 8 Mar 2018 09:29:19 -0800 (PST) X-Google-Smtp-Source: AG47ELuS2fuZuJpjtsWJyeME3rHE3CEl9VqCbim/UgXuhw26yir79E3lThQANh5BLCsql7HXQzTv X-Received: by 2002:a17:902:8a97:: with SMTP id p23-v6mr14976359plo.177.1520530159069; Thu, 08 Mar 2018 09:29:19 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1520530159; cv=none; d=google.com; s=arc-20160816; b=xiAEsMoN/QJDbRVzG7myjA+nPFR5iMv5tBJKGU4wWoLHaWm6ozzywp+jJdBs430Wi8 mVM7w7mzOc5ANiJ4sZcGwsu1/pu+Uu87v/cE2vlSuEMl5XZ5v6VdYxZeZsyNukbgxgB3 lkNtC6ohqnS9y+5gDqO30fiqzt51oAD7DwwfeVTp90fjwBHCZqZpeVctfY6p0FYHQUP/ BKU3iya9XVpbmXthS6vWOoj1zzOsP9b8WhLlXRxkpE4niM1LLB4Tk6q0d7XWGgaKcizu fXvwWxg/HmUn4yqgExtkYYQClgPW6ZmPyFX2gcT4To7fLTRK7yktAXAOKA0JcCzhUwET AJbw== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=+0CIMEy0+x2EFzT8P6PXs9MvsHxLwiVAdoYTM8r830c=; b=0v8HKQhf8z4rHkOKSQ0RS1iQ4dl/6ZuOULhkO4/h3umbpqz8pN1Fazfl9idXZVvEKA KYafKEhunoFKXgeOVmGxoxsTVObARxJCyuz2WXcVTqDMJ0obvFRHN1A1+USXRC2coogG iSq9i8SgdPCEip09hyXFrvjunA//5dk+P1I43J3hKmvJWgEip9VEDpzbP/D70DGbOB/T 5xvwaP35QshUX81pbSGJj921v1g7YULETVFXRUbbCDEgRQ6vV03NC/1wSWCQBPi7x3Px K04fjISX3CWgPKXJff8+c9fa5Zi6/vkOPEaa7h2GhiNB0Izw5i5rCSplADXUjXdbeyek a0Hw== 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 g7-v6si7421789plp.38.2018.03.08.09.29.04; Thu, 08 Mar 2018 09:29:19 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S936018AbeCHR1b (ORCPT + 99 others); Thu, 8 Mar 2018 12:27:31 -0500 Received: from gateway31.websitewelcome.com ([192.185.144.94]:11684 "EHLO gateway31.websitewelcome.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S935740AbeCHR13 (ORCPT ); Thu, 8 Mar 2018 12:27:29 -0500 Received: from cm10.websitewelcome.com (cm10.websitewelcome.com [100.42.49.4]) by gateway31.websitewelcome.com (Postfix) with ESMTP id 1CC4616AE1 for ; Thu, 8 Mar 2018 11:27:27 -0600 (CST) Received: from gator4166.hostgator.com ([108.167.133.22]) by cmsmtp with SMTP id tzKBemxancGlptzKBefZpc; Thu, 08 Mar 2018 11:27:27 -0600 Received: from [189.175.117.58] (port=52988 helo=[192.168.1.66]) by gator4166.hostgator.com with esmtpsa (TLSv1.2:ECDHE-RSA-AES128-GCM-SHA256:128) (Exim 4.89_1) (envelope-from ) id 1etzKA-0020Xd-IB; Thu, 08 Mar 2018 11:27:26 -0600 Subject: Re: [PATCH] video: fbdev: via_aux_vt1632: remove VLA usage To: Emil Velikov , "Gustavo A. R. Silva" Cc: Florian Tobias Schandinat , Bartlomiej Zolnierkiewicz , linux-fbdev , "Linux-Kernel@Vger. Kernel. Org" , ML dri-devel References: <20180307195415.GA666@embeddedgus> From: "Gustavo A. R. Silva" Message-ID: <469f6c0d-186e-aaf7-469f-3d5b416b2b3f@embeddedor.com> Date: Thu, 8 Mar 2018 11:27:25 -0600 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit 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.175.117.58 X-Source-L: No X-Exim-ID: 1etzKA-0020Xd-IB X-Source: X-Source-Args: X-Source-Dir: X-Source-Sender: ([192.168.1.66]) [189.175.117.58]:52988 X-Source-Auth: garsilva@embeddedor.com X-Email-Count: 22 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 Hi Emil, On 03/08/2018 05:58 AM, Emil Velikov wrote: > Hi Gustavo, > > On 7 March 2018 at 19:54, Gustavo A. R. Silva wrote: >> In preparation to enabling -Wvla, remove VLA and replace it >> with a fixed-length array instead. Also, remove variable 'len'. >> > What is the reason behind adding -Wvla? Is there a thread some that I > can read up on? > Sure. This is the thread: https://lkml.org/lkml/2018/3/7/621 >> Notice that no new IDs have been added in seven years. >> >> Signed-off-by: Gustavo A. R. Silva >> --- >> drivers/video/fbdev/via/via_aux_vt1632.c | 6 +++--- >> 1 file changed, 3 insertions(+), 3 deletions(-) >> >> diff --git a/drivers/video/fbdev/via/via_aux_vt1632.c b/drivers/video/fbdev/via/via_aux_vt1632.c >> index d24f4cd..0cd0d2a 100644 >> --- a/drivers/video/fbdev/via/via_aux_vt1632.c >> +++ b/drivers/video/fbdev/via/via_aux_vt1632.c >> @@ -35,10 +35,10 @@ static void probe(struct via_aux_bus *bus, u8 addr) >> .addr = addr, >> .name = name}; >> /* check vendor id and device id */ >> - const u8 id[] = {0x06, 0x11, 0x92, 0x31}, len = ARRAY_SIZE(id); >> - u8 tmp[len]; >> + const u8 id[4] = {0x06, 0x11, 0x92, 0x31}; >> + u8 tmp[4]; >> >> - if (!via_aux_read(&drv, 0x00, tmp, len) || memcmp(id, tmp, len)) >> + if (!via_aux_read(&drv, 0x00, tmp, 4) || memcmp(id, tmp, 4)) > > Generally, hard coding a bunch of numbers like that makes for > confusing and fragile code. > You are correct. > A lot simpler and more obvious solution is like the following. > It silences the compiler warning (-Wvla - pedantic) you while keeping > the original clarity. > > const u8 id[] = {0x06, 0x11, 0x92, 0x31}, len = ARRAY_SIZE(id); > - u8 tmp[len]; > + u8 tmp[ARRAY_SIZE(id)]; // Using len causes a Wvla warning > Yeah, this works just fine. There are a total of four instances of this same issue in other files for the VIA component. I'll fix them and send a single patch shortly. Thanks for the feedback. I appreciate it. -- Gustavo