aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media')
-rw-r--r--drivers/media/video/gspca/Makefile2
-rw-r--r--drivers/media/video/gspca/sonixj.c27
2 files changed, 14 insertions, 15 deletions
diff --git a/drivers/media/video/gspca/Makefile b/drivers/media/video/gspca/Makefile
index b510b06fd873..b87322f4a487 100644
--- a/drivers/media/video/gspca/Makefile
+++ b/drivers/media/video/gspca/Makefile
@@ -6,7 +6,7 @@ obj-$(CONFIG_USB_GSPCA_OV519) += gspca_ov519.o
6obj-$(CONFIG_USB_GSPCA_PAC207) += gspca_pac207.o 6obj-$(CONFIG_USB_GSPCA_PAC207) += gspca_pac207.o
7obj-$(CONFIG_USB_GSPCA_PAC7311) += gspca_pac7311.o 7obj-$(CONFIG_USB_GSPCA_PAC7311) += gspca_pac7311.o
8obj-$(CONFIG_USB_GSPCA_SONIXB) += gspca_sonixb.o 8obj-$(CONFIG_USB_GSPCA_SONIXB) += gspca_sonixb.o
9obj-$(CONFIG_USB_GSPCA_SONXIJ) += gspca_sonixj.o 9obj-$(CONFIG_USB_GSPCA_SONIXJ) += gspca_sonixj.o
10obj-$(CONFIG_USB_GSPCA_SPCA500) += gspca_spca500.o 10obj-$(CONFIG_USB_GSPCA_SPCA500) += gspca_spca500.o
11obj-$(CONFIG_USB_GSPCA_SPCA501) += gspca_spca501.o 11obj-$(CONFIG_USB_GSPCA_SPCA501) += gspca_spca501.o
12obj-$(CONFIG_USB_GSPCA_SPCA505) += gspca_spca505.o 12obj-$(CONFIG_USB_GSPCA_SPCA505) += gspca_spca505.o
diff --git a/drivers/media/video/gspca/sonixj.c b/drivers/media/video/gspca/sonixj.c
index 03fe77d38cc1..93b17340b7b1 100644
--- a/drivers/media/video/gspca/sonixj.c
+++ b/drivers/media/video/gspca/sonixj.c
@@ -267,10 +267,12 @@ static const __u8 gamma_def[] = {
267 0xa6, 0xb2, 0xbf, 0xca, 0xd5, 0xe0, 0xeb, 0xf5, 0xff 267 0xa6, 0xb2, 0xbf, 0xca, 0xd5, 0xe0, 0xeb, 0xf5, 0xff
268}; 268};
269 269
270/* color matrix and offsets */
270static const __u8 reg84[] = { 271static const __u8 reg84[] = {
271 0x14, 0x00, 0x27, 0x00, 0x07, 0x00, 0xe5, 0x0f, 272 0x14, 0x00, 0x27, 0x00, 0x07, 0x00, /* YR YG YB gains */
272 0xe4, 0x0f, 0x38, 0x00, 0x3e, 0x00, 0xc3, 0x0f, 273 0xe8, 0x0f, 0xda, 0x0f, 0x40, 0x00, /* UR UG UB */
273 0xf7, 0x0f, 0x00, 0x00, 0x00 274 0x3e, 0x00, 0xcd, 0x0f, 0xf7, 0x0f, /* VR VG VB */
275 0x00, 0x00, 0x00 /* YUV offsets */
274}; 276};
275static const __u8 hv7131r_sensor_init[][8] = { 277static const __u8 hv7131r_sensor_init[][8] = {
276 {0xC1, 0x11, 0x01, 0x08, 0x01, 0x00, 0x00, 0x10}, 278 {0xC1, 0x11, 0x01, 0x08, 0x01, 0x00, 0x00, 0x10},
@@ -1102,20 +1104,17 @@ static unsigned int setexposure(struct gspca_dev *gspca_dev,
1102static void setbrightcont(struct gspca_dev *gspca_dev) 1104static void setbrightcont(struct gspca_dev *gspca_dev)
1103{ 1105{
1104 struct sd *sd = (struct sd *) gspca_dev; 1106 struct sd *sd = (struct sd *) gspca_dev;
1105 unsigned val; 1107 int val;
1106 __u8 reg84_full[0x15]; 1108 __u8 reg84_full[0x15];
1107 1109
1108 memset(reg84_full, 0, sizeof reg84_full); 1110 memcpy(reg84_full, reg84, sizeof reg84_full);
1109 val = sd->contrast * 0x20 / CONTRAST_MAX + 0x10; /* 10..30 */ 1111 val = sd->contrast * 0x30 / CONTRAST_MAX + 0x10; /* 10..40 */
1110 reg84_full[2] = val; 1112 reg84_full[0] = (val + 1) / 2; /* red */
1111 reg84_full[0] = (val + 1) / 2; 1113 reg84_full[2] = val; /* green */
1112 reg84_full[4] = (val + 1) / 5; 1114 reg84_full[4] = (val + 1) / 5; /* blue */
1113 if (val > BRIGHTNESS_DEF) 1115 val = (sd->brightness - BRIGHTNESS_DEF) * 0x10
1114 val = (sd->brightness - BRIGHTNESS_DEF) * 0x20
1115 / BRIGHTNESS_MAX; 1116 / BRIGHTNESS_MAX;
1116 else 1117 reg84_full[0x12] = val & 0x1f; /* 5:0 signed value */
1117 val = 0;
1118 reg84_full[0x12] = val; /* 00..1f */
1119 reg_w(gspca_dev, 0x84, reg84_full, sizeof reg84_full); 1118 reg_w(gspca_dev, 0x84, reg84_full, sizeof reg84_full);
1120} 1119}
1121 1120