Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp4609860pxu; Thu, 10 Dec 2020 00:28:30 -0800 (PST) X-Google-Smtp-Source: ABdhPJzFbTNt8Mjda1o2NQIn1hRADjvg/txYGiFCw9HsJdFkzJooAYFY5AAqtJvXilUxuF5er/J+ X-Received: by 2002:aa7:cad2:: with SMTP id l18mr5604329edt.183.1607588910687; Thu, 10 Dec 2020 00:28:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607588910; cv=none; d=google.com; s=arc-20160816; b=t10krU9xBZa6T2/wSKxhm46qBPExUDRxINxw9Yk25v3zmw3dtZQygupd6XjpGG/Rne mc4mZa7AKjdBnNGm+ENSqfH/xOkiYNuFUwtSG4lUknkELbhQfbkSa/vdSHVnHkKEFfbg zrvj6xL9Gz+QuaUi8rtWtm9CyIZeCxjlgVVrqZE5K0mZ6v5oAB/lQf1ZYR2PjHYPwvnq X/SOHrLM1C5quot2NhS/KKfS8Rlo6xPHOlPXX3jBGBivHkPJZDEO3JCYenDB6Q4t4ifW jzne5ZF9hzauTmP9Mzs+rvNEoXgqHn2nkeZJxJt7Zv4gl7Qnq6qTsaxrm9mhk8zhrG9w S4dg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version; bh=bALKz7ou045OVVjtEQhAIxeM6l3p2vtzdMmOOh1FY44=; b=Y7hspC0kym3i4PqjP77QYiLGVnxQTEuik6aOx/B0DwJA5pomcUv0otVgxulM2cp4gF 9Y6IFpsekFpYGrMIoob/Ia/9bdmaj6jMbb167lyxI/RxLKg7WekfRfk1Ce6mMoaZya9c g4iiWnxZF3JeXJyxVeB9L0XikDKUOk7Na+IhaP7WW6h0sMGq3ysxrOEC7mLfx35edgoW Pk/oftD0lGCNqQl8bLxMOAHGJKkLv+vkBydhigRqgIC2KpKi5AeAWEH33w04iwB7bKpI PlT2+3+7A9SR+XVFSo9bFgoKEG/Bhere1H6ULJOA5nl4D09OKDLuJviISiYOCNk3djaO 21iw== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y4si2380328edp.451.2020.12.10.00.28.07; Thu, 10 Dec 2020 00:28:30 -0800 (PST) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387954AbgLJIY1 (ORCPT + 99 others); Thu, 10 Dec 2020 03:24:27 -0500 Received: from mail-ot1-f66.google.com ([209.85.210.66]:42105 "EHLO mail-ot1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387534AbgLJIYR (ORCPT ); Thu, 10 Dec 2020 03:24:17 -0500 Received: by mail-ot1-f66.google.com with SMTP id 11so4107159oty.9; Thu, 10 Dec 2020 00:24:02 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=bALKz7ou045OVVjtEQhAIxeM6l3p2vtzdMmOOh1FY44=; b=oQOltPAWfvqdlnPnjrv5e0E9YPFE2tY5HTj3gIEUTXcCo4A1Z6YuoJNJBrSuJw4oaM s4RCLHPVGyxZmkWo/BG06mn2aXg8UNxpFEagIjrmb4SOsHbY4ujE2wv/k99H2mCF69aG woVhpfapXtz4Joc1PV8vWduRAF6BUI7cJCpUuqp9fHaFMcN3xWCgqFABoxnOGQGCku06 PTlDCbSgbc2Awe4o7XOJgMQH5n7JMuQIvHLHD4oE6uI6bMacRZb6JgEkOH0ve+efdlX/ GvXufK0688GJu0HAt8oUEN0oqrorCYHdiTidcnTAE/mSefB37sfy8JAqmR2/vLApTRWt VE6A== X-Gm-Message-State: AOAM531cG3ArzJg7GrKyqCs6Mm6TvinmFBo+1HF3AI/1j1lvNuTxUynb 7gglq8iyoFtVPHcn7CDHgH7916oXKcYhyUMI4iA= X-Received: by 2002:a05:6830:210a:: with SMTP id i10mr4997267otc.145.1607588616676; Thu, 10 Dec 2020 00:23:36 -0800 (PST) MIME-Version: 1.0 References: <1607414643-25498-1-git-send-email-yoshihiro.shimoda.uh@renesas.com> <1607414643-25498-3-git-send-email-yoshihiro.shimoda.uh@renesas.com> In-Reply-To: From: Geert Uytterhoeven Date: Thu, 10 Dec 2020 09:23:25 +0100 Message-ID: Subject: Re: [PATCH 2/3] mfd: bd9571mwv: Make the driver more generic To: Yoshihiro Shimoda Cc: Marek Vasut , Lee Jones , Khiem Nguyen , Linux-Renesas , Linux Kernel Mailing List Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Shimoda-san, On Thu, Dec 10, 2020 at 5:10 AM Yoshihiro Shimoda wrote: > > From: Geert Uytterhoeven, Sent: Wednesday, December 9, 2020 10:26 PM > > On Tue, Dec 8, 2020 at 9:06 AM Yoshihiro Shimoda > > wrote: > > > > index 80c6ef0..57bdb6a 100644 > > > --- a/drivers/mfd/bd9571mwv.c > > > +++ b/drivers/mfd/bd9571mwv.c > > > > > @@ -127,13 +137,12 @@ static int bd9571mwv_identify(struct bd9571mwv *bd) > > > ret); > > > return ret; > > > } > > > - > > > - if (value != BD9571MWV_PRODUCT_CODE_VAL) { > > > + /* Confirm the product code */ > > > + if (value != bd->data->product_code_val) { > > > dev_err(dev, "Invalid product code ID %02x (expected %02x)\n", > > > - value, BD9571MWV_PRODUCT_CODE_VAL); > > > + value, bd->data->product_code_val); > > > return -EINVAL; > > > } > > > > Reading the product code register, and checking the product code value > > can be removed, as bd9571mwv_probe() has verified it already. > > Indeed. I'll remove this. OK. > > > --- a/include/linux/mfd/bd9571mwv.h > > > +++ b/include/linux/mfd/bd9571mwv.h > > > + */ > > > +struct bd957x_data { > > > + int product_code_val; > > > > unsigned int? > > We can remove this member. True. > Or, keeping this member and then we check the product code by this member > instead of switch() like below? > > /* No build test, JFYI */ > struct bd957x_data *data_array[] = { > &bd9571mwv_data, > &bd9574mwf_data, > }; > > for (i = 0; I < ARRAY_SIZE(data_array); i++) { > if (val == data_array[i].product_code_val) { > bd->data = data_array[i]; > break; > } > } Given we probably won't have more than a handful variants, I'm leaning towards the switch() approach. Gr{oetje,eeting}s, Geert -- Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@linux-m68k.org In personal conversations with technical people, I call myself a hacker. But when I'm talking to journalists I just say "programmer" or something like that. -- Linus Torvalds