Lines Matching refs:input
181 static void tw5864_frame_interval_set(struct tw5864_input *input);
209 static int tw5864_input_std_get(struct tw5864_input *input, in tw5864_input_std_get() argument
212 struct tw5864_dev *dev = input->root; in tw5864_input_std_get()
213 u8 std_reg = tw_indir_readb(TW5864_INDIR_VIN_E(input->nr)); in tw5864_input_std_get()
226 static int tw5864_enable_input(struct tw5864_input *input) in tw5864_enable_input() argument
228 struct tw5864_dev *dev = input->root; in tw5864_enable_input()
229 int nr = input->nr; in tw5864_enable_input()
241 input->frame_seqno = 0; in tw5864_enable_input()
242 input->frame_gop_seqno = 0; in tw5864_enable_input()
243 input->h264_idr_pic_id = 0; in tw5864_enable_input()
245 input->reg_dsp_qp = input->qp; in tw5864_enable_input()
246 input->reg_dsp_ref_mvp_lambda = lambda_lookup_table[input->qp]; in tw5864_enable_input()
247 input->reg_dsp_i4x4_weight = intra4x4_lambda3[input->qp]; in tw5864_enable_input()
248 input->reg_emu = TW5864_EMU_EN_LPF | TW5864_EMU_EN_BHOST in tw5864_enable_input()
250 input->reg_dsp = nr /* channel id */ in tw5864_enable_input()
255 input->resolution = D1; in tw5864_enable_input()
257 d1_height = (input->std == STD_NTSC) ? 480 : 576; in tw5864_enable_input()
259 input->width = d1_width; in tw5864_enable_input()
260 input->height = d1_height; in tw5864_enable_input()
262 input->reg_interlacing = 0x4; in tw5864_enable_input()
264 switch (input->resolution) { in tw5864_enable_input()
267 frame_height_bus_value = input->height - 1; in tw5864_enable_input()
271 input->reg_dsp_codec |= TW5864_CIF_MAP_MD | TW5864_HD1_MAP_MD; in tw5864_enable_input()
272 input->reg_emu |= TW5864_DSP_FRAME_TYPE_D1; in tw5864_enable_input()
273 input->reg_interlacing = TW5864_DI_EN | TW5864_DSP_INTER_ST; in tw5864_enable_input()
278 input->height /= 2; in tw5864_enable_input()
279 input->width /= 2; in tw5864_enable_input()
281 frame_height_bus_value = input->height * 2 - 1; in tw5864_enable_input()
285 input->reg_dsp_codec |= TW5864_HD1_MAP_MD; in tw5864_enable_input()
286 input->reg_emu |= TW5864_DSP_FRAME_TYPE_D1; in tw5864_enable_input()
292 input->height /= 4; in tw5864_enable_input()
293 input->width /= 2; in tw5864_enable_input()
295 frame_height_bus_value = input->height * 2 - 1; in tw5864_enable_input()
299 input->reg_dsp_codec |= TW5864_CIF_MAP_MD; in tw5864_enable_input()
304 input->height /= 4; in tw5864_enable_input()
305 input->width /= 4; in tw5864_enable_input()
307 frame_height_bus_value = input->height * 2 - 1; in tw5864_enable_input()
311 input->reg_dsp_codec |= TW5864_CIF_MAP_MD; in tw5864_enable_input()
322 tw_indir_writeb(TW5864_INDIR_OUT_PIC_WIDTH(nr), input->width / 4); in tw5864_enable_input()
323 tw_indir_writeb(TW5864_INDIR_OUT_PIC_HEIGHT(nr), input->height / 4); in tw5864_enable_input()
329 input->width = 704; in tw5864_enable_input()
335 ((input->width / 16) << 8) | (input->height / 16)); in tw5864_enable_input()
346 tw5864_frame_interval_set(input); in tw5864_enable_input()
358 input->std == STD_NTSC ? 29 : 24); in tw5864_enable_input()
365 input->enabled = 1; in tw5864_enable_input()
371 void tw5864_request_encoded_frame(struct tw5864_input *input) in tw5864_request_encoded_frame() argument
373 struct tw5864_dev *dev = input->root; in tw5864_request_encoded_frame()
377 tw_writel(TW5864_EMU, input->reg_emu); in tw5864_request_encoded_frame()
378 tw_writel(TW5864_INTERLACING, input->reg_interlacing); in tw5864_request_encoded_frame()
379 tw_writel(TW5864_DSP, input->reg_dsp); in tw5864_request_encoded_frame()
381 tw_writel(TW5864_DSP_QP, input->reg_dsp_qp); in tw5864_request_encoded_frame()
382 tw_writel(TW5864_DSP_REF_MVP_LAMBDA, input->reg_dsp_ref_mvp_lambda); in tw5864_request_encoded_frame()
383 tw_writel(TW5864_DSP_I4x4_WEIGHT, input->reg_dsp_i4x4_weight); in tw5864_request_encoded_frame()
388 if (input->frame_gop_seqno == 0) { in tw5864_request_encoded_frame()
391 input->h264_idr_pic_id++; in tw5864_request_encoded_frame()
392 input->h264_idr_pic_id &= TW5864_DSP_REF_FRM; in tw5864_request_encoded_frame()
398 tw5864_prepare_frame_headers(input); in tw5864_request_encoded_frame()
401 ((input->tail_nb_bits + 24) << TW5864_VLC_BIT_ALIGN_SHIFT) | in tw5864_request_encoded_frame()
402 input->reg_dsp_qp); in tw5864_request_encoded_frame()
405 2 * input->nr); in tw5864_request_encoded_frame()
415 static int tw5864_disable_input(struct tw5864_input *input) in tw5864_disable_input() argument
417 struct tw5864_dev *dev = input->root; in tw5864_disable_input()
420 dev_dbg(&dev->pci->dev, "Disabling channel %d\n", input->nr); in tw5864_disable_input()
423 input->enabled = 0; in tw5864_disable_input()
430 struct tw5864_input *input = vb2_get_drv_priv(q); in tw5864_start_streaming() local
433 ret = tw5864_enable_input(input); in tw5864_start_streaming()
437 while (!list_empty(&input->active)) { in tw5864_start_streaming()
438 struct tw5864_buf *buf = list_entry(input->active.next, in tw5864_start_streaming()
450 struct tw5864_input *input = vb2_get_drv_priv(q); in tw5864_stop_streaming() local
452 tw5864_disable_input(input); in tw5864_stop_streaming()
454 spin_lock_irqsave(&input->slock, flags); in tw5864_stop_streaming()
455 if (input->vb) { in tw5864_stop_streaming()
456 vb2_buffer_done(&input->vb->vb.vb2_buf, VB2_BUF_STATE_ERROR); in tw5864_stop_streaming()
457 input->vb = NULL; in tw5864_stop_streaming()
459 while (!list_empty(&input->active)) { in tw5864_stop_streaming()
460 struct tw5864_buf *buf = list_entry(input->active.next, in tw5864_stop_streaming()
466 spin_unlock_irqrestore(&input->slock, flags); in tw5864_stop_streaming()
480 struct tw5864_input *input = in tw5864_s_ctrl() local
482 struct tw5864_dev *dev = input->root; in tw5864_s_ctrl()
487 tw_indir_writeb(TW5864_INDIR_VIN_A_BRIGHT(input->nr), in tw5864_s_ctrl()
491 tw_indir_writeb(TW5864_INDIR_VIN_7_HUE(input->nr), in tw5864_s_ctrl()
495 tw_indir_writeb(TW5864_INDIR_VIN_9_CNTRST(input->nr), in tw5864_s_ctrl()
499 tw_indir_writeb(TW5864_INDIR_VIN_B_SAT_U(input->nr), in tw5864_s_ctrl()
501 tw_indir_writeb(TW5864_INDIR_VIN_C_SAT_V(input->nr), in tw5864_s_ctrl()
505 input->gop = ctrl->val; in tw5864_s_ctrl()
508 spin_lock_irqsave(&input->slock, flags); in tw5864_s_ctrl()
509 input->qp = ctrl->val; in tw5864_s_ctrl()
510 input->reg_dsp_qp = input->qp; in tw5864_s_ctrl()
511 input->reg_dsp_ref_mvp_lambda = lambda_lookup_table[input->qp]; in tw5864_s_ctrl()
512 input->reg_dsp_i4x4_weight = intra4x4_lambda3[input->qp]; in tw5864_s_ctrl()
513 spin_unlock_irqrestore(&input->slock, flags); in tw5864_s_ctrl()
516 memset(input->md_threshold_grid_values, ctrl->val, in tw5864_s_ctrl()
517 sizeof(input->md_threshold_grid_values)); in tw5864_s_ctrl()
523 memcpy(input->md_threshold_grid_values, in tw5864_s_ctrl()
524 input->md_threshold_grid_ctrl->p_new.p_u16, in tw5864_s_ctrl()
525 sizeof(input->md_threshold_grid_values)); in tw5864_s_ctrl()
534 struct tw5864_input *input = video_drvdata(file); in tw5864_fmt_vid_cap() local
537 switch (input->std) { in tw5864_fmt_vid_cap()
559 struct tw5864_input *input = video_drvdata(file); in tw5864_enum_input() local
560 struct tw5864_dev *dev = input->root; in tw5864_enum_input()
562 u8 indir_0x000 = tw_indir_readb(TW5864_INDIR_VIN_0(input->nr)); in tw5864_enum_input()
563 u8 indir_0x00d = tw_indir_readb(TW5864_INDIR_VIN_D(input->nr)); in tw5864_enum_input()
571 snprintf(i->name, sizeof(i->name), "Encoder %d", input->nr); in tw5864_enum_input()
603 struct tw5864_input *input = video_drvdata(file); in tw5864_querycap() local
607 input->nr); in tw5864_querycap()
613 struct tw5864_input *input = video_drvdata(file); in tw5864_querystd() local
617 ret = tw5864_input_std_get(input, &tw_std); in tw5864_querystd()
627 struct tw5864_input *input = video_drvdata(file); in tw5864_g_std() local
629 *std = input->v4l2_std; in tw5864_g_std()
635 struct tw5864_input *input = video_drvdata(file); in tw5864_s_std() local
636 struct tw5864_dev *dev = input->root; in tw5864_s_std()
638 input->v4l2_std = std; in tw5864_s_std()
639 input->std = tw5864_from_v4l2_std(std); in tw5864_s_std()
640 tw_indir_writeb(TW5864_INDIR_VIN_E(input->nr), input->std); in tw5864_s_std()
669 static void tw5864_frame_interval_set(struct tw5864_input *input) in tw5864_frame_interval_set() argument
694 struct tw5864_dev *dev = input->root; in tw5864_frame_interval_set()
697 int std_max_fps = input->std == STD_NTSC ? 30 : 25; in tw5864_frame_interval_set()
699 for (shift = 0; shift < std_max_fps; shift += input->frame_interval) in tw5864_frame_interval_set()
702 tw_writel(TW5864_H264EN_RATE_CNTL_LO_WORD(input->nr, 0), in tw5864_frame_interval_set()
704 tw_writel(TW5864_H264EN_RATE_CNTL_HI_WORD(input->nr, 0), in tw5864_frame_interval_set()
708 static int tw5864_frameinterval_get(struct tw5864_input *input, in tw5864_frameinterval_get() argument
711 struct tw5864_dev *dev = input->root; in tw5864_frameinterval_get()
713 switch (input->std) { in tw5864_frameinterval_get()
725 input->std); in tw5864_frameinterval_get()
735 struct tw5864_input *input = video_drvdata(file); in tw5864_enum_framesizes() local
744 fsize->discrete.height = input->std == STD_NTSC ? 480 : 576; in tw5864_enum_framesizes()
752 struct tw5864_input *input = video_drvdata(file); in tw5864_enum_frameintervals() local
754 int std_max_fps = input->std == STD_NTSC ? 30 : 25; in tw5864_enum_frameintervals()
769 ret = tw5864_frameinterval_get(input, &frameinterval); in tw5864_enum_frameintervals()
784 struct tw5864_input *input = video_drvdata(file); in tw5864_g_parm() local
790 ret = tw5864_frameinterval_get(input, &cp->timeperframe); in tw5864_g_parm()
794 cp->timeperframe.numerator *= input->frame_interval; in tw5864_g_parm()
804 struct tw5864_input *input = video_drvdata(file); in tw5864_s_parm() local
809 ret = tw5864_frameinterval_get(input, &time_base); in tw5864_s_parm()
814 t->numerator = time_base.numerator * input->frame_interval; in tw5864_s_parm()
822 input->frame_interval = t->numerator / time_base.numerator; in tw5864_s_parm()
823 if (input->frame_interval < 1) in tw5864_s_parm()
824 input->frame_interval = 1; in tw5864_s_parm()
825 tw5864_frame_interval_set(input); in tw5864_s_parm()
850 struct tw5864_input *input = video_drvdata(file); in tw5864_g_reg() local
851 struct tw5864_dev *dev = input->root; in tw5864_g_reg()
872 struct tw5864_input *input = video_drvdata(file); in tw5864_s_reg() local
873 struct tw5864_dev *dev = input->root; in tw5864_s_reg()
1098 static int tw5864_video_input_init(struct tw5864_input *input, int video_nr) in tw5864_video_input_init() argument
1100 struct tw5864_dev *dev = input->root; in tw5864_video_input_init()
1102 struct v4l2_ctrl_handler *hdl = &input->hdl; in tw5864_video_input_init()
1104 mutex_init(&input->lock); in tw5864_video_input_init()
1105 spin_lock_init(&input->slock); in tw5864_video_input_init()
1108 INIT_LIST_HEAD(&input->active); in tw5864_video_input_init()
1109 input->vidq.type = V4L2_BUF_TYPE_VIDEO_CAPTURE; in tw5864_video_input_init()
1110 input->vidq.timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_MONOTONIC; in tw5864_video_input_init()
1111 input->vidq.io_modes = VB2_MMAP | VB2_READ | VB2_DMABUF; in tw5864_video_input_init()
1112 input->vidq.ops = &tw5864_video_qops; in tw5864_video_input_init()
1113 input->vidq.mem_ops = &vb2_dma_contig_memops; in tw5864_video_input_init()
1114 input->vidq.drv_priv = input; in tw5864_video_input_init()
1115 input->vidq.gfp_flags = 0; in tw5864_video_input_init()
1116 input->vidq.buf_struct_size = sizeof(struct tw5864_buf); in tw5864_video_input_init()
1117 input->vidq.lock = &input->lock; in tw5864_video_input_init()
1118 input->vidq.min_queued_buffers = 2; in tw5864_video_input_init()
1119 input->vidq.dev = &input->root->pci->dev; in tw5864_video_input_init()
1120 ret = vb2_queue_init(&input->vidq); in tw5864_video_input_init()
1124 input->vdev = tw5864_video_template; in tw5864_video_input_init()
1125 input->vdev.v4l2_dev = &input->root->v4l2_dev; in tw5864_video_input_init()
1126 input->vdev.lock = &input->lock; in tw5864_video_input_init()
1127 input->vdev.queue = &input->vidq; in tw5864_video_input_init()
1128 video_set_drvdata(&input->vdev, input); in tw5864_video_input_init()
1151 input->md_threshold_grid_ctrl = in tw5864_video_input_init()
1157 input->vdev.ctrl_handler = hdl; in tw5864_video_input_init()
1160 input->qp = QP_VALUE; in tw5864_video_input_init()
1161 input->gop = GOP_SIZE; in tw5864_video_input_init()
1162 input->frame_interval = 1; in tw5864_video_input_init()
1164 ret = video_register_device(&input->vdev, VFL_TYPE_VIDEO, video_nr); in tw5864_video_input_init()
1168 dev_info(&input->root->pci->dev, "Registered video device %s\n", in tw5864_video_input_init()
1169 video_device_node_name(&input->vdev)); in tw5864_video_input_init()
1175 input->v4l2_std = V4L2_STD_NTSC_M; in tw5864_video_input_init()
1176 input->std = STD_NTSC; in tw5864_video_input_init()
1187 mutex_destroy(&input->lock); in tw5864_video_input_init()
1217 void tw5864_prepare_frame_headers(struct tw5864_input *input) in tw5864_prepare_frame_headers() argument
1219 struct tw5864_buf *vb = input->vb; in tw5864_prepare_frame_headers()
1225 spin_lock_irqsave(&input->slock, flags); in tw5864_prepare_frame_headers()
1226 if (list_empty(&input->active)) { in tw5864_prepare_frame_headers()
1227 spin_unlock_irqrestore(&input->slock, flags); in tw5864_prepare_frame_headers()
1228 input->vb = NULL; in tw5864_prepare_frame_headers()
1231 vb = list_first_entry(&input->active, struct tw5864_buf, list); in tw5864_prepare_frame_headers()
1233 spin_unlock_irqrestore(&input->slock, flags); in tw5864_prepare_frame_headers()
1254 if (input->frame_gop_seqno == 0) in tw5864_prepare_frame_headers()
1255 tw5864_h264_put_stream_header(&dst, &dst_space, input->qp, in tw5864_prepare_frame_headers()
1256 input->width, input->height); in tw5864_prepare_frame_headers()
1259 tw5864_h264_put_slice_header(&dst, &dst_space, input->h264_idr_pic_id, in tw5864_prepare_frame_headers()
1260 input->frame_gop_seqno, in tw5864_prepare_frame_headers()
1261 &input->tail_nb_bits, &input->tail); in tw5864_prepare_frame_headers()
1262 input->vb = vb; in tw5864_prepare_frame_headers()
1263 input->buf_cur_ptr = dst; in tw5864_prepare_frame_headers()
1264 input->buf_cur_space_left = dst_space; in tw5864_prepare_frame_headers()
1301 struct tw5864_input *input = frame->input; in tw5864_is_motion_triggered() local
1307 const u16 thresh = input->md_threshold_grid_values[i]; in tw5864_is_motion_triggered()
1366 struct tw5864_input *input = frame->input; in tw5864_handle_frame() local
1367 struct tw5864_dev *dev = input->root; in tw5864_handle_frame()
1371 u8 *dst = input->buf_cur_ptr; in tw5864_handle_frame()
1387 spin_lock_irqsave(&input->slock, flags); in tw5864_handle_frame()
1388 vb = input->vb; in tw5864_handle_frame()
1389 input->vb = NULL; in tw5864_handle_frame()
1390 spin_unlock_irqrestore(&input->slock, flags); in tw5864_handle_frame()
1403 if (input->buf_cur_space_left < frame_len * 5 / 4) { in tw5864_handle_frame()
1406 input->buf_cur_space_left, frame_len); in tw5864_handle_frame()
1410 for (i = 0; i < 8 - input->tail_nb_bits; i++) in tw5864_handle_frame()
1414 dst[0] = (input->tail & tail_mask) | (vlc_first_byte & vlc_mask); in tw5864_handle_frame()
1454 v4l2_event_queue(&input->vdev, &ev); in tw5864_handle_frame()