RE: [PATCH v2 0/3] media: pci: intel: ivsc: Add driver of Intel Visual Sensing Controller(IVSC)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




> -----Original Message-----
> From: Laurent Pinchart <laurent.pinchart@xxxxxxxxxxxxxxxx>
> Sent: Friday, February 17, 2023 7:12 PM
> 
> Hello Wentong,
> 
> On Fri, Feb 17, 2023 at 06:20:10AM +0000, Wu, Wentong wrote:
> > On Wednesday, February 15, 2023 5:43 PM, Laurent Pinchart wrote:
> > > 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
> > >
> > > Do you have plan to support these features in the ivsc driver in the future ?
> >
> > Not sure, but the first step is to upstream this driver.
> 
> Sure, no problem.
> 
> > > > 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.
> > >
> > > How does the privacy mode work, and how can the user trust that the
> > > closed- source IVSC and IME firmwares will honour the privacy settings ?
> >
> > No camera data will be allowed to go through IVSC, and then there will
> > be no data on IVSC CSI transmitter side.
> 
> But how can I be sure that the IVSC will not use the camera behind my back, if
> it's all controlled through a closed-source firmware ?

Actually I don't know how to answer your question, but this is guaranteed though we have no plan to open-source the firmware.

> 
> > > > 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.
> > > >
> > > > Implementation:
> > > > There are two different drivers to handle ACE and CSI hardware
> > > > modules inside IVSC.
> > > >  - mei_csi: MEI client driver to send commands and receive notifications
> from CSI module.
> > > >  - mei_ace: MEI client driver to send commands and get status from ACE
> module.
> > > > Interface is exposed via ivsc.h to acquire and release camera
> > > > sensor and
> > > > CSI-2 link.
> > >
> > > Do I understand correctly, from your diagram below, that the
> > > communication between the IME and IVSC goes through SPI ?
> > >
> > > > Below diagram shows connections of IVSC/ISH/IPU/Camera sensor.
> > > > ------------------------------------------------------------------
> > > > -----------
> > > > | Host Processor                                                            |
> > > > |                                                                           |
> > > > |       -----------------       -----------------       ---------------     |
> > > > |       |               |       |               |       |             | I2C |
> > > > |       |      IPU      |       |      ISH      |       |camera driver|--|  |
> > > > |       |               |       |               |       |             |  |  |
> > > > |       -----------------       -----------------       ---------------  |  |
> > > > |               |                       |                      |         |  |
> > > > |               |                       |               ---------------  |  |
> > > > |               |                       |               |             |  |  |
> > > > |               |                       |               | IVSC driver |  |  |
> > > > |               |                       |               |             |  |  |
> > > > |               |                       |               ---------------  |  |
> > > > |               |                       |                      |         |  |
> > > > ----------------|-----------------------|----------------------|---------|---
> > > >                 | CSI                   | I2C                  |SPI      |
> > > >                 |                       |                      |         |
> > > > ----------------|-----------------------|----------------      |         |
> > > > | IVSC          |                                       |      |         |
> > > > |               |                                       |      |         |
> > > > |       -----------------       -----------------       |      |         |
> > > > |       |               |       |               |       |      |         |
> > > > |       |      CSI      |       |      ACE      |       |------|         |
> > > > |       |               |       |               |       |                |
> > > > |       -----------------       -----------------       |                |
> > > > |               |                       | I2C           |                |
> > > > ----------------|-----------------------|----------------                |
> > > >                 | CSI                   |                                |
> > > >                 |                       |                                |
> > > >             --------------------------------                             |
> > > >             |                              | I2C                         |
> > > >             |         camera sensor        |-----------------------------|
> > > >             |                              |
> > > >             --------------------------------
> > > >
> > > > Wentong Wu (3):
> > > >   media: pci: intel: ivsc: Add CSI submodule
> > > >   media: pci: intel: ivsc: Add ACE submodule
> > > >   media: pci: intel: ivsc: Add acquire/release API for ivsc
> > > >
> > > >  drivers/media/pci/Kconfig              |   1 +
> > > >  drivers/media/pci/intel/Makefile       |   2 +
> > > >  drivers/media/pci/intel/ivsc/Kconfig   |  12 +
> > > >  drivers/media/pci/intel/ivsc/Makefile  |   7 +
> > > >  drivers/media/pci/intel/ivsc/ivsc.c    |  84 +++++
> > > >  drivers/media/pci/intel/ivsc/mei_ace.c | 472
> > > > +++++++++++++++++++++++++  drivers/media/pci/intel/ivsc/mei_ace.h
> > > > |> 36 ++  drivers/media/pci/intel/ivsc/mei_csi.c | 342
> > > > ++++++++++++++++++  drivers/media/pci/intel/ivsc/mei_csi.h |  60 ++++
> > > >  include/linux/ivsc.h                   |  74 ++++
> > > >  10 files changed, 1090 insertions(+)  create mode 100644
> > > > drivers/media/pci/intel/ivsc/Kconfig
> > > >  create mode 100644 drivers/media/pci/intel/ivsc/Makefile
> > > >  create mode 100644 drivers/media/pci/intel/ivsc/ivsc.c
> > > >  create mode 100644 drivers/media/pci/intel/ivsc/mei_ace.c
> > > >  create mode 100644 drivers/media/pci/intel/ivsc/mei_ace.h
> > > >  create mode 100644 drivers/media/pci/intel/ivsc/mei_csi.c
> > > >  create mode 100644 drivers/media/pci/intel/ivsc/mei_csi.h
> > > >  create mode 100644 include/linux/ivsc.h
> 
> --
> Regards,
> 
> Laurent Pinchart




[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]

  Powered by Linux