aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/media/video/gspca/sonixj.c18
1 files changed, 13 insertions, 5 deletions
diff --git a/drivers/media/video/gspca/sonixj.c b/drivers/media/video/gspca/sonixj.c
index 44f86e1f80f0..572b0f363b64 100644
--- a/drivers/media/video/gspca/sonixj.c
+++ b/drivers/media/video/gspca/sonixj.c
@@ -977,13 +977,13 @@ static int sd_init(struct gspca_dev *gspca_dev)
977 case BRIDGE_SN9C105: 977 case BRIDGE_SN9C105:
978 if (regF1 != 0x11) 978 if (regF1 != 0x11)
979 return -ENODEV; 979 return -ENODEV;
980 reg_w(gspca_dev, 0x02, regGpio, 2); 980 reg_w(gspca_dev, 0x01, regGpio, 2);
981 break; 981 break;
982 case BRIDGE_SN9C120: 982 case BRIDGE_SN9C120:
983 if (regF1 != 0x12) 983 if (regF1 != 0x12)
984 return -ENODEV; 984 return -ENODEV;
985 regGpio[1] = 0x70; 985 regGpio[1] = 0x70;
986 reg_w(gspca_dev, 0x02, regGpio, 2); 986 reg_w(gspca_dev, 0x01, regGpio, 2);
987 break; 987 break;
988 default: 988 default:
989/* case BRIDGE_SN9C110: */ 989/* case BRIDGE_SN9C110: */
@@ -1184,7 +1184,7 @@ static void sd_start(struct gspca_dev *gspca_dev)
1184 static const __u8 CA[] = { 0x28, 0xd8, 0x14, 0xec }; 1184 static const __u8 CA[] = { 0x28, 0xd8, 0x14, 0xec };
1185 static const __u8 CE[] = { 0x32, 0xdd, 0x2d, 0xdd }; /* MI0360 */ 1185 static const __u8 CE[] = { 0x32, 0xdd, 0x2d, 0xdd }; /* MI0360 */
1186 static const __u8 CE_ov76xx[] = 1186 static const __u8 CE_ov76xx[] =
1187 { 0x32, 0xdd, 0x32, 0xdd }; /* OV7630/48 */ 1187 { 0x32, 0xdd, 0x32, 0xdd };
1188 1188
1189 sn9c1xx = sn_tb[(int) sd->sensor]; 1189 sn9c1xx = sn_tb[(int) sd->sensor];
1190 configure_gpio(gspca_dev, sn9c1xx); 1190 configure_gpio(gspca_dev, sn9c1xx);
@@ -1224,8 +1224,15 @@ static void sd_start(struct gspca_dev *gspca_dev)
1224 reg_w(gspca_dev, 0x20, gamma_def, sizeof gamma_def); 1224 reg_w(gspca_dev, 0x20, gamma_def, sizeof gamma_def);
1225 for (i = 0; i < 8; i++) 1225 for (i = 0; i < 8; i++)
1226 reg_w(gspca_dev, 0x84, reg84, sizeof reg84); 1226 reg_w(gspca_dev, 0x84, reg84, sizeof reg84);
1227 switch (sd->sensor) {
1228 case SENSOR_OV7660:
1229 reg_w1(gspca_dev, 0x9a, 0x05);
1230 break;
1231 default:
1227 reg_w1(gspca_dev, 0x9a, 0x08); 1232 reg_w1(gspca_dev, 0x9a, 0x08);
1228 reg_w1(gspca_dev, 0x99, 0x59); 1233 reg_w1(gspca_dev, 0x99, 0x59);
1234 break;
1235 }
1229 1236
1230 mode = gspca_dev->cam.cam_mode[(int) gspca_dev->curr_mode].priv; 1237 mode = gspca_dev->cam.cam_mode[(int) gspca_dev->curr_mode].priv;
1231 if (mode) 1238 if (mode)
@@ -1276,8 +1283,8 @@ static void sd_start(struct gspca_dev *gspca_dev)
1276/* reg1 = 0x44; */ 1283/* reg1 = 0x44; */
1277/* reg1 = 0x46; (done) */ 1284/* reg1 = 0x46; (done) */
1278 } else { 1285 } else {
1279 reg17 = 0x22; /* 640 MCKSIZE */ 1286 reg17 = 0xa2; /* 640 */
1280 reg1 = 0x06; 1287 reg1 = 0x44;
1281 } 1288 }
1282 break; 1289 break;
1283 } 1290 }
@@ -1286,6 +1293,7 @@ static void sd_start(struct gspca_dev *gspca_dev)
1286 switch (sd->sensor) { 1293 switch (sd->sensor) {
1287 case SENSOR_OV7630: 1294 case SENSOR_OV7630:
1288 case SENSOR_OV7648: 1295 case SENSOR_OV7648:
1296 case SENSOR_OV7660:
1289 reg_w(gspca_dev, 0xce, CE_ov76xx, 4); 1297 reg_w(gspca_dev, 0xce, CE_ov76xx, 4);
1290 break; 1298 break;
1291 default: 1299 default: