Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp3074122ybi; Tue, 2 Jul 2019 01:39:38 -0700 (PDT) X-Google-Smtp-Source: APXvYqxS4YEuBW050h2f5VdiPIVgtlhxXBNKTtX0/eL6yWfWIuKMsZ0rlDjmulxfv59ZSjc4VfGt X-Received: by 2002:a17:902:d20a:: with SMTP id t10mr33054967ply.52.1562056778396; Tue, 02 Jul 2019 01:39:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1562056778; cv=none; d=google.com; s=arc-20160816; b=IN5hjQ+jmZJRFNvVfVtIARwBTXLdJ+xFpYd8265qNC+j+R9YMblo5BL+Qhas7xqFsy +5F3Xe/XdsLtcQHAsMVum4MVG0j+qzlgmMMYH18VDn0JN7027F5dzBRW++T3yWHVOD9Z AI2U9C/EuTiRGw+0NosMGD4EA6o6N1cyNeKoCFSVsRgzBER8+CLiPsbTPGCe6O2S+I73 4SEAQs7QJIrF7Kd9WZRC/x2B+kYrqrdvZaO1kCiSgcGiPQgvZWasLPhcC8jjOUqdK585 Wzda2eHntY988TMgbsFF5b7sFPq+V7eeFCJ5S8Kxnd9QSXYAVRheLbfRxOFPc6wM+ZEi PyCg== 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:references:cc:to:from:subject; bh=Q824hHWrv6SyAD+un/ab6N8HCz+BWUYZ09W4tDZ8Eyc=; b=u525wmB+0ex4JLWo77h+Z+xAqNYzjVauFz0/IpUhhaACC/h3U5ls4WeuZOMhjjQH+u wWuVIpuLRYy0lUqVOvKBaNI7eA3NrXopzsZW+sBJ9Pvtd5SVMrvdMBAb59l0enEEBzSm fui+eJY9WP5VZCjA/DfNsg9ELQLjpiJhem2J6p+vNbnJyWnby+srzi05PX/yDY6GwAKA cMPCCkxQzQ4l1igMWpwBErouFNKfJqn4JNoAPg4mnzuFRGW/Qc/Y2WDerYjnre09VhKy Lj3Q8hGMo59ncqN+IcJA+UVCHfBBWdFmKmJH4WMmUrvehfNrf+lTru406gmaGBK/js4b XRRg== 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 l13si1672533pjq.69.2019.07.02.01.39.22; Tue, 02 Jul 2019 01:39:38 -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 S1726526AbfGBIhc (ORCPT + 99 others); Tue, 2 Jul 2019 04:37:32 -0400 Received: from ns.iliad.fr ([212.27.33.1]:56440 "EHLO ns.iliad.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725940AbfGBIhc (ORCPT ); Tue, 2 Jul 2019 04:37:32 -0400 Received: from ns.iliad.fr (localhost [127.0.0.1]) by ns.iliad.fr (Postfix) with ESMTP id EC3B720BC5; Tue, 2 Jul 2019 10:37:28 +0200 (CEST) Received: from [192.168.108.49] (freebox.vlq16.iliad.fr [213.36.7.13]) by ns.iliad.fr (Postfix) with ESMTP id 74BF22079D; Tue, 2 Jul 2019 10:37:28 +0200 (CEST) Subject: Re: [PATCH v1] media: si2168: Refactor command setup code From: Marc Gonzalez To: Antti Palosaari , Mauro Carvalho Chehab Cc: linux-media , LKML , =?UTF-8?Q?Jonathan_Neusch=c3=a4fer?= , Bjorn Andersson , Brad Love References: <6a8f9a5b-2e88-8c26-440b-76af0d91eda6@free.fr> Message-ID: <5cdfcd0d-067b-16f0-1860-36997c1f04ee@free.fr> Date: Tue, 2 Jul 2019 10:37:28 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.6.1 MIME-Version: 1.0 In-Reply-To: <6a8f9a5b-2e88-8c26-440b-76af0d91eda6@free.fr> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit X-Virus-Scanned: ClamAV using ClamSMTP ; ns.iliad.fr ; Tue Jul 2 10:37:28 2019 +0200 (CEST) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 01/07/2019 13:44, Marc Gonzalez wrote: > By refactoring the command setup code, we can let the compiler > determine the size of each command. > > Signed-off-by: Marc Gonzalez > --- > drivers/media/dvb-frontends/si2168.c | 142 ++++++++------------------- > 1 file changed, 41 insertions(+), 101 deletions(-) > > diff --git a/drivers/media/dvb-frontends/si2168.c b/drivers/media/dvb-frontends/si2168.c > index 168c503e9154..19398f041c79 100644 > --- a/drivers/media/dvb-frontends/si2168.c > +++ b/drivers/media/dvb-frontends/si2168.c > @@ -11,6 +11,12 @@ > > static const struct dvb_frontend_ops si2168_ops; > > +#define CMD_SETUP(cmd, __args, __rlen) do { \ > + int wlen = sizeof(__args) - 1; \ > + memcpy(cmd.args, __args, wlen); \ > + cmd.wlen = wlen; cmd.rlen = __rlen; \ > +} while (0) > + I'm planning on sending a v2 where drivers/media/tuners/si2157.c is refactored the same way. Not sure where to store the macro. Maybe include/media/dvb_frontend.h ? Regards.