Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 99D8AC6379F for ; Thu, 23 Feb 2023 08:20:10 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233369AbjBWIUJ (ORCPT ); Thu, 23 Feb 2023 03:20:09 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46170 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233508AbjBWIUF (ORCPT ); Thu, 23 Feb 2023 03:20:05 -0500 Received: from smtp15.bhosted.nl (smtp15.bhosted.nl [IPv6:2a02:9e0:8000::26]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 67E7B4C6F0 for ; Thu, 23 Feb 2023 00:20:02 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=protonic.nl; s=202111; h=message-id:references:in-reply-to:reply-to:subject:cc:to:from:date: content-transfer-encoding:content-type:mime-version:from; bh=dq7QMb++ghVX0hglhWq4dxVA8wD/izUizUd3XT6OvEQ=; b=COePPPmzUH4UN8knj1wE6FQ/2gp1MKJCXCF0Lzur9usYXiub/r14j88rymCi3gB3Z1I5Ed4ymU25B HT9OPbbBn9J9BrvjjQMQ63tc6b8nZLLO6q8cAC2yzah4EQLYUGHMcenVgq0t2XiQzWCX8R4i9nzqi8 sj7YI7D6p8UYrYfGqjbtsmtrcWxJ3PpGPa82ZUXtpunsC3xZfPLet6qmMJWP+w2Ea6I8Y8xd8bHelO 0zt9yZeEyHffIi5HiC6fIECpL7LgHHgPIf8iFuYdIF4MECtDW1cRRyt5ByjlHXtOL/SQF09FqSXdRM Z8XLfW+Ty5Tw9ceWESDcQeNN123c+jw== X-MSG-ID: dbf9e1f2-b352-11ed-8fb4-0050569d3a82 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit Date: Thu, 23 Feb 2023 09:19:57 +0100 From: Robin van der Gracht To: Andy Shevchenko Cc: Geert Uytterhoeven , Rob Herring , Krzysztof Kozlowski , "Russell King (Oracle)" , Raul E Rangel , Wolfram Sang , linux-kernel@vger.kernel.org, linux-i2c@vger.kernel.org, linux-usb@vger.kernel.org, Miguel Ojeda , Heikki Krogerus , Greg Kroah-Hartman , devicetree@vger.kernel.org Subject: Re: [PATCH v1 2/3] auxdisplay: ht16k33: Make use of device_get_match_data() Organization: Protonic Holland Reply-To: robin@protonic.nl Mail-Reply-To: robin@protonic.nl In-Reply-To: References: <20230221133307.20287-1-andriy.shevchenko@linux.intel.com> <20230221133307.20287-3-andriy.shevchenko@linux.intel.com> <0235f0fed989a8b027db720663699f5d@protonic.nl> Message-ID: X-Sender: robin@protonic.nl User-Agent: Roundcube Webmail/1.3.1 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2023-02-22 18:20, Andy Shevchenko wrote: > + Cc: OF bindings people for the mess with the IDs. > > On Wed, Feb 22, 2023 at 07:01:40PM +0200, Andy Shevchenko wrote: >> On Wed, Feb 22, 2023 at 05:46:00PM +0100, Robin van der Gracht wrote: >> > On 2023-02-21 18:48, Andy Shevchenko wrote: >> > > On Tue, Feb 21, 2023 at 05:10:00PM +0100, Robin van der Gracht wrote: >> > > > On 2023-02-21 14:40, Andy Shevchenko wrote: >> > > > > On Tue, Feb 21, 2023 at 03:33:06PM +0200, Andy Shevchenko wrote: > > ... > >> > > > > > - id = i2c_of_match_device(dev->driver->of_match_table, client); >> > > > > > - if (id) >> > > > > > - priv->type = (uintptr_t)id->data; >> > > > > > + priv->type = (uintptr_t)device_get_match_data(dev); >> > > > > >> > > > > Looking closer the I²C ID table should provide DISP_MATRIX to keep >> > > > > default and >> >> > > > > this needs to be not dropped. >> >> ^^^^^ (1) >> >> > > > > So, the question is what to do with unknown type then, return -EINVAL >> > > > > from probe()? >> > > > >> > > > If you leave out your addition of the DISP_UNKNOWN type, the default >> > > > type >> > > > will be DISP_MATRIX if no match is found, which is as it is now. >> > > > >> > > > In that case the following change should suffice: >> > > > >> > > > @@ -713,7 +715,6 @@ static int ht16k33_seg_probe(struct device *dev, >> > > > struct >> > > > ht16k33_priv *priv, >> > > > static int ht16k33_probe(struct i2c_client *client) >> > > > { >> > > > struct device *dev = &client->dev; >> > > > - const struct of_device_id *id; >> > > > struct ht16k33_priv *priv; >> > > > uint32_t dft_brightness; >> > > > int err; >> > > > @@ -728,9 +729,8 @@ static int ht16k33_probe(struct i2c_client >> > > > *client) >> > > > return -ENOMEM; >> > > > >> > > > priv->client = client; >> > > > - id = i2c_of_match_device(dev->driver->of_match_table, client); >> > > > - if (id) >> > > > - priv->type = (uintptr_t)id->data; >> > > > + priv->type = (uintptr_t)device_get_match_data(dev); >> > > > + >> > > > i2c_set_clientdata(client, priv); >> > > > >> > > > err = ht16k33_initialize(priv); >> > > > >> > > > Or do you think falling back to DISP_MATRIX if no match is found is >> > > > wrong? >> > > >> > > First of all, the I²C ID table should actually use DISP_MATRIX. >> > > >> > > Second, there are two points: >> > > >> > > - It would be nice to check if the OF ID table doesn't provide a setting >> > > (shouldn't we try I²C ID table and then, if still nothing, bail out?) >> > > >> > > - The I²C ID table can be extended in the future with another entry >> > > which >> > > may want to have different default >> > >> > For my understanding, please correct me if I'm wrong; >> > >> > For all methods of instantiation during ht16k33 probe, i2c_of_match_device() >> > matches the compatible strings in the OF ID table due to a call to >> > i2c_of_match_device_sysfs(). >> > >> > device_get_match_data() only matches the compatible strings in the OF ID >> > table for devicetree instantiation because of_match_device() won't match >> > is there is no actual of_node. >> >> That's half-true. On ACPI based platforms we may have no of_node and >> match >> against OF ID table. >> >> > So with only device_get_match_data() and a non devicetree instantiation, >> > priv->type will always be (uintptr_t)NULL = 0 = DISP_MATRIX. >> >> Yes. >> >> > Which effectively breaks i.e. user-space instantiation for other display >> > types which now do work due to i2c_of_match_device(). >> > (so my suggestion above is not sufficient). >> > >> > Are you proposing extending and searching the I2C ID table to work around >> > that? >> >> See (1) above. This is the downside I have noticed after sending this >> series. >> So, the I²C ID table match has to be restored, but the above mentioned >> issues >> with existing table are not gone, hence they need to be addressed in >> the next >> version. > > I see now what you mean. So, we have even more issues in this driver: > - I²C table is not in sync with all devices supported > - the OF ID table seems has something really badly formed for adafruit > (just a number after a comma) > > The latter shows how broken it is. The I²C ID table mechanism is used > as > a backward compatibility to the OF. Unfortunately, user space may not > provide > the data except in form of DT overlays, so for the legacy enumeration > we > have only device name, which is a set of 4 digits for adafruit case. > > Now imagine if by some reason we will get adafruit2 (you name it) with > the same schema. How I²C framework can understand that you meant > adafruit > and not adafruit2? Or did I miss something? I agree. I've added Geert Uytterhoeven to the CC. He added support for the adafruit segment displays. Maybe he has a comment on this. Kind regards, Robin van der Gracht