blob: 7d3816fca5a8722a82ddb53e6351444edb238093 [file] [log] [blame]
Andreas Pokorny47c12962014-08-08 10:40:56 +02001/*
2 * Copyright 2014 Canonical
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
10 *
11 * The above copyright notice and this permission notice shall be included in
12 * all copies or substantial portions of the Software.
13 *
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
17 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20 * OTHER DEALINGS IN THE SOFTWARE.
21 *
22 * Authors: Andreas Pokorny
23 */
24
Gerd Hoffmann182e7f92019-01-18 13:20:16 +010025#include "qxl_drv.h"
Gerd Hoffmann9b369112019-01-18 13:20:13 +010026#include "qxl_object.h"
Andreas Pokorny47c12962014-08-08 10:40:56 +020027
28/* Empty Implementations as there should not be any other driver for a virtual
29 * device that might share buffers with qxl */
30
31int qxl_gem_prime_pin(struct drm_gem_object *obj)
32{
Gerd Hoffmann182e7f92019-01-18 13:20:16 +010033 struct qxl_bo *bo = gem_to_qxl_bo(obj);
34
35 return qxl_bo_pin(bo);
Andreas Pokorny47c12962014-08-08 10:40:56 +020036}
37
38void qxl_gem_prime_unpin(struct drm_gem_object *obj)
39{
Gerd Hoffmann182e7f92019-01-18 13:20:16 +010040 struct qxl_bo *bo = gem_to_qxl_bo(obj);
41
42 qxl_bo_unpin(bo);
Andreas Pokorny47c12962014-08-08 10:40:56 +020043}
44
Gerd Hoffmannab042b822019-04-26 07:33:24 +020045struct sg_table *qxl_gem_prime_get_sg_table(struct drm_gem_object *obj)
46{
47 return ERR_PTR(-ENOSYS);
48}
49
50struct drm_gem_object *qxl_gem_prime_import_sg_table(
51 struct drm_device *dev, struct dma_buf_attachment *attach,
52 struct sg_table *table)
53{
54 return ERR_PTR(-ENOSYS);
55}
56
Andreas Pokorny47c12962014-08-08 10:40:56 +020057void *qxl_gem_prime_vmap(struct drm_gem_object *obj)
58{
Gerd Hoffmann9b369112019-01-18 13:20:13 +010059 struct qxl_bo *bo = gem_to_qxl_bo(obj);
60 void *ptr;
61 int ret;
62
63 ret = qxl_bo_kmap(bo, &ptr);
64 if (ret < 0)
65 return ERR_PTR(ret);
66
67 return ptr;
Andreas Pokorny47c12962014-08-08 10:40:56 +020068}
69
70void qxl_gem_prime_vunmap(struct drm_gem_object *obj, void *vaddr)
71{
Gerd Hoffmann9b369112019-01-18 13:20:13 +010072 struct qxl_bo *bo = gem_to_qxl_bo(obj);
73
74 qxl_bo_kunmap(bo);
Andreas Pokorny47c12962014-08-08 10:40:56 +020075}
76
77int qxl_gem_prime_mmap(struct drm_gem_object *obj,
78 struct vm_area_struct *area)
79{
Anton Protopopovdada1682016-02-06 23:25:28 -050080 return -ENOSYS;
Andreas Pokorny47c12962014-08-08 10:40:56 +020081}