Lines Matching full:dw9768

15 #define DW9768_NAME				"dw9768"
31 * DW9768 requires waiting time of Topr after PD reset takes place.
39 * DW9768 separates two registers to control the VCM position.
78 * DW9768 requires waiting time (delay time) of t_OPR after power-up,
100 /* dw9768 device structure */
101 struct dw9768 { struct
113 static inline struct dw9768 *sd_to_dw9768(struct v4l2_subdev *subdev) in sd_to_dw9768() argument
115 return container_of(subdev, struct dw9768, sd); in sd_to_dw9768()
202 static int dw9768_mod_reg(struct dw9768 *dw9768, u8 reg, u8 mask, u8 val) in dw9768_mod_reg() argument
204 struct i2c_client *client = v4l2_get_subdevdata(&dw9768->sd); in dw9768_mod_reg()
216 static int dw9768_set_dac(struct dw9768 *dw9768, u16 val) in dw9768_set_dac() argument
218 struct i2c_client *client = v4l2_get_subdevdata(&dw9768->sd); in dw9768_set_dac()
224 static int dw9768_init(struct dw9768 *dw9768) in dw9768_init() argument
226 struct i2c_client *client = v4l2_get_subdevdata(&dw9768->sd); in dw9768_init()
248 ret = dw9768_mod_reg(dw9768, DW9768_AAC_PRESC_REG, in dw9768_init()
250 dw9768->aac_mode << 5); in dw9768_init()
255 if (dw9768->clock_presc != DW9768_CLOCK_PRE_SCALE_DEFAULT) { in dw9768_init()
256 ret = dw9768_mod_reg(dw9768, DW9768_AAC_PRESC_REG, in dw9768_init()
258 dw9768->clock_presc); in dw9768_init()
264 if (dw9768->aac_timing != DW9768_AAC_TIME_DEFAULT) { in dw9768_init()
266 dw9768->aac_timing); in dw9768_init()
271 for (val = dw9768->focus->val % DW9768_MOVE_STEPS; in dw9768_init()
272 val <= dw9768->focus->val; in dw9768_init()
274 ret = dw9768_set_dac(dw9768, val); in dw9768_init()
279 usleep_range(dw9768->move_delay_us, in dw9768_init()
280 dw9768->move_delay_us + 1000); in dw9768_init()
286 static int dw9768_release(struct dw9768 *dw9768) in dw9768_release() argument
288 struct i2c_client *client = v4l2_get_subdevdata(&dw9768->sd); in dw9768_release()
291 val = round_down(dw9768->focus->val, DW9768_MOVE_STEPS); in dw9768_release()
293 ret = dw9768_set_dac(dw9768, val); in dw9768_release()
298 usleep_range(dw9768->move_delay_us, in dw9768_release()
299 dw9768->move_delay_us + 1000); in dw9768_release()
319 struct dw9768 *dw9768 = sd_to_dw9768(sd); in dw9768_runtime_suspend() local
321 dw9768_release(dw9768); in dw9768_runtime_suspend()
323 dw9768->supplies); in dw9768_runtime_suspend()
331 struct dw9768 *dw9768 = sd_to_dw9768(sd); in dw9768_runtime_resume() local
335 dw9768->supplies); in dw9768_runtime_resume()
347 ret = dw9768_init(dw9768); in dw9768_runtime_resume()
355 dw9768->supplies); in dw9768_runtime_resume()
362 struct dw9768 *dw9768 = container_of(ctrl->handler, in dw9768_set_ctrl() local
363 struct dw9768, ctrls); in dw9768_set_ctrl()
366 return dw9768_set_dac(dw9768, ctrl->val); in dw9768_set_ctrl()
394 static int dw9768_init_controls(struct dw9768 *dw9768) in dw9768_init_controls() argument
396 struct v4l2_ctrl_handler *hdl = &dw9768->ctrls; in dw9768_init_controls()
401 dw9768->focus = v4l2_ctrl_new_std(hdl, ops, V4L2_CID_FOCUS_ABSOLUTE, 0, in dw9768_init_controls()
408 dw9768->sd.ctrl_handler = hdl; in dw9768_init_controls()
416 struct dw9768 *dw9768; in dw9768_probe() local
421 dw9768 = devm_kzalloc(dev, sizeof(*dw9768), GFP_KERNEL); in dw9768_probe()
422 if (!dw9768) in dw9768_probe()
426 v4l2_i2c_subdev_init(&dw9768->sd, client, &dw9768_ops); in dw9768_probe()
428 dw9768->aac_mode = DW9768_AAC_MODE_DEFAULT; in dw9768_probe()
429 dw9768->aac_timing = DW9768_AAC_TIME_DEFAULT; in dw9768_probe()
430 dw9768->clock_presc = DW9768_CLOCK_PRE_SCALE_DEFAULT; in dw9768_probe()
434 &dw9768->aac_mode); in dw9768_probe()
438 &dw9768->clock_presc); in dw9768_probe()
442 &dw9768->aac_timing); in dw9768_probe()
444 dw9768->move_delay_us = dw9768_cal_move_delay(dw9768->aac_mode, in dw9768_probe()
445 dw9768->clock_presc, in dw9768_probe()
446 dw9768->aac_timing); in dw9768_probe()
449 dw9768->supplies[i].supply = dw9768_supply_names[i]; in dw9768_probe()
452 dw9768->supplies); in dw9768_probe()
459 ret = dw9768_init_controls(dw9768); in dw9768_probe()
464 dw9768->sd.flags |= V4L2_SUBDEV_FL_HAS_DEVNODE; in dw9768_probe()
465 dw9768->sd.internal_ops = &dw9768_int_ops; in dw9768_probe()
467 ret = media_entity_pads_init(&dw9768->sd.entity, 0, NULL); in dw9768_probe()
471 dw9768->sd.entity.function = MEDIA_ENT_F_LENS; in dw9768_probe()
492 ret = v4l2_async_register_subdev(&dw9768->sd); in dw9768_probe()
509 media_entity_cleanup(&dw9768->sd.entity); in dw9768_probe()
511 v4l2_ctrl_handler_free(&dw9768->ctrls); in dw9768_probe()
519 struct dw9768 *dw9768 = sd_to_dw9768(sd); in dw9768_remove() local
522 v4l2_async_unregister_subdev(&dw9768->sd); in dw9768_remove()
523 v4l2_ctrl_handler_free(&dw9768->ctrls); in dw9768_remove()
524 media_entity_cleanup(&dw9768->sd.entity); in dw9768_remove()
534 { .compatible = "dongwoon,dw9768" },
558 MODULE_DESCRIPTION("DW9768 VCM driver");