Commit 803f9ccf authored by Jean-Francois Moine's avatar Jean-Francois Moine Committed by Mauro Carvalho Chehab

V4L/DVB (9097): gspca: Adjust control values and restore compilation of sonixj.

- no compilation since last changeset
- brightness is a signed value
- better values of the color matrix

[mchehab@redhat.com: fix a merge conflict]
Signed-off-by: default avatarJean-Francois Moine <moinejf@free.fr>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent eeb00c60
...@@ -6,7 +6,7 @@ obj-$(CONFIG_USB_GSPCA_OV519) += gspca_ov519.o ...@@ -6,7 +6,7 @@ obj-$(CONFIG_USB_GSPCA_OV519) += gspca_ov519.o
obj-$(CONFIG_USB_GSPCA_PAC207) += gspca_pac207.o obj-$(CONFIG_USB_GSPCA_PAC207) += gspca_pac207.o
obj-$(CONFIG_USB_GSPCA_PAC7311) += gspca_pac7311.o obj-$(CONFIG_USB_GSPCA_PAC7311) += gspca_pac7311.o
obj-$(CONFIG_USB_GSPCA_SONIXB) += gspca_sonixb.o obj-$(CONFIG_USB_GSPCA_SONIXB) += gspca_sonixb.o
obj-$(CONFIG_USB_GSPCA_SONXIJ) += gspca_sonixj.o obj-$(CONFIG_USB_GSPCA_SONIXJ) += gspca_sonixj.o
obj-$(CONFIG_USB_GSPCA_SPCA500) += gspca_spca500.o obj-$(CONFIG_USB_GSPCA_SPCA500) += gspca_spca500.o
obj-$(CONFIG_USB_GSPCA_SPCA501) += gspca_spca501.o obj-$(CONFIG_USB_GSPCA_SPCA501) += gspca_spca501.o
obj-$(CONFIG_USB_GSPCA_SPCA505) += gspca_spca505.o obj-$(CONFIG_USB_GSPCA_SPCA505) += gspca_spca505.o
......
...@@ -267,10 +267,12 @@ static const __u8 gamma_def[] = { ...@@ -267,10 +267,12 @@ static const __u8 gamma_def[] = {
0xa6, 0xb2, 0xbf, 0xca, 0xd5, 0xe0, 0xeb, 0xf5, 0xff 0xa6, 0xb2, 0xbf, 0xca, 0xd5, 0xe0, 0xeb, 0xf5, 0xff
}; };
/* color matrix and offsets */
static const __u8 reg84[] = { static const __u8 reg84[] = {
0x14, 0x00, 0x27, 0x00, 0x07, 0x00, 0xe5, 0x0f, 0x14, 0x00, 0x27, 0x00, 0x07, 0x00, /* YR YG YB gains */
0xe4, 0x0f, 0x38, 0x00, 0x3e, 0x00, 0xc3, 0x0f, 0xe8, 0x0f, 0xda, 0x0f, 0x40, 0x00, /* UR UG UB */
0xf7, 0x0f, 0x00, 0x00, 0x00 0x3e, 0x00, 0xcd, 0x0f, 0xf7, 0x0f, /* VR VG VB */
0x00, 0x00, 0x00 /* YUV offsets */
}; };
static const __u8 hv7131r_sensor_init[][8] = { static const __u8 hv7131r_sensor_init[][8] = {
{0xC1, 0x11, 0x01, 0x08, 0x01, 0x00, 0x00, 0x10}, {0xC1, 0x11, 0x01, 0x08, 0x01, 0x00, 0x00, 0x10},
...@@ -1102,20 +1104,17 @@ static unsigned int setexposure(struct gspca_dev *gspca_dev, ...@@ -1102,20 +1104,17 @@ static unsigned int setexposure(struct gspca_dev *gspca_dev,
static void setbrightcont(struct gspca_dev *gspca_dev) static void setbrightcont(struct gspca_dev *gspca_dev)
{ {
struct sd *sd = (struct sd *) gspca_dev; struct sd *sd = (struct sd *) gspca_dev;
unsigned val; int val;
__u8 reg84_full[0x15]; __u8 reg84_full[0x15];
memset(reg84_full, 0, sizeof reg84_full); memcpy(reg84_full, reg84, sizeof reg84_full);
val = sd->contrast * 0x20 / CONTRAST_MAX + 0x10; /* 10..30 */ val = sd->contrast * 0x30 / CONTRAST_MAX + 0x10; /* 10..40 */
reg84_full[2] = val; reg84_full[0] = (val + 1) / 2; /* red */
reg84_full[0] = (val + 1) / 2; reg84_full[2] = val; /* green */
reg84_full[4] = (val + 1) / 5; reg84_full[4] = (val + 1) / 5; /* blue */
if (val > BRIGHTNESS_DEF) val = (sd->brightness - BRIGHTNESS_DEF) * 0x10
val = (sd->brightness - BRIGHTNESS_DEF) * 0x20
/ BRIGHTNESS_MAX; / BRIGHTNESS_MAX;
else reg84_full[0x12] = val & 0x1f; /* 5:0 signed value */
val = 0;
reg84_full[0x12] = val; /* 00..1f */
reg_w(gspca_dev, 0x84, reg84_full, sizeof reg84_full); reg_w(gspca_dev, 0x84, reg84_full, sizeof reg84_full);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment