Lines Matching +full:1 +full:- +full:sd
1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * Copyright (c) 2001 Jean-Fredric Clere, Nikolas Zimmermann, Georg Acher
4 * Mark Cave-Ayland, Carlo E Prelz, Dick Streefland
9 * P/N 861050-0010: Sensor HDCS1000 ASIC STV0600
10 * P/N 861050-0020: Sensor Photobit PB100 ASIC STV0600-1 - QuickCam Express
11 * P/N 861055: Sensor ST VV6410 ASIC STV0610 - LEGO cam
12 * P/N 861075-0040: Sensor HDCS1000 ASIC
13 * P/N 961179-0700: Sensor ST VV6410 ASIC STV0602 - Dexxa WebCam USB
14 * P/N 861040-0000: Sensor ST VV6410 ASIC STV0610 - QuickCam Web
18 * The spec file for the PB-0100 suggests the following for best quality
26 auto-exposure
28 * PB_EXPGAIN = R14 = 0x11 (17 dec) : Sets the auto-exposure value
30 auto-exposure routine
78 container_of(ctrl->handler, struct gspca_dev, ctrl_handler); in pb0100_s_ctrl()
79 struct sd *sd = (struct sd *)gspca_dev; in pb0100_s_ctrl() local
80 struct pb0100_ctrls *ctrls = sd->sensor_priv; in pb0100_s_ctrl()
81 int err = -EINVAL; in pb0100_s_ctrl()
83 switch (ctrl->id) { in pb0100_s_ctrl()
85 err = pb0100_set_autogain(gspca_dev, ctrl->val); in pb0100_s_ctrl()
88 if (ctrl->val) in pb0100_s_ctrl()
90 err = pb0100_set_gain(gspca_dev, ctrls->gain->val); in pb0100_s_ctrl()
93 err = pb0100_set_exposure(gspca_dev, ctrls->exposure->val); in pb0100_s_ctrl()
96 err = pb0100_set_autogain_target(gspca_dev, ctrl->val); in pb0100_s_ctrl()
106 static int pb0100_init_controls(struct sd *sd) in pb0100_init_controls() argument
108 struct v4l2_ctrl_handler *hdl = &sd->gspca_dev.ctrl_handler; in pb0100_init_controls()
116 .step = 1, in pb0100_init_controls()
124 .max = 1, in pb0100_init_controls()
125 .step = 1, in pb0100_init_controls()
126 .def = 1, in pb0100_init_controls()
131 return -ENOMEM; in pb0100_init_controls()
134 ctrls->autogain = v4l2_ctrl_new_std(hdl, &pb0100_ctrl_ops, in pb0100_init_controls()
135 V4L2_CID_AUTOGAIN, 0, 1, 1, 1); in pb0100_init_controls()
136 ctrls->exposure = v4l2_ctrl_new_std(hdl, &pb0100_ctrl_ops, in pb0100_init_controls()
137 V4L2_CID_EXPOSURE, 0, 511, 1, 12); in pb0100_init_controls()
138 ctrls->gain = v4l2_ctrl_new_std(hdl, &pb0100_ctrl_ops, in pb0100_init_controls()
139 V4L2_CID_GAIN, 0, 255, 1, 128); in pb0100_init_controls()
140 ctrls->red = v4l2_ctrl_new_std(hdl, &pb0100_ctrl_ops, in pb0100_init_controls()
141 V4L2_CID_RED_BALANCE, -255, 255, 1, 0); in pb0100_init_controls()
142 ctrls->blue = v4l2_ctrl_new_std(hdl, &pb0100_ctrl_ops, in pb0100_init_controls()
143 V4L2_CID_BLUE_BALANCE, -255, 255, 1, 0); in pb0100_init_controls()
144 ctrls->natural = v4l2_ctrl_new_custom(hdl, &natural_light, NULL); in pb0100_init_controls()
145 ctrls->target = v4l2_ctrl_new_custom(hdl, &autogain_target, NULL); in pb0100_init_controls()
146 if (hdl->error) { in pb0100_init_controls()
148 return hdl->error; in pb0100_init_controls()
150 sd->sensor_priv = ctrls; in pb0100_init_controls()
151 v4l2_ctrl_auto_cluster(5, &ctrls->autogain, 0, false); in pb0100_init_controls()
155 static int pb0100_probe(struct sd *sd) in pb0100_probe() argument
160 err = stv06xx_read_sensor(sd, PB_IDENT, &sensor); in pb0100_probe()
163 return -ENODEV; in pb0100_probe()
165 return -ENODEV; in pb0100_probe()
169 sd->gspca_dev.cam.cam_mode = pb0100_mode; in pb0100_probe()
170 sd->gspca_dev.cam.nmodes = ARRAY_SIZE(pb0100_mode); in pb0100_probe()
175 static int pb0100_start(struct sd *sd) in pb0100_start() argument
180 struct gspca_dev *gspca_dev = (struct gspca_dev *)sd; in pb0100_start()
181 struct cam *cam = &sd->gspca_dev.cam; in pb0100_start()
182 u32 mode = cam->cam_mode[sd->gspca_dev.curr_mode].priv; in pb0100_start()
184 intf = usb_ifnum_to_if(sd->gspca_dev.dev, sd->gspca_dev.iface); in pb0100_start()
185 alt = usb_altnum_to_altsetting(intf, sd->gspca_dev.alt); in pb0100_start()
187 return -ENODEV; in pb0100_start()
189 if (alt->desc.bNumEndpoints < 1) in pb0100_start()
190 return -ENODEV; in pb0100_start()
192 packet_size = le16_to_cpu(alt->endpoint[0].desc.wMaxPacketSize); in pb0100_start()
195 max_packet_size = sd->sensor->max_packet_size[sd->gspca_dev.curr_mode]; in pb0100_start()
197 stv06xx_write_sensor(sd, PB_ROWSPEED, BIT(4)|BIT(3)|BIT(1)); in pb0100_start()
199 stv06xx_write_sensor(sd, PB_ROWSPEED, BIT(5)|BIT(3)|BIT(1)); in pb0100_start()
203 stv06xx_write_sensor(sd, PB_RSTART, 30); in pb0100_start()
204 stv06xx_write_sensor(sd, PB_CSTART, 20); in pb0100_start()
205 stv06xx_write_sensor(sd, PB_RWSIZE, 240 - 1); in pb0100_start()
206 stv06xx_write_sensor(sd, PB_CWSIZE, 320 - 1); in pb0100_start()
208 stv06xx_write_sensor(sd, PB_RSTART, 8); in pb0100_start()
209 stv06xx_write_sensor(sd, PB_CSTART, 4); in pb0100_start()
210 stv06xx_write_sensor(sd, PB_RWSIZE, 288 - 1); in pb0100_start()
211 stv06xx_write_sensor(sd, PB_CWSIZE, 352 - 1); in pb0100_start()
215 stv06xx_write_bridge(sd, STV_Y_CTRL, 0x02); /* Wrong, FIXME */ in pb0100_start()
216 stv06xx_write_bridge(sd, STV_X_CTRL, 0x06); in pb0100_start()
218 stv06xx_write_bridge(sd, STV_SCAN_RATE, 0x10); in pb0100_start()
220 stv06xx_write_bridge(sd, STV_Y_CTRL, 0x01); in pb0100_start()
221 stv06xx_write_bridge(sd, STV_X_CTRL, 0x0a); in pb0100_start()
222 /* larger -> slower */ in pb0100_start()
223 stv06xx_write_bridge(sd, STV_SCAN_RATE, 0x20); in pb0100_start()
226 err = stv06xx_write_sensor(sd, PB_CONTROL, BIT(5)|BIT(3)|BIT(1)); in pb0100_start()
232 static int pb0100_stop(struct sd *sd) in pb0100_stop() argument
234 struct gspca_dev *gspca_dev = (struct gspca_dev *)sd; in pb0100_stop()
237 err = stv06xx_write_sensor(sd, PB_ABORTFRAME, 1); in pb0100_stop()
242 /* Set bit 1 to zero */ in pb0100_stop()
243 err = stv06xx_write_sensor(sd, PB_CONTROL, BIT(5)|BIT(3)); in pb0100_stop()
254 static int pb0100_init(struct sd *sd) in pb0100_init() argument
256 stv06xx_write_bridge(sd, STV_REG00, 1); in pb0100_init()
257 stv06xx_write_bridge(sd, STV_SCAN_RATE, 0); in pb0100_init()
260 stv06xx_write_sensor(sd, PB_RESET, 1); in pb0100_init()
261 stv06xx_write_sensor(sd, PB_RESET, 0); in pb0100_init()
264 stv06xx_write_sensor(sd, PB_CONTROL, BIT(5)|BIT(3)); in pb0100_init()
267 stv06xx_write_sensor(sd, PB_PREADCTRL, BIT(12)|BIT(10)|BIT(6)); in pb0100_init()
268 stv06xx_write_sensor(sd, PB_ADCGLOBALGAIN, 12); in pb0100_init()
270 /* Set up auto-exposure */ in pb0100_init()
273 stv06xx_write_sensor(sd, PB_R28, 12); in pb0100_init()
275 stv06xx_write_sensor(sd, PB_ADCMAXGAIN, 180); in pb0100_init()
277 stv06xx_write_sensor(sd, PB_ADCMINGAIN, 12); in pb0100_init()
279 allowed for auto-exposure routine */ in pb0100_init()
280 stv06xx_write_sensor(sd, PB_R54, 3); in pb0100_init()
282 allowed for auto-exposure routine */ in pb0100_init()
283 stv06xx_write_sensor(sd, PB_R55, 0); in pb0100_init()
284 stv06xx_write_sensor(sd, PB_UPDATEINT, 1); in pb0100_init()
285 /* R15 Expose0 (maximum that auto-exposure may use) */ in pb0100_init()
286 stv06xx_write_sensor(sd, PB_R15, 800); in pb0100_init()
287 /* R17 Expose2 (minimum that auto-exposure may use) */ in pb0100_init()
288 stv06xx_write_sensor(sd, PB_R17, 10); in pb0100_init()
290 stv06xx_write_sensor(sd, PB_EXPGAIN, 0); in pb0100_init()
293 stv06xx_write_sensor(sd, PB_VOFFSET, 0); in pb0100_init()
295 stv06xx_write_sensor(sd, PB_ADCGAINH, 11); in pb0100_init()
297 stv06xx_write_sensor(sd, PB_ADCGAINL, 0); in pb0100_init()
300 stv06xx_write_bridge(sd, STV_REG00, 0x11); in pb0100_init()
301 stv06xx_write_bridge(sd, STV_REG03, 0x45); in pb0100_init()
302 stv06xx_write_bridge(sd, STV_REG04, 0x07); in pb0100_init()
305 stv06xx_write_sensor(sd, PB_ROWSPEED, BIT(4)|BIT(3)|BIT(1)); in pb0100_init()
306 stv06xx_write_sensor(sd, PB_CFILLIN, 14); in pb0100_init()
307 stv06xx_write_sensor(sd, PB_VBL, 0); in pb0100_init()
308 stv06xx_write_sensor(sd, PB_FINTTIME, 0); in pb0100_init()
309 stv06xx_write_sensor(sd, PB_RINTTIME, 123); in pb0100_init()
311 stv06xx_write_bridge(sd, STV_REG01, 0xc2); in pb0100_init()
312 stv06xx_write_bridge(sd, STV_REG02, 0xb0); in pb0100_init()
316 static int pb0100_dump(struct sd *sd) in pb0100_dump() argument
324 struct sd *sd = (struct sd *) gspca_dev; in pb0100_set_gain() local
325 struct pb0100_ctrls *ctrls = sd->sensor_priv; in pb0100_set_gain()
327 err = stv06xx_write_sensor(sd, PB_G1GAIN, val); in pb0100_set_gain()
329 err = stv06xx_write_sensor(sd, PB_G2GAIN, val); in pb0100_set_gain()
334 err = pb0100_set_red_balance(gspca_dev, ctrls->red->val); in pb0100_set_gain()
336 err = pb0100_set_blue_balance(gspca_dev, ctrls->blue->val); in pb0100_set_gain()
344 struct sd *sd = (struct sd *) gspca_dev; in pb0100_set_red_balance() local
345 struct pb0100_ctrls *ctrls = sd->sensor_priv; in pb0100_set_red_balance()
347 val += ctrls->gain->val; in pb0100_set_red_balance()
353 err = stv06xx_write_sensor(sd, PB_RGAIN, val); in pb0100_set_red_balance()
363 struct sd *sd = (struct sd *) gspca_dev; in pb0100_set_blue_balance() local
364 struct pb0100_ctrls *ctrls = sd->sensor_priv; in pb0100_set_blue_balance()
366 val += ctrls->gain->val; in pb0100_set_blue_balance()
372 err = stv06xx_write_sensor(sd, PB_BGAIN, val); in pb0100_set_blue_balance()
381 struct sd *sd = (struct sd *) gspca_dev; in pb0100_set_exposure() local
384 err = stv06xx_write_sensor(sd, PB_RINTTIME, val); in pb0100_set_exposure()
394 struct sd *sd = (struct sd *) gspca_dev; in pb0100_set_autogain() local
395 struct pb0100_ctrls *ctrls = sd->sensor_priv; in pb0100_set_autogain()
398 if (ctrls->natural->val) in pb0100_set_autogain()
405 err = stv06xx_write_sensor(sd, PB_EXPGAIN, val); in pb0100_set_autogain()
407 val, ctrls->natural->val, err); in pb0100_set_autogain()
415 struct sd *sd = (struct sd *) gspca_dev; in pb0100_set_autogain_target() local
419 totalpixels = gspca_dev->pixfmt.width * gspca_dev->pixfmt.height; in pb0100_set_autogain_target()
423 darkpixels = totalpixels - brightpixels; in pb0100_set_autogain_target()
424 err = stv06xx_write_sensor(sd, PB_R21, brightpixels); in pb0100_set_autogain_target()
426 err = stv06xx_write_sensor(sd, PB_R22, darkpixels); in pb0100_set_autogain_target()