linux/drivers/media/video/gspca/zc3xx.c
<<
>>
Prefs
   1/*
   2 * Z-Star/Vimicro zc301/zc302p/vc30x library
   3 *
   4 * Copyright (C) 2009-2011 Jean-Francois Moine <http://moinejf.free.fr>
   5 * Copyright (C) 2004 2005 2006 Michel Xhaard mxhaard@magic.fr
   6 *
   7 * This program is free software; you can redistribute it and/or modify
   8 * it under the terms of the GNU General Public License as published by
   9 * the Free Software Foundation; either version 2 of the License, or
  10 * (at your option) any later version.
  11 *
  12 * This program is distributed in the hope that it will be useful,
  13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  15 * GNU General Public License for more details.
  16 *
  17 * You should have received a copy of the GNU General Public License
  18 * along with this program; if not, write to the Free Software
  19 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  20 */
  21
  22#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
  23
  24#define MODULE_NAME "zc3xx"
  25
  26#include <linux/input.h>
  27#include "gspca.h"
  28#include "jpeg.h"
  29
  30MODULE_AUTHOR("Jean-Francois Moine <http://moinejf.free.fr>, "
  31                "Serge A. Suchkov <Serge.A.S@tochka.ru>");
  32MODULE_DESCRIPTION("GSPCA ZC03xx/VC3xx USB Camera Driver");
  33MODULE_LICENSE("GPL");
  34
  35static int force_sensor = -1;
  36
  37#define QUANT_VAL 1             /* quantization table */
  38#include "zc3xx-reg.h"
  39
  40/* controls */
  41enum e_ctrl {
  42        BRIGHTNESS,
  43        CONTRAST,
  44        EXPOSURE,
  45        GAMMA,
  46        AUTOGAIN,
  47        LIGHTFREQ,
  48        SHARPNESS,
  49        NCTRLS          /* number of controls */
  50};
  51
  52#define AUTOGAIN_DEF 1
  53
  54/* specific webcam descriptor */
  55struct sd {
  56        struct gspca_dev gspca_dev;     /* !! must be the first item */
  57
  58        struct gspca_ctrl ctrls[NCTRLS];
  59
  60        u8 quality;                     /* image quality */
  61#define QUALITY_MIN 50
  62#define QUALITY_MAX 80
  63#define QUALITY_DEF 70
  64
  65        u8 bridge;
  66        u8 sensor;              /* Type of image sensor chip */
  67        u16 chip_revision;
  68
  69        u8 jpeg_hdr[JPEG_HDR_SZ];
  70};
  71enum bridges {
  72        BRIDGE_ZC301,
  73        BRIDGE_ZC303,
  74};
  75enum sensors {
  76        SENSOR_ADCM2700,
  77        SENSOR_CS2102,
  78        SENSOR_CS2102K,
  79        SENSOR_GC0303,
  80        SENSOR_GC0305,
  81        SENSOR_HDCS2020,
  82        SENSOR_HV7131B,
  83        SENSOR_HV7131R,
  84        SENSOR_ICM105A,
  85        SENSOR_MC501CB,
  86        SENSOR_MT9V111_1,       /* (mi360soc) zc301 */
  87        SENSOR_MT9V111_3,       /* (mi360soc) zc303 */
  88        SENSOR_OV7620,          /* OV7648 - same values */
  89        SENSOR_OV7630C,
  90        SENSOR_PAS106,
  91        SENSOR_PAS202B,
  92        SENSOR_PB0330,
  93        SENSOR_PO2030,
  94        SENSOR_TAS5130C,
  95        SENSOR_MAX
  96};
  97
  98/* V4L2 controls supported by the driver */
  99static void setcontrast(struct gspca_dev *gspca_dev);
 100static void setexposure(struct gspca_dev *gspca_dev);
 101static int sd_setautogain(struct gspca_dev *gspca_dev, __s32 val);
 102static void setlightfreq(struct gspca_dev *gspca_dev);
 103static void setsharpness(struct gspca_dev *gspca_dev);
 104
 105static const struct ctrl sd_ctrls[NCTRLS] = {
 106[BRIGHTNESS] = {
 107            {
 108                .id      = V4L2_CID_BRIGHTNESS,
 109                .type    = V4L2_CTRL_TYPE_INTEGER,
 110                .name    = "Brightness",
 111                .minimum = 0,
 112                .maximum = 255,
 113                .step    = 1,
 114                .default_value = 128,
 115            },
 116            .set_control = setcontrast
 117        },
 118[CONTRAST] = {
 119            {
 120                .id      = V4L2_CID_CONTRAST,
 121                .type    = V4L2_CTRL_TYPE_INTEGER,
 122                .name    = "Contrast",
 123                .minimum = 0,
 124                .maximum = 255,
 125                .step    = 1,
 126                .default_value = 128,
 127            },
 128            .set_control = setcontrast
 129        },
 130[EXPOSURE] = {
 131            {
 132                .id      = V4L2_CID_EXPOSURE,
 133                .type    = V4L2_CTRL_TYPE_INTEGER,
 134                .name    = "Exposure",
 135                .minimum = 0x30d,
 136                .maximum        = 0x493e,
 137                .step           = 1,
 138                .default_value  = 0x927
 139            },
 140            .set_control = setexposure
 141        },
 142[GAMMA] = {
 143            {
 144                .id      = V4L2_CID_GAMMA,
 145                .type    = V4L2_CTRL_TYPE_INTEGER,
 146                .name    = "Gamma",
 147                .minimum = 1,
 148                .maximum = 6,
 149                .step    = 1,
 150                .default_value = 4,
 151            },
 152            .set_control = setcontrast
 153        },
 154[AUTOGAIN] = {
 155            {
 156                .id      = V4L2_CID_AUTOGAIN,
 157                .type    = V4L2_CTRL_TYPE_BOOLEAN,
 158                .name    = "Auto Gain",
 159                .minimum = 0,
 160                .maximum = 1,
 161                .step    = 1,
 162                .default_value = AUTOGAIN_DEF,
 163                .flags   = V4L2_CTRL_FLAG_UPDATE
 164            },
 165            .set = sd_setautogain
 166        },
 167[LIGHTFREQ] = {
 168            {
 169                .id      = V4L2_CID_POWER_LINE_FREQUENCY,
 170                .type    = V4L2_CTRL_TYPE_MENU,
 171                .name    = "Light frequency filter",
 172                .minimum = 0,
 173                .maximum = 2,   /* 0: 0, 1: 50Hz, 2:60Hz */
 174                .step    = 1,
 175                .default_value = 0,
 176            },
 177            .set_control = setlightfreq
 178        },
 179[SHARPNESS] = {
 180            {
 181                .id      = V4L2_CID_SHARPNESS,
 182                .type    = V4L2_CTRL_TYPE_INTEGER,
 183                .name    = "Sharpness",
 184                .minimum = 0,
 185                .maximum = 3,
 186                .step    = 1,
 187                .default_value = 2,
 188            },
 189            .set_control = setsharpness
 190        },
 191};
 192
 193static const struct v4l2_pix_format vga_mode[] = {
 194        {320, 240, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
 195                .bytesperline = 320,
 196                .sizeimage = 320 * 240 * 3 / 8 + 590,
 197                .colorspace = V4L2_COLORSPACE_JPEG,
 198                .priv = 1},
 199        {640, 480, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
 200                .bytesperline = 640,
 201                .sizeimage = 640 * 480 * 3 / 8 + 590,
 202                .colorspace = V4L2_COLORSPACE_JPEG,
 203                .priv = 0},
 204};
 205
 206static const struct v4l2_pix_format broken_vga_mode[] = {
 207        {320, 232, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
 208                .bytesperline = 320,
 209                .sizeimage = 320 * 232 * 4 / 8 + 590,
 210                .colorspace = V4L2_COLORSPACE_JPEG,
 211                .priv = 1},
 212        {640, 472, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
 213                .bytesperline = 640,
 214                .sizeimage = 640 * 472 * 3 / 8 + 590,
 215                .colorspace = V4L2_COLORSPACE_JPEG,
 216                .priv = 0},
 217};
 218
 219static const struct v4l2_pix_format sif_mode[] = {
 220        {176, 144, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
 221                .bytesperline = 176,
 222                .sizeimage = 176 * 144 * 3 / 8 + 590,
 223                .colorspace = V4L2_COLORSPACE_JPEG,
 224                .priv = 1},
 225        {352, 288, V4L2_PIX_FMT_JPEG, V4L2_FIELD_NONE,
 226                .bytesperline = 352,
 227                .sizeimage = 352 * 288 * 3 / 8 + 590,
 228                .colorspace = V4L2_COLORSPACE_JPEG,
 229                .priv = 0},
 230};
 231
 232/* usb exchanges */
 233struct usb_action {
 234        u8      req;
 235        u8      val;
 236        u16     idx;
 237};
 238
 239static const struct usb_action adcm2700_Initial[] = {
 240        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},         /* 00,00,01,cc */
 241        {0xa0, 0x04, ZC3XX_R002_CLOCKSELECT},           /* 00,02,04,cc */
 242        {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING},          /* 00,08,03,cc */
 243        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 244        {0xa0, 0xd3, ZC3XX_R08B_I2CDEVICEADDR},         /* 00,8b,d3,cc */
 245        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},        /* 00,03,02,cc */
 246        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},         /* 00,04,80,cc */
 247        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},       /* 00,05,01,cc */
 248        {0xa0, 0xd8, ZC3XX_R006_FRAMEHEIGHTLOW},        /* 00,06,d8,cc */
 249        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},       /* 00,01,01,cc */
 250        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,03,cc */
 251        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,01,cc */
 252        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,05,cc */
 253        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},          /* 00,98,00,cc */
 254        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},          /* 00,9a,00,cc */
 255        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},             /* 01,1a,00,cc */
 256        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},             /* 01,1c,00,cc */
 257        {0xa0, 0xde, ZC3XX_R09C_WINHEIGHTLOW},          /* 00,9c,de,cc */
 258        {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},           /* 00,9e,86,cc */
 259        {0xbb, 0x00, 0x0400},                           /* 04,00,00,bb */
 260        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 261        {0xbb, 0x0f, 0x140f},                           /* 14,0f,0f,bb */
 262        {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},      /* 01,01,37,cc */
 263        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},         /* 01,00,0d,cc */
 264        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},             /* 01,89,06,cc */
 265        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},         /* 01,c5,03,cc */
 266        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},           /* 01,cb,13,cc */
 267        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},        /* 02,50,08,cc */
 268        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},          /* 03,01,08,cc */
 269        {0xa0, 0x58, ZC3XX_R116_RGAIN},                 /* 01,16,58,cc */
 270        {0xa0, 0x5a, ZC3XX_R118_BGAIN},                 /* 01,18,5a,cc */
 271        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},     /* 01,80,02,cc */
 272        {0xa0, 0xd3, ZC3XX_R08B_I2CDEVICEADDR},         /* 00,8b,d3,cc */
 273        {0xbb, 0x00, 0x0408},                           /* 04,00,08,bb */
 274        {0xdd, 0x00, 0x0200},                           /* 00,02,00,dd */
 275        {0xbb, 0x00, 0x0400},                           /* 04,00,00,bb */
 276        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 277        {0xbb, 0x0f, 0x140f},                           /* 14,0f,0f,bb */
 278        {0xbb, 0xe0, 0x0c2e},                           /* 0c,e0,2e,bb */
 279        {0xbb, 0x01, 0x2000},                           /* 20,01,00,bb */
 280        {0xbb, 0x96, 0x2400},                           /* 24,96,00,bb */
 281        {0xbb, 0x06, 0x1006},                           /* 10,06,06,bb */
 282        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 283        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 284        {0xaa, 0xfe, 0x0002},                           /* 00,fe,02,aa */
 285        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 286        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 287        {0xbb, 0x5f, 0x2090},                           /* 20,5f,90,bb */
 288        {0xbb, 0x01, 0x8000},                           /* 80,01,00,bb */
 289        {0xbb, 0x09, 0x8400},                           /* 84,09,00,bb */
 290        {0xbb, 0x86, 0x0002},                           /* 00,86,02,bb */
 291        {0xbb, 0xe6, 0x0401},                           /* 04,e6,01,bb */
 292        {0xbb, 0x86, 0x0802},                           /* 08,86,02,bb */
 293        {0xbb, 0xe6, 0x0c01},                           /* 0c,e6,01,bb */
 294        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 295        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 296        {0xaa, 0xfe, 0x0000},                           /* 00,fe,00,aa */
 297        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 298        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 299        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 300        {0xaa, 0xfe, 0x0020},                           /* 00,fe,20,aa */
 301/*mswin+*/
 302        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},
 303        {0xaa, 0xfe, 0x0002},
 304        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
 305        {0xaa, 0xb4, 0xcd37},
 306        {0xaa, 0xa4, 0x0004},
 307        {0xaa, 0xa8, 0x0007},
 308        {0xaa, 0xac, 0x0004},
 309/*mswin-*/
 310        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 311        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 312        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 313        {0xaa, 0xfe, 0x0000},                           /* 00,fe,00,aa */
 314        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 315        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 316        {0xbb, 0x04, 0x0400},                           /* 04,04,00,bb */
 317        {0xdd, 0x00, 0x0100},                           /* 00,01,00,dd */
 318        {0xbb, 0x01, 0x0400},                           /* 04,01,00,bb */
 319        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 320        {0xaa, 0xfe, 0x0002},                           /* 00,fe,02,aa */
 321        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 322        {0xbb, 0x41, 0x2803},                           /* 28,41,03,bb */
 323        {0xbb, 0x40, 0x2c03},                           /* 2c,40,03,bb */
 324        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 325        {0xaa, 0xfe, 0x0010},                           /* 00,fe,10,aa */
 326        {}
 327};
 328static const struct usb_action adcm2700_InitialScale[] = {
 329        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},         /* 00,00,01,cc */
 330        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},           /* 00,02,10,cc */
 331        {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING},          /* 00,08,03,cc */
 332        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 333        {0xa0, 0xd3, ZC3XX_R08B_I2CDEVICEADDR},         /* 00,8b,d3,cc */
 334        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},        /* 00,03,02,cc */
 335        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},         /* 00,04,80,cc */
 336        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},       /* 00,05,01,cc */
 337        {0xa0, 0xd0, ZC3XX_R006_FRAMEHEIGHTLOW},        /* 00,06,d0,cc */
 338        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},       /* 00,01,01,cc */
 339        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,03,cc */
 340        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,01,cc */
 341        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,05,cc */
 342        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},          /* 00,98,00,cc */
 343        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},          /* 00,9a,00,cc */
 344        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},             /* 01,1a,00,cc */
 345        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},             /* 01,1c,00,cc */
 346        {0xa0, 0xd8, ZC3XX_R09C_WINHEIGHTLOW},          /* 00,9c,d8,cc */
 347        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},           /* 00,9e,88,cc */
 348        {0xbb, 0x00, 0x0400},                           /* 04,00,00,bb */
 349        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 350        {0xbb, 0x0f, 0x140f},                           /* 14,0f,0f,bb */
 351        {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},      /* 01,01,37,cc */
 352        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},         /* 01,00,0d,cc */
 353        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},             /* 01,89,06,cc */
 354        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},         /* 01,c5,03,cc */
 355        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},           /* 01,cb,13,cc */
 356        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},        /* 02,50,08,cc */
 357        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},          /* 03,01,08,cc */
 358        {0xa0, 0x58, ZC3XX_R116_RGAIN},                 /* 01,16,58,cc */
 359        {0xa0, 0x5a, ZC3XX_R118_BGAIN},                 /* 01,18,5a,cc */
 360        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},     /* 01,80,02,cc */
 361        {0xa0, 0xd3, ZC3XX_R08B_I2CDEVICEADDR},         /* 00,8b,d3,cc */
 362        {0xbb, 0x00, 0x0408},                           /* 04,00,08,bb */
 363        {0xdd, 0x00, 0x0200},                           /* 00,02,00,dd */
 364        {0xbb, 0x00, 0x0400},                           /* 04,00,00,bb */
 365        {0xdd, 0x00, 0x0050},                           /* 00,00,50,dd */
 366        {0xbb, 0x0f, 0x140f},                           /* 14,0f,0f,bb */
 367        {0xbb, 0xe0, 0x0c2e},                           /* 0c,e0,2e,bb */
 368        {0xbb, 0x01, 0x2000},                           /* 20,01,00,bb */
 369        {0xbb, 0x96, 0x2400},                           /* 24,96,00,bb */
 370        {0xbb, 0x06, 0x1006},                           /* 10,06,06,bb */
 371        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 372        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 373        {0xaa, 0xfe, 0x0002},                           /* 00,fe,02,aa */
 374        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 375        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 376        {0xbb, 0x5f, 0x2090},                           /* 20,5f,90,bb */
 377        {0xbb, 0x01, 0x8000},                           /* 80,01,00,bb */
 378        {0xbb, 0x09, 0x8400},                           /* 84,09,00,bb */
 379        {0xbb, 0x86, 0x0002},                           /* 00,88,02,bb */
 380        {0xbb, 0xe6, 0x0401},                           /* 04,e6,01,bb */
 381        {0xbb, 0x86, 0x0802},                           /* 08,88,02,bb */
 382        {0xbb, 0xe6, 0x0c01},                           /* 0c,e6,01,bb */
 383        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 384        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 385        {0xaa, 0xfe, 0x0000},                           /* 00,fe,00,aa */
 386        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 387        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 388        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 389        {0xaa, 0xfe, 0x0020},                           /* 00,fe,20,aa */
 390        /*******/
 391        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 392        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 393        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 394        {0xaa, 0xfe, 0x0000},                           /* 00,fe,00,aa */
 395        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 396        {0xdd, 0x00, 0x0010},                           /* 00,00,10,dd */
 397        {0xbb, 0x04, 0x0400},                           /* 04,04,00,bb */
 398        {0xdd, 0x00, 0x0100},                           /* 00,01,00,dd */
 399        {0xbb, 0x01, 0x0400},                           /* 04,01,00,bb */
 400        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 401        {0xaa, 0xfe, 0x0002},                           /* 00,fe,02,aa */
 402        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 403        {0xbb, 0x41, 0x2803},                           /* 28,41,03,bb */
 404        {0xbb, 0x40, 0x2c03},                           /* 2c,40,03,bb */
 405        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 406        {0xaa, 0xfe, 0x0010},                           /* 00,fe,10,aa */
 407        {}
 408};
 409static const struct usb_action adcm2700_50HZ[] = {
 410        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 411        {0xaa, 0xfe, 0x0002},                           /* 00,fe,02,aa */
 412        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 413        {0xbb, 0x05, 0x8400},                           /* 84,05,00,bb */
 414        {0xbb, 0xd0, 0xb007},                           /* b0,d0,07,bb */
 415        {0xbb, 0xa0, 0xb80f},                           /* b8,a0,0f,bb */
 416        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 417        {0xaa, 0xfe, 0x0010},                           /* 00,fe,10,aa */
 418        {0xaa, 0x26, 0x00d0},                           /* 00,26,d0,aa */
 419        {0xaa, 0x28, 0x0002},                           /* 00,28,02,aa */
 420        {}
 421};
 422static const struct usb_action adcm2700_60HZ[] = {
 423        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 424        {0xaa, 0xfe, 0x0002},                           /* 00,fe,02,aa */
 425        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 426        {0xbb, 0x07, 0x8400},                           /* 84,07,00,bb */
 427        {0xbb, 0x82, 0xb006},                           /* b0,82,06,bb */
 428        {0xbb, 0x04, 0xb80d},                           /* b8,04,0d,bb */
 429        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 430        {0xaa, 0xfe, 0x0010},                           /* 00,fe,10,aa */
 431        {0xaa, 0x26, 0x0057},                           /* 00,26,57,aa */
 432        {0xaa, 0x28, 0x0002},                           /* 00,28,02,aa */
 433        {}
 434};
 435static const struct usb_action adcm2700_NoFliker[] = {
 436        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 437        {0xaa, 0xfe, 0x0002},                           /* 00,fe,02,aa */
 438        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0a,cc */
 439        {0xbb, 0x07, 0x8400},                           /* 84,07,00,bb */
 440        {0xbb, 0x05, 0xb000},                           /* b0,05,00,bb */
 441        {0xbb, 0xa0, 0xb801},                           /* b8,a0,01,bb */
 442        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
 443        {0xaa, 0xfe, 0x0010},                           /* 00,fe,10,aa */
 444        {}
 445};
 446static const struct usb_action cs2102_InitialScale[] = {        /* 320x240 */
 447        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
 448        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
 449        {0xa0, 0x00, ZC3XX_R010_CMOSSENSORSELECT},
 450        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
 451        {0xa0, 0x20, ZC3XX_R080_HBLANKHIGH},
 452        {0xa0, 0x21, ZC3XX_R081_HBLANKLOW},
 453        {0xa0, 0x30, ZC3XX_R083_RGAINADDR},
 454        {0xa0, 0x31, ZC3XX_R084_GGAINADDR},
 455        {0xa0, 0x32, ZC3XX_R085_BGAINADDR},
 456        {0xa0, 0x23, ZC3XX_R086_EXPTIMEHIGH},
 457        {0xa0, 0x24, ZC3XX_R087_EXPTIMEMID},
 458        {0xa0, 0x25, ZC3XX_R088_EXPTIMELOW},
 459        {0xa0, 0xb3, ZC3XX_R08B_I2CDEVICEADDR},
 460        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* 00 */
 461        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
 462        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
 463        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
 464        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
 465        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
 466        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
 467        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
 468        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
 469        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
 470        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
 471        {0xaa, 0x02, 0x0008},
 472        {0xaa, 0x03, 0x0000},
 473        {0xaa, 0x11, 0x0000},
 474        {0xaa, 0x12, 0x0089},
 475        {0xaa, 0x13, 0x0000},
 476        {0xaa, 0x14, 0x00e9},
 477        {0xaa, 0x20, 0x0000},
 478        {0xaa, 0x22, 0x0000},
 479        {0xaa, 0x0b, 0x0004},
 480        {0xaa, 0x30, 0x0030},
 481        {0xaa, 0x31, 0x0030},
 482        {0xaa, 0x32, 0x0030},
 483        {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
 484        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
 485        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
 486        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
 487        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
 488        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
 489        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
 490        {0xa0, 0x10, 0x01ae},
 491        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
 492        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
 493        {0xa0, 0x68, ZC3XX_R18D_YTARGET},
 494        {0xa0, 0x00, 0x01ad},
 495        {}
 496};
 497
 498static const struct usb_action cs2102_Initial[] = {     /* 640x480 */
 499        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
 500        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
 501        {0xa0, 0x00, ZC3XX_R010_CMOSSENSORSELECT},
 502        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
 503        {0xa0, 0x20, ZC3XX_R080_HBLANKHIGH},
 504        {0xa0, 0x21, ZC3XX_R081_HBLANKLOW},
 505        {0xa0, 0x30, ZC3XX_R083_RGAINADDR},
 506        {0xa0, 0x31, ZC3XX_R084_GGAINADDR},
 507        {0xa0, 0x32, ZC3XX_R085_BGAINADDR},
 508        {0xa0, 0x23, ZC3XX_R086_EXPTIMEHIGH},
 509        {0xa0, 0x24, ZC3XX_R087_EXPTIMEMID},
 510        {0xa0, 0x25, ZC3XX_R088_EXPTIMELOW},
 511        {0xa0, 0xb3, ZC3XX_R08B_I2CDEVICEADDR},
 512        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* 00 */
 513        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
 514        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
 515        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
 516        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
 517        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
 518        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
 519        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
 520        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
 521        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
 522        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
 523        {0xaa, 0x02, 0x0008},
 524        {0xaa, 0x03, 0x0000},
 525        {0xaa, 0x11, 0x0001},
 526        {0xaa, 0x12, 0x0087},
 527        {0xaa, 0x13, 0x0001},
 528        {0xaa, 0x14, 0x00e7},
 529        {0xaa, 0x20, 0x0000},
 530        {0xaa, 0x22, 0x0000},
 531        {0xaa, 0x0b, 0x0004},
 532        {0xaa, 0x30, 0x0030},
 533        {0xaa, 0x31, 0x0030},
 534        {0xaa, 0x32, 0x0030},
 535        {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
 536        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
 537        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
 538        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
 539        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
 540        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
 541        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
 542        {0xa0, 0x15, 0x01ae},
 543        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
 544        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
 545        {0xa0, 0x68, ZC3XX_R18D_YTARGET},
 546        {0xa0, 0x00, 0x01ad},
 547        {}
 548};
 549static const struct usb_action cs2102_50HZScale[] = {
 550        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
 551        {0xaa, 0x23, 0x0001},
 552        {0xaa, 0x24, 0x005f},
 553        {0xaa, 0x25, 0x0090},
 554        {0xaa, 0x21, 0x00dd},
 555        {0xa0, 0x02, ZC3XX_R190_EXPOSURELIMITHIGH},
 556        {0xa0, 0xbf, ZC3XX_R191_EXPOSURELIMITMID},
 557        {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW},
 558        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
 559        {0xa0, 0x3a, ZC3XX_R196_ANTIFLICKERMID},
 560        {0xa0, 0x98, ZC3XX_R197_ANTIFLICKERLOW},
 561        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
 562        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
 563        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
 564        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
 565        {0xa0, 0xdd, ZC3XX_R01D_HSYNC_0},
 566        {0xa0, 0xe4, ZC3XX_R01E_HSYNC_1},
 567        {0xa0, 0xf0, ZC3XX_R01F_HSYNC_2},
 568        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
 569        {}
 570};
 571static const struct usb_action cs2102_50HZ[] = {
 572        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
 573        {0xaa, 0x23, 0x0000},
 574        {0xaa, 0x24, 0x00af},
 575        {0xaa, 0x25, 0x00c8},
 576        {0xaa, 0x21, 0x0068},
 577        {0xa0, 0x01, ZC3XX_R190_EXPOSURELIMITHIGH},
 578        {0xa0, 0x5f, ZC3XX_R191_EXPOSURELIMITMID},
 579        {0xa0, 0x90, ZC3XX_R192_EXPOSURELIMITLOW},
 580        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
 581        {0xa0, 0x1d, ZC3XX_R196_ANTIFLICKERMID},
 582        {0xa0, 0x4c, ZC3XX_R197_ANTIFLICKERLOW},
 583        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
 584        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
 585        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
 586        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
 587        {0xa0, 0x68, ZC3XX_R01D_HSYNC_0},
 588        {0xa0, 0xe3, ZC3XX_R01E_HSYNC_1},
 589        {0xa0, 0xf0, ZC3XX_R01F_HSYNC_2},
 590        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
 591        {}
 592};
 593static const struct usb_action cs2102_60HZScale[] = {
 594        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
 595        {0xaa, 0x23, 0x0001},
 596        {0xaa, 0x24, 0x0055},
 597        {0xaa, 0x25, 0x00cc},
 598        {0xaa, 0x21, 0x003f},
 599        {0xa0, 0x02, ZC3XX_R190_EXPOSURELIMITHIGH},
 600        {0xa0, 0xab, ZC3XX_R191_EXPOSURELIMITMID},
 601        {0xa0, 0x98, ZC3XX_R192_EXPOSURELIMITLOW},
 602        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
 603        {0xa0, 0x30, ZC3XX_R196_ANTIFLICKERMID},
 604        {0xa0, 0xd4, ZC3XX_R197_ANTIFLICKERLOW},
 605        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
 606        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
 607        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
 608        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
 609        {0xa0, 0x39, ZC3XX_R01D_HSYNC_0},
 610        {0xa0, 0x70, ZC3XX_R01E_HSYNC_1},
 611        {0xa0, 0xb0, ZC3XX_R01F_HSYNC_2},
 612        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
 613        {}
 614};
 615static const struct usb_action cs2102_60HZ[] = {
 616        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
 617        {0xaa, 0x23, 0x0000},
 618        {0xaa, 0x24, 0x00aa},
 619        {0xaa, 0x25, 0x00e6},
 620        {0xaa, 0x21, 0x003f},
 621        {0xa0, 0x01, ZC3XX_R190_EXPOSURELIMITHIGH},
 622        {0xa0, 0x55, ZC3XX_R191_EXPOSURELIMITMID},
 623        {0xa0, 0xcc, ZC3XX_R192_EXPOSURELIMITLOW},
 624        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
 625        {0xa0, 0x18, ZC3XX_R196_ANTIFLICKERMID},
 626        {0xa0, 0x6a, ZC3XX_R197_ANTIFLICKERLOW},
 627        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
 628        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
 629        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
 630        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
 631        {0xa0, 0x3f, ZC3XX_R01D_HSYNC_0},
 632        {0xa0, 0xa5, ZC3XX_R01E_HSYNC_1},
 633        {0xa0, 0xf0, ZC3XX_R01F_HSYNC_2},
 634        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
 635        {}
 636};
 637static const struct usb_action cs2102_NoFlikerScale[] = {
 638        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
 639        {0xaa, 0x23, 0x0001},
 640        {0xaa, 0x24, 0x005f},
 641        {0xaa, 0x25, 0x0000},
 642        {0xaa, 0x21, 0x0001},
 643        {0xa0, 0x02, ZC3XX_R190_EXPOSURELIMITHIGH},
 644        {0xa0, 0xbf, ZC3XX_R191_EXPOSURELIMITMID},
 645        {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
 646        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
 647        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
 648        {0xa0, 0x80, ZC3XX_R197_ANTIFLICKERLOW},
 649        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
 650        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
 651        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
 652        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
 653        {0xa0, 0x01, ZC3XX_R01D_HSYNC_0},
 654        {0xa0, 0x40, ZC3XX_R01E_HSYNC_1},
 655        {0xa0, 0xa0, ZC3XX_R01F_HSYNC_2},
 656        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
 657        {}
 658};
 659static const struct usb_action cs2102_NoFliker[] = {
 660        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
 661        {0xaa, 0x23, 0x0000},
 662        {0xaa, 0x24, 0x00af},
 663        {0xaa, 0x25, 0x0080},
 664        {0xaa, 0x21, 0x0001},
 665        {0xa0, 0x01, ZC3XX_R190_EXPOSURELIMITHIGH},
 666        {0xa0, 0x5f, ZC3XX_R191_EXPOSURELIMITMID},
 667        {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW},
 668        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
 669        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
 670        {0xa0, 0x80, ZC3XX_R197_ANTIFLICKERLOW},
 671        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
 672        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
 673        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
 674        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
 675        {0xa0, 0x01, ZC3XX_R01D_HSYNC_0},
 676        {0xa0, 0x40, ZC3XX_R01E_HSYNC_1},
 677        {0xa0, 0xa0, ZC3XX_R01F_HSYNC_2},
 678        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
 679        {}
 680};
 681
 682/* CS2102_KOCOM */
 683static const struct usb_action cs2102K_InitialScale[] = {
 684        {0xa0, 0x11, ZC3XX_R002_CLOCKSELECT},
 685        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
 686        {0xa0, 0x08, ZC3XX_R010_CMOSSENSORSELECT},
 687        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
 688        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
 689        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
 690        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
 691        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
 692        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
 693        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
 694        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
 695        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
 696        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
 697        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
 698        {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
 699        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
 700        {0xa0, 0x55, ZC3XX_R08B_I2CDEVICEADDR},
 701        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
 702        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
 703        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 704        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 705        {0xa0, 0x0a, ZC3XX_R092_I2CADDRESSSELECT},
 706        {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
 707        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 708        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 709        {0xa0, 0x0b, ZC3XX_R092_I2CADDRESSSELECT},
 710        {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
 711        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 712        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 713        {0xa0, 0x0c, ZC3XX_R092_I2CADDRESSSELECT},
 714        {0xa0, 0x7c, ZC3XX_R093_I2CSETVALUE},
 715        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 716        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 717        {0xa0, 0x0d, ZC3XX_R092_I2CADDRESSSELECT},
 718        {0xa0, 0xa3, ZC3XX_R093_I2CSETVALUE},
 719        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 720        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 721        {0xa0, 0x03, ZC3XX_R092_I2CADDRESSSELECT},
 722        {0xa0, 0xfb, ZC3XX_R093_I2CSETVALUE},
 723        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 724        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 725        {0xa0, 0x05, ZC3XX_R092_I2CADDRESSSELECT},
 726        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
 727        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 728        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 729        {0xa0, 0x06, ZC3XX_R092_I2CADDRESSSELECT},
 730        {0xa0, 0x03, ZC3XX_R093_I2CSETVALUE},
 731        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 732        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 733        {0xa0, 0x09, ZC3XX_R092_I2CADDRESSSELECT},
 734        {0xa0, 0x08, ZC3XX_R093_I2CSETVALUE},
 735        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 736        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 737        {0xa0, 0x0e, ZC3XX_R092_I2CADDRESSSELECT},
 738        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
 739        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 740        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 741        {0xa0, 0x0f, ZC3XX_R092_I2CADDRESSSELECT},
 742        {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
 743        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 744        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 745        {0xa0, 0x10, ZC3XX_R092_I2CADDRESSSELECT},
 746        {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
 747        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 748        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 749        {0xa0, 0x11, ZC3XX_R092_I2CADDRESSSELECT},
 750        {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
 751        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 752        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 753        {0xa0, 0x12, ZC3XX_R092_I2CADDRESSSELECT},
 754        {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
 755        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 756        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 757        {0xa0, 0x15, ZC3XX_R092_I2CADDRESSSELECT},
 758        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
 759        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 760        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 761        {0xa0, 0x16, ZC3XX_R092_I2CADDRESSSELECT},
 762        {0xa0, 0x0c, ZC3XX_R093_I2CSETVALUE},
 763        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 764        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 765        {0xa0, 0x17, ZC3XX_R092_I2CADDRESSSELECT},
 766        {0xa0, 0x0c, ZC3XX_R093_I2CSETVALUE},
 767        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 768        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 769        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
 770        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
 771        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 772        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 773        {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},
 774        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
 775        {0xa0, 0x78, ZC3XX_R18D_YTARGET},
 776        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
 777        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
 778        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
 779        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
 780        {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},
 781        {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},
 782        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
 783        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
 784        {0xa0, 0x00, 0x01ad},
 785        {0xa0, 0x01, 0x01b1},
 786        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
 787        {0xa0, 0x60, ZC3XX_R116_RGAIN},
 788        {0xa0, 0x40, ZC3XX_R117_GGAIN},
 789        {0xa0, 0x4c, ZC3XX_R118_BGAIN},
 790        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* clock ? */
 791        {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},   /* sharpness+ */
 792        {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},   /* sharpness- */
 793        {0xa0, 0x13, ZC3XX_R120_GAMMA00},       /* gamma 4 */
 794        {0xa0, 0x38, ZC3XX_R121_GAMMA01},
 795        {0xa0, 0x59, ZC3XX_R122_GAMMA02},
 796        {0xa0, 0x79, ZC3XX_R123_GAMMA03},
 797        {0xa0, 0x92, ZC3XX_R124_GAMMA04},
 798        {0xa0, 0xa7, ZC3XX_R125_GAMMA05},
 799        {0xa0, 0xb9, ZC3XX_R126_GAMMA06},
 800        {0xa0, 0xc8, ZC3XX_R127_GAMMA07},
 801        {0xa0, 0xd4, ZC3XX_R128_GAMMA08},
 802        {0xa0, 0xdf, ZC3XX_R129_GAMMA09},
 803        {0xa0, 0xe7, ZC3XX_R12A_GAMMA0A},
 804        {0xa0, 0xee, ZC3XX_R12B_GAMMA0B},
 805        {0xa0, 0xf4, ZC3XX_R12C_GAMMA0C},
 806        {0xa0, 0xf9, ZC3XX_R12D_GAMMA0D},
 807        {0xa0, 0xfc, ZC3XX_R12E_GAMMA0E},
 808        {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
 809        {0xa0, 0x26, ZC3XX_R130_GAMMA10},
 810        {0xa0, 0x22, ZC3XX_R131_GAMMA11},
 811        {0xa0, 0x20, ZC3XX_R132_GAMMA12},
 812        {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
 813        {0xa0, 0x16, ZC3XX_R134_GAMMA14},
 814        {0xa0, 0x13, ZC3XX_R135_GAMMA15},
 815        {0xa0, 0x10, ZC3XX_R136_GAMMA16},
 816        {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
 817        {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
 818        {0xa0, 0x09, ZC3XX_R139_GAMMA19},
 819        {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
 820        {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
 821        {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
 822        {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
 823        {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
 824        {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
 825        {0xa0, 0x58, ZC3XX_R10A_RGB00}, /* matrix */
 826        {0xa0, 0xf4, ZC3XX_R10B_RGB01},
 827        {0xa0, 0xf4, ZC3XX_R10C_RGB02},
 828        {0xa0, 0xf4, ZC3XX_R10D_RGB10},
 829        {0xa0, 0x58, ZC3XX_R10E_RGB11},
 830        {0xa0, 0xf4, ZC3XX_R10F_RGB12},
 831        {0xa0, 0xf4, ZC3XX_R110_RGB20},
 832        {0xa0, 0xf4, ZC3XX_R111_RGB21},
 833        {0xa0, 0x58, ZC3XX_R112_RGB22},
 834        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
 835        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
 836        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
 837        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
 838        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 839        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 840        {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
 841        {0xa0, 0x22, ZC3XX_R093_I2CSETVALUE},
 842        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 843        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 844        {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
 845        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
 846        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 847        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 848        {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
 849        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
 850        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 851        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 852        {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
 853        {0xa0, 0x22, ZC3XX_R093_I2CSETVALUE},
 854        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 855        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 856        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
 857        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
 858        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 859        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 860        {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH},
 861        {0xa0, 0x22, ZC3XX_R0A4_EXPOSURETIMELOW},
 862        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
 863        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
 864        {0xa0, 0xee, ZC3XX_R192_EXPOSURELIMITLOW},
 865        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
 866        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
 867        {0xa0, 0x3a, ZC3XX_R197_ANTIFLICKERLOW},
 868        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
 869        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
 870        {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF},
 871        {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP},
 872        {0xa0, 0x04, ZC3XX_R01D_HSYNC_0},
 873        {0xa0, 0x0f, ZC3XX_R01E_HSYNC_1},
 874        {0xa0, 0x19, ZC3XX_R01F_HSYNC_2},
 875        {0xa0, 0x1f, ZC3XX_R020_HSYNC_3},
 876        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
 877        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
 878        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
 879        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
 880        {0xa0, 0x60, ZC3XX_R116_RGAIN},
 881        {0xa0, 0x40, ZC3XX_R117_GGAIN},
 882        {0xa0, 0x4c, ZC3XX_R118_BGAIN},
 883        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
 884        {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
 885        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
 886        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 887        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 888        {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
 889        {0xa0, 0x5c, ZC3XX_R093_I2CSETVALUE},
 890        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 891        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 892        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
 893        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
 894        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 895        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 896        {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
 897        {0xa0, 0x5c, ZC3XX_R093_I2CSETVALUE},
 898        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 899        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 900        {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
 901        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
 902        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 903        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 904        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
 905        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
 906        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 907        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 908        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
 909        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
 910        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
 911        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
 912        {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
 913        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
 914        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 915        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 916        {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
 917        {0xa0, 0x96, ZC3XX_R093_I2CSETVALUE},
 918        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 919        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 920        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
 921        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
 922        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 923        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 924        {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
 925        {0xa0, 0x96, ZC3XX_R093_I2CSETVALUE},
 926        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 927        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 928        {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
 929        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
 930        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 931        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 932        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
 933        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
 934        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 935        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 936        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
 937        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
 938        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
 939        {}
 940};
 941
 942static const struct usb_action cs2102K_Initial[] = {
 943        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
 944        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
 945        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
 946        {0xa0, 0x08, ZC3XX_R010_CMOSSENSORSELECT},
 947        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
 948        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
 949        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
 950        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
 951        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
 952        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
 953        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
 954        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
 955        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
 956        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
 957        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
 958        {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
 959        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
 960/*fixme: next sequence = i2c exchanges*/
 961        {0xa0, 0x55, ZC3XX_R08B_I2CDEVICEADDR},
 962        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
 963        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
 964        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 965        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 966        {0xa0, 0x0a, ZC3XX_R092_I2CADDRESSSELECT},
 967        {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
 968        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 969        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 970        {0xa0, 0x0b, ZC3XX_R092_I2CADDRESSSELECT},
 971        {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
 972        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 973        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 974        {0xa0, 0x0c, ZC3XX_R092_I2CADDRESSSELECT},
 975        {0xa0, 0x7b, ZC3XX_R093_I2CSETVALUE},
 976        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 977        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 978        {0xa0, 0x0d, ZC3XX_R092_I2CADDRESSSELECT},
 979        {0xa0, 0xa3, ZC3XX_R093_I2CSETVALUE},
 980        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 981        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 982        {0xa0, 0x03, ZC3XX_R092_I2CADDRESSSELECT},
 983        {0xa0, 0xfb, ZC3XX_R093_I2CSETVALUE},
 984        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 985        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 986        {0xa0, 0x05, ZC3XX_R092_I2CADDRESSSELECT},
 987        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
 988        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 989        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 990        {0xa0, 0x06, ZC3XX_R092_I2CADDRESSSELECT},
 991        {0xa0, 0x03, ZC3XX_R093_I2CSETVALUE},
 992        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 993        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 994        {0xa0, 0x09, ZC3XX_R092_I2CADDRESSSELECT},
 995        {0xa0, 0x08, ZC3XX_R093_I2CSETVALUE},
 996        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
 997        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
 998        {0xa0, 0x0e, ZC3XX_R092_I2CADDRESSSELECT},
 999        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1000        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1001        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1002        {0xa0, 0x0f, ZC3XX_R092_I2CADDRESSSELECT},
1003        {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
1004        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1005        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1006        {0xa0, 0x10, ZC3XX_R092_I2CADDRESSSELECT},
1007        {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
1008        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1009        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1010        {0xa0, 0x11, ZC3XX_R092_I2CADDRESSSELECT},
1011        {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
1012        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1013        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1014        {0xa0, 0x12, ZC3XX_R092_I2CADDRESSSELECT},
1015        {0xa0, 0x18, ZC3XX_R093_I2CSETVALUE},
1016        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1017        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1018        {0xa0, 0x15, ZC3XX_R092_I2CADDRESSSELECT},
1019        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1020        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1021        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1022        {0xa0, 0x16, ZC3XX_R092_I2CADDRESSSELECT},
1023        {0xa0, 0x0c, ZC3XX_R093_I2CSETVALUE},
1024        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1025        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1026        {0xa0, 0x17, ZC3XX_R092_I2CADDRESSSELECT},
1027        {0xa0, 0x0c, ZC3XX_R093_I2CSETVALUE},
1028        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1029        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1030        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1031        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1032        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1033        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1034        {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION},
1035        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1036        {0xa0, 0x78, ZC3XX_R18D_YTARGET},
1037        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1038        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1039        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1040        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1041        {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},
1042        {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},
1043        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1044        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
1045        {0xa0, 0x00, 0x01ad},
1046        {0xa0, 0x01, 0x01b1},
1047        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
1048        {0xa0, 0x60, ZC3XX_R116_RGAIN},
1049        {0xa0, 0x40, ZC3XX_R117_GGAIN},
1050        {0xa0, 0x4c, ZC3XX_R118_BGAIN},
1051        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* clock ? */
1052        {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},   /* sharpness+ */
1053        {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},   /* sharpness- */
1054        {0xa0, 0x13, ZC3XX_R120_GAMMA00},       /* gamma 4 */
1055        {0xa0, 0x38, ZC3XX_R121_GAMMA01},
1056        {0xa0, 0x59, ZC3XX_R122_GAMMA02},
1057        {0xa0, 0x79, ZC3XX_R123_GAMMA03},
1058        {0xa0, 0x92, ZC3XX_R124_GAMMA04},
1059        {0xa0, 0xa7, ZC3XX_R125_GAMMA05},
1060        {0xa0, 0xb9, ZC3XX_R126_GAMMA06},
1061        {0xa0, 0xc8, ZC3XX_R127_GAMMA07},
1062        {0xa0, 0xd4, ZC3XX_R128_GAMMA08},
1063        {0xa0, 0xdf, ZC3XX_R129_GAMMA09},
1064        {0xa0, 0xe7, ZC3XX_R12A_GAMMA0A},
1065        {0xa0, 0xee, ZC3XX_R12B_GAMMA0B},
1066        {0xa0, 0xf4, ZC3XX_R12C_GAMMA0C},
1067        {0xa0, 0xf9, ZC3XX_R12D_GAMMA0D},
1068        {0xa0, 0xfc, ZC3XX_R12E_GAMMA0E},
1069        {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
1070        {0xa0, 0x26, ZC3XX_R130_GAMMA10},
1071        {0xa0, 0x22, ZC3XX_R131_GAMMA11},
1072        {0xa0, 0x20, ZC3XX_R132_GAMMA12},
1073        {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
1074        {0xa0, 0x16, ZC3XX_R134_GAMMA14},
1075        {0xa0, 0x13, ZC3XX_R135_GAMMA15},
1076        {0xa0, 0x10, ZC3XX_R136_GAMMA16},
1077        {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
1078        {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
1079        {0xa0, 0x09, ZC3XX_R139_GAMMA19},
1080        {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
1081        {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
1082        {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
1083        {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
1084        {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
1085        {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
1086        {0xa0, 0x58, ZC3XX_R10A_RGB00}, /* matrix */
1087        {0xa0, 0xf4, ZC3XX_R10B_RGB01},
1088        {0xa0, 0xf4, ZC3XX_R10C_RGB02},
1089        {0xa0, 0xf4, ZC3XX_R10D_RGB10},
1090        {0xa0, 0x58, ZC3XX_R10E_RGB11},
1091        {0xa0, 0xf4, ZC3XX_R10F_RGB12},
1092        {0xa0, 0xf4, ZC3XX_R110_RGB20},
1093        {0xa0, 0xf4, ZC3XX_R111_RGB21},
1094        {0xa0, 0x58, ZC3XX_R112_RGB22},
1095        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
1096        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
1097        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1098        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1099        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1100        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1101        {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1102        {0xa0, 0x22, ZC3XX_R093_I2CSETVALUE},
1103        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1104        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1105        {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1106        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1107        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1108        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1109        {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1110        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1111        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1112        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1113        {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1114        {0xa0, 0x22, ZC3XX_R093_I2CSETVALUE},
1115        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1116        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1117        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1118        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1119        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1120        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1121        {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH},
1122        {0xa0, 0x22, ZC3XX_R0A4_EXPOSURETIMELOW},
1123        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
1124        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
1125        {0xa0, 0xee, ZC3XX_R192_EXPOSURELIMITLOW},
1126        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
1127        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
1128        {0xa0, 0x3a, ZC3XX_R197_ANTIFLICKERLOW},
1129        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
1130        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
1131        {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF},
1132        {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP},
1133        {0xa0, 0x04, ZC3XX_R01D_HSYNC_0},
1134        {0xa0, 0x0f, ZC3XX_R01E_HSYNC_1},
1135        {0xa0, 0x19, ZC3XX_R01F_HSYNC_2},
1136        {0xa0, 0x1f, ZC3XX_R020_HSYNC_3},
1137        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
1138        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
1139        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1140        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1141        {0xa0, 0x60, ZC3XX_R116_RGAIN},
1142        {0xa0, 0x40, ZC3XX_R117_GGAIN},
1143        {0xa0, 0x4c, ZC3XX_R118_BGAIN},
1144        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1145        {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1146        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1147        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1148        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1149        {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1150        {0xa0, 0x5c, ZC3XX_R093_I2CSETVALUE},
1151        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1152        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1153        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1154        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1155        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1156        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1157        {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1158        {0xa0, 0x5c, ZC3XX_R093_I2CSETVALUE},
1159        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1160        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1161        {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1162        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1163        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1164        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1165        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1166        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1167        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1168        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1169        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1170        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1171        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1172        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1173        {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1174        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1175        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1176        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1177        {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1178        {0xa0, 0x96, ZC3XX_R093_I2CSETVALUE},
1179        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1180        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1181        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1182        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1183        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1184        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1185        {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1186        {0xa0, 0x96, ZC3XX_R093_I2CSETVALUE},
1187        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1188        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1189        {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1190        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1191        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1192        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1193        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1194        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1195        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1196        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1197        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1198        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1199        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1200/*fixme:what does the next sequence?*/
1201        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1202        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1203        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1204        {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1205        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1206        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1207        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1208        {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1209        {0xa0, 0xd0, ZC3XX_R093_I2CSETVALUE},
1210        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1211        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1212        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1213        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1214        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1215        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1216        {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1217        {0xa0, 0xd0, ZC3XX_R093_I2CSETVALUE},
1218        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1219        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1220        {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1221        {0xa0, 0x01, ZC3XX_R093_I2CSETVALUE},
1222        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1223        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1224        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1225        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1226        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1227        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1228        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1229        {0xa0, 0x02, ZC3XX_R008_CLOCKSETTING},
1230        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1231        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1232        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1233        {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1234        {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1235        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1236        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1237        {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1238        {0xa0, 0x0a, ZC3XX_R093_I2CSETVALUE},
1239        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1240        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1241        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1242        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1243        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1244        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1245        {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1246        {0xa0, 0x0a, ZC3XX_R093_I2CSETVALUE},
1247        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1248        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1249        {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1250        {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1251        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1252        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1253        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1254        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1255        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1256        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1257        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1258        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1259        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1260        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1261        {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1262        {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1263        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1264        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1265        {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1266        {0xa0, 0x44, ZC3XX_R093_I2CSETVALUE},
1267        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1268        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1269        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1270        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1271        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1272        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1273        {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1274        {0xa0, 0x44, ZC3XX_R093_I2CSETVALUE},
1275        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1276        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1277        {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1278        {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1279        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1280        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1281        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1282        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1283        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1284        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1285        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1286        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1287        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1288        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1289        {0xa0, 0x20, ZC3XX_R092_I2CADDRESSSELECT},
1290        {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1291        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1292        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1293        {0xa0, 0x21, ZC3XX_R092_I2CADDRESSSELECT},
1294        {0xa0, 0x7e, ZC3XX_R093_I2CSETVALUE},
1295        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1296        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1297        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1298        {0xa0, 0x00, ZC3XX_R093_I2CSETVALUE},
1299        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1300        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1301        {0xa0, 0x13, ZC3XX_R092_I2CADDRESSSELECT},
1302        {0xa0, 0x7e, ZC3XX_R093_I2CSETVALUE},
1303        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1304        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1305        {0xa0, 0x14, ZC3XX_R092_I2CADDRESSSELECT},
1306        {0xa0, 0x02, ZC3XX_R093_I2CSETVALUE},
1307        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1308        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1309        {0xa0, 0x18, ZC3XX_R092_I2CADDRESSSELECT},
1310        {0xa0, 0x04, ZC3XX_R093_I2CSETVALUE},
1311        {0xa0, 0x00, ZC3XX_R094_I2CWRITEACK},
1312        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
1313        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1314        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1315        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
1316        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
1317        {}
1318};
1319
1320static const struct usb_action gc0305_Initial[] = {     /* 640x480 */
1321        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
1322        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* 00,08,03,cc */
1323        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
1324        {0xa0, 0x04, ZC3XX_R002_CLOCKSELECT},   /* 00,02,04,cc */
1325        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},        /* 00,03,02,cc */
1326        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
1327        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},       /* 00,05,01,cc */
1328        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},        /* 00,06,e0,cc */
1329        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},       /* 00,01,01,cc */
1330        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,03,cc */
1331        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,01,cc */
1332        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},  /* 00,98,00,cc */
1333        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},  /* 00,9a,00,cc */
1334        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},     /* 01,1a,00,cc */
1335        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},     /* 01,1c,00,cc */
1336        {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},  /* 00,9c,e6,cc */
1337        {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},   /* 00,9e,86,cc */
1338        {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc */
1339        {0xaa, 0x13, 0x0002},   /* 00,13,02,aa */
1340        {0xaa, 0x15, 0x0003},   /* 00,15,03,aa */
1341        {0xaa, 0x01, 0x0000},   /* 00,01,00,aa */
1342        {0xaa, 0x02, 0x0000},   /* 00,02,00,aa */
1343        {0xaa, 0x1a, 0x0000},   /* 00,1a,00,aa */
1344        {0xaa, 0x1c, 0x0017},   /* 00,1c,17,aa */
1345        {0xaa, 0x1d, 0x0080},   /* 00,1d,80,aa */
1346        {0xaa, 0x1f, 0x0008},   /* 00,1f,08,aa */
1347        {0xaa, 0x21, 0x0012},   /* 00,21,12,aa */
1348        {0xa0, 0x82, ZC3XX_R086_EXPTIMEHIGH},   /* 00,86,82,cc */
1349        {0xa0, 0x83, ZC3XX_R087_EXPTIMEMID},    /* 00,87,83,cc */
1350        {0xa0, 0x84, ZC3XX_R088_EXPTIMELOW},    /* 00,88,84,cc */
1351        {0xaa, 0x05, 0x0000},   /* 00,05,00,aa */
1352        {0xaa, 0x0a, 0x0000},   /* 00,0a,00,aa */
1353        {0xaa, 0x0b, 0x00b0},   /* 00,0b,b0,aa */
1354        {0xaa, 0x0c, 0x0000},   /* 00,0c,00,aa */
1355        {0xaa, 0x0d, 0x00b0},   /* 00,0d,b0,aa */
1356        {0xaa, 0x0e, 0x0000},   /* 00,0e,00,aa */
1357        {0xaa, 0x0f, 0x00b0},   /* 00,0f,b0,aa */
1358        {0xaa, 0x10, 0x0000},   /* 00,10,00,aa */
1359        {0xaa, 0x11, 0x00b0},   /* 00,11,b0,aa */
1360        {0xaa, 0x16, 0x0001},   /* 00,16,01,aa */
1361        {0xaa, 0x17, 0x00e6},   /* 00,17,e6,aa */
1362        {0xaa, 0x18, 0x0002},   /* 00,18,02,aa */
1363        {0xaa, 0x19, 0x0086},   /* 00,19,86,aa */
1364        {0xaa, 0x20, 0x0000},   /* 00,20,00,aa */
1365        {0xaa, 0x1b, 0x0020},   /* 00,1b,20,aa */
1366        {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},      /* 01,01,b7,cc */
1367        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,05,cc */
1368        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
1369        {0xa0, 0x76, ZC3XX_R189_AWBSTATUS},     /* 01,89,76,cc */
1370        {0xa0, 0x09, 0x01ad},   /* 01,ad,09,cc */
1371        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
1372        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},   /* 01,cb,13,cc */
1373        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},        /* 02,50,08,cc */
1374        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},  /* 03,01,08,cc */
1375        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},   /* 01,a8,60,cc */
1376        {0xa0, 0x85, ZC3XX_R18D_YTARGET},       /* 01,8d,85,cc */
1377        {0xa0, 0x00, 0x011e},   /* 01,1e,00,cc */
1378        {0xa0, 0x52, ZC3XX_R116_RGAIN}, /* 01,16,52,cc */
1379        {0xa0, 0x40, ZC3XX_R117_GGAIN}, /* 01,17,40,cc */
1380        {0xa0, 0x52, ZC3XX_R118_BGAIN}, /* 01,18,52,cc */
1381        {0xa0, 0x03, ZC3XX_R113_RGB03}, /* 01,13,03,cc */
1382        {}
1383};
1384static const struct usb_action gc0305_InitialScale[] = { /* 320x240 */
1385        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
1386        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* 00,08,03,cc */
1387        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc */
1388        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},   /* 00,02,10,cc */
1389        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},        /* 00,03,02,cc */
1390        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
1391        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},       /* 00,05,01,cc */
1392        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},        /* 00,06,e0,cc */
1393        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},       /* 00,01,01,cc */
1394        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,03,cc */
1395        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,01,cc */
1396        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},  /* 00,98,00,cc */
1397        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},  /* 00,9a,00,cc */
1398        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},     /* 01,1a,00,cc */
1399        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},     /* 01,1c,00,cc */
1400        {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},  /* 00,9c,e8,cc */
1401        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},   /* 00,9e,88,cc */
1402        {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,98,cc */
1403        {0xaa, 0x13, 0x0000},   /* 00,13,00,aa */
1404        {0xaa, 0x15, 0x0001},   /* 00,15,01,aa */
1405        {0xaa, 0x01, 0x0000},   /* 00,01,00,aa */
1406        {0xaa, 0x02, 0x0000},   /* 00,02,00,aa */
1407        {0xaa, 0x1a, 0x0000},   /* 00,1a,00,aa */
1408        {0xaa, 0x1c, 0x0017},   /* 00,1c,17,aa */
1409        {0xaa, 0x1d, 0x0080},   /* 00,1d,80,aa */
1410        {0xaa, 0x1f, 0x0008},   /* 00,1f,08,aa */
1411        {0xaa, 0x21, 0x0012},   /* 00,21,12,aa */
1412        {0xa0, 0x82, ZC3XX_R086_EXPTIMEHIGH},   /* 00,86,82,cc */
1413        {0xa0, 0x83, ZC3XX_R087_EXPTIMEMID},    /* 00,87,83,cc */
1414        {0xa0, 0x84, ZC3XX_R088_EXPTIMELOW},    /* 00,88,84,cc */
1415        {0xaa, 0x05, 0x0000},   /* 00,05,00,aa */
1416        {0xaa, 0x0a, 0x0000},   /* 00,0a,00,aa */
1417        {0xaa, 0x0b, 0x00b0},   /* 00,0b,b0,aa */
1418        {0xaa, 0x0c, 0x0000},   /* 00,0c,00,aa */
1419        {0xaa, 0x0d, 0x00b0},   /* 00,0d,b0,aa */
1420        {0xaa, 0x0e, 0x0000},   /* 00,0e,00,aa */
1421        {0xaa, 0x0f, 0x00b0},   /* 00,0f,b0,aa */
1422        {0xaa, 0x10, 0x0000},   /* 00,10,00,aa */
1423        {0xaa, 0x11, 0x00b0},   /* 00,11,b0,aa */
1424        {0xaa, 0x16, 0x0001},   /* 00,16,01,aa */
1425        {0xaa, 0x17, 0x00e8},   /* 00,17,e8,aa */
1426        {0xaa, 0x18, 0x0002},   /* 00,18,02,aa */
1427        {0xaa, 0x19, 0x0088},   /* 00,19,88,aa */
1428        {0xaa, 0x20, 0x0000},   /* 00,20,00,aa */
1429        {0xaa, 0x1b, 0x0020},   /* 00,1b,20,aa */
1430        {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},      /* 01,01,b7,cc */
1431        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,05,cc */
1432        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
1433        {0xa0, 0x76, ZC3XX_R189_AWBSTATUS},     /* 01,89,76,cc */
1434        {0xa0, 0x09, 0x01ad},   /* 01,ad,09,cc */
1435        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
1436        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},   /* 01,cb,13,cc */
1437        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},        /* 02,50,08,cc */
1438        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},  /* 03,01,08,cc */
1439        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},   /* 01,a8,60,cc */
1440        {0xa0, 0x00, 0x011e},   /* 01,1e,00,cc */
1441        {0xa0, 0x52, ZC3XX_R116_RGAIN}, /* 01,16,52,cc */
1442        {0xa0, 0x40, ZC3XX_R117_GGAIN}, /* 01,17,40,cc */
1443        {0xa0, 0x52, ZC3XX_R118_BGAIN}, /* 01,18,52,cc */
1444        {0xa0, 0x03, ZC3XX_R113_RGB03}, /* 01,13,03,cc */
1445        {}
1446};
1447static const struct usb_action gc0305_50HZ[] = {
1448        {0xaa, 0x82, 0x0000},   /* 00,82,00,aa */
1449        {0xaa, 0x83, 0x0002},   /* 00,83,02,aa */
1450        {0xaa, 0x84, 0x0038},   /* 00,84,38,aa */       /* win: 00,84,ec */
1451        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
1452        {0xa0, 0x0b, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,0b,cc */
1453        {0xa0, 0x18, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,18,cc */
1454                                                        /* win: 01,92,10 */
1455        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
1456        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
1457        {0xa0, 0x8e, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,8e,cc */
1458                                                        /* win: 01,97,ec */
1459        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},      /* 01,8c,0e,cc */
1460        {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE},    /* 01,8f,15,cc */
1461        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,10,cc */
1462        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
1463        {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},       /* 00,1d,62,cc */
1464        {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},       /* 00,1e,90,cc */
1465        {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},       /* 00,1f,c8,cc */
1466        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},       /* 00,20,ff,cc */
1467        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},    /* 01,1d,60,cc */
1468        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},     /* 01,80,42,cc */
1469/*      {0xa0, 0x85, ZC3XX_R18D_YTARGET},        * 01,8d,85,cc *
1470                                                 * if 640x480 */
1471        {}
1472};
1473static const struct usb_action gc0305_60HZ[] = {
1474        {0xaa, 0x82, 0x0000},   /* 00,82,00,aa */
1475        {0xaa, 0x83, 0x0000},   /* 00,83,00,aa */
1476        {0xaa, 0x84, 0x00ec},   /* 00,84,ec,aa */
1477        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
1478        {0xa0, 0x0b, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,0b,cc */
1479        {0xa0, 0x10, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,10,cc */
1480        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
1481        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
1482        {0xa0, 0xec, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,ec,cc */
1483        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},      /* 01,8c,0e,cc */
1484        {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE},    /* 01,8f,15,cc */
1485        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,10,cc */
1486        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
1487        {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},       /* 00,1d,62,cc */
1488        {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},       /* 00,1e,90,cc */
1489        {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},       /* 00,1f,c8,cc */
1490        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},       /* 00,20,ff,cc */
1491        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},    /* 01,1d,60,cc */
1492        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},     /* 01,80,42,cc */
1493        {0xa0, 0x80, ZC3XX_R18D_YTARGET},       /* 01,8d,80,cc */
1494        {}
1495};
1496
1497static const struct usb_action gc0305_NoFliker[] = {
1498        {0xa0, 0x0c, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0c,cc */
1499        {0xaa, 0x82, 0x0000},   /* 00,82,00,aa */
1500        {0xaa, 0x83, 0x0000},   /* 00,83,00,aa */
1501        {0xaa, 0x84, 0x0020},   /* 00,84,20,aa */
1502        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
1503        {0xa0, 0x00, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,00,cc */
1504        {0xa0, 0x48, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,48,cc */
1505        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
1506        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
1507        {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,10,cc */
1508        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},      /* 01,8c,0e,cc */
1509        {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE},    /* 01,8f,15,cc */
1510        {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},       /* 00,1d,62,cc */
1511        {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},       /* 00,1e,90,cc */
1512        {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},       /* 00,1f,c8,cc */
1513        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},       /* 00,20,ff,cc */
1514        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},    /* 01,1d,60,cc */
1515        {0xa0, 0x03, ZC3XX_R180_AUTOCORRECTENABLE},     /* 01,80,03,cc */
1516        {0xa0, 0x80, ZC3XX_R18D_YTARGET},       /* 01,8d,80,cc */
1517        {}
1518};
1519
1520static const struct usb_action hdcs2020_InitialScale[] = {
1521        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
1522        {0xa0, 0x11, ZC3XX_R002_CLOCKSELECT},
1523        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* qtable 0x05 */
1524        {0xa0, 0x08, ZC3XX_R010_CMOSSENSORSELECT},
1525        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
1526        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
1527        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
1528        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
1529        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
1530        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
1531        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
1532        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
1533        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
1534        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
1535        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
1536        {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
1537        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
1538        {0xaa, 0x1c, 0x0000},
1539        {0xaa, 0x0a, 0x0001},
1540        {0xaa, 0x0b, 0x0006},
1541        {0xaa, 0x0c, 0x007b},
1542        {0xaa, 0x0d, 0x00a7},
1543        {0xaa, 0x03, 0x00fb},
1544        {0xaa, 0x05, 0x0000},
1545        {0xaa, 0x06, 0x0003},
1546        {0xaa, 0x09, 0x0008},
1547
1548        {0xaa, 0x0f, 0x0018},   /* set sensor gain */
1549        {0xaa, 0x10, 0x0018},
1550        {0xaa, 0x11, 0x0018},
1551        {0xaa, 0x12, 0x0018},
1552
1553        {0xaa, 0x15, 0x004e},
1554        {0xaa, 0x1c, 0x0004},
1555        {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},
1556        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1557        {0xa0, 0x70, ZC3XX_R18D_YTARGET},
1558        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1559        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1560        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1561        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1562        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1563        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
1564        {0xa1, 0x01, 0x0002},
1565        {0xa1, 0x01, 0x0008},
1566        {0xa1, 0x01, 0x0180},
1567        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
1568        {0xa0, 0x40, ZC3XX_R116_RGAIN},
1569        {0xa0, 0x40, ZC3XX_R117_GGAIN},
1570        {0xa0, 0x40, ZC3XX_R118_BGAIN},
1571        {0xa1, 0x01, 0x0008},
1572        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* clock ? */
1573        {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},   /* sharpness+ */
1574        {0xa1, 0x01, 0x01c8},
1575        {0xa1, 0x01, 0x01c9},
1576        {0xa1, 0x01, 0x01ca},
1577        {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},   /* sharpness- */
1578        {0xa0, 0x13, ZC3XX_R120_GAMMA00},       /* gamma 4 */
1579        {0xa0, 0x38, ZC3XX_R121_GAMMA01},
1580        {0xa0, 0x59, ZC3XX_R122_GAMMA02},
1581        {0xa0, 0x79, ZC3XX_R123_GAMMA03},
1582        {0xa0, 0x92, ZC3XX_R124_GAMMA04},
1583        {0xa0, 0xa7, ZC3XX_R125_GAMMA05},
1584        {0xa0, 0xb9, ZC3XX_R126_GAMMA06},
1585        {0xa0, 0xc8, ZC3XX_R127_GAMMA07},
1586        {0xa0, 0xd4, ZC3XX_R128_GAMMA08},
1587        {0xa0, 0xdf, ZC3XX_R129_GAMMA09},
1588        {0xa0, 0xe7, ZC3XX_R12A_GAMMA0A},
1589        {0xa0, 0xee, ZC3XX_R12B_GAMMA0B},
1590        {0xa0, 0xf4, ZC3XX_R12C_GAMMA0C},
1591        {0xa0, 0xf9, ZC3XX_R12D_GAMMA0D},
1592        {0xa0, 0xfc, ZC3XX_R12E_GAMMA0E},
1593        {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
1594        {0xa0, 0x26, ZC3XX_R130_GAMMA10},
1595        {0xa0, 0x22, ZC3XX_R131_GAMMA11},
1596        {0xa0, 0x20, ZC3XX_R132_GAMMA12},
1597        {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
1598        {0xa0, 0x16, ZC3XX_R134_GAMMA14},
1599        {0xa0, 0x13, ZC3XX_R135_GAMMA15},
1600        {0xa0, 0x10, ZC3XX_R136_GAMMA16},
1601        {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
1602        {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
1603        {0xa0, 0x09, ZC3XX_R139_GAMMA19},
1604        {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
1605        {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
1606        {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
1607        {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
1608        {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
1609        {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
1610
1611        {0xa0, 0x66, ZC3XX_R10A_RGB00}, /* matrix */
1612        {0xa0, 0xed, ZC3XX_R10B_RGB01},
1613        {0xa0, 0xed, ZC3XX_R10C_RGB02},
1614        {0xa0, 0xed, ZC3XX_R10D_RGB10},
1615        {0xa0, 0x66, ZC3XX_R10E_RGB11},
1616        {0xa0, 0xed, ZC3XX_R10F_RGB12},
1617        {0xa0, 0xed, ZC3XX_R110_RGB20},
1618        {0xa0, 0xed, ZC3XX_R111_RGB21},
1619        {0xa0, 0x66, ZC3XX_R112_RGB22},
1620
1621        {0xa1, 0x01, 0x0180},
1622        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
1623        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
1624        {0xaa, 0x13, 0x0031},
1625        {0xaa, 0x14, 0x0001},
1626        {0xaa, 0x0e, 0x0004},
1627        {0xaa, 0x19, 0x00cd},
1628        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
1629        {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
1630        {0xa0, 0x62, ZC3XX_R192_EXPOSURELIMITLOW},
1631        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
1632        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
1633        {0xa0, 0x3d, ZC3XX_R197_ANTIFLICKERLOW},
1634        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
1635        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
1636
1637        {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 0x14 */
1638        {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP},
1639        {0xa0, 0x04, ZC3XX_R01D_HSYNC_0},
1640        {0xa0, 0x18, ZC3XX_R01E_HSYNC_1},
1641        {0xa0, 0x2c, ZC3XX_R01F_HSYNC_2},
1642        {0xa0, 0x41, ZC3XX_R020_HSYNC_3},
1643        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
1644        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1645        {0xa1, 0x01, 0x0180},
1646        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1647        {0xa0, 0x40, ZC3XX_R116_RGAIN},
1648        {0xa0, 0x40, ZC3XX_R117_GGAIN},
1649        {0xa0, 0x40, ZC3XX_R118_BGAIN},
1650        {}
1651};
1652static const struct usb_action hdcs2020_Initial[] = {
1653        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
1654        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
1655        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
1656        {0xa0, 0x08, ZC3XX_R010_CMOSSENSORSELECT},
1657        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
1658        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
1659        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
1660        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
1661        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
1662        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
1663        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
1664        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
1665        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
1666        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
1667        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
1668        {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
1669        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
1670        {0xaa, 0x1c, 0x0000},
1671        {0xaa, 0x0a, 0x0001},
1672        {0xaa, 0x0b, 0x0006},
1673        {0xaa, 0x0c, 0x007a},
1674        {0xaa, 0x0d, 0x00a7},
1675        {0xaa, 0x03, 0x00fb},
1676        {0xaa, 0x05, 0x0000},
1677        {0xaa, 0x06, 0x0003},
1678        {0xaa, 0x09, 0x0008},
1679        {0xaa, 0x0f, 0x0018},   /* original setting */
1680        {0xaa, 0x10, 0x0018},
1681        {0xaa, 0x11, 0x0018},
1682        {0xaa, 0x12, 0x0018},
1683        {0xaa, 0x15, 0x004e},
1684        {0xaa, 0x1c, 0x0004},
1685        {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION},
1686        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1687        {0xa0, 0x70, ZC3XX_R18D_YTARGET},
1688        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1689        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1690        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1691        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1692        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1693        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
1694        {0xa1, 0x01, 0x0002},
1695        {0xa1, 0x01, 0x0008},
1696        {0xa1, 0x01, 0x0180},
1697        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
1698        {0xa0, 0x40, ZC3XX_R116_RGAIN},
1699        {0xa0, 0x40, ZC3XX_R117_GGAIN},
1700        {0xa0, 0x40, ZC3XX_R118_BGAIN},
1701        {0xa1, 0x01, 0x0008},
1702        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* clock ? */
1703        {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},   /* sharpness+ */
1704        {0xa1, 0x01, 0x01c8},
1705        {0xa1, 0x01, 0x01c9},
1706        {0xa1, 0x01, 0x01ca},
1707        {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},   /* sharpness- */
1708        {0xa0, 0x13, ZC3XX_R120_GAMMA00},       /* gamma 4 */
1709        {0xa0, 0x38, ZC3XX_R121_GAMMA01},
1710        {0xa0, 0x59, ZC3XX_R122_GAMMA02},
1711        {0xa0, 0x79, ZC3XX_R123_GAMMA03},
1712        {0xa0, 0x92, ZC3XX_R124_GAMMA04},
1713        {0xa0, 0xa7, ZC3XX_R125_GAMMA05},
1714        {0xa0, 0xb9, ZC3XX_R126_GAMMA06},
1715        {0xa0, 0xc8, ZC3XX_R127_GAMMA07},
1716        {0xa0, 0xd4, ZC3XX_R128_GAMMA08},
1717        {0xa0, 0xdf, ZC3XX_R129_GAMMA09},
1718        {0xa0, 0xe7, ZC3XX_R12A_GAMMA0A},
1719        {0xa0, 0xee, ZC3XX_R12B_GAMMA0B},
1720        {0xa0, 0xf4, ZC3XX_R12C_GAMMA0C},
1721        {0xa0, 0xf9, ZC3XX_R12D_GAMMA0D},
1722        {0xa0, 0xfc, ZC3XX_R12E_GAMMA0E},
1723        {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
1724        {0xa0, 0x26, ZC3XX_R130_GAMMA10},
1725        {0xa0, 0x22, ZC3XX_R131_GAMMA11},
1726        {0xa0, 0x20, ZC3XX_R132_GAMMA12},
1727        {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
1728        {0xa0, 0x16, ZC3XX_R134_GAMMA14},
1729        {0xa0, 0x13, ZC3XX_R135_GAMMA15},
1730        {0xa0, 0x10, ZC3XX_R136_GAMMA16},
1731        {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
1732        {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
1733        {0xa0, 0x09, ZC3XX_R139_GAMMA19},
1734        {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
1735        {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
1736        {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
1737        {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
1738        {0xa0, 0x03, ZC3XX_R13E_GAMMA1E},
1739        {0xa0, 0x02, ZC3XX_R13F_GAMMA1F},
1740        {0xa0, 0x66, ZC3XX_R10A_RGB00}, /* matrix */
1741        {0xa0, 0xed, ZC3XX_R10B_RGB01},
1742        {0xa0, 0xed, ZC3XX_R10C_RGB02},
1743        {0xa0, 0xed, ZC3XX_R10D_RGB10},
1744        {0xa0, 0x66, ZC3XX_R10E_RGB11},
1745        {0xa0, 0xed, ZC3XX_R10F_RGB12},
1746        {0xa0, 0xed, ZC3XX_R110_RGB20},
1747        {0xa0, 0xed, ZC3XX_R111_RGB21},
1748        {0xa0, 0x66, ZC3XX_R112_RGB22},
1749        {0xa1, 0x01, 0x0180},
1750        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
1751        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
1752 /**** set exposure ***/
1753        {0xaa, 0x13, 0x0031},
1754        {0xaa, 0x14, 0x0001},
1755        {0xaa, 0x0e, 0x0004},
1756        {0xaa, 0x19, 0x00cd},
1757        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
1758        {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
1759        {0xa0, 0x62, ZC3XX_R192_EXPOSURELIMITLOW},
1760        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
1761        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
1762        {0xa0, 0x3d, ZC3XX_R197_ANTIFLICKERLOW},
1763        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
1764        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
1765        {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF},
1766        {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP},
1767        {0xa0, 0x04, ZC3XX_R01D_HSYNC_0},
1768        {0xa0, 0x18, ZC3XX_R01E_HSYNC_1},
1769        {0xa0, 0x2c, ZC3XX_R01F_HSYNC_2},
1770        {0xa0, 0x41, ZC3XX_R020_HSYNC_3},
1771        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
1772        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1773        {0xa1, 0x01, 0x0180},
1774        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
1775        {0xa0, 0x40, ZC3XX_R116_RGAIN},
1776        {0xa0, 0x40, ZC3XX_R117_GGAIN},
1777        {0xa0, 0x40, ZC3XX_R118_BGAIN},
1778        {}
1779};
1780static const struct usb_action hdcs2020_50HZ[] = {
1781        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1782        {0xaa, 0x13, 0x0018},                   /* 00,13,18,aa */
1783        {0xaa, 0x14, 0x0001},                   /* 00,14,01,aa */
1784        {0xaa, 0x0e, 0x0005},                   /* 00,0e,05,aa */
1785        {0xaa, 0x19, 0x001f},                   /* 00,19,1f,aa */
1786        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1787        {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,02,cc */
1788        {0xa0, 0x76, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,76,cc */
1789        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1790        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1791        {0xa0, 0x46, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,46,cc */
1792        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
1793        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
1794        {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,0c,cc */
1795        {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,28,cc */
1796        {0xa0, 0x05, ZC3XX_R01D_HSYNC_0}, /* 00,1d,05,cc */
1797        {0xa0, 0x1a, ZC3XX_R01E_HSYNC_1}, /* 00,1e,1a,cc */
1798        {0xa0, 0x2f, ZC3XX_R01F_HSYNC_2}, /* 00,1f,2f,cc */
1799        {}
1800};
1801static const struct usb_action hdcs2020_60HZ[] = {
1802        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1803        {0xaa, 0x13, 0x0031},                   /* 00,13,31,aa */
1804        {0xaa, 0x14, 0x0001},                   /* 00,14,01,aa */
1805        {0xaa, 0x0e, 0x0004},                   /* 00,0e,04,aa */
1806        {0xaa, 0x19, 0x00cd},                   /* 00,19,cd,aa */
1807        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1808        {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,02,cc */
1809        {0xa0, 0x62, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,62,cc */
1810        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1811        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1812        {0xa0, 0x3d, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,3d,cc */
1813        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
1814        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
1815        {0xa0, 0x0c, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,0c,cc */
1816        {0xa0, 0x28, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,28,cc */
1817        {0xa0, 0x04, ZC3XX_R01D_HSYNC_0}, /* 00,1d,04,cc */
1818        {0xa0, 0x18, ZC3XX_R01E_HSYNC_1}, /* 00,1e,18,cc */
1819        {0xa0, 0x2c, ZC3XX_R01F_HSYNC_2}, /* 00,1f,2c,cc */
1820        {}
1821};
1822static const struct usb_action hdcs2020_NoFliker[] = {
1823        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1824        {0xaa, 0x13, 0x0010},                   /* 00,13,10,aa */
1825        {0xaa, 0x14, 0x0001},                   /* 00,14,01,aa */
1826        {0xaa, 0x0e, 0x0004},                   /* 00,0e,04,aa */
1827        {0xaa, 0x19, 0x0000},                   /* 00,19,00,aa */
1828        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
1829        {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,02,cc */
1830        {0xa0, 0x70, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,70,cc */
1831        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
1832        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
1833        {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
1834        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
1835        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
1836        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
1837        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
1838        {0xa0, 0x04, ZC3XX_R01D_HSYNC_0}, /* 00,1d,04,cc */
1839        {0xa0, 0x17, ZC3XX_R01E_HSYNC_1}, /* 00,1e,17,cc */
1840        {0xa0, 0x2a, ZC3XX_R01F_HSYNC_2}, /* 00,1f,2a,cc */
1841        {}
1842};
1843
1844static const struct usb_action hv7131b_InitialScale[] = {       /* 320x240 */
1845        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
1846        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
1847        {0xa0, 0x00, ZC3XX_R010_CMOSSENSORSELECT},
1848        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
1849        {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
1850        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* 00 */
1851        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
1852        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
1853        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
1854        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
1855        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
1856        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
1857        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
1858        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
1859        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
1860        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
1861        {0xaa, 0x30, 0x002d},
1862        {0xaa, 0x01, 0x0005},
1863        {0xaa, 0x11, 0x0000},
1864        {0xaa, 0x13, 0x0001},   /* {0xaa, 0x13, 0x0000}, */
1865        {0xaa, 0x14, 0x0001},
1866        {0xaa, 0x15, 0x00e8},
1867        {0xaa, 0x16, 0x0002},
1868        {0xaa, 0x17, 0x0086},           /* 00,17,88,aa */
1869        {0xaa, 0x31, 0x0038},
1870        {0xaa, 0x32, 0x0038},
1871        {0xaa, 0x33, 0x0038},
1872        {0xaa, 0x5b, 0x0001},
1873        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
1874        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1875        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1876        {0xa0, 0x68, ZC3XX_R18D_YTARGET},
1877        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
1878        {0xa0, 0x00, 0x01ad},
1879        {0xa0, 0xc0, 0x019b},
1880        {0xa0, 0xa0, 0x019c},
1881        {0xa0, 0x02, ZC3XX_R188_MINGAIN},
1882        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1883        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1884        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1885        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1886        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
1887        {0xaa, 0x02, 0x0090},                   /* 00,02,80,aa */
1888        {}
1889};
1890
1891static const struct usb_action hv7131b_Initial[] = {    /* 640x480*/
1892        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
1893        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
1894        {0xa0, 0x00, ZC3XX_R010_CMOSSENSORSELECT},
1895        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
1896        {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
1897        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* 00 */
1898        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
1899        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
1900        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
1901        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
1902        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
1903        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
1904        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
1905        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
1906        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
1907        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
1908        {0xaa, 0x30, 0x002d},
1909        {0xaa, 0x01, 0x0005},
1910        {0xaa, 0x11, 0x0001},
1911        {0xaa, 0x13, 0x0000},   /* {0xaa, 0x13, 0x0001}; */
1912        {0xaa, 0x14, 0x0001},
1913        {0xaa, 0x15, 0x00e6},
1914        {0xaa, 0x16, 0x0002},
1915        {0xaa, 0x17, 0x0086},
1916        {0xaa, 0x31, 0x0038},
1917        {0xaa, 0x32, 0x0038},
1918        {0xaa, 0x33, 0x0038},
1919        {0xaa, 0x5b, 0x0001},
1920        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
1921        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
1922        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
1923        {0xa0, 0x70, ZC3XX_R18D_YTARGET},
1924        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
1925        {0xa0, 0x00, 0x01ad},
1926        {0xa0, 0xc0, 0x019b},
1927        {0xa0, 0xa0, 0x019c},
1928        {0xa0, 0x02, ZC3XX_R188_MINGAIN},
1929        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
1930        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
1931        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
1932        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
1933        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
1934        {0xaa, 0x02, 0x0090},   /* {0xaa, 0x02, 0x0080}, */
1935        {}
1936};
1937static const struct usb_action hv7131b_50HZ[] = {       /* 640x480*/
1938        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1939        {0xaa, 0x25, 0x0007},                   /* 00,25,07,aa */
1940        {0xaa, 0x26, 0x0053},                   /* 00,26,53,aa */
1941        {0xaa, 0x27, 0x0000},                   /* 00,27,00,aa */
1942        {0xaa, 0x20, 0x0000},                   /* 00,20,00,aa */
1943        {0xaa, 0x21, 0x0050},                   /* 00,21,50,aa */
1944        {0xaa, 0x22, 0x001b},                   /* 00,22,1b,aa */
1945        {0xaa, 0x23, 0x00fc},                   /* 00,23,fc,aa */
1946        {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,2f,cc */
1947        {0xa0, 0x9b, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,9b,cc */
1948        {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,80,cc */
1949        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
1950        {0xa0, 0xea, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,ea,cc */
1951        {0xa0, 0x60, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,60,cc */
1952        {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},      /* 01,8c,0c,cc */
1953        {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},    /* 01,8f,18,cc */
1954        {0xa0, 0x18, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,18,cc */
1955        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
1956        {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},       /* 00,1d,00,cc */
1957        {0xa0, 0x50, ZC3XX_R01E_HSYNC_1},       /* 00,1e,50,cc */
1958        {0xa0, 0x1b, ZC3XX_R01F_HSYNC_2},       /* 00,1f,1b,cc */
1959        {0xa0, 0xfc, ZC3XX_R020_HSYNC_3},       /* 00,20,fc,cc */
1960        {}
1961};
1962static const struct usb_action hv7131b_50HZScale[] = {  /* 320x240 */
1963        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1964        {0xaa, 0x25, 0x0007},                   /* 00,25,07,aa */
1965        {0xaa, 0x26, 0x0053},                   /* 00,26,53,aa */
1966        {0xaa, 0x27, 0x0000},                   /* 00,27,00,aa */
1967        {0xaa, 0x20, 0x0000},                   /* 00,20,00,aa */
1968        {0xaa, 0x21, 0x0050},                   /* 00,21,50,aa */
1969        {0xaa, 0x22, 0x0012},                   /* 00,22,12,aa */
1970        {0xaa, 0x23, 0x0080},                   /* 00,23,80,aa */
1971        {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,2f,cc */
1972        {0xa0, 0x9b, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,9b,cc */
1973        {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,80,cc */
1974        {0xa0, 0x01, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,01,cc */
1975        {0xa0, 0xd4, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,d4,cc */
1976        {0xa0, 0xc0, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,c0,cc */
1977        {0xa0, 0x07, ZC3XX_R18C_AEFREEZE},      /* 01,8c,07,cc */
1978        {0xa0, 0x0f, ZC3XX_R18F_AEUNFREEZE},    /* 01,8f,0f,cc */
1979        {0xa0, 0x18, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,18,cc */
1980        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
1981        {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},       /* 00,1d,00,cc */
1982        {0xa0, 0x50, ZC3XX_R01E_HSYNC_1},       /* 00,1e,50,cc */
1983        {0xa0, 0x12, ZC3XX_R01F_HSYNC_2},       /* 00,1f,12,cc */
1984        {0xa0, 0x80, ZC3XX_R020_HSYNC_3},       /* 00,20,80,cc */
1985        {}
1986};
1987static const struct usb_action hv7131b_60HZ[] = {       /* 640x480*/
1988        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
1989        {0xaa, 0x25, 0x0007},                   /* 00,25,07,aa */
1990        {0xaa, 0x26, 0x00a1},                   /* 00,26,a1,aa */
1991        {0xaa, 0x27, 0x0020},                   /* 00,27,20,aa */
1992        {0xaa, 0x20, 0x0000},                   /* 00,20,00,aa */
1993        {0xaa, 0x21, 0x0040},                   /* 00,21,40,aa */
1994        {0xaa, 0x22, 0x0013},                   /* 00,22,13,aa */
1995        {0xaa, 0x23, 0x004c},                   /* 00,23,4c,aa */
1996        {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,2f,cc */
1997        {0xa0, 0x4d, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,4d,cc */
1998        {0xa0, 0x60, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,60,cc */
1999        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
2000        {0xa0, 0xc3, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,c3,cc */
2001        {0xa0, 0x50, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,50,cc */
2002        {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},      /* 01,8c,0c,cc */
2003        {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},    /* 01,8f,18,cc */
2004        {0xa0, 0x18, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,18,cc */
2005        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
2006        {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},       /* 00,1d,00,cc */
2007        {0xa0, 0x40, ZC3XX_R01E_HSYNC_1},       /* 00,1e,40,cc */
2008        {0xa0, 0x13, ZC3XX_R01F_HSYNC_2},       /* 00,1f,13,cc */
2009        {0xa0, 0x4c, ZC3XX_R020_HSYNC_3},       /* 00,20,4c,cc */
2010        {}
2011};
2012static const struct usb_action hv7131b_60HZScale[] = {  /* 320x240 */
2013        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2014        {0xaa, 0x25, 0x0007},                   /* 00,25,07,aa */
2015        {0xaa, 0x26, 0x00a1},                   /* 00,26,a1,aa */
2016        {0xaa, 0x27, 0x0020},                   /* 00,27,20,aa */
2017        {0xaa, 0x20, 0x0000},                   /* 00,20,00,aa */
2018        {0xaa, 0x21, 0x00a0},                   /* 00,21,a0,aa */
2019        {0xaa, 0x22, 0x0016},                   /* 00,22,16,aa */
2020        {0xaa, 0x23, 0x0040},                   /* 00,23,40,aa */
2021        {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,2f,cc */
2022        {0xa0, 0x4d, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,4d,cc */
2023        {0xa0, 0x60, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,60,cc */
2024        {0xa0, 0x01, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,01,cc */
2025        {0xa0, 0x86, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,86,cc */
2026        {0xa0, 0xa0, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,a0,cc */
2027        {0xa0, 0x07, ZC3XX_R18C_AEFREEZE},      /* 01,8c,07,cc */
2028        {0xa0, 0x0f, ZC3XX_R18F_AEUNFREEZE},    /* 01,8f,0f,cc */
2029        {0xa0, 0x18, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,18,cc */
2030        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
2031        {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},       /* 00,1d,00,cc */
2032        {0xa0, 0xa0, ZC3XX_R01E_HSYNC_1},       /* 00,1e,a0,cc */
2033        {0xa0, 0x16, ZC3XX_R01F_HSYNC_2},       /* 00,1f,16,cc */
2034        {0xa0, 0x40, ZC3XX_R020_HSYNC_3},       /* 00,20,40,cc */
2035        {}
2036};
2037static const struct usb_action hv7131b_NoFliker[] = {   /* 640x480*/
2038        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2039        {0xaa, 0x25, 0x0003},                   /* 00,25,03,aa */
2040        {0xaa, 0x26, 0x0000},                   /* 00,26,00,aa */
2041        {0xaa, 0x27, 0x0000},                   /* 00,27,00,aa */
2042        {0xaa, 0x20, 0x0000},                   /* 00,20,00,aa */
2043        {0xaa, 0x21, 0x0010},                   /* 00,21,10,aa */
2044        {0xaa, 0x22, 0x0000},                   /* 00,22,00,aa */
2045        {0xaa, 0x23, 0x0003},                   /* 00,23,03,aa */
2046        {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,2f,cc */
2047        {0xa0, 0xf8, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,f8,cc */
2048        {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,00,cc */
2049        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
2050        {0xa0, 0x02, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,02,cc */
2051        {0xa0, 0x00, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,00,cc */
2052        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},      /* 01,8c,10,cc */
2053        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},    /* 01,8f,20,cc */
2054        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,00,cc */
2055        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,00,cc */
2056        {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},       /* 00,1d,00,cc */
2057        {0xa0, 0x10, ZC3XX_R01E_HSYNC_1},       /* 00,1e,10,cc */
2058        {0xa0, 0x00, ZC3XX_R01F_HSYNC_2},       /* 00,1f,00,cc */
2059        {0xa0, 0x03, ZC3XX_R020_HSYNC_3},       /* 00,20,03,cc */
2060        {}
2061};
2062static const struct usb_action hv7131b_NoFlikerScale[] = { /* 320x240 */
2063        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2064        {0xaa, 0x25, 0x0003},                   /* 00,25,03,aa */
2065        {0xaa, 0x26, 0x0000},                   /* 00,26,00,aa */
2066        {0xaa, 0x27, 0x0000},                   /* 00,27,00,aa */
2067        {0xaa, 0x20, 0x0000},                   /* 00,20,00,aa */
2068        {0xaa, 0x21, 0x00a0},                   /* 00,21,a0,aa */
2069        {0xaa, 0x22, 0x0016},                   /* 00,22,16,aa */
2070        {0xaa, 0x23, 0x0040},                   /* 00,23,40,aa */
2071        {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,2f,cc */
2072        {0xa0, 0xf8, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,f8,cc */
2073        {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,00,cc */
2074        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
2075        {0xa0, 0x02, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,02,cc */
2076        {0xa0, 0x00, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,00,cc */
2077        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},      /* 01,8c,10,cc */
2078        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},    /* 01,8f,20,cc */
2079        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,00,cc */
2080        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,00,cc */
2081        {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},       /* 00,1d,00,cc */
2082        {0xa0, 0xa0, ZC3XX_R01E_HSYNC_1},       /* 00,1e,a0,cc */
2083        {0xa0, 0x16, ZC3XX_R01F_HSYNC_2},       /* 00,1f,16,cc */
2084        {0xa0, 0x40, ZC3XX_R020_HSYNC_3},       /* 00,20,40,cc */
2085        {}
2086};
2087
2088/* from lPEPI264v.inf (hv7131b!) */
2089static const struct usb_action hv7131r_InitialScale[] = {
2090        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
2091        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
2092        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},
2093        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
2094        {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
2095        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
2096        {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
2097        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
2098        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
2099        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
2100        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
2101        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
2102        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
2103        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
2104        {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
2105        {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
2106        {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
2107        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
2108        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
2109        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
2110        {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
2111        {0xdd, 0x00, 0x0200},
2112        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
2113        {0xaa, 0x01, 0x000c},
2114        {0xaa, 0x11, 0x0000},
2115        {0xaa, 0x13, 0x0000},
2116        {0xaa, 0x14, 0x0001},
2117        {0xaa, 0x15, 0x00e8},
2118        {0xaa, 0x16, 0x0002},
2119        {0xaa, 0x17, 0x0088},
2120        {0xaa, 0x30, 0x000b},
2121        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2122        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
2123        {0xa0, 0x78, ZC3XX_R18D_YTARGET},
2124        {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN},
2125        {0xa0, 0x00, 0x01ad},
2126        {0xa0, 0xc0, 0x019b},
2127        {0xa0, 0xa0, 0x019c},
2128        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
2129        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
2130        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
2131        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
2132        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
2133        {}
2134};
2135static const struct usb_action hv7131r_Initial[] = {
2136        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
2137        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
2138        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},
2139        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
2140        {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
2141        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
2142        {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
2143        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
2144        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
2145        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
2146        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
2147        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
2148        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
2149        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
2150        {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
2151        {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},
2152        {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
2153        {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},
2154        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
2155        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
2156        {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
2157        {0xdd, 0x00, 0x0200},
2158        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
2159        {0xaa, 0x01, 0x000c},
2160        {0xaa, 0x11, 0x0000},
2161        {0xaa, 0x13, 0x0000},
2162        {0xaa, 0x14, 0x0001},
2163        {0xaa, 0x15, 0x00e6},
2164        {0xaa, 0x16, 0x0002},
2165        {0xaa, 0x17, 0x0086},
2166        {0xaa, 0x30, 0x000b},
2167        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2168        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
2169        {0xa0, 0x78, ZC3XX_R18D_YTARGET},
2170        {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN},
2171        {0xa0, 0x00, 0x01ad},
2172        {0xa0, 0xc0, 0x019b},
2173        {0xa0, 0xa0, 0x019c},
2174        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
2175        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
2176        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
2177        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
2178        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
2179        {}
2180};
2181static const struct usb_action hv7131r_50HZ[] = {
2182        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2183        {0xa0, 0x06, ZC3XX_R190_EXPOSURELIMITHIGH},
2184        {0xa0, 0x68, ZC3XX_R191_EXPOSURELIMITMID},
2185        {0xa0, 0xa0, ZC3XX_R192_EXPOSURELIMITLOW},
2186        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2187        {0xa0, 0xea, ZC3XX_R196_ANTIFLICKERMID},
2188        {0xa0, 0x60, ZC3XX_R197_ANTIFLICKERLOW},
2189        {0xa0, 0x18, ZC3XX_R18C_AEFREEZE},
2190        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2191        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2192        {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
2193        {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},
2194        {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1},
2195        {0xa0, 0x00, ZC3XX_R01F_HSYNC_2},
2196        {0xa0, 0x08, ZC3XX_R020_HSYNC_3},
2197        {}
2198};
2199static const struct usb_action hv7131r_50HZScale[] = {
2200        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2201        {0xa0, 0x0c, ZC3XX_R190_EXPOSURELIMITHIGH},
2202        {0xa0, 0xd1, ZC3XX_R191_EXPOSURELIMITMID},
2203        {0xa0, 0x40, ZC3XX_R192_EXPOSURELIMITLOW},
2204        {0xa0, 0x01, ZC3XX_R195_ANTIFLICKERHIGH},
2205        {0xa0, 0xd4, ZC3XX_R196_ANTIFLICKERMID},
2206        {0xa0, 0xc0, ZC3XX_R197_ANTIFLICKERLOW},
2207        {0xa0, 0x18, ZC3XX_R18C_AEFREEZE},
2208        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2209        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2210        {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
2211        {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},
2212        {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1},
2213        {0xa0, 0x00, ZC3XX_R01F_HSYNC_2},
2214        {0xa0, 0x08, ZC3XX_R020_HSYNC_3},
2215        {}
2216};
2217static const struct usb_action hv7131r_60HZ[] = {
2218        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2219        {0xa0, 0x06, ZC3XX_R190_EXPOSURELIMITHIGH},
2220        {0xa0, 0x1a, ZC3XX_R191_EXPOSURELIMITMID},
2221        {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW},
2222        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2223        {0xa0, 0xc3, ZC3XX_R196_ANTIFLICKERMID},
2224        {0xa0, 0x50, ZC3XX_R197_ANTIFLICKERLOW},
2225        {0xa0, 0x18, ZC3XX_R18C_AEFREEZE},
2226        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2227        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2228        {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
2229        {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},
2230        {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1},
2231        {0xa0, 0x00, ZC3XX_R01F_HSYNC_2},
2232        {0xa0, 0x08, ZC3XX_R020_HSYNC_3},
2233        {}
2234};
2235static const struct usb_action hv7131r_60HZScale[] = {
2236        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2237        {0xa0, 0x0c, ZC3XX_R190_EXPOSURELIMITHIGH},
2238        {0xa0, 0x35, ZC3XX_R191_EXPOSURELIMITMID},
2239        {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
2240        {0xa0, 0x01, ZC3XX_R195_ANTIFLICKERHIGH},
2241        {0xa0, 0x86, ZC3XX_R196_ANTIFLICKERMID},
2242        {0xa0, 0xa0, ZC3XX_R197_ANTIFLICKERLOW},
2243        {0xa0, 0x18, ZC3XX_R18C_AEFREEZE},
2244        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2245        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2246        {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
2247        {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},
2248        {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1},
2249        {0xa0, 0x00, ZC3XX_R01F_HSYNC_2},
2250        {0xa0, 0x08, ZC3XX_R020_HSYNC_3},
2251        {}
2252};
2253static const struct usb_action hv7131r_NoFliker[] = {
2254        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2255        {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH},
2256        {0xa0, 0xf8, ZC3XX_R191_EXPOSURELIMITMID},
2257        {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
2258        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2259        {0xa0, 0x02, ZC3XX_R196_ANTIFLICKERMID},
2260        {0xa0, 0x58, ZC3XX_R197_ANTIFLICKERLOW},
2261        {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
2262        {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
2263        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
2264        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
2265        {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},
2266        {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1},
2267        {0xa0, 0x00, ZC3XX_R01F_HSYNC_2},
2268        {0xa0, 0x08, ZC3XX_R020_HSYNC_3},
2269        {}
2270};
2271static const struct usb_action hv7131r_NoFlikerScale[] = {
2272        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2273        {0xa0, 0x2f, ZC3XX_R190_EXPOSURELIMITHIGH},
2274        {0xa0, 0xf8, ZC3XX_R191_EXPOSURELIMITMID},
2275        {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
2276        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2277        {0xa0, 0x04, ZC3XX_R196_ANTIFLICKERMID},
2278        {0xa0, 0xb0, ZC3XX_R197_ANTIFLICKERLOW},
2279        {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
2280        {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
2281        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
2282        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
2283        {0xa0, 0x00, ZC3XX_R01D_HSYNC_0},
2284        {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1},
2285        {0xa0, 0x00, ZC3XX_R01F_HSYNC_2},
2286        {0xa0, 0x08, ZC3XX_R020_HSYNC_3},
2287        {}
2288};
2289
2290static const struct usb_action icm105a_InitialScale[] = {
2291        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
2292        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
2293        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
2294        {0xa0, 0x0c, ZC3XX_R010_CMOSSENSORSELECT},
2295        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
2296        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
2297        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
2298        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
2299        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
2300        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
2301        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
2302        {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR},
2303        {0xa0, 0x00, ZC3XX_R097_WINYSTARTHIGH},
2304        {0xa0, 0x01, ZC3XX_R098_WINYSTARTLOW},
2305        {0xa0, 0x00, ZC3XX_R099_WINXSTARTHIGH},
2306        {0xa0, 0x01, ZC3XX_R09A_WINXSTARTLOW},
2307        {0xa0, 0x01, ZC3XX_R11A_FIRSTYLOW},
2308        {0xa0, 0x01, ZC3XX_R11C_FIRSTXLOW},
2309        {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
2310        {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
2311        {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
2312        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
2313        {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
2314        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
2315        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
2316        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
2317        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
2318        {0xaa, 0x01, 0x0010},
2319        {0xaa, 0x03, 0x0000},
2320        {0xaa, 0x04, 0x0001},
2321        {0xaa, 0x05, 0x0020},
2322        {0xaa, 0x06, 0x0001},
2323        {0xaa, 0x08, 0x0000},
2324        {0xaa, 0x03, 0x0001},
2325        {0xaa, 0x04, 0x0011},
2326        {0xaa, 0x05, 0x00a0},
2327        {0xaa, 0x06, 0x0001},
2328        {0xaa, 0x08, 0x0000},
2329        {0xaa, 0x03, 0x0002},
2330        {0xaa, 0x04, 0x0013},
2331        {0xaa, 0x05, 0x0020},
2332        {0xaa, 0x06, 0x0001},
2333        {0xaa, 0x08, 0x0000},
2334        {0xaa, 0x03, 0x0003},
2335        {0xaa, 0x04, 0x0015},
2336        {0xaa, 0x05, 0x0020},
2337        {0xaa, 0x06, 0x0005},
2338        {0xaa, 0x08, 0x0000},
2339        {0xaa, 0x03, 0x0004},
2340        {0xaa, 0x04, 0x0017},
2341        {0xaa, 0x05, 0x0020},
2342        {0xaa, 0x06, 0x000d},
2343        {0xaa, 0x08, 0x0000},
2344        {0xaa, 0x03, 0x0005},
2345        {0xaa, 0x04, 0x0019},
2346        {0xaa, 0x05, 0x0020},
2347        {0xaa, 0x06, 0x0005},
2348        {0xaa, 0x08, 0x0000},
2349        {0xaa, 0x03, 0x0006},
2350        {0xaa, 0x04, 0x0017},
2351        {0xaa, 0x05, 0x0026},
2352        {0xaa, 0x06, 0x0005},
2353        {0xaa, 0x08, 0x0000},
2354        {0xaa, 0x03, 0x0007},
2355        {0xaa, 0x04, 0x0019},
2356        {0xaa, 0x05, 0x0022},
2357        {0xaa, 0x06, 0x0005},
2358        {0xaa, 0x08, 0x0000},
2359        {0xaa, 0x03, 0x0008},
2360        {0xaa, 0x04, 0x0021},
2361        {0xaa, 0x05, 0x00aa},
2362        {0xaa, 0x06, 0x0005},
2363        {0xaa, 0x08, 0x0000},
2364        {0xaa, 0x03, 0x0009},
2365        {0xaa, 0x04, 0x0023},
2366        {0xaa, 0x05, 0x00aa},
2367        {0xaa, 0x06, 0x000d},
2368        {0xaa, 0x08, 0x0000},
2369        {0xaa, 0x03, 0x000a},
2370        {0xaa, 0x04, 0x0025},
2371        {0xaa, 0x05, 0x00aa},
2372        {0xaa, 0x06, 0x0005},
2373        {0xaa, 0x08, 0x0000},
2374        {0xaa, 0x03, 0x000b},
2375        {0xaa, 0x04, 0x00ec},
2376        {0xaa, 0x05, 0x002e},
2377        {0xaa, 0x06, 0x0005},
2378        {0xaa, 0x08, 0x0000},
2379        {0xaa, 0x03, 0x000c},
2380        {0xaa, 0x04, 0x00fa},
2381        {0xaa, 0x05, 0x002a},
2382        {0xaa, 0x06, 0x0005},
2383        {0xaa, 0x08, 0x0000},
2384        {0xaa, 0x07, 0x000d},
2385        {0xaa, 0x01, 0x0005},
2386        {0xaa, 0x94, 0x0002},
2387        {0xaa, 0x90, 0x0000},
2388        {0xaa, 0x91, 0x001f},
2389        {0xaa, 0x10, 0x0064},
2390        {0xaa, 0x9b, 0x00f0},
2391        {0xaa, 0x9c, 0x0002},
2392        {0xaa, 0x14, 0x001a},
2393        {0xaa, 0x20, 0x0080},
2394        {0xaa, 0x22, 0x0080},
2395        {0xaa, 0x24, 0x0080},
2396        {0xaa, 0x26, 0x0080},
2397        {0xaa, 0x00, 0x0084},
2398        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
2399        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
2400        {0xaa, 0xa8, 0x00c0},
2401        {0xa1, 0x01, 0x0002},
2402        {0xa1, 0x01, 0x0008},
2403        {0xa1, 0x01, 0x0180},
2404        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
2405        {0xa0, 0x40, ZC3XX_R116_RGAIN},
2406        {0xa0, 0x40, ZC3XX_R117_GGAIN},
2407        {0xa0, 0x40, ZC3XX_R118_BGAIN},
2408        {0xa1, 0x01, 0x0008},
2409
2410        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* clock ? */
2411        {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},   /* sharpness+ */
2412        {0xa1, 0x01, 0x01c8},
2413        {0xa1, 0x01, 0x01c9},
2414        {0xa1, 0x01, 0x01ca},
2415        {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},   /* sharpness- */
2416        {0xa0, 0x52, ZC3XX_R10A_RGB00}, /* matrix */
2417        {0xa0, 0xf7, ZC3XX_R10B_RGB01},
2418        {0xa0, 0xf7, ZC3XX_R10C_RGB02},
2419        {0xa0, 0xf7, ZC3XX_R10D_RGB10},
2420        {0xa0, 0x52, ZC3XX_R10E_RGB11},
2421        {0xa0, 0xf7, ZC3XX_R10F_RGB12},
2422        {0xa0, 0xf7, ZC3XX_R110_RGB20},
2423        {0xa0, 0xf7, ZC3XX_R111_RGB21},
2424        {0xa0, 0x52, ZC3XX_R112_RGB22},
2425        {0xa1, 0x01, 0x0180},
2426        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
2427        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2428        {0xaa, 0x0d, 0x0003},
2429        {0xaa, 0x0c, 0x008c},
2430        {0xaa, 0x0e, 0x0095},
2431        {0xaa, 0x0f, 0x0002},
2432        {0xaa, 0x1c, 0x0094},
2433        {0xaa, 0x1d, 0x0002},
2434        {0xaa, 0x20, 0x0080},
2435        {0xaa, 0x22, 0x0080},
2436        {0xaa, 0x24, 0x0080},
2437        {0xaa, 0x26, 0x0080},
2438        {0xaa, 0x00, 0x0084},
2439        {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH},
2440        {0xa0, 0x94, ZC3XX_R0A4_EXPOSURETIMELOW},
2441        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
2442        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
2443        {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW},
2444        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2445        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
2446        {0xa0, 0x84, ZC3XX_R197_ANTIFLICKERLOW},
2447        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
2448        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2449        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2450        {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP},
2451        {0xa0, 0xe3, ZC3XX_R01D_HSYNC_0},
2452        {0xa0, 0xec, ZC3XX_R01E_HSYNC_1},
2453        {0xa0, 0xf5, ZC3XX_R01F_HSYNC_2},
2454        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
2455        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
2456        {0xa0, 0xc0, ZC3XX_R1A8_DIGITALGAIN},
2457        {0xa0, 0xc0, ZC3XX_R11D_GLOBALGAIN},
2458        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
2459        {0xa1, 0x01, 0x0180},
2460        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
2461        {0xa0, 0x40, ZC3XX_R116_RGAIN},
2462        {0xa0, 0x40, ZC3XX_R117_GGAIN},
2463        {0xa0, 0x40, ZC3XX_R118_BGAIN},
2464        {}
2465};
2466
2467static const struct usb_action icm105a_Initial[] = {
2468        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
2469        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
2470        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
2471        {0xa0, 0x0c, ZC3XX_R010_CMOSSENSORSELECT},
2472        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
2473        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
2474        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
2475        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
2476        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
2477        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
2478        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
2479        {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR},
2480        {0xa0, 0x00, ZC3XX_R097_WINYSTARTHIGH},
2481        {0xa0, 0x02, ZC3XX_R098_WINYSTARTLOW},
2482        {0xa0, 0x00, ZC3XX_R099_WINXSTARTHIGH},
2483        {0xa0, 0x02, ZC3XX_R09A_WINXSTARTLOW},
2484        {0xa0, 0x02, ZC3XX_R11A_FIRSTYLOW},
2485        {0xa0, 0x02, ZC3XX_R11C_FIRSTXLOW},
2486        {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},
2487        {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},
2488        {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
2489        {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},
2490        {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
2491        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
2492        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
2493        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
2494        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
2495        {0xaa, 0x01, 0x0010},
2496        {0xaa, 0x03, 0x0000},
2497        {0xaa, 0x04, 0x0001},
2498        {0xaa, 0x05, 0x0020},
2499        {0xaa, 0x06, 0x0001},
2500        {0xaa, 0x08, 0x0000},
2501        {0xaa, 0x03, 0x0001},
2502        {0xaa, 0x04, 0x0011},
2503        {0xaa, 0x05, 0x00a0},
2504        {0xaa, 0x06, 0x0001},
2505        {0xaa, 0x08, 0x0000},
2506        {0xaa, 0x03, 0x0002},
2507        {0xaa, 0x04, 0x0013},
2508        {0xaa, 0x05, 0x0020},
2509        {0xaa, 0x06, 0x0001},
2510        {0xaa, 0x08, 0x0000},
2511        {0xaa, 0x03, 0x0003},
2512        {0xaa, 0x04, 0x0015},
2513        {0xaa, 0x05, 0x0020},
2514        {0xaa, 0x06, 0x0005},
2515        {0xaa, 0x08, 0x0000},
2516        {0xaa, 0x03, 0x0004},
2517        {0xaa, 0x04, 0x0017},
2518        {0xaa, 0x05, 0x0020},
2519        {0xaa, 0x06, 0x000d},
2520        {0xaa, 0x08, 0x0000},
2521        {0xaa, 0x03, 0x0005},
2522        {0xa0, 0x04, ZC3XX_R092_I2CADDRESSSELECT},
2523        {0xa0, 0x19, ZC3XX_R093_I2CSETVALUE},
2524        {0xa0, 0x01, ZC3XX_R090_I2CCOMMAND},
2525        {0xa1, 0x01, 0x0091},
2526        {0xaa, 0x05, 0x0020},
2527        {0xaa, 0x06, 0x0005},
2528        {0xaa, 0x08, 0x0000},
2529        {0xaa, 0x03, 0x0006},
2530        {0xaa, 0x04, 0x0017},
2531        {0xaa, 0x05, 0x0026},
2532        {0xaa, 0x06, 0x0005},
2533        {0xaa, 0x08, 0x0000},
2534        {0xaa, 0x03, 0x0007},
2535        {0xaa, 0x04, 0x0019},
2536        {0xaa, 0x05, 0x0022},
2537        {0xaa, 0x06, 0x0005},
2538        {0xaa, 0x08, 0x0000},
2539        {0xaa, 0x03, 0x0008},
2540        {0xaa, 0x04, 0x0021},
2541        {0xaa, 0x05, 0x00aa},
2542        {0xaa, 0x06, 0x0005},
2543        {0xaa, 0x08, 0x0000},
2544        {0xaa, 0x03, 0x0009},
2545        {0xaa, 0x04, 0x0023},
2546        {0xaa, 0x05, 0x00aa},
2547        {0xaa, 0x06, 0x000d},
2548        {0xaa, 0x08, 0x0000},
2549        {0xaa, 0x03, 0x000a},
2550        {0xaa, 0x04, 0x0025},
2551        {0xaa, 0x05, 0x00aa},
2552        {0xaa, 0x06, 0x0005},
2553        {0xaa, 0x08, 0x0000},
2554        {0xaa, 0x03, 0x000b},
2555        {0xaa, 0x04, 0x00ec},
2556        {0xaa, 0x05, 0x002e},
2557        {0xaa, 0x06, 0x0005},
2558        {0xaa, 0x08, 0x0000},
2559        {0xaa, 0x03, 0x000c},
2560        {0xaa, 0x04, 0x00fa},
2561        {0xaa, 0x05, 0x002a},
2562        {0xaa, 0x06, 0x0005},
2563        {0xaa, 0x08, 0x0000},
2564        {0xaa, 0x07, 0x000d},
2565        {0xaa, 0x01, 0x0005},
2566        {0xaa, 0x94, 0x0002},
2567        {0xaa, 0x90, 0x0000},
2568        {0xaa, 0x91, 0x0010},
2569        {0xaa, 0x10, 0x0064},
2570        {0xaa, 0x9b, 0x00f0},
2571        {0xaa, 0x9c, 0x0002},
2572        {0xaa, 0x14, 0x001a},
2573        {0xaa, 0x20, 0x0080},
2574        {0xaa, 0x22, 0x0080},
2575        {0xaa, 0x24, 0x0080},
2576        {0xaa, 0x26, 0x0080},
2577        {0xaa, 0x00, 0x0084},
2578        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
2579        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
2580        {0xaa, 0xa8, 0x0080},
2581        {0xa0, 0x78, ZC3XX_R18D_YTARGET},
2582        {0xa1, 0x01, 0x0002},
2583        {0xa1, 0x01, 0x0008},
2584        {0xa1, 0x01, 0x0180},
2585        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
2586        {0xa0, 0x40, ZC3XX_R116_RGAIN},
2587        {0xa0, 0x40, ZC3XX_R117_GGAIN},
2588        {0xa0, 0x40, ZC3XX_R118_BGAIN},
2589        {0xa1, 0x01, 0x0008},
2590
2591        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* clock ? */
2592        {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},   /* sharpness+ */
2593        {0xa1, 0x01, 0x01c8},
2594        {0xa1, 0x01, 0x01c9},
2595        {0xa1, 0x01, 0x01ca},
2596        {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},   /* sharpness- */
2597
2598        {0xa0, 0x52, ZC3XX_R10A_RGB00}, /* matrix */
2599        {0xa0, 0xf7, ZC3XX_R10B_RGB01},
2600        {0xa0, 0xf7, ZC3XX_R10C_RGB02},
2601        {0xa0, 0xf7, ZC3XX_R10D_RGB10},
2602        {0xa0, 0x52, ZC3XX_R10E_RGB11},
2603        {0xa0, 0xf7, ZC3XX_R10F_RGB12},
2604        {0xa0, 0xf7, ZC3XX_R110_RGB20},
2605        {0xa0, 0xf7, ZC3XX_R111_RGB21},
2606        {0xa0, 0x52, ZC3XX_R112_RGB22},
2607        {0xa1, 0x01, 0x0180},
2608        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
2609        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
2610        {0xaa, 0x0d, 0x0003},
2611        {0xaa, 0x0c, 0x0020},
2612        {0xaa, 0x0e, 0x000e},
2613        {0xaa, 0x0f, 0x0002},
2614        {0xaa, 0x1c, 0x000d},
2615        {0xaa, 0x1d, 0x0002},
2616        {0xaa, 0x20, 0x0080},
2617        {0xaa, 0x22, 0x0080},
2618        {0xaa, 0x24, 0x0080},
2619        {0xaa, 0x26, 0x0080},
2620        {0xaa, 0x00, 0x0084},
2621        {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH},
2622        {0xa0, 0x0d, ZC3XX_R0A4_EXPOSURETIMELOW},
2623        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
2624        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
2625        {0xa0, 0x1a, ZC3XX_R192_EXPOSURELIMITLOW},
2626        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
2627        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
2628        {0xa0, 0x4b, ZC3XX_R197_ANTIFLICKERLOW},
2629        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
2630        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
2631        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
2632        {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP},
2633        {0xa0, 0xc8, ZC3XX_R01D_HSYNC_0},
2634        {0xa0, 0xd8, ZC3XX_R01E_HSYNC_1},
2635        {0xa0, 0xea, ZC3XX_R01F_HSYNC_2},
2636        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
2637        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN},
2638        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
2639        {0xa1, 0x01, 0x0180},
2640        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
2641        {0xa0, 0x40, ZC3XX_R116_RGAIN},
2642        {0xa0, 0x40, ZC3XX_R117_GGAIN},
2643        {0xa0, 0x40, ZC3XX_R118_BGAIN},
2644        {}
2645};
2646static const struct usb_action icm105a_50HZScale[] = {
2647        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2648        {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2649        {0xaa, 0x0c, 0x0020}, /* 00,0c,20,aa */
2650        {0xaa, 0x0e, 0x000e}, /* 00,0e,0e,aa */
2651        {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2652        {0xaa, 0x1c, 0x000d}, /* 00,1c,0d,aa */
2653        {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2654        {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2655        {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2656        {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2657        {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2658        {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
2659        {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2660        {0xa0, 0x0d, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,0d,cc */
2661        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2662        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2663        {0xa0, 0x1a, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,1a,cc */
2664        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2665        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2666        {0xa0, 0x4b, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,4b,cc */
2667        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2668        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2669        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
2670        {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,12,cc */
2671        {0xa0, 0xc8, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c8,cc */
2672        {0xa0, 0xd8, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d8,cc */
2673        {0xa0, 0xea, ZC3XX_R01F_HSYNC_2}, /* 00,1f,ea,cc */
2674        {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2675        {}
2676};
2677static const struct usb_action icm105a_50HZ[] = {
2678        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2679        {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2680        {0xaa, 0x0c, 0x008c}, /* 00,0c,8c,aa */
2681        {0xaa, 0x0e, 0x0095}, /* 00,0e,95,aa */
2682        {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2683        {0xaa, 0x1c, 0x0094}, /* 00,1c,94,aa */
2684        {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2685        {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2686        {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2687        {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2688        {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2689        {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
2690        {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2691        {0xa0, 0x94, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,94,cc */
2692        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2693        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2694        {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,20,cc */
2695        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2696        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2697        {0xa0, 0x84, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,84,cc */
2698        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2699        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2700        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
2701        {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,12,cc */
2702        {0xa0, 0xe3, ZC3XX_R01D_HSYNC_0}, /* 00,1d,e3,cc */
2703        {0xa0, 0xec, ZC3XX_R01E_HSYNC_1}, /* 00,1e,ec,cc */
2704        {0xa0, 0xf5, ZC3XX_R01F_HSYNC_2}, /* 00,1f,f5,cc */
2705        {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2706        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN}, /* 01,a7,00,cc */
2707        {0xa0, 0xc0, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,c0,cc */
2708        {}
2709};
2710static const struct usb_action icm105a_60HZScale[] = {
2711        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2712        {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2713        {0xaa, 0x0c, 0x0004}, /* 00,0c,04,aa */
2714        {0xaa, 0x0e, 0x000d}, /* 00,0e,0d,aa */
2715        {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2716        {0xaa, 0x1c, 0x0008}, /* 00,1c,08,aa */
2717        {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2718        {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2719        {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2720        {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2721        {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2722        {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
2723        {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2724        {0xa0, 0x08, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,08,cc */
2725        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2726        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2727        {0xa0, 0x10, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,10,cc */
2728        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2729        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2730        {0xa0, 0x41, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,41,cc */
2731        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2732        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2733        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
2734        {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,12,cc */
2735        {0xa0, 0xc1, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c1,cc */
2736        {0xa0, 0xd4, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d4,cc */
2737        {0xa0, 0xe8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e8,cc */
2738        {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2739        {}
2740};
2741static const struct usb_action icm105a_60HZ[] = {
2742        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2743        {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2744        {0xaa, 0x0c, 0x0008}, /* 00,0c,08,aa */
2745        {0xaa, 0x0e, 0x0086}, /* 00,0e,86,aa */
2746        {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2747        {0xaa, 0x1c, 0x0085}, /* 00,1c,85,aa */
2748        {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2749        {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2750        {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2751        {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2752        {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2753        {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
2754        {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2755        {0xa0, 0x85, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,85,cc */
2756        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2757        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2758        {0xa0, 0x08, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,08,cc */
2759        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2760        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2761        {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,81,cc */
2762        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2763        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2764        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
2765        {0xa0, 0x12, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,12,cc */
2766        {0xa0, 0xc2, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c2,cc */
2767        {0xa0, 0xd6, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d6,cc */
2768        {0xa0, 0xea, ZC3XX_R01F_HSYNC_2}, /* 00,1f,ea,cc */
2769        {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2770        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN}, /* 01,a7,00,cc */
2771        {0xa0, 0xc0, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,c0,cc */
2772        {}
2773};
2774static const struct usb_action icm105a_NoFlikerScale[] = {
2775        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2776        {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2777        {0xaa, 0x0c, 0x0004}, /* 00,0c,04,aa */
2778        {0xaa, 0x0e, 0x000d}, /* 00,0e,0d,aa */
2779        {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2780        {0xaa, 0x1c, 0x0000}, /* 00,1c,00,aa */
2781        {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2782        {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2783        {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2784        {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2785        {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2786        {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
2787        {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2788        {0xa0, 0x00, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,00,cc */
2789        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2790        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2791        {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,20,cc */
2792        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2793        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2794        {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
2795        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2796        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2797        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
2798        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
2799        {0xa0, 0xc1, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c1,cc */
2800        {0xa0, 0xd4, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d4,cc */
2801        {0xa0, 0xe8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e8,cc */
2802        {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2803        {}
2804};
2805static const struct usb_action icm105a_NoFliker[] = {
2806        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2807        {0xaa, 0x0d, 0x0003}, /* 00,0d,03,aa */
2808        {0xaa, 0x0c, 0x0004}, /* 00,0c,04,aa */
2809        {0xaa, 0x0e, 0x0081}, /* 00,0e,81,aa */
2810        {0xaa, 0x0f, 0x0002}, /* 00,0f,02,aa */
2811        {0xaa, 0x1c, 0x0080}, /* 00,1c,80,aa */
2812        {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
2813        {0xaa, 0x20, 0x0080}, /* 00,20,80,aa */
2814        {0xaa, 0x22, 0x0080}, /* 00,22,80,aa */
2815        {0xaa, 0x24, 0x0080}, /* 00,24,80,aa */
2816        {0xaa, 0x26, 0x0080}, /* 00,26,80,aa */
2817        {0xaa, 0x00, 0x0084}, /* 00,00,84,aa */
2818        {0xa0, 0x02, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,02,cc */
2819        {0xa0, 0x80, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,80,cc */
2820        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
2821        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
2822        {0xa0, 0x20, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,20,cc */
2823        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
2824        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
2825        {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
2826        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE}, /* 01,8c,10,cc */
2827        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,20,cc */
2828        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
2829        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
2830        {0xa0, 0xc1, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c1,cc */
2831        {0xa0, 0xd4, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d4,cc */
2832        {0xa0, 0xe8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e8,cc */
2833        {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
2834        {0xa0, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN}, /* 01,a7,00,cc */
2835        {0xa0, 0xc0, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,c0,cc */
2836        {}
2837};
2838
2839static const struct usb_action mc501cb_Initial[] = {
2840        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
2841        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT}, /* 00,02,00,cc */
2842        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
2843        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
2844        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
2845        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
2846        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
2847        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
2848        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
2849        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
2850        {0xa0, 0xd8, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d8,cc */
2851        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
2852        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
2853        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
2854        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
2855        {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH}, /* 00,9b,01,cc */
2856        {0xa0, 0xde, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,de,cc */
2857        {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH}, /* 00,9d,02,cc */
2858        {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
2859        {0xa0, 0x33, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,33,cc */
2860        {0xa0, 0x34, ZC3XX_R087_EXPTIMEMID}, /* 00,87,34,cc */
2861        {0xa0, 0x35, ZC3XX_R088_EXPTIMELOW}, /* 00,88,35,cc */
2862        {0xa0, 0xb0, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,b0,cc */
2863        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
2864        {0xaa, 0x01, 0x0001}, /* 00,01,01,aa */
2865        {0xaa, 0x01, 0x0003}, /* 00,01,03,aa */
2866        {0xaa, 0x01, 0x0001}, /* 00,01,01,aa */
2867        {0xaa, 0x03, 0x0000}, /* 00,03,00,aa */
2868        {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
2869        {0xaa, 0x11, 0x0080}, /* 00,11,80,aa */
2870        {0xaa, 0x12, 0x0000}, /* 00,12,00,aa */
2871        {0xaa, 0x13, 0x0000}, /* 00,13,00,aa */
2872        {0xaa, 0x14, 0x0000}, /* 00,14,00,aa */
2873        {0xaa, 0x15, 0x0000}, /* 00,15,00,aa */
2874        {0xaa, 0x16, 0x0000}, /* 00,16,00,aa */
2875        {0xaa, 0x17, 0x0001}, /* 00,17,01,aa */
2876        {0xaa, 0x18, 0x00de}, /* 00,18,de,aa */
2877        {0xaa, 0x19, 0x0002}, /* 00,19,02,aa */
2878        {0xaa, 0x1a, 0x0086}, /* 00,1a,86,aa */
2879        {0xaa, 0x20, 0x00a8}, /* 00,20,a8,aa */
2880        {0xaa, 0x22, 0x0000}, /* 00,22,00,aa */
2881        {0xaa, 0x23, 0x0000}, /* 00,23,00,aa */
2882        {0xaa, 0x24, 0x0000}, /* 00,24,00,aa */
2883        {0xaa, 0x40, 0x0033}, /* 00,40,33,aa */
2884        {0xaa, 0x41, 0x0077}, /* 00,41,77,aa */
2885        {0xaa, 0x42, 0x0053}, /* 00,42,53,aa */
2886        {0xaa, 0x43, 0x00b0}, /* 00,43,b0,aa */
2887        {0xaa, 0x4b, 0x0001}, /* 00,4b,01,aa */
2888        {0xaa, 0x72, 0x0020}, /* 00,72,20,aa */
2889        {0xaa, 0x73, 0x0000}, /* 00,73,00,aa */
2890        {0xaa, 0x80, 0x0000}, /* 00,80,00,aa */
2891        {0xaa, 0x85, 0x0050}, /* 00,85,50,aa */
2892        {0xaa, 0x91, 0x0070}, /* 00,91,70,aa */
2893        {0xaa, 0x92, 0x0072}, /* 00,92,72,aa */
2894        {0xaa, 0x03, 0x0001}, /* 00,03,01,aa */
2895        {0xaa, 0x10, 0x00a0}, /* 00,10,a0,aa */
2896        {0xaa, 0x11, 0x0001}, /* 00,11,01,aa */
2897        {0xaa, 0x30, 0x0000}, /* 00,30,00,aa */
2898        {0xaa, 0x60, 0x0000}, /* 00,60,00,aa */
2899        {0xaa, 0xa0, 0x001a}, /* 00,a0,1a,aa */
2900        {0xaa, 0xa1, 0x0000}, /* 00,a1,00,aa */
2901        {0xaa, 0xa2, 0x003f}, /* 00,a2,3f,aa */
2902        {0xaa, 0xa3, 0x0028}, /* 00,a3,28,aa */
2903        {0xaa, 0xa4, 0x0010}, /* 00,a4,10,aa */
2904        {0xaa, 0xa5, 0x0020}, /* 00,a5,20,aa */
2905        {0xaa, 0xb1, 0x0044}, /* 00,b1,44,aa */
2906        {0xaa, 0xd0, 0x0001}, /* 00,d0,01,aa */
2907        {0xaa, 0xd1, 0x0085}, /* 00,d1,85,aa */
2908        {0xaa, 0xd2, 0x0080}, /* 00,d2,80,aa */
2909        {0xaa, 0xd3, 0x0080}, /* 00,d3,80,aa */
2910        {0xaa, 0xd4, 0x0080}, /* 00,d4,80,aa */
2911        {0xaa, 0xd5, 0x0080}, /* 00,d5,80,aa */
2912        {0xaa, 0xc0, 0x00c3}, /* 00,c0,c3,aa */
2913        {0xaa, 0xc2, 0x0044}, /* 00,c2,44,aa */
2914        {0xaa, 0xc4, 0x0040}, /* 00,c4,40,aa */
2915        {0xaa, 0xc5, 0x0020}, /* 00,c5,20,aa */
2916        {0xaa, 0xc6, 0x0008}, /* 00,c6,08,aa */
2917        {0xaa, 0x03, 0x0004}, /* 00,03,04,aa */
2918        {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
2919        {0xaa, 0x40, 0x0030}, /* 00,40,30,aa */
2920        {0xaa, 0x41, 0x0020}, /* 00,41,20,aa */
2921        {0xaa, 0x42, 0x002d}, /* 00,42,2d,aa */
2922        {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2923        {0xaa, 0x1c, 0x0050}, /* 00,1C,50,aa */
2924        {0xaa, 0x11, 0x0081}, /* 00,11,81,aa */
2925        {0xaa, 0x3b, 0x001d}, /* 00,3b,1D,aa */
2926        {0xaa, 0x3c, 0x004c}, /* 00,3c,4C,aa */
2927        {0xaa, 0x3d, 0x0018}, /* 00,3d,18,aa */
2928        {0xaa, 0x3e, 0x006a}, /* 00,3e,6A,aa */
2929        {0xaa, 0x01, 0x0000}, /* 00,01,00,aa */
2930        {0xaa, 0x52, 0x00ff}, /* 00,52,FF,aa */
2931        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
2932        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
2933        {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,37,cc */
2934        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
2935        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
2936        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
2937        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
2938        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
2939        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
2940        {0xaa, 0x03, 0x0002}, /* 00,03,02,aa */
2941        {0xaa, 0x51, 0x0027}, /* 00,51,27,aa */
2942        {0xaa, 0x52, 0x0020}, /* 00,52,20,aa */
2943        {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2944        {0xaa, 0x50, 0x0010}, /* 00,50,10,aa */
2945        {0xaa, 0x51, 0x0010}, /* 00,51,10,aa */
2946        {0xaa, 0x54, 0x0010}, /* 00,54,10,aa */
2947        {0xaa, 0x55, 0x0010}, /* 00,55,10,aa */
2948        {0xa0, 0xf0, 0x0199}, /* 01,99,F0,cc */
2949        {0xa0, 0x80, 0x019a}, /* 01,9A,80,cc */
2950
2951        {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
2952        {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
2953        {0xaa, 0x36, 0x001d}, /* 00,36,1D,aa */
2954        {0xaa, 0x37, 0x004c}, /* 00,37,4C,aa */
2955        {0xaa, 0x3b, 0x001d}, /* 00,3B,1D,aa */
2956        {}
2957};
2958
2959static const struct usb_action mc501cb_InitialScale[] = {       /* 320x240 */
2960        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
2961        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT}, /* 00,02,10,cc */
2962        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
2963        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
2964        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
2965        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
2966        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
2967        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
2968        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
2969        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
2970        {0xa0, 0xd0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d0,cc */
2971        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
2972        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
2973        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
2974        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
2975        {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH}, /* 00,9b,01,cc */
2976        {0xa0, 0xd8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,d8,cc */
2977        {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH}, /* 00,9d,02,cc */
2978        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
2979        {0xa0, 0x33, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,33,cc */
2980        {0xa0, 0x34, ZC3XX_R087_EXPTIMEMID}, /* 00,87,34,cc */
2981        {0xa0, 0x35, ZC3XX_R088_EXPTIMELOW}, /* 00,88,35,cc */
2982        {0xa0, 0xb0, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,b0,cc */
2983        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
2984        {0xaa, 0x01, 0x0001}, /* 00,01,01,aa */
2985        {0xaa, 0x01, 0x0003}, /* 00,01,03,aa */
2986        {0xaa, 0x01, 0x0001}, /* 00,01,01,aa */
2987        {0xaa, 0x03, 0x0000}, /* 00,03,00,aa */
2988        {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
2989        {0xaa, 0x11, 0x0080}, /* 00,11,80,aa */
2990        {0xaa, 0x12, 0x0000}, /* 00,12,00,aa */
2991        {0xaa, 0x13, 0x0000}, /* 00,13,00,aa */
2992        {0xaa, 0x14, 0x0000}, /* 00,14,00,aa */
2993        {0xaa, 0x15, 0x0000}, /* 00,15,00,aa */
2994        {0xaa, 0x16, 0x0000}, /* 00,16,00,aa */
2995        {0xaa, 0x17, 0x0001}, /* 00,17,01,aa */
2996        {0xaa, 0x18, 0x00d8}, /* 00,18,d8,aa */
2997        {0xaa, 0x19, 0x0002}, /* 00,19,02,aa */
2998        {0xaa, 0x1a, 0x0088}, /* 00,1a,88,aa */
2999        {0xaa, 0x20, 0x00a8}, /* 00,20,a8,aa */
3000        {0xaa, 0x22, 0x0000}, /* 00,22,00,aa */
3001        {0xaa, 0x23, 0x0000}, /* 00,23,00,aa */
3002        {0xaa, 0x24, 0x0000}, /* 00,24,00,aa */
3003        {0xaa, 0x40, 0x0033}, /* 00,40,33,aa */
3004        {0xaa, 0x41, 0x0077}, /* 00,41,77,aa */
3005        {0xaa, 0x42, 0x0053}, /* 00,42,53,aa */
3006        {0xaa, 0x43, 0x00b0}, /* 00,43,b0,aa */
3007        {0xaa, 0x4b, 0x0001}, /* 00,4b,01,aa */
3008        {0xaa, 0x72, 0x0020}, /* 00,72,20,aa */
3009        {0xaa, 0x73, 0x0000}, /* 00,73,00,aa */
3010        {0xaa, 0x80, 0x0000}, /* 00,80,00,aa */
3011        {0xaa, 0x85, 0x0050}, /* 00,85,50,aa */
3012        {0xaa, 0x91, 0x0070}, /* 00,91,70,aa */
3013        {0xaa, 0x92, 0x0072}, /* 00,92,72,aa */
3014        {0xaa, 0x03, 0x0001}, /* 00,03,01,aa */
3015        {0xaa, 0x10, 0x00a0}, /* 00,10,a0,aa */
3016        {0xaa, 0x11, 0x0001}, /* 00,11,01,aa */
3017        {0xaa, 0x30, 0x0000}, /* 00,30,00,aa */
3018        {0xaa, 0x60, 0x0000}, /* 00,60,00,aa */
3019        {0xaa, 0xa0, 0x001a}, /* 00,a0,1a,aa */
3020        {0xaa, 0xa1, 0x0000}, /* 00,a1,00,aa */
3021        {0xaa, 0xa2, 0x003f}, /* 00,a2,3f,aa */
3022        {0xaa, 0xa3, 0x0028}, /* 00,a3,28,aa */
3023        {0xaa, 0xa4, 0x0010}, /* 00,a4,10,aa */
3024        {0xaa, 0xa5, 0x0020}, /* 00,a5,20,aa */
3025        {0xaa, 0xb1, 0x0044}, /* 00,b1,44,aa */
3026        {0xaa, 0xd0, 0x0001}, /* 00,d0,01,aa */
3027        {0xaa, 0xd1, 0x0085}, /* 00,d1,85,aa */
3028        {0xaa, 0xd2, 0x0080}, /* 00,d2,80,aa */
3029        {0xaa, 0xd3, 0x0080}, /* 00,d3,80,aa */
3030        {0xaa, 0xd4, 0x0080}, /* 00,d4,80,aa */
3031        {0xaa, 0xd5, 0x0080}, /* 00,d5,80,aa */
3032        {0xaa, 0xc0, 0x00c3}, /* 00,c0,c3,aa */
3033        {0xaa, 0xc2, 0x0044}, /* 00,c2,44,aa */
3034        {0xaa, 0xc4, 0x0040}, /* 00,c4,40,aa */
3035        {0xaa, 0xc5, 0x0020}, /* 00,c5,20,aa */
3036        {0xaa, 0xc6, 0x0008}, /* 00,c6,08,aa */
3037        {0xaa, 0x03, 0x0004}, /* 00,03,04,aa */
3038        {0xaa, 0x10, 0x0000}, /* 00,10,00,aa */
3039        {0xaa, 0x40, 0x0030}, /* 00,40,30,aa */
3040        {0xaa, 0x41, 0x0020}, /* 00,41,20,aa */
3041        {0xaa, 0x42, 0x002d}, /* 00,42,2d,aa */
3042        {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3043        {0xaa, 0x1c, 0x0050}, /* 00,1c,50,aa */
3044        {0xaa, 0x11, 0x0081}, /* 00,11,81,aa */
3045        {0xaa, 0x3b, 0x003a}, /* 00,3b,3A,aa */
3046        {0xaa, 0x3c, 0x0098}, /* 00,3c,98,aa */
3047        {0xaa, 0x3d, 0x0030}, /* 00,3d,30,aa */
3048        {0xaa, 0x3e, 0x00d4}, /* 00,3E,D4,aa */
3049        {0xaa, 0x01, 0x0000}, /* 00,01,00,aa */
3050        {0xaa, 0x52, 0x00ff}, /* 00,52,FF,aa */
3051        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
3052        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
3053        {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,37,cc */
3054        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
3055        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
3056        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
3057        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
3058        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
3059        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
3060        {0xaa, 0x03, 0x0002}, /* 00,03,02,aa */
3061        {0xaa, 0x51, 0x004e}, /* 00,51,4E,aa */
3062        {0xaa, 0x52, 0x0041}, /* 00,52,41,aa */
3063        {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3064        {0xaa, 0x50, 0x0010}, /* 00,50,10,aa */
3065        {0xaa, 0x51, 0x0010}, /* 00,51,10,aa */
3066        {0xaa, 0x54, 0x0010}, /* 00,54,10,aa */
3067        {0xaa, 0x55, 0x0010}, /* 00,55,10,aa */
3068        {0xa0, 0xf0, 0x0199}, /* 01,99,F0,cc */
3069        {0xa0, 0x80, 0x019a}, /* 01,9A,80,cc */
3070        {}
3071};
3072
3073static const struct usb_action mc501cb_50HZ[] = {
3074        {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3075        {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3076        {0xaa, 0x36, 0x001d}, /* 00,36,1D,aa */
3077        {0xaa, 0x37, 0x004c}, /* 00,37,4C,aa */
3078        {0xaa, 0x3b, 0x001d}, /* 00,3B,1D,aa */
3079        {0xaa, 0x3c, 0x004c}, /* 00,3C,4C,aa */
3080        {0xaa, 0x3d, 0x001d}, /* 00,3D,1D,aa */
3081        {0xaa, 0x3e, 0x004c}, /* 00,3E,4C,aa */
3082        {}
3083};
3084
3085static const struct usb_action mc501cb_50HZScale[] = {
3086        {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3087        {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3088        {0xaa, 0x36, 0x003a}, /* 00,36,3A,aa */
3089        {0xaa, 0x37, 0x0098}, /* 00,37,98,aa */
3090        {0xaa, 0x3b, 0x003a}, /* 00,3B,3A,aa */
3091        {0xaa, 0x3c, 0x0098}, /* 00,3C,98,aa */
3092        {0xaa, 0x3d, 0x003a}, /* 00,3D,3A,aa */
3093        {0xaa, 0x3e, 0x0098}, /* 00,3E,98,aa */
3094        {}
3095};
3096
3097static const struct usb_action mc501cb_60HZ[] = {
3098        {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3099        {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3100        {0xaa, 0x36, 0x0018}, /* 00,36,18,aa */
3101        {0xaa, 0x37, 0x006a}, /* 00,37,6A,aa */
3102        {0xaa, 0x3d, 0x0018}, /* 00,3D,18,aa */
3103        {0xaa, 0x3e, 0x006a}, /* 00,3E,6A,aa */
3104        {0xaa, 0x3b, 0x0018}, /* 00,3B,18,aa */
3105        {0xaa, 0x3c, 0x006a}, /* 00,3C,6A,aa */
3106        {}
3107};
3108
3109static const struct usb_action mc501cb_60HZScale[] = {
3110        {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3111        {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3112        {0xaa, 0x36, 0x0030}, /* 00,36,30,aa */
3113        {0xaa, 0x37, 0x00d4}, /* 00,37,D4,aa */
3114        {0xaa, 0x3d, 0x0030}, /* 00,3D,30,aa */
3115        {0xaa, 0x3e, 0x00d4}, /* 00,3E,D4,aa */
3116        {0xaa, 0x3b, 0x0030}, /* 00,3B,30,aa */
3117        {0xaa, 0x3c, 0x00d4}, /* 00,3C,D4,aa */
3118        {}
3119};
3120
3121static const struct usb_action mc501cb_NoFliker[] = {
3122        {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3123        {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3124        {0xaa, 0x36, 0x0018}, /* 00,36,18,aa */
3125        {0xaa, 0x37, 0x006a}, /* 00,37,6A,aa */
3126        {0xaa, 0x3d, 0x0018}, /* 00,3D,18,aa */
3127        {0xaa, 0x3e, 0x006a}, /* 00,3E,6A,aa */
3128        {0xaa, 0x3b, 0x0018}, /* 00,3B,18,aa */
3129        {0xaa, 0x3c, 0x006a}, /* 00,3C,6A,aa */
3130        {}
3131};
3132
3133static const struct usb_action mc501cb_NoFlikerScale[] = {
3134        {0xaa, 0x03, 0x0003}, /* 00,03,03,aa */
3135        {0xaa, 0x10, 0x00fc}, /* 00,10,fc,aa */
3136        {0xaa, 0x36, 0x0030}, /* 00,36,30,aa */
3137        {0xaa, 0x37, 0x00d4}, /* 00,37,D4,aa */
3138        {0xaa, 0x3d, 0x0030}, /* 00,3D,30,aa */
3139        {0xaa, 0x3e, 0x00d4}, /* 00,3E,D4,aa */
3140        {0xaa, 0x3b, 0x0030}, /* 00,3B,30,aa */
3141        {0xaa, 0x3c, 0x00d4}, /* 00,3C,D4,aa */
3142        {}
3143};
3144
3145/* from zs211.inf */
3146static const struct usb_action ov7620_Initial[] = {     /* 640x480 */
3147        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
3148        {0xa0, 0x40, ZC3XX_R002_CLOCKSELECT}, /* 00,02,40,cc */
3149        {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING}, /* 00,08,00,cc */
3150        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
3151        {0xa0, 0x06, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,06,cc */
3152        {0xa0, 0x02, ZC3XX_R083_RGAINADDR}, /* 00,83,02,cc */
3153        {0xa0, 0x01, ZC3XX_R085_BGAINADDR}, /* 00,85,01,cc */
3154        {0xa0, 0x80, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,80,cc */
3155        {0xa0, 0x81, ZC3XX_R087_EXPTIMEMID}, /* 00,87,81,cc */
3156        {0xa0, 0x10, ZC3XX_R088_EXPTIMELOW}, /* 00,88,10,cc */
3157        {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,a1,cc */
3158        {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE}, /* 00,8d,08,cc */
3159        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
3160        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
3161        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
3162        {0xa0, 0xd8, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d8,cc */
3163        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
3164        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
3165        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
3166        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
3167        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
3168        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
3169        {0xa0, 0xde, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,de,cc */
3170        {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,86,cc */
3171        {0xaa, 0x12, 0x0088}, /* 00,12,88,aa */
3172        {0xaa, 0x12, 0x0048}, /* 00,12,48,aa */
3173        {0xaa, 0x75, 0x008a}, /* 00,75,8a,aa */
3174        {0xaa, 0x13, 0x00a3}, /* 00,13,a3,aa */
3175        {0xaa, 0x04, 0x0000}, /* 00,04,00,aa */
3176        {0xaa, 0x05, 0x0000}, /* 00,05,00,aa */
3177        {0xaa, 0x14, 0x0000}, /* 00,14,00,aa */
3178        {0xaa, 0x15, 0x0004}, /* 00,15,04,aa */
3179        {0xaa, 0x17, 0x0018}, /* 00,17,18,aa */
3180        {0xaa, 0x18, 0x00ba}, /* 00,18,ba,aa */
3181        {0xaa, 0x19, 0x0002}, /* 00,19,02,aa */
3182        {0xaa, 0x1a, 0x00f1}, /* 00,1a,f1,aa */
3183        {0xaa, 0x20, 0x0040}, /* 00,20,40,aa */
3184        {0xaa, 0x24, 0x0088}, /* 00,24,88,aa */
3185        {0xaa, 0x25, 0x0078}, /* 00,25,78,aa */
3186        {0xaa, 0x27, 0x00f6}, /* 00,27,f6,aa */
3187        {0xaa, 0x28, 0x00a0}, /* 00,28,a0,aa */
3188        {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
3189        {0xaa, 0x2a, 0x0083}, /* 00,2a,83,aa */
3190        {0xaa, 0x2b, 0x0096}, /* 00,2b,96,aa */
3191        {0xaa, 0x2d, 0x0005}, /* 00,2d,05,aa */
3192        {0xaa, 0x74, 0x0020}, /* 00,74,20,aa */
3193        {0xaa, 0x61, 0x0068}, /* 00,61,68,aa */
3194        {0xaa, 0x64, 0x0088}, /* 00,64,88,aa */
3195        {0xaa, 0x00, 0x0000}, /* 00,00,00,aa */
3196        {0xaa, 0x06, 0x0080}, /* 00,06,80,aa */
3197        {0xaa, 0x01, 0x0090}, /* 00,01,90,aa */
3198        {0xaa, 0x02, 0x0030}, /* 00,02,30,aa */
3199        {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,77,cc */
3200        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
3201        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
3202        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
3203        {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
3204        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
3205        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
3206        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
3207        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
3208        {0xa0, 0x68, ZC3XX_R116_RGAIN}, /* 01,16,68,cc */
3209        {0xa0, 0x52, ZC3XX_R118_BGAIN}, /* 01,18,52,cc */
3210        {0xa0, 0x40, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,40,cc */
3211        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
3212        {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,50,cc */
3213        {}
3214};
3215static const struct usb_action ov7620_InitialScale[] = {        /* 320x240 */
3216        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
3217        {0xa0, 0x50, ZC3XX_R002_CLOCKSELECT},   /* 00,02,50,cc */
3218        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* 00,08,00,cc */
3219                                                /* mx change? */
3220        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
3221        {0xa0, 0x06, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,06,cc */
3222        {0xa0, 0x02, ZC3XX_R083_RGAINADDR},     /* 00,83,02,cc */
3223        {0xa0, 0x01, ZC3XX_R085_BGAINADDR},     /* 00,85,01,cc */
3224        {0xa0, 0x80, ZC3XX_R086_EXPTIMEHIGH},   /* 00,86,80,cc */
3225        {0xa0, 0x81, ZC3XX_R087_EXPTIMEMID},    /* 00,87,81,cc */
3226        {0xa0, 0x10, ZC3XX_R088_EXPTIMELOW},    /* 00,88,10,cc */
3227        {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,a1,cc */
3228        {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE}, /* 00,8d,08,cc */
3229        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
3230        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
3231        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
3232        {0xa0, 0xd0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,d0,cc */
3233        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
3234        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
3235        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},  /* 00,98,00,cc */
3236        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},  /* 00,9a,00,cc */
3237        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},     /* 01,1a,00,cc */
3238        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},     /* 01,1c,00,cc */
3239        {0xa0, 0xd6, ZC3XX_R09C_WINHEIGHTLOW},  /* 00,9c,d6,cc */
3240                                                /* OV7648 00,9c,d8,cc */
3241        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},   /* 00,9e,88,cc */
3242        {0xaa, 0x12, 0x0088}, /* 00,12,88,aa */
3243        {0xaa, 0x12, 0x0048}, /* 00,12,48,aa */
3244        {0xaa, 0x75, 0x008a}, /* 00,75,8a,aa */
3245        {0xaa, 0x13, 0x00a3}, /* 00,13,a3,aa */
3246        {0xaa, 0x04, 0x0000}, /* 00,04,00,aa */
3247        {0xaa, 0x05, 0x0000}, /* 00,05,00,aa */
3248        {0xaa, 0x14, 0x0000}, /* 00,14,00,aa */
3249        {0xaa, 0x15, 0x0004}, /* 00,15,04,aa */
3250        {0xaa, 0x24, 0x0088}, /* 00,24,88,aa */
3251        {0xaa, 0x25, 0x0078}, /* 00,25,78,aa */
3252        {0xaa, 0x17, 0x0018}, /* 00,17,18,aa */
3253        {0xaa, 0x18, 0x00ba}, /* 00,18,ba,aa */
3254        {0xaa, 0x19, 0x0002}, /* 00,19,02,aa */
3255        {0xaa, 0x1a, 0x00f2}, /* 00,1a,f2,aa */
3256        {0xaa, 0x20, 0x0040}, /* 00,20,40,aa */
3257        {0xaa, 0x27, 0x00f6}, /* 00,27,f6,aa */
3258        {0xaa, 0x28, 0x00a0}, /* 00,28,a0,aa */
3259        {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
3260        {0xaa, 0x2a, 0x0083}, /* 00,2a,83,aa */
3261        {0xaa, 0x2b, 0x0096}, /* 00,2b,96,aa */
3262        {0xaa, 0x2d, 0x0005}, /* 00,2d,05,aa */
3263        {0xaa, 0x74, 0x0020}, /* 00,74,20,aa */
3264        {0xaa, 0x61, 0x0068}, /* 00,61,68,aa */
3265        {0xaa, 0x64, 0x0088}, /* 00,64,88,aa */
3266        {0xaa, 0x00, 0x0000}, /* 00,00,00,aa */
3267        {0xaa, 0x06, 0x0080}, /* 00,06,80,aa */
3268        {0xaa, 0x01, 0x0090}, /* 00,01,90,aa */
3269        {0xaa, 0x02, 0x0030}, /* 00,02,30,aa */
3270        {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,77,cc */
3271        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
3272        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
3273        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},     /* 01,89,06,cc */
3274        {0xa0, 0x00, 0x01ad},                   /* 01,ad,00,cc */
3275        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
3276        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},   /* 01,cb,13,cc */
3277        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
3278        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},  /* 03,01,08,cc */
3279        {0xa0, 0x68, ZC3XX_R116_RGAIN},         /* 01,16,68,cc */
3280        {0xa0, 0x52, ZC3XX_R118_BGAIN},         /* 01,18,52,cc */
3281        {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},    /* 01,1d,50,cc */
3282        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
3283        {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN},   /* 01,a8,50,cc */
3284        {}
3285};
3286static const struct usb_action ov7620_50HZ[] = {
3287        {0xaa, 0x13, 0x00a3},   /* 00,13,a3,aa */
3288        {0xdd, 0x00, 0x0100},   /* 00,01,00,dd */
3289        {0xaa, 0x2b, 0x0096},   /* 00,2b,96,aa */
3290        {0xaa, 0x75, 0x008a},   /* 00,75,8a,aa */
3291        {0xaa, 0x2d, 0x0005},   /* 00,2d,05,aa */
3292        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
3293        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,04,cc */
3294        {0xa0, 0x18, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,18,cc */
3295        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
3296        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
3297        {0xa0, 0x83, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,83,cc */
3298        {0xaa, 0x10, 0x0082},                           /* 00,10,82,aa */
3299        {0xaa, 0x76, 0x0003},                           /* 00,76,03,aa */
3300/*      {0xa0, 0x40, ZC3XX_R002_CLOCKSELECT},            * 00,02,40,cc
3301                                                         * if mode0 (640x480) */
3302        {}
3303};
3304static const struct usb_action ov7620_60HZ[] = {
3305        {0xaa, 0x13, 0x00a3},                   /* 00,13,a3,aa */
3306                                                /* (bug in zs211.inf) */
3307        {0xdd, 0x00, 0x0100},                   /* 00,01,00,dd */
3308        {0xaa, 0x2b, 0x0000},                   /* 00,2b,00,aa */
3309        {0xaa, 0x75, 0x008a},                   /* 00,75,8a,aa */
3310        {0xaa, 0x2d, 0x0005},                   /* 00,2d,05,aa */
3311        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3312        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
3313        {0xa0, 0x18, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,18,cc */
3314        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3315        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3316        {0xa0, 0x83, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,83,cc */
3317        {0xaa, 0x10, 0x0020},                   /* 00,10,20,aa */
3318        {0xaa, 0x76, 0x0003},                   /* 00,76,03,aa */
3319/*      {0xa0, 0x40, ZC3XX_R002_CLOCKSELECT},    * 00,02,40,cc
3320                                                 * if mode0 (640x480) */
3321/* ?? in gspca v1, it was
3322        {0xa0, 0x00, 0x0039},  * 00,00,00,dd *
3323        {0xa1, 0x01, 0x0037},           */
3324        {}
3325};
3326static const struct usb_action ov7620_NoFliker[] = {
3327        {0xaa, 0x13, 0x00a3},                   /* 00,13,a3,aa */
3328                                                /* (bug in zs211.inf) */
3329        {0xdd, 0x00, 0x0100},                   /* 00,01,00,dd */
3330        {0xaa, 0x2b, 0x0000},                   /* 00,2b,00,aa */
3331        {0xaa, 0x75, 0x008e},                   /* 00,75,8e,aa */
3332        {0xaa, 0x2d, 0x0001},                   /* 00,2d,01,aa */
3333        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3334        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,04,cc */
3335        {0xa0, 0x18, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,18,cc */
3336        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3337        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3338        {0xa0, 0x01, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,01,cc */
3339/*      {0xa0, 0x44, ZC3XX_R002_CLOCKSELECT},    * 00,02,44,cc
3340                                                 * if mode1 (320x240) */
3341/* ?? was
3342        {0xa0, 0x00, 0x0039},  * 00,00,00,dd *
3343        {0xa1, 0x01, 0x0037},           */
3344        {}
3345};
3346
3347static const struct usb_action ov7630c_InitialScale[] = {
3348        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
3349        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
3350        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
3351        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
3352        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3353        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
3354        {0xa0, 0x06, ZC3XX_R010_CMOSSENSORSELECT},
3355        {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR},
3356        {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
3357        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
3358        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
3359        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
3360        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
3361        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
3362        {0xaa, 0x12, 0x0080},
3363        {0xa0, 0x02, ZC3XX_R083_RGAINADDR},
3364        {0xa0, 0x01, ZC3XX_R085_BGAINADDR},
3365        {0xa0, 0x90, ZC3XX_R086_EXPTIMEHIGH},
3366        {0xa0, 0x91, ZC3XX_R087_EXPTIMEMID},
3367        {0xa0, 0x10, ZC3XX_R088_EXPTIMELOW},
3368        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
3369        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
3370        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
3371        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
3372        {0xa0, 0xd8, ZC3XX_R09C_WINHEIGHTLOW},
3373        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
3374        {0xaa, 0x12, 0x0069},
3375        {0xaa, 0x04, 0x0020},
3376        {0xaa, 0x06, 0x0050},
3377        {0xaa, 0x13, 0x0083},
3378        {0xaa, 0x14, 0x0000},
3379        {0xaa, 0x15, 0x0024},
3380        {0xaa, 0x17, 0x0018},
3381        {0xaa, 0x18, 0x00ba},
3382        {0xaa, 0x19, 0x0002},
3383        {0xaa, 0x1a, 0x00f6},
3384        {0xaa, 0x1b, 0x0002},
3385        {0xaa, 0x20, 0x00c2},
3386        {0xaa, 0x24, 0x0060},
3387        {0xaa, 0x25, 0x0040},
3388        {0xaa, 0x26, 0x0030},
3389        {0xaa, 0x27, 0x00ea},
3390        {0xaa, 0x28, 0x00a0},
3391        {0xaa, 0x21, 0x0000},
3392        {0xaa, 0x2a, 0x0081},
3393        {0xaa, 0x2b, 0x0096},
3394        {0xaa, 0x2d, 0x0094},
3395        {0xaa, 0x2f, 0x003d},
3396        {0xaa, 0x30, 0x0024},
3397        {0xaa, 0x60, 0x0000},
3398        {0xaa, 0x61, 0x0040},
3399        {0xaa, 0x68, 0x007c},
3400        {0xaa, 0x6f, 0x0015},
3401        {0xaa, 0x75, 0x0088},
3402        {0xaa, 0x77, 0x00b5},
3403        {0xaa, 0x01, 0x0060},
3404        {0xaa, 0x02, 0x0060},
3405        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
3406        {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
3407        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3408        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3409        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
3410        {0xa0, 0x00, 0x01ad},
3411        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
3412        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
3413        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3414        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3415        {0xa0, 0x60, ZC3XX_R116_RGAIN},
3416        {0xa0, 0x46, ZC3XX_R118_BGAIN},
3417        {0xa0, 0x04, ZC3XX_R113_RGB03},
3418/* 0x10, */
3419        {0xa1, 0x01, 0x0002},
3420        {0xa0, 0x50, ZC3XX_R10A_RGB00}, /* matrix */
3421        {0xa0, 0xf8, ZC3XX_R10B_RGB01},
3422        {0xa0, 0xf8, ZC3XX_R10C_RGB02},
3423        {0xa0, 0xf8, ZC3XX_R10D_RGB10},
3424        {0xa0, 0x50, ZC3XX_R10E_RGB11},
3425        {0xa0, 0xf8, ZC3XX_R10F_RGB12},
3426        {0xa0, 0xf8, ZC3XX_R110_RGB20},
3427        {0xa0, 0xf8, ZC3XX_R111_RGB21},
3428        {0xa0, 0x50, ZC3XX_R112_RGB22},
3429        {0xa1, 0x01, 0x0008},
3430        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* clock ? */
3431        {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},   /* sharpness+ */
3432        {0xa1, 0x01, 0x01c8},
3433        {0xa1, 0x01, 0x01c9},
3434        {0xa1, 0x01, 0x01ca},
3435        {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},   /* sharpness- */
3436        {0xa0, 0x01, ZC3XX_R120_GAMMA00},       /* gamma 2 ?*/
3437        {0xa0, 0x0c, ZC3XX_R121_GAMMA01},
3438        {0xa0, 0x1f, ZC3XX_R122_GAMMA02},
3439        {0xa0, 0x3a, ZC3XX_R123_GAMMA03},
3440        {0xa0, 0x53, ZC3XX_R124_GAMMA04},
3441        {0xa0, 0x6d, ZC3XX_R125_GAMMA05},
3442        {0xa0, 0x85, ZC3XX_R126_GAMMA06},
3443        {0xa0, 0x9c, ZC3XX_R127_GAMMA07},
3444        {0xa0, 0xb0, ZC3XX_R128_GAMMA08},
3445        {0xa0, 0xc2, ZC3XX_R129_GAMMA09},
3446        {0xa0, 0xd1, ZC3XX_R12A_GAMMA0A},
3447        {0xa0, 0xde, ZC3XX_R12B_GAMMA0B},
3448        {0xa0, 0xe9, ZC3XX_R12C_GAMMA0C},
3449        {0xa0, 0xf2, ZC3XX_R12D_GAMMA0D},
3450        {0xa0, 0xf9, ZC3XX_R12E_GAMMA0E},
3451        {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
3452        {0xa0, 0x05, ZC3XX_R130_GAMMA10},
3453        {0xa0, 0x0f, ZC3XX_R131_GAMMA11},
3454        {0xa0, 0x16, ZC3XX_R132_GAMMA12},
3455        {0xa0, 0x1a, ZC3XX_R133_GAMMA13},
3456        {0xa0, 0x19, ZC3XX_R134_GAMMA14},
3457        {0xa0, 0x19, ZC3XX_R135_GAMMA15},
3458        {0xa0, 0x17, ZC3XX_R136_GAMMA16},
3459        {0xa0, 0x15, ZC3XX_R137_GAMMA17},
3460        {0xa0, 0x12, ZC3XX_R138_GAMMA18},
3461        {0xa0, 0x10, ZC3XX_R139_GAMMA19},
3462        {0xa0, 0x0e, ZC3XX_R13A_GAMMA1A},
3463        {0xa0, 0x0b, ZC3XX_R13B_GAMMA1B},
3464        {0xa0, 0x09, ZC3XX_R13C_GAMMA1C},
3465        {0xa0, 0x08, ZC3XX_R13D_GAMMA1D},
3466        {0xa0, 0x06, ZC3XX_R13E_GAMMA1E},
3467        {0xa0, 0x03, ZC3XX_R13F_GAMMA1F},
3468        {0xa0, 0x50, ZC3XX_R10A_RGB00}, /* matrix */
3469        {0xa0, 0xf8, ZC3XX_R10B_RGB01},
3470        {0xa0, 0xf8, ZC3XX_R10C_RGB02},
3471        {0xa0, 0xf8, ZC3XX_R10D_RGB10},
3472        {0xa0, 0x50, ZC3XX_R10E_RGB11},
3473        {0xa0, 0xf8, ZC3XX_R10F_RGB12},
3474        {0xa0, 0xf8, ZC3XX_R110_RGB20},
3475        {0xa0, 0xf8, ZC3XX_R111_RGB21},
3476        {0xa0, 0x50, ZC3XX_R112_RGB22},
3477
3478        {0xa1, 0x01, 0x0180},
3479        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
3480        {0xaa, 0x10, 0x001b},
3481        {0xaa, 0x76, 0x0002},
3482        {0xaa, 0x2a, 0x0081},
3483        {0xaa, 0x2b, 0x0000},
3484        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
3485        {0xa0, 0x01, ZC3XX_R191_EXPOSURELIMITMID},
3486        {0xa0, 0xb8, ZC3XX_R192_EXPOSURELIMITLOW},
3487        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
3488        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
3489        {0xa0, 0x37, ZC3XX_R197_ANTIFLICKERLOW},
3490        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
3491        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
3492        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
3493        {0xa0, 0x26, ZC3XX_R1AA_DIGITALGAINSTEP},
3494        {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
3495        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
3496        {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
3497        {0xaa, 0x13, 0x0083},   /* 40 */
3498        {0xa1, 0x01, 0x0180},
3499        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
3500        {}
3501};
3502
3503static const struct usb_action ov7630c_Initial[] = {
3504        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
3505        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
3506        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3507        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
3508        {0xa0, 0x06, ZC3XX_R010_CMOSSENSORSELECT},
3509        {0xa0, 0xa1, ZC3XX_R08B_I2CDEVICEADDR},
3510        {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
3511        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
3512        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
3513        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
3514        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
3515        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
3516
3517        {0xaa, 0x12, 0x0080},
3518        {0xa0, 0x02, ZC3XX_R083_RGAINADDR},
3519        {0xa0, 0x01, ZC3XX_R085_BGAINADDR},
3520        {0xa0, 0x90, ZC3XX_R086_EXPTIMEHIGH},
3521        {0xa0, 0x91, ZC3XX_R087_EXPTIMEMID},
3522        {0xa0, 0x10, ZC3XX_R088_EXPTIMELOW},
3523        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
3524        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
3525        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
3526        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
3527        {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},
3528        {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},
3529        {0xaa, 0x12, 0x0069},   /* i2c */
3530        {0xaa, 0x04, 0x0020},
3531        {0xaa, 0x06, 0x0050},
3532        {0xaa, 0x13, 0x00c3},
3533        {0xaa, 0x14, 0x0000},
3534        {0xaa, 0x15, 0x0024},
3535        {0xaa, 0x19, 0x0003},
3536        {0xaa, 0x1a, 0x00f6},
3537        {0xaa, 0x1b, 0x0002},
3538        {0xaa, 0x20, 0x00c2},
3539        {0xaa, 0x24, 0x0060},
3540        {0xaa, 0x25, 0x0040},
3541        {0xaa, 0x26, 0x0030},
3542        {0xaa, 0x27, 0x00ea},
3543        {0xaa, 0x28, 0x00a0},
3544        {0xaa, 0x21, 0x0000},
3545        {0xaa, 0x2a, 0x0081},
3546        {0xaa, 0x2b, 0x0096},
3547        {0xaa, 0x2d, 0x0084},
3548        {0xaa, 0x2f, 0x003d},
3549        {0xaa, 0x30, 0x0024},
3550        {0xaa, 0x60, 0x0000},
3551        {0xaa, 0x61, 0x0040},
3552        {0xaa, 0x68, 0x007c},
3553        {0xaa, 0x6f, 0x0015},
3554        {0xaa, 0x75, 0x0088},
3555        {0xaa, 0x77, 0x00b5},
3556        {0xaa, 0x01, 0x0060},
3557        {0xaa, 0x02, 0x0060},
3558        {0xaa, 0x17, 0x0018},
3559        {0xaa, 0x18, 0x00ba},
3560        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
3561        {0xa0, 0x77, ZC3XX_R101_SENSORCORRECTION},
3562        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3563        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3564        {0xa0, 0x04, ZC3XX_R1A7_CALCGLOBALMEAN},
3565        {0xa0, 0x00, 0x01ad},
3566        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
3567        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
3568        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3569        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3570        {0xa0, 0x60, ZC3XX_R116_RGAIN},
3571        {0xa0, 0x46, ZC3XX_R118_BGAIN},
3572        {0xa0, 0x04, ZC3XX_R113_RGB03},
3573
3574        {0xa1, 0x01, 0x0002},
3575        {0xa0, 0x4e, ZC3XX_R10A_RGB00}, /* matrix */
3576        {0xa0, 0xfe, ZC3XX_R10B_RGB01},
3577        {0xa0, 0xf4, ZC3XX_R10C_RGB02},
3578        {0xa0, 0xf7, ZC3XX_R10D_RGB10},
3579        {0xa0, 0x4d, ZC3XX_R10E_RGB11},
3580        {0xa0, 0xfc, ZC3XX_R10F_RGB12},
3581        {0xa0, 0x00, ZC3XX_R110_RGB20},
3582        {0xa0, 0xf6, ZC3XX_R111_RGB21},
3583        {0xa0, 0x4a, ZC3XX_R112_RGB22},
3584
3585        {0xa1, 0x01, 0x0008},
3586        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* clock ? */
3587        {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},   /* sharpness+ */
3588        {0xa1, 0x01, 0x01c8},
3589        {0xa1, 0x01, 0x01c9},
3590        {0xa1, 0x01, 0x01ca},
3591        {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},   /* sharpness- */
3592        {0xa0, 0x16, ZC3XX_R120_GAMMA00},       /* gamma ~4 */
3593        {0xa0, 0x3a, ZC3XX_R121_GAMMA01},
3594        {0xa0, 0x5b, ZC3XX_R122_GAMMA02},
3595        {0xa0, 0x7c, ZC3XX_R123_GAMMA03},
3596        {0xa0, 0x94, ZC3XX_R124_GAMMA04},
3597        {0xa0, 0xa9, ZC3XX_R125_GAMMA05},
3598        {0xa0, 0xbb, ZC3XX_R126_GAMMA06},
3599        {0xa0, 0xca, ZC3XX_R127_GAMMA07},
3600        {0xa0, 0xd7, ZC3XX_R128_GAMMA08},
3601        {0xa0, 0xe1, ZC3XX_R129_GAMMA09},
3602        {0xa0, 0xea, ZC3XX_R12A_GAMMA0A},
3603        {0xa0, 0xf1, ZC3XX_R12B_GAMMA0B},
3604        {0xa0, 0xf7, ZC3XX_R12C_GAMMA0C},
3605        {0xa0, 0xfc, ZC3XX_R12D_GAMMA0D},
3606        {0xa0, 0xff, ZC3XX_R12E_GAMMA0E},
3607        {0xa0, 0xff, ZC3XX_R12F_GAMMA0F},
3608        {0xa0, 0x20, ZC3XX_R130_GAMMA10},
3609        {0xa0, 0x22, ZC3XX_R131_GAMMA11},
3610        {0xa0, 0x20, ZC3XX_R132_GAMMA12},
3611        {0xa0, 0x1c, ZC3XX_R133_GAMMA13},
3612        {0xa0, 0x16, ZC3XX_R134_GAMMA14},
3613        {0xa0, 0x13, ZC3XX_R135_GAMMA15},
3614        {0xa0, 0x10, ZC3XX_R136_GAMMA16},
3615        {0xa0, 0x0d, ZC3XX_R137_GAMMA17},
3616        {0xa0, 0x0b, ZC3XX_R138_GAMMA18},
3617        {0xa0, 0x09, ZC3XX_R139_GAMMA19},
3618        {0xa0, 0x07, ZC3XX_R13A_GAMMA1A},
3619        {0xa0, 0x06, ZC3XX_R13B_GAMMA1B},
3620        {0xa0, 0x05, ZC3XX_R13C_GAMMA1C},
3621        {0xa0, 0x04, ZC3XX_R13D_GAMMA1D},
3622        {0xa0, 0x00, ZC3XX_R13E_GAMMA1E},
3623        {0xa0, 0x01, ZC3XX_R13F_GAMMA1F},
3624        {0xa0, 0x4e, ZC3XX_R10A_RGB00}, /* matrix */
3625        {0xa0, 0xfe, ZC3XX_R10B_RGB01},
3626        {0xa0, 0xf4, ZC3XX_R10C_RGB02},
3627        {0xa0, 0xf7, ZC3XX_R10D_RGB10},
3628        {0xa0, 0x4d, ZC3XX_R10E_RGB11},
3629        {0xa0, 0xfc, ZC3XX_R10F_RGB12},
3630        {0xa0, 0x00, ZC3XX_R110_RGB20},
3631        {0xa0, 0xf6, ZC3XX_R111_RGB21},
3632        {0xa0, 0x4a, ZC3XX_R112_RGB22},
3633
3634        {0xa1, 0x01, 0x0180},
3635        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
3636        {0xaa, 0x10, 0x000d},
3637        {0xaa, 0x76, 0x0002},
3638        {0xaa, 0x2a, 0x0081},
3639        {0xaa, 0x2b, 0x0000},
3640        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
3641        {0xa0, 0x00, ZC3XX_R191_EXPOSURELIMITMID},
3642        {0xa0, 0xd8, ZC3XX_R192_EXPOSURELIMITLOW},
3643        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
3644        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
3645        {0xa0, 0x1b, ZC3XX_R197_ANTIFLICKERLOW},
3646        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
3647        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
3648        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},
3649        {0xa0, 0x26, ZC3XX_R1AA_DIGITALGAINSTEP},
3650        {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
3651        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE},
3652        {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
3653        {0xaa, 0x13, 0x00c3},
3654
3655        {0xa1, 0x01, 0x0180},
3656        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
3657        {}
3658};
3659
3660static const struct usb_action pas106b_Initial_com[] = {
3661/* Sream and Sensor specific */
3662        {0xa1, 0x01, 0x0010},   /* CMOSSensorSelect */
3663/* System */
3664        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* SystemControl */
3665        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* SystemControl */
3666/* Picture size */
3667        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},   /* ClockSelect */
3668        {0xa0, 0x03, 0x003a},
3669        {0xa0, 0x0c, 0x003b},
3670        {0xa0, 0x04, 0x0038},
3671        {}
3672};
3673
3674static const struct usb_action pas106b_InitialScale[] = {       /* 176x144 */
3675/* JPEG control */
3676        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3677/* Sream and Sensor specific */
3678        {0xa0, 0x0f, ZC3XX_R010_CMOSSENSORSELECT},
3679/* Picture size */
3680        {0xa0, 0x00, ZC3XX_R003_FRAMEWIDTHHIGH},
3681        {0xa0, 0xb0, ZC3XX_R004_FRAMEWIDTHLOW},
3682        {0xa0, 0x00, ZC3XX_R005_FRAMEHEIGHTHIGH},
3683        {0xa0, 0x90, ZC3XX_R006_FRAMEHEIGHTLOW},
3684/* System */
3685        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
3686/* Sream and Sensor specific */
3687        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
3688        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
3689/* Sensor Interface */
3690        {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
3691/* Window inside sensor array */
3692        {0xa0, 0x03, ZC3XX_R09A_WINXSTARTLOW},
3693        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
3694        {0xa0, 0x03, ZC3XX_R11C_FIRSTXLOW},
3695        {0xa0, 0x28, ZC3XX_R09C_WINHEIGHTLOW},
3696        {0xa0, 0x68, ZC3XX_R09E_WINWIDTHLOW},
3697/* Init the sensor */
3698        {0xaa, 0x02, 0x0004},
3699        {0xaa, 0x08, 0x0000},
3700        {0xaa, 0x09, 0x0005},
3701        {0xaa, 0x0a, 0x0002},
3702        {0xaa, 0x0b, 0x0002},
3703        {0xaa, 0x0c, 0x0005},
3704        {0xaa, 0x0d, 0x0000},
3705        {0xaa, 0x0e, 0x0002},
3706        {0xaa, 0x14, 0x0081},
3707/* Other registers */
3708        {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
3709/* Frame retreiving */
3710        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
3711/* Gains */
3712        {0xa0, 0xa0, ZC3XX_R1A8_DIGITALGAIN},
3713/* Unknown */
3714        {0xa0, 0x00, 0x01ad},
3715/* Sharpness */
3716        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
3717        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
3718/* Other registers */
3719        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3720/* Auto exposure and white balance */
3721        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3722/*Dead pixels */
3723        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3724/* EEPROM */
3725        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3726/* JPEG control */
3727        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3728        {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},
3729        {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},
3730/* Other registers */
3731        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3732/* Auto exposure and white balance */
3733        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3734/*Dead pixels */
3735        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3736/* EEPROM */
3737        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3738/* JPEG control */
3739        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3740        {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},
3741        {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},
3742
3743        {0xa0, 0x58, ZC3XX_R10A_RGB00}, /* matrix */
3744        {0xa0, 0xf4, ZC3XX_R10B_RGB01},
3745        {0xa0, 0xf4, ZC3XX_R10C_RGB02},
3746        {0xa0, 0xf4, ZC3XX_R10D_RGB10},
3747        {0xa0, 0x58, ZC3XX_R10E_RGB11},
3748        {0xa0, 0xf4, ZC3XX_R10F_RGB12},
3749        {0xa0, 0xf4, ZC3XX_R110_RGB20},
3750        {0xa0, 0xf4, ZC3XX_R111_RGB21},
3751        {0xa0, 0x58, ZC3XX_R112_RGB22},
3752/* Auto correction */
3753        {0xa0, 0x03, ZC3XX_R181_WINXSTART},
3754        {0xa0, 0x08, ZC3XX_R182_WINXWIDTH},
3755        {0xa0, 0x16, ZC3XX_R183_WINXCENTER},
3756        {0xa0, 0x03, ZC3XX_R184_WINYSTART},
3757        {0xa0, 0x05, ZC3XX_R185_WINYWIDTH},
3758        {0xa0, 0x14, ZC3XX_R186_WINYCENTER},
3759        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
3760/* Auto exposure and white balance */
3761        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
3762        {0xa0, 0x03, ZC3XX_R191_EXPOSURELIMITMID},
3763        {0xa0, 0xb1, ZC3XX_R192_EXPOSURELIMITLOW},
3764        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
3765        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
3766        {0xa0, 0x87, ZC3XX_R197_ANTIFLICKERLOW},
3767        {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
3768        {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
3769/* sensor on */
3770        {0xaa, 0x07, 0x00b1},
3771        {0xaa, 0x05, 0x0003},
3772        {0xaa, 0x04, 0x0001},
3773        {0xaa, 0x03, 0x003b},
3774/* Gains */
3775        {0xa0, 0x20, ZC3XX_R1A9_DIGITALLIMITDIFF},
3776        {0xa0, 0x26, ZC3XX_R1AA_DIGITALGAINSTEP},
3777        {0xa0, 0xa0, ZC3XX_R11D_GLOBALGAIN},
3778        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
3779/* Auto correction */
3780        {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
3781        {0xa1, 0x01, 0x0180},                           /* AutoCorrectEnable */
3782        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
3783/* Gains */
3784        {0xa0, 0x40, ZC3XX_R116_RGAIN},
3785        {0xa0, 0x40, ZC3XX_R117_GGAIN},
3786        {0xa0, 0x40, ZC3XX_R118_BGAIN},
3787        {}
3788};
3789
3790static const struct usb_action pas106b_Initial[] = {    /* 352x288 */
3791/* JPEG control */
3792        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3793/* Sream and Sensor specific */
3794        {0xa0, 0x0f, ZC3XX_R010_CMOSSENSORSELECT},
3795/* Picture size */
3796        {0xa0, 0x01, ZC3XX_R003_FRAMEWIDTHHIGH},
3797        {0xa0, 0x60, ZC3XX_R004_FRAMEWIDTHLOW},
3798        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
3799        {0xa0, 0x20, ZC3XX_R006_FRAMEHEIGHTLOW},
3800/* System */
3801        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
3802/* Sream and Sensor specific */
3803        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},
3804        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
3805/* Sensor Interface */
3806        {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},
3807/* Window inside sensor array */
3808        {0xa0, 0x03, ZC3XX_R09A_WINXSTARTLOW},
3809        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
3810        {0xa0, 0x03, ZC3XX_R11C_FIRSTXLOW},
3811        {0xa0, 0x28, ZC3XX_R09C_WINHEIGHTLOW},
3812        {0xa0, 0x68, ZC3XX_R09E_WINWIDTHLOW},
3813/* Init the sensor */
3814        {0xaa, 0x02, 0x0004},
3815        {0xaa, 0x08, 0x0000},
3816        {0xaa, 0x09, 0x0005},
3817        {0xaa, 0x0a, 0x0002},
3818        {0xaa, 0x0b, 0x0002},
3819        {0xaa, 0x0c, 0x0005},
3820        {0xaa, 0x0d, 0x0000},
3821        {0xaa, 0x0e, 0x0002},
3822        {0xaa, 0x14, 0x0081},
3823/* Other registers */
3824        {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
3825/* Frame retreiving */
3826        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
3827/* Gains */
3828        {0xa0, 0xa0, ZC3XX_R1A8_DIGITALGAIN},
3829/* Unknown */
3830        {0xa0, 0x00, 0x01ad},
3831/* Sharpness */
3832        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
3833        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
3834/* Other registers */
3835        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3836/* Auto exposure and white balance */
3837        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3838        {0xa0, 0x80, ZC3XX_R18D_YTARGET},
3839/*Dead pixels */
3840        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3841/* EEPROM */
3842        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3843/* JPEG control */
3844        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3845        {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},
3846        {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},
3847/* Other registers */
3848        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
3849/* Auto exposure and white balance */
3850        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
3851/*Dead pixels */
3852        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
3853/* EEPROM */
3854        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
3855/* JPEG control */
3856        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3857        {0xa0, 0x08, ZC3XX_R1C6_SHARPNESS00},
3858        {0xa0, 0x0f, ZC3XX_R1CB_SHARPNESS05},
3859
3860        {0xa0, 0x58, ZC3XX_R10A_RGB00}, /* matrix */
3861        {0xa0, 0xf4, ZC3XX_R10B_RGB01},
3862        {0xa0, 0xf4, ZC3XX_R10C_RGB02},
3863        {0xa0, 0xf4, ZC3XX_R10D_RGB10},
3864        {0xa0, 0x58, ZC3XX_R10E_RGB11},
3865        {0xa0, 0xf4, ZC3XX_R10F_RGB12},
3866        {0xa0, 0xf4, ZC3XX_R110_RGB20},
3867        {0xa0, 0xf4, ZC3XX_R111_RGB21},
3868        {0xa0, 0x58, ZC3XX_R112_RGB22},
3869/* Auto correction */
3870        {0xa0, 0x03, ZC3XX_R181_WINXSTART},
3871        {0xa0, 0x08, ZC3XX_R182_WINXWIDTH},
3872        {0xa0, 0x16, ZC3XX_R183_WINXCENTER},
3873        {0xa0, 0x03, ZC3XX_R184_WINYSTART},
3874        {0xa0, 0x05, ZC3XX_R185_WINYWIDTH},
3875        {0xa0, 0x14, ZC3XX_R186_WINYCENTER},
3876        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
3877
3878/* Auto exposure and white balance */
3879        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
3880        {0xa0, 0x03, ZC3XX_R191_EXPOSURELIMITMID},
3881        {0xa0, 0xb1, ZC3XX_R192_EXPOSURELIMITLOW},
3882
3883        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
3884        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
3885        {0xa0, 0x87, ZC3XX_R197_ANTIFLICKERLOW},
3886
3887        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
3888        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
3889/* sensor on */
3890        {0xaa, 0x07, 0x00b1},
3891        {0xaa, 0x05, 0x0003},
3892        {0xaa, 0x04, 0x0001},
3893        {0xaa, 0x03, 0x003b},
3894/* Gains */
3895        {0xa0, 0x20, ZC3XX_R1A9_DIGITALLIMITDIFF},
3896        {0xa0, 0x26, ZC3XX_R1AA_DIGITALGAINSTEP},
3897        {0xa0, 0xa0, ZC3XX_R11D_GLOBALGAIN},
3898        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
3899/* Auto correction */
3900        {0xa0, 0x40, ZC3XX_R180_AUTOCORRECTENABLE},
3901        {0xa1, 0x01, 0x0180},                           /* AutoCorrectEnable */
3902        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
3903/* Gains */
3904        {0xa0, 0x40, ZC3XX_R116_RGAIN},
3905        {0xa0, 0x40, ZC3XX_R117_GGAIN},
3906        {0xa0, 0x40, ZC3XX_R118_BGAIN},
3907
3908        {0xa0, 0x00, 0x0007},                   /* AutoCorrectEnable */
3909        {0xa0, 0xff, ZC3XX_R018_FRAMELOST},     /* Frame adjust */
3910        {}
3911};
3912static const struct usb_action pas106b_50HZ[] = {
3913        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3914        {0xa0, 0x06, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,06,cc */
3915        {0xa0, 0x54, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,54,cc */
3916        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3917        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3918        {0xa0, 0x87, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,87,cc */
3919        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},      /* 01,8c,10,cc */
3920        {0xa0, 0x30, ZC3XX_R18F_AEUNFREEZE},    /* 01,8f,30,cc */
3921        {0xaa, 0x03, 0x0021},                   /* 00,03,21,aa */
3922        {0xaa, 0x04, 0x000c},                   /* 00,04,0c,aa */
3923        {0xaa, 0x05, 0x0002},                   /* 00,05,02,aa */
3924        {0xaa, 0x07, 0x001c},                   /* 00,07,1c,aa */
3925        {0xa0, 0x04, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,04,cc */
3926        {}
3927};
3928static const struct usb_action pas106b_60HZ[] = {
3929        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3930        {0xa0, 0x06, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,06,cc */
3931        {0xa0, 0x2e, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,2e,cc */
3932        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3933        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3934        {0xa0, 0x71, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,71,cc */
3935        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},      /* 01,8c,10,cc */
3936        {0xa0, 0x30, ZC3XX_R18F_AEUNFREEZE},    /* 01,8f,30,cc */
3937        {0xaa, 0x03, 0x001c},                   /* 00,03,1c,aa */
3938        {0xaa, 0x04, 0x0004},                   /* 00,04,04,aa */
3939        {0xaa, 0x05, 0x0001},                   /* 00,05,01,aa */
3940        {0xaa, 0x07, 0x00c4},                   /* 00,07,c4,aa */
3941        {0xa0, 0x04, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,04,cc */
3942        {}
3943};
3944static const struct usb_action pas106b_NoFliker[] = {
3945        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
3946        {0xa0, 0x06, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,06,cc */
3947        {0xa0, 0x50, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,50,cc */
3948        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
3949        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
3950        {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,10,cc */
3951        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},      /* 01,8c,10,cc */
3952        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},    /* 01,8f,20,cc */
3953        {0xaa, 0x03, 0x0013},                   /* 00,03,13,aa */
3954        {0xaa, 0x04, 0x0000},                   /* 00,04,00,aa */
3955        {0xaa, 0x05, 0x0001},                   /* 00,05,01,aa */
3956        {0xaa, 0x07, 0x0030},                   /* 00,07,30,aa */
3957        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
3958        {}
3959};
3960
3961/* from lvWIMv.inf 046d:08a2/:08aa 2007/06/03 */
3962static const struct usb_action pas202b_Initial[] = {    /* 640x480 */
3963        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},         /* 00,00,01,cc */
3964        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
3965        {0xa0, 0x0e, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0e,cc */
3966        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},           /* 00,02,00,cc */
3967        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},        /* 00,03,02,cc */
3968        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},         /* 00,04,80,cc */
3969        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},       /* 00,05,01,cc */
3970        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},        /* 00,06,e0,cc */
3971        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},       /* 00,01,01,cc */
3972        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,03,cc */
3973        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,01,cc */
3974        {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},       /* 00,8d,08,cc */
3975        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},          /* 00,98,00,cc */
3976        {0xa0, 0x03, ZC3XX_R09A_WINXSTARTLOW},          /* 00,9a,03,cc */
3977        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},             /* 01,1a,00,cc */
3978        {0xa0, 0x03, ZC3XX_R11C_FIRSTXLOW},             /* 01,1c,03,cc */
3979        {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},         /* 00,9b,01,cc */
3980        {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},          /* 00,9c,e6,cc */
3981        {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},          /* 00,9d,02,cc */
3982        {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},           /* 00,9e,86,cc */
3983        {0xaa, 0x02, 0x0002},                   /* 00,02,04,aa --> 02 */
3984        {0xaa, 0x07, 0x0006},                           /* 00,07,06,aa */
3985        {0xaa, 0x08, 0x0002},                           /* 00,08,02,aa */
3986        {0xaa, 0x09, 0x0006},                           /* 00,09,06,aa */
3987        {0xaa, 0x0a, 0x0001},                           /* 00,0a,01,aa */
3988        {0xaa, 0x0b, 0x0001},                           /* 00,0b,01,aa */
3989        {0xaa, 0x0c, 0x0006},
3990        {0xaa, 0x0d, 0x0000},                           /* 00,0d,00,aa */
3991        {0xaa, 0x10, 0x0000},                           /* 00,10,00,aa */
3992        {0xaa, 0x12, 0x0005},                           /* 00,12,05,aa */
3993        {0xaa, 0x13, 0x0063},                           /* 00,13,63,aa */
3994        {0xaa, 0x15, 0x0070},                           /* 00,15,70,aa */
3995        {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},      /* 01,01,b7,cc */
3996        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},         /* 01,00,0d,cc */
3997        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},             /* 01,89,06,cc */
3998        {0xa0, 0x00, 0x01ad},                           /* 01,ad,00,cc */
3999        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},         /* 01,c5,03,cc */
4000        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},           /* 01,cb,13,cc */
4001        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},        /* 02,50,08,cc */
4002        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},          /* 03,01,08,cc */
4003        {0xa0, 0x70, ZC3XX_R18D_YTARGET},               /* 01,8d,70,cc */
4004        {}
4005};
4006static const struct usb_action pas202b_InitialScale[] = {       /* 320x240 */
4007        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},         /* 00,00,01,cc */
4008        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
4009        {0xa0, 0x0e, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,0e,cc */
4010        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},           /* 00,02,10,cc */
4011        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},        /* 00,03,02,cc */
4012        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},         /* 00,04,80,cc */
4013        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},       /* 00,05,01,cc */
4014        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4015        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},       /* 00,01,01,cc */
4016        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,03,cc */
4017        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,01,cc */
4018        {0xa0, 0x08, ZC3XX_R08D_COMPABILITYMODE},       /* 00,8d,08,cc */
4019        {0xa0, 0x08, ZC3XX_R098_WINYSTARTLOW},          /* 00,98,08,cc */
4020        {0xa0, 0x02, ZC3XX_R09A_WINXSTARTLOW},          /* 00,9a,02,cc */
4021        {0xa0, 0x08, ZC3XX_R11A_FIRSTYLOW},             /* 01,1a,08,cc */
4022        {0xa0, 0x02, ZC3XX_R11C_FIRSTXLOW},             /* 01,1c,02,cc */
4023        {0xa0, 0x01, ZC3XX_R09B_WINHEIGHTHIGH},         /* 00,9b,01,cc */
4024        {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
4025        {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},          /* 00,9d,02,cc */
4026        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},           /* 00,9e,88,cc */
4027        {0xaa, 0x02, 0x0002},                           /* 00,02,02,aa */
4028        {0xaa, 0x07, 0x0006},                           /* 00,07,06,aa */
4029        {0xaa, 0x08, 0x0002},                           /* 00,08,02,aa */
4030        {0xaa, 0x09, 0x0006},                           /* 00,09,06,aa */
4031        {0xaa, 0x0a, 0x0001},                           /* 00,0a,01,aa */
4032        {0xaa, 0x0b, 0x0001},                           /* 00,0b,01,aa */
4033        {0xaa, 0x0c, 0x0006},
4034        {0xaa, 0x0d, 0x0000},                           /* 00,0d,00,aa */
4035        {0xaa, 0x10, 0x0000},                           /* 00,10,00,aa */
4036        {0xaa, 0x12, 0x0005},                           /* 00,12,05,aa */
4037        {0xaa, 0x13, 0x0063},                           /* 00,13,63,aa */
4038        {0xaa, 0x15, 0x0070},                           /* 00,15,70,aa */
4039        {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},      /* 01,01,37,cc */
4040        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},         /* 01,00,0d,cc */
4041        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},             /* 01,89,06,cc */
4042        {0xa0, 0x00, 0x01ad},                           /* 01,ad,00,cc */
4043        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},         /* 01,c5,03,cc */
4044        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},           /* 01,cb,13,cc */
4045        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},        /* 02,50,08,cc */
4046        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},          /* 03,01,08,cc */
4047        {0xa0, 0x70, ZC3XX_R18D_YTARGET},               /* 01,8d,70,cc */
4048        {0xa0, 0xff, ZC3XX_R097_WINYSTARTHIGH},
4049        {0xa0, 0xfe, ZC3XX_R098_WINYSTARTLOW},
4050        {}
4051};
4052static const struct usb_action pas202b_50HZ[] = {
4053        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},         /* 00,19,00,cc */
4054        {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},            /* 00,87,20,cc */
4055        {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},            /* 00,88,21,cc */
4056        {0xaa, 0x20, 0x0002},                           /* 00,20,02,aa */
4057        {0xaa, 0x21, 0x001b},
4058        {0xaa, 0x03, 0x0044},                           /* 00,03,44,aa */
4059        {0xaa, 0x04, 0x0008},
4060        {0xaa, 0x05, 0x001b},
4061        {0xaa, 0x0e, 0x0001},                           /* 00,0e,01,aa */
4062        {0xaa, 0x0f, 0x0000},                           /* 00,0f,00,aa */
4063        {0xa0, 0x1c, ZC3XX_R1A9_DIGITALLIMITDIFF},
4064        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
4065        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
4066        {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
4067        {0xa0, 0x1b, ZC3XX_R192_EXPOSURELIMITLOW},
4068        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
4069        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
4070        {0xa0, 0x4d, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,4d,cc */
4071        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4072        {0xa0, 0x1b, ZC3XX_R18F_AEUNFREEZE},
4073        {0xa0, 0x44, ZC3XX_R01D_HSYNC_0},               /* 00,1d,44,cc */
4074        {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1},               /* 00,1e,6f,cc */
4075        {0xa0, 0xad, ZC3XX_R01F_HSYNC_2},               /* 00,1f,ad,cc */
4076        {0xa0, 0xeb, ZC3XX_R020_HSYNC_3},               /* 00,20,eb,cc */
4077        {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},            /* 00,87,0f,cc */
4078        {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},            /* 00,88,0e,cc */
4079        {}
4080};
4081static const struct usb_action pas202b_50HZScale[] = {
4082        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},         /* 00,19,00,cc */
4083        {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},            /* 00,87,20,cc */
4084        {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},            /* 00,88,21,cc */
4085        {0xaa, 0x20, 0x0004},
4086        {0xaa, 0x21, 0x003d},
4087        {0xaa, 0x03, 0x0041},                           /* 00,03,41,aa */
4088        {0xaa, 0x04, 0x0010},
4089        {0xaa, 0x05, 0x003d},
4090        {0xaa, 0x0e, 0x0001},                           /* 00,0e,01,aa */
4091        {0xaa, 0x0f, 0x0000},                           /* 00,0f,00,aa */
4092        {0xa0, 0x1c, ZC3XX_R1A9_DIGITALLIMITDIFF},
4093        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
4094        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
4095        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
4096        {0xa0, 0x3d, ZC3XX_R192_EXPOSURELIMITLOW},
4097        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
4098        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
4099        {0xa0, 0x9b, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,9b,cc */
4100        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4101        {0xa0, 0x1b, ZC3XX_R18F_AEUNFREEZE},
4102        {0xa0, 0x41, ZC3XX_R01D_HSYNC_0},               /* 00,1d,41,cc */
4103        {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1},               /* 00,1e,6f,cc */
4104        {0xa0, 0xad, ZC3XX_R01F_HSYNC_2},               /* 00,1f,ad,cc */
4105        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,20,ff,cc */
4106        {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},            /* 00,87,0f,cc */
4107        {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},            /* 00,88,0e,cc */
4108        {}
4109};
4110static const struct usb_action pas202b_60HZ[] = {
4111        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},         /* 00,19,00,cc */
4112        {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},            /* 00,87,20,cc */
4113        {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},            /* 00,88,21,cc */
4114        {0xaa, 0x20, 0x0002},                           /* 00,20,02,aa */
4115        {0xaa, 0x21, 0x0000},                           /* 00,21,00,aa */
4116        {0xaa, 0x03, 0x0045},                           /* 00,03,45,aa */
4117        {0xaa, 0x04, 0x0008},                           /* 00,04,08,aa */
4118        {0xaa, 0x05, 0x0000},                           /* 00,05,00,aa */
4119        {0xaa, 0x0e, 0x0001},                           /* 00,0e,01,aa */
4120        {0xaa, 0x0f, 0x0000},                           /* 00,0f,00,aa */
4121        {0xa0, 0x1c, ZC3XX_R1A9_DIGITALLIMITDIFF},
4122        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
4123        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
4124        {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
4125        {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
4126        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
4127        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
4128        {0xa0, 0x40, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,40,cc */
4129        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4130        {0xa0, 0x1b, ZC3XX_R18F_AEUNFREEZE},
4131        {0xa0, 0x45, ZC3XX_R01D_HSYNC_0},               /* 00,1d,45,cc */
4132        {0xa0, 0x8e, ZC3XX_R01E_HSYNC_1},               /* 00,1e,8e,cc */
4133        {0xa0, 0xc1, ZC3XX_R01F_HSYNC_2},               /* 00,1f,c1,cc */
4134        {0xa0, 0xf5, ZC3XX_R020_HSYNC_3},               /* 00,20,f5,cc */
4135        {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},            /* 00,87,0f,cc */
4136        {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},            /* 00,88,0e,cc */
4137        {}
4138};
4139static const struct usb_action pas202b_60HZScale[] = {
4140        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},         /* 00,19,00,cc */
4141        {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},            /* 00,87,20,cc */
4142        {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},            /* 00,88,21,cc */
4143        {0xaa, 0x20, 0x0004},
4144        {0xaa, 0x21, 0x0008},
4145        {0xaa, 0x03, 0x0042},                           /* 00,03,42,aa */
4146        {0xaa, 0x04, 0x0010},
4147        {0xaa, 0x05, 0x0008},
4148        {0xaa, 0x0e, 0x0001},                           /* 00,0e,01,aa */
4149        {0xaa, 0x0f, 0x0000},                           /* 00,0f,00,aa */
4150        {0xa0, 0x1c, ZC3XX_R1A9_DIGITALLIMITDIFF},
4151        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc */
4152        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
4153        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
4154        {0xa0, 0x08, ZC3XX_R192_EXPOSURELIMITLOW},
4155        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
4156        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
4157        {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,81,cc */
4158        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4159        {0xa0, 0x1b, ZC3XX_R18F_AEUNFREEZE},
4160        {0xa0, 0x42, ZC3XX_R01D_HSYNC_0},               /* 00,1d,42,cc */
4161        {0xa0, 0x6f, ZC3XX_R01E_HSYNC_1},               /* 00,1e,6f,cc */
4162        {0xa0, 0xaf, ZC3XX_R01F_HSYNC_2},               /* 00,1f,af,cc */
4163        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,20,ff,cc */
4164        {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},            /* 00,87,0f,cc */
4165        {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},            /* 00,88,0e,cc */
4166        {}
4167};
4168static const struct usb_action pas202b_NoFliker[] = {
4169        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},         /* 00,19,00,cc */
4170        {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},            /* 00,87,20,cc */
4171        {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},            /* 00,88,21,cc */
4172        {0xaa, 0x20, 0x0002},                           /* 00,20,02,aa */
4173        {0xaa, 0x21, 0x0006},
4174        {0xaa, 0x03, 0x0040},                           /* 00,03,40,aa */
4175        {0xaa, 0x04, 0x0008},                           /* 00,04,08,aa */
4176        {0xaa, 0x05, 0x0006},
4177        {0xaa, 0x0e, 0x0001},                           /* 00,0e,01,aa */
4178        {0xaa, 0x0f, 0x0000},                           /* 00,0f,00,aa */
4179        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
4180        {0xa0, 0x02, ZC3XX_R191_EXPOSURELIMITMID},
4181        {0xa0, 0x06, ZC3XX_R192_EXPOSURELIMITLOW},
4182        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
4183        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
4184        {0xa0, 0x01, ZC3XX_R197_ANTIFLICKERLOW},
4185        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},              /* 01,8c,10,cc */
4186        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},            /* 01,8f,20,cc */
4187        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,00,cc */
4188        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4189        {0xa0, 0x40, ZC3XX_R01D_HSYNC_0},               /* 00,1d,40,cc */
4190        {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},               /* 00,1e,60,cc */
4191        {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},               /* 00,1f,90,cc */
4192        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,20,ff,cc */
4193        {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},            /* 00,87,0f,cc */
4194        {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},            /* 00,88,0e,cc */
4195        {}
4196};
4197static const struct usb_action pas202b_NoFlikerScale[] = {
4198        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},         /* 00,19,00,cc */
4199        {0xa0, 0x20, ZC3XX_R087_EXPTIMEMID},            /* 00,87,20,cc */
4200        {0xa0, 0x21, ZC3XX_R088_EXPTIMELOW},            /* 00,88,21,cc */
4201        {0xaa, 0x20, 0x0004},
4202        {0xaa, 0x21, 0x000c},
4203        {0xaa, 0x03, 0x0040},                           /* 00,03,40,aa */
4204        {0xaa, 0x04, 0x0010},
4205        {0xaa, 0x05, 0x000c},
4206        {0xaa, 0x0e, 0x0001},                           /* 00,0e,01,aa */
4207        {0xaa, 0x0f, 0x0000},                           /* 00,0f,00,aa */
4208        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc */
4209        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
4210        {0xa0, 0x0c, ZC3XX_R192_EXPOSURELIMITLOW},
4211        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc */
4212        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc */
4213        {0xa0, 0x02, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,02,cc */
4214        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},              /* 01,8c,10,cc */
4215        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},            /* 01,8f,20,cc */
4216        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,00,cc */
4217        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4218        {0xa0, 0x40, ZC3XX_R01D_HSYNC_0},               /* 00,1d,40,cc */
4219        {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},               /* 00,1e,60,cc */
4220        {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},               /* 00,1f,90,cc */
4221        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,20,ff,cc */
4222        {0xa0, 0x0f, ZC3XX_R087_EXPTIMEMID},            /* 00,87,0f,cc */
4223        {0xa0, 0x0e, ZC3XX_R088_EXPTIMELOW},            /* 00,88,0e,cc */
4224        {}
4225};
4226
4227/* mt9v111 (mi0360soc) and pb0330 from vm30x.inf 0ac8:301b 07/02/13 */
4228static const struct usb_action mt9v111_1_Initial[] = {  /* 640x480 */
4229        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4230        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
4231        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4232        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
4233        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4234        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4235        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4236        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4237        {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4238        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4239        {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
4240        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4241        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4242        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4243        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4244        {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4245        {0xdd, 0x00, 0x0200},
4246        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4247        {0xaa, 0x01, 0x0001},
4248        {0xaa, 0x06, 0x0000},
4249        {0xaa, 0x08, 0x0483},
4250        {0xaa, 0x01, 0x0004},
4251        {0xaa, 0x08, 0x0006},
4252        {0xaa, 0x02, 0x0011},
4253        {0xaa, 0x03, 0x01e5},                   /*jfm: was 01e7*/
4254        {0xaa, 0x04, 0x0285},                   /*jfm: was 0287*/
4255        {0xaa, 0x07, 0x3002},
4256        {0xaa, 0x20, 0x5100},
4257        {0xaa, 0x35, 0x507f},
4258        {0xaa, 0x30, 0x0005},
4259        {0xaa, 0x31, 0x0000},
4260        {0xaa, 0x58, 0x0078},
4261        {0xaa, 0x62, 0x0411},
4262        {0xaa, 0x2b, 0x007f},
4263        {0xaa, 0x2c, 0x007f},                   /*jfm: was 0030*/
4264        {0xaa, 0x2d, 0x007f},                   /*jfm: was 0030*/
4265        {0xaa, 0x2e, 0x007f},                   /*jfm: was 0030*/
4266        {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4267        {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},
4268        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4269        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4270        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4271        {0xa0, 0x09, 0x01ad},                   /*jfm: was 00*/
4272        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4273        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4274        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4275        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4276        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
4277        {0xa0, 0x6c, ZC3XX_R18D_YTARGET},
4278        {0xa0, 0x61, ZC3XX_R116_RGAIN},
4279        {0xa0, 0x65, ZC3XX_R118_BGAIN},
4280        {}
4281};
4282static const struct usb_action mt9v111_1_InitialScale[] = {     /* 320x240 */
4283        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4284        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
4285        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4286        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
4287        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4288        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4289        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4290        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4291        {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4292        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4293        {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
4294        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4295        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4296        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4297        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4298        {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4299        {0xdd, 0x00, 0x0200},
4300        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4301        {0xaa, 0x01, 0x0001},
4302        {0xaa, 0x06, 0x0000},
4303        {0xaa, 0x08, 0x0483},
4304        {0xaa, 0x01, 0x0004},
4305        {0xaa, 0x08, 0x0006},
4306        {0xaa, 0x02, 0x0011},
4307        {0xaa, 0x03, 0x01e7},
4308        {0xaa, 0x04, 0x0287},
4309        {0xaa, 0x07, 0x3002},
4310        {0xaa, 0x20, 0x5100},
4311        {0xaa, 0x35, 0x007f},                   /*jfm: was 0050*/
4312        {0xaa, 0x30, 0x0005},
4313        {0xaa, 0x31, 0x0000},
4314        {0xaa, 0x58, 0x0078},
4315        {0xaa, 0x62, 0x0411},
4316        {0xaa, 0x2b, 0x007f},                   /*jfm: was 28*/
4317        {0xaa, 0x2c, 0x007f},                   /*jfm: was 30*/
4318        {0xaa, 0x2d, 0x007f},                   /*jfm: was 30*/
4319        {0xaa, 0x2e, 0x007f},                   /*jfm: was 28*/
4320        {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4321        {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},
4322        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4323        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4324        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4325        {0xa0, 0x09, 0x01ad},                   /*jfm: was 00*/
4326        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4327        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4328        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4329        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4330        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
4331        {0xa0, 0x6c, ZC3XX_R18D_YTARGET},
4332        {0xa0, 0x61, ZC3XX_R116_RGAIN},
4333        {0xa0, 0x65, ZC3XX_R118_BGAIN},
4334        {}
4335};
4336static const struct usb_action mt9v111_1_AE50HZ[] = {
4337        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4338        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4339        {0xbb, 0x00, 0x0562},
4340        {0xbb, 0x01, 0x09aa},
4341        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4342        {0xa0, 0x03, ZC3XX_R191_EXPOSURELIMITMID},
4343        {0xa0, 0x9b, ZC3XX_R192_EXPOSURELIMITLOW},
4344        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4345        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4346        {0xa0, 0x47, ZC3XX_R197_ANTIFLICKERLOW},
4347        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4348        {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4349        {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4350        {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4351        {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},
4352        {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},
4353        {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},
4354        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4355        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4356        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4357        {}
4358};
4359static const struct usb_action mt9v111_1_AE50HZScale[] = {
4360        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4361        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4362        {0xbb, 0x00, 0x0509},
4363        {0xbb, 0x01, 0x0934},
4364        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4365        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4366        {0xa0, 0xd2, ZC3XX_R192_EXPOSURELIMITLOW},
4367        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4368        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4369        {0xa0, 0x9a, ZC3XX_R197_ANTIFLICKERLOW},
4370        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4371        {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4372        {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4373        {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4374        {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4375        {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4376        {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4377        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4378        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4379        {}
4380};
4381static const struct usb_action mt9v111_1_AE60HZ[] = {
4382        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4383        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4384        {0xaa, 0x05, 0x003d},
4385        {0xaa, 0x09, 0x016e},
4386        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4387        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4388        {0xa0, 0xdd, ZC3XX_R192_EXPOSURELIMITLOW},
4389        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4390        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4391        {0xa0, 0x3d, ZC3XX_R197_ANTIFLICKERLOW},
4392        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4393        {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4394        {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4395        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4396        {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},
4397        {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},
4398        {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},
4399        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4400        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4401        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4402        {}
4403};
4404static const struct usb_action mt9v111_1_AE60HZScale[] = {
4405        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4406        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4407        {0xbb, 0x00, 0x0509},
4408        {0xbb, 0x01, 0x0983},
4409        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4410        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4411        {0xa0, 0x8f, ZC3XX_R192_EXPOSURELIMITLOW},
4412        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4413        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4414        {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW},
4415        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4416        {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4417        {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4418        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4419        {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4420        {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4421        {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4422        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4423        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4424        {}
4425};
4426static const struct usb_action mt9v111_1_AENoFliker[] = {
4427        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4428        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4429        {0xbb, 0x00, 0x0509},
4430        {0xbb, 0x01, 0x0960},
4431        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4432        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4433        {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4434        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4435        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4436        {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
4437        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4438        {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4439        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4440        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4441        {0xa0, 0x09, ZC3XX_R01D_HSYNC_0},
4442        {0xa0, 0x40, ZC3XX_R01E_HSYNC_1},
4443        {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4444        {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4445        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4446        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4447        {}
4448};
4449static const struct usb_action mt9v111_1_AENoFlikerScale[] = {
4450        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4451        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4452        {0xbb, 0x00, 0x0534},
4453        {0xbb, 0x02, 0x0960},
4454        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4455        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4456        {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4457        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4458        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4459        {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
4460        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4461        {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4462        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4463        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4464        {0xa0, 0x34, ZC3XX_R01D_HSYNC_0},
4465        {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},
4466        {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4467        {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4468        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4469        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4470        {}
4471};
4472/* from usbvm303.inf 0ac8:303b 07/03/25 (3 - tas5130c) */
4473static const struct usb_action mt9v111_3_Initial[] = {
4474        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4475        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
4476        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4477        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
4478        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4479        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4480        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4481        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4482        {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4483        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4484        {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
4485        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4486        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4487        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4488        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4489        {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4490        {0xdd, 0x00, 0x0200},
4491        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4492        {0xaa, 0x01, 0x0001},           /* select IFP/SOC registers */
4493        {0xaa, 0x06, 0x0000},           /* operating mode control */
4494        {0xaa, 0x08, 0x0483},           /* output format control */
4495                                        /* H red first, V red or blue first,
4496                                         * raw Bayer, auto flicker */
4497        {0xaa, 0x01, 0x0004},           /* select sensor core registers */
4498        {0xaa, 0x08, 0x0006},           /* row start */
4499        {0xaa, 0x02, 0x0011},           /* column start */
4500        {0xaa, 0x03, 0x01e5},           /* window height - 1 */
4501        {0xaa, 0x04, 0x0285},           /* window width - 1 */
4502        {0xaa, 0x07, 0x3002},           /* output control */
4503        {0xaa, 0x20, 0x1100},           /* read mode: bits 8 & 12 (?) */
4504        {0xaa, 0x35, 0x007f},           /* global gain */
4505        {0xaa, 0x30, 0x0005},
4506        {0xaa, 0x31, 0x0000},
4507        {0xaa, 0x58, 0x0078},
4508        {0xaa, 0x62, 0x0411},
4509        {0xaa, 0x2b, 0x007f},           /* green1 gain */
4510        {0xaa, 0x2c, 0x007f},           /* blue gain */
4511        {0xaa, 0x2d, 0x007f},           /* red gain */
4512        {0xaa, 0x2e, 0x007f},           /* green2 gain */
4513        {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4514        {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
4515        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4516        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4517        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4518        {0xa0, 0x00, 0x01ad},
4519        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4520        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4521        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4522        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4523        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
4524        {0xa0, 0x80, ZC3XX_R18D_YTARGET},
4525        {0xa0, 0x61, ZC3XX_R116_RGAIN},
4526        {0xa0, 0x65, ZC3XX_R118_BGAIN},
4527        {}
4528};
4529static const struct usb_action mt9v111_3_InitialScale[] = {
4530        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4531        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
4532        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4533        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
4534        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4535        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4536        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4537        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4538        {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4539        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4540        {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
4541        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4542        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4543        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4544        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4545        {0xa0, 0xdc, ZC3XX_R08B_I2CDEVICEADDR},
4546        {0xdd, 0x00, 0x0200},
4547        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4548        {0xaa, 0x01, 0x0001},
4549        {0xaa, 0x06, 0x0000},
4550        {0xaa, 0x08, 0x0483},
4551        {0xaa, 0x01, 0x0004},
4552        {0xaa, 0x08, 0x0006},
4553        {0xaa, 0x02, 0x0011},
4554        {0xaa, 0x03, 0x01e7},
4555        {0xaa, 0x04, 0x0287},
4556        {0xaa, 0x07, 0x3002},
4557        {0xaa, 0x20, 0x1100},
4558        {0xaa, 0x35, 0x007f},
4559        {0xaa, 0x30, 0x0005},
4560        {0xaa, 0x31, 0x0000},
4561        {0xaa, 0x58, 0x0078},
4562        {0xaa, 0x62, 0x0411},
4563        {0xaa, 0x2b, 0x007f},
4564        {0xaa, 0x2c, 0x007f},
4565        {0xaa, 0x2d, 0x007f},
4566        {0xaa, 0x2e, 0x007f},
4567        {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4568        {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
4569        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4570        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4571        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4572        {0xa0, 0x00, 0x01ad},
4573        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4574        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4575        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4576        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4577        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
4578        {0xa0, 0x80, ZC3XX_R18D_YTARGET},
4579        {0xa0, 0x61, ZC3XX_R116_RGAIN},
4580        {0xa0, 0x65, ZC3XX_R118_BGAIN},
4581        {}
4582};
4583static const struct usb_action mt9v111_3_AE50HZ[] = {
4584        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4585        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4586        {0xaa, 0x05, 0x0009},           /* horizontal blanking */
4587        {0xaa, 0x09, 0x01ce},           /* shutter width */
4588        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4589        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4590        {0xa0, 0xd2, ZC3XX_R192_EXPOSURELIMITLOW},
4591        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4592        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4593        {0xa0, 0x9a, ZC3XX_R197_ANTIFLICKERLOW},
4594        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4595        {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4596        {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4597        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4598        {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4599        {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4600        {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4601        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4602        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4603        {}
4604};
4605static const struct usb_action mt9v111_3_AE50HZScale[] = {
4606        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4607        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4608        {0xaa, 0x05, 0x0009},
4609        {0xaa, 0x09, 0x01ce},
4610        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4611        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4612        {0xa0, 0xd2, ZC3XX_R192_EXPOSURELIMITLOW},
4613        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4614        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4615        {0xa0, 0x9a, ZC3XX_R197_ANTIFLICKERLOW},
4616        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4617        {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4618        {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4619        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4620        {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4621        {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4622        {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4623        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4624        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4625        {}
4626};
4627static const struct usb_action mt9v111_3_AE60HZ[] = {
4628        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4629        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4630        {0xaa, 0x05, 0x0009},
4631        {0xaa, 0x09, 0x0083},
4632        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4633        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4634        {0xa0, 0x8f, ZC3XX_R192_EXPOSURELIMITLOW},
4635        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4636        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4637        {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW},
4638        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4639        {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4640        {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4641        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4642        {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4643        {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4644        {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4645        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4646        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4647        {}
4648};
4649static const struct usb_action mt9v111_3_AE60HZScale[] = {
4650        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4651        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4652        {0xaa, 0x05, 0x0009},
4653        {0xaa, 0x09, 0x0083},
4654        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4655        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4656        {0xa0, 0x8f, ZC3XX_R192_EXPOSURELIMITLOW},
4657        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4658        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4659        {0xa0, 0x81, ZC3XX_R197_ANTIFLICKERLOW},
4660        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4661        {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4662        {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4663        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
4664        {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4665        {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1},
4666        {0xa0, 0xf9, ZC3XX_R01F_HSYNC_2},
4667        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4668        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4669        {}
4670};
4671static const struct usb_action mt9v111_3_AENoFliker[] = {
4672        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4673        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4674        {0xaa, 0x05, 0x0034},
4675        {0xaa, 0x09, 0x0260},
4676        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4677        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4678        {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4679        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4680        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4681        {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
4682        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4683        {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4684        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4685        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4686        {0xa0, 0x34, ZC3XX_R01D_HSYNC_0},
4687        {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},
4688        {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4689        {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4690        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4691        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4692        {}
4693};
4694static const struct usb_action mt9v111_3_AENoFlikerScale[] = {
4695        {0xa0, 0x00, ZC3XX_R180_AUTOCORRECTENABLE},
4696        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4697        {0xaa, 0x05, 0x0034},
4698        {0xaa, 0x09, 0x0260},
4699        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4700        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4701        {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4702        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4703        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4704        {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
4705        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4706        {0xa0, 0x1c, ZC3XX_R18F_AEUNFREEZE},
4707        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4708        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4709        {0xa0, 0x34, ZC3XX_R01D_HSYNC_0},
4710        {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},
4711        {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4712        {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4713        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4714        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},
4715        {}
4716};
4717
4718static const struct usb_action pb0330_Initial[] = {     /* 640x480 */
4719        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4720        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* 00 */
4721        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4722        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},
4723        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4724        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4725        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4726        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4727        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4728        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4729        {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
4730        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4731        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4732        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4733        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4734        {0xdd, 0x00, 0x0200},
4735        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4736        {0xaa, 0x01, 0x0006},
4737        {0xaa, 0x02, 0x0011},
4738        {0xaa, 0x03, 0x01e5},                   /*jfm: was 1e7*/
4739        {0xaa, 0x04, 0x0285},                   /*jfm: was 0287*/
4740        {0xaa, 0x06, 0x0003},
4741        {0xaa, 0x07, 0x3002},
4742        {0xaa, 0x20, 0x1100},
4743        {0xaa, 0x2f, 0xf7b0},
4744        {0xaa, 0x30, 0x0005},
4745        {0xaa, 0x31, 0x0000},
4746        {0xaa, 0x34, 0x0100},
4747        {0xaa, 0x35, 0x0060},
4748        {0xaa, 0x3d, 0x068f},
4749        {0xaa, 0x40, 0x01e0},
4750        {0xaa, 0x58, 0x0078},
4751        {0xaa, 0x62, 0x0411},
4752        {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4753        {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
4754        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4755        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4756        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4757        {0xa0, 0x09, 0x01ad},                   /*jfm: was 00 */
4758        {0xa0, 0x15, 0x01ae},
4759        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4760        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4761        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4762        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4763        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
4764        {0xa0, 0x78, ZC3XX_R18D_YTARGET},       /*jfm: was 6c*/
4765        {}
4766};
4767static const struct usb_action pb0330_InitialScale[] = {        /* 320x240 */
4768        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
4769        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},  /* 00 */
4770        {0xa0, 0x0a, ZC3XX_R010_CMOSSENSORSELECT},
4771        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},
4772        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
4773        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
4774        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
4775        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
4776        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
4777        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4778        {0xa0, 0x07, ZC3XX_R012_VIDEOCONTROLFUNC},
4779        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},
4780        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},
4781        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},
4782        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},
4783        {0xdd, 0x00, 0x0200},
4784        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4785        {0xaa, 0x01, 0x0006},
4786        {0xaa, 0x02, 0x0011},
4787        {0xaa, 0x03, 0x01e7},
4788        {0xaa, 0x04, 0x0287},
4789        {0xaa, 0x06, 0x0003},
4790        {0xaa, 0x07, 0x3002},
4791        {0xaa, 0x20, 0x1100},
4792        {0xaa, 0x2f, 0xf7b0},
4793        {0xaa, 0x30, 0x0005},
4794        {0xaa, 0x31, 0x0000},
4795        {0xaa, 0x34, 0x0100},
4796        {0xaa, 0x35, 0x0060},
4797        {0xaa, 0x3d, 0x068f},
4798        {0xaa, 0x40, 0x01e0},
4799        {0xaa, 0x58, 0x0078},
4800        {0xaa, 0x62, 0x0411},
4801        {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},
4802        {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
4803        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
4804        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
4805        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
4806        {0xa0, 0x09, 0x01ad},
4807        {0xa0, 0x15, 0x01ae},
4808        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
4809        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
4810        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
4811        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
4812        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},
4813        {0xa0, 0x78, ZC3XX_R18D_YTARGET},       /*jfm: was 6c*/
4814        {}
4815};
4816static const struct usb_action pb0330_50HZ[] = {
4817        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4818        {0xbb, 0x00, 0x055c},
4819        {0xbb, 0x01, 0x09aa},
4820        {0xbb, 0x00, 0x1001},
4821        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4822        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4823        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4824        {0xa0, 0xc4, ZC3XX_R192_EXPOSURELIMITLOW},
4825        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4826        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4827        {0xa0, 0x47, ZC3XX_R197_ANTIFLICKERLOW},
4828        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4829        {0xa0, 0x1a, ZC3XX_R18F_AEUNFREEZE},
4830        {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4831        {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4832        {0xa0, 0x5c, ZC3XX_R01D_HSYNC_0},
4833        {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},
4834        {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},
4835        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4836        {}
4837};
4838static const struct usb_action pb0330_50HZScale[] = {
4839        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4840        {0xbb, 0x00, 0x0566},
4841        {0xbb, 0x02, 0x09b2},
4842        {0xbb, 0x00, 0x1002},
4843        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4844        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4845        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4846        {0xa0, 0x8c, ZC3XX_R192_EXPOSURELIMITLOW},
4847        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4848        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4849        {0xa0, 0x8a, ZC3XX_R197_ANTIFLICKERLOW},
4850        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4851        {0xa0, 0x1a, ZC3XX_R18F_AEUNFREEZE},
4852        {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4853        {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4854        {0xa0, 0xd7, ZC3XX_R01D_HSYNC_0},
4855        {0xa0, 0xf0, ZC3XX_R01E_HSYNC_1},
4856        {0xa0, 0xf8, ZC3XX_R01F_HSYNC_2},
4857        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},
4858        {}
4859};
4860static const struct usb_action pb0330_60HZ[] = {
4861        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4862        {0xbb, 0x00, 0x0535},
4863        {0xbb, 0x01, 0x0974},
4864        {0xbb, 0x00, 0x1001},
4865        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4866        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4867        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4868        {0xa0, 0xfe, ZC3XX_R192_EXPOSURELIMITLOW},
4869        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4870        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4871        {0xa0, 0x3e, ZC3XX_R197_ANTIFLICKERLOW},
4872        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4873        {0xa0, 0x1a, ZC3XX_R18F_AEUNFREEZE},
4874        {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4875        {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4876        {0xa0, 0x35, ZC3XX_R01D_HSYNC_0},
4877        {0xa0, 0x50, ZC3XX_R01E_HSYNC_1},
4878        {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4879        {0xa0, 0xd0, ZC3XX_R020_HSYNC_3},
4880        {}
4881};
4882static const struct usb_action pb0330_60HZScale[] = {
4883        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4884        {0xbb, 0x00, 0x0535},
4885        {0xbb, 0x02, 0x096c},
4886        {0xbb, 0x00, 0x1002},
4887        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4888        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4889        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4890        {0xa0, 0xc0, ZC3XX_R192_EXPOSURELIMITLOW},
4891        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4892        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4893        {0xa0, 0x7c, ZC3XX_R197_ANTIFLICKERLOW},
4894        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},
4895        {0xa0, 0x1a, ZC3XX_R18F_AEUNFREEZE},
4896        {0xa0, 0x14, ZC3XX_R1A9_DIGITALLIMITDIFF},
4897        {0xa0, 0x66, ZC3XX_R1AA_DIGITALGAINSTEP},
4898        {0xa0, 0x35, ZC3XX_R01D_HSYNC_0},
4899        {0xa0, 0x50, ZC3XX_R01E_HSYNC_1},
4900        {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4901        {0xa0, 0xd0, ZC3XX_R020_HSYNC_3},
4902        {}
4903};
4904static const struct usb_action pb0330_NoFliker[] = {
4905        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4906        {0xbb, 0x00, 0x0509},
4907        {0xbb, 0x02, 0x0940},
4908        {0xbb, 0x00, 0x1002},
4909        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4910        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4911        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4912        {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4913        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4914        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4915        {0xa0, 0x01, ZC3XX_R197_ANTIFLICKERLOW},
4916        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
4917        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
4918        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4919        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4920        {0xa0, 0x09, ZC3XX_R01D_HSYNC_0},
4921        {0xa0, 0x40, ZC3XX_R01E_HSYNC_1},
4922        {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4923        {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4924        {}
4925};
4926static const struct usb_action pb0330_NoFlikerScale[] = {
4927        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS},
4928        {0xbb, 0x00, 0x0535},
4929        {0xbb, 0x01, 0x0980},
4930        {0xbb, 0x00, 0x1001},
4931        {0xa0, 0x60, ZC3XX_R11D_GLOBALGAIN},
4932        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},
4933        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
4934        {0xa0, 0xf0, ZC3XX_R192_EXPOSURELIMITLOW},
4935        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
4936        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
4937        {0xa0, 0x01, ZC3XX_R197_ANTIFLICKERLOW},
4938        {0xa0, 0x10, ZC3XX_R18C_AEFREEZE},
4939        {0xa0, 0x20, ZC3XX_R18F_AEUNFREEZE},
4940        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF},
4941        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP},
4942        {0xa0, 0x35, ZC3XX_R01D_HSYNC_0},
4943        {0xa0, 0x60, ZC3XX_R01E_HSYNC_1},
4944        {0xa0, 0x90, ZC3XX_R01F_HSYNC_2},
4945        {0xa0, 0xe0, ZC3XX_R020_HSYNC_3},
4946        {}
4947};
4948
4949/* from oem9.inf */
4950static const struct usb_action po2030_Initial[] = {     /* 640x480 */
4951        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
4952        {0xa0, 0x04, ZC3XX_R002_CLOCKSELECT},   /* 00,02,04,cc */
4953        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
4954        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
4955        {0xa0, 0x04, ZC3XX_R080_HBLANKHIGH}, /* 00,80,04,cc */
4956        {0xa0, 0x05, ZC3XX_R081_HBLANKLOW}, /* 00,81,05,cc */
4957        {0xa0, 0x16, ZC3XX_R083_RGAINADDR}, /* 00,83,16,cc */
4958        {0xa0, 0x18, ZC3XX_R085_BGAINADDR}, /* 00,85,18,cc */
4959        {0xa0, 0x1a, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,1a,cc */
4960        {0xa0, 0x1b, ZC3XX_R087_EXPTIMEMID}, /* 00,87,1b,cc */
4961        {0xa0, 0x1c, ZC3XX_R088_EXPTIMELOW}, /* 00,88,1c,cc */
4962        {0xa0, 0xee, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,ee,cc */
4963        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
4964        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
4965        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
4966        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
4967        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
4968        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
4969        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc */
4970        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
4971        {0xaa, 0x8d, 0x0008},                   /* 00,8d,08,aa */
4972        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},  /* 00,98,00,cc */
4973        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},  /* 00,9a,00,cc */
4974        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},     /* 01,1a,00,cc */
4975        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},     /* 01,1c,00,cc */
4976        {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},  /* 00,9c,e6,cc */
4977        {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},   /* 00,9e,86,cc */
4978        {0xaa, 0x09, 0x00ce}, /* 00,09,ce,aa */
4979        {0xaa, 0x0b, 0x0005}, /* 00,0b,05,aa */
4980        {0xaa, 0x0d, 0x0054}, /* 00,0d,54,aa */
4981        {0xaa, 0x0f, 0x00eb}, /* 00,0f,eb,aa */
4982        {0xaa, 0x87, 0x0000}, /* 00,87,00,aa */
4983        {0xaa, 0x88, 0x0004}, /* 00,88,04,aa */
4984        {0xaa, 0x89, 0x0000}, /* 00,89,00,aa */
4985        {0xaa, 0x8a, 0x0005}, /* 00,8a,05,aa */
4986        {0xaa, 0x13, 0x0003}, /* 00,13,03,aa */
4987        {0xaa, 0x16, 0x0040}, /* 00,16,40,aa */
4988        {0xaa, 0x18, 0x0040}, /* 00,18,40,aa */
4989        {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
4990        {0xaa, 0x29, 0x00e8}, /* 00,29,e8,aa */
4991        {0xaa, 0x45, 0x0045}, /* 00,45,45,aa */
4992        {0xaa, 0x50, 0x00ed}, /* 00,50,ed,aa */
4993        {0xaa, 0x51, 0x0025}, /* 00,51,25,aa */
4994        {0xaa, 0x52, 0x0042}, /* 00,52,42,aa */
4995        {0xaa, 0x53, 0x002f}, /* 00,53,2f,aa */
4996        {0xaa, 0x79, 0x0025}, /* 00,79,25,aa */
4997        {0xaa, 0x7b, 0x0000}, /* 00,7b,00,aa */
4998        {0xaa, 0x7e, 0x0025}, /* 00,7e,25,aa */
4999        {0xaa, 0x7f, 0x0025}, /* 00,7f,25,aa */
5000        {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
5001        {0xaa, 0x33, 0x0036}, /* 00,33,36,aa */
5002        {0xaa, 0x36, 0x0060}, /* 00,36,60,aa */
5003        {0xaa, 0x37, 0x0008}, /* 00,37,08,aa */
5004        {0xaa, 0x3b, 0x0031}, /* 00,3b,31,aa */
5005        {0xaa, 0x44, 0x000f}, /* 00,44,0f,aa */
5006        {0xaa, 0x58, 0x0002}, /* 00,58,02,aa */
5007        {0xaa, 0x66, 0x00c0}, /* 00,66,c0,aa */
5008        {0xaa, 0x67, 0x0044}, /* 00,67,44,aa */
5009        {0xaa, 0x6b, 0x00a0}, /* 00,6b,a0,aa */
5010        {0xaa, 0x6c, 0x0054}, /* 00,6c,54,aa */
5011        {0xaa, 0xd6, 0x0007}, /* 00,d6,07,aa */
5012        {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,f7,cc */
5013        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
5014        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
5015        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
5016        {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
5017        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
5018        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
5019        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
5020        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
5021        {0xa0, 0x7a, ZC3XX_R116_RGAIN}, /* 01,16,7a,cc */
5022        {0xa0, 0x4a, ZC3XX_R118_BGAIN}, /* 01,18,4a,cc */
5023        {}
5024};
5025
5026/* from oem9.inf */
5027static const struct usb_action po2030_InitialScale[] = {        /* 320x240 */
5028        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL}, /* 00,00,01,cc */
5029        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT}, /* 00,02,10,cc */
5030        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT}, /* 00,10,01,cc */
5031        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING}, /* 00,01,01,cc */
5032        {0xa0, 0x04, ZC3XX_R080_HBLANKHIGH}, /* 00,80,04,cc */
5033        {0xa0, 0x05, ZC3XX_R081_HBLANKLOW}, /* 00,81,05,cc */
5034        {0xa0, 0x16, ZC3XX_R083_RGAINADDR}, /* 00,83,16,cc */
5035        {0xa0, 0x18, ZC3XX_R085_BGAINADDR}, /* 00,85,18,cc */
5036        {0xa0, 0x1a, ZC3XX_R086_EXPTIMEHIGH}, /* 00,86,1a,cc */
5037        {0xa0, 0x1b, ZC3XX_R087_EXPTIMEMID}, /* 00,87,1b,cc */
5038        {0xa0, 0x1c, ZC3XX_R088_EXPTIMELOW}, /* 00,88,1c,cc */
5039        {0xa0, 0xee, ZC3XX_R08B_I2CDEVICEADDR}, /* 00,8b,ee,cc */
5040        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING}, /* 00,08,03,cc */
5041        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,03,cc */
5042        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,01,cc */
5043        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH}, /* 00,03,02,cc */
5044        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW}, /* 00,04,80,cc */
5045        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH}, /* 00,05,01,cc */
5046        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW}, /* 00,06,e0,cc */
5047        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
5048        {0xaa, 0x8d, 0x0008},                   /* 00,8d,08,aa */
5049        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW}, /* 00,98,00,cc */
5050        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW}, /* 00,9a,00,cc */
5051        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW}, /* 01,1a,00,cc */
5052        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW}, /* 01,1c,00,cc */
5053        {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW}, /* 00,9c,e8,cc */
5054        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW}, /* 00,9e,88,cc */
5055        {0xaa, 0x09, 0x00cc}, /* 00,09,cc,aa */
5056        {0xaa, 0x0b, 0x0005}, /* 00,0b,05,aa */
5057        {0xaa, 0x0d, 0x0058}, /* 00,0d,58,aa */
5058        {0xaa, 0x0f, 0x00ed}, /* 00,0f,ed,aa */
5059        {0xaa, 0x87, 0x0000}, /* 00,87,00,aa */
5060        {0xaa, 0x88, 0x0004}, /* 00,88,04,aa */
5061        {0xaa, 0x89, 0x0000}, /* 00,89,00,aa */
5062        {0xaa, 0x8a, 0x0005}, /* 00,8a,05,aa */
5063        {0xaa, 0x13, 0x0003}, /* 00,13,03,aa */
5064        {0xaa, 0x16, 0x0040}, /* 00,16,40,aa */
5065        {0xaa, 0x18, 0x0040}, /* 00,18,40,aa */
5066        {0xaa, 0x1d, 0x0002}, /* 00,1d,02,aa */
5067        {0xaa, 0x29, 0x00e8}, /* 00,29,e8,aa */
5068        {0xaa, 0x45, 0x0045}, /* 00,45,45,aa */
5069        {0xaa, 0x50, 0x00ed}, /* 00,50,ed,aa */
5070        {0xaa, 0x51, 0x0025}, /* 00,51,25,aa */
5071        {0xaa, 0x52, 0x0042}, /* 00,52,42,aa */
5072        {0xaa, 0x53, 0x002f}, /* 00,53,2f,aa */
5073        {0xaa, 0x79, 0x0025}, /* 00,79,25,aa */
5074        {0xaa, 0x7b, 0x0000}, /* 00,7b,00,aa */
5075        {0xaa, 0x7e, 0x0025}, /* 00,7e,25,aa */
5076        {0xaa, 0x7f, 0x0025}, /* 00,7f,25,aa */
5077        {0xaa, 0x21, 0x0000}, /* 00,21,00,aa */
5078        {0xaa, 0x33, 0x0036}, /* 00,33,36,aa */
5079        {0xaa, 0x36, 0x0060}, /* 00,36,60,aa */
5080        {0xaa, 0x37, 0x0008}, /* 00,37,08,aa */
5081        {0xaa, 0x3b, 0x0031}, /* 00,3b,31,aa */
5082        {0xaa, 0x44, 0x000f}, /* 00,44,0f,aa */
5083        {0xaa, 0x58, 0x0002}, /* 00,58,02,aa */
5084        {0xaa, 0x66, 0x00c0}, /* 00,66,c0,aa */
5085        {0xaa, 0x67, 0x0044}, /* 00,67,44,aa */
5086        {0xaa, 0x6b, 0x00a0}, /* 00,6b,a0,aa */
5087        {0xaa, 0x6c, 0x0054}, /* 00,6c,54,aa */
5088        {0xaa, 0xd6, 0x0007}, /* 00,d6,07,aa */
5089        {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION}, /* 01,01,f7,cc */
5090        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC}, /* 00,12,05,cc */
5091        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE}, /* 01,00,0d,cc */
5092        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS}, /* 01,89,06,cc */
5093        {0xa0, 0x00, 0x01ad}, /* 01,ad,00,cc */
5094        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE}, /* 01,c5,03,cc */
5095        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05}, /* 01,cb,13,cc */
5096        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE}, /* 02,50,08,cc */
5097        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS}, /* 03,01,08,cc */
5098        {0xa0, 0x7a, ZC3XX_R116_RGAIN}, /* 01,16,7a,cc */
5099        {0xa0, 0x4a, ZC3XX_R118_BGAIN}, /* 01,18,4a,cc */
5100        {}
5101};
5102
5103static const struct usb_action po2030_50HZ[] = {
5104        {0xaa, 0x8d, 0x0008}, /* 00,8d,08,aa */
5105        {0xaa, 0x1a, 0x0001}, /* 00,1a,01,aa */
5106        {0xaa, 0x1b, 0x000a}, /* 00,1b,0a,aa */
5107        {0xaa, 0x1c, 0x00b0}, /* 00,1c,b0,aa */
5108        {0xa0, 0x05, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,05,cc */
5109        {0xa0, 0x35, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,35,cc */
5110        {0xa0, 0x70, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,70,cc */
5111        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5112        {0xa0, 0x85, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,85,cc */
5113        {0xa0, 0x58, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,58,cc */
5114        {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0c,cc */
5115        {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,18,cc */
5116        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,60,cc */
5117        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
5118        {0xa0, 0x22, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,22,cc */
5119        {0xa0, 0x88, ZC3XX_R18D_YTARGET}, /* 01,8d,88,cc */
5120        {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN}, /* 01,1d,58,cc */
5121        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,42,cc */
5122        {}
5123};
5124
5125static const struct usb_action po2030_60HZ[] = {
5126        {0xaa, 0x8d, 0x0008}, /* 00,8d,08,aa */
5127        {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa */
5128        {0xaa, 0x1b, 0x00de}, /* 00,1b,de,aa */
5129        {0xaa, 0x1c, 0x0040}, /* 00,1c,40,aa */
5130        {0xa0, 0x08, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,08,cc */
5131        {0xa0, 0xae, ZC3XX_R191_EXPOSURELIMITMID}, /* 01,91,ae,cc */
5132        {0xa0, 0x80, ZC3XX_R192_EXPOSURELIMITLOW}, /* 01,92,80,cc */
5133        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5134        {0xa0, 0x6f, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,6f,cc */
5135        {0xa0, 0x20, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,20,cc */
5136        {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE}, /* 01,8c,0c,cc */
5137        {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE}, /* 01,8f,18,cc */
5138        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN}, /* 01,a8,60,cc */
5139        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,10,cc */
5140        {0xa0, 0x22, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,22,cc */
5141        {0xa0, 0x88, ZC3XX_R18D_YTARGET},               /* 01,8d,88,cc */
5142                                                        /* win: 01,8d,80 */
5143        {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN},            /* 01,1d,58,cc */
5144        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},     /* 01,80,42,cc */
5145        {}
5146};
5147
5148static const struct usb_action po2030_NoFliker[] = {
5149        {0xa0, 0x02, ZC3XX_R180_AUTOCORRECTENABLE}, /* 01,80,02,cc */
5150        {0xaa, 0x8d, 0x000d}, /* 00,8d,0d,aa */
5151        {0xaa, 0x1a, 0x0000}, /* 00,1a,00,aa */
5152        {0xaa, 0x1b, 0x0002}, /* 00,1b,02,aa */
5153        {0xaa, 0x1c, 0x0078}, /* 00,1c,78,aa */
5154        {0xaa, 0x46, 0x0000}, /* 00,46,00,aa */
5155        {0xaa, 0x15, 0x0000}, /* 00,15,00,aa */
5156        {}
5157};
5158
5159static const struct usb_action tas5130c_InitialScale[] = {      /* 320x240 */
5160        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
5161        {0xa0, 0x50, ZC3XX_R002_CLOCKSELECT},
5162        {0xa0, 0x03, ZC3XX_R008_CLOCKSETTING},
5163        {0xa0, 0x02, ZC3XX_R010_CMOSSENSORSELECT},
5164        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
5165        {0xa0, 0x00, ZC3XX_R001_SYSTEMOPERATING},
5166        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
5167        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
5168        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
5169        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
5170        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
5171        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
5172        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
5173
5174        {0xa0, 0x04, ZC3XX_R098_WINYSTARTLOW},
5175        {0xa0, 0x0f, ZC3XX_R09A_WINXSTARTLOW},
5176        {0xa0, 0x04, ZC3XX_R11A_FIRSTYLOW},
5177        {0xa0, 0x0f, ZC3XX_R11C_FIRSTXLOW},
5178        {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},
5179        {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
5180        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},
5181        {0xa0, 0x06, ZC3XX_R08D_COMPABILITYMODE},
5182        {0xa0, 0xf7, ZC3XX_R101_SENSORCORRECTION},
5183        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
5184        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
5185        {0xa0, 0x70, ZC3XX_R18D_YTARGET},
5186        {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN},
5187        {0xa0, 0x00, 0x01ad},
5188        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
5189        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
5190        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
5191        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
5192        {0xa0, 0x07, ZC3XX_R0A5_EXPOSUREGAIN},
5193        {0xa0, 0x02, ZC3XX_R0A6_EXPOSUREBLACKLVL},
5194        {}
5195};
5196static const struct usb_action tas5130c_Initial[] = {   /* 640x480 */
5197        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},
5198        {0xa0, 0x40, ZC3XX_R002_CLOCKSELECT},
5199        {0xa0, 0x00, ZC3XX_R008_CLOCKSETTING},
5200        {0xa0, 0x02, ZC3XX_R010_CMOSSENSORSELECT},
5201        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
5202        {0xa0, 0x00, ZC3XX_R001_SYSTEMOPERATING},
5203        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},
5204        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},
5205        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},
5206        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},
5207        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},
5208        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},
5209        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},
5210        {0xa0, 0x05, ZC3XX_R098_WINYSTARTLOW},
5211        {0xa0, 0x0f, ZC3XX_R09A_WINXSTARTLOW},
5212        {0xa0, 0x05, ZC3XX_R11A_FIRSTYLOW},
5213        {0xa0, 0x0f, ZC3XX_R11C_FIRSTXLOW},
5214        {0xa0, 0xe6, ZC3XX_R09C_WINHEIGHTLOW},
5215        {0xa0, 0x02, ZC3XX_R09D_WINWIDTHHIGH},
5216        {0xa0, 0x86, ZC3XX_R09E_WINWIDTHLOW},
5217        {0xa0, 0x06, ZC3XX_R08D_COMPABILITYMODE},
5218        {0xa0, 0x37, ZC3XX_R101_SENSORCORRECTION},
5219        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},
5220        {0xa0, 0x06, ZC3XX_R189_AWBSTATUS},
5221        {0xa0, 0x70, ZC3XX_R18D_YTARGET},
5222        {0xa0, 0x50, ZC3XX_R1A8_DIGITALGAIN},
5223        {0xa0, 0x00, 0x01ad},
5224        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},
5225        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},
5226        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},
5227        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},
5228        {0xa0, 0x07, ZC3XX_R0A5_EXPOSUREGAIN},
5229        {0xa0, 0x02, ZC3XX_R0A6_EXPOSUREBLACKLVL},
5230        {}
5231};
5232static const struct usb_action tas5130c_50HZ[] = {
5233        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
5234        {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5235        {0xaa, 0xa4, 0x0063}, /* 00,a4,63,aa */
5236        {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5237        {0xa0, 0x63, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,63,cc */
5238        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
5239        {0xa0, 0x04, ZC3XX_R191_EXPOSURELIMITMID},
5240        {0xa0, 0xfe, ZC3XX_R192_EXPOSURELIMITLOW},
5241        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5242        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
5243        {0xa0, 0x47, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,47,cc */
5244        {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5245        {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5246        {0xa0, 0x08, ZC3XX_R1A9_DIGITALLIMITDIFF},
5247        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
5248        {0xa0, 0xd3, ZC3XX_R01D_HSYNC_0}, /* 00,1d,d3,cc */
5249        {0xa0, 0xda, ZC3XX_R01E_HSYNC_1}, /* 00,1e,da,cc */
5250        {0xa0, 0xea, ZC3XX_R01F_HSYNC_2}, /* 00,1f,ea,cc */
5251        {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5252        {0xa0, 0x03, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,03,cc */
5253        {0xa0, 0x4c, ZC3XX_R0A0_MAXXLOW},
5254        {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
5255        {}
5256};
5257static const struct usb_action tas5130c_50HZScale[] = {
5258        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
5259        {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5260        {0xaa, 0xa4, 0x0077}, /* 00,a4,77,aa */
5261        {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5262        {0xa0, 0x77, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,77,cc */
5263        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
5264        {0xa0, 0x07, ZC3XX_R191_EXPOSURELIMITMID},
5265        {0xa0, 0xd0, ZC3XX_R192_EXPOSURELIMITLOW},
5266        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5267        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
5268        {0xa0, 0x7d, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,7d,cc */
5269        {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5270        {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5271        {0xa0, 0x08, ZC3XX_R1A9_DIGITALLIMITDIFF},
5272        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
5273        {0xa0, 0xf0, ZC3XX_R01D_HSYNC_0}, /* 00,1d,f0,cc */
5274        {0xa0, 0xf4, ZC3XX_R01E_HSYNC_1}, /* 00,1e,f4,cc */
5275        {0xa0, 0xf8, ZC3XX_R01F_HSYNC_2}, /* 00,1f,f8,cc */
5276        {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5277        {0xa0, 0x03, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,03,cc */
5278        {0xa0, 0xc0, ZC3XX_R0A0_MAXXLOW},
5279        {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
5280        {}
5281};
5282static const struct usb_action tas5130c_60HZ[] = {
5283        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
5284        {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5285        {0xaa, 0xa4, 0x0036}, /* 00,a4,36,aa */
5286        {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5287        {0xa0, 0x36, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,36,cc */
5288        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
5289        {0xa0, 0x05, ZC3XX_R191_EXPOSURELIMITMID},
5290        {0xa0, 0x54, ZC3XX_R192_EXPOSURELIMITLOW},
5291        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5292        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
5293        {0xa0, 0x3e, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,3e,cc */
5294        {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5295        {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5296        {0xa0, 0x08, ZC3XX_R1A9_DIGITALLIMITDIFF},
5297        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
5298        {0xa0, 0xca, ZC3XX_R01D_HSYNC_0}, /* 00,1d,ca,cc */
5299        {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d0,cc */
5300        {0xa0, 0xe0, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e0,cc */
5301        {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5302        {0xa0, 0x03, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,03,cc */
5303        {0xa0, 0x28, ZC3XX_R0A0_MAXXLOW},
5304        {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
5305        {}
5306};
5307static const struct usb_action tas5130c_60HZScale[] = {
5308        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
5309        {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5310        {0xaa, 0xa4, 0x0077}, /* 00,a4,77,aa */
5311        {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5312        {0xa0, 0x77, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,77,cc */
5313        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
5314        {0xa0, 0x09, ZC3XX_R191_EXPOSURELIMITMID},
5315        {0xa0, 0x47, ZC3XX_R192_EXPOSURELIMITLOW},
5316        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH}, /* 01,95,00,cc */
5317        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID}, /* 01,96,00,cc */
5318        {0xa0, 0x7d, ZC3XX_R197_ANTIFLICKERLOW}, /* 01,97,7d,cc */
5319        {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5320        {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5321        {0xa0, 0x08, ZC3XX_R1A9_DIGITALLIMITDIFF},
5322        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},
5323        {0xa0, 0xc8, ZC3XX_R01D_HSYNC_0}, /* 00,1d,c8,cc */
5324        {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d0,cc */
5325        {0xa0, 0xe0, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e0,cc */
5326        {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5327        {0xa0, 0x03, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,03,cc */
5328        {0xa0, 0x20, ZC3XX_R0A0_MAXXLOW},
5329        {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
5330        {}
5331};
5332static const struct usb_action tas5130c_NoFliker[] = {
5333        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
5334        {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5335        {0xaa, 0xa4, 0x0040}, /* 00,a4,40,aa */
5336        {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5337        {0xa0, 0x40, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,40,cc */
5338        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
5339        {0xa0, 0x05, ZC3XX_R191_EXPOSURELIMITMID},
5340        {0xa0, 0xa0, ZC3XX_R192_EXPOSURELIMITLOW},
5341        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
5342        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
5343        {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
5344        {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5345        {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5346        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
5347        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
5348        {0xa0, 0xbc, ZC3XX_R01D_HSYNC_0}, /* 00,1d,bc,cc */
5349        {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d0,cc */
5350        {0xa0, 0xe0, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e0,cc */
5351        {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5352        {0xa0, 0x02, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,02,cc */
5353        {0xa0, 0xf0, ZC3XX_R0A0_MAXXLOW},
5354        {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
5355        {}
5356};
5357
5358static const struct usb_action tas5130c_NoFlikerScale[] = {
5359        {0xa0, 0x00, ZC3XX_R019_AUTOADJUSTFPS}, /* 00,19,00,cc */
5360        {0xaa, 0xa3, 0x0001}, /* 00,a3,01,aa */
5361        {0xaa, 0xa4, 0x0090}, /* 00,a4,90,aa */
5362        {0xa0, 0x01, ZC3XX_R0A3_EXPOSURETIMEHIGH}, /* 00,a3,01,cc */
5363        {0xa0, 0x90, ZC3XX_R0A4_EXPOSURETIMELOW}, /* 00,a4,90,cc */
5364        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH}, /* 01,90,00,cc */
5365        {0xa0, 0x0a, ZC3XX_R191_EXPOSURELIMITMID},
5366        {0xa0, 0x00, ZC3XX_R192_EXPOSURELIMITLOW},
5367        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},
5368        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},
5369        {0xa0, 0x04, ZC3XX_R197_ANTIFLICKERLOW},
5370        {0xa0, 0x0c, ZC3XX_R18C_AEFREEZE},
5371        {0xa0, 0x18, ZC3XX_R18F_AEUNFREEZE},
5372        {0xa0, 0x00, ZC3XX_R1A9_DIGITALLIMITDIFF}, /* 01,a9,00,cc */
5373        {0xa0, 0x00, ZC3XX_R1AA_DIGITALGAINSTEP}, /* 01,aa,00,cc */
5374        {0xa0, 0xbc, ZC3XX_R01D_HSYNC_0}, /* 00,1d,bc,cc */
5375        {0xa0, 0xd0, ZC3XX_R01E_HSYNC_1}, /* 00,1e,d0,cc */
5376        {0xa0, 0xe0, ZC3XX_R01F_HSYNC_2}, /* 00,1f,e0,cc */
5377        {0xa0, 0xff, ZC3XX_R020_HSYNC_3}, /* 00,20,ff,cc */
5378        {0xa0, 0x02, ZC3XX_R09F_MAXXHIGH}, /* 00,9f,02,cc */
5379        {0xa0, 0xf0, ZC3XX_R0A0_MAXXLOW},
5380        {0xa0, 0x50, ZC3XX_R11D_GLOBALGAIN},
5381        {}
5382};
5383
5384static const struct usb_action gc0303_InitialScale[] = {
5385        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},         /* 00,00,01,cc, */
5386        {0xa0, 0x02, ZC3XX_R008_CLOCKSETTING},          /* 00,08,02,cc, */
5387        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc, */
5388        {0xa0, 0x10, ZC3XX_R002_CLOCKSELECT},           /* 00,02,00,cc,
5389                                                         * 0<->10 */
5390        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},        /* 00,03,02,cc, */
5391        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},         /* 00,04,80,cc, */
5392        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},       /* 00,05,01,cc, */
5393        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},        /* 00,06,e0,cc, */
5394        {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR},         /* 00,8b,98,cc, */
5395        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},       /* 00,01,01,cc, */
5396        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,03,cc, */
5397        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,01,cc, */
5398        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},          /* 00,98,00,cc, */
5399        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},          /* 00,9a,00,cc, */
5400        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},             /* 01,1a,00,cc, */
5401        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},             /* 01,1c,00,cc, */
5402        {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},          /* 00,9c,e6,cc,
5403                                                         * 6<->8 */
5404        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},           /* 00,9e,86,cc,
5405                                                         * 6<->8 */
5406        {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},            /* 00,87,10,cc, */
5407        {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR},         /* 00,8b,98,cc, */
5408        {0xaa, 0x1b, 0x0024},           /* 00,1b,24,aa, */
5409        {0xdd, 0x00, 0x0080},           /* 00,00,80,dd, */
5410        {0xaa, 0x1b, 0x0000},           /* 00,1b,00,aa, */
5411        {0xaa, 0x13, 0x0002},           /* 00,13,02,aa, */
5412        {0xaa, 0x15, 0x0004},           /* 00,15,04,aa */
5413/*??    {0xaa, 0x01, 0x0000}, */
5414        {0xaa, 0x01, 0x0000},
5415        {0xaa, 0x1a, 0x0000},           /* 00,1a,00,aa, */
5416        {0xaa, 0x1c, 0x0017},           /* 00,1c,17,aa, */
5417        {0xa0, 0x82, ZC3XX_R086_EXPTIMEHIGH},           /* 00,86,82,cc, */
5418        {0xa0, 0x83, ZC3XX_R087_EXPTIMEMID},            /* 00,87,83,cc, */
5419        {0xa0, 0x84, ZC3XX_R088_EXPTIMELOW},            /* 00,88,84,cc, */
5420        {0xaa, 0x05, 0x0010},           /* 00,05,10,aa, */
5421        {0xaa, 0x0a, 0x0000},           /* 00,0a,00,aa, */
5422        {0xaa, 0x0b, 0x00a0},           /* 00,0b,a0,aa, */
5423        {0xaa, 0x0c, 0x0000},           /* 00,0c,00,aa, */
5424        {0xaa, 0x0d, 0x00a0},           /* 00,0d,a0,aa, */
5425        {0xaa, 0x0e, 0x0000},           /* 00,0e,00,aa, */
5426        {0xaa, 0x0f, 0x00a0},           /* 00,0f,a0,aa, */
5427        {0xaa, 0x10, 0x0000},           /* 00,10,00,aa, */
5428        {0xaa, 0x11, 0x00a0},           /* 00,11,a0,aa, */
5429/*??    {0xa0, 0x00, 0x0039},
5430        {0xa1, 0x01, 0x0037}, */
5431        {0xaa, 0x16, 0x0001},           /* 00,16,01,aa, */
5432        {0xaa, 0x17, 0x00e8},           /* 00,17,e6,aa, (e6 -> e8) */
5433        {0xaa, 0x18, 0x0002},           /* 00,18,02,aa, */
5434        {0xaa, 0x19, 0x0088},           /* 00,19,86,aa, */
5435        {0xaa, 0x20, 0x0020},           /* 00,20,20,aa, */
5436        {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},      /* 01,01,b7,cc, */
5437        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,05,cc, */
5438        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},         /* 01,00,0d,cc, */
5439        {0xa0, 0x76, ZC3XX_R189_AWBSTATUS},             /* 01,89,76,cc, */
5440        {0xa0, 0x09, 0x01ad},                           /* 01,ad,09,cc, */
5441        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},         /* 01,c5,03,cc, */
5442        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},           /* 01,cb,13,cc, */
5443        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},        /* 02,50,08,cc, */
5444        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},          /* 03,01,08,cc, */
5445        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},           /* 01,a8,60,cc, */
5446        {0xa0, 0x61, ZC3XX_R116_RGAIN},                 /* 01,16,61,cc, */
5447        {0xa0, 0x65, ZC3XX_R118_BGAIN},                 /* 01,18,65,cc */
5448        {}
5449};
5450
5451static const struct usb_action gc0303_Initial[] = {
5452        {0xa0, 0x01, ZC3XX_R000_SYSTEMCONTROL},         /* 00,00,01,cc, */
5453        {0xa0, 0x02, ZC3XX_R008_CLOCKSETTING},          /* 00,08,02,cc, */
5454        {0xa0, 0x01, ZC3XX_R010_CMOSSENSORSELECT},      /* 00,10,01,cc, */
5455        {0xa0, 0x00, ZC3XX_R002_CLOCKSELECT},           /* 00,02,10,cc, */
5456        {0xa0, 0x02, ZC3XX_R003_FRAMEWIDTHHIGH},        /* 00,03,02,cc, */
5457        {0xa0, 0x80, ZC3XX_R004_FRAMEWIDTHLOW},         /* 00,04,80,cc, */
5458        {0xa0, 0x01, ZC3XX_R005_FRAMEHEIGHTHIGH},       /* 00,05,01,cc, */
5459        {0xa0, 0xe0, ZC3XX_R006_FRAMEHEIGHTLOW},        /* 00,06,e0,cc, */
5460        {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR},         /* 00,8b,98,cc, */
5461        {0xa0, 0x01, ZC3XX_R001_SYSTEMOPERATING},       /* 00,01,01,cc, */
5462        {0xa0, 0x03, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,03,cc, */
5463        {0xa0, 0x01, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,01,cc, */
5464        {0xa0, 0x00, ZC3XX_R098_WINYSTARTLOW},          /* 00,98,00,cc, */
5465        {0xa0, 0x00, ZC3XX_R09A_WINXSTARTLOW},          /* 00,9a,00,cc, */
5466        {0xa0, 0x00, ZC3XX_R11A_FIRSTYLOW},             /* 01,1a,00,cc, */
5467        {0xa0, 0x00, ZC3XX_R11C_FIRSTXLOW},             /* 01,1c,00,cc, */
5468        {0xa0, 0xe8, ZC3XX_R09C_WINHEIGHTLOW},          /* 00,9c,e8,cc,
5469                                                         * 8<->6 */
5470        {0xa0, 0x88, ZC3XX_R09E_WINWIDTHLOW},           /* 00,9e,88,cc,
5471                                                         * 8<->6 */
5472        {0xa0, 0x10, ZC3XX_R087_EXPTIMEMID},            /* 00,87,10,cc, */
5473        {0xa0, 0x98, ZC3XX_R08B_I2CDEVICEADDR},         /* 00,8b,98,cc, */
5474        {0xaa, 0x1b, 0x0024},           /* 00,1b,24,aa, */
5475        {0xdd, 0x00, 0x0080},           /* 00,00,80,dd, */
5476        {0xaa, 0x1b, 0x0000},           /* 00,1b,00,aa, */
5477        {0xaa, 0x13, 0x0002},           /* 00,13,02,aa, */
5478        {0xaa, 0x15, 0x0004},           /* 00,15,04,aa */
5479/*??    {0xaa, 0x01, 0x0000}, */
5480        {0xaa, 0x01, 0x0000},
5481        {0xaa, 0x1a, 0x0000},           /* 00,1a,00,aa, */
5482        {0xaa, 0x1c, 0x0017},           /* 00,1c,17,aa, */
5483        {0xa0, 0x82, ZC3XX_R086_EXPTIMEHIGH},   /* 00,86,82,cc, */
5484        {0xa0, 0x83, ZC3XX_R087_EXPTIMEMID},    /* 00,87,83,cc, */
5485        {0xa0, 0x84, ZC3XX_R088_EXPTIMELOW},    /* 00,88,84,cc, */
5486        {0xaa, 0x05, 0x0010},           /* 00,05,10,aa, */
5487        {0xaa, 0x0a, 0x0000},           /* 00,0a,00,aa, */
5488        {0xaa, 0x0b, 0x00a0},           /* 00,0b,a0,aa, */
5489        {0xaa, 0x0c, 0x0000},           /* 00,0c,00,aa, */
5490        {0xaa, 0x0d, 0x00a0},           /* 00,0d,a0,aa, */
5491        {0xaa, 0x0e, 0x0000},           /* 00,0e,00,aa, */
5492        {0xaa, 0x0f, 0x00a0},           /* 00,0f,a0,aa, */
5493        {0xaa, 0x10, 0x0000},           /* 00,10,00,aa, */
5494        {0xaa, 0x11, 0x00a0},           /* 00,11,a0,aa, */
5495/*??    {0xa0, 0x00, 0x0039},
5496        {0xa1, 0x01, 0x0037}, */
5497        {0xaa, 0x16, 0x0001},           /* 00,16,01,aa, */
5498        {0xaa, 0x17, 0x00e8},           /* 00,17,e6,aa (e6 -> e8) */
5499        {0xaa, 0x18, 0x0002},           /* 00,18,02,aa, */
5500        {0xaa, 0x19, 0x0088},           /* 00,19,88,aa, */
5501        {0xaa, 0x20, 0x0020},           /* 00,20,20,aa, */
5502        {0xa0, 0xb7, ZC3XX_R101_SENSORCORRECTION},      /* 01,01,b7,cc, */
5503        {0xa0, 0x05, ZC3XX_R012_VIDEOCONTROLFUNC},      /* 00,12,05,cc, */
5504        {0xa0, 0x0d, ZC3XX_R100_OPERATIONMODE},         /* 01,00,0d,cc, */
5505        {0xa0, 0x76, ZC3XX_R189_AWBSTATUS},             /* 01,89,76,cc, */
5506        {0xa0, 0x09, 0x01ad},                           /* 01,ad,09,cc, */
5507        {0xa0, 0x03, ZC3XX_R1C5_SHARPNESSMODE},         /* 01,c5,03,cc, */
5508        {0xa0, 0x13, ZC3XX_R1CB_SHARPNESS05},           /* 01,cb,13,cc, */
5509        {0xa0, 0x08, ZC3XX_R250_DEADPIXELSMODE},        /* 02,50,08,cc, */
5510        {0xa0, 0x08, ZC3XX_R301_EEPROMACCESS},          /* 03,01,08,cc, */
5511        {0xa0, 0x60, ZC3XX_R1A8_DIGITALGAIN},           /* 01,a8,60,cc, */
5512        {0xa0, 0x61, ZC3XX_R116_RGAIN},         /* 01,16,61,cc, */
5513        {0xa0, 0x65, ZC3XX_R118_BGAIN},         /* 01,18,65,cc */
5514        {}
5515};
5516static const struct usb_action gc0303_50HZScale[] = {
5517        {0xaa, 0x82, 0x0000},           /* 00,82,00,aa */
5518        {0xaa, 0x83, 0x0001},           /* 00,83,01,aa */
5519        {0xaa, 0x84, 0x00aa},           /* 00,84,aa,aa */
5520        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc, */
5521        {0xa0, 0x06, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,0d,cc, */
5522        {0xa0, 0xa8, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,50,cc, */
5523        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc, */
5524        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc, */
5525        {0xa0, 0x8e, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,47,cc, */
5526        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},              /* 01,8c,0e,cc, */
5527        {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE},            /* 01,8f,15,cc, */
5528        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,10,cc, */
5529        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc, */
5530        {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},               /* 00,1d,62,cc, */
5531        {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},               /* 00,1e,90,cc, */
5532        {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},               /* 00,1f,c8,cc, */
5533        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,20,ff,cc, */
5534        {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN},            /* 01,1d,58,cc, */
5535        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},     /* 01,80,42,cc, */
5536        {0xa0, 0x78, ZC3XX_R18D_YTARGET},               /* 01,8d,78,cc */
5537        {}
5538};
5539
5540static const struct usb_action gc0303_50HZ[] = {
5541        {0xaa, 0x82, 0x0000},           /* 00,82,00,aa */
5542        {0xaa, 0x83, 0x0003},           /* 00,83,03,aa */
5543        {0xaa, 0x84, 0x0054},           /* 00,84,54,aa */
5544        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc, */
5545        {0xa0, 0x0d, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,0d,cc, */
5546        {0xa0, 0x50, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,50,cc, */
5547        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc, */
5548        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc, */
5549        {0xa0, 0x8e, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,8e,cc, */
5550        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},              /* 01,8c,0e,cc, */
5551        {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE},            /* 01,8f,15,cc, */
5552        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,10,cc, */
5553        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc, */
5554        {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},               /* 00,1d,62,cc, */
5555        {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},               /* 00,1e,90,cc, */
5556        {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},               /* 00,1f,c8,cc, */
5557        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,20,ff,cc, */
5558        {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN},            /* 01,1d,58,cc, */
5559        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},     /* 01,80,42,cc, */
5560        {0xa0, 0x78, ZC3XX_R18D_YTARGET},               /* 01,8d,78,cc */
5561        {}
5562};
5563
5564static const struct usb_action gc0303_60HZScale[] = {
5565        {0xaa, 0x82, 0x0000},           /* 00,82,00,aa */
5566        {0xaa, 0x83, 0x0001},           /* 00,83,01,aa */
5567        {0xaa, 0x84, 0x0062},           /* 00,84,62,aa */
5568        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc, */
5569        {0xa0, 0x05, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,05,cc, */
5570        {0xa0, 0x88, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,88,cc, */
5571        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc, */
5572        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc, */
5573        {0xa0, 0x3b, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,3b,cc, */
5574        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},              /* 01,8c,0e,cc, */
5575        {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE},            /* 01,8f,15,cc, */
5576        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,a9,10,cc, */
5577        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,aa,24,cc, */
5578        {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},               /* 00,1d,62,cc, */
5579        {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},               /* 00,1e,90,cc, */
5580        {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},               /* 00,1f,c8,cc, */
5581        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,20,ff,cc, */
5582        {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN},            /* 01,1d,58,cc, */
5583        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},     /* 01,80,42,cc, */
5584        {0xa0, 0x78, ZC3XX_R18D_YTARGET},               /* 01,8d,78,cc */
5585        {}
5586};
5587
5588static const struct usb_action gc0303_60HZ[] = {
5589        {0xaa, 0x82, 0x0000},           /* 00,82,00,aa */
5590        {0xaa, 0x83, 0x0002},           /* 00,83,02,aa */
5591        {0xaa, 0x84, 0x00c4},           /* 00,84,c4,aa */
5592        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc, */
5593        {0xa0, 0x0b, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,1,0b,cc, */
5594        {0xa0, 0x10, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,2,10,cc, */
5595        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,5,00,cc, */
5596        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,6,00,cc, */
5597        {0xa0, 0x76, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,7,76,cc, */
5598        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},              /* 01,c,0e,cc, */
5599        {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE},            /* 01,f,15,cc, */
5600        {0xa0, 0x10, ZC3XX_R1A9_DIGITALLIMITDIFF},      /* 01,9,10,cc, */
5601        {0xa0, 0x24, ZC3XX_R1AA_DIGITALGAINSTEP},       /* 01,a,24,cc, */
5602        {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},               /* 00,d,62,cc, */
5603        {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},               /* 00,e,90,cc, */
5604        {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},               /* 00,f,c8,cc, */
5605        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,0,ff,cc, */
5606        {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN},            /* 01,d,58,cc, */
5607        {0xa0, 0x42, ZC3XX_R180_AUTOCORRECTENABLE},     /* 01,80,42,cc, */
5608        {0xa0, 0x78, ZC3XX_R18D_YTARGET},               /* 01,d,78,cc */
5609        {}
5610};
5611
5612static const struct usb_action gc0303_NoFlikerScale[] = {
5613        {0xa0, 0x0c, ZC3XX_R100_OPERATIONMODE},         /* 01,00,0c,cc, */
5614        {0xaa, 0x82, 0x0000},           /* 00,82,00,aa */
5615        {0xaa, 0x83, 0x0000},           /* 00,83,00,aa */
5616        {0xaa, 0x84, 0x0020},           /* 00,84,20,aa */
5617        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,0,00,cc, */
5618        {0xa0, 0x05, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,05,cc, */
5619        {0xa0, 0x88, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,88,cc, */
5620        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc, */
5621        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc, */
5622        {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,10,cc, */
5623        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},              /* 01,8c,0e,cc, */
5624        {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE},            /* 01,8f,15,cc, */
5625        {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},               /* 00,1d,62,cc, */
5626        {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},               /* 00,1e,90,cc, */
5627        {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},               /* 00,1f,c8,cc, */
5628        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,20,ff,cc, */
5629        {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN},            /* 01,1d,58,cc, */
5630        {0xa0, 0x03, ZC3XX_R180_AUTOCORRECTENABLE},     /* 01,80,03,cc */
5631        {}
5632};
5633
5634static const struct usb_action gc0303_NoFliker[] = {
5635        {0xa0, 0x0c, ZC3XX_R100_OPERATIONMODE},         /* 01,00,0c,cc, */
5636        {0xaa, 0x82, 0x0000},           /* 00,82,00,aa */
5637        {0xaa, 0x83, 0x0000},           /* 00,83,00,aa */
5638        {0xaa, 0x84, 0x0020},           /* 00,84,20,aa */
5639        {0xa0, 0x00, ZC3XX_R190_EXPOSURELIMITHIGH},     /* 01,90,00,cc, */
5640        {0xa0, 0x0b, ZC3XX_R191_EXPOSURELIMITMID},      /* 01,91,0b,cc, */
5641        {0xa0, 0x10, ZC3XX_R192_EXPOSURELIMITLOW},      /* 01,92,10,cc, */
5642        {0xa0, 0x00, ZC3XX_R195_ANTIFLICKERHIGH},       /* 01,95,00,cc, */
5643        {0xa0, 0x00, ZC3XX_R196_ANTIFLICKERMID},        /* 01,96,00,cc, */
5644        {0xa0, 0x10, ZC3XX_R197_ANTIFLICKERLOW},        /* 01,97,10,cc, */
5645        {0xa0, 0x0e, ZC3XX_R18C_AEFREEZE},              /* 01,8c,0e,cc, */
5646        {0xa0, 0x15, ZC3XX_R18F_AEUNFREEZE},            /* 01,8f,15,cc, */
5647        {0xa0, 0x62, ZC3XX_R01D_HSYNC_0},               /* 00,1d,62,cc, */
5648        {0xa0, 0x90, ZC3XX_R01E_HSYNC_1},               /* 00,1e,90,cc, */
5649        {0xa0, 0xc8, ZC3XX_R01F_HSYNC_2},               /* 00,1f,c8,cc, */
5650        {0xa0, 0xff, ZC3XX_R020_HSYNC_3},               /* 00,20,ff,cc, */
5651        {0xa0, 0x58, ZC3XX_R11D_GLOBALGAIN},            /* 01,1d,58,cc, */
5652        {0xa0, 0x03, ZC3XX_R180_AUTOCORRECTENABLE},     /* 01,80,03,cc */
5653        {}
5654};
5655
5656static u8 reg_r_i(struct gspca_dev *gspca_dev,
5657                u16 index)
5658{
5659        int ret;
5660
5661        if (gspca_dev->usb_err < 0)
5662                return 0;
5663        ret = usb_control_msg(gspca_dev->dev,
5664                        usb_rcvctrlpipe(gspca_dev->dev, 0),
5665                        0xa1,
5666                        USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
5667                        0x01,                   /* value */
5668                        index, gspca_dev->usb_buf, 1,
5669                        500);
5670        if (ret < 0) {
5671                pr_err("reg_r_i err %d\n", ret);
5672                gspca_dev->usb_err = ret;
5673                return 0;
5674        }
5675        return gspca_dev->usb_buf[0];
5676}
5677
5678static u8 reg_r(struct gspca_dev *gspca_dev,
5679                u16 index)
5680{
5681        u8 ret;
5682
5683        ret = reg_r_i(gspca_dev, index);
5684        PDEBUG(D_USBI, "reg r [%04x] -> %02x", index, ret);
5685        return ret;
5686}
5687
5688static void reg_w_i(struct gspca_dev *gspca_dev,
5689                        u8 value,
5690                        u16 index)
5691{
5692        int ret;
5693
5694        if (gspca_dev->usb_err < 0)
5695                return;
5696        ret = usb_control_msg(gspca_dev->dev,
5697                        usb_sndctrlpipe(gspca_dev->dev, 0),
5698                        0xa0,
5699                        USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_DEVICE,
5700                        value, index, NULL, 0,
5701                        500);
5702        if (ret < 0) {
5703                pr_err("reg_w_i err %d\n", ret);
5704                gspca_dev->usb_err = ret;
5705        }
5706}
5707
5708static void reg_w(struct gspca_dev *gspca_dev,
5709                        u8 value,
5710                        u16 index)
5711{
5712        PDEBUG(D_USBO, "reg w [%04x] = %02x", index, value);
5713        reg_w_i(gspca_dev, value, index);
5714}
5715
5716static u16 i2c_read(struct gspca_dev *gspca_dev,
5717                        u8 reg)
5718{
5719        u8 retbyte;
5720        u16 retval;
5721
5722        if (gspca_dev->usb_err < 0)
5723                return 0;
5724        reg_w_i(gspca_dev, reg, 0x0092);
5725        reg_w_i(gspca_dev, 0x02, 0x0090);               /* <- read command */
5726        msleep(20);
5727        retbyte = reg_r_i(gspca_dev, 0x0091);           /* read status */
5728        if (retbyte != 0x00)
5729                pr_err("i2c_r status error %02x\n", retbyte);
5730        retval = reg_r_i(gspca_dev, 0x0095);            /* read Lowbyte */
5731        retval |= reg_r_i(gspca_dev, 0x0096) << 8;      /* read Hightbyte */
5732        PDEBUG(D_USBI, "i2c r [%02x] -> %04x (%02x)",
5733                        reg, retval, retbyte);
5734        return retval;
5735}
5736
5737static u8 i2c_write(struct gspca_dev *gspca_dev,
5738                        u8 reg,
5739                        u8 valL,
5740                        u8 valH)
5741{
5742        u8 retbyte;
5743
5744        if (gspca_dev->usb_err < 0)
5745                return 0;
5746        reg_w_i(gspca_dev, reg, 0x92);
5747        reg_w_i(gspca_dev, valL, 0x93);
5748        reg_w_i(gspca_dev, valH, 0x94);
5749        reg_w_i(gspca_dev, 0x01, 0x90);         /* <- write command */
5750        msleep(1);
5751        retbyte = reg_r_i(gspca_dev, 0x0091);           /* read status */
5752        if (retbyte != 0x00)
5753                pr_err("i2c_w status error %02x\n", retbyte);
5754        PDEBUG(D_USBO, "i2c w [%02x] = %02x%02x (%02x)",
5755                        reg, valH, valL, retbyte);
5756        return retbyte;
5757}
5758
5759static void usb_exchange(struct gspca_dev *gspca_dev,
5760                        const struct usb_action *action)
5761{
5762        while (action->req) {
5763                switch (action->req) {
5764                case 0xa0:      /* write register */
5765                        reg_w(gspca_dev, action->val, action->idx);
5766                        break;
5767                case 0xa1:      /* read status */
5768                        reg_r(gspca_dev, action->idx);
5769                        break;
5770                case 0xaa:
5771                        i2c_write(gspca_dev,
5772                                  action->val,                  /* reg */
5773                                  action->idx & 0xff,           /* valL */
5774                                  action->idx >> 8);            /* valH */
5775                        break;
5776                case 0xbb:
5777                        i2c_write(gspca_dev,
5778                                  action->idx >> 8,             /* reg */
5779                                  action->idx & 0xff,           /* valL */
5780                                  action->val);                 /* valH */
5781                        break;
5782                default:
5783/*              case 0xdd:       * delay */
5784                        msleep(action->idx);
5785                        break;
5786                }
5787                action++;
5788                msleep(1);
5789        }
5790}
5791
5792static void setmatrix(struct gspca_dev *gspca_dev)
5793{
5794        struct sd *sd = (struct sd *) gspca_dev;
5795        int i;
5796        const u8 *matrix;
5797        static const u8 adcm2700_matrix[9] =
5798/*              {0x66, 0xed, 0xed, 0xed, 0x66, 0xed, 0xed, 0xed, 0x66}; */
5799/*ms-win*/
5800                {0x74, 0xed, 0xed, 0xed, 0x74, 0xed, 0xed, 0xed, 0x74};
5801        static const u8 gc0305_matrix[9] =
5802                {0x50, 0xf8, 0xf8, 0xf8, 0x50, 0xf8, 0xf8, 0xf8, 0x50};
5803        static const u8 ov7620_matrix[9] =
5804                {0x58, 0xf4, 0xf4, 0xf4, 0x58, 0xf4, 0xf4, 0xf4, 0x58};
5805        static const u8 pas202b_matrix[9] =
5806                {0x4c, 0xf5, 0xff, 0xf9, 0x51, 0xf5, 0xfb, 0xed, 0x5f};
5807        static const u8 po2030_matrix[9] =
5808                {0x60, 0xf0, 0xf0, 0xf0, 0x60, 0xf0, 0xf0, 0xf0, 0x60};
5809        static const u8 tas5130c_matrix[9] =
5810                {0x68, 0xec, 0xec, 0xec, 0x68, 0xec, 0xec, 0xec, 0x68};
5811        static const u8 gc0303_matrix[9] =
5812                {0x7b, 0xea, 0xea, 0xea, 0x7b, 0xea, 0xea, 0xea, 0x7b};
5813        static const u8 *matrix_tb[SENSOR_MAX] = {
5814                [SENSOR_ADCM2700] =     adcm2700_matrix,
5815                [SENSOR_CS2102] =       ov7620_matrix,
5816                [SENSOR_CS2102K] =      NULL,
5817                [SENSOR_GC0303] =       gc0303_matrix,
5818                [SENSOR_GC0305] =       gc0305_matrix,
5819                [SENSOR_HDCS2020] =     NULL,
5820                [SENSOR_HV7131B] =      NULL,
5821                [SENSOR_HV7131R] =      po2030_matrix,
5822                [SENSOR_ICM105A] =      po2030_matrix,
5823                [SENSOR_MC501CB] =      NULL,
5824                [SENSOR_MT9V111_1] =    gc0305_matrix,
5825                [SENSOR_MT9V111_3] =    gc0305_matrix,
5826                [SENSOR_OV7620] =       ov7620_matrix,
5827                [SENSOR_OV7630C] =      NULL,
5828                [SENSOR_PAS106] =       NULL,
5829                [SENSOR_PAS202B] =      pas202b_matrix,
5830                [SENSOR_PB0330] =       gc0305_matrix,
5831                [SENSOR_PO2030] =       po2030_matrix,
5832                [SENSOR_TAS5130C] =     tas5130c_matrix,
5833        };
5834
5835        matrix = matrix_tb[sd->sensor];
5836        if (matrix == NULL)
5837                return;         /* matrix already loaded */
5838        for (i = 0; i < ARRAY_SIZE(ov7620_matrix); i++)
5839                reg_w(gspca_dev, matrix[i], 0x010a + i);
5840}
5841
5842static void setsharpness(struct gspca_dev *gspca_dev)
5843{
5844        struct sd *sd = (struct sd *) gspca_dev;
5845        int sharpness;
5846        static const u8 sharpness_tb[][2] = {
5847                {0x02, 0x03},
5848                {0x04, 0x07},
5849                {0x08, 0x0f},
5850                {0x10, 0x1e}
5851        };
5852
5853        sharpness = sd->ctrls[SHARPNESS].val;
5854        reg_w(gspca_dev, sharpness_tb[sharpness][0], 0x01c6);
5855        reg_r(gspca_dev, 0x01c8);
5856        reg_r(gspca_dev, 0x01c9);
5857        reg_r(gspca_dev, 0x01ca);
5858        reg_w(gspca_dev, sharpness_tb[sharpness][1], 0x01cb);
5859}
5860
5861static void setcontrast(struct gspca_dev *gspca_dev)
5862{
5863        struct sd *sd = (struct sd *) gspca_dev;
5864        const u8 *Tgamma;
5865        int g, i, brightness, contrast, adj, gp1, gp2;
5866        u8 gr[16];
5867        static const u8 delta_b[16] =           /* delta for brightness */
5868                {0x50, 0x38, 0x2d, 0x28, 0x24, 0x21, 0x1e, 0x1d,
5869                 0x1d, 0x1b, 0x1b, 0x1b, 0x19, 0x18, 0x18, 0x18};
5870        static const u8 delta_c[16] =           /* delta for contrast */
5871                {0x2c, 0x1a, 0x12, 0x0c, 0x0a, 0x06, 0x06, 0x06,
5872                 0x04, 0x06, 0x04, 0x04, 0x03, 0x03, 0x02, 0x02};
5873        static const u8 gamma_tb[6][16] = {
5874                {0x00, 0x00, 0x03, 0x0d, 0x1b, 0x2e, 0x45, 0x5f,
5875                 0x79, 0x93, 0xab, 0xc1, 0xd4, 0xe5, 0xf3, 0xff},
5876                {0x01, 0x0c, 0x1f, 0x3a, 0x53, 0x6d, 0x85, 0x9c,
5877                 0xb0, 0xc2, 0xd1, 0xde, 0xe9, 0xf2, 0xf9, 0xff},
5878                {0x04, 0x16, 0x30, 0x4e, 0x68, 0x81, 0x98, 0xac,
5879                 0xbe, 0xcd, 0xda, 0xe4, 0xed, 0xf5, 0xfb, 0xff},
5880                {0x13, 0x38, 0x59, 0x79, 0x92, 0xa7, 0xb9, 0xc8,
5881                 0xd4, 0xdf, 0xe7, 0xee, 0xf4, 0xf9, 0xfc, 0xff},
5882                {0x20, 0x4b, 0x6e, 0x8d, 0xa3, 0xb5, 0xc5, 0xd2,
5883                 0xdc, 0xe5, 0xec, 0xf2, 0xf6, 0xfa, 0xfd, 0xff},
5884                {0x24, 0x44, 0x64, 0x84, 0x9d, 0xb2, 0xc4, 0xd3,
5885                 0xe0, 0xeb, 0xf4, 0xff, 0xff, 0xff, 0xff, 0xff},
5886        };
5887
5888        Tgamma = gamma_tb[sd->ctrls[GAMMA].val - 1];
5889
5890        contrast = ((int) sd->ctrls[CONTRAST].val - 128); /* -128 / 127 */
5891        brightness = ((int) sd->ctrls[BRIGHTNESS].val - 128); /* -128 / 92 */
5892        adj = 0;
5893        gp1 = gp2 = 0;
5894        for (i = 0; i < 16; i++) {
5895                g = Tgamma[i] + delta_b[i] * brightness / 256
5896                                - delta_c[i] * contrast / 256 - adj / 2;
5897                if (g > 0xff)
5898                        g = 0xff;
5899                else if (g < 0)
5900                        g = 0;
5901                reg_w(gspca_dev, g, 0x0120 + i);        /* gamma */
5902                if (contrast > 0)
5903                        adj--;
5904                else if (contrast < 0)
5905                        adj++;
5906                if (i > 1)
5907                        gr[i - 1] = (g - gp2) / 2;
5908                else if (i != 0)
5909                        gr[0] = gp1 == 0 ? 0 : (g - gp1);
5910                gp2 = gp1;
5911                gp1 = g;
5912        }
5913        gr[15] = (0xff - gp2) / 2;
5914        for (i = 0; i < 16; i++)
5915                reg_w(gspca_dev, gr[i], 0x0130 + i);    /* gradient */
5916}
5917
5918static void getexposure(struct gspca_dev *gspca_dev)
5919{
5920        struct sd *sd = (struct sd *) gspca_dev;
5921
5922        sd->ctrls[EXPOSURE].val = (i2c_read(gspca_dev, 0x25) << 9)
5923                | (i2c_read(gspca_dev, 0x26) << 1)
5924                | (i2c_read(gspca_dev, 0x27) >> 7);
5925}
5926
5927static void setexposure(struct gspca_dev *gspca_dev)
5928{
5929        struct sd *sd = (struct sd *) gspca_dev;
5930        int val;
5931
5932        val = sd->ctrls[EXPOSURE].val;
5933        i2c_write(gspca_dev, 0x25, val >> 9, 0x00);
5934        i2c_write(gspca_dev, 0x26, val >> 1, 0x00);
5935        i2c_write(gspca_dev, 0x27, val << 7, 0x00);
5936}
5937
5938static void setquality(struct gspca_dev *gspca_dev)
5939{
5940        struct sd *sd = (struct sd *) gspca_dev;
5941        u8 frxt;
5942
5943        switch (sd->sensor) {
5944        case SENSOR_ADCM2700:
5945        case SENSOR_GC0305:
5946        case SENSOR_HV7131B:
5947        case SENSOR_HV7131R:
5948        case SENSOR_OV7620:
5949        case SENSOR_PAS202B:
5950        case SENSOR_PO2030:
5951                return;
5952        }
5953/*fixme: is it really 0008 0007 0018 for all other sensors? */
5954        reg_w(gspca_dev, QUANT_VAL, 0x0008);
5955        frxt = 0x30;
5956        reg_w(gspca_dev, frxt, 0x0007);
5957#if QUANT_VAL == 0 || QUANT_VAL == 1 || QUANT_VAL == 2
5958        frxt = 0xff;
5959#elif QUANT_VAL == 3
5960        frxt = 0xf0;
5961#elif QUANT_VAL == 4
5962        frxt = 0xe0;
5963#else
5964        frxt = 0x20;
5965#endif
5966        reg_w(gspca_dev, frxt, 0x0018);
5967}
5968
5969/* Matches the sensor's internal frame rate to the lighting frequency.
5970 * Valid frequencies are:
5971 *      50Hz, for European and Asian lighting (default)
5972 *      60Hz, for American lighting
5973 *      0 = No Fliker (for outdoore usage)
5974 */
5975static void setlightfreq(struct gspca_dev *gspca_dev)
5976{
5977        struct sd *sd = (struct sd *) gspca_dev;
5978        int i, mode;
5979        const struct usb_action *zc3_freq;
5980        static const struct usb_action *freq_tb[SENSOR_MAX][6] = {
5981        [SENSOR_ADCM2700] =
5982                {adcm2700_NoFliker, adcm2700_NoFliker,
5983                 adcm2700_50HZ, adcm2700_50HZ,
5984                 adcm2700_60HZ, adcm2700_60HZ},
5985        [SENSOR_CS2102] =
5986                {cs2102_NoFliker, cs2102_NoFlikerScale,
5987                 cs2102_50HZ, cs2102_50HZScale,
5988                 cs2102_60HZ, cs2102_60HZScale},
5989        [SENSOR_CS2102K] =
5990                {cs2102_NoFliker, cs2102_NoFlikerScale,
5991                 NULL, NULL, /* currently disabled */
5992                 NULL, NULL},
5993        [SENSOR_GC0303] =
5994                {gc0303_NoFliker, gc0303_NoFlikerScale,
5995                 gc0303_50HZ, gc0303_50HZScale,
5996                 gc0303_60HZ, gc0303_60HZScale},
5997        [SENSOR_GC0305] =
5998                {gc0305_NoFliker, gc0305_NoFliker,
5999                 gc0305_50HZ, gc0305_50HZ,
6000                 gc0305_60HZ, gc0305_60HZ},
6001        [SENSOR_HDCS2020] =
6002                {hdcs2020_NoFliker, hdcs2020_NoFliker,
6003                 hdcs2020_50HZ, hdcs2020_50HZ,
6004                 hdcs2020_60HZ, hdcs2020_60HZ},
6005        [SENSOR_HV7131B] =
6006                {hv7131b_NoFliker, hv7131b_NoFlikerScale,
6007                 hv7131b_50HZ, hv7131b_50HZScale,
6008                 hv7131b_60HZ, hv7131b_60HZScale},
6009        [SENSOR_HV7131R] =
6010                {hv7131r_NoFliker, hv7131r_NoFlikerScale,
6011                 hv7131r_50HZ, hv7131r_50HZScale,
6012                 hv7131r_60HZ, hv7131r_60HZScale},
6013        [SENSOR_ICM105A] =
6014                {icm105a_NoFliker, icm105a_NoFlikerScale,
6015                 icm105a_50HZ, icm105a_50HZScale,
6016                 icm105a_60HZ, icm105a_60HZScale},
6017        [SENSOR_MC501CB] =
6018                {mc501cb_NoFliker, mc501cb_NoFlikerScale,
6019                 mc501cb_50HZ, mc501cb_50HZScale,
6020                 mc501cb_60HZ, mc501cb_60HZScale},
6021        [SENSOR_MT9V111_1] =
6022                {mt9v111_1_AENoFliker, mt9v111_1_AENoFlikerScale,
6023                 mt9v111_1_AE50HZ, mt9v111_1_AE50HZScale,
6024                 mt9v111_1_AE60HZ, mt9v111_1_AE60HZScale},
6025        [SENSOR_MT9V111_3] =
6026                {mt9v111_3_AENoFliker, mt9v111_3_AENoFlikerScale,
6027                 mt9v111_3_AE50HZ, mt9v111_3_AE50HZScale,
6028                 mt9v111_3_AE60HZ, mt9v111_3_AE60HZScale},
6029        [SENSOR_OV7620] =
6030                {ov7620_NoFliker, ov7620_NoFliker,
6031                 ov7620_50HZ, ov7620_50HZ,
6032                 ov7620_60HZ, ov7620_60HZ},
6033        [SENSOR_OV7630C] =
6034                {NULL, NULL,
6035                 NULL, NULL,
6036                 NULL, NULL},
6037        [SENSOR_PAS106] =
6038                {pas106b_NoFliker, pas106b_NoFliker,
6039                 pas106b_50HZ, pas106b_50HZ,
6040                 pas106b_60HZ, pas106b_60HZ},
6041        [SENSOR_PAS202B] =
6042                {pas202b_NoFliker, pas202b_NoFlikerScale,
6043                 pas202b_50HZ, pas202b_50HZScale,
6044                 pas202b_60HZ, pas202b_60HZScale},
6045        [SENSOR_PB0330] =
6046                {pb0330_NoFliker, pb0330_NoFlikerScale,
6047                 pb0330_50HZ, pb0330_50HZScale,
6048                 pb0330_60HZ, pb0330_60HZScale},
6049        [SENSOR_PO2030] =
6050                {po2030_NoFliker, po2030_NoFliker,
6051                 po2030_50HZ, po2030_50HZ,
6052                 po2030_60HZ, po2030_60HZ},
6053        [SENSOR_TAS5130C] =
6054                {tas5130c_NoFliker, tas5130c_NoFlikerScale,
6055                 tas5130c_50HZ, tas5130c_50HZScale,
6056                 tas5130c_60HZ, tas5130c_60HZScale},
6057        };
6058
6059        i = sd->ctrls[LIGHTFREQ].val * 2;
6060        mode = gspca_dev->cam.cam_mode[gspca_dev->curr_mode].priv;
6061        if (mode)
6062                i++;                    /* 320x240 */
6063        zc3_freq = freq_tb[sd->sensor][i];
6064        if (zc3_freq == NULL)
6065                return;
6066        usb_exchange(gspca_dev, zc3_freq);
6067        switch (sd->sensor) {
6068        case SENSOR_GC0305:
6069                if (mode                                /* if 320x240 */
6070                    && sd->ctrls[LIGHTFREQ].val == 1)   /* and 50Hz */
6071                        reg_w(gspca_dev, 0x85, 0x018d);
6072                                        /* win: 0x80, 0x018d */
6073                break;
6074        case SENSOR_OV7620:
6075                if (!mode) {                            /* if 640x480 */
6076                        if (sd->ctrls[LIGHTFREQ].val != 0) /* and filter */
6077                                reg_w(gspca_dev, 0x40, 0x0002);
6078                        else
6079                                reg_w(gspca_dev, 0x44, 0x0002);
6080                }
6081                break;
6082        case SENSOR_PAS202B:
6083                reg_w(gspca_dev, 0x00, 0x01a7);
6084                break;
6085        }
6086}
6087
6088static void setautogain(struct gspca_dev *gspca_dev)
6089{
6090        struct sd *sd = (struct sd *) gspca_dev;
6091        u8 autoval;
6092
6093        if (sd->ctrls[AUTOGAIN].val)
6094                autoval = 0x42;
6095        else
6096                autoval = 0x02;
6097        reg_w(gspca_dev, autoval, 0x0180);
6098}
6099
6100static void send_unknown(struct gspca_dev *gspca_dev, int sensor)
6101{
6102        reg_w(gspca_dev, 0x01, 0x0000);         /* bridge reset */
6103        switch (sensor) {
6104        case SENSOR_PAS106:
6105                reg_w(gspca_dev, 0x03, 0x003a);
6106                reg_w(gspca_dev, 0x0c, 0x003b);
6107                reg_w(gspca_dev, 0x08, 0x0038);
6108                break;
6109        case SENSOR_ADCM2700:
6110        case SENSOR_GC0305:
6111        case SENSOR_OV7620:
6112        case SENSOR_MT9V111_1:
6113        case SENSOR_MT9V111_3:
6114        case SENSOR_PB0330:
6115        case SENSOR_PO2030:
6116                reg_w(gspca_dev, 0x0d, 0x003a);
6117                reg_w(gspca_dev, 0x02, 0x003b);
6118                reg_w(gspca_dev, 0x00, 0x0038);
6119                break;
6120        case SENSOR_HV7131R:
6121        case SENSOR_PAS202B:
6122                reg_w(gspca_dev, 0x03, 0x003b);
6123                reg_w(gspca_dev, 0x0c, 0x003a);
6124                reg_w(gspca_dev, 0x0b, 0x0039);
6125                if (sensor == SENSOR_PAS202B)
6126                        reg_w(gspca_dev, 0x0b, 0x0038);
6127                break;
6128        }
6129}
6130
6131/* start probe 2 wires */
6132static void start_2wr_probe(struct gspca_dev *gspca_dev, int sensor)
6133{
6134        reg_w(gspca_dev, 0x01, 0x0000);
6135        reg_w(gspca_dev, sensor, 0x0010);
6136        reg_w(gspca_dev, 0x01, 0x0001);
6137        reg_w(gspca_dev, 0x03, 0x0012);
6138        reg_w(gspca_dev, 0x01, 0x0012);
6139/*      msleep(2); */
6140}
6141
6142static int sif_probe(struct gspca_dev *gspca_dev)
6143{
6144        u16 checkword;
6145
6146        start_2wr_probe(gspca_dev, 0x0f);               /* PAS106 */
6147        reg_w(gspca_dev, 0x08, 0x008d);
6148        msleep(150);
6149        checkword = ((i2c_read(gspca_dev, 0x00) & 0x0f) << 4)
6150                        | ((i2c_read(gspca_dev, 0x01) & 0xf0) >> 4);
6151        PDEBUG(D_PROBE, "probe sif 0x%04x", checkword);
6152        if (checkword == 0x0007) {
6153                send_unknown(gspca_dev, SENSOR_PAS106);
6154                return 0x0f;                    /* PAS106 */
6155        }
6156        return -1;
6157}
6158
6159static int vga_2wr_probe(struct gspca_dev *gspca_dev)
6160{
6161        u16 retword;
6162
6163        start_2wr_probe(gspca_dev, 0x00);       /* HV7131B */
6164        i2c_write(gspca_dev, 0x01, 0xaa, 0x00);
6165        retword = i2c_read(gspca_dev, 0x01);
6166        if (retword != 0)
6167                return 0x00;                    /* HV7131B */
6168
6169        start_2wr_probe(gspca_dev, 0x04);       /* CS2102 */
6170        i2c_write(gspca_dev, 0x01, 0xaa, 0x00);
6171        retword = i2c_read(gspca_dev, 0x01);
6172        if (retword != 0)
6173                return 0x04;                    /* CS2102 */
6174
6175        start_2wr_probe(gspca_dev, 0x06);       /* OmniVision */
6176        reg_w(gspca_dev, 0x08, 0x008d);
6177        i2c_write(gspca_dev, 0x11, 0xaa, 0x00);
6178        retword = i2c_read(gspca_dev, 0x11);
6179        if (retword != 0) {
6180                /* (should have returned 0xaa) --> Omnivision? */
6181                /* reg_r 0x10 -> 0x06 -->  */
6182                goto ov_check;
6183        }
6184
6185        start_2wr_probe(gspca_dev, 0x08);       /* HDCS2020 */
6186        i2c_write(gspca_dev, 0x1c, 0x00, 0x00);
6187        i2c_write(gspca_dev, 0x15, 0xaa, 0x00);
6188        retword = i2c_read(gspca_dev, 0x15);
6189        if (retword != 0)
6190                return 0x08;                    /* HDCS2020 */
6191
6192        start_2wr_probe(gspca_dev, 0x0a);       /* PB0330 */
6193        i2c_write(gspca_dev, 0x07, 0xaa, 0xaa);
6194        retword = i2c_read(gspca_dev, 0x07);
6195        if (retword != 0)
6196                return 0x0a;                    /* PB0330 */
6197        retword = i2c_read(gspca_dev, 0x03);
6198        if (retword != 0)
6199                return 0x0a;                    /* PB0330 ?? */
6200        retword = i2c_read(gspca_dev, 0x04);
6201        if (retword != 0)
6202                return 0x0a;                    /* PB0330 ?? */
6203
6204        start_2wr_probe(gspca_dev, 0x0c);       /* ICM105A */
6205        i2c_write(gspca_dev, 0x01, 0x11, 0x00);
6206        retword = i2c_read(gspca_dev, 0x01);
6207        if (retword != 0)
6208                return 0x0c;                    /* ICM105A */
6209
6210        start_2wr_probe(gspca_dev, 0x0e);       /* PAS202BCB */
6211        reg_w(gspca_dev, 0x08, 0x008d);
6212        i2c_write(gspca_dev, 0x03, 0xaa, 0x00);
6213        msleep(50);
6214        retword = i2c_read(gspca_dev, 0x03);
6215        if (retword != 0) {
6216                send_unknown(gspca_dev, SENSOR_PAS202B);
6217                return 0x0e;                    /* PAS202BCB */
6218        }
6219
6220        start_2wr_probe(gspca_dev, 0x02);       /* TAS5130C */
6221        i2c_write(gspca_dev, 0x01, 0xaa, 0x00);
6222        retword = i2c_read(gspca_dev, 0x01);
6223        if (retword != 0)
6224                return 0x02;                    /* TAS5130C */
6225ov_check:
6226        reg_r(gspca_dev, 0x0010);               /* ?? */
6227        reg_r(gspca_dev, 0x0010);
6228
6229        reg_w(gspca_dev, 0x01, 0x0000);
6230        reg_w(gspca_dev, 0x01, 0x0001);
6231        reg_w(gspca_dev, 0x06, 0x0010);         /* OmniVision */
6232        reg_w(gspca_dev, 0xa1, 0x008b);
6233        reg_w(gspca_dev, 0x08, 0x008d);
6234        msleep(500);
6235        reg_w(gspca_dev, 0x01, 0x0012);
6236        i2c_write(gspca_dev, 0x12, 0x80, 0x00); /* sensor reset */
6237        retword = i2c_read(gspca_dev, 0x0a) << 8;
6238        retword |= i2c_read(gspca_dev, 0x0b);
6239        PDEBUG(D_PROBE, "probe 2wr ov vga 0x%04x", retword);
6240        switch (retword) {
6241        case 0x7631:                            /* OV7630C */
6242                reg_w(gspca_dev, 0x06, 0x0010);
6243                break;
6244        case 0x7620:                            /* OV7620 */
6245        case 0x7648:                            /* OV7648 */
6246                break;
6247        default:
6248                return -1;                      /* not OmniVision */
6249        }
6250        return retword;
6251}
6252
6253struct sensor_by_chipset_revision {
6254        u16 revision;
6255        u8 internal_sensor_id;
6256};
6257static const struct sensor_by_chipset_revision chipset_revision_sensor[] = {
6258        {0xc000, 0x12},         /* TAS5130C */
6259        {0xc001, 0x13},         /* MT9V111 */
6260        {0xe001, 0x13},
6261        {0x8001, 0x13},
6262        {0x8000, 0x14},         /* CS2102K */
6263        {0x8400, 0x15},         /* MT9V111 */
6264        {0xe400, 0x15},
6265};
6266
6267static int vga_3wr_probe(struct gspca_dev *gspca_dev)
6268{
6269        struct sd *sd = (struct sd *) gspca_dev;
6270        int i;
6271        u16 retword;
6272
6273/*fixme: lack of 8b=b3 (11,12)-> 10, 8b=e0 (14,15,16)-> 12 found in gspcav1*/
6274        reg_w(gspca_dev, 0x02, 0x0010);
6275        reg_r(gspca_dev, 0x0010);
6276        reg_w(gspca_dev, 0x01, 0x0000);
6277        reg_w(gspca_dev, 0x00, 0x0010);
6278        reg_w(gspca_dev, 0x01, 0x0001);
6279        reg_w(gspca_dev, 0x91, 0x008b);
6280        reg_w(gspca_dev, 0x03, 0x0012);
6281        reg_w(gspca_dev, 0x01, 0x0012);
6282        reg_w(gspca_dev, 0x05, 0x0012);
6283        retword = i2c_read(gspca_dev, 0x14);
6284        if (retword != 0)
6285                return 0x11;                    /* HV7131R */
6286        retword = i2c_read(gspca_dev, 0x15);
6287        if (retword != 0)
6288                return 0x11;                    /* HV7131R */
6289        retword = i2c_read(gspca_dev, 0x16);
6290        if (retword != 0)
6291                return 0x11;                    /* HV7131R */
6292
6293        reg_w(gspca_dev, 0x02, 0x0010);
6294        retword = reg_r(gspca_dev, 0x000b) << 8;
6295        retword |= reg_r(gspca_dev, 0x000a);
6296        PDEBUG(D_PROBE, "probe 3wr vga 1 0x%04x", retword);
6297        reg_r(gspca_dev, 0x0010);
6298        if ((retword & 0xff00) == 0x6400)
6299                return 0x02;            /* TAS5130C */
6300        for (i = 0; i < ARRAY_SIZE(chipset_revision_sensor); i++) {
6301                if (chipset_revision_sensor[i].revision == retword) {
6302                        sd->chip_revision = retword;
6303                        send_unknown(gspca_dev, SENSOR_PB0330);
6304                        return chipset_revision_sensor[i].internal_sensor_id;
6305                }
6306        }
6307
6308        reg_w(gspca_dev, 0x01, 0x0000); /* check PB0330 */
6309        reg_w(gspca_dev, 0x01, 0x0001);
6310        reg_w(gspca_dev, 0xdd, 0x008b);
6311        reg_w(gspca_dev, 0x0a, 0x0010);
6312        reg_w(gspca_dev, 0x03, 0x0012);
6313        reg_w(gspca_dev, 0x01, 0x0012);
6314        retword = i2c_read(gspca_dev, 0x00);
6315        if (retword != 0) {
6316                PDEBUG(D_PROBE, "probe 3wr vga type 0a");
6317                return 0x0a;                    /* PB0330 */
6318        }
6319
6320        /* probe gc0303 / gc0305 */
6321        reg_w(gspca_dev, 0x01, 0x0000);
6322        reg_w(gspca_dev, 0x01, 0x0001);
6323        reg_w(gspca_dev, 0x98, 0x008b);
6324        reg_w(gspca_dev, 0x01, 0x0010);
6325        reg_w(gspca_dev, 0x03, 0x0012);
6326        msleep(2);
6327        reg_w(gspca_dev, 0x01, 0x0012);
6328        retword = i2c_read(gspca_dev, 0x00);
6329        if (retword != 0) {
6330                PDEBUG(D_PROBE, "probe 3wr vga type %02x", retword);
6331                if (retword == 0x0011)                  /* gc0303 */
6332                        return 0x0303;
6333                if (retword == 0x0029)                  /* gc0305 */
6334                        send_unknown(gspca_dev, SENSOR_GC0305);
6335                return retword;
6336        }
6337
6338        reg_w(gspca_dev, 0x01, 0x0000); /* check OmniVision */
6339        reg_w(gspca_dev, 0x01, 0x0001);
6340        reg_w(gspca_dev, 0xa1, 0x008b);
6341        reg_w(gspca_dev, 0x08, 0x008d);
6342        reg_w(gspca_dev, 0x06, 0x0010);
6343        reg_w(gspca_dev, 0x01, 0x0012);
6344        reg_w(gspca_dev, 0x05, 0x0012);
6345        if (i2c_read(gspca_dev, 0x1c) == 0x007f /* OV7610 - manufacturer ID */
6346            && i2c_read(gspca_dev, 0x1d) == 0x00a2) {
6347                send_unknown(gspca_dev, SENSOR_OV7620);
6348                return 0x06;            /* OmniVision confirm ? */
6349        }
6350
6351        reg_w(gspca_dev, 0x01, 0x0000);
6352        reg_w(gspca_dev, 0x00, 0x0002);
6353        reg_w(gspca_dev, 0x01, 0x0010);
6354        reg_w(gspca_dev, 0x01, 0x0001);
6355        reg_w(gspca_dev, 0xee, 0x008b);
6356        reg_w(gspca_dev, 0x03, 0x0012);
6357        reg_w(gspca_dev, 0x01, 0x0012);
6358        reg_w(gspca_dev, 0x05, 0x0012);
6359        retword = i2c_read(gspca_dev, 0x00) << 8;       /* ID 0 */
6360        retword |= i2c_read(gspca_dev, 0x01);           /* ID 1 */
6361        PDEBUG(D_PROBE, "probe 3wr vga 2 0x%04x", retword);
6362        if (retword == 0x2030) {
6363#ifdef GSPCA_DEBUG
6364                u8 retbyte;
6365
6366                retbyte = i2c_read(gspca_dev, 0x02);    /* revision number */
6367                PDEBUG(D_PROBE, "sensor PO2030 rev 0x%02x", retbyte);
6368#endif
6369                send_unknown(gspca_dev, SENSOR_PO2030);
6370                return retword;
6371        }
6372
6373        reg_w(gspca_dev, 0x01, 0x0000);
6374        reg_w(gspca_dev, 0x0a, 0x0010);
6375        reg_w(gspca_dev, 0xd3, 0x008b);
6376        reg_w(gspca_dev, 0x01, 0x0001);
6377        reg_w(gspca_dev, 0x03, 0x0012);
6378        reg_w(gspca_dev, 0x01, 0x0012);
6379        reg_w(gspca_dev, 0x05, 0x0012);
6380        reg_w(gspca_dev, 0xd3, 0x008b);
6381        retword = i2c_read(gspca_dev, 0x01);
6382        if (retword != 0) {
6383                PDEBUG(D_PROBE, "probe 3wr vga type 0a ? ret: %04x", retword);
6384                return 0x16;                    /* adcm2700 (6100/6200) */
6385        }
6386        return -1;
6387}
6388
6389static int zcxx_probeSensor(struct gspca_dev *gspca_dev)
6390{
6391        struct sd *sd = (struct sd *) gspca_dev;
6392        int sensor;
6393
6394        switch (sd->sensor) {
6395        case SENSOR_MC501CB:
6396                return -1;              /* don't probe */
6397        case SENSOR_GC0303:
6398                        /* may probe but with no write in reg 0x0010 */
6399                return -1;              /* don't probe */
6400        case SENSOR_PAS106:
6401                sensor =  sif_probe(gspca_dev);
6402                if (sensor >= 0)
6403                        return sensor;
6404                break;
6405        }
6406        sensor = vga_2wr_probe(gspca_dev);
6407        if (sensor >= 0)
6408                return sensor;
6409        return vga_3wr_probe(gspca_dev);
6410}
6411
6412/* this function is called at probe time */
6413static int sd_config(struct gspca_dev *gspca_dev,
6414                        const struct usb_device_id *id)
6415{
6416        struct sd *sd = (struct sd *) gspca_dev;
6417
6418        if (id->idProduct == 0x301b)
6419                sd->bridge = BRIDGE_ZC301;
6420        else
6421                sd->bridge = BRIDGE_ZC303;
6422
6423        /* define some sensors from the vendor/product */
6424        sd->sensor = id->driver_info;
6425
6426        gspca_dev->cam.ctrls = sd->ctrls;
6427        sd->quality = QUALITY_DEF;
6428
6429        /* if USB 1.1, let some bandwidth for the audio device */
6430        if (gspca_dev->audio && gspca_dev->dev->speed < USB_SPEED_HIGH)
6431                gspca_dev->nbalt--;
6432
6433        return 0;
6434}
6435
6436/* this function is called at probe and resume time */
6437static int sd_init(struct gspca_dev *gspca_dev)
6438{
6439        struct sd *sd = (struct sd *) gspca_dev;
6440        struct cam *cam;
6441        int sensor;
6442        static const u8 gamma[SENSOR_MAX] = {
6443                [SENSOR_ADCM2700] =     4,
6444                [SENSOR_CS2102] =       4,
6445                [SENSOR_CS2102K] =      5,
6446                [SENSOR_GC0303] =       3,
6447                [SENSOR_GC0305] =       4,
6448                [SENSOR_HDCS2020] =     4,
6449                [SENSOR_HV7131B] =      4,
6450                [SENSOR_HV7131R] =      4,
6451                [SENSOR_ICM105A] =      4,
6452                [SENSOR_MC501CB] =      4,
6453                [SENSOR_MT9V111_1] =    4,
6454                [SENSOR_MT9V111_3] =    4,
6455                [SENSOR_OV7620] =       3,
6456                [SENSOR_OV7630C] =      4,
6457                [SENSOR_PAS106] =       4,
6458                [SENSOR_PAS202B] =      4,
6459                [SENSOR_PB0330] =       4,
6460                [SENSOR_PO2030] =       4,
6461                [SENSOR_TAS5130C] =     3,
6462        };
6463        static const u8 mode_tb[SENSOR_MAX] = {
6464                [SENSOR_ADCM2700] =     2,
6465                [SENSOR_CS2102] =       1,
6466                [SENSOR_CS2102K] =      1,
6467                [SENSOR_GC0303] =       1,
6468                [SENSOR_GC0305] =       1,
6469                [SENSOR_HDCS2020] =     1,
6470                [SENSOR_HV7131B] =      1,
6471                [SENSOR_HV7131R] =      1,
6472                [SENSOR_ICM105A] =      1,
6473                [SENSOR_MC501CB] =      2,
6474                [SENSOR_MT9V111_1] =    1,
6475                [SENSOR_MT9V111_3] =    1,
6476                [SENSOR_OV7620] =       2,
6477                [SENSOR_OV7630C] =      1,
6478                [SENSOR_PAS106] =       0,
6479                [SENSOR_PAS202B] =      1,
6480                [SENSOR_PB0330] =       1,
6481                [SENSOR_PO2030] =       1,
6482                [SENSOR_TAS5130C] =     1,
6483        };
6484
6485        sensor = zcxx_probeSensor(gspca_dev);
6486        if (sensor >= 0)
6487                PDEBUG(D_PROBE, "probe sensor -> %04x", sensor);
6488        if ((unsigned) force_sensor < SENSOR_MAX) {
6489                sd->sensor = force_sensor;
6490                PDEBUG(D_PROBE, "sensor forced to %d", force_sensor);
6491        } else {
6492                switch (sensor) {
6493                case -1:
6494                        switch (sd->sensor) {
6495                        case SENSOR_MC501CB:
6496                                PDEBUG(D_PROBE, "Sensor MC501CB");
6497                                break;
6498                        case SENSOR_GC0303:
6499                                PDEBUG(D_PROBE, "Sensor GC0303");
6500                                break;
6501                        default:
6502                                pr_warn("Unknown sensor - set to TAS5130C\n");
6503                                sd->sensor = SENSOR_TAS5130C;
6504                        }
6505                        break;
6506                case 0:
6507                        /* check the sensor type */
6508                        sensor = i2c_read(gspca_dev, 0x00);
6509                        PDEBUG(D_PROBE, "Sensor hv7131 type %d", sensor);
6510                        switch (sensor) {
6511                        case 0:                 /* hv7131b */
6512                        case 1:                 /* hv7131e */
6513                                PDEBUG(D_PROBE, "Find Sensor HV7131B");
6514                                sd->sensor = SENSOR_HV7131B;
6515                                break;
6516                        default:
6517/*                      case 2:                  * hv7131r */
6518                                PDEBUG(D_PROBE, "Find Sensor HV7131R");
6519                                sd->sensor = SENSOR_HV7131R;
6520                                break;
6521                        }
6522                        break;
6523                case 0x02:
6524                        PDEBUG(D_PROBE, "Sensor TAS5130C");
6525                        sd->sensor = SENSOR_TAS5130C;
6526                        break;
6527                case 0x04:
6528                        PDEBUG(D_PROBE, "Find Sensor CS2102");
6529                        sd->sensor = SENSOR_CS2102;
6530                        break;
6531                case 0x08:
6532                        PDEBUG(D_PROBE, "Find Sensor HDCS2020");
6533                        sd->sensor = SENSOR_HDCS2020;
6534                        break;
6535                case 0x0a:
6536                        PDEBUG(D_PROBE,
6537                                "Find Sensor PB0330. Chip revision %x",
6538                                sd->chip_revision);
6539                        sd->sensor = SENSOR_PB0330;
6540                        break;
6541                case 0x0c:
6542                        PDEBUG(D_PROBE, "Find Sensor ICM105A");
6543                        sd->sensor = SENSOR_ICM105A;
6544                        break;
6545                case 0x0e:
6546                        PDEBUG(D_PROBE, "Find Sensor PAS202B");
6547                        sd->sensor = SENSOR_PAS202B;
6548/*                      sd->sharpness = 1; */
6549                        break;
6550                case 0x0f:
6551                        PDEBUG(D_PROBE, "Find Sensor PAS106");
6552                        sd->sensor = SENSOR_PAS106;
6553                        break;
6554                case 0x10:
6555                case 0x12:
6556                        PDEBUG(D_PROBE, "Find Sensor TAS5130C");
6557                        sd->sensor = SENSOR_TAS5130C;
6558                        break;
6559                case 0x11:
6560                        PDEBUG(D_PROBE, "Find Sensor HV7131R");
6561                        sd->sensor = SENSOR_HV7131R;
6562                        break;
6563                case 0x13:
6564                case 0x15:
6565                        PDEBUG(D_PROBE,
6566                                "Sensor MT9V111. Chip revision %04x",
6567                                sd->chip_revision);
6568                        sd->sensor = sd->bridge == BRIDGE_ZC301
6569                                        ? SENSOR_MT9V111_1
6570                                        : SENSOR_MT9V111_3;
6571                        break;
6572                case 0x14:
6573                        PDEBUG(D_PROBE,
6574                                "Find Sensor CS2102K?. Chip revision %x",
6575                                sd->chip_revision);
6576                        sd->sensor = SENSOR_CS2102K;
6577                        break;
6578                case 0x16:
6579                        PDEBUG(D_PROBE, "Find Sensor ADCM2700");
6580                        sd->sensor = SENSOR_ADCM2700;
6581                        break;
6582                case 0x29:
6583                        PDEBUG(D_PROBE, "Find Sensor GC0305");
6584                        sd->sensor = SENSOR_GC0305;
6585                        break;
6586                case 0x0303:
6587                        PDEBUG(D_PROBE, "Sensor GC0303");
6588                        sd->sensor =  SENSOR_GC0303;
6589                        break;
6590                case 0x2030:
6591                        PDEBUG(D_PROBE, "Find Sensor PO2030");
6592                        sd->sensor = SENSOR_PO2030;
6593                        sd->ctrls[SHARPNESS].def = 0;   /* from win traces */
6594                        break;
6595                case 0x7620:
6596                        PDEBUG(D_PROBE, "Find Sensor OV7620");
6597                        sd->sensor = SENSOR_OV7620;
6598                        break;
6599                case 0x7631:
6600                        PDEBUG(D_PROBE, "Find Sensor OV7630C");
6601                        sd->sensor = SENSOR_OV7630C;
6602                        break;
6603                case 0x7648:
6604                        PDEBUG(D_PROBE, "Find Sensor OV7648");
6605                        sd->sensor = SENSOR_OV7620;     /* same sensor (?) */
6606                        break;
6607                default:
6608                        pr_err("Unknown sensor %04x\n", sensor);
6609                        return -EINVAL;
6610                }
6611        }
6612        if (sensor < 0x20) {
6613                if (sensor == -1 || sensor == 0x10 || sensor == 0x12)
6614                        reg_w(gspca_dev, 0x02, 0x0010);
6615                reg_r(gspca_dev, 0x0010);
6616        }
6617
6618        cam = &gspca_dev->cam;
6619        switch (mode_tb[sd->sensor]) {
6620        case 0:
6621                cam->cam_mode = sif_mode;
6622                cam->nmodes = ARRAY_SIZE(sif_mode);
6623                break;
6624        case 1:
6625                cam->cam_mode = vga_mode;
6626                cam->nmodes = ARRAY_SIZE(vga_mode);
6627                break;
6628        default:
6629/*      case 2: */
6630                cam->cam_mode = broken_vga_mode;
6631                cam->nmodes = ARRAY_SIZE(broken_vga_mode);
6632                break;
6633        }
6634
6635        sd->ctrls[GAMMA].def = gamma[sd->sensor];
6636
6637        switch (sd->sensor) {
6638        case SENSOR_HV7131R:
6639                break;
6640        case SENSOR_OV7630C:
6641                gspca_dev->ctrl_dis = (1 << LIGHTFREQ) | (1 << EXPOSURE);
6642                break;
6643        default:
6644                gspca_dev->ctrl_dis = (1 << EXPOSURE);
6645                break;
6646        }
6647#if AUTOGAIN_DEF
6648        if (sd->ctrls[AUTOGAIN].val)
6649                gspca_dev->ctrl_inac = (1 << EXPOSURE);
6650#endif
6651
6652        /* switch off the led */
6653        reg_w(gspca_dev, 0x01, 0x0000);
6654        return gspca_dev->usb_err;
6655}
6656
6657static int sd_start(struct gspca_dev *gspca_dev)
6658{
6659        struct sd *sd = (struct sd *) gspca_dev;
6660        int mode;
6661        static const struct usb_action *init_tb[SENSOR_MAX][2] = {
6662        [SENSOR_ADCM2700] =
6663                        {adcm2700_Initial, adcm2700_InitialScale},
6664        [SENSOR_CS2102] =
6665                        {cs2102_Initial, cs2102_InitialScale},
6666        [SENSOR_CS2102K] =
6667                        {cs2102K_Initial, cs2102K_InitialScale},
6668        [SENSOR_GC0303] =
6669                {gc0303_Initial, gc0303_InitialScale},
6670        [SENSOR_GC0305] =
6671                        {gc0305_Initial, gc0305_InitialScale},
6672        [SENSOR_HDCS2020] =
6673                        {hdcs2020_Initial, hdcs2020_InitialScale},
6674        [SENSOR_HV7131B] =
6675                        {hv7131b_Initial, hv7131b_InitialScale},
6676        [SENSOR_HV7131R] =
6677                        {hv7131r_Initial, hv7131r_InitialScale},
6678        [SENSOR_ICM105A] =
6679                        {icm105a_Initial, icm105a_InitialScale},
6680        [SENSOR_MC501CB] =
6681                        {mc501cb_Initial, mc501cb_InitialScale},
6682        [SENSOR_MT9V111_1] =
6683                        {mt9v111_1_Initial, mt9v111_1_InitialScale},
6684        [SENSOR_MT9V111_3] =
6685                        {mt9v111_3_Initial, mt9v111_3_InitialScale},
6686        [SENSOR_OV7620] =
6687                        {ov7620_Initial, ov7620_InitialScale},
6688        [SENSOR_OV7630C] =
6689                        {ov7630c_Initial, ov7630c_InitialScale},
6690        [SENSOR_PAS106] =
6691                        {pas106b_Initial, pas106b_InitialScale},
6692        [SENSOR_PAS202B] =
6693                        {pas202b_Initial, pas202b_InitialScale},
6694        [SENSOR_PB0330] =
6695                        {pb0330_Initial, pb0330_InitialScale},
6696        [SENSOR_PO2030] =
6697                        {po2030_Initial, po2030_InitialScale},
6698        [SENSOR_TAS5130C] =
6699                        {tas5130c_Initial, tas5130c_InitialScale},
6700        };
6701
6702        /* create the JPEG header */
6703        jpeg_define(sd->jpeg_hdr, gspca_dev->height, gspca_dev->width,
6704                        0x21);          /* JPEG 422 */
6705        jpeg_set_qual(sd->jpeg_hdr, sd->quality);
6706
6707        mode = gspca_dev->cam.cam_mode[gspca_dev->curr_mode].priv;
6708        switch (sd->sensor) {
6709        case SENSOR_HV7131R:
6710                zcxx_probeSensor(gspca_dev);
6711                break;
6712        case SENSOR_PAS106:
6713                usb_exchange(gspca_dev, pas106b_Initial_com);
6714                break;
6715        }
6716        usb_exchange(gspca_dev, init_tb[sd->sensor][mode]);
6717
6718        switch (sd->sensor) {
6719        case SENSOR_ADCM2700:
6720        case SENSOR_GC0305:
6721        case SENSOR_OV7620:
6722        case SENSOR_PO2030:
6723        case SENSOR_TAS5130C:
6724        case SENSOR_GC0303:
6725/*              msleep(100);                     * ?? */
6726                reg_r(gspca_dev, 0x0002);       /* --> 0x40 */
6727                reg_w(gspca_dev, 0x09, 0x01ad); /* (from win traces) */
6728                reg_w(gspca_dev, 0x15, 0x01ae);
6729                if (sd->sensor == SENSOR_TAS5130C)
6730                        break;
6731                reg_w(gspca_dev, 0x0d, 0x003a);
6732                reg_w(gspca_dev, 0x02, 0x003b);
6733                reg_w(gspca_dev, 0x00, 0x0038);
6734                break;
6735        case SENSOR_HV7131R:
6736        case SENSOR_PAS202B:
6737                reg_w(gspca_dev, 0x03, 0x003b);
6738                reg_w(gspca_dev, 0x0c, 0x003a);
6739                reg_w(gspca_dev, 0x0b, 0x0039);
6740                if (sd->sensor == SENSOR_HV7131R)
6741                        reg_w(gspca_dev, 0x50, ZC3XX_R11D_GLOBALGAIN);
6742                break;
6743        }
6744
6745        setmatrix(gspca_dev);
6746        switch (sd->sensor) {
6747        case SENSOR_ADCM2700:
6748        case SENSOR_OV7620:
6749                reg_r(gspca_dev, 0x0008);
6750                reg_w(gspca_dev, 0x00, 0x0008);
6751                break;
6752        case SENSOR_PAS202B:
6753        case SENSOR_GC0305:
6754        case SENSOR_HV7131R:
6755        case SENSOR_TAS5130C:
6756                reg_r(gspca_dev, 0x0008);
6757                /* fall thru */
6758        case SENSOR_PO2030:
6759                reg_w(gspca_dev, 0x03, 0x0008);
6760                break;
6761        }
6762        setsharpness(gspca_dev);
6763
6764        /* set the gamma tables when not set */
6765        switch (sd->sensor) {
6766        case SENSOR_CS2102K:            /* gamma set in xxx_Initial */
6767        case SENSOR_HDCS2020:
6768        case SENSOR_OV7630C:
6769                break;
6770        default:
6771                setcontrast(gspca_dev);
6772                break;
6773        }
6774        setmatrix(gspca_dev);                   /* one more time? */
6775        switch (sd->sensor) {
6776        case SENSOR_OV7620:
6777        case SENSOR_PAS202B:
6778                reg_r(gspca_dev, 0x0180);       /* from win */
6779                reg_w(gspca_dev, 0x00, 0x0180);
6780                break;
6781        default:
6782                setquality(gspca_dev);
6783                break;
6784        }
6785        setlightfreq(gspca_dev);
6786
6787        switch (sd->sensor) {
6788        case SENSOR_ADCM2700:
6789                reg_w(gspca_dev, 0x09, 0x01ad); /* (from win traces) */
6790                reg_w(gspca_dev, 0x15, 0x01ae);
6791                reg_w(gspca_dev, 0x02, 0x0180);
6792                                                /* ms-win + */
6793                reg_w(gspca_dev, 0x40, 0x0117);
6794                break;
6795        case SENSOR_HV7131R:
6796                if (!sd->ctrls[AUTOGAIN].val)
6797                        setexposure(gspca_dev);
6798                reg_w(gspca_dev, 0x00, ZC3XX_R1A7_CALCGLOBALMEAN);
6799                break;
6800        case SENSOR_GC0305:
6801        case SENSOR_TAS5130C:
6802                reg_w(gspca_dev, 0x09, 0x01ad); /* (from win traces) */
6803                reg_w(gspca_dev, 0x15, 0x01ae);
6804                /* fall thru */
6805        case SENSOR_PAS202B:
6806        case SENSOR_PO2030:
6807/*              reg_w(gspca_dev, 0x40, ZC3XX_R117_GGAIN); in win traces */
6808                reg_r(gspca_dev, 0x0180);
6809                break;
6810        case SENSOR_OV7620:
6811                reg_w(gspca_dev, 0x09, 0x01ad);
6812                reg_w(gspca_dev, 0x15, 0x01ae);
6813                i2c_read(gspca_dev, 0x13);      /*fixme: returns 0xa3 */
6814                i2c_write(gspca_dev, 0x13, 0xa3, 0x00);
6815                                        /*fixme: returned value to send? */
6816                reg_w(gspca_dev, 0x40, 0x0117);
6817                reg_r(gspca_dev, 0x0180);
6818                break;
6819        }
6820
6821        setautogain(gspca_dev);
6822        switch (sd->sensor) {
6823        case SENSOR_PO2030:
6824                msleep(50);
6825                reg_w(gspca_dev, 0x00, 0x0007); /* (from win traces) */
6826                reg_w(gspca_dev, 0x02, ZC3XX_R008_CLOCKSETTING);
6827                break;
6828        }
6829        return gspca_dev->usb_err;
6830}
6831
6832/* called on streamoff with alt 0 and on disconnect */
6833static void sd_stop0(struct gspca_dev *gspca_dev)
6834{
6835        struct sd *sd = (struct sd *) gspca_dev;
6836
6837        if (!gspca_dev->present)
6838                return;
6839        send_unknown(gspca_dev, sd->sensor);
6840}
6841
6842static void sd_pkt_scan(struct gspca_dev *gspca_dev,
6843                        u8 *data,
6844                        int len)
6845{
6846        struct sd *sd = (struct sd *) gspca_dev;
6847
6848        /* check the JPEG end of frame */
6849        if (len >= 3
6850         && data[len - 3] == 0xff && data[len - 2] == 0xd9) {
6851/*fixme: what does the last byte mean?*/
6852                gspca_frame_add(gspca_dev, LAST_PACKET,
6853                                        data, len - 1);
6854                return;
6855        }
6856
6857        /* check the JPEG start of a frame */
6858        if (data[0] == 0xff && data[1] == 0xd8) {
6859                /* put the JPEG header in the new frame */
6860                gspca_frame_add(gspca_dev, FIRST_PACKET,
6861                        sd->jpeg_hdr, JPEG_HDR_SZ);
6862
6863                /* remove the webcam's header:
6864                 * ff d8 ff fe 00 0e 00 00 ss ss 00 01 ww ww hh hh pp pp
6865                 *      - 'ss ss' is the frame sequence number (BE)
6866                 *      - 'ww ww' and 'hh hh' are the window dimensions (BE)
6867                 *      - 'pp pp' is the packet sequence number (BE)
6868                 */
6869                data += 18;
6870                len -= 18;
6871        }
6872        gspca_frame_add(gspca_dev, INTER_PACKET, data, len);
6873}
6874
6875static int sd_setautogain(struct gspca_dev *gspca_dev, __s32 val)
6876{
6877        struct sd *sd = (struct sd *) gspca_dev;
6878
6879        sd->ctrls[AUTOGAIN].val = val;
6880        if (val) {
6881                gspca_dev->ctrl_inac |= (1 << EXPOSURE);
6882        } else {
6883                gspca_dev->ctrl_inac &= ~(1 << EXPOSURE);
6884                if (gspca_dev->streaming)
6885                        getexposure(gspca_dev);
6886        }
6887        if (gspca_dev->streaming)
6888                setautogain(gspca_dev);
6889        return gspca_dev->usb_err;
6890}
6891
6892static int sd_querymenu(struct gspca_dev *gspca_dev,
6893                        struct v4l2_querymenu *menu)
6894{
6895        switch (menu->id) {
6896        case V4L2_CID_POWER_LINE_FREQUENCY:
6897                switch (menu->index) {
6898                case 0:         /* V4L2_CID_POWER_LINE_FREQUENCY_DISABLED */
6899                        strcpy((char *) menu->name, "NoFliker");
6900                        return 0;
6901                case 1:         /* V4L2_CID_POWER_LINE_FREQUENCY_50HZ */
6902                        strcpy((char *) menu->name, "50 Hz");
6903                        return 0;
6904                case 2:         /* V4L2_CID_POWER_LINE_FREQUENCY_60HZ */
6905                        strcpy((char *) menu->name, "60 Hz");
6906                        return 0;
6907                }
6908                break;
6909        }
6910        return -EINVAL;
6911}
6912
6913static int sd_set_jcomp(struct gspca_dev *gspca_dev,
6914                        struct v4l2_jpegcompression *jcomp)
6915{
6916        struct sd *sd = (struct sd *) gspca_dev;
6917
6918        if (jcomp->quality < QUALITY_MIN)
6919                sd->quality = QUALITY_MIN;
6920        else if (jcomp->quality > QUALITY_MAX)
6921                sd->quality = QUALITY_MAX;
6922        else
6923                sd->quality = jcomp->quality;
6924        if (gspca_dev->streaming)
6925                jpeg_set_qual(sd->jpeg_hdr, sd->quality);
6926        return gspca_dev->usb_err;
6927}
6928
6929static int sd_get_jcomp(struct gspca_dev *gspca_dev,
6930                        struct v4l2_jpegcompression *jcomp)
6931{
6932        struct sd *sd = (struct sd *) gspca_dev;
6933
6934        memset(jcomp, 0, sizeof *jcomp);
6935        jcomp->quality = sd->quality;
6936        jcomp->jpeg_markers = V4L2_JPEG_MARKER_DHT
6937                        | V4L2_JPEG_MARKER_DQT;
6938        return 0;
6939}
6940
6941#if defined(CONFIG_INPUT) || defined(CONFIG_INPUT_MODULE)
6942static int sd_int_pkt_scan(struct gspca_dev *gspca_dev,
6943                        u8 *data,               /* interrupt packet data */
6944                        int len)                /* interrput packet length */
6945{
6946        if (len == 8 && data[4] == 1) {
6947                input_report_key(gspca_dev->input_dev, KEY_CAMERA, 1);
6948                input_sync(gspca_dev->input_dev);
6949                input_report_key(gspca_dev->input_dev, KEY_CAMERA, 0);
6950                input_sync(gspca_dev->input_dev);
6951        }
6952
6953        return 0;
6954}
6955#endif
6956
6957static const struct sd_desc sd_desc = {
6958        .name = MODULE_NAME,
6959        .ctrls = sd_ctrls,
6960        .nctrls = ARRAY_SIZE(sd_ctrls),
6961        .config = sd_config,
6962        .init = sd_init,
6963        .start = sd_start,
6964        .stop0 = sd_stop0,
6965        .pkt_scan = sd_pkt_scan,
6966        .querymenu = sd_querymenu,
6967        .get_jcomp = sd_get_jcomp,
6968        .set_jcomp = sd_set_jcomp,
6969#if defined(CONFIG_INPUT) || defined(CONFIG_INPUT_MODULE)
6970        .int_pkt_scan = sd_int_pkt_scan,
6971#endif
6972};
6973
6974static const struct usb_device_id device_table[] = {
6975        {USB_DEVICE(0x03f0, 0x1b07)},
6976        {USB_DEVICE(0x041e, 0x041e)},
6977        {USB_DEVICE(0x041e, 0x4017)},
6978        {USB_DEVICE(0x041e, 0x401c), .driver_info = SENSOR_PAS106},
6979        {USB_DEVICE(0x041e, 0x401e)},
6980        {USB_DEVICE(0x041e, 0x401f)},
6981        {USB_DEVICE(0x041e, 0x4022)},
6982        {USB_DEVICE(0x041e, 0x4029)},
6983        {USB_DEVICE(0x041e, 0x4034), .driver_info = SENSOR_PAS106},
6984        {USB_DEVICE(0x041e, 0x4035), .driver_info = SENSOR_PAS106},
6985        {USB_DEVICE(0x041e, 0x4036)},
6986        {USB_DEVICE(0x041e, 0x403a)},
6987        {USB_DEVICE(0x041e, 0x4051), .driver_info = SENSOR_GC0303},
6988        {USB_DEVICE(0x041e, 0x4053), .driver_info = SENSOR_GC0303},
6989        {USB_DEVICE(0x0458, 0x7007)},
6990        {USB_DEVICE(0x0458, 0x700c)},
6991        {USB_DEVICE(0x0458, 0x700f)},
6992        {USB_DEVICE(0x0461, 0x0a00)},
6993        {USB_DEVICE(0x046d, 0x089d), .driver_info = SENSOR_MC501CB},
6994        {USB_DEVICE(0x046d, 0x08a0)},
6995        {USB_DEVICE(0x046d, 0x08a1)},
6996        {USB_DEVICE(0x046d, 0x08a2)},
6997        {USB_DEVICE(0x046d, 0x08a3)},
6998        {USB_DEVICE(0x046d, 0x08a6)},
6999        {USB_DEVICE(0x046d, 0x08a7)},
7000        {USB_DEVICE(0x046d, 0x08a9)},
7001        {USB_DEVICE(0x046d, 0x08aa)},
7002        {USB_DEVICE(0x046d, 0x08ac)},
7003        {USB_DEVICE(0x046d, 0x08ad)},
7004        {USB_DEVICE(0x046d, 0x08ae)},
7005        {USB_DEVICE(0x046d, 0x08af)},
7006        {USB_DEVICE(0x046d, 0x08b9)},
7007        {USB_DEVICE(0x046d, 0x08d7)},
7008        {USB_DEVICE(0x046d, 0x08d8)},
7009        {USB_DEVICE(0x046d, 0x08d9)},
7010        {USB_DEVICE(0x046d, 0x08da)},
7011        {USB_DEVICE(0x046d, 0x08dd), .driver_info = SENSOR_MC501CB},
7012        {USB_DEVICE(0x0471, 0x0325), .driver_info = SENSOR_PAS106},
7013        {USB_DEVICE(0x0471, 0x0326), .driver_info = SENSOR_PAS106},
7014        {USB_DEVICE(0x0471, 0x032d), .driver_info = SENSOR_PAS106},
7015        {USB_DEVICE(0x0471, 0x032e), .driver_info = SENSOR_PAS106},
7016        {USB_DEVICE(0x055f, 0xc005)},
7017        {USB_DEVICE(0x055f, 0xd003)},
7018        {USB_DEVICE(0x055f, 0xd004)},
7019        {USB_DEVICE(0x0698, 0x2003)},
7020        {USB_DEVICE(0x0ac8, 0x0301), .driver_info = SENSOR_PAS106},
7021        {USB_DEVICE(0x0ac8, 0x0302), .driver_info = SENSOR_PAS106},
7022        {USB_DEVICE(0x0ac8, 0x301b)},
7023        {USB_DEVICE(0x0ac8, 0x303b)},
7024        {USB_DEVICE(0x0ac8, 0x305b)},
7025        {USB_DEVICE(0x0ac8, 0x307b)},
7026        {USB_DEVICE(0x10fd, 0x0128)},
7027        {USB_DEVICE(0x10fd, 0x804d)},
7028        {USB_DEVICE(0x10fd, 0x8050)},
7029        {}                      /* end of entry */
7030};
7031MODULE_DEVICE_TABLE(usb, device_table);
7032
7033/* -- device connect -- */
7034static int sd_probe(struct usb_interface *intf,
7035                        const struct usb_device_id *id)
7036{
7037        return gspca_dev_probe(intf, id, &sd_desc, sizeof(struct sd),
7038                                THIS_MODULE);
7039}
7040
7041/* USB driver */
7042static struct usb_driver sd_driver = {
7043        .name = MODULE_NAME,
7044        .id_table = device_table,
7045        .probe = sd_probe,
7046        .disconnect = gspca_disconnect,
7047#ifdef CONFIG_PM
7048        .suspend = gspca_suspend,
7049        .resume = gspca_resume,
7050#endif
7051};
7052
7053static int __init sd_mod_init(void)
7054{
7055        return usb_register(&sd_driver);
7056}
7057
7058static void __exit sd_mod_exit(void)
7059{
7060        usb_deregister(&sd_driver);
7061}
7062
7063module_init(sd_mod_init);
7064module_exit(sd_mod_exit);
7065
7066module_param(force_sensor, int, 0644);
7067MODULE_PARM_DESC(force_sensor,
7068        "Force sensor. Only for experts!!!");
7069
lxr.linux.no kindly hosted by Redpill Linpro AS, provider of Linux consulting and operations services since 1995.