Stop using alloc_ctx and just fill in the device pointer.
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Cc: Kyungmin Park <kyungmin.park@samsung.com>
Cc: Sylwester Nawrocki <s.nawrocki@samsung.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
        if (ret < 0)
                goto err_m2m;
 
-       /* Initialize continious memory allocator */
        vb2_dma_contig_set_max_seg_size(dev, DMA_BIT_MASK(32));
-       gsc->alloc_ctx = vb2_dma_contig_init_ctx(dev);
-       if (IS_ERR(gsc->alloc_ctx)) {
-               ret = PTR_ERR(gsc->alloc_ctx);
-               goto err_pm;
-       }
 
        dev_dbg(dev, "gsc-%d registered successfully\n", gsc->id);
 
        pm_runtime_put(dev);
        return 0;
-err_pm:
-       pm_runtime_put(dev);
+
 err_m2m:
        gsc_unregister_m2m_device(gsc);
 err_v4l2:
        gsc_unregister_m2m_device(gsc);
        v4l2_device_unregister(&gsc->v4l2_dev);
 
-       vb2_dma_contig_cleanup_ctx(gsc->alloc_ctx);
        vb2_dma_contig_clear_max_seg_size(&pdev->dev);
        pm_runtime_disable(&pdev->dev);
        gsc_clk_put(gsc);
 
        wait_queue_head_t               irq_queue;
        struct gsc_m2m_device           m2m;
        unsigned long                   state;
-       struct vb2_alloc_ctx            *alloc_ctx;
        struct video_device             vdev;
        struct v4l2_device              v4l2_dev;
 };
 
                return -EINVAL;
 
        *num_planes = frame->fmt->num_planes;
-       for (i = 0; i < frame->fmt->num_planes; i++) {
+       for (i = 0; i < frame->fmt->num_planes; i++)
                sizes[i] = frame->payload[i];
-               allocators[i] = ctx->gsc_dev->alloc_ctx;
-       }
        return 0;
 }
 
        src_vq->buf_struct_size = sizeof(struct v4l2_m2m_buffer);
        src_vq->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_COPY;
        src_vq->lock = &ctx->gsc_dev->lock;
+       src_vq->dev = &ctx->gsc_dev->pdev->dev;
 
        ret = vb2_queue_init(src_vq);
        if (ret)
        dst_vq->buf_struct_size = sizeof(struct v4l2_m2m_buffer);
        dst_vq->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_COPY;
        dst_vq->lock = &ctx->gsc_dev->lock;
+       dst_vq->dev = &ctx->gsc_dev->pdev->dev;
 
        return vb2_queue_init(dst_vq);
 }
 
                       unsigned int sizes[], void *allocators[])
 {
        struct camif_vp *vp = vb2_get_drv_priv(vq);
-       struct camif_dev *camif = vp->camif;
        struct camif_frame *frame = &vp->out_frame;
        const struct camif_fmt *fmt = vp->out_fmt;
        unsigned int size;
                return -EINVAL;
 
        size = (frame->f_width * frame->f_height * fmt->depth) / 8;
-       allocators[0] = camif->alloc_ctx;
 
        if (*num_planes)
                return sizes[0] < size ? -EINVAL : 0;
        q->drv_priv = vp;
        q->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_MONOTONIC;
        q->lock = &vp->camif->lock;
+       q->dev = camif->v4l2_dev.dev;
 
        ret = vb2_queue_init(q);
        if (ret)
 
        if (ret < 0)
                goto err_pm;
 
-       /* Initialize contiguous memory allocator */
-       camif->alloc_ctx = vb2_dma_contig_init_ctx(dev);
-       if (IS_ERR(camif->alloc_ctx)) {
-               ret = PTR_ERR(camif->alloc_ctx);
-               goto err_alloc;
-       }
-
        ret = camif_media_dev_init(camif);
        if (ret < 0)
-               goto err_mdev;
+               goto err_alloc;
 
        ret = camif_register_sensor(camif);
        if (ret < 0)
        media_device_unregister(&camif->media_dev);
        media_device_cleanup(&camif->media_dev);
        camif_unregister_media_entities(camif);
-err_mdev:
-       vb2_dma_contig_cleanup_ctx(camif->alloc_ctx);
 err_alloc:
        pm_runtime_put(dev);
        pm_runtime_disable(dev);
 
  * @ctrl_handler: v4l2 control handler (owned by @subdev)
  * @test_pattern: test pattern controls
  * @vp:           video path (DMA) description (codec/preview)
- * @alloc_ctx:    memory buffer allocator context
  * @variant:      variant information for this device
  * @dev:         pointer to the CAMIF device struct
  * @pdata:       a copy of the driver's platform data
        u8                              colorfx_cr;
 
        struct camif_vp                 vp[CAMIF_VP_NUM];
-       struct vb2_alloc_ctx            *alloc_ctx;
 
        const struct s3c_camif_variant  *variant;
        struct device                   *dev;
 
 
        sizes[0] = f->size;
        *nplanes = 1;
-       alloc_ctxs[0] = ctx->dev->alloc_ctx;
 
        if (*nbuffers == 0)
                *nbuffers = 1;
        src_vq->buf_struct_size = sizeof(struct v4l2_m2m_buffer);
        src_vq->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_COPY;
        src_vq->lock = &ctx->dev->mutex;
+       src_vq->dev = ctx->dev->v4l2_dev.dev;
 
        ret = vb2_queue_init(src_vq);
        if (ret)
        dst_vq->buf_struct_size = sizeof(struct v4l2_m2m_buffer);
        dst_vq->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_COPY;
        dst_vq->lock = &ctx->dev->mutex;
+       dst_vq->dev = ctx->dev->v4l2_dev.dev;
 
        return vb2_queue_init(dst_vq);
 }
        }
 
        vb2_dma_contig_set_max_seg_size(&pdev->dev, DMA_BIT_MASK(32));
-       dev->alloc_ctx = vb2_dma_contig_init_ctx(&pdev->dev);
-       if (IS_ERR(dev->alloc_ctx)) {
-               ret = PTR_ERR(dev->alloc_ctx);
-               goto unprep_clk_gate;
-       }
 
        ret = v4l2_device_register(&pdev->dev, &dev->v4l2_dev);
        if (ret)
-               goto alloc_ctx_cleanup;
+               goto unprep_clk_gate;
        vfd = video_device_alloc();
        if (!vfd) {
                v4l2_err(&dev->v4l2_dev, "Failed to allocate video device\n");
        video_device_release(vfd);
 unreg_v4l2_dev:
        v4l2_device_unregister(&dev->v4l2_dev);
-alloc_ctx_cleanup:
-       vb2_dma_contig_cleanup_ctx(dev->alloc_ctx);
 unprep_clk_gate:
        clk_unprepare(dev->gate);
 put_clk_gate:
        v4l2_m2m_release(dev->m2m_dev);
        video_unregister_device(dev->vfd);
        v4l2_device_unregister(&dev->v4l2_dev);
-       vb2_dma_contig_cleanup_ctx(dev->alloc_ctx);
        vb2_dma_contig_clear_max_seg_size(&pdev->dev);
        clk_unprepare(dev->gate);
        clk_put(dev->gate);
 
        struct mutex            mutex;
        spinlock_t              ctrl_lock;
        atomic_t                num_inst;
-       struct vb2_alloc_ctx    *alloc_ctx;
        void __iomem            *regs;
        struct clk              *clk;
        struct clk              *gate;
 
        *nbuffers = count;
        *nplanes = 1;
        sizes[0] = size;
-       alloc_ctxs[0] = ctx->jpeg->alloc_ctx;
 
        return 0;
 }
        src_vq->mem_ops = &vb2_dma_contig_memops;
        src_vq->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_COPY;
        src_vq->lock = &ctx->jpeg->lock;
+       src_vq->dev = ctx->jpeg->dev;
 
        ret = vb2_queue_init(src_vq);
        if (ret)
        dst_vq->mem_ops = &vb2_dma_contig_memops;
        dst_vq->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_COPY;
        dst_vq->lock = &ctx->jpeg->lock;
+       dst_vq->dev = ctx->jpeg->dev;
 
        return vb2_queue_init(dst_vq);
 }
        }
 
        vb2_dma_contig_set_max_seg_size(&pdev->dev, DMA_BIT_MASK(32));
-       jpeg->alloc_ctx = vb2_dma_contig_init_ctx(&pdev->dev);
-       if (IS_ERR(jpeg->alloc_ctx)) {
-               v4l2_err(&jpeg->v4l2_dev, "Failed to init memory allocator\n");
-               ret = PTR_ERR(jpeg->alloc_ctx);
-               goto m2m_init_rollback;
-       }
 
        /* JPEG encoder /dev/videoX node */
        jpeg->vfd_encoder = video_device_alloc();
        if (!jpeg->vfd_encoder) {
                v4l2_err(&jpeg->v4l2_dev, "Failed to allocate video device\n");
                ret = -ENOMEM;
-               goto vb2_allocator_rollback;
+               goto m2m_init_rollback;
        }
        snprintf(jpeg->vfd_encoder->name, sizeof(jpeg->vfd_encoder->name),
                                "%s-enc", S5P_JPEG_M2M_NAME);
        if (ret) {
                v4l2_err(&jpeg->v4l2_dev, "Failed to register video device\n");
                video_device_release(jpeg->vfd_encoder);
-               goto vb2_allocator_rollback;
+               goto m2m_init_rollback;
        }
 
        video_set_drvdata(jpeg->vfd_encoder, jpeg);
 enc_vdev_register_rollback:
        video_unregister_device(jpeg->vfd_encoder);
 
-vb2_allocator_rollback:
-       vb2_dma_contig_cleanup_ctx(jpeg->alloc_ctx);
-
 m2m_init_rollback:
        v4l2_m2m_release(jpeg->m2m_dev);
 
 
        video_unregister_device(jpeg->vfd_decoder);
        video_unregister_device(jpeg->vfd_encoder);
-       vb2_dma_contig_cleanup_ctx(jpeg->alloc_ctx);
        vb2_dma_contig_clear_max_seg_size(&pdev->dev);
        v4l2_m2m_release(jpeg->m2m_dev);
        v4l2_device_unregister(&jpeg->v4l2_dev);
 
  * @irq:               JPEG IP irq
  * @clocks:            JPEG IP clock(s)
  * @dev:               JPEG IP struct device
- * @alloc_ctx:         videobuf2 memory allocator's context
  * @variant:           driver variant to be used
  * @irq_status         interrupt flags set during single encode/decode
                        operation
        enum exynos4_jpeg_result irq_ret;
        struct clk              *clocks[JPEG_MAX_CLOCKS];
        struct device           *dev;
-       void                    *alloc_ctx;
        struct s5p_jpeg_variant *variant;
        u32                     irq_status;
 };
 
 
        /** V4L2 device */
        struct v4l2_device v4l2_dev;
-       /** context of allocator */
-       void *alloc_ctx;
        /** event wait queue */
        wait_queue_head_t event_queue;
        /** state flags */
 
        }
 
        vb2_dma_contig_set_max_seg_size(mdev->dev, DMA_BIT_MASK(32));
-       mdev->alloc_ctx = vb2_dma_contig_init_ctx(mdev->dev);
-       if (IS_ERR(mdev->alloc_ctx)) {
-               mxr_err(mdev, "could not acquire vb2 allocator\n");
-               ret = PTR_ERR(mdev->alloc_ctx);
-               goto fail_v4l2_dev;
-       }
 
        /* registering outputs */
        mdev->output_cnt = 0;
                mxr_err(mdev, "failed to register any output\n");
                ret = -ENODEV;
                /* skipping fail_output because there is nothing to free */
-               goto fail_vb2_allocator;
+               goto fail_v4l2_dev;
        }
 
        return 0;
                kfree(mdev->output[i]);
        memset(mdev->output, 0, sizeof(mdev->output));
 
-fail_vb2_allocator:
-       /* freeing allocator context */
-       vb2_dma_contig_cleanup_ctx(mdev->alloc_ctx);
-
 fail_v4l2_dev:
        /* NOTE: automatically unregister all subdevs */
        v4l2_device_unregister(v4l2_dev);
        for (i = 0; i < mdev->output_cnt; ++i)
                kfree(mdev->output[i]);
 
-       vb2_dma_contig_cleanup_ctx(mdev->alloc_ctx);
        vb2_dma_contig_clear_max_seg_size(mdev->dev);
        v4l2_device_unregister(&mdev->v4l2_dev);
 }
 
        *nplanes = fmt->num_subframes;
        for (i = 0; i < fmt->num_subframes; ++i) {
-               alloc_ctxs[i] = layer->mdev->alloc_ctx;
                sizes[i] = planes[i].sizeimage;
                mxr_dbg(mdev, "size[%d] = %08x\n", i, sizes[i]);
        }
                .min_buffers_needed = 1,
                .mem_ops = &vb2_dma_contig_memops,
                .lock = &layer->mutex,
+               .dev = mdev->dev,
        };
 
        return layer;