From patchwork Mon Oct 1 14:03:39 2012 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Lad, Prabhakar" X-Patchwork-Id: 1531601 Return-Path: X-Original-To: patchwork-linux-media@patchwork.kernel.org Delivered-To: patchwork-process-083081@patchwork2.kernel.org Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by patchwork2.kernel.org (Postfix) with ESMTP id 046EFDFFCC for ; Mon, 1 Oct 2012 14:05:43 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752946Ab2JAOFc (ORCPT ); Mon, 1 Oct 2012 10:05:32 -0400 Received: from mail-da0-f46.google.com ([209.85.210.46]:51030 "EHLO mail-da0-f46.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751169Ab2JAOFa (ORCPT ); Mon, 1 Oct 2012 10:05:30 -0400 Received: by dakn41 with SMTP id n41so388031dak.19 for ; Mon, 01 Oct 2012 07:05:30 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=from:to:cc:subject:date:message-id:x-mailer; bh=HQ97nASskacNkNMCNpdt+YPR3hyrIOruingEP32t0og=; b=u59QDL06eL9dVfhY+z+BX069RhSgZk65lGCrXtiRnnM776mmz+hczCbc6b2zP2reh5 l5Qq5dSl3m46Sp7eKMQe7V3oAovpTAYult+cHYJnlOdLVqVh7S4Kv6RjPIUnCULvXQa4 PHD+MQL5gM8nk7AhQmf4rq8XXs/KmU3dOx2nFY9t3+rEUUyxIseYDgVtQtAQ/g/GNXd+ A4fXXNpQu9t4+2qtejyksdCdBgqH+6z9elsBgzCSFDV3IntEJKXMkPIaWcez6xXP0dGv 7+xGVQ8B1RqkRVskKdAtykA1egaAeCVnXrr4iplrFAT2q5K+MBbayKKnT2RccTXvIFw+ fDYw== Received: by 10.68.220.2 with SMTP id ps2mr41293361pbc.61.1349100329547; Mon, 01 Oct 2012 07:05:29 -0700 (PDT) Received: from localhost.localdomain ([117.221.42.190]) by mx.google.com with ESMTPS id wl4sm10339069pbc.17.2012.10.01.07.05.09 (version=TLSv1/SSLv3 cipher=OTHER); Mon, 01 Oct 2012 07:05:28 -0700 (PDT) From: Prabhakar To: LMML Cc: DLOS , Manjunath Hadli , VGER , LDOC , "Lad, Prabhakar" , Sakari Ailus , Laurent Pinchart , Guennadi Liakhovetski , Sylwester Nawrocki , Hans Verkuil , Rob Landley , Mauro Carvalho Chehab Subject: [PATCH RFC] media: v4l2-ctrl: Add digital gain controls Date: Mon, 1 Oct 2012 19:33:39 +0530 Message-Id: <1349100219-7599-1-git-send-email-prabhakar.lad@ti.com> X-Mailer: git-send-email 1.7.4.1 Sender: linux-media-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-media@vger.kernel.org From: Lad, Prabhakar add support for per color component digital gain controls and also their corresponding offset. Signed-off-by: Lad, Prabhakar Signed-off-by: Manjunath Hadli Cc: Sakari Ailus Cc: Laurent Pinchart Cc: Guennadi Liakhovetski Cc: Sylwester Nawrocki Cc: Hans Verkuil Cc: Hans de Goede hdegoede@redhat.com Cc: Chris MacGregor chris@cybermato.com Cc: Rob Landley Cc: Mauro Carvalho Chehab --- Documentation/DocBook/media/v4l/controls.xml | 54 ++++++++++++++++++++++++++ drivers/media/v4l2-core/v4l2-ctrls.c | 11 +++++ include/linux/v4l2-controls.h | 11 +++++ 3 files changed, 76 insertions(+), 0 deletions(-) diff --git a/Documentation/DocBook/media/v4l/controls.xml b/Documentation/DocBook/media/v4l/controls.xml index a84a08c..9bf54f3 100644 --- a/Documentation/DocBook/media/v4l/controls.xml +++ b/Documentation/DocBook/media/v4l/controls.xml @@ -4277,6 +4277,60 @@ interface and may change in the future. specific test patterns can be used to test if a device is working properly. + + V4L2_CID_GAIN_RED + integer + + + V4L2_CID_GAIN_GREEN_RED + integer + + + V4L2_CID_GAIN_GREEN_BLUE + integer + + + V4L2_CID_GAIN_BLUE + integer + + + V4L2_CID_GAIN_GREEN + integer + + + Some capture/sensor devices have + the capability to set per color component digital gain values. + + + V4L2_CID_GAIN_OFFSET + integer + + + V4L2_CID_BLUE_OFFSET + integer + + + V4L2_CID_RED_OFFSET + integer + + + V4L2_CID_GREEN_OFFSET + integer + + + V4L2_CID_GREEN_RED_OFFSET + integer + + + V4L2_CID_GREEN_BLUE_OFFSET + integer + + + Some capture/sensor devices have the + capability to set per color component digital gain offset values. + V4L2_CID_GAIN_OFFSET is the global gain offset and the rest are per + color component gain offsets. + diff --git a/drivers/media/v4l2-core/v4l2-ctrls.c b/drivers/media/v4l2-core/v4l2-ctrls.c index 93cd0a4..02cc1d2 100644 --- a/drivers/media/v4l2-core/v4l2-ctrls.c +++ b/drivers/media/v4l2-core/v4l2-ctrls.c @@ -750,6 +750,17 @@ const char *v4l2_ctrl_get_name(u32 id) case V4L2_CID_LINK_FREQ: return "Link Frequency"; case V4L2_CID_PIXEL_RATE: return "Pixel Rate"; case V4L2_CID_TEST_PATTERN: return "Test Pattern"; + case V4L2_CID_GAIN_RED: return "Digital Gain Red"; + case V4L2_CID_GAIN_GREEN_RED: return "Digital Gain Green Red"; + case V4L2_CID_GAIN_GREEN_BLUE: return "Digital Gain Green Blue"; + case V4L2_CID_GAIN_BLUE: return "Digital Gain Blue"; + case V4L2_CID_GAIN_GREEN: return "Digital Gain Green"; + case V4L2_CID_GAIN_OFFSET: return "Digital Gain Offset"; + case V4L2_CID_BLUE_OFFSET: return "Digital Gain Blue Offset"; + case V4L2_CID_RED_OFFSET: return "Digital Gain Red Offset"; + case V4L2_CID_GREEN_OFFSET: return "Digital Gain Green Offset"; + case V4L2_CID_GREEN_RED_OFFSET: return "Digital Gain Green Red Offset"; + case V4L2_CID_GREEN_BLUE_OFFSET: return "Digital Gain Green Blue Offset"; /* DV controls */ case V4L2_CID_DV_CLASS: return "Digital Video Controls"; diff --git a/include/linux/v4l2-controls.h b/include/linux/v4l2-controls.h index e1b3680..087596d 100644 --- a/include/linux/v4l2-controls.h +++ b/include/linux/v4l2-controls.h @@ -758,5 +758,16 @@ enum v4l2_jpeg_chroma_subsampling { #define V4L2_CID_LINK_FREQ (V4L2_CID_IMAGE_PROC_CLASS_BASE + 1) #define V4L2_CID_PIXEL_RATE (V4L2_CID_IMAGE_PROC_CLASS_BASE + 2) #define V4L2_CID_TEST_PATTERN (V4L2_CID_IMAGE_PROC_CLASS_BASE + 3) +#define V4L2_CID_GAIN_RED (V4L2_CID_IMAGE_PROC_CLASS_BASE + 4) +#define V4L2_CID_GAIN_GREEN_RED (V4L2_CID_IMAGE_PROC_CLASS_BASE + 5) +#define V4L2_CID_GAIN_GREEN_BLUE (V4L2_CID_IMAGE_PROC_CLASS_BASE + 6) +#define V4L2_CID_GAIN_BLUE (V4L2_CID_IMAGE_PROC_CLASS_BASE + 7) +#define V4L2_CID_GAIN_GREEN (V4L2_CID_IMAGE_PROC_CLASS_BASE + 8) +#define V4L2_CID_GAIN_OFFSET (V4L2_CID_IMAGE_PROC_CLASS_BASE + 9) +#define V4L2_CID_BLUE_OFFSET (V4L2_CID_IMAGE_PROC_CLASS_BASE + 10) +#define V4L2_CID_RED_OFFSET (V4L2_CID_IMAGE_PROC_CLASS_BASE + 11) +#define V4L2_CID_GREEN_OFFSET (V4L2_CID_IMAGE_PROC_CLASS_BASE + 12) +#define V4L2_CID_GREEN_RED_OFFSET (V4L2_CID_IMAGE_PROC_CLASS_BASE + 13) +#define V4L2_CID_GREEN_BLUE_OFFSET (V4L2_CID_IMAGE_PROC_CLASS_BASE + 14) #endif