Lines Matching full:gsc

25 #include "gsc-core.h"
30 struct gsc_dev *gsc = ctx->gsc_dev; in gsc_m2m_ctx_stop_req() local
33 curr_ctx = v4l2_m2m_get_curr_priv(gsc->m2m.m2m_dev); in gsc_m2m_ctx_stop_req()
34 if (!gsc_m2m_pending(gsc) || (curr_ctx != ctx)) in gsc_m2m_ctx_stop_req()
38 ret = wait_event_timeout(gsc->irq_queue, in gsc_m2m_ctx_stop_req()
147 struct gsc_dev *gsc; in gsc_m2m_device_run() local
155 gsc = ctx->gsc_dev; in gsc_m2m_device_run()
156 spin_lock_irqsave(&gsc->slock, flags); in gsc_m2m_device_run()
158 set_bit(ST_M2M_PEND, &gsc->state); in gsc_m2m_device_run()
161 if (gsc->m2m.ctx != ctx) { in gsc_m2m_device_run()
162 pr_debug("gsc->m2m.ctx = 0x%p, current_ctx = 0x%p", in gsc_m2m_device_run()
163 gsc->m2m.ctx, ctx); in gsc_m2m_device_run()
165 gsc->m2m.ctx = ctx; in gsc_m2m_device_run()
172 wake_up(&gsc->irq_queue); in gsc_m2m_device_run()
182 gsc_set_prefbuf(gsc, &ctx->s_frame); in gsc_m2m_device_run()
183 gsc_hw_set_input_addr(gsc, &ctx->s_frame.addr, GSC_M2M_BUF_NUM); in gsc_m2m_device_run()
184 gsc_hw_set_output_addr(gsc, &ctx->d_frame.addr, GSC_M2M_BUF_NUM); in gsc_m2m_device_run()
187 gsc_hw_set_input_buf_masking(gsc, GSC_M2M_BUF_NUM, false); in gsc_m2m_device_run()
188 gsc_hw_set_output_buf_masking(gsc, GSC_M2M_BUF_NUM, false); in gsc_m2m_device_run()
189 gsc_hw_set_frm_done_irq_mask(gsc, false); in gsc_m2m_device_run()
190 gsc_hw_set_gsc_irq_enable(gsc, true); in gsc_m2m_device_run()
215 gsc_hw_enable_control(gsc, true); in gsc_m2m_device_run()
217 spin_unlock_irqrestore(&gsc->slock, flags); in gsc_m2m_device_run()
222 spin_unlock_irqrestore(&gsc->slock, flags); in gsc_m2m_device_run()
289 struct gsc_dev *gsc = ctx->gsc_dev; in gsc_m2m_querycap() local
294 dev_name(&gsc->pdev->dev)); in gsc_m2m_querycap()
370 struct gsc_dev *gsc = ctx->gsc_dev; in gsc_m2m_reqbufs() local
374 gsc->variant->in_buf_cnt : gsc->variant->out_buf_cnt; in gsc_m2m_reqbufs()
613 struct gsc_dev *gsc = video_drvdata(file); in gsc_m2m_open() local
617 pr_debug("pid: %d, state: 0x%lx", task_pid_nr(current), gsc->state); in gsc_m2m_open()
619 if (mutex_lock_interruptible(&gsc->lock)) in gsc_m2m_open()
628 v4l2_fh_init(&ctx->fh, gsc->m2m.vfd); in gsc_m2m_open()
638 ctx->gsc_dev = gsc; in gsc_m2m_open()
648 ctx->m2m_ctx = v4l2_m2m_ctx_init(gsc->m2m.m2m_dev, ctx, queue_init); in gsc_m2m_open()
655 if (gsc->m2m.refcnt++ == 0) in gsc_m2m_open()
656 set_bit(ST_M2M_OPEN, &gsc->state); in gsc_m2m_open()
658 pr_debug("gsc m2m driver is opened, ctx(0x%p)", ctx); in gsc_m2m_open()
660 mutex_unlock(&gsc->lock); in gsc_m2m_open()
670 mutex_unlock(&gsc->lock); in gsc_m2m_open()
677 struct gsc_dev *gsc = ctx->gsc_dev; in gsc_m2m_release() local
680 task_pid_nr(current), gsc->state, gsc->m2m.refcnt); in gsc_m2m_release()
682 mutex_lock(&gsc->lock); in gsc_m2m_release()
689 if (--gsc->m2m.refcnt <= 0) in gsc_m2m_release()
690 clear_bit(ST_M2M_OPEN, &gsc->state); in gsc_m2m_release()
693 mutex_unlock(&gsc->lock); in gsc_m2m_release()
701 struct gsc_dev *gsc = ctx->gsc_dev; in gsc_m2m_poll() local
704 if (mutex_lock_interruptible(&gsc->lock)) in gsc_m2m_poll()
708 mutex_unlock(&gsc->lock); in gsc_m2m_poll()
716 struct gsc_dev *gsc = ctx->gsc_dev; in gsc_m2m_mmap() local
719 if (mutex_lock_interruptible(&gsc->lock)) in gsc_m2m_mmap()
723 mutex_unlock(&gsc->lock); in gsc_m2m_mmap()
742 int gsc_register_m2m_device(struct gsc_dev *gsc) in gsc_register_m2m_device() argument
747 if (!gsc) in gsc_register_m2m_device()
750 pdev = gsc->pdev; in gsc_register_m2m_device()
752 gsc->vdev.fops = &gsc_m2m_fops; in gsc_register_m2m_device()
753 gsc->vdev.ioctl_ops = &gsc_m2m_ioctl_ops; in gsc_register_m2m_device()
754 gsc->vdev.release = video_device_release_empty; in gsc_register_m2m_device()
755 gsc->vdev.lock = &gsc->lock; in gsc_register_m2m_device()
756 gsc->vdev.vfl_dir = VFL_DIR_M2M; in gsc_register_m2m_device()
757 gsc->vdev.v4l2_dev = &gsc->v4l2_dev; in gsc_register_m2m_device()
758 gsc->vdev.device_caps = V4L2_CAP_STREAMING | in gsc_register_m2m_device()
760 snprintf(gsc->vdev.name, sizeof(gsc->vdev.name), "%s.%d:m2m", in gsc_register_m2m_device()
761 GSC_MODULE_NAME, gsc->id); in gsc_register_m2m_device()
763 video_set_drvdata(&gsc->vdev, gsc); in gsc_register_m2m_device()
765 gsc->m2m.vfd = &gsc->vdev; in gsc_register_m2m_device()
766 gsc->m2m.m2m_dev = v4l2_m2m_init(&gsc_m2m_ops); in gsc_register_m2m_device()
767 if (IS_ERR(gsc->m2m.m2m_dev)) { in gsc_register_m2m_device()
769 return PTR_ERR(gsc->m2m.m2m_dev); in gsc_register_m2m_device()
772 ret = video_register_device(&gsc->vdev, VFL_TYPE_VIDEO, -1); in gsc_register_m2m_device()
779 pr_debug("gsc m2m driver registered as /dev/video%d", gsc->vdev.num); in gsc_register_m2m_device()
783 v4l2_m2m_release(gsc->m2m.m2m_dev); in gsc_register_m2m_device()
788 void gsc_unregister_m2m_device(struct gsc_dev *gsc) in gsc_unregister_m2m_device() argument
790 if (gsc) { in gsc_unregister_m2m_device()
791 v4l2_m2m_release(gsc->m2m.m2m_dev); in gsc_unregister_m2m_device()
792 video_unregister_device(&gsc->vdev); in gsc_unregister_m2m_device()