Lines Matching refs:go

41 int go7007_read_interrupt(struct go7007 *go, u16 *value, u16 *data)  in go7007_read_interrupt()  argument
43 go->interrupt_available = 0; in go7007_read_interrupt()
44 go->hpi_ops->read_interrupt(go); in go7007_read_interrupt()
45 if (wait_event_timeout(go->interrupt_waitq, in go7007_read_interrupt()
46 go->interrupt_available, 5*HZ) < 0) { in go7007_read_interrupt()
47 v4l2_err(&go->v4l2_dev, "timeout waiting for read interrupt\n"); in go7007_read_interrupt()
50 if (!go->interrupt_available) in go7007_read_interrupt()
52 go->interrupt_available = 0; in go7007_read_interrupt()
53 *value = go->interrupt_value & 0xfffe; in go7007_read_interrupt()
54 *data = go->interrupt_data; in go7007_read_interrupt()
64 int go7007_read_addr(struct go7007 *go, u16 addr, u16 *data) in go7007_read_addr() argument
69 if (go7007_write_interrupt(go, 0x0010, addr) < 0) in go7007_read_addr()
72 if (go7007_read_interrupt(go, &value, data) == 0 && in go7007_read_addr()
86 static int go7007_load_encoder(struct go7007 *go) in go7007_load_encoder() argument
94 if (go->boot_fw == NULL) { in go7007_load_encoder()
95 if (request_firmware(&fw_entry, fw_name, go->dev)) { in go7007_load_encoder()
96 v4l2_err(go, "unable to load firmware from file \"%s\"\n", fw_name); in go7007_load_encoder()
100 v4l2_err(go, "file \"%s\" does not appear to be go7007 firmware\n", fw_name); in go7007_load_encoder()
107 v4l2_err(go, "unable to allocate %d bytes for firmware transfer\n", fw_len); in go7007_load_encoder()
112 go->boot_fw_len = fw_len; in go7007_load_encoder()
113 go->boot_fw = bounce; in go7007_load_encoder()
115 if (go7007_interface_reset(go) < 0 || in go7007_load_encoder()
116 go7007_send_firmware(go, go->boot_fw, go->boot_fw_len) < 0 || in go7007_load_encoder()
117 go7007_read_interrupt(go, &intr_val, &intr_data) < 0 || in go7007_load_encoder()
119 v4l2_err(go, "error transferring firmware\n"); in go7007_load_encoder()
134 int go7007_boot_encoder(struct go7007 *go, int init_i2c) in go7007_boot_encoder() argument
138 mutex_lock(&go->hw_lock); in go7007_boot_encoder()
139 ret = go7007_load_encoder(go); in go7007_boot_encoder()
140 mutex_unlock(&go->hw_lock); in go7007_boot_encoder()
145 if (go7007_i2c_init(go) < 0) in go7007_boot_encoder()
147 go->i2c_adapter_online = 1; in go7007_boot_encoder()
159 static int go7007_init_encoder(struct go7007 *go) in go7007_init_encoder() argument
161 if (go->board_info->audio_flags & GO7007_AUDIO_I2S_MASTER) { in go7007_init_encoder()
162 go7007_write_addr(go, 0x1000, 0x0811); in go7007_init_encoder()
163 go7007_write_addr(go, 0x1000, 0x0c11); in go7007_init_encoder()
165 switch (go->board_id) { in go7007_init_encoder()
168 go7007_write_addr(go, 0x3c82, 0x0001); in go7007_init_encoder()
169 go7007_write_addr(go, 0x3c80, 0x00fe); in go7007_init_encoder()
173 go7007_write_addr(go, 0x3c82, 0x0000); in go7007_init_encoder()
174 go7007_write_addr(go, 0x3c80, 0x00df); in go7007_init_encoder()
180 go7007_write_addr(go, 0x3c82, 0x000d); in go7007_init_encoder()
181 go7007_write_addr(go, 0x3c80, 0x00f2); in go7007_init_encoder()
193 int go7007_reset_encoder(struct go7007 *go) in go7007_reset_encoder() argument
195 if (go7007_load_encoder(go) < 0) in go7007_reset_encoder()
197 return go7007_init_encoder(go); in go7007_reset_encoder()
205 struct go7007 *go = i2c_get_adapdata(adapter); in init_i2c_module() local
206 struct v4l2_device *v4l2_dev = &go->v4l2_dev; in init_i2c_module()
218 go->sd_video = sd; in init_i2c_module()
220 go->sd_audio = sd; in init_i2c_module()
235 struct go7007 *go = container_of(v4l2_dev, struct go7007, v4l2_dev); in go7007_remove() local
238 if (go->hpi_ops->release) in go7007_remove()
239 go->hpi_ops->release(go); in go7007_remove()
240 if (go->i2c_adapter_online) { in go7007_remove()
241 i2c_del_adapter(&go->i2c_adapter); in go7007_remove()
242 go->i2c_adapter_online = 0; in go7007_remove()
245 kfree(go->boot_fw); in go7007_remove()
246 go7007_v4l2_remove(go); in go7007_remove()
247 kfree(go); in go7007_remove()
258 int go7007_register_encoder(struct go7007 *go, unsigned num_i2c_devs) in go7007_register_encoder() argument
262 dev_info(go->dev, "go7007: registering new %s\n", go->name); in go7007_register_encoder()
264 go->v4l2_dev.release = go7007_remove; in go7007_register_encoder()
265 ret = v4l2_device_register(go->dev, &go->v4l2_dev); in go7007_register_encoder()
269 mutex_lock(&go->hw_lock); in go7007_register_encoder()
270 ret = go7007_init_encoder(go); in go7007_register_encoder()
271 mutex_unlock(&go->hw_lock); in go7007_register_encoder()
275 ret = go7007_v4l2_ctrl_init(go); in go7007_register_encoder()
279 if (!go->i2c_adapter_online && in go7007_register_encoder()
280 go->board_info->flags & GO7007_BOARD_USE_ONBOARD_I2C) { in go7007_register_encoder()
281 ret = go7007_i2c_init(go); in go7007_register_encoder()
284 go->i2c_adapter_online = 1; in go7007_register_encoder()
286 if (go->i2c_adapter_online) { in go7007_register_encoder()
287 if (go->board_id == GO7007_BOARDID_ADS_USBAV_709) { in go7007_register_encoder()
289 go7007_write_addr(go, 0x3c82, 0x0009); in go7007_register_encoder()
291 go7007_write_addr(go, 0x3c82, 0x000d); in go7007_register_encoder()
294 init_i2c_module(&go->i2c_adapter, &go->board_info->i2c_devs[i]); in go7007_register_encoder()
296 if (go->tuner_type >= 0) { in go7007_register_encoder()
299 .type = go->tuner_type, in go7007_register_encoder()
303 v4l2_device_call_all(&go->v4l2_dev, 0, tuner, in go7007_register_encoder()
306 if (go->board_id == GO7007_BOARDID_ADLINK_MPG24) in go7007_register_encoder()
307 v4l2_subdev_call(go->sd_video, video, s_routing, in go7007_register_encoder()
308 0, 0, go->channel_number + 1); in go7007_register_encoder()
311 ret = go7007_v4l2_init(go); in go7007_register_encoder()
315 if (go->board_info->flags & GO7007_BOARD_HAS_AUDIO) { in go7007_register_encoder()
316 go->audio_enabled = 1; in go7007_register_encoder()
317 go7007_snd_init(go); in go7007_register_encoder()
329 int go7007_start_encoder(struct go7007 *go) in go7007_start_encoder() argument
335 go->modet_enable = 0; in go7007_start_encoder()
337 go->modet[i].enable = 0; in go7007_start_encoder()
339 switch (v4l2_ctrl_g_ctrl(go->modet_mode)) { in go7007_start_encoder()
341 memset(go->modet_map, 0, sizeof(go->modet_map)); in go7007_start_encoder()
342 go->modet[0].enable = 1; in go7007_start_encoder()
343 go->modet_enable = 1; in go7007_start_encoder()
346 for (y = 0; y < go->height / 16; y++) { in go7007_start_encoder()
347 for (x = 0; x < go->width / 16; x++) { in go7007_start_encoder()
348 int idx = y * go->width / 16 + x; in go7007_start_encoder()
350 go->modet[go->modet_map[idx]].enable = 1; in go7007_start_encoder()
353 go->modet_enable = 1; in go7007_start_encoder()
357 if (go->dvd_mode) in go7007_start_encoder()
358 go->modet_enable = 0; in go7007_start_encoder()
360 if (go7007_construct_fw_image(go, &fw, &fw_len) < 0) in go7007_start_encoder()
363 if (go7007_send_firmware(go, fw, fw_len) < 0 || in go7007_start_encoder()
364 go7007_read_interrupt(go, &intr_val, &intr_data) < 0) { in go7007_start_encoder()
365 v4l2_err(&go->v4l2_dev, "error transferring firmware\n"); in go7007_start_encoder()
370 go->state = STATE_DATA; in go7007_start_encoder()
371 go->parse_length = 0; in go7007_start_encoder()
372 go->seen_frame = 0; in go7007_start_encoder()
373 if (go7007_stream_start(go) < 0) { in go7007_start_encoder()
374 v4l2_err(&go->v4l2_dev, "error starting stream transfer\n"); in go7007_start_encoder()
396 static void go7007_set_motion_regions(struct go7007 *go, struct go7007_buffer *vb, in go7007_set_motion_regions() argument
399 if (motion_regions != go->modet_event_status) { in go7007_set_motion_regions()
409 v4l2_event_queue(&go->vdev, &ev); in go7007_set_motion_regions()
410 go->modet_event_status = motion_regions; in go7007_set_motion_regions()
418 static void go7007_motion_regions(struct go7007 *go, struct go7007_buffer *vb) in go7007_motion_regions() argument
423 unsigned stride = (go->width + 7) >> 3; in go7007_motion_regions()
428 store_byte(vb, go->active_map[i]); in go7007_motion_regions()
429 for (y = 0; y < go->height / 16; y++) { in go7007_motion_regions()
430 for (x = 0; x < go->width / 16; x++) { in go7007_motion_regions()
431 if (!(go->active_map[y * stride + (x >> 3)] & (1 << (x & 7)))) in go7007_motion_regions()
433 motion[go->modet_map[y * (go->width / 16) + x]]++; in go7007_motion_regions()
441 go7007_set_motion_regions(go, vb, motion_regions); in go7007_motion_regions()
447 static struct go7007_buffer *frame_boundary(struct go7007 *go, struct go7007_buffer *vb) in frame_boundary() argument
453 spin_lock(&go->spinlock); in frame_boundary()
454 if (!list_empty(&go->vidq_active)) in frame_boundary()
455 vb = go->active_buf = in frame_boundary()
456 list_first_entry(&go->vidq_active, struct go7007_buffer, list); in frame_boundary()
457 spin_unlock(&go->spinlock); in frame_boundary()
458 go->next_seq++; in frame_boundary()
462 vb->vb.v4l2_buf.sequence = go->next_seq++; in frame_boundary()
464 go7007_motion_regions(go, vb); in frame_boundary()
466 go7007_set_motion_regions(go, vb, 0); in frame_boundary()
470 spin_lock(&go->spinlock); in frame_boundary()
472 if (list_empty(&go->vidq_active)) in frame_boundary()
475 vb = list_first_entry(&go->vidq_active, struct go7007_buffer, list); in frame_boundary()
476 go->active_buf = vb; in frame_boundary()
477 spin_unlock(&go->spinlock); in frame_boundary()
482 static void write_bitmap_word(struct go7007 *go) in write_bitmap_word() argument
484 int x, y, i, stride = ((go->width >> 4) + 7) >> 3; in write_bitmap_word()
487 y = (((go->parse_length - 1) << 3) + i) / (go->width >> 4); in write_bitmap_word()
488 x = (((go->parse_length - 1) << 3) + i) % (go->width >> 4); in write_bitmap_word()
489 if (stride * y + (x >> 3) < sizeof(go->active_map)) in write_bitmap_word()
490 go->active_map[stride * y + (x >> 3)] |= in write_bitmap_word()
491 (go->modet_word & 1) << (x & 0x7); in write_bitmap_word()
492 go->modet_word >>= 1; in write_bitmap_word()
501 void go7007_parse_video_stream(struct go7007 *go, u8 *buf, int length) in go7007_parse_video_stream() argument
503 struct go7007_buffer *vb = go->active_buf; in go7007_parse_video_stream()
506 switch (go->format) { in go7007_parse_video_stream()
522 v4l2_info(&go->v4l2_dev, "dropping oversized frame\n"); in go7007_parse_video_stream()
526 vb = go->active_buf = NULL; in go7007_parse_video_stream()
529 switch (go->state) { in go7007_parse_video_stream()
533 go->state = STATE_00; in go7007_parse_video_stream()
536 go->state = STATE_FF; in go7007_parse_video_stream()
546 go->state = STATE_00_00; in go7007_parse_video_stream()
550 go->state = STATE_FF; in go7007_parse_video_stream()
555 go->state = STATE_DATA; in go7007_parse_video_stream()
566 go->state = STATE_00_00_01; in go7007_parse_video_stream()
571 go->state = STATE_FF; in go7007_parse_video_stream()
577 go->state = STATE_DATA; in go7007_parse_video_stream()
582 if (buf[i] == 0xF8 && go->modet_enable == 0) { in go7007_parse_video_stream()
588 go->state = STATE_DATA; in go7007_parse_video_stream()
593 if ((go->format == V4L2_PIX_FMT_MPEG1 || in go7007_parse_video_stream()
594 go->format == V4L2_PIX_FMT_MPEG2 || in go7007_parse_video_stream()
595 go->format == V4L2_PIX_FMT_MPEG4) && in go7007_parse_video_stream()
599 if (vb == NULL || go->seen_frame) in go7007_parse_video_stream()
600 vb = frame_boundary(go, vb); in go7007_parse_video_stream()
601 go->seen_frame = buf[i] == frame_start_code; in go7007_parse_video_stream()
602 if (vb && go->seen_frame) in go7007_parse_video_stream()
609 go->parse_length = 12; in go7007_parse_video_stream()
610 go->state = STATE_UNPARSED; in go7007_parse_video_stream()
613 go->state = STATE_VBI_LEN_A; in go7007_parse_video_stream()
616 go->parse_length = 0; in go7007_parse_video_stream()
617 memset(go->active_map, 0, in go7007_parse_video_stream()
618 sizeof(go->active_map)); in go7007_parse_video_stream()
619 go->state = STATE_MODET_MAP; in go7007_parse_video_stream()
625 go->state = STATE_FF; in go7007_parse_video_stream()
632 go->state = STATE_DATA; in go7007_parse_video_stream()
640 go->state = STATE_00; in go7007_parse_video_stream()
647 if (go->format == V4L2_PIX_FMT_MJPEG) in go7007_parse_video_stream()
648 vb = frame_boundary(go, vb); in go7007_parse_video_stream()
653 go->state = STATE_DATA; in go7007_parse_video_stream()
658 go->parse_length = buf[i] << 8; in go7007_parse_video_stream()
659 go->state = STATE_VBI_LEN_B; in go7007_parse_video_stream()
662 go->parse_length |= buf[i]; in go7007_parse_video_stream()
663 if (go->parse_length > 0) in go7007_parse_video_stream()
664 go->state = STATE_UNPARSED; in go7007_parse_video_stream()
666 go->state = STATE_DATA; in go7007_parse_video_stream()
669 if (go->parse_length < 204) { in go7007_parse_video_stream()
670 if (go->parse_length & 1) { in go7007_parse_video_stream()
671 go->modet_word |= buf[i]; in go7007_parse_video_stream()
672 write_bitmap_word(go); in go7007_parse_video_stream()
674 go->modet_word = buf[i] << 8; in go7007_parse_video_stream()
675 } else if (go->parse_length == 207 && vb) { in go7007_parse_video_stream()
678 if (++go->parse_length == 208) in go7007_parse_video_stream()
679 go->state = STATE_DATA; in go7007_parse_video_stream()
682 if (--go->parse_length == 0) in go7007_parse_video_stream()
683 go->state = STATE_DATA; in go7007_parse_video_stream()
696 struct go7007 *go; in go7007_alloc() local
699 go = kzalloc(sizeof(struct go7007), GFP_KERNEL); in go7007_alloc()
700 if (go == NULL) in go7007_alloc()
702 go->dev = dev; in go7007_alloc()
703 go->board_info = board; in go7007_alloc()
704 go->board_id = 0; in go7007_alloc()
705 go->tuner_type = -1; in go7007_alloc()
706 go->channel_number = 0; in go7007_alloc()
707 go->name[0] = 0; in go7007_alloc()
708 mutex_init(&go->hw_lock); in go7007_alloc()
709 init_waitqueue_head(&go->frame_waitq); in go7007_alloc()
710 spin_lock_init(&go->spinlock); in go7007_alloc()
711 go->status = STATUS_INIT; in go7007_alloc()
712 memset(&go->i2c_adapter, 0, sizeof(go->i2c_adapter)); in go7007_alloc()
713 go->i2c_adapter_online = 0; in go7007_alloc()
714 go->interrupt_available = 0; in go7007_alloc()
715 init_waitqueue_head(&go->interrupt_waitq); in go7007_alloc()
716 go->input = 0; in go7007_alloc()
717 go7007_update_board(go); in go7007_alloc()
718 go->encoder_h_halve = 0; in go7007_alloc()
719 go->encoder_v_halve = 0; in go7007_alloc()
720 go->encoder_subsample = 0; in go7007_alloc()
721 go->format = V4L2_PIX_FMT_MJPEG; in go7007_alloc()
722 go->bitrate = 1500000; in go7007_alloc()
723 go->fps_scale = 1; in go7007_alloc()
724 go->pali = 0; in go7007_alloc()
725 go->aspect_ratio = GO7007_RATIO_1_1; in go7007_alloc()
726 go->gop_size = 0; in go7007_alloc()
727 go->ipb = 0; in go7007_alloc()
728 go->closed_gop = 0; in go7007_alloc()
729 go->repeat_seqhead = 0; in go7007_alloc()
730 go->seq_header_enable = 0; in go7007_alloc()
731 go->gop_header_enable = 0; in go7007_alloc()
732 go->dvd_mode = 0; in go7007_alloc()
733 go->interlace_coding = 0; in go7007_alloc()
735 go->modet[i].enable = 0; in go7007_alloc()
737 go->modet_map[i] = 0; in go7007_alloc()
738 go->audio_deliver = NULL; in go7007_alloc()
739 go->audio_enabled = 0; in go7007_alloc()
741 return go; in go7007_alloc()
745 void go7007_update_board(struct go7007 *go) in go7007_update_board() argument
747 const struct go7007_board_info *board = go->board_info; in go7007_update_board()
750 go->standard = GO7007_STD_NTSC; in go7007_update_board()
751 go->std = V4L2_STD_NTSC_M; in go7007_update_board()
752 go->width = 720; in go7007_update_board()
753 go->height = 480; in go7007_update_board()
754 go->sensor_framerate = 30000; in go7007_update_board()
756 go->standard = GO7007_STD_OTHER; in go7007_update_board()
757 go->width = board->sensor_width; in go7007_update_board()
758 go->height = board->sensor_height; in go7007_update_board()
759 go->sensor_framerate = board->sensor_framerate; in go7007_update_board()
761 go->encoder_v_offset = board->sensor_v_offset; in go7007_update_board()
762 go->encoder_h_offset = board->sensor_h_offset; in go7007_update_board()