73 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. SPDX-License-Identifier: GPL-2.0
 | |
| 
 | |
| .. include:: <isonum.txt>
 | |
| 
 | |
| ================================
 | |
| Starfive Camera Subsystem driver
 | |
| ================================
 | |
| 
 | |
| Introduction
 | |
| ------------
 | |
| 
 | |
| This file documents the driver for the Starfive Camera Subsystem found on
 | |
| Starfive JH7110 SoC. The driver is located under drivers/staging/media/starfive/
 | |
| camss.
 | |
| 
 | |
| The driver implements V4L2, Media controller and v4l2_subdev interfaces. Camera
 | |
| sensor using V4L2 subdev interface in the kernel is supported.
 | |
| 
 | |
| The driver has been successfully used on the Gstreamer 1.18.5 with v4l2src
 | |
| plugin.
 | |
| 
 | |
| 
 | |
| Starfive Camera Subsystem hardware
 | |
| ----------------------------------
 | |
| 
 | |
| The Starfive Camera Subsystem hardware consists of::
 | |
| 
 | |
|                     |\         +---------------+      +-----------+
 | |
|   +----------+      |  \       |               |      |           |
 | |
|   |          |      |   |      |               |      |           |
 | |
|   |   MIPI   |----->|   |----->|      ISP      |----->|           |
 | |
|   |          |      |   |      |               |      |           |
 | |
|   +----------+      |   |      |               |      |  Memory   |
 | |
|                     |MUX|      +---------------+      | Interface |
 | |
|   +----------+      |   |                             |           |
 | |
|   |          |      |   |---------------------------->|           |
 | |
|   | Parallel |----->|   |                             |           |
 | |
|   |          |      |   |                             |           |
 | |
|   +----------+      |  /                              |           |
 | |
|                     |/                                +-----------+
 | |
| 
 | |
| - MIPI: The MIPI interface, receiving data from a MIPI CSI-2 camera sensor.
 | |
| 
 | |
| - Parallel: The parallel interface,  receiving data from a parallel sensor.
 | |
| 
 | |
| - ISP: The ISP, processing raw Bayer data from an image sensor and producing
 | |
|   YUV frames.
 | |
| 
 | |
| 
 | |
| Topology
 | |
| --------
 | |
| 
 | |
| The media controller pipeline graph is as follows:
 | |
| 
 | |
| .. _starfive_camss_graph:
 | |
| 
 | |
| .. kernel-figure:: starfive_camss_graph.dot
 | |
|     :alt:   starfive_camss_graph.dot
 | |
|     :align: center
 | |
| 
 | |
| The driver has 2 video devices:
 | |
| 
 | |
| - capture_raw: The capture device, capturing image data directly from a sensor.
 | |
| - capture_yuv: The capture device, capturing YUV frame data processed by the
 | |
|   ISP module
 | |
| 
 | |
| The driver has 3 subdevices:
 | |
| 
 | |
| - stf_isp: is responsible for all the isp operations, outputs YUV frames.
 | |
| - cdns_csi2rx: a CSI-2 bridge supporting up to 4 CSI lanes in input, and 4
 | |
|   different pixel streams in output.
 | |
| - imx219: an image sensor, image data is sent through MIPI CSI-2.
 |