[3/3] platform/x86: int3472/discrete: Add support for sensor-drivers which expect clken + pled GPIOs
Message ID | 20221124200007.390901-4-hdegoede@redhat.com (mailing list archive) |
---|---|
State | Not Applicable |
Headers |
Received: from vger.kernel.org ([23.128.96.18]) by www.linuxtv.org with esmtp (Exim 4.92) (envelope-from <linux-media-owner@vger.kernel.org>) id 1oyIPS-00Bhr2-KZ; Thu, 24 Nov 2022 20:01:23 +0000 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229586AbiKXUBV (ORCPT <rfc822;mkrufky@linuxtv.org> + 1 other); Thu, 24 Nov 2022 15:01:21 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60366 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229568AbiKXUBU (ORCPT <rfc822;linux-media@vger.kernel.org>); Thu, 24 Nov 2022 15:01:20 -0500 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CA21F2AE2E for <linux-media@vger.kernel.org>; Thu, 24 Nov 2022 12:00:24 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1669320023; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=7vMfC4eODGr/G7aZBCsosazHm3HF6RAZ7q1rCBxpwOk=; b=UY/vdJJVHHtbY+07txQeBOk0kXciP8vgzZDHNcu1s2Ke3EVxvwPW83ZqUcHR70IkOCiXV8 OtXM8vVscmL0Pco4u3M48MFjcgwei4ga/kfgYkT51uuA9ScYw+2+GdGyahDsXnN09pq6ef wGre7syVQvPHk/nGlxJpmEA6giTdHW8= Received: from mimecast-mx02.redhat.com (mimecast-mx02.redhat.com [66.187.233.88]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-333-Q1mk0d26NpKJOlZz8toQCA-1; Thu, 24 Nov 2022 15:00:18 -0500 X-MC-Unique: Q1mk0d26NpKJOlZz8toQCA-1 Received: from smtp.corp.redhat.com (int-mx07.intmail.prod.int.rdu2.redhat.com [10.11.54.7]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx02.redhat.com (Postfix) with ESMTPS id 99FA4185A794; Thu, 24 Nov 2022 20:00:17 +0000 (UTC) Received: from shalem.redhat.com (unknown [10.39.195.152]) by smtp.corp.redhat.com (Postfix) with ESMTP id B3A141415114; Thu, 24 Nov 2022 20:00:15 +0000 (UTC) From: Hans de Goede <hdegoede@redhat.com> To: Mark Gross <markgross@kernel.org>, Andy Shevchenko <andy@kernel.org>, Daniel Scally <djrscally@gmail.com> Cc: Hans de Goede <hdegoede@redhat.com>, platform-driver-x86@vger.kernel.org, Sakari Ailus <sakari.ailus@linux.intel.com>, Kate Hsuan <hpa@redhat.com>, linux-media@vger.kernel.org Subject: [PATCH 3/3] platform/x86: int3472/discrete: Add support for sensor-drivers which expect clken + pled GPIOs Date: Thu, 24 Nov 2022 21:00:07 +0100 Message-Id: <20221124200007.390901-4-hdegoede@redhat.com> In-Reply-To: <20221124200007.390901-1-hdegoede@redhat.com> References: <20221124200007.390901-1-hdegoede@redhat.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 3.1 on 10.11.54.7 X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: <linux-media.vger.kernel.org> X-Mailing-List: linux-media@vger.kernel.org X-LSpam-Score: -2.5 (--) X-LSpam-Report: No, score=-2.5 required=5.0 tests=BAYES_00=-1.9,DKIMWL_WL_HIGH=0.001,DKIM_SIGNED=0.1,DKIM_VALID=-0.1,DKIM_VALID_AU=-0.1,HEADER_FROM_DIFFERENT_DOMAINS=0.5,MAILING_LIST_MULTI=-1 autolearn=ham autolearn_force=no |
Series |
platform/x86: int3472/discrete: Make it work with IPU6
|
|
Commit Message
Hans de Goede
Nov. 24, 2022, 8 p.m. UTC
The hm11b1 and ov01a1s sensor drivers shipped with the out of tree IPU6
driver, expect the clk_en GPIO to be modelled as a "clken" GPIO rather
then using the clk framework; and the hm11b1, ov01a1s and ov2740 driver
all 3 expect the privacy-led to be modelled as a "pled" GPIO, rather then
it being turned on/off at the same time as the clk.
Adjust how we handle the GPIOs on these sensors accordingly, for now at
least, so that the out of tree driver can work with standard distro kernels
through e.g. dkms. Otherwise users need to run a patched kernel just for
this small difference.
This of course needs to be revisited when we mainline these sensor drivers,
I can imagine the drivers getting clk-framework support when they are
mainlined and then at that same time their acpi HID can be dropped from
the use_gpio_for_clk_acpi_ids[] array.
Note there already is a mainline driver for the ov2740, but that is not
impacted by this change since atm it uses neither the clk framework nor
a "clken" GPIO.
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
---
Maybe we should patch the sensor drivers for sensors supported with
the IPU3 to also expect the privacy-led to always be a separate GPIO?
This way we can also avoid the camera LED briefly going on at boot,
when the driver is powering things up to read the sensor's ID register.
And I have also put looking at making the mainline ov2740 driver suitable
for use with the (out of tree) IPU6 driver on my TODO list.
---
drivers/platform/x86/intel/int3472/common.h | 2 +-
drivers/platform/x86/intel/int3472/discrete.c | 37 +++++++++++++++----
2 files changed, 31 insertions(+), 8 deletions(-)
Comments
Hi Hans, Thank you for the patch. On Thu, Nov 24, 2022 at 09:00:07PM +0100, Hans de Goede wrote: > The hm11b1 and ov01a1s sensor drivers shipped with the out of tree IPU6 > driver, expect the clk_en GPIO to be modelled as a "clken" GPIO rather > then using the clk framework; and the hm11b1, ov01a1s and ov2740 driver > all 3 expect the privacy-led to be modelled as a "pled" GPIO, rather then > it being turned on/off at the same time as the clk. I don't like this idea much. I see this as opening the door to other hacks in mainline just for the purpose of supporting out-of-tree drivers. That's not how we should operate upstream. Why can't we patch the out-of-tree drivers to use the clock framework, given that's what it will need to do in mainline ? That shouldn't be a too intrusive change. > Adjust how we handle the GPIOs on these sensors accordingly, for now at > least, so that the out of tree driver can work with standard distro kernels > through e.g. dkms. Otherwise users need to run a patched kernel just for > this small difference. > > This of course needs to be revisited when we mainline these sensor drivers, > I can imagine the drivers getting clk-framework support when they are > mainlined and then at that same time their acpi HID can be dropped from > the use_gpio_for_clk_acpi_ids[] array. > > Note there already is a mainline driver for the ov2740, but that is not > impacted by this change since atm it uses neither the clk framework nor > a "clken" GPIO. > > Signed-off-by: Hans de Goede <hdegoede@redhat.com> > --- > Maybe we should patch the sensor drivers for sensors supported with > the IPU3 to also expect the privacy-led to always be a separate GPIO? > > This way we can also avoid the camera LED briefly going on at boot, > when the driver is powering things up to read the sensor's ID register. To fix the privacy LED flickering problem correctly we need to avoid powering up sensor at probe time, as there are hardware designs that wire the privacy LED to the sensor power rails without any way to disable it in software. > And I have also put looking at making the mainline ov2740 driver suitable > for use with the (out of tree) IPU6 driver on my TODO list. > --- > drivers/platform/x86/intel/int3472/common.h | 2 +- > drivers/platform/x86/intel/int3472/discrete.c | 37 +++++++++++++++---- > 2 files changed, 31 insertions(+), 8 deletions(-) > > diff --git a/drivers/platform/x86/intel/int3472/common.h b/drivers/platform/x86/intel/int3472/common.h > index 53270d19c73a..58647d3084b9 100644 > --- a/drivers/platform/x86/intel/int3472/common.h > +++ b/drivers/platform/x86/intel/int3472/common.h > @@ -23,7 +23,7 @@ > #define INT3472_GPIO_TYPE_PRIVACY_LED 0x0d > > #define INT3472_PDEV_MAX_NAME_LEN 23 > -#define INT3472_MAX_SENSOR_GPIOS 3 > +#define INT3472_MAX_SENSOR_GPIOS 4 > > #define GPIO_REGULATOR_NAME_LENGTH 21 > #define GPIO_REGULATOR_SUPPLY_NAME_LENGTH 9 > diff --git a/drivers/platform/x86/intel/int3472/discrete.c b/drivers/platform/x86/intel/int3472/discrete.c > index 9159291be28a..bfcf8184db16 100644 > --- a/drivers/platform/x86/intel/int3472/discrete.c > +++ b/drivers/platform/x86/intel/int3472/discrete.c > @@ -216,6 +216,26 @@ static const char *int3472_dsm_type_to_func(u8 type) > return "unknown"; > } > > +/* > + * The hm11b1 and ov01a1s sensor drivers shipped with the out of tree IPU6 driver, > + * expect the clk_en GPIO to be modelled as a "clken" GPIO rather then as a clk and > + * the hm11b1, ov01a1s and ov2740 driver all 3 expect the privacy-led to be modelled > + * as a "pled" GPIO, rather then it being turned on/off at the same time as the clk. > + * > + * Note there also is a mainline driver for the ov2740, but that does not use > + * the clk framework atm either. > + * > + * Adjust how we handle the GPIOs on these sensors accordingly, for now at least. > + * This needs to be revisited when we mainline these sensor drivers / when we merge > + * the necessary changes in the ov2740 sensor driver so that it can work on the IPU6. > + */ > +static const struct acpi_device_id use_gpio_for_clk_acpi_ids[] = { > + { "HIMX11B1" }, /* hm11b1 */ > + { "OVTI01AS" }, /* ov01a1s */ > + { "INT3474" }, /* ov2740 */ > + {} > +}; > + > /** > * skl_int3472_handle_gpio_resources: Map PMIC resources to consuming sensor > * @ares: A pointer to a &struct acpi_resource > @@ -293,19 +313,22 @@ static int skl_int3472_handle_gpio_resources(struct acpi_resource *ares, > (polarity == GPIO_ACTIVE_HIGH) ? "high" : "low"); > > switch (type) { > + case INT3472_GPIO_TYPE_CLK_ENABLE: > + case INT3472_GPIO_TYPE_PRIVACY_LED: > + if (!acpi_match_device_ids(int3472->adev, use_gpio_for_clk_acpi_ids)) { > + ret = skl_int3472_map_gpio_to_clk(int3472, agpio, type); > + if (ret) > + err_msg = "Failed to map GPIO to clock\n"; > + > + break; > + } > + fallthrough; > case INT3472_GPIO_TYPE_RESET: > case INT3472_GPIO_TYPE_POWERDOWN: > ret = skl_int3472_map_gpio_to_sensor(int3472, agpio, func, polarity); > if (ret) > err_msg = "Failed to map GPIO pin to sensor\n"; > > - break; > - case INT3472_GPIO_TYPE_CLK_ENABLE: > - case INT3472_GPIO_TYPE_PRIVACY_LED: > - ret = skl_int3472_map_gpio_to_clk(int3472, agpio, type); > - if (ret) > - err_msg = "Failed to map GPIO to clock\n"; > - > break; > case INT3472_GPIO_TYPE_POWER_ENABLE: > ret = skl_int3472_register_regulator(int3472, agpio);
Hi Hans On 24/11/2022 20:00, Hans de Goede wrote: > The hm11b1 and ov01a1s sensor drivers shipped with the out of tree IPU6 > driver, expect the clk_en GPIO to be modelled as a "clken" GPIO rather > then using the clk framework; and the hm11b1, ov01a1s and ov2740 driver > all 3 expect the privacy-led to be modelled as a "pled" GPIO, rather then > it being turned on/off at the same time as the clk. > > Adjust how we handle the GPIOs on these sensors accordingly, for now at > least, so that the out of tree driver can work with standard distro kernels > through e.g. dkms. Otherwise users need to run a patched kernel just for > this small difference. > > This of course needs to be revisited when we mainline these sensor drivers, > I can imagine the drivers getting clk-framework support when they are > mainlined and then at that same time their acpi HID can be dropped from > the use_gpio_for_clk_acpi_ids[] array. > > Note there already is a mainline driver for the ov2740, but that is not > impacted by this change since atm it uses neither the clk framework nor > a "clken" GPIO. > > Signed-off-by: Hans de Goede <hdegoede@redhat.com> > --- > Maybe we should patch the sensor drivers for sensors supported with > the IPU3 to also expect the privacy-led to always be a separate GPIO? > > This way we can also avoid the camera LED briefly going on at boot, > when the driver is powering things up to read the sensor's ID register. > > And I have also put looking at making the mainline ov2740 driver suitable > for use with the (out of tree) IPU6 driver on my TODO list. > --- > drivers/platform/x86/intel/int3472/common.h | 2 +- > drivers/platform/x86/intel/int3472/discrete.c | 37 +++++++++++++++---- > 2 files changed, 31 insertions(+), 8 deletions(-) > > diff --git a/drivers/platform/x86/intel/int3472/common.h b/drivers/platform/x86/intel/int3472/common.h > index 53270d19c73a..58647d3084b9 100644 > --- a/drivers/platform/x86/intel/int3472/common.h > +++ b/drivers/platform/x86/intel/int3472/common.h > @@ -23,7 +23,7 @@ > #define INT3472_GPIO_TYPE_PRIVACY_LED 0x0d > > #define INT3472_PDEV_MAX_NAME_LEN 23 > -#define INT3472_MAX_SENSOR_GPIOS 3 > +#define INT3472_MAX_SENSOR_GPIOS 4 > > #define GPIO_REGULATOR_NAME_LENGTH 21 > #define GPIO_REGULATOR_SUPPLY_NAME_LENGTH 9 > diff --git a/drivers/platform/x86/intel/int3472/discrete.c b/drivers/platform/x86/intel/int3472/discrete.c > index 9159291be28a..bfcf8184db16 100644 > --- a/drivers/platform/x86/intel/int3472/discrete.c > +++ b/drivers/platform/x86/intel/int3472/discrete.c > @@ -216,6 +216,26 @@ static const char *int3472_dsm_type_to_func(u8 type) > return "unknown"; > } > > +/* > + * The hm11b1 and ov01a1s sensor drivers shipped with the out of tree IPU6 driver, > + * expect the clk_en GPIO to be modelled as a "clken" GPIO rather then as a clk and > + * the hm11b1, ov01a1s and ov2740 driver all 3 expect the privacy-led to be modelled > + * as a "pled" GPIO, rather then it being turned on/off at the same time as the clk. > + * > + * Note there also is a mainline driver for the ov2740, but that does not use > + * the clk framework atm either. > + * > + * Adjust how we handle the GPIOs on these sensors accordingly, for now at least. > + * This needs to be revisited when we mainline these sensor drivers / when we merge > + * the necessary changes in the ov2740 sensor driver so that it can work on the IPU6. > + */ I'm not really sure about this one though; wouldn't it be better to alter those sensor drivers to use the clock framework properly? Thanks Dan > +static const struct acpi_device_id use_gpio_for_clk_acpi_ids[] = { > + { "HIMX11B1" }, /* hm11b1 */ > + { "OVTI01AS" }, /* ov01a1s */ > + { "INT3474" }, /* ov2740 */ > + {} > +}; > + > /** > * skl_int3472_handle_gpio_resources: Map PMIC resources to consuming sensor > * @ares: A pointer to a &struct acpi_resource > @@ -293,19 +313,22 @@ static int skl_int3472_handle_gpio_resources(struct acpi_resource *ares, > (polarity == GPIO_ACTIVE_HIGH) ? "high" : "low"); > > switch (type) { > + case INT3472_GPIO_TYPE_CLK_ENABLE: > + case INT3472_GPIO_TYPE_PRIVACY_LED: > + if (!acpi_match_device_ids(int3472->adev, use_gpio_for_clk_acpi_ids)) { > + ret = skl_int3472_map_gpio_to_clk(int3472, agpio, type); > + if (ret) > + err_msg = "Failed to map GPIO to clock\n"; > + > + break; > + } > + fallthrough; > case INT3472_GPIO_TYPE_RESET: > case INT3472_GPIO_TYPE_POWERDOWN: > ret = skl_int3472_map_gpio_to_sensor(int3472, agpio, func, polarity); > if (ret) > err_msg = "Failed to map GPIO pin to sensor\n"; > > - break; > - case INT3472_GPIO_TYPE_CLK_ENABLE: > - case INT3472_GPIO_TYPE_PRIVACY_LED: > - ret = skl_int3472_map_gpio_to_clk(int3472, agpio, type); > - if (ret) > - err_msg = "Failed to map GPIO to clock\n"; > - > break; > case INT3472_GPIO_TYPE_POWER_ENABLE: > ret = skl_int3472_register_regulator(int3472, agpio);
Hi, On 11/25/22 17:07, Dan Scally wrote: > Hi Hans > > On 24/11/2022 20:00, Hans de Goede wrote: >> The hm11b1 and ov01a1s sensor drivers shipped with the out of tree IPU6 >> driver, expect the clk_en GPIO to be modelled as a "clken" GPIO rather >> then using the clk framework; and the hm11b1, ov01a1s and ov2740 driver >> all 3 expect the privacy-led to be modelled as a "pled" GPIO, rather then >> it being turned on/off at the same time as the clk. >> >> Adjust how we handle the GPIOs on these sensors accordingly, for now at >> least, so that the out of tree driver can work with standard distro kernels >> through e.g. dkms. Otherwise users need to run a patched kernel just for >> this small difference. >> >> This of course needs to be revisited when we mainline these sensor drivers, >> I can imagine the drivers getting clk-framework support when they are >> mainlined and then at that same time their acpi HID can be dropped from >> the use_gpio_for_clk_acpi_ids[] array. >> >> Note there already is a mainline driver for the ov2740, but that is not >> impacted by this change since atm it uses neither the clk framework nor >> a "clken" GPIO. >> >> Signed-off-by: Hans de Goede <hdegoede@redhat.com> >> --- >> Maybe we should patch the sensor drivers for sensors supported with >> the IPU3 to also expect the privacy-led to always be a separate GPIO? >> >> This way we can also avoid the camera LED briefly going on at boot, >> when the driver is powering things up to read the sensor's ID register. >> >> And I have also put looking at making the mainline ov2740 driver suitable >> for use with the (out of tree) IPU6 driver on my TODO list. >> --- >> drivers/platform/x86/intel/int3472/common.h | 2 +- >> drivers/platform/x86/intel/int3472/discrete.c | 37 +++++++++++++++---- >> 2 files changed, 31 insertions(+), 8 deletions(-) >> >> diff --git a/drivers/platform/x86/intel/int3472/common.h b/drivers/platform/x86/intel/int3472/common.h >> index 53270d19c73a..58647d3084b9 100644 >> --- a/drivers/platform/x86/intel/int3472/common.h >> +++ b/drivers/platform/x86/intel/int3472/common.h >> @@ -23,7 +23,7 @@ >> #define INT3472_GPIO_TYPE_PRIVACY_LED 0x0d >> #define INT3472_PDEV_MAX_NAME_LEN 23 >> -#define INT3472_MAX_SENSOR_GPIOS 3 >> +#define INT3472_MAX_SENSOR_GPIOS 4 >> #define GPIO_REGULATOR_NAME_LENGTH 21 >> #define GPIO_REGULATOR_SUPPLY_NAME_LENGTH 9 >> diff --git a/drivers/platform/x86/intel/int3472/discrete.c b/drivers/platform/x86/intel/int3472/discrete.c >> index 9159291be28a..bfcf8184db16 100644 >> --- a/drivers/platform/x86/intel/int3472/discrete.c >> +++ b/drivers/platform/x86/intel/int3472/discrete.c >> @@ -216,6 +216,26 @@ static const char *int3472_dsm_type_to_func(u8 type) >> return "unknown"; >> } >> +/* >> + * The hm11b1 and ov01a1s sensor drivers shipped with the out of tree IPU6 driver, >> + * expect the clk_en GPIO to be modelled as a "clken" GPIO rather then as a clk and >> + * the hm11b1, ov01a1s and ov2740 driver all 3 expect the privacy-led to be modelled >> + * as a "pled" GPIO, rather then it being turned on/off at the same time as the clk. >> + * >> + * Note there also is a mainline driver for the ov2740, but that does not use >> + * the clk framework atm either. >> + * >> + * Adjust how we handle the GPIOs on these sensors accordingly, for now at least. >> + * This needs to be revisited when we mainline these sensor drivers / when we merge >> + * the necessary changes in the ov2740 sensor driver so that it can work on the IPU6. >> + */ > > > I'm not really sure about this one though; wouldn't it be better to alter those sensor drivers to use the clock framework properly? Yes, Laurent more or less said the same thing; and I was already starting to think in this direction myself when typing the cover letter. So yes I agree with you and Laurent. That still leaves the question of what to do with devices with just a privacy LED without a clk-en though. Dan, do you have a list of sensors which currently are known to work / be used together with the IPU3 (and the int3472 discrete code) ? I know I will need to modifi the ov5693 code, but I wonder what other drivers I will need to modify ? I think I might just move those sensor-drivers over to using a GPIO for the privacy LED and just always register a GPIO for the privacy LED pin, does that sound like a good idea to you ? Anyways it is weekend now and I've already worked too many hours this week, so I'll take a look at this on Monday. Regards, Hans >> +static const struct acpi_device_id use_gpio_for_clk_acpi_ids[] = { >> + { "HIMX11B1" }, /* hm11b1 */ >> + { "OVTI01AS" }, /* ov01a1s */ >> + { "INT3474" }, /* ov2740 */ >> + {} >> +}; >> + >> /** >> * skl_int3472_handle_gpio_resources: Map PMIC resources to consuming sensor >> * @ares: A pointer to a &struct acpi_resource >> @@ -293,19 +313,22 @@ static int skl_int3472_handle_gpio_resources(struct acpi_resource *ares, >> (polarity == GPIO_ACTIVE_HIGH) ? "high" : "low"); >> switch (type) { >> + case INT3472_GPIO_TYPE_CLK_ENABLE: >> + case INT3472_GPIO_TYPE_PRIVACY_LED: >> + if (!acpi_match_device_ids(int3472->adev, use_gpio_for_clk_acpi_ids)) { >> + ret = skl_int3472_map_gpio_to_clk(int3472, agpio, type); >> + if (ret) >> + err_msg = "Failed to map GPIO to clock\n"; >> + >> + break; >> + } >> + fallthrough; >> case INT3472_GPIO_TYPE_RESET: >> case INT3472_GPIO_TYPE_POWERDOWN: >> ret = skl_int3472_map_gpio_to_sensor(int3472, agpio, func, polarity); >> if (ret) >> err_msg = "Failed to map GPIO pin to sensor\n"; >> - break; >> - case INT3472_GPIO_TYPE_CLK_ENABLE: >> - case INT3472_GPIO_TYPE_PRIVACY_LED: >> - ret = skl_int3472_map_gpio_to_clk(int3472, agpio, type); >> - if (ret) >> - err_msg = "Failed to map GPIO to clock\n"; >> - >> break; >> case INT3472_GPIO_TYPE_POWER_ENABLE: >> ret = skl_int3472_register_regulator(int3472, agpio); >
Morning Hans On 25/11/2022 18:38, Hans de Goede wrote: > Hi, > > On 11/25/22 17:07, Dan Scally wrote: >> Hi Hans >> >> On 24/11/2022 20:00, Hans de Goede wrote: >>> The hm11b1 and ov01a1s sensor drivers shipped with the out of tree IPU6 >>> driver, expect the clk_en GPIO to be modelled as a "clken" GPIO rather >>> then using the clk framework; and the hm11b1, ov01a1s and ov2740 driver >>> all 3 expect the privacy-led to be modelled as a "pled" GPIO, rather then >>> it being turned on/off at the same time as the clk. >>> >>> Adjust how we handle the GPIOs on these sensors accordingly, for now at >>> least, so that the out of tree driver can work with standard distro kernels >>> through e.g. dkms. Otherwise users need to run a patched kernel just for >>> this small difference. >>> >>> This of course needs to be revisited when we mainline these sensor drivers, >>> I can imagine the drivers getting clk-framework support when they are >>> mainlined and then at that same time their acpi HID can be dropped from >>> the use_gpio_for_clk_acpi_ids[] array. >>> >>> Note there already is a mainline driver for the ov2740, but that is not >>> impacted by this change since atm it uses neither the clk framework nor >>> a "clken" GPIO. >>> >>> Signed-off-by: Hans de Goede <hdegoede@redhat.com> >>> --- >>> Maybe we should patch the sensor drivers for sensors supported with >>> the IPU3 to also expect the privacy-led to always be a separate GPIO? >>> >>> This way we can also avoid the camera LED briefly going on at boot, >>> when the driver is powering things up to read the sensor's ID register. >>> >>> And I have also put looking at making the mainline ov2740 driver suitable >>> for use with the (out of tree) IPU6 driver on my TODO list. >>> --- >>> drivers/platform/x86/intel/int3472/common.h | 2 +- >>> drivers/platform/x86/intel/int3472/discrete.c | 37 +++++++++++++++---- >>> 2 files changed, 31 insertions(+), 8 deletions(-) >>> >>> diff --git a/drivers/platform/x86/intel/int3472/common.h b/drivers/platform/x86/intel/int3472/common.h >>> index 53270d19c73a..58647d3084b9 100644 >>> --- a/drivers/platform/x86/intel/int3472/common.h >>> +++ b/drivers/platform/x86/intel/int3472/common.h >>> @@ -23,7 +23,7 @@ >>> #define INT3472_GPIO_TYPE_PRIVACY_LED 0x0d >>> #define INT3472_PDEV_MAX_NAME_LEN 23 >>> -#define INT3472_MAX_SENSOR_GPIOS 3 >>> +#define INT3472_MAX_SENSOR_GPIOS 4 >>> #define GPIO_REGULATOR_NAME_LENGTH 21 >>> #define GPIO_REGULATOR_SUPPLY_NAME_LENGTH 9 >>> diff --git a/drivers/platform/x86/intel/int3472/discrete.c b/drivers/platform/x86/intel/int3472/discrete.c >>> index 9159291be28a..bfcf8184db16 100644 >>> --- a/drivers/platform/x86/intel/int3472/discrete.c >>> +++ b/drivers/platform/x86/intel/int3472/discrete.c >>> @@ -216,6 +216,26 @@ static const char *int3472_dsm_type_to_func(u8 type) >>> return "unknown"; >>> } >>> +/* >>> + * The hm11b1 and ov01a1s sensor drivers shipped with the out of tree IPU6 driver, >>> + * expect the clk_en GPIO to be modelled as a "clken" GPIO rather then as a clk and >>> + * the hm11b1, ov01a1s and ov2740 driver all 3 expect the privacy-led to be modelled >>> + * as a "pled" GPIO, rather then it being turned on/off at the same time as the clk. >>> + * >>> + * Note there also is a mainline driver for the ov2740, but that does not use >>> + * the clk framework atm either. >>> + * >>> + * Adjust how we handle the GPIOs on these sensors accordingly, for now at least. >>> + * This needs to be revisited when we mainline these sensor drivers / when we merge >>> + * the necessary changes in the ov2740 sensor driver so that it can work on the IPU6. >>> + */ >> >> I'm not really sure about this one though; wouldn't it be better to alter those sensor drivers to use the clock framework properly? > Yes, Laurent more or less said the same thing; and I was already starting > to think in this direction myself when typing the cover letter. > > So yes I agree with you and Laurent. That still leaves the question of what to do > with devices with just a privacy LED without a clk-en though. > > Dan, do you have a list of sensors which currently are known to work / be used > together with the IPU3 (and the int3472 discrete code) ? > > I know I will need to modifi the ov5693 code, but I wonder what other drivers > I will need to modify ? The ov5693, ov8865 and ov7251 are the upstream working ones. There's a couple more that need changes upstreaming, but I can handle those during that process. > > I think I might just move those sensor-drivers over to using a GPIO > for the privacy LED and just always register a GPIO for the privacy LED > pin, does that sound like a good idea to you ? Well if we can't handle it during the int3472 code then yes - I certainly don't have a better idea. > Anyways it is weekend now and I've already worked too many hours this week, > so I'll take a look at this on Monday. > > Regards, > > Hans > > > >>> +static const struct acpi_device_id use_gpio_for_clk_acpi_ids[] = { >>> + { "HIMX11B1" }, /* hm11b1 */ >>> + { "OVTI01AS" }, /* ov01a1s */ >>> + { "INT3474" }, /* ov2740 */ >>> + {} >>> +}; >>> + >>> /** >>> * skl_int3472_handle_gpio_resources: Map PMIC resources to consuming sensor >>> * @ares: A pointer to a &struct acpi_resource >>> @@ -293,19 +313,22 @@ static int skl_int3472_handle_gpio_resources(struct acpi_resource *ares, >>> (polarity == GPIO_ACTIVE_HIGH) ? "high" : "low"); >>> switch (type) { >>> + case INT3472_GPIO_TYPE_CLK_ENABLE: >>> + case INT3472_GPIO_TYPE_PRIVACY_LED: >>> + if (!acpi_match_device_ids(int3472->adev, use_gpio_for_clk_acpi_ids)) { >>> + ret = skl_int3472_map_gpio_to_clk(int3472, agpio, type); >>> + if (ret) >>> + err_msg = "Failed to map GPIO to clock\n"; >>> + >>> + break; >>> + } >>> + fallthrough; >>> case INT3472_GPIO_TYPE_RESET: >>> case INT3472_GPIO_TYPE_POWERDOWN: >>> ret = skl_int3472_map_gpio_to_sensor(int3472, agpio, func, polarity); >>> if (ret) >>> err_msg = "Failed to map GPIO pin to sensor\n"; >>> - break; >>> - case INT3472_GPIO_TYPE_CLK_ENABLE: >>> - case INT3472_GPIO_TYPE_PRIVACY_LED: >>> - ret = skl_int3472_map_gpio_to_clk(int3472, agpio, type); >>> - if (ret) >>> - err_msg = "Failed to map GPIO to clock\n"; >>> - >>> break; >>> case INT3472_GPIO_TYPE_POWER_ENABLE: >>> ret = skl_int3472_register_regulator(int3472, agpio);
Hi, On 11/28/22 08:39, Dan Scally wrote: > Morning Hans > > On 25/11/2022 18:38, Hans de Goede wrote: >> Hi, >> >> On 11/25/22 17:07, Dan Scally wrote: >>> Hi Hans >>> >>> On 24/11/2022 20:00, Hans de Goede wrote: >>>> The hm11b1 and ov01a1s sensor drivers shipped with the out of tree IPU6 >>>> driver, expect the clk_en GPIO to be modelled as a "clken" GPIO rather >>>> then using the clk framework; and the hm11b1, ov01a1s and ov2740 driver >>>> all 3 expect the privacy-led to be modelled as a "pled" GPIO, rather then >>>> it being turned on/off at the same time as the clk. >>>> >>>> Adjust how we handle the GPIOs on these sensors accordingly, for now at >>>> least, so that the out of tree driver can work with standard distro kernels >>>> through e.g. dkms. Otherwise users need to run a patched kernel just for >>>> this small difference. >>>> >>>> This of course needs to be revisited when we mainline these sensor drivers, >>>> I can imagine the drivers getting clk-framework support when they are >>>> mainlined and then at that same time their acpi HID can be dropped from >>>> the use_gpio_for_clk_acpi_ids[] array. >>>> >>>> Note there already is a mainline driver for the ov2740, but that is not >>>> impacted by this change since atm it uses neither the clk framework nor >>>> a "clken" GPIO. >>>> >>>> Signed-off-by: Hans de Goede <hdegoede@redhat.com> >>>> --- >>>> Maybe we should patch the sensor drivers for sensors supported with >>>> the IPU3 to also expect the privacy-led to always be a separate GPIO? >>>> >>>> This way we can also avoid the camera LED briefly going on at boot, >>>> when the driver is powering things up to read the sensor's ID register. >>>> >>>> And I have also put looking at making the mainline ov2740 driver suitable >>>> for use with the (out of tree) IPU6 driver on my TODO list. >>>> --- >>>> drivers/platform/x86/intel/int3472/common.h | 2 +- >>>> drivers/platform/x86/intel/int3472/discrete.c | 37 +++++++++++++++---- >>>> 2 files changed, 31 insertions(+), 8 deletions(-) >>>> >>>> diff --git a/drivers/platform/x86/intel/int3472/common.h b/drivers/platform/x86/intel/int3472/common.h >>>> index 53270d19c73a..58647d3084b9 100644 >>>> --- a/drivers/platform/x86/intel/int3472/common.h >>>> +++ b/drivers/platform/x86/intel/int3472/common.h >>>> @@ -23,7 +23,7 @@ >>>> #define INT3472_GPIO_TYPE_PRIVACY_LED 0x0d >>>> #define INT3472_PDEV_MAX_NAME_LEN 23 >>>> -#define INT3472_MAX_SENSOR_GPIOS 3 >>>> +#define INT3472_MAX_SENSOR_GPIOS 4 >>>> #define GPIO_REGULATOR_NAME_LENGTH 21 >>>> #define GPIO_REGULATOR_SUPPLY_NAME_LENGTH 9 >>>> diff --git a/drivers/platform/x86/intel/int3472/discrete.c b/drivers/platform/x86/intel/int3472/discrete.c >>>> index 9159291be28a..bfcf8184db16 100644 >>>> --- a/drivers/platform/x86/intel/int3472/discrete.c >>>> +++ b/drivers/platform/x86/intel/int3472/discrete.c >>>> @@ -216,6 +216,26 @@ static const char *int3472_dsm_type_to_func(u8 type) >>>> return "unknown"; >>>> } >>>> +/* >>>> + * The hm11b1 and ov01a1s sensor drivers shipped with the out of tree IPU6 driver, >>>> + * expect the clk_en GPIO to be modelled as a "clken" GPIO rather then as a clk and >>>> + * the hm11b1, ov01a1s and ov2740 driver all 3 expect the privacy-led to be modelled >>>> + * as a "pled" GPIO, rather then it being turned on/off at the same time as the clk. >>>> + * >>>> + * Note there also is a mainline driver for the ov2740, but that does not use >>>> + * the clk framework atm either. >>>> + * >>>> + * Adjust how we handle the GPIOs on these sensors accordingly, for now at least. >>>> + * This needs to be revisited when we mainline these sensor drivers / when we merge >>>> + * the necessary changes in the ov2740 sensor driver so that it can work on the IPU6. >>>> + */ >>> >>> I'm not really sure about this one though; wouldn't it be better to alter those sensor drivers to use the clock framework properly? >> Yes, Laurent more or less said the same thing; and I was already starting >> to think in this direction myself when typing the cover letter. >> >> So yes I agree with you and Laurent. That still leaves the question of what to do >> with devices with just a privacy LED without a clk-en though. >> >> Dan, do you have a list of sensors which currently are known to work / be used >> together with the IPU3 (and the int3472 discrete code) ? >> >> I know I will need to modifi the ov5693 code, but I wonder what other drivers >> I will need to modify ? > > > The ov5693, ov8865 and ov7251 are the upstream working ones. There's a couple more that need changes upstreaming, but I can handle those during that process. Ok thanks. >> I think I might just move those sensor-drivers over to using a GPIO >> for the privacy LED and just always register a GPIO for the privacy LED >> pin, does that sound like a good idea to you ? > > > Well if we can't handle it during the int3472 code then yes - I certainly don't have a better idea. I will patch the 3 sensors listed above to take an optional privacy LED GPIO then. I do plan to work on the sensor_power helper library which I discussed soon-ish since that should make things a lot easier, but for now I'll just do this the quick and dirty way, also to make backporting easier for distros (so that they can have a kernel which works with both IPU3 and the out-of-tree IPU6 stuff). Regards, Hans > >> Anyways it is weekend now and I've already worked too many hours this week, >> so I'll take a look at this on Monday. >> >> Regards, >> >> Hans >> >> >> >>>> +static const struct acpi_device_id use_gpio_for_clk_acpi_ids[] = { >>>> + { "HIMX11B1" }, /* hm11b1 */ >>>> + { "OVTI01AS" }, /* ov01a1s */ >>>> + { "INT3474" }, /* ov2740 */ >>>> + {} >>>> +}; >>>> + >>>> /** >>>> * skl_int3472_handle_gpio_resources: Map PMIC resources to consuming sensor >>>> * @ares: A pointer to a &struct acpi_resource >>>> @@ -293,19 +313,22 @@ static int skl_int3472_handle_gpio_resources(struct acpi_resource *ares, >>>> (polarity == GPIO_ACTIVE_HIGH) ? "high" : "low"); >>>> switch (type) { >>>> + case INT3472_GPIO_TYPE_CLK_ENABLE: >>>> + case INT3472_GPIO_TYPE_PRIVACY_LED: >>>> + if (!acpi_match_device_ids(int3472->adev, use_gpio_for_clk_acpi_ids)) { >>>> + ret = skl_int3472_map_gpio_to_clk(int3472, agpio, type); >>>> + if (ret) >>>> + err_msg = "Failed to map GPIO to clock\n"; >>>> + >>>> + break; >>>> + } >>>> + fallthrough; >>>> case INT3472_GPIO_TYPE_RESET: >>>> case INT3472_GPIO_TYPE_POWERDOWN: >>>> ret = skl_int3472_map_gpio_to_sensor(int3472, agpio, func, polarity); >>>> if (ret) >>>> err_msg = "Failed to map GPIO pin to sensor\n"; >>>> - break; >>>> - case INT3472_GPIO_TYPE_CLK_ENABLE: >>>> - case INT3472_GPIO_TYPE_PRIVACY_LED: >>>> - ret = skl_int3472_map_gpio_to_clk(int3472, agpio, type); >>>> - if (ret) >>>> - err_msg = "Failed to map GPIO to clock\n"; >>>> - >>>> break; >>>> case INT3472_GPIO_TYPE_POWER_ENABLE: >>>> ret = skl_int3472_register_regulator(int3472, agpio); >
diff --git a/drivers/platform/x86/intel/int3472/common.h b/drivers/platform/x86/intel/int3472/common.h index 53270d19c73a..58647d3084b9 100644 --- a/drivers/platform/x86/intel/int3472/common.h +++ b/drivers/platform/x86/intel/int3472/common.h @@ -23,7 +23,7 @@ #define INT3472_GPIO_TYPE_PRIVACY_LED 0x0d #define INT3472_PDEV_MAX_NAME_LEN 23 -#define INT3472_MAX_SENSOR_GPIOS 3 +#define INT3472_MAX_SENSOR_GPIOS 4 #define GPIO_REGULATOR_NAME_LENGTH 21 #define GPIO_REGULATOR_SUPPLY_NAME_LENGTH 9 diff --git a/drivers/platform/x86/intel/int3472/discrete.c b/drivers/platform/x86/intel/int3472/discrete.c index 9159291be28a..bfcf8184db16 100644 --- a/drivers/platform/x86/intel/int3472/discrete.c +++ b/drivers/platform/x86/intel/int3472/discrete.c @@ -216,6 +216,26 @@ static const char *int3472_dsm_type_to_func(u8 type) return "unknown"; } +/* + * The hm11b1 and ov01a1s sensor drivers shipped with the out of tree IPU6 driver, + * expect the clk_en GPIO to be modelled as a "clken" GPIO rather then as a clk and + * the hm11b1, ov01a1s and ov2740 driver all 3 expect the privacy-led to be modelled + * as a "pled" GPIO, rather then it being turned on/off at the same time as the clk. + * + * Note there also is a mainline driver for the ov2740, but that does not use + * the clk framework atm either. + * + * Adjust how we handle the GPIOs on these sensors accordingly, for now at least. + * This needs to be revisited when we mainline these sensor drivers / when we merge + * the necessary changes in the ov2740 sensor driver so that it can work on the IPU6. + */ +static const struct acpi_device_id use_gpio_for_clk_acpi_ids[] = { + { "HIMX11B1" }, /* hm11b1 */ + { "OVTI01AS" }, /* ov01a1s */ + { "INT3474" }, /* ov2740 */ + {} +}; + /** * skl_int3472_handle_gpio_resources: Map PMIC resources to consuming sensor * @ares: A pointer to a &struct acpi_resource @@ -293,19 +313,22 @@ static int skl_int3472_handle_gpio_resources(struct acpi_resource *ares, (polarity == GPIO_ACTIVE_HIGH) ? "high" : "low"); switch (type) { + case INT3472_GPIO_TYPE_CLK_ENABLE: + case INT3472_GPIO_TYPE_PRIVACY_LED: + if (!acpi_match_device_ids(int3472->adev, use_gpio_for_clk_acpi_ids)) { + ret = skl_int3472_map_gpio_to_clk(int3472, agpio, type); + if (ret) + err_msg = "Failed to map GPIO to clock\n"; + + break; + } + fallthrough; case INT3472_GPIO_TYPE_RESET: case INT3472_GPIO_TYPE_POWERDOWN: ret = skl_int3472_map_gpio_to_sensor(int3472, agpio, func, polarity); if (ret) err_msg = "Failed to map GPIO pin to sensor\n"; - break; - case INT3472_GPIO_TYPE_CLK_ENABLE: - case INT3472_GPIO_TYPE_PRIVACY_LED: - ret = skl_int3472_map_gpio_to_clk(int3472, agpio, type); - if (ret) - err_msg = "Failed to map GPIO to clock\n"; - break; case INT3472_GPIO_TYPE_POWER_ENABLE: ret = skl_int3472_register_regulator(int3472, agpio);