mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-12-29 17:25:38 +00:00
ceafdaac46
As the end goal is to have platform drivers split by vendor, rename omap3isp/ to ti/omap3isp/. Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
93 lines
2.6 KiB
ReStructuredText
93 lines
2.6 KiB
ReStructuredText
.. SPDX-License-Identifier: GPL-2.0
|
|
|
|
.. include:: <isonum.txt>
|
|
|
|
OMAP 3 Image Signal Processor (ISP) driver
|
|
==========================================
|
|
|
|
Copyright |copy| 2010 Nokia Corporation
|
|
|
|
Copyright |copy| 2009 Texas Instruments, Inc.
|
|
|
|
Contacts: Laurent Pinchart <laurent.pinchart@ideasonboard.com>,
|
|
Sakari Ailus <sakari.ailus@iki.fi>, David Cohen <dacohen@gmail.com>
|
|
|
|
|
|
Introduction
|
|
------------
|
|
|
|
This file documents the Texas Instruments OMAP 3 Image Signal Processor (ISP)
|
|
driver located under drivers/media/platform/ti/omap3isp. The original driver was
|
|
written by Texas Instruments but since that it has been rewritten (twice) at
|
|
Nokia.
|
|
|
|
The driver has been successfully used on the following versions of OMAP 3:
|
|
|
|
- 3430
|
|
- 3530
|
|
- 3630
|
|
|
|
The driver implements V4L2, Media controller and v4l2_subdev interfaces.
|
|
Sensor, lens and flash drivers using the v4l2_subdev interface in the kernel
|
|
are supported.
|
|
|
|
|
|
Split to subdevs
|
|
----------------
|
|
|
|
The OMAP 3 ISP is split into V4L2 subdevs, each of the blocks inside the ISP
|
|
having one subdev to represent it. Each of the subdevs provide a V4L2 subdev
|
|
interface to userspace.
|
|
|
|
- OMAP3 ISP CCP2
|
|
- OMAP3 ISP CSI2a
|
|
- OMAP3 ISP CCDC
|
|
- OMAP3 ISP preview
|
|
- OMAP3 ISP resizer
|
|
- OMAP3 ISP AEWB
|
|
- OMAP3 ISP AF
|
|
- OMAP3 ISP histogram
|
|
|
|
Each possible link in the ISP is modelled by a link in the Media controller
|
|
interface. For an example program see [#]_.
|
|
|
|
|
|
Controlling the OMAP 3 ISP
|
|
--------------------------
|
|
|
|
In general, the settings given to the OMAP 3 ISP take effect at the beginning
|
|
of the following frame. This is done when the module becomes idle during the
|
|
vertical blanking period on the sensor. In memory-to-memory operation the pipe
|
|
is run one frame at a time. Applying the settings is done between the frames.
|
|
|
|
All the blocks in the ISP, excluding the CSI-2 and possibly the CCP2 receiver,
|
|
insist on receiving complete frames. Sensors must thus never send the ISP
|
|
partial frames.
|
|
|
|
Autoidle does have issues with some ISP blocks on the 3430, at least.
|
|
Autoidle is only enabled on 3630 when the omap3isp module parameter autoidle
|
|
is non-zero.
|
|
|
|
Technical reference manuals (TRMs) and other documentation
|
|
----------------------------------------------------------
|
|
|
|
OMAP 3430 TRM:
|
|
<URL:http://focus.ti.com/pdfs/wtbu/OMAP34xx_ES3.1.x_PUBLIC_TRM_vZM.zip>
|
|
Referenced 2011-03-05.
|
|
|
|
OMAP 35xx TRM:
|
|
<URL:http://www.ti.com/litv/pdf/spruf98o> Referenced 2011-03-05.
|
|
|
|
OMAP 3630 TRM:
|
|
<URL:http://focus.ti.com/pdfs/wtbu/OMAP36xx_ES1.x_PUBLIC_TRM_vQ.zip>
|
|
Referenced 2011-03-05.
|
|
|
|
DM 3730 TRM:
|
|
<URL:http://www.ti.com/litv/pdf/sprugn4h> Referenced 2011-03-06.
|
|
|
|
|
|
References
|
|
----------
|
|
|
|
.. [#] http://git.ideasonboard.org/?p=media-ctl.git;a=summary
|