Lines Matching refs:gsc
34 struct gsc_dev *gsc = ctx->gsc_dev; in gsc_m2m_ctx_stop_req() local
37 curr_ctx = v4l2_m2m_get_curr_priv(gsc->m2m.m2m_dev); in gsc_m2m_ctx_stop_req()
38 if (!gsc_m2m_pending(gsc) || (curr_ctx != ctx)) in gsc_m2m_ctx_stop_req()
42 ret = wait_event_timeout(gsc->irq_queue, in gsc_m2m_ctx_stop_req()
153 struct gsc_dev *gsc; in gsc_m2m_device_run() local
161 gsc = ctx->gsc_dev; in gsc_m2m_device_run()
162 spin_lock_irqsave(&gsc->slock, flags); in gsc_m2m_device_run()
164 set_bit(ST_M2M_PEND, &gsc->state); in gsc_m2m_device_run()
167 if (gsc->m2m.ctx != ctx) { in gsc_m2m_device_run()
169 gsc->m2m.ctx, ctx); in gsc_m2m_device_run()
171 gsc->m2m.ctx = ctx; in gsc_m2m_device_run()
178 wake_up(&gsc->irq_queue); in gsc_m2m_device_run()
188 gsc_set_prefbuf(gsc, &ctx->s_frame); in gsc_m2m_device_run()
189 gsc_hw_set_input_addr(gsc, &ctx->s_frame.addr, GSC_M2M_BUF_NUM); in gsc_m2m_device_run()
190 gsc_hw_set_output_addr(gsc, &ctx->d_frame.addr, GSC_M2M_BUF_NUM); in gsc_m2m_device_run()
193 gsc_hw_set_input_buf_masking(gsc, GSC_M2M_BUF_NUM, false); in gsc_m2m_device_run()
194 gsc_hw_set_output_buf_masking(gsc, GSC_M2M_BUF_NUM, false); in gsc_m2m_device_run()
195 gsc_hw_set_frm_done_irq_mask(gsc, false); in gsc_m2m_device_run()
196 gsc_hw_set_gsc_irq_enable(gsc, true); in gsc_m2m_device_run()
221 gsc_hw_enable_control(gsc, true); in gsc_m2m_device_run()
223 spin_unlock_irqrestore(&gsc->slock, flags); in gsc_m2m_device_run()
228 spin_unlock_irqrestore(&gsc->slock, flags); in gsc_m2m_device_run()
295 struct gsc_dev *gsc = ctx->gsc_dev; in gsc_m2m_querycap() local
300 dev_name(&gsc->pdev->dev)); in gsc_m2m_querycap()
378 struct gsc_dev *gsc = ctx->gsc_dev; in gsc_m2m_reqbufs() local
382 gsc->variant->in_buf_cnt : gsc->variant->out_buf_cnt; in gsc_m2m_reqbufs()
624 struct gsc_dev *gsc = video_drvdata(file); in gsc_m2m_open() local
628 pr_debug("pid: %d, state: 0x%lx", task_pid_nr(current), gsc->state); in gsc_m2m_open()
630 if (mutex_lock_interruptible(&gsc->lock)) in gsc_m2m_open()
639 v4l2_fh_init(&ctx->fh, gsc->m2m.vfd); in gsc_m2m_open()
649 ctx->gsc_dev = gsc; in gsc_m2m_open()
659 ctx->m2m_ctx = v4l2_m2m_ctx_init(gsc->m2m.m2m_dev, ctx, queue_init); in gsc_m2m_open()
666 if (gsc->m2m.refcnt++ == 0) in gsc_m2m_open()
667 set_bit(ST_M2M_OPEN, &gsc->state); in gsc_m2m_open()
671 mutex_unlock(&gsc->lock); in gsc_m2m_open()
681 mutex_unlock(&gsc->lock); in gsc_m2m_open()
688 struct gsc_dev *gsc = ctx->gsc_dev; in gsc_m2m_release() local
691 task_pid_nr(current), gsc->state, gsc->m2m.refcnt); in gsc_m2m_release()
693 mutex_lock(&gsc->lock); in gsc_m2m_release()
700 if (--gsc->m2m.refcnt <= 0) in gsc_m2m_release()
701 clear_bit(ST_M2M_OPEN, &gsc->state); in gsc_m2m_release()
704 mutex_unlock(&gsc->lock); in gsc_m2m_release()
712 struct gsc_dev *gsc = ctx->gsc_dev; in gsc_m2m_poll() local
715 if (mutex_lock_interruptible(&gsc->lock)) in gsc_m2m_poll()
719 mutex_unlock(&gsc->lock); in gsc_m2m_poll()
727 struct gsc_dev *gsc = ctx->gsc_dev; in gsc_m2m_mmap() local
730 if (mutex_lock_interruptible(&gsc->lock)) in gsc_m2m_mmap()
734 mutex_unlock(&gsc->lock); in gsc_m2m_mmap()
753 int gsc_register_m2m_device(struct gsc_dev *gsc) in gsc_register_m2m_device() argument
758 if (!gsc) in gsc_register_m2m_device()
761 pdev = gsc->pdev; in gsc_register_m2m_device()
763 gsc->vdev.fops = &gsc_m2m_fops; in gsc_register_m2m_device()
764 gsc->vdev.ioctl_ops = &gsc_m2m_ioctl_ops; in gsc_register_m2m_device()
765 gsc->vdev.release = video_device_release_empty; in gsc_register_m2m_device()
766 gsc->vdev.lock = &gsc->lock; in gsc_register_m2m_device()
767 gsc->vdev.vfl_dir = VFL_DIR_M2M; in gsc_register_m2m_device()
768 gsc->vdev.v4l2_dev = &gsc->v4l2_dev; in gsc_register_m2m_device()
769 snprintf(gsc->vdev.name, sizeof(gsc->vdev.name), "%s.%d:m2m", in gsc_register_m2m_device()
770 GSC_MODULE_NAME, gsc->id); in gsc_register_m2m_device()
772 video_set_drvdata(&gsc->vdev, gsc); in gsc_register_m2m_device()
774 gsc->m2m.vfd = &gsc->vdev; in gsc_register_m2m_device()
775 gsc->m2m.m2m_dev = v4l2_m2m_init(&gsc_m2m_ops); in gsc_register_m2m_device()
776 if (IS_ERR(gsc->m2m.m2m_dev)) { in gsc_register_m2m_device()
778 return PTR_ERR(gsc->m2m.m2m_dev); in gsc_register_m2m_device()
781 ret = video_register_device(&gsc->vdev, VFL_TYPE_GRABBER, -1); in gsc_register_m2m_device()
788 pr_debug("gsc m2m driver registered as /dev/video%d", gsc->vdev.num); in gsc_register_m2m_device()
792 v4l2_m2m_release(gsc->m2m.m2m_dev); in gsc_register_m2m_device()
797 void gsc_unregister_m2m_device(struct gsc_dev *gsc) in gsc_unregister_m2m_device() argument
799 if (gsc) { in gsc_unregister_m2m_device()
800 v4l2_m2m_release(gsc->m2m.m2m_dev); in gsc_unregister_m2m_device()
801 video_unregister_device(&gsc->vdev); in gsc_unregister_m2m_device()