Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp617039ybi; Fri, 12 Jul 2019 01:50:47 -0700 (PDT) X-Google-Smtp-Source: APXvYqyp+DLa40RScbq7oEua0b7QEqQ62MsJzhgnQsJTnKrNRQ8mriI7zUmBgGRubzqsI3aMEcQQ X-Received: by 2002:a17:902:788f:: with SMTP id q15mr10209109pll.236.1562921447250; Fri, 12 Jul 2019 01:50:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1562921447; cv=none; d=google.com; s=arc-20160816; b=qI1Dbrwcf0sVqwOiE1fJUdkJHI/iATBK2EGLfZiGY2Ui1FgD3tM6rak9wVItl3inWf 8m4e9opeL/5Julj/R/JTEawNe7aABqXPNG3q85XPVF9TmA8uXYzF8EyyMS1V5WLj44Ll 0jdPw9oQT0j/Lok4Ck/Pshui8kYMtqnyKwqzZPWFhwW3F29mRXCWByS3Dc3kb1gfWY+t qnXjd/zQaCLiSA8NMpXuWE7ltArQQlJmK/cRt/R5q4TqywYLwq9vUOeX6/KrcDyqY/Z6 2J6Fd6dSdBTZBbC2WnGKops2H/hx9Qu/lyH8czexdjKJyLMml6I9VeJxq5Su/ak74OyF xg9g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=2TjfGvBFZ4x1DXdzJB+qB3H1+egMG60gdJ99RkTsxRU=; b=uQ9uqaCRn9S+mRVgxcTr69gLni13tJUFfWk//NQohsF9Sxd4M+gWRDDCs9pl5SMJdU qOzhnNkzcNhYS/0ChfJ5HfLPKN+1J6GJNgh92+qz7Ts/fgp3d9hP8TINbT2DOJazyHvT MYHwlwIlznmO/8DiAXiVYxSWRuO8QQ8GNxw6JYlk+gCqRs8dSC6B0TDmkx23J1ew9wUR 84dumrXQ0j09NGH/taZgBwiRn5kpsf0gQcr17sLKCYVGKE/QHFba2Yt88S5R+llnqPDF zmng9GBdaOyXDMP0OVIc1kHi63DrevR7yG1NKqtjqzXhAJsayEn6gU/Y+IuGB7GrlVrP UpEw== 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 f20si7533179pfn.166.2019.07.12.01.50.31; Fri, 12 Jul 2019 01:50:47 -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 S1726344AbfGLIta (ORCPT + 99 others); Fri, 12 Jul 2019 04:49:30 -0400 Received: from antares.kleine-koenig.org ([94.130.110.236]:42758 "EHLO antares.kleine-koenig.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726078AbfGLIta (ORCPT ); Fri, 12 Jul 2019 04:49:30 -0400 X-Greylist: delayed 337 seconds by postgrey-1.27 at vger.kernel.org; Fri, 12 Jul 2019 04:49:29 EDT Received: by antares.kleine-koenig.org (Postfix, from userid 1000) id 999A471D4A0; Fri, 12 Jul 2019 10:43:51 +0200 (CEST) Date: Fri, 12 Jul 2019 10:43:46 +0200 From: Uwe =?iso-8859-1?Q?Kleine-K=F6nig?= To: Marc Gonzalez Cc: Antti Palosaari , Mauro Carvalho Chehab , Jonathan =?iso-8859-1?Q?Neusch=E4fer?= , linux-media , LKML , MSM , Brad Love , Bjorn Andersson Subject: Re: [PATCH v3] media: si2168: Refactor command setup code Message-ID: <20190712084343.GA28962@taurus.defre.kleine-koenig.org> References: <544859b5-108a-1909-d612-64f67a02aeec@free.fr> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha512; protocol="application/pgp-signature"; boundary="5mCyUwZo2JvN/JJP" Content-Disposition: inline In-Reply-To: <544859b5-108a-1909-d612-64f67a02aeec@free.fr> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --5mCyUwZo2JvN/JJP Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: quoted-printable Hello, On Thu, Jul 04, 2019 at 12:33:22PM +0200, Marc Gonzalez wrote: > Refactor the command setup code, and let the compiler determine > the size of each command. >=20 > Reviewed-by: Jonathan Neusch=E4fer > Signed-off-by: Marc Gonzalez > --- > Changes from v1: > - Use a real function to populate struct si2168_cmd *cmd, and a trivial > macro wrapping it (macro because sizeof). > Changes from v2: > - Fix header mess > - Add Jonathan's tag > --- > drivers/media/dvb-frontends/si2168.c | 146 +++++++++------------------ > 1 file changed, 45 insertions(+), 101 deletions(-) >=20 > diff --git a/drivers/media/dvb-frontends/si2168.c b/drivers/media/dvb-fro= ntends/si2168.c > index c64b360ce6b5..5e81e076369c 100644 > --- a/drivers/media/dvb-frontends/si2168.c > +++ b/drivers/media/dvb-frontends/si2168.c > @@ -12,6 +12,16 @@ > =20 > static const struct dvb_frontend_ops si2168_ops; > =20 > +static void cmd_setup(struct si2168_cmd *cmd, char *args, int wlen, int = rlen) I'd add an "inline" here. And you could add a const for *args. > +{ > + memcpy(cmd->args, args, wlen); > + cmd->wlen =3D wlen; > + cmd->rlen =3D rlen; > +} > + > +#define CMD_SETUP(cmd, args, rlen) \ > + cmd_setup(cmd, args, sizeof(args) - 1, rlen) Here is the chance to add some static checking. Also it is a good habit to put parens around macro arguments. Something like: #define CMD_SETUP(cmd, args, rlen) ({ \ BUILD_BUG_ON(sizeof((args)) - 1 > SI2168_ARGLEN); cmd_setup((cmd), (args), __must_be_array((args)) + sizeof((args)) - 1, (rl= en)); Maybe let this macro live in drivers/media/dvb-frontends/si2168_priv.h where struct si2168_cmd is defined? I looked over the transformations in the rest of the patch and this looks good. Best regards Uwe --5mCyUwZo2JvN/JJP Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iQEzBAABCgAdFiEEfnIqFpAYrP8+dKQLwfwUeK3K7AkFAl0oSDwACgkQwfwUeK3K 7AkeBAf+I6QEDR298PCHto1ijeLdlLRFE7Ietsd+QeVUPOfW8FqfEowGHGd9gmPd kzR3NzgupP4MFxxw00BVwxf9iOeBMo94Q6ggPzBDI4X5BE71jFhwo3+QkJM7XuyX TAHq3pZ5aMInl27Kw54PxqCYRHPozZ4JxnsVys6kJvh/JkaiRMQApxm69ry10J23 u/gBDTnC80FsAjJ0QRSGBzjPytcx0UeAf/RXPodE5mtz0PAiyVefyK6+NRXrxEcW mZqfi8T4azYGcijVK4qU+bSAkRjwwk8Xdthkby1C7IhjR0yOSh2g0ZyH0hG3w4Xi M+2jYIacxtSrd3sDzOvT3k6eB7DS9w== =yXyE -----END PGP SIGNATURE----- --5mCyUwZo2JvN/JJP--