hc
2024-05-10 61598093bbdd283a7edc367d900f223070ead8d2
kernel/drivers/gpu/drm/etnaviv/etnaviv_gem.h
....@@ -6,7 +6,7 @@
66 #ifndef __ETNAVIV_GEM_H__
77 #define __ETNAVIV_GEM_H__
88
9
-#include <linux/reservation.h>
9
+#include <linux/dma-resv.h>
1010 #include "etnaviv_cmdbuf.h"
1111 #include "etnaviv_drv.h"
1212
....@@ -25,7 +25,7 @@
2525 struct list_head scan_node;
2626 struct list_head mmu_node;
2727 struct etnaviv_gem_object *object;
28
- struct etnaviv_iommu *mmu;
28
+ struct etnaviv_iommu_context *context;
2929 struct drm_mm_node vram_node;
3030 unsigned int use;
3131 u32 iova;
....@@ -46,10 +46,6 @@
4646 struct page **pages;
4747 struct sg_table *sgt;
4848 void *vaddr;
49
-
50
- /* normally (resv == &_resv) except for imported bo's */
51
- struct reservation_object *resv;
52
- struct reservation_object _resv;
5349
5450 struct list_head vram_list;
5551
....@@ -81,6 +77,7 @@
8177
8278 struct etnaviv_gem_submit_bo {
8379 u32 flags;
80
+ u64 va;
8481 struct etnaviv_gem_object *obj;
8582 struct etnaviv_vram_mapping *mapping;
8683 struct dma_fence *excl;
....@@ -95,7 +92,9 @@
9592 struct etnaviv_gem_submit {
9693 struct drm_sched_job sched_job;
9794 struct kref refcount;
95
+ struct etnaviv_file_private *ctx;
9896 struct etnaviv_gpu *gpu;
97
+ struct etnaviv_iommu_context *mmu_context, *prev_mmu_context;
9998 struct dma_fence *out_fence, *in_fence;
10099 int out_fence_id;
101100 struct list_head node; /* GPU active submit list */
....@@ -106,24 +105,23 @@
106105 unsigned int nr_pmrs;
107106 struct etnaviv_perfmon_request *pmrs;
108107 unsigned int nr_bos;
109
- struct etnaviv_gem_submit_bo bos[0];
108
+ struct etnaviv_gem_submit_bo bos[];
110109 /* No new members here, the previous one is variable-length! */
111110 };
112111
113112 void etnaviv_submit_put(struct etnaviv_gem_submit * submit);
114113
115114 int etnaviv_gem_wait_bo(struct etnaviv_gpu *gpu, struct drm_gem_object *obj,
116
- struct timespec *timeout);
115
+ struct drm_etnaviv_timespec *timeout);
117116 int etnaviv_gem_new_private(struct drm_device *dev, size_t size, u32 flags,
118
- struct reservation_object *robj, const struct etnaviv_gem_ops *ops,
119
- struct etnaviv_gem_object **res);
117
+ const struct etnaviv_gem_ops *ops, struct etnaviv_gem_object **res);
120118 void etnaviv_gem_obj_add(struct drm_device *dev, struct drm_gem_object *obj);
121119 struct page **etnaviv_gem_get_pages(struct etnaviv_gem_object *obj);
122120 void etnaviv_gem_put_pages(struct etnaviv_gem_object *obj);
123121
124122 struct etnaviv_vram_mapping *etnaviv_gem_mapping_get(
125
- struct drm_gem_object *obj, struct etnaviv_gpu *gpu);
126
-void etnaviv_gem_mapping_reference(struct etnaviv_vram_mapping *mapping);
123
+ struct drm_gem_object *obj, struct etnaviv_iommu_context *mmu_context,
124
+ u64 va);
127125 void etnaviv_gem_mapping_unreference(struct etnaviv_vram_mapping *mapping);
128126
129127 #endif /* __ETNAVIV_GEM_H__ */