All of lore.kernel.org
 help / color / mirror / Atom feed
From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
To: davinci-linux-open-source@linux.davincidsp.com
Cc: Manjunath Hadli <manjunath.hadli@ti.com>,
	LMML <linux-media@vger.kernel.org>,
	linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org,
	Rob Landley <rob@landley.net>,
	Mauro Carvalho Chehab <mchehab@infradead.org>
Subject: Re: [PATCH] [media] davinci: vpfe: Add documentation
Date: Sun, 15 Jul 2012 14:46:25 +0200	[thread overview]
Message-ID: <6781973.T5EQaLmeMs@avalon> (raw)
In-Reply-To: <1342021166-6092-1-git-send-email-manjunath.hadli@ti.com>

Hi Manjunath,

Thanks for the patch.

On Wednesday 11 July 2012 21:09:26 Manjunath Hadli wrote:
> Add documentation on the Davinci VPFE driver. Document the subdevs,
> and private IOTCLs the driver implements
> 
> Signed-off-by: Manjunath Hadli <manjunath.hadli@ti.com>
> Signed-off-by: Lad, Prabhakar <prabhakar.lad@ti.com>
> ---
>  Documentation/video4linux/davinci-vpfe-mc.txt |  263
> +++++++++++++++++++++++++ 1 files changed, 263 insertions(+), 0
> deletions(-)
>  create mode 100644 Documentation/video4linux/davinci-vpfe-mc.txt
> 
> diff --git a/Documentation/video4linux/davinci-vpfe-mc.txt
> b/Documentation/video4linux/davinci-vpfe-mc.txt new file mode 100644
> index 0000000..968194f
> --- /dev/null
> +++ b/Documentation/video4linux/davinci-vpfe-mc.txt
> @@ -0,0 +1,263 @@
> +Davinci Video processing Front End (VPFE) driver
> +
> +Copyright (C) 2012 Texas Instruments Inc
> +
> +Contacts: Manjunath Hadli <manjunath.hadli@ti.com>
> +
> +Introduction
> +============
> +
> +This file documents the Texas Instruments Davinci Video processing Front
> End
> +(VPFE) driver located under drivers/media/video/davinci. The original
> driver
> +exists for Davinci VPFE, which is now being changed to Media Controller
> +Framework.
> +
> +Currently the driver has been successfully used on the following version of
> Davinci:
> +
> +	DM365/DM368

Does the driver still support the DM644x ?

> +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 Davinic VPFE is split into V4L2 subdevs, each of the blocks inside the

s/Davinic/Davinci/

> VPFE
> +having one subdev to represent it. Each of the subdevs provide a V4L2
> subdev
> +interface to userspace.
> +
> +	DAVINCI CCDC
> +	DAVINCI PREVIEWER
> +	DAVINCI RESIZER

the DM36x VPFE documentation doesn't split the hardware in CCDC, PREVIEWER and 
RESIZER modules, but in ISIF, IPIPEIF and IPIPE. Why don't you use those names 
? It looks like you're introducing an abstraction layer on top of the existing 
driver. Why is that needed, why don't you just port the driver to the MC API 
instead ?

> +	DAVINCI AEW
> +	DAVINCI AF
> +
> +Each possible link in the VPFE is modeled by a link in the Media controller
> +interface. For an example program see [1].
> +
> +
> +Private IOCTLs
> +==============
> +
> +The Davinci Video processing Front End (VPFE) driver supports standard V4L2
> +IOCTLs and controls where possible and practical. Much of the functions
> provided
> +by the VPFE, however, does not fall under the standard IOCTLs.
> +
> +In general, there is a private ioctl for configuring each of the blocks
> +containing hardware-dependent functions.
> +
> +The following private IOCTLs are supported:
> +
> +1: IOCTL: PREV_S_PARAM/PREV_G_PARAM
> +Description:
> +	Sets/Gets the parameters required by the previewer module
> +Parameter:
> +	/**
> +	 * struct prev_module_param- structure to configure preview modules
> +	 * @version: Version of the preview module

Who is responsible for filling this field, the application or the driver ?

> +	 * @len: Length of the module config structure
> +	 * @module_id: Module id
> +	 * @param: pointer to module config parameter.

What is module_id for ? What does param point to ?

> +	 */
> +	struct prev_module_param {
> +		char version[IMP_MAX_NAME_SIZE];

Is there a need to express the version as a string instead of an integer ?

> +		unsigned short len;
> +		unsigned short module_id;
> +		void *param;
> +	};
> +
> +2: IOCTL: PREV_S_CONFIG/PREV_G_CONFIG
> +Description:
> +	Sets/Gets the configuration required by the previewer channel
> +Parameter:
> +	/**
> +	 * struct prev_channel_config - structure for configuring the previewer
> channel
> +	 * @len: Length of the user configuration
> +	 * @config: pointer to either single shot config or continuous
> +	 */
> +	struct prev_channel_config {
> +		unsigned short len;
> +		void *config;
> +	};

What's the difference between parameters and configuration ? What does config 
point to ?

> +
> +3: IOCTL: PREV_ENUM_CAP
> +Description:
> +	Queries the modules available in the image processor for preview the
> +	input image.
> +Parameter:
> +	/**
> +	 * struct prev_cap - structure to enumerate capabilities of previewer
> +	 * @index: application use this to iterate over the available modules
> +	 * @version: version of the preview module
> +	 * @module_id: module id
> +	 * @control: control operation allowed in continuous mode? 1 - allowed, 0
> - not allowed
> +	 * @path: path on which the module is sitting
> +	 * @module_name: module name
> +	 */
> +	struct prev_cap {
> +		unsigned short index;
> +		char version[IMP_MAX_NAME_SIZE];
> +		unsigned short module_id;
> +		char control;
> +		enum imp_data_paths path;
> +		char module_name[IMP_MAX_NAME_SIZE];
> +	};

Enumerating internal modules is exactly what the MC API was designed for. Why 
do you reimplement that using private ioctls ?

> +
> +4: IOCTL: RSZ_S_CONFIG/RSZ_G_CONFIG
> +Description:
> +	Sets/Gets the configuration required by the resizer channel
> +Parameter:
> +	/**
> +	 * struct rsz_channel_config - structure for configuring the resizer
> channel +	 * @chain: chain this resizer at the previewer output
> +	 * @len: length of the user configuration
> +	 * @config: pointer to either single shot config or continuous
> +	 */
> +	struct rsz_channel_config {
> +		unsigned char chain;
> +		unsigned short len;
> +		void *config;
> +	};

Same question as for the preview engine, what does this do, what does config 
point to ? What is the chain parameter for ?

> +
> +5: IOCTL: VPFE_CMD_S_CCDC_RAW_PARAMS/VPFE_CMD_G_CCDC_RAW_PARAMS
> +Description:
> +	Sets/Gets the CCDC parameter
> +Parameter:
> +	/**
> +	 * struct ccdc_config_params_raw - structure for configuring ccdc params
> +	 * @linearize: linearization parameters for image sensor data input
> +	 * @df_csc: data formatter or CSC
> +	 * @dfc: defect Pixel Correction (DFC) configuration
> +	 * @bclamp: Black/Digital Clamp configuration
> +	 * @gain_offset: Gain, offset adjustments

Can't you use subdev V4L2 controls for gains ?

> +	 * @culling: Culling
> +	 * @pred: predictor for DPCM compression
> +	 * @horz_offset: horizontal offset for Gain/LSC/DFC
> +	 * @vert_offset: vertical offset for Gain/LSC/DFC
> +	 * @col_pat_field0: color pattern for field 0
> +	 * @col_pat_field1: color pattern for field 1

Shouldn't color patterns be computed automatically by the driver based on the 
media bus pixel code ?

> +	 * @data_size: data size from 8 to 16 bits
> +	 * @data_shift: data shift applied before storing to SDRAM

Ditto, this should probably be computed automatically.

> +	 * @test_pat_gen: enable input test pattern generation

You could use a subdev V4L2 control for that.

> +	 */
> +	struct ccdc_config_params_raw {
> +		struct ccdc_linearize linearize;
> +		struct ccdc_df_csc df_csc;
> +		struct ccdc_dfc dfc;
> +		struct ccdc_black_clamp bclamp;
> +		struct ccdc_gain_offsets_adj gain_offset;
> +		struct ccdc_cul culling;
> +		enum ccdc_dpcm_predictor pred;
> +		unsigned short horz_offset;
> +		unsigned short vert_offset;
> +		struct ccdc_col_pat col_pat_field0;
> +		struct ccdc_col_pat col_pat_field1;
> +		enum ccdc_data_size data_size;
> +		enum ccdc_datasft data_shift;
> +		unsigned char test_pat_gen;
> +	};
> +
> +6: IOCTL: AF_S_PARAM/AF_G_PARAM
> +Description:
> +	AF_S_PARAM performs the hardware setup and sets the parameter for
> +	AF engine.AF_G_PARAM gets the parameter setup in AF engine
> +Parameter:
> +	/**
> +	 * struct af_configuration - struct to configure parameters of AF engine
> +	 * @alaw_enable: ALAW status
> +	 * @fv_sel: focus value selection
> +	 * @hmf_config: HMF configurations
> +	 * @rgb_pos: RGB Positions. Only applicable with AF_HFV_ONLY selection
> +	 * @iir_config: IIR filter configurations
> +	 * @fir_config: FIR filter configuration
> +	 * @paxel_config: Paxel parameters
> +	 * @mode: accumulator mode
> +	 */
> +	struct af_configuration {
> +		enum af_enable_flag alaw_enable;

Can this be computed automatically based on the media bus pixel code ? 

> +		enum af_focus_val_sel fv_sel;
> +		struct af_hmf hmf_config;
> +		enum rgbpos rgb_pos;

Same here ?

> +		struct af_iir iir_config;
> +		struct af_fir fir_config;
> +		struct af_paxel paxel_config;
> +		enum af_mode mode;
> +	};
> +
> +7: IOCTL: AF_GET_STAT
> +Description:
> +	Copy the entire statistics located in application buffer
> +	to user space from the AF engine
> +Parameter:
> +	/**
> +	 * struct af_statdata - structure to get statistics from AF engine
> +	 * @buffer: pointer to buffer
> +	 * @buf_length: length of buffer
> +	 */
> +	struct af_statdata {
> +		void *buffer;
> +		int buf_length;
> +	};

The OMAP3 ISP driver also needs to export statistics data to userspace. We 
should design a common API here.

> +8: IOCTL: AEW_S_PARAM/AEW_G_PARAM
> +Description:
> +	AEW_S_PARAM performs the hardware setup and sets the parameter for
> +	AEW engine.AEW_G_PARAM gets the parameter setup in AEW engine
> +Parameter:
> +	/**
> +	 * struct aew_configuration -  struct to configure parameters of AEW
> engine
> +	 * @alaw_enable: A-law status
> +	 * @format: AE/AWB output format
> +	 * @sum_shift: AW/AWB right shift value for sum of pixels
> +	 * @saturation_limit: Saturation Limit
> +	 * @hmf_config: HMF configurations
> +	 * @window_config: Window for AEW Engine
> +	 * @blackwindow_config: Black Window
> +	 */
> +	struct aew_configuration {
> +		enum aew_enable_flag alaw_enable;

Computed automatically as well ?

> +		enum aew_output_format out_format;
> +		char sum_shift;
> +		int saturation_limit;
> +		struct aew_hmf hmf_config;
> +		struct aew_window window_config;
> +		struct aew_black_window blackwindow_config;
> +	};
> +
> +9: IOCTL: AEW_GET_STAT
> +Description:
> +	Copy the entire statistics located in application buffer
> +	to user space from the AEW engine
> +Parameter:
> +	/**
> +	 * struct aew_statdata - structure to get statistics from AEW engine
> +	 * @buffer: pointer to buffer
> +	 * @buf_length: length of buffer
> +	 */
> +	struct aew_statdata {
> +		void *buffer;
> +		int buf_length;
> +	};

Same comment as for AF_GET_STAT.

> +Technical reference manuals (TRMs) and other documentation
> +==========================================================
> +
> +Davinci DM365 TRM:
> +<URL:http://www.ti.com/lit/ds/sprs457e/sprs457e.pdf>
> +Referenced MARCH 2009-REVISED JUNE 2011
> +
> +Davinci DM368 TRM:
> +<URL:http://www.ti.com/lit/ds/sprs668c/sprs668c.pdf>
> +Referenced APRIL 2010-REVISED JUNE 2011
> +
> +Davinci Video Processing Front End (VPFE) DM36x
> +<URL:http://www.ti.com/lit/ug/sprufg8c/sprufg8c.pdf>
> +
> +
> +References
> +==========
> +
> +[1] http://git.ideasonboard.org/?p=media-ctl.git;a=summary

-- 
Regards,

Laurent Pinchart


       reply	other threads:[~2012-07-15 12:46 UTC|newest]

Thread overview: 32+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <1342021166-6092-1-git-send-email-manjunath.hadli@ti.com>
2012-07-15 12:46 ` Laurent Pinchart [this message]
2012-07-17 10:43   ` [PATCH] [media] davinci: vpfe: Add documentation Hadli, Manjunath
2012-07-17 10:43     ` Hadli, Manjunath
2012-07-26  0:12     ` Laurent Pinchart
2012-07-26  0:12       ` Laurent Pinchart
2012-07-26  0:13       ` Laurent Pinchart
2012-07-26  0:25     ` Laurent Pinchart
2012-07-26  0:25       ` Laurent Pinchart
2012-07-27  5:49       ` Hadli, Manjunath
2012-07-27  5:49         ` Hadli, Manjunath
2012-07-27 10:49         ` Laurent Pinchart
2012-07-27 10:49           ` Laurent Pinchart
2012-07-31  7:45           ` Manju
2012-07-31  7:45             ` Manju
2012-08-02 21:25             ` Laurent Pinchart
2012-08-02 21:25               ` Laurent Pinchart
2012-08-02  0:07 ` Sakari Ailus
2012-08-09  3:43   ` Manjunath Hadli
2012-08-16 16:23     ` Sakari Ailus
2012-08-22  8:56       ` Manjunath Hadli
2012-09-01 17:25         ` Sakari Ailus
2012-09-01 17:26           ` Sakari Ailus
2012-09-04  6:14           ` Manjunath Hadli
2012-08-29 14:41       ` Prabhakar Lad
2012-09-01  9:57         ` Sakari Ailus
2012-09-01 14:22           ` Laurent Pinchart
2012-09-01 14:53             ` Prabhakar Lad
2012-09-01 16:11               ` Sakari Ailus
2012-09-02  3:03                 ` Laurent Pinchart
2012-09-02  8:44             ` Hans Verkuil
2012-08-16 13:10 ` Rob Landley
2012-08-16 13:24   ` Prabhakar Lad

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=6781973.T5EQaLmeMs@avalon \
    --to=laurent.pinchart@ideasonboard.com \
    --cc=davinci-linux-open-source@linux.davincidsp.com \
    --cc=linux-doc@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-media@vger.kernel.org \
    --cc=manjunath.hadli@ti.com \
    --cc=mchehab@infradead.org \
    --cc=rob@landley.net \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.