This is an automatic generated email to let you know that the following patch 
were queued:

Subject: media: add panel register access functions
Author:  Florian Echtler <f...@butterbrot.org>
Date:    Thu Feb 8 03:43:05 2018 -0500

These functions provide write access to the internal LCD panel registers
which also control the sensor. They can be used to disable the
preprocessor, set the illumination brightness, and adjust gain/contrast
(which are stored together in one register internally called "vsvideo").

Signed-off-by: Florian Echtler <f...@butterbrot.org>
Signed-off-by: Hans Verkuil <hans.verk...@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mche...@s-opensource.com>

 drivers/input/touchscreen/sur40.c | 75 +++++++++++++++++++++++++++++++++++++++
 1 file changed, 75 insertions(+)

---

diff --git a/drivers/input/touchscreen/sur40.c 
b/drivers/input/touchscreen/sur40.c
index 45ad5746aad8..3b56f7d05ec5 100644
--- a/drivers/input/touchscreen/sur40.c
+++ b/drivers/input/touchscreen/sur40.c
@@ -257,6 +257,81 @@ static int sur40_command(struct sur40_state *dev,
                               0x00, index, buffer, size, 1000);
 }
 
+/* poke a byte in the panel register space */
+static int sur40_poke(struct sur40_state *dev, u8 offset, u8 value)
+{
+       int result;
+       u8 index = 0x96; // 0xae for permanent write
+
+       result = usb_control_msg(dev->usbdev, usb_sndctrlpipe(dev->usbdev, 0),
+               SUR40_POKE, USB_TYPE_VENDOR | USB_RECIP_DEVICE | USB_DIR_OUT,
+               0x32, index, NULL, 0, 1000);
+       if (result < 0)
+               goto error;
+       msleep(5);
+
+       result = usb_control_msg(dev->usbdev, usb_sndctrlpipe(dev->usbdev, 0),
+               SUR40_POKE, USB_TYPE_VENDOR | USB_RECIP_DEVICE | USB_DIR_OUT,
+               0x72, offset, NULL, 0, 1000);
+       if (result < 0)
+               goto error;
+       msleep(5);
+
+       result = usb_control_msg(dev->usbdev, usb_sndctrlpipe(dev->usbdev, 0),
+               SUR40_POKE, USB_TYPE_VENDOR | USB_RECIP_DEVICE | USB_DIR_OUT,
+               0xb2, value, NULL, 0, 1000);
+       if (result < 0)
+               goto error;
+       msleep(5);
+
+error:
+       return result;
+}
+
+static int sur40_set_preprocessor(struct sur40_state *dev, u8 value)
+{
+       u8 setting_07[2] = { 0x01, 0x00 };
+       u8 setting_17[2] = { 0x85, 0x80 };
+       int result;
+
+       if (value > 1)
+               return -ERANGE;
+
+       result = usb_control_msg(dev->usbdev, usb_sndctrlpipe(dev->usbdev, 0),
+               SUR40_POKE, USB_TYPE_VENDOR | USB_RECIP_DEVICE | USB_DIR_OUT,
+               0x07, setting_07[value], NULL, 0, 1000);
+       if (result < 0)
+               goto error;
+       msleep(5);
+
+       result = usb_control_msg(dev->usbdev, usb_sndctrlpipe(dev->usbdev, 0),
+               SUR40_POKE, USB_TYPE_VENDOR | USB_RECIP_DEVICE | USB_DIR_OUT,
+               0x17, setting_17[value], NULL, 0, 1000);
+       if (result < 0)
+               goto error;
+       msleep(5);
+
+error:
+       return result;
+}
+
+static void sur40_set_vsvideo(struct sur40_state *handle, u8 value)
+{
+       int i;
+
+       for (i = 0; i < 4; i++)
+               sur40_poke(handle, 0x1c+i, value);
+       handle->vsvideo = value;
+}
+
+static void sur40_set_irlevel(struct sur40_state *handle, u8 value)
+{
+       int i;
+
+       for (i = 0; i < 8; i++)
+               sur40_poke(handle, 0x08+(2*i), value);
+}
+
 /* Initialization routine, called from sur40_open */
 static int sur40_init(struct sur40_state *dev)
 {

_______________________________________________
linuxtv-commits mailing list
linuxtv-commits@linuxtv.org
https://www.linuxtv.org/cgi-bin/mailman/listinfo/linuxtv-commits

Reply via email to