V4L/DVB (9997): gspca - main: Don't lock the kernel on ioctl.
[safe/jmp/linux-2.6] / drivers / media / video / gspca / zc3xx.c
index 4f95ab8..a62c8ac 100644 (file)
@@ -51,16 +51,16 @@ struct sd {
 #define SENSOR_CS2102 0
 #define SENSOR_CS2102K 1
 #define SENSOR_GC0305 2
-#define SENSOR_HDCS2020 3
-#define SENSOR_HDCS2020b 4
-#define SENSOR_HV7131B 5
-#define SENSOR_HV7131C 6
-#define SENSOR_ICM105A 7
-#define SENSOR_MC501CB 8
-#define SENSOR_OV7620 9
-/*#define SENSOR_OV7648 9 - same values */
-#define SENSOR_OV7630C 10
-#define SENSOR_PAS106 11
+#define SENSOR_HDCS2020b 3
+#define SENSOR_HV7131B 4
+#define SENSOR_HV7131C 5
+#define SENSOR_ICM105A 6
+#define SENSOR_MC501CB 7
+#define SENSOR_OV7620 8
+/*#define SENSOR_OV7648 8 - same values */
+#define SENSOR_OV7630C 9
+#define SENSOR_PAS106 10
+#define SENSOR_PAS202B 11
 #define SENSOR_PB0330 12
 #define SENSOR_PO2030 13
 #define SENSOR_TAS5130CK 14
@@ -1653,295 +1653,6 @@ static const struct usb_action gc0305_NoFliker[] = {
        {}
 };
 
-/* play poker with registers at your own risk !! */
-static const struct usb_action hdcs2020xx_Initial[] = {
-       {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
-       {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
-       {0xa0, 0x0e, ZC3XX_R010_CMOSSENSORSELECT},
-       {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
-       {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
-       {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
-       {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
-       {0xa0, 0xd0, ZC3XX_R006_FRAMEHEIGHTLOW},
-                                               /* D0 ?? E0 did not start */
-       {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
-       {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
-       {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
-       {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
-       {0xa0, 0x08, ZC3XX_R098_WINYSTARTLOW},
-       {0xa0, 0x02, ZC3XX_R09A_WINXSTARTLOW},
-       {0xa0, 0x08, ZC3XX_R11A_FIRSTYLOW},
-       {0xa0, 0x02, ZC3XX_R11C_FIRSTXLOW},
-       {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
-       {0xa0, 0xd8, ZC3XX_R09C_WINHEIGHTLOW},
-       {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
-       {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
-       {0xaa, 0x02, 0x0002},
-       {0xaa, 0x07, 0x0006},
-       {0xaa, 0x08, 0x0002},
-       {0xaa, 0x09, 0x0006},
-       {0xaa, 0x0a, 0x0001},
-       {0xaa, 0x0b, 0x0001},
-       {0xaa, 0x0c, 0x0008},
-       {0xaa, 0x0d, 0x0000},
-       {0xaa, 0x10, 0x0000},
-       {0xaa, 0x12, 0x0005},
-       {0xaa, 0x13, 0x0063},
-       {0xaa, 0x15, 0x0070},
-       {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
-       {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
-       {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
-       {0xa0, 0x00, 0x01ad},
-       {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
-       {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
-       {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
-       {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
-       {0xa0, 0x70, ZC3XX_R18D_YTARGET},
-       {0xa1, 0x01, 0x0002},
-       {0xa1, 0x01, 0x0008},
-       {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* clock ? */
-       {0xa0, 0x04, ZC3XX_R1C6_SHARPNESS00},   /* sharpness+ */
-       {0xa1, 0x01, 0x01c8},
-       {0xa1, 0x01, 0x01c9},
-       {0xa1, 0x01, 0x01ca},
-       {0xa0, 0x07, ZC3XX_R1CB_SHARPNESS05},   /* sharpness- */
-       {0xa0, 0x11, ZC3XX_R120_GAMMA00},       /* gamma ~4 */
-       {0xa0, 0x37, ZC3XX_R121_GAMMA01},
-       {0xa0, 0x58, ZC3XX_R122_GAMMA02},
-       {0xa0, 0x79, ZC3XX_R123_GAMMA03},
-       {0xa0, 0x91, ZC3XX_R124_GAMMA04},
-       {0xa0, 0xa6, ZC3XX_R125_GAMMA05},
-       {0xa0, 0xb8, ZC3XX_R126_GAMMA06},
-       {0xa0, 0xc7, ZC3XX_R127_GAMMA07},
-       {0xa0, 0xd3, ZC3XX_R128_GAMMA08},
-       {0xa0, 0xde, ZC3XX_R129_GAMMA09},
-       {0xa0, 0xe6, ZC3XX_R12A_GAMMA0A},
-       {0xa0, 0xed, ZC3XX_R12B_GAMMA0B},
-       {0xa0, 0xf3, ZC3XX_R12C_GAMMA0C},
-       {0xa0, 0xf8, ZC3XX_R12D_GAMMA0D},
-       {0xa0, 0xfb, ZC3XX_R12E_GAMMA0E},
-       {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
-       {0xa0, 0x26, ZC3XX_R130_GAMMA10},
-       {0xa0, 0x23, ZC3XX_R131_GAMMA11},
-       {0xa0, 0x20, ZC3XX_R132_GAMMA12},
-       {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
-       {0xa0, 0x16, ZC3XX_R134_GAMMA14},
-       {0xa0, 0x13, ZC3XX_R135_GAMMA15},
-       {0xa0, 0x10, ZC3XX_R136_GAMMA16},
-       {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
-       {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
-       {0xa0, 0x09, ZC3XX_R139_GAMMA19},
-       {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
-       {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
-       {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
-       {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
-       {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
-       {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
-
-       {0xa0, 0x4c, ZC3XX_R10A_RGB00}, /* matrix */
-       {0xa0, 0xf5, ZC3XX_R10B_RGB01},
-       {0xa0, 0xff, ZC3XX_R10C_RGB02},
-       {0xa0, 0xf9, ZC3XX_R10D_RGB10},
-       {0xa0, 0x51, ZC3XX_R10E_RGB11},
-       {0xa0, 0xf5, ZC3XX_R10F_RGB12},
-       {0xa0, 0xfb, ZC3XX_R110_RGB20},
-       {0xa0, 0xed, ZC3XX_R111_RGB21},
-       {0xa0, 0x5f, ZC3XX_R112_RGB22},
-
-       {0xa1, 0x01, 0x0180},
-       {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
-       {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
-       {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},
-       {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},
-       {0xaa, 0x20, 0x0004},
-       {0xaa, 0x21, 0x003d},
-       {0xaa, 0x03, 0x0041},
-       {0xaa, 0x04, 0x0010},
-       {0xaa, 0x05, 0x003d},
-       {0xaa, 0x0e, 0x0001},
-       {0xaa, 0x0f, 0x0000},
-       {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
-       {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
-       {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
-       {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
-       {0xa0, 0x3d, ZC3XX_R192_EXPOSURELIMITLOW},
-       {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
-       {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
-       {0xa0, 0x9b, ZC3XX_R197_ANTIFLICKERLOW},
-       {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
-       {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
-       {0xa0, 0x41, ZC3XX_R01D_HSYNC_0},
-       {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1},
-       {0xa0, 0xad, ZC3XX_R01F_HSYNC_2},
-       {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
-       {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},
-       {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},
-       {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
-       {0xa1, 0x01, 0x0195},
-       {0xa1, 0x01, 0x0196},
-       {0xa1, 0x01, 0x0197},
-       {0xa0, 0x3d, ZC3XX_R192_EXPOSURELIMITLOW},
-       {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
-       {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
-       {0xa0, 0x1d, ZC3XX_R116_RGAIN},
-       {0xa0, 0x40, ZC3XX_R117_GGAIN},
-       {0xa0, 0x85, ZC3XX_R118_BGAIN},
-       {0xa1, 0x01, 0x0116},
-       {0xa1, 0x01, 0x0118},
-       {0xa1, 0x01, 0x0180},
-       {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
-       {0xa0, 0x1d, ZC3XX_R116_RGAIN},
-       {0xa0, 0x40, ZC3XX_R117_GGAIN},
-       {0xa0, 0x85, ZC3XX_R118_BGAIN},
-       {0xa1, 0x01, 0x0116},
-       {0xa1, 0x01, 0x0118},
-/*     {0xa0, 0x02, ZC3XX_R008_CLOCKSETTING}, */
-       {0xa0, 0x00, 0x0007},
-       {}
-};
-
-static const struct usb_action hdcs2020xx_InitialScale[] = {
-       {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
-       {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
-       {0xa0, 0x0e, ZC3XX_R010_CMOSSENSORSELECT},
-       {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
-       {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
-       {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
-       {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
-       {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
-       {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
-       {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
-       {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
-       {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
-       {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
-       {0xa0, 0x03, ZC3XX_R09A_WINXSTARTLOW},
-       {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
-       {0xa0, 0x03, ZC3XX_R11C_FIRSTXLOW},
-       {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
-       {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},
-       {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
-       {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},
-       {0xaa, 0x02, 0x0002},
-       {0xaa, 0x07, 0x0006},
-       {0xaa, 0x08, 0x0002},
-       {0xaa, 0x09, 0x0006},
-       {0xaa, 0x0a, 0x0001},
-       {0xaa, 0x0b, 0x0001},
-       {0xaa, 0x0c, 0x0008},
-       {0xaa, 0x0d, 0x0000},
-       {0xaa, 0x10, 0x0000},
-       {0xaa, 0x12, 0x0005},
-       {0xaa, 0x13, 0x0063},
-       {0xaa, 0x15, 0x0070},
-       {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},
-       {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
-       {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
-       {0xa0, 0x00, 0x01ad},
-       {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
-       {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
-       {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
-       {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
-       {0xa0, 0x70, ZC3XX_R18D_YTARGET},
-       {0xa1, 0x01, 0x0002},
-       {0xa1, 0x01, 0x0008},
-       {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* clock ? */
-       {0xa0, 0x04, ZC3XX_R1C6_SHARPNESS00},   /* sharpness+ */
-       {0xa1, 0x01, 0x01c8},
-       {0xa1, 0x01, 0x01c9},
-       {0xa1, 0x01, 0x01ca},
-       {0xa0, 0x07, ZC3XX_R1CB_SHARPNESS05},   /* sharpness- */
-       {0xa0, 0x11, ZC3XX_R120_GAMMA00},       /* gamma ~4*/
-       {0xa0, 0x37, ZC3XX_R121_GAMMA01},
-       {0xa0, 0x58, ZC3XX_R122_GAMMA02},
-       {0xa0, 0x79, ZC3XX_R123_GAMMA03},
-       {0xa0, 0x91, ZC3XX_R124_GAMMA04},
-       {0xa0, 0xa6, ZC3XX_R125_GAMMA05},
-       {0xa0, 0xb8, ZC3XX_R126_GAMMA06},
-       {0xa0, 0xc7, ZC3XX_R127_GAMMA07},
-       {0xa0, 0xd3, ZC3XX_R128_GAMMA08},
-       {0xa0, 0xde, ZC3XX_R129_GAMMA09},
-       {0xa0, 0xe6, ZC3XX_R12A_GAMMA0A},
-       {0xa0, 0xed, ZC3XX_R12B_GAMMA0B},
-       {0xa0, 0xf3, ZC3XX_R12C_GAMMA0C},
-       {0xa0, 0xf8, ZC3XX_R12D_GAMMA0D},
-       {0xa0, 0xfb, ZC3XX_R12E_GAMMA0E},
-       {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
-       {0xa0, 0x26, ZC3XX_R130_GAMMA10},
-       {0xa0, 0x23, ZC3XX_R131_GAMMA11},
-       {0xa0, 0x20, ZC3XX_R132_GAMMA12},
-       {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
-       {0xa0, 0x16, ZC3XX_R134_GAMMA14},
-       {0xa0, 0x13, ZC3XX_R135_GAMMA15},
-       {0xa0, 0x10, ZC3XX_R136_GAMMA16},
-       {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
-       {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
-       {0xa0, 0x09, ZC3XX_R139_GAMMA19},
-       {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
-       {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
-       {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
-       {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
-       {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
-       {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
-       {0xa0, 0x60, ZC3XX_R10A_RGB00}, /* matrix */
-       {0xa0, 0xff, ZC3XX_R10B_RGB01},
-       {0xa0, 0xff, ZC3XX_R10C_RGB02},
-       {0xa0, 0xff, ZC3XX_R10D_RGB10},
-       {0xa0, 0x60, ZC3XX_R10E_RGB11},
-       {0xa0, 0xff, ZC3XX_R10F_RGB12},
-       {0xa0, 0xff, ZC3XX_R110_RGB20},
-       {0xa0, 0xff, ZC3XX_R111_RGB21},
-       {0xa0, 0x60, ZC3XX_R112_RGB22},
-
-       {0xa1, 0x01, 0x0180},
-       {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
-       {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
-       {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},
-       {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},
-       {0xaa, 0x20, 0x0002},
-       {0xaa, 0x21, 0x001b},
-       {0xaa, 0x03, 0x0044},
-       {0xaa, 0x04, 0x0008},
-       {0xaa, 0x05, 0x001b},
-       {0xaa, 0x0e, 0x0001},
-       {0xaa, 0x0f, 0x0000},
-       {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
-       {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
-       {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
-       {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
-       {0xa0, 0x1b, ZC3XX_R192_EXPOSURELIMITLOW},
-       {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
-       {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
-       {0xa0, 0x4d, ZC3XX_R197_ANTIFLICKERLOW},
-       {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
-       {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
-       {0xa0, 0x44, ZC3XX_R01D_HSYNC_0},
-       {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1},
-       {0xa0, 0xad, ZC3XX_R01F_HSYNC_2},
-       {0xa0, 0xeb, ZC3XX_R020_HSYNC_3},
-       {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},
-       {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},
-       {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
-       {0xa1, 0x01, 0x0195},
-       {0xa1, 0x01, 0x0196},
-       {0xa1, 0x01, 0x0197},
-       {0xa0, 0x1b, ZC3XX_R192_EXPOSURELIMITLOW},
-       {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
-       {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
-       {0xa0, 0x1d, ZC3XX_R116_RGAIN},
-       {0xa0, 0x40, ZC3XX_R117_GGAIN},
-       {0xa0, 0x99, ZC3XX_R118_BGAIN},
-       {0xa1, 0x01, 0x0116},
-       {0xa1, 0x01, 0x0118},
-       {0xa1, 0x01, 0x0180},
-       {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
-       {0xa0, 0x1d, ZC3XX_R116_RGAIN},
-       {0xa0, 0x40, ZC3XX_R117_GGAIN},
-       {0xa0, 0x99, ZC3XX_R118_BGAIN},
-/*     {0xa0, 0x02, ZC3XX_R008_CLOCKSETTING}, */
-       {0xa0, 0x00, 0x0007},
-/*     {0xa0, 0x18, 0x00fe}, */
-       {}
-};
 static const struct usb_action hdcs2020xb_Initial[] = {
        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
        {0xa0, 0x11, ZC3XX_R002_CLOCKSELECT},
@@ -4419,6 +4130,270 @@ static const struct usb_action pas106b_NoFliker[] = {
        {}
 };
 
+/* from usbvm31b.inf */
+static const struct usb_action pas202b_Initial[] = {   /* 640x480 */
+       {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},         /* 00,00,01,cc */
+       {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING},          /* 00,08,00,cc */
+       {0xa0, 0x0e, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0e,cc */
+       {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},           /* 00,02,00,cc */
+       {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},        /* 00,03,02,cc */
+       {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},         /* 00,04,80,cc */
+       {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},       /* 00,05,01,cc */
+       {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},        /* 00,06,e0,cc */
+       {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},       /* 00,01,01,cc */
+       {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,03,cc */
+       {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,01,cc */
+       {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},       /* 00,8d,08,cc */
+       {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},          /* 00,98,00,cc */
+       {0xa0, 0x03, ZC3XX_R09A_WINXSTARTLOW},          /* 00,9a,03,cc */
+       {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},             /* 01,1a,00,cc */
+       {0xa0, 0x03, ZC3XX_R11C_FIRSTXLOW},             /* 01,1c,03,cc */
+       {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},         /* 00,9b,01,cc */
+       {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},          /* 00,9c,e6,cc */
+       {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},          /* 00,9d,02,cc */
+       {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},           /* 00,9e,86,cc */
+       {0xaa, 0x02, 0x0002},                   /* 00,02,04,aa --> 02 */
+       {0xaa, 0x07, 0x0006},                           /* 00,07,06,aa */
+       {0xaa, 0x08, 0x0002},                           /* 00,08,02,aa */
+       {0xaa, 0x09, 0x0006},                           /* 00,09,06,aa */
+       {0xaa, 0x0a, 0x0001},                           /* 00,0a,01,aa */
+       {0xaa, 0x0b, 0x0001},                           /* 00,0b,01,aa */
+       {0xaa, 0x0c, 0x0008},                           /* 00,0c,08,aa */
+       {0xaa, 0x0d, 0x0000},                           /* 00,0d,00,aa */
+       {0xaa, 0x10, 0x0000},                           /* 00,10,00,aa */
+       {0xaa, 0x12, 0x0005},                           /* 00,12,05,aa */
+       {0xaa, 0x13, 0x0063},                           /* 00,13,63,aa */
+       {0xaa, 0x15, 0x0070},                           /* 00,15,70,aa */
+       {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},      /* 01,01,b7,cc */
+       {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},         /* 01,00,0d,cc */
+       {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},             /* 01,89,06,cc */
+       {0xa0, 0x00, 0x01ad},                           /* 01,ad,00,cc */
+       {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},         /* 01,c5,03,cc */
+       {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},           /* 01,cb,13,cc */
+       {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},        /* 02,50,08,cc */
+       {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},          /* 03,01,08,cc */
+       {0xa0, 0x70, ZC3XX_R18D_YTARGET},               /* 01,8d,70,cc */
+       {}
+};
+static const struct usb_action pas202b_InitialScale[] = {      /* 320x240 */
+       {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},         /* 00,00,01,cc */
+       {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING},          /* 00,08,00,cc */
+       {0xa0, 0x0e, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0e,cc */
+       {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},           /* 00,02,10,cc */
+       {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},        /* 00,03,02,cc */
+       {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},         /* 00,04,80,cc */
+       {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},       /* 00,05,01,cc */
+       {0xa0, 0xd0, ZC3XX_R006_FRAMEHEIGHTLOW},        /* 00,06,d0,cc */
+       {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},       /* 00,01,01,cc */
+       {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,03,cc */
+       {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,01,cc */
+       {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},       /* 00,8d,08,cc */
+       {0xa0, 0x08, ZC3XX_R098_WINYSTARTLOW},          /* 00,98,08,cc */
+       {0xa0, 0x02, ZC3XX_R09A_WINXSTARTLOW},          /* 00,9a,02,cc */
+       {0xa0, 0x08, ZC3XX_R11A_FIRSTYLOW},             /* 01,1a,08,cc */
+       {0xa0, 0x02, ZC3XX_R11C_FIRSTXLOW},             /* 01,1c,02,cc */
+       {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},         /* 00,9b,01,cc */
+       {0xa0, 0xd8, ZC3XX_R09C_WINHEIGHTLOW},          /* 00,9c,d8,cc */
+       {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},          /* 00,9d,02,cc */
+       {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},           /* 00,9e,88,cc */
+       {0xaa, 0x02, 0x0002},                           /* 00,02,02,aa */
+       {0xaa, 0x07, 0x0006},                           /* 00,07,06,aa */
+       {0xaa, 0x08, 0x0002},                           /* 00,08,02,aa */
+       {0xaa, 0x09, 0x0006},                           /* 00,09,06,aa */
+       {0xaa, 0x0a, 0x0001},                           /* 00,0a,01,aa */
+       {0xaa, 0x0b, 0x0001},                           /* 00,0b,01,aa */
+       {0xaa, 0x0c, 0x0008},                           /* 00,0c,08,aa */
+       {0xaa, 0x0d, 0x0000},                           /* 00,0d,00,aa */
+       {0xaa, 0x10, 0x0000},                           /* 00,10,00,aa */
+       {0xaa, 0x12, 0x0005},                           /* 00,12,05,aa */
+       {0xaa, 0x13, 0x0063},                           /* 00,13,63,aa */
+       {0xaa, 0x15, 0x0070},                           /* 00,15,70,aa */
+       {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},      /* 01,01,37,cc */
+       {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},         /* 01,00,0d,cc */
+       {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},             /* 01,89,06,cc */
+       {0xa0, 0x00, 0x01ad},                           /* 01,ad,00,cc */
+       {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},         /* 01,c5,03,cc */
+       {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},           /* 01,cb,13,cc */
+       {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},        /* 02,50,08,cc */
+       {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},          /* 03,01,08,cc */
+       {0xa0, 0x70, ZC3XX_R18D_YTARGET},               /* 01,8d,70,cc */
+       {}
+};
+static const struct usb_action pas202b_50HZ[] = {
+       {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},         /* 00,19,00,cc */
+       {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},            /* 00,87,20,cc */
+       {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},            /* 00,88,21,cc */
+       {0xaa, 0x20, 0x0002},                           /* 00,20,02,aa */
+       {0xaa, 0x21, 0x0068},                           /* 00,21,68,aa */
+       {0xaa, 0x03, 0x0044},                           /* 00,03,44,aa */
+       {0xaa, 0x04, 0x0009},                           /* 00,04,09,aa */
+       {0xaa, 0x05, 0x0028},                           /* 00,05,28,aa */
+       {0xaa, 0x0e, 0x0001},                           /* 00,0e,01,aa */
+       {0xaa, 0x0f, 0x0000},                           /* 00,0f,00,aa */
+       {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,14,cc */
+       {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
+       {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
+       {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,07,cc */
+       {0xa0, 0xd2, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,d2,cc */
+       {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
+       {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
+       {0xa0, 0x4d, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,4d,cc */
+       {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},              /* 01,8c,10,cc */
+       {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},            /* 01,8f,20,cc */
+       {0xa0, 0x44, ZC3XX_R01D_HSYNC_0},               /* 00,1d,44,cc */
+       {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1},               /* 00,1e,6f,cc */
+       {0xa0, 0xad, ZC3XX_R01F_HSYNC_2},               /* 00,1f,ad,cc */
+       {0xa0, 0xeb, ZC3XX_R020_HSYNC_3},               /* 00,20,eb,cc */
+       {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},            /* 00,87,0f,cc */
+       {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},            /* 00,88,0e,cc */
+       {}
+};
+static const struct usb_action pas202b_50HZScale[] = {
+       {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},         /* 00,19,00,cc */
+       {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},            /* 00,87,20,cc */
+       {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},            /* 00,88,21,cc */
+       {0xaa, 0x20, 0x0002},                           /* 00,20,02,aa */
+       {0xaa, 0x21, 0x006c},                           /* 00,21,6c,aa */
+       {0xaa, 0x03, 0x0041},                           /* 00,03,41,aa */
+       {0xaa, 0x04, 0x0009},                           /* 00,04,09,aa */
+       {0xaa, 0x05, 0x002c},                           /* 00,05,2c,aa */
+       {0xaa, 0x0e, 0x0001},                           /* 00,0e,01,aa */
+       {0xaa, 0x0f, 0x0000},                           /* 00,0f,00,aa */
+       {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,14,cc */
+       {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
+       {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
+       {0xa0, 0x0f, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,0f,cc */
+       {0xa0, 0xbe, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,be,cc */
+       {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
+       {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
+       {0xa0, 0x9b, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,9b,cc */
+       {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},              /* 01,8c,10,cc */
+       {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},            /* 01,8f,20,cc */
+       {0xa0, 0x41, ZC3XX_R01D_HSYNC_0},               /* 00,1d,41,cc */
+       {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1},               /* 00,1e,6f,cc */
+       {0xa0, 0xad, ZC3XX_R01F_HSYNC_2},               /* 00,1f,ad,cc */
+       {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,20,ff,cc */
+       {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},            /* 00,87,0f,cc */
+       {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},            /* 00,88,0e,cc */
+       {}
+};
+static const struct usb_action pas202b_60HZ[] = {
+       {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},         /* 00,19,00,cc */
+       {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},            /* 00,87,20,cc */
+       {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},            /* 00,88,21,cc */
+       {0xaa, 0x20, 0x0002},                           /* 00,20,02,aa */
+       {0xaa, 0x21, 0x0000},                           /* 00,21,00,aa */
+       {0xaa, 0x03, 0x0045},                           /* 00,03,45,aa */
+       {0xaa, 0x04, 0x0008},                           /* 00,04,08,aa */
+       {0xaa, 0x05, 0x0000},                           /* 00,05,00,aa */
+       {0xaa, 0x0e, 0x0001},                           /* 00,0e,01,aa */
+       {0xaa, 0x0f, 0x0000},                           /* 00,0f,00,aa */
+       {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,14,cc */
+       {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
+       {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
+       {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,07,cc */
+       {0xa0, 0xc0, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,c0,cc */
+       {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
+       {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
+       {0xa0, 0x40, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,40,cc */
+       {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},              /* 01,8c,10,cc */
+       {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},            /* 01,8f,20,cc */
+       {0xa0, 0x45, ZC3XX_R01D_HSYNC_0},               /* 00,1d,45,cc */
+       {0xa0, 0x8e, ZC3XX_R01E_HSYNC_1},               /* 00,1e,8e,cc */
+       {0xa0, 0xc1, ZC3XX_R01F_HSYNC_2},               /* 00,1f,c1,cc */
+       {0xa0, 0xf5, ZC3XX_R020_HSYNC_3},               /* 00,20,f5,cc */
+       {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},            /* 00,87,0f,cc */
+       {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},            /* 00,88,0e,cc */
+       {}
+};
+static const struct usb_action pas202b_60HZScale[] = {
+       {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},         /* 00,19,00,cc */
+       {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},            /* 00,87,20,cc */
+       {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},            /* 00,88,21,cc */
+       {0xaa, 0x20, 0x0002},                           /* 00,20,02,aa */
+       {0xaa, 0x21, 0x0004},                           /* 00,21,04,aa */
+       {0xaa, 0x03, 0x0042},                           /* 00,03,42,aa */
+       {0xaa, 0x04, 0x0008},                           /* 00,04,08,aa */
+       {0xaa, 0x05, 0x0004},                           /* 00,05,04,aa */
+       {0xaa, 0x0e, 0x0001},                           /* 00,0e,01,aa */
+       {0xaa, 0x0f, 0x0000},                           /* 00,0f,00,aa */
+       {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,14,cc */
+       {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
+       {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
+       {0xa0, 0x0f, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,0f,cc */
+       {0xa0, 0x9f, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,9f,cc */
+       {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
+       {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
+       {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,81,cc */
+       {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},              /* 01,8c,10,cc */
+       {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},            /* 01,8f,20,cc */
+       {0xa0, 0x42, ZC3XX_R01D_HSYNC_0},               /* 00,1d,42,cc */
+       {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1},               /* 00,1e,6f,cc */
+       {0xa0, 0xaf, ZC3XX_R01F_HSYNC_2},               /* 00,1f,af,cc */
+       {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,20,ff,cc */
+       {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},            /* 00,87,0f,cc */
+       {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},            /* 00,88,0e,cc */
+       {}
+};
+static const struct usb_action pas202b_NoFliker[] = {
+       {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},         /* 00,19,00,cc */
+       {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},            /* 00,87,20,cc */
+       {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},            /* 00,88,21,cc */
+       {0xaa, 0x20, 0x0002},                           /* 00,20,02,aa */
+       {0xaa, 0x21, 0x0020},                           /* 00,21,20,aa */
+       {0xaa, 0x03, 0x0040},                           /* 00,03,40,aa */
+       {0xaa, 0x04, 0x0008},                           /* 00,04,08,aa */
+       {0xaa, 0x05, 0x0020},                           /* 00,05,20,aa */
+       {0xaa, 0x0e, 0x0001},                           /* 00,0e,01,aa */
+       {0xaa, 0x0f, 0x0000},                           /* 00,0f,00,aa */
+       {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
+       {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,07,cc */
+       {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,f0,cc */
+       {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
+       {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
+       {0xa0, 0x02, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,02,cc */
+       {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},              /* 01,8c,10,cc */
+       {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},            /* 01,8f,20,cc */
+       {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,00,cc */
+       {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,00,cc */
+       {0xa0, 0x40, ZC3XX_R01D_HSYNC_0},               /* 00,1d,40,cc */
+       {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},               /* 00,1e,60,cc */
+       {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},               /* 00,1f,90,cc */
+       {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,20,ff,cc */
+       {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},            /* 00,87,0f,cc */
+       {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},            /* 00,88,0e,cc */
+       {}
+};
+static const struct usb_action pas202b_NoFlikerScale[] = {
+       {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},         /* 00,19,00,cc */
+       {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},            /* 00,87,20,cc */
+       {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},            /* 00,88,21,cc */
+       {0xaa, 0x20, 0x0002},                           /* 00,20,02,aa */
+       {0xaa, 0x21, 0x0010},                           /* 00,21,10,aa */
+       {0xaa, 0x03, 0x0040},                           /* 00,03,40,aa */
+       {0xaa, 0x04, 0x0008},                           /* 00,04,08,aa */
+       {0xaa, 0x05, 0x0010},                           /* 00,05,10,aa */
+       {0xaa, 0x0e, 0x0001},                           /* 00,0e,01,aa */
+       {0xaa, 0x0f, 0x0000},                           /* 00,0f,00,aa */
+       {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
+       {0xa0, 0x0f, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,0f,cc */
+       {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,f0,cc */
+       {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
+       {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
+       {0xa0, 0x02, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,02,cc */
+       {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},              /* 01,8c,10,cc */
+       {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},            /* 01,8f,20,cc */
+       {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,00,cc */
+       {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,00,cc */
+       {0xa0, 0x40, ZC3XX_R01D_HSYNC_0},               /* 00,1d,40,cc */
+       {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},               /* 00,1e,60,cc */
+       {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},               /* 00,1f,90,cc */
+       {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,20,ff,cc */
+       {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},            /* 00,87,0f,cc */
+       {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},            /* 00,88,0e,cc */
+       {}
+};
+
 static const struct usb_action pb03303x_Initial[] = {
        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
@@ -6333,7 +6308,7 @@ static __u8 i2c_write(struct gspca_dev *gspca_dev,
        reg_w_i(gspca_dev->dev, valL, 0x93);
        reg_w_i(gspca_dev->dev, valH, 0x94);
        reg_w_i(gspca_dev->dev, 0x01, 0x90);            /* <- write command */
-       msleep(5);
+       msleep(15);
        retbyte = reg_r_i(gspca_dev, 0x0091);           /* read status */
        PDEBUG(D_USBO, "i2c w [%02x] = %02x%02x (%02x)",
                        reg, valH, valL, retbyte);
@@ -6376,31 +6351,35 @@ static void setmatrix(struct gspca_dev *gspca_dev)
                {0x50, 0xf8, 0xf8, 0xf8, 0x50, 0xf8, 0xf8, 0xf8, 0x50};
        static const __u8 ov7620_matrix[9] =
                {0x58, 0xf4, 0xf4, 0xf4, 0x58, 0xf4, 0xf4, 0xf4, 0x58};
+       static const __u8 pas202b_matrix[9] =
+               {0x4c, 0xf5, 0xff, 0xf9, 0x51, 0xf5, 0xfb, 0xed, 0x5f};
        static const __u8 po2030_matrix[9] =
                {0x60, 0xf0, 0xf0, 0xf0, 0x60, 0xf0, 0xf0, 0xf0, 0x60};
        static const __u8 vf0250_matrix[9] =
                {0x7b, 0xea, 0xea, 0xea, 0x7b, 0xea, 0xea, 0xea, 0x7b};
+       static const __u8 *matrix_tb[SENSOR_MAX] = {
+               NULL,           /* SENSOR_CS2102 0 */
+               NULL,           /* SENSOR_CS2102K 1 */
+               gc0305_matrix,  /* SENSOR_GC0305 2 */
+               NULL,           /* SENSOR_HDCS2020b 3 */
+               NULL,           /* SENSOR_HV7131B 4 */
+               NULL,           /* SENSOR_HV7131C 5 */
+               NULL,           /* SENSOR_ICM105A 6 */
+               NULL,           /* SENSOR_MC501CB 7 */
+               ov7620_matrix,  /* SENSOR_OV7620 8 */
+               NULL,           /* SENSOR_OV7630C 9 */
+               NULL,           /* SENSOR_PAS106 10 */
+               pas202b_matrix, /* SENSOR_PAS202B 11 */
+               NULL,           /* SENSOR_PB0330 12 */
+               po2030_matrix,  /* SENSOR_PO2030 13 */
+               NULL,           /* SENSOR_TAS5130CK 14 */
+               NULL,           /* SENSOR_TAS5130CXX 15 */
+               vf0250_matrix,  /* SENSOR_TAS5130C_VF0250 16 */
+       };
 
-       switch (sd->sensor) {
-       case SENSOR_GC0305:
-       case SENSOR_HV7131B:
-               matrix = gc0305_matrix;
-               break;
-       case SENSOR_MC501CB:
-               return;         /* no matrix? */
-       case SENSOR_OV7620:
-/*     case SENSOR_OV7648: */
-               matrix = ov7620_matrix;
-               break;
-       case SENSOR_PO2030:
-               matrix = po2030_matrix;
-               break;
-       case SENSOR_TAS5130C_VF0250:
-               matrix = vf0250_matrix;
-               break;
-       default:                /* matrix already loaded */
-               return;
-       }
+       matrix = matrix_tb[sd->sensor];
+       if (matrix == NULL)
+               return;         /* matrix already loaded */
        for (i = 0; i < ARRAY_SIZE(ov7620_matrix); i++)
                reg_w(gspca_dev->dev, matrix[i], 0x010a + i);
 }
@@ -6616,42 +6595,42 @@ static int setlightfreq(struct gspca_dev *gspca_dev)
                {gc0305_NoFliker, gc0305_NoFliker,
                 gc0305_50HZ, gc0305_50HZ,
                 gc0305_60HZ, gc0305_60HZ},
-/* SENSOR_HDCS2020 3 */
-               {NULL, NULL,
-                NULL, NULL,
-                NULL, NULL},
-/* SENSOR_HDCS2020b 4 */
+/* SENSOR_HDCS2020b 3 */
                {hdcs2020b_NoFliker, hdcs2020b_NoFliker,
                 hdcs2020b_50HZ, hdcs2020b_50HZ,
                 hdcs2020b_60HZ, hdcs2020b_60HZ},
-/* SENSOR_HV7131B 5 */
+/* SENSOR_HV7131B 4 */
                {hv7131b_NoFlikerScale, hv7131b_NoFliker,
                 hv7131b_50HZScale, hv7131b_50HZ,
                 hv7131b_60HZScale, hv7131b_60HZ},
-/* SENSOR_HV7131C 6 */
+/* SENSOR_HV7131C 5 */
                {NULL, NULL,
                 NULL, NULL,
                 NULL, NULL},
-/* SENSOR_ICM105A 7 */
+/* SENSOR_ICM105A 6 */
                {icm105a_NoFliker, icm105a_NoFlikerScale,
                 icm105a_50HZ, icm105a_50HZScale,
                 icm105a_60HZ, icm105a_60HZScale},
-/* SENSOR_MC501CB 8 */
+/* SENSOR_MC501CB 7 */
                {MC501CB_NoFliker, MC501CB_NoFlikerScale,
                 MC501CB_50HZ, MC501CB_50HZScale,
                 MC501CB_60HZ, MC501CB_60HZScale},
-/* SENSOR_OV7620 9 */
+/* SENSOR_OV7620 8 */
                {OV7620_NoFliker, OV7620_NoFliker,
                 OV7620_50HZ, OV7620_50HZ,
                 OV7620_60HZ, OV7620_60HZ},
-/* SENSOR_OV7630C 10 */
+/* SENSOR_OV7630C 9 */
                {NULL, NULL,
                 NULL, NULL,
                 NULL, NULL},
-/* SENSOR_PAS106 11 */
+/* SENSOR_PAS106 10 */
                {pas106b_NoFliker, pas106b_NoFliker,
                 pas106b_50HZ, pas106b_50HZ,
                 pas106b_60HZ, pas106b_60HZ},
+/* SENSOR_PAS202B 11 */
+               {pas202b_NoFlikerScale, pas202b_NoFliker,
+                pas202b_50HZScale, pas202b_50HZ,
+                pas202b_60HZScale, pas202b_60HZ},
 /* SENSOR_PB0330 12 */
                {pb0330_NoFliker, pb0330_NoFlikerScale,
                 pb0330_50HZ, pb0330_50HZScale,
@@ -7033,15 +7012,15 @@ static int sd_config(struct gspca_dev *gspca_dev,
                5,      /* SENSOR_CS2102 0 */
                5,      /* SENSOR_CS2102K 1 */
                4,      /* SENSOR_GC0305 2 */
-               4,      /* SENSOR_HDCS2020 3 */
-               4,      /* SENSOR_HDCS2020b 4 */
-               4,      /* SENSOR_HV7131B 5 */
-               4,      /* SENSOR_HV7131C 6 */
-               4,      /* SENSOR_ICM105A 7 */
-               4,      /* SENSOR_MC501CB 8 */
-               3,      /* SENSOR_OV7620 9 */
-               4,      /* SENSOR_OV7630C 10 */
-               4,      /* SENSOR_PAS106 11 */
+               4,      /* SENSOR_HDCS2020b 3 */
+               4,      /* SENSOR_HV7131B 4 */
+               4,      /* SENSOR_HV7131C 5 */
+               4,      /* SENSOR_ICM105A 6 */
+               4,      /* SENSOR_MC501CB 7 */
+               3,      /* SENSOR_OV7620 8 */
+               4,      /* SENSOR_OV7630C 9 */
+               4,      /* SENSOR_PAS106 10 */
+               4,      /* SENSOR_PAS202B 11 */
                4,      /* SENSOR_PB0330 12 */
                4,      /* SENSOR_PO2030 13 */
                4,      /* SENSOR_TAS5130CK 14 */
@@ -7097,8 +7076,8 @@ static int sd_config(struct gspca_dev *gspca_dev,
                        sd->sensor = SENSOR_ICM105A;
                        break;
                case 0x0e:
-                       PDEBUG(D_PROBE, "Find Sensor HDCS2020");
-                       sd->sensor = SENSOR_HDCS2020;
+                       PDEBUG(D_PROBE, "Find Sensor PAS202B");
+                       sd->sensor = SENSOR_PAS202B;
                        sd->sharpness = 1;
                        break;
                case 0x0f:
@@ -7191,7 +7170,6 @@ static int sd_config(struct gspca_dev *gspca_dev,
        case SENSOR_PO2030:
                gspca_dev->ctrl_dis = (1 << BRIGHTNESS_IDX);
                break;
-       case SENSOR_HDCS2020:
        case SENSOR_HV7131B:
        case SENSOR_HV7131C:
        case SENSOR_OV7630C:
@@ -7221,15 +7199,15 @@ static int sd_start(struct gspca_dev *gspca_dev)
                {cs2102_InitialScale, cs2102_Initial},          /* 0 */
                {cs2102K_InitialScale, cs2102K_Initial},        /* 1 */
                {gc0305_Initial, gc0305_InitialScale},          /* 2 */
-               {hdcs2020xx_InitialScale, hdcs2020xx_Initial},  /* 3 */
-               {hdcs2020xb_InitialScale, hdcs2020xb_Initial},  /* 4 */
-               {hv7131bxx_InitialScale, hv7131bxx_Initial},    /* 5 */
-               {hv7131cxx_InitialScale, hv7131cxx_Initial},    /* 6 */
-               {icm105axx_InitialScale, icm105axx_Initial},    /* 7 */
-               {MC501CB_InitialScale, MC501CB_Initial},        /* 9 */
-               {OV7620_mode0, OV7620_mode1},                   /* 9 */
-               {ov7630c_InitialScale, ov7630c_Initial},        /* 10 */
-               {pas106b_InitialScale, pas106b_Initial},        /* 11 */
+               {hdcs2020xb_InitialScale, hdcs2020xb_Initial},  /* 3 */
+               {hv7131bxx_InitialScale, hv7131bxx_Initial},    /* 4 */
+               {hv7131cxx_InitialScale, hv7131cxx_Initial},    /* 5 */
+               {icm105axx_InitialScale, icm105axx_Initial},    /* 6 */
+               {MC501CB_InitialScale, MC501CB_Initial},        /* 7 */
+               {OV7620_mode0, OV7620_mode1},                   /* 8 */
+               {ov7630c_InitialScale, ov7630c_Initial},        /* 9 */
+               {pas106b_InitialScale, pas106b_Initial},        /* 10 */
+               {pas202b_Initial, pas202b_InitialScale},        /* 11 */
                {pb0330xx_InitialScale, pb0330xx_Initial},      /* 12 */
 /* or          {pb03303x_InitialScale, pb03303x_Initial}, */
                {PO2030_mode0, PO2030_mode1},                   /* 13 */
@@ -7286,6 +7264,7 @@ static int sd_start(struct gspca_dev *gspca_dev)
                reg_r(gspca_dev, 0x0008);
                reg_w(dev, 0x00, 0x0008);
                break;
+       case SENSOR_PAS202B:
        case SENSOR_GC0305:
                reg_r(gspca_dev, 0x0008);
                /* fall thru */
@@ -7299,7 +7278,6 @@ static int sd_start(struct gspca_dev *gspca_dev)
        switch (sd->sensor) {
        case SENSOR_CS2102:             /* gamma set in xxx_Initial */
        case SENSOR_CS2102K:
-       case SENSOR_HDCS2020:
        case SENSOR_HDCS2020b:
        case SENSOR_PB0330:             /* pb with chip_revision - see above */
        case SENSOR_OV7630C:
@@ -7312,6 +7290,7 @@ static int sd_start(struct gspca_dev *gspca_dev)
        setmatrix(gspca_dev);                   /* one more time? */
        switch (sd->sensor) {
        case SENSOR_OV7620:
+       case SENSOR_PAS202B:
                reg_r(gspca_dev, 0x0180);       /* from win */
                reg_w(dev, 0x00, 0x0180);
                break;
@@ -7323,37 +7302,29 @@ static int sd_start(struct gspca_dev *gspca_dev)
 
        switch (sd->sensor) {
        case SENSOR_GC0305:
-       case SENSOR_OV7620:
                reg_w(dev, 0x09, 0x01ad);       /* (from win traces) */
                reg_w(dev, 0x15, 0x01ae);
-               sd->autogain = 0;
-               break;
+               /* fall thru */
+       case SENSOR_PAS202B:
        case SENSOR_PO2030:
-               reg_w(dev, 0x40, 0x0117);       /* (from win traces) */
-               reg_r(gspca_dev, 0x0180);
-               break;
-       }
-
-       setautogain(gspca_dev);
-       switch (sd->sensor) {
-       case SENSOR_GC0305:
-/*             setlightfreq(gspca_dev);        ?? (end: 80 -> [18d]) */
-               reg_w(dev, 0x09, 0x01ad);       /* (from win traces) */
-               reg_w(dev, 0x15, 0x01ae);
-               reg_w(dev, 0x40, 0x0180);
-               reg_w(dev, 0x40, 0x0117);
+/*             reg_w(dev, 0x40, ZC3XX_R117_GGAIN);  * (from win traces) */
                reg_r(gspca_dev, 0x0180);
-               sd->autogain = 1;
-               setautogain(gspca_dev);
                break;
        case SENSOR_OV7620:
+               reg_w(dev, 0x09, 0x01ad);
+               reg_w(dev, 0x15, 0x01ae);
                i2c_read(gspca_dev, 0x13);      /*fixme: returns 0xa3 */
                i2c_write(gspca_dev, 0x13, 0xa3, 0x00);
                                         /*fixme: returned value to send? */
-               reg_w(dev, 0x40, 0x0117);       /* (from win traces) */
+               reg_w(dev, 0x40, 0x0117);
                reg_r(gspca_dev, 0x0180);
-               setautogain(gspca_dev);
-               msleep(500);
+               break;
+       }
+
+       setautogain(gspca_dev);
+       switch (sd->sensor) {
+       case SENSOR_PAS202B:
+               reg_w(dev, 0x00, 0x0007);       /* (from win traces) */
                break;
        case SENSOR_PO2030:
                msleep(500);
@@ -7363,6 +7334,8 @@ static int sd_start(struct gspca_dev *gspca_dev)
                reg_w(dev, 0x02, 0x0008);
                break;
        }
+       if (sd->sensor == SENSOR_PAS202B)
+               reg_w(dev, 0x02, ZC3XX_R008_CLOCKSETTING);
        return 0;
 }