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 BA1D7C6FD1F for ; Thu, 16 Mar 2023 09:04:55 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230160AbjCPJEm (ORCPT ); Thu, 16 Mar 2023 05:04:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37258 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230124AbjCPJEh (ORCPT ); Thu, 16 Mar 2023 05:04:37 -0400 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 5FFBE8A76 for ; Thu, 16 Mar 2023 02:03:47 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1678957426; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=Y1rEqwiPnTPfVSZn3K2HCzTZptxivznkp3it79y9uvo=; b=NMAfs+BAKnRBJpJlUAHzPluqWJWqGM9XB4AkdzpyBYu8oZsut6jJcjUJZzUNB2q8ALhxb/ osXMbeHP/3ytDFwhM0A7WxWrvRbpzk4Q7FepLJEbIYdkkJJF9IA7741Ha5Uc7GxIkKT6rR YZCm/yB9XDhfe6cb5ZH+S0H/u2ZP//M= Received: from mail-ed1-f72.google.com (mail-ed1-f72.google.com [209.85.208.72]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-647-tCSJh_H0MHKMWqpBWfAn7A-1; Thu, 16 Mar 2023 05:03:45 -0400 X-MC-Unique: tCSJh_H0MHKMWqpBWfAn7A-1 Received: by mail-ed1-f72.google.com with SMTP id y24-20020aa7ccd8000000b004be3955a42eso2042392edt.22 for ; Thu, 16 Mar 2023 02:03:45 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; t=1678957424; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=Y1rEqwiPnTPfVSZn3K2HCzTZptxivznkp3it79y9uvo=; b=KNDn4Nk2ARvi9F0tRCEhlPl3yp+u+f1Sl5umdJLMLaaitWv+k+35zYN7+Gna7t7y2J m800WxcWNvmANQN3c++bkHfPJYLDhwn+VUwQ7jEXtEKkatgDLmG/qAEENJ1TBlYeQWCC eRr2FpWHk7Tbf+3MoaswGACh5+xOWQUbcWJhPyL2SwPRtSl4dypCD2K6qfsGjtssfRc0 yTdyly4GzQY9/h6rRg4751T3Jq9oZw+DkzumWfbYQtakx5GSgR/m9pguNylSwcfyOhBY eSWNVASoNtEs3kStx7kG61la35HawGjmSiz9BjUWOjkWa/LidgdpNVGLXSIM1TW2qObB bkCg== X-Gm-Message-State: AO0yUKVZDAJA2SMZy/K60djx2C8lp5LWHrJ519Jy2SSN+752PWgdKQYj +G44xN9rtQ5B2foNoCkBHNS7fetzENdlUiOGdSC4aFwD//55kKOP0EyZatmPbopLozu9wvo4aqi ZE0KbXN99w2jZR6YCF+WembLu X-Received: by 2002:a50:ee8e:0:b0:4af:7bdc:188e with SMTP id f14-20020a50ee8e000000b004af7bdc188emr5842279edr.16.1678957424066; Thu, 16 Mar 2023 02:03:44 -0700 (PDT) X-Google-Smtp-Source: AK7set9I1Tl9ju4fSq6Yb1KDNKoBPH2KbQsxMJ2WNpnQ2c8lNJ4tK8kjfFo8qnhB9eBO3bhT2Pcw1w== X-Received: by 2002:a50:ee8e:0:b0:4af:7bdc:188e with SMTP id f14-20020a50ee8e000000b004af7bdc188emr5842268edr.16.1678957423784; Thu, 16 Mar 2023 02:03:43 -0700 (PDT) Received: from ?IPV6:2001:1c00:c32:7800:5bfa:a036:83f0:f9ec? (2001-1c00-0c32-7800-5bfa-a036-83f0-f9ec.cable.dynamic.v6.ziggo.nl. [2001:1c00:c32:7800:5bfa:a036:83f0:f9ec]) by smtp.gmail.com with ESMTPSA id b12-20020a170906038c00b00924d38bbdc0sm3592833eja.105.2023.03.16.02.03.43 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 16 Mar 2023 02:03:43 -0700 (PDT) Message-ID: <346c376e-01ed-267e-b1c8-ee42c345d03f@redhat.com> Date: Thu, 16 Mar 2023 10:03:42 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.7.1 Subject: Re: [PATCH v2 0/3] media: pci: intel: ivsc: Add driver of Intel Visual Sensing Controller(IVSC) To: "Wu, Wentong" , Sakari Ailus Cc: "mchehab@kernel.org" , "linux-media@vger.kernel.org" , "Pandruvada, Srinivas" , "pierre-louis.bossart@linux.intel.com" , "Wang, Zhifeng" , "Ye, Xiang" , "Qiu, Tian Shu" , "Cao, Bingbu" , "linux-kernel@vger.kernel.org" References: <20230213022347.2480307-1-wentong.wu@intel.com> <4c3ba301-6241-f2f4-f139-b4f4a0cd6223@redhat.com> Content-Language: en-US, nl From: Hans de Goede In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On 3/16/23 03:58, Wu, Wentong wrote: > > >> -----Original Message----- >> From: Hans de Goede >> Sent: Thursday, March 9, 2023 11:24 PM >> >> > attachments> >> >> Hi Wentong, >> >> On 3/9/23 15:29, Wu, Wentong wrote: >>> Hi Hans, >>> >>> Thanks >>> >>> And AFAICT, there is no IVSC device on your Dell Latitude 9420 where the >> platform is based on TGL instead of ADL, and I have never heard IVSC runs on >> TGL, if no IVSC, INT3472 will control sensor's power. >>> And I will double confirm with people who know dell product well tomorrow. >> >> Ah, I was under the impression that there was an IVSC there because: >> >> 1. The sensor driver for the used sensor (tries to) poke the IVSC 2. Things did not >> work without building the IVSC drivers, but that might >> be due to a dependency on the LCJA GPIO expander instead > > Below is your dmesg log, the required SPI controller for IVSC isn't here. > > [ 35.538114] ljca 2-6:1.0: acked sem wait timed out ret:0 timeout:20 ack:0 > [ 35.538129] ljca 2-6:1.0: MNG_ENUM_SPI failed ret:-110 len:7 num:0 > [ 35.538621] ljca 2-6:1.0: LJCA USB device init success > [ 35.538776] usbcore: registered new interface driver ljca > > Also I checked your SSDT, there is no IVSC device and the sensor device depends on > INT3472 instead of IVSC device as on my setup. Ack. >> But you might very well be right, that would also explain the "intel vsc not ready" >> messages in dmesg. >> >> If with the IVSC case the IVSC controls the power to the sensor too, then >> another option might be to model the I2C-switch + the power-control as a >> powerdown GPIO for the sensor, which most sensor drivers already try to use. >> The advantage of doing this would be that GPIO lookups can reference the GPIO >> provider + consumer by device-name so then we don't need to have both >> devices instantiated at the time of >> adding the GPIO lookup. And in that case we could e.g. add the lookup >> before registering the I2C controller. > > Can we add IVSC device to acpi_honor_dep_ids, so that when everything is done during > mei_ace probe, acpi_dev_clear_dependencies can make sensor start probe? Does the sensor ACPI device node have an ACPI _DEP on the IVSC device ? If yes, then yes we can add the IVSC device to acpi_honor_dep_id and make mei_ace probe call acpi_dev_clear_dependencies(). Regards, Hans >> Sakari, what do you think of instead of using runtime-pm + devlinks having the >> IVSC code export a powerdown GPIO to the sensor ? >> >> This also decouples the ivsc powerstate from the sensor power-state which >> might be useful if we ever want to use some of the more advanced ivsc features, >> where AFAICT the ivsc fully controls the sensor. >> >> Regards, >> >> Hans >> >> >> >> >>>> -----Original Message----- >>>> From: Hans de Goede >>>> Sent: Thursday, March 9, 2023 9:30 PM >>>> To: Wu, Wentong >>>> Subject: Re: [PATCH v2 0/3] media: pci: intel: ivsc: Add driver of >>>> Intel Visual Sensing Controller(IVSC) >>>> >>>> Hi Wentong, >>>> >>>> Attached are the requested dmesg + acpidump for the Dell Latitude 9420. >>>> >>>> Regards, >>>> >>>> Hans >>>> >>>> >>>> >>>> >>>> On 3/9/23 14:21, Wu, Wentong wrote: >>>>> Hi >>>>> >>>>>> -----Original Message----- >>>>>> From: Hans de Goede >>>>>> Sent: Thursday, March 9, 2023 5:28 PM >>>>>> >>>>>> Hi, >>>>>> >>>>>> On 3/9/23 02:08, Wu, Wentong wrote: >>>>>>> >>>>>>> >>>>>>>> -----Original Message----- >>>>>>>> From: Hans de Goede >>>>>>>> Sent: Tuesday, March 7, 2023 5:10 PM >>>>>>>> >>>>>>>> Hi, >>>>>>>> >>>>>>>> On 3/7/23 09:40, Wu, Wentong wrote: >>>>>>>>> >>>>>>>>> >>>>>>>>>> -----Original Message----- >>>>>>>>>> From: Sakari Ailus >>>>>>>>>> Sent: Tuesday, March 7, 2023 4:30 PM >>>>>>>>>> >>>>>>>>>> Hi Wentong, >>>>>>>>>> >>>>>>>>>> On Tue, Mar 07, 2023 at 08:17:04AM +0000, Wu, Wentong wrote: >>>>>>>>>>> >>>>>>>>>>> >>>>>>>>>>>> -----Original Message----- >>>>>>>>>>>> From: Hans de Goede >>>>>>>>>>>> Sent: Wednesday, March 1, 2023 6:42 PM >>>>>>>>>>>> >>>>>>>>>>>> Hi, >>>>>>>>>>>> >>>>>>>>>>>> On 3/1/23 11:34, Sakari Ailus wrote: >>>>>>>>>>>>> Hi Wentong, >>>>>>>>>>>>> >>>>>>>>>>>>> On Mon, Feb 13, 2023 at 10:23:44AM +0800, Wentong Wu wrote: >>>>>>>>>>>>>> Intel Visual Sensing Controller (IVSC), codenamed "Clover >>>>>>>>>>>>>> Falls", is a companion chip designed to provide secure and >>>>>>>>>>>>>> low power vision capability to IA platforms. IVSC is >>>>>>>>>>>>>> available in existing commercial platforms from multiple OEMs. >>>>>>>>>>>>>> >>>>>>>>>>>>>> The primary use case of IVSC is to bring in context awareness. >>>>>>>>>>>>>> IVSC interfaces directly with the platform main camera >>>>>>>>>>>>>> sensor via a CSI-2 link and processes the image data with >>>>>>>>>>>>>> the embedded AI engine. The detected events are sent over >>>>>>>>>>>>>> I2C to ISH (Intel Sensor Hub) for additional data fusion >>>>>>>>>>>>>> from multiple >>>> sensors. >>>>>>>>>>>>>> The fusion results are used to implement advanced use cases like: >>>>>>>>>>>>>> - Face detection to unlock screen >>>>>>>>>>>>>> - Detect user presence to manage backlight setting or >>>>>>>>>>>>>> waking up system >>>>>>>>>>>>>> >>>>>>>>>>>>>> Since the Image Processing Unit(IPU) used on the host >>>>>>>>>>>>>> processor needs to configure the CSI-2 link in normal >>>>>>>>>>>>>> camera usages, the >>>>>>>>>>>>>> CSI-2 link and camera sensor can only be used in >>>>>>>>>>>>>> mutually-exclusive ways by host IPU and IVSC. By default >>>>>>>>>>>>>> the IVSC owns the CSI-2 link and camera sensor. The IPU >>>>>>>>>>>>>> driver can take ownership of the CSI-2 link and camera >>>>>>>>>>>>>> sensor using interfaces provided >>>>>>>>>> by this IVSC driver. >>>>>>>>>>>>>> >>>>>>>>>>>>>> Switching ownership requires an interface with two >>>>>>>>>>>>>> different hardware modules inside IVSC. The software >>>>>>>>>>>>>> interface to these modules is via Intel MEI (The Intel >> Management Engine) commands. >>>>>>>>>>>>>> These two hardware modules have two different MEI UUIDs to >>>>>>>>>>>>>> enumerate. These hardware >>>>>>>>>>>> modules are: >>>>>>>>>>>>>> - ACE (Algorithm Context Engine): This module is for >>>>>>>>>>>>>> algorithm computing when IVSC owns camera sensor. Also ACE >>>>>>>>>>>>>> module controls camera sensor's ownership. This hardware >>>>>>>>>>>>>> module is used to set ownership >>>>>>>>>>>> of camera sensor. >>>>>>>>>>>>>> - CSI (Camera Serial Interface): This module is used to >>>>>>>>>>>>>> route camera sensor data either to IVSC or to host for IPU >>>>>>>>>>>>>> driver and >>>>>>>>>> application. >>>>>>>>>>>>>> >>>>>>>>>>>>>> IVSC also provides a privacy mode. When privacy mode is >>>>>>>>>>>>>> turned on, camera sensor can't be used. This means that >>>>>>>>>>>>>> both ACE and host IPU can't get image data. And when this >>>>>>>>>>>>>> mode is turned on, host IPU driver is informed via a >>>>>>>>>>>>>> registered callback, so that user can be >>>>>>>>>> notified. >>>>>>>>>>>>>> >>>>>>>>>>>>>> In summary, to acquire ownership of camera by IPU driver, >>>>>>>>>>>>>> first ACE module needs to be informed of ownership and then >>>>>>>>>>>>>> to setup MIPI CSI-2 link for the camera sensor and IPU. >>>>>>>>>>>>> >>>>>>>>>>>>> I thought this for a while and did some research, and I can >>>>>>>>>>>>> suggest the >>>>>>>>>>>>> following: >>>>>>>>>>>>> >>>>>>>>>>>>> - The IVSC sub-device implements a control for privacy >>>>>>>> (V4L2_CID_PRIVACY >>>>>>>>>>>>> is a good fit). >>>>>>>>>>>>> >>>>>>>>>>>>> - Camera sensor access needs to be requested from IVSC >>>>>>>>>>>>> before accessing >>>>>>>>>> the >>>>>>>>>>>>> sensor via I²C. The IVSC ownership control needs to be in the >> right >>>>>>>>>>>>> setting for this to work, and device links can be used for >>>>>>>>>>>>> that >>>> purpose >>>>>>>>>>>>> (see device_link_add()). With DL_FLAG_PM_RUNTIME and >>>>>>>>>>>> DL_FLAG_RPM_ACTIVE, >>>>>>>>>>>>> the supplier devices will be PM runtime resumed before the >>>> consumer >>>>>>>>>>>>> (camera sensor). As these devices are purely virtual on >>>>>>>>>>>>> host side and >>>>>> has >>>>>>>>>>>>> no power state as such, you can use runtime PM callbacks >>>>>>>>>>>>> to transfer >>>>>>>> the >>>>>>>>>>>>> ownership. >>>>>>>>>>>> >>>>>>>>>>>> Interesting proposal to use device-links + runtime-pm for >>>>>>>>>>>> this instead of modelling this as an i2c-mux. FWIW I'm fine >>>>>>>>>>>> with going this route instead of using an i2c-mux approach. >>>>>>>>>>>> >>>>>>>>>>>> I have been thinking about the i2c-mux approach a bit and the >>>>>>>>>>>> problem is that we are not really muxing but want to turn >>>>>>>>>>>> on/off control and AFAIK the i2c-mux framework simply leaves >>>>>>>>>>>> the mux muxed to the last used i2c-chain, so control will >>>>>>>>>>>> never be released when the i2c >>>>>>>>>> transfers are done. >>>>>>>>>>>> >>>>>>>>>>>> And if were to somehow modify things (or maybe there already >>>>>>>>>>>> is some release >>>>>>>>>>>> callback) then the downside becomes that the i2c-mux core >>>>>>>>>>>> code operates at the i2c transfer level. So each i2c >>>>>>>>>>>> read/write would then enable + >>>>>>>>>> disavle control. >>>>>>>>>>>> >>>>>>>>>>>> Modelling this using something like runtime pm as such is a >>>>>>>>>>>> much better fit because then we request control once on probe >>>>>>>>>>>> / stream-on and release it once we are fully done, rather >>>>>>>>>>>> then requesting + releasing control once per i2c- transfer. >>>>>>>>>>> >>>>>>>>>>> Seems runtime pm can't fix the problem of initial i2c transfer >>>>>>>>>>> during sensor driver probe, probably we have to switch to >>>>>>>>>>> i2c-mux modeling >>>>>>>> way. >>>>>>>>>> >>>>>>>>>> What do you mean? The supplier devices are resumed before the >>>>>>>>>> driver's probe is called. >>>>>>>>> >>>>>>>>> But we setup the link with device_link_add during IVSC driver's >>>>>>>>> probe, we can't guarantee driver probe's sequence. >>>>>>>> >>>>>>>> Then maybe we need to do the device_link_add somewhere else. >>>>>>> >>>>>>> sensor's parent is the LJCA I2C device whose driver is being >>>>>>> upstream https://www.spinics.net/lists/kernel/msg4702552.htmland >>>>>>> and sensor's power is controlled by IVSC instead of INT3472 if IVSC >> enabled. >>>>>> >>>>>> I believe that the INT3472 code is still involved at least on a >>>>>> Dell Latitude 9420 the INT3472 code still needs to set the >>>>>> clock-enable and the privacy-LED GPIOs otherwise the main camera won't >> work. >>>>>> >>>>>> So I'm not sure what you mean with "sensor's power is controlled by >>>>>> IVSC instead of INT3472" ? >>>>> >>>>> Could you please share your kernel log and DSDT? Thanks >>>>> >>>>> BR, >>>>> Wentong >>>>>> >>>>>> >>>>>>> struct device_link *device_link_add(struct device *consumer, >>>>>>> struct device *supplier, u32 >>>>>>> flags) >>>>>>> >>>>>>> So probably we have to add above device_link_add in LJCA I2C's >>>>>>> driver, and we can find the consumer(camera sensor) with ACPI API, >>>>>>> but the supplier, mei_ace, is mei client device under mei >>>>>>> framework and it's dynamically allocated device instead of ACPI >>>>>>> device, probably I can find its parent with some ACPI lookup from >>>>>>> this LJCA I2C device, but unfortunately mei framework doesn't >>>>>>> export the API to find mei client device with its parent bus device(struct >> mei_device). >>>>>>> >>>>>>> I'm not sure if modeling this mei_ace as LJCA I2C's runtime power >>>>>>> control is acceptable, if yes, probably this mei_ace driver have >>>>>>> to go with LJCA I2C device driver. >>>>>> >>>>>> Looking at the ACPI table the sensor ACPI device has 2 _DEP-s >>>>>> listed the I2C controller and the INT3472 device. Since we are >>>>>> already doing similar setup in the INT3472 device that seems like a >>>>>> good place to add the device_link()-s (it can return -EPROBE_DEFER >>>>>> to wait for the mei_ace >>>> to show up). >>>>>> >>>>>> But when the INT3472 code runs, the consumer device does not exist >>>>>> yet and AFAICT the same is true when the LCJA i2c-controller driver >>>>>> is getting >>>> registered. >>>>>> The consumer only exists when the i2c_client is instantiated and at >>>>>> that point the sensor drivers probe() method can run immediately >>>>>> and we are too late to add the device_link. >>>>>> >>>>>> As a hobby project I have been working on atomisp2 support and I >>>>>> have a similar issue there. There is no INT3472 device there, but >>>>>> there is a _DSM method which needs to be used to figure out which >>>>>> ACPI GPIO resource is reset / powerdown and if the GPIOs are active-low >> or active high. >>>>>> >>>>>> I have written a little helper function to call the _DSM and to >>>>>> then turn this into lookups and call devm_acpi_dev_add_driver_gpios(). >>>>>> >>>>>> Since on atomisp2 we cannot use the INT3472 driver to delay the >>>>>> sensor-driver probe and have the INT3472 driver setup the GPIO >>>>>> lookup, at least for the sensor drivers used with >>>>>> atomisp2 there is going to be a need to add a single line to probe() like this: >>>>>> >>>>>> v4l2_get_acpi_sensor_info(&i2c_client->dev, NULL); >>>>>> >>>>>> To me it sounds like we need to do something similar here and >>>>>> extend the helper function which I have written (but not yet submitted >> upstream) : >>>>>> >>>>>> https://github.com/jwrdegoede/linux- >>>>>> sunxi/commit/e2287979db43d46fa7d354c1bde92eb6219b613d >>>>>> >>>>>> To also setup the device-links needed for the runtime-pm solution >>>>>> to getting the i2c passed through to the sensor. >>>>>> >>>>>> Ideally v4l2_get_acpi_sensor_info() should return void (easier to >>>>>> use in the sensor drivers) but I think it should return an int, so >>>>>> that it can e.g. return - EPROBE_DEFER to wait for the mei_ace. >>>>>> >>>>>> Regards, >>>>>> >>>>>> Hans >>>>>> >>>>>> >>>>>> >>>>>> >>>>>>>> The mainline kernel delays probing of camera sensors on Intel >>>>>>>> platforms until the INT3472 driver has probed the INT3472 device >>>>>>>> on which the sensors have an ACPI _DEP. >>>>>>>> >>>>>>>> This is already used to make sure that clock lookups and >>>>>>>> regulator info is in place before the sensor's probe() function runs. >>>>>>>> >>>>>>>> So that when the driver does clk_get() it succeeds and so that >>>>>>>> regulator_get() does not end up returning a dummy regulator. >>>>>>>> >>>>>>>> So I think the code adding the device_link-s for the IVSC should >>>>>>>> be added >>>>>>>> to: drivers/platform/x86/intel/int3472/discrete.c and then the >>>>>>>> runtime-resume will happen before the sensor's probe() function runs. >>>>>>>> >>>>>>>> Likewise drivers/platform/x86/intel/int3472/discrete.c should >>>>>>>> also ensure that the ivsc driver's probe() has run before it >>>>>>>> calls >>>>>> acpi_dev_clear_dependencies(). >>>>>>>> >>>>>>>> The acpi_dev_clear_dependencies() call in discrete.c tells the >>>>>>>> ACPI subsystem to go ahead and create the i2c-clients for the >>>>>>>> sensors and allow the sensor drivers to get loaded and probe the sensor. >>>>>>>> >>>>>>>> Regards, >>>>>>>> >>>>>>>> Hans >>>>>>> >>>>> >