Home
last modified time | relevance | path

Searched refs:submit (Results 1 – 25 of 186) sorted by relevance

12345678

/Linux-v6.1/drivers/gpu/drm/etnaviv/
Detnaviv_gem_submit.c34 struct etnaviv_gem_submit *submit; in submit_create() local
35 size_t sz = size_vstruct(nr_bos, sizeof(submit->bos[0]), sizeof(*submit)); in submit_create()
37 submit = kzalloc(sz, GFP_KERNEL); in submit_create()
38 if (!submit) in submit_create()
41 submit->pmrs = kcalloc(nr_pmrs, sizeof(struct etnaviv_perfmon_request), in submit_create()
43 if (!submit->pmrs) { in submit_create()
44 kfree(submit); in submit_create()
47 submit->nr_pmrs = nr_pmrs; in submit_create()
49 submit->gpu = gpu; in submit_create()
50 kref_init(&submit->refcount); in submit_create()
[all …]
Detnaviv_sched.c22 struct etnaviv_gem_submit *submit = to_etnaviv_submit(sched_job); in etnaviv_sched_run_job() local
26 fence = etnaviv_gpu_submit(submit); in etnaviv_sched_run_job()
28 dev_dbg(submit->gpu->dev, "skipping bad job\n"); in etnaviv_sched_run_job()
36 struct etnaviv_gem_submit *submit = to_etnaviv_submit(sched_job); in etnaviv_sched_timedout_job() local
37 struct etnaviv_gpu *gpu = submit->gpu; in etnaviv_sched_timedout_job()
48 if (dma_fence_is_signaled(submit->out_fence)) in etnaviv_sched_timedout_job()
69 etnaviv_core_dump(submit); in etnaviv_sched_timedout_job()
85 struct etnaviv_gem_submit *submit = to_etnaviv_submit(sched_job); in etnaviv_sched_free_job() local
89 etnaviv_submit_put(submit); in etnaviv_sched_free_job()
98 int etnaviv_sched_push_job(struct etnaviv_gem_submit *submit) in etnaviv_sched_push_job() argument
[all …]
Detnaviv_dump.c113 void etnaviv_core_dump(struct etnaviv_gem_submit *submit) in etnaviv_core_dump() argument
115 struct etnaviv_gpu *gpu = submit->gpu; in etnaviv_core_dump()
137 mmu_size + gpu->buffer.size + submit->cmdbuf.size; in etnaviv_core_dump()
140 for (i = 0; i < submit->nr_bos; i++) { in etnaviv_core_dump()
141 obj = submit->bos[i].obj; in etnaviv_core_dump()
179 submit->cmdbuf.vaddr, submit->cmdbuf.size, in etnaviv_core_dump()
180 etnaviv_cmdbuf_get_va(&submit->cmdbuf, in etnaviv_core_dump()
196 for (i = 0; i < submit->nr_bos; i++) { in etnaviv_core_dump()
201 obj = submit->bos[i].obj; in etnaviv_core_dump()
202 vram = submit->bos[i].mapping; in etnaviv_core_dump()
Detnaviv_gpu.c1280 const struct etnaviv_gem_submit *submit = event->submit; in sync_point_perfmon_sample() local
1283 for (i = 0; i < submit->nr_pmrs; i++) { in sync_point_perfmon_sample()
1284 const struct etnaviv_perfmon_request *pmr = submit->pmrs + i; in sync_point_perfmon_sample()
1287 etnaviv_perfmon_process(gpu, pmr, submit->exec_state); in sync_point_perfmon_sample()
1312 const struct etnaviv_gem_submit *submit = event->submit; in sync_point_perfmon_sample_post() local
1318 for (i = 0; i < submit->nr_pmrs; i++) { in sync_point_perfmon_sample_post()
1319 const struct etnaviv_perfmon_request *pmr = submit->pmrs + i; in sync_point_perfmon_sample_post()
1337 struct dma_fence *etnaviv_gpu_submit(struct etnaviv_gem_submit *submit) in etnaviv_gpu_submit() argument
1339 struct etnaviv_gpu *gpu = submit->gpu; in etnaviv_gpu_submit()
1344 if (!submit->runtime_resumed) { in etnaviv_gpu_submit()
[all …]
/Linux-v6.1/drivers/gpu/drm/msm/
Dmsm_gem_submit.c30 struct msm_gem_submit *submit; in submit_create() local
34 sz = struct_size(submit, bos, nr_bos) + in submit_create()
35 ((u64)nr_cmds * sizeof(submit->cmd[0])); in submit_create()
40 submit = kzalloc(sz, GFP_KERNEL); in submit_create()
41 if (!submit) in submit_create()
44 ret = drm_sched_job_init(&submit->base, queue->entity, queue); in submit_create()
46 kfree(submit); in submit_create()
50 kref_init(&submit->ref); in submit_create()
51 submit->dev = dev; in submit_create()
52 submit->aspace = queue->ctx->aspace; in submit_create()
[all …]
Dmsm_rd.c87 struct msm_gem_submit *submit; member
313 struct msm_gem_submit *submit, int idx, in snapshot_buf() argument
316 struct msm_gem_object *obj = submit->bos[idx].obj; in snapshot_buf()
321 offset = iova - submit->bos[idx].iova; in snapshot_buf()
323 iova = submit->bos[idx].iova; in snapshot_buf()
338 if (!(submit->bos[idx].flags & MSM_SUBMIT_BO_READ)) in snapshot_buf()
357 void msm_rd_dump_submit(struct msm_rd_state *rd, struct msm_gem_submit *submit, in msm_rd_dump_submit() argument
370 WARN_ON(!mutex_is_locked(&submit->gpu->lock)); in msm_rd_dump_submit()
383 task = pid_task(submit->pid, PIDTYPE_PID); in msm_rd_dump_submit()
387 pid_nr(submit->pid), submit->seqno); in msm_rd_dump_submit()
[all …]
Dmsm_gpu.c261 struct msm_gem_submit *submit, char *comm, char *cmd) in msm_gpu_crashstate_capture() argument
282 if (submit) { in msm_gpu_crashstate_capture()
285 state->bos = kcalloc(submit->nr_bos, in msm_gpu_crashstate_capture()
288 for (i = 0; state->bos && i < submit->nr_bos; i++) { in msm_gpu_crashstate_capture()
289 msm_gpu_crashstate_get_bo(state, submit->bos[i].obj, in msm_gpu_crashstate_capture()
290 submit->bos[i].iova, in msm_gpu_crashstate_capture()
291 should_dump(submit, i)); in msm_gpu_crashstate_capture()
304 struct msm_gem_submit *submit, char *comm, char *cmd) in msm_gpu_crashstate_capture() argument
316 struct msm_gem_submit *submit; in find_submit() local
320 list_for_each_entry(submit, &ring->submits, node) { in find_submit()
[all …]
Dmsm_ringbuffer.c16 struct msm_gem_submit *submit = to_msm_submit(job); in msm_job_run() local
17 struct msm_fence_context *fctx = submit->ring->fctx; in msm_job_run()
18 struct msm_gpu *gpu = submit->gpu; in msm_job_run()
21 submit->hw_fence = msm_fence_alloc(fctx); in msm_job_run()
23 for (i = 0; i < submit->nr_bos; i++) { in msm_job_run()
24 struct drm_gem_object *obj = &submit->bos[i].obj->base; in msm_job_run()
27 msm_gem_unpin_vma_fenced(submit->bos[i].vma, fctx); in msm_job_run()
29 submit->bos[i].flags &= ~(BO_VMA_PINNED | BO_OBJ_PINNED); in msm_job_run()
36 msm_gpu_submit(gpu, submit); in msm_job_run()
40 return dma_fence_get(submit->hw_fence); in msm_job_run()
[all …]
Dmsm_gpu_trace.h34 TP_PROTO(struct msm_gem_submit *submit, u64 ticks),
35 TP_ARGS(submit, ticks),
44 __entry->pid = pid_nr(submit->pid);
45 __entry->id = submit->ident;
46 __entry->ringid = submit->ring->id;
47 __entry->seqno = submit->seqno;
57 TP_PROTO(struct msm_gem_submit *submit, u64 elapsed, u64 clock,
59 TP_ARGS(submit, elapsed, clock, start, end),
71 __entry->pid = pid_nr(submit->pid);
72 __entry->id = submit->ident;
[all …]
Dmsm_gem.h314 static inline void msm_gem_submit_get(struct msm_gem_submit *submit) in msm_gem_submit_get() argument
316 kref_get(&submit->ref); in msm_gem_submit_get()
319 static inline void msm_gem_submit_put(struct msm_gem_submit *submit) in msm_gem_submit_put() argument
321 kref_put(&submit->ref, __msm_gem_submit_destroy); in msm_gem_submit_put()
324 void msm_submit_retire(struct msm_gem_submit *submit);
330 should_dump(struct msm_gem_submit *submit, int idx) in should_dump() argument
333 return rd_full || (submit->bos[idx].flags & MSM_SUBMIT_BO_DUMP); in should_dump()
/Linux-v6.1/crypto/async_tx/
Dasync_raid6_recov.c20 size_t len, struct async_submit_ctl *submit) in async_sum_product() argument
22 struct dma_chan *chan = async_tx_find_channel(submit, DMA_PQ, in async_sum_product()
39 if (submit->flags & ASYNC_TX_FENCE) in async_sum_product()
58 async_tx_submit(chan, tx, submit); in async_sum_product()
70 async_tx_quiesce(&submit->depend_tx); in async_sum_product()
89 struct async_submit_ctl *submit) in async_mult() argument
91 struct dma_chan *chan = async_tx_find_channel(submit, DMA_PQ, in async_mult()
107 if (submit->flags & ASYNC_TX_FENCE) in async_mult()
128 async_tx_submit(chan, tx, submit); in async_mult()
141 async_tx_quiesce(&submit->depend_tx); in async_mult()
[all …]
Dasync_xor.c24 struct async_submit_ctl *submit) in do_async_xor() argument
28 dma_async_tx_callback cb_fn_orig = submit->cb_fn; in do_async_xor()
29 void *cb_param_orig = submit->cb_param; in do_async_xor()
30 enum async_tx_flags flags_orig = submit->flags; in do_async_xor()
40 submit->flags = flags_orig; in do_async_xor()
46 submit->flags &= ~ASYNC_TX_ACK; in do_async_xor()
47 submit->flags |= ASYNC_TX_FENCE; in do_async_xor()
48 submit->cb_fn = NULL; in do_async_xor()
49 submit->cb_param = NULL; in do_async_xor()
51 submit->cb_fn = cb_fn_orig; in do_async_xor()
[all …]
Dasync_pq.c39 struct async_submit_ctl *submit) in do_async_gen_syndrome() argument
43 enum async_tx_flags flags_orig = submit->flags; in do_async_gen_syndrome()
44 dma_async_tx_callback cb_fn_orig = submit->cb_fn; in do_async_gen_syndrome()
45 dma_async_tx_callback cb_param_orig = submit->cb_param; in do_async_gen_syndrome()
52 submit->flags = flags_orig; in do_async_gen_syndrome()
59 submit->flags &= ~ASYNC_TX_ACK; in do_async_gen_syndrome()
60 submit->flags |= ASYNC_TX_FENCE; in do_async_gen_syndrome()
61 submit->cb_fn = NULL; in do_async_gen_syndrome()
62 submit->cb_param = NULL; in do_async_gen_syndrome()
64 submit->cb_fn = cb_fn_orig; in do_async_gen_syndrome()
[all …]
Draid6test.c60 struct async_submit_ctl submit; in raid6_dual_recov() local
71 init_async_submit(&submit, 0, NULL, NULL, NULL, addr_conv); in raid6_dual_recov()
73 disks, bytes, &submit); in raid6_dual_recov()
91 init_async_submit(&submit, ASYNC_TX_XOR_ZERO_DST, NULL, in raid6_dual_recov()
93 tx = async_xor(dest, blocks, 0, count, bytes, &submit); in raid6_dual_recov()
95 init_async_submit(&submit, 0, tx, NULL, NULL, addr_conv); in raid6_dual_recov()
97 disks, bytes, &submit); in raid6_dual_recov()
102 init_async_submit(&submit, 0, NULL, NULL, NULL, addr_conv); in raid6_dual_recov()
104 faila, ptrs, offs, &submit); in raid6_dual_recov()
107 init_async_submit(&submit, 0, NULL, NULL, NULL, addr_conv); in raid6_dual_recov()
[all …]
Dasync_tx.c43 __async_tx_find_channel(struct async_submit_ctl *submit, in __async_tx_find_channel() argument
46 struct dma_async_tx_descriptor *depend_tx = submit->depend_tx; in __async_tx_find_channel()
144 struct async_submit_ctl *submit) in async_tx_submit() argument
146 struct dma_async_tx_descriptor *depend_tx = submit->depend_tx; in async_tx_submit()
148 tx->callback = submit->cb_fn; in async_tx_submit()
149 tx->callback_param = submit->cb_param; in async_tx_submit()
204 if (submit->flags & ASYNC_TX_ACK) in async_tx_submit()
221 async_trigger_callback(struct async_submit_ctl *submit) in async_trigger_callback() argument
226 struct dma_async_tx_descriptor *depend_tx = submit->depend_tx; in async_trigger_callback()
245 async_tx_submit(chan, tx, submit); in async_trigger_callback()
[all …]
Dasync_memcpy.c34 struct async_submit_ctl *submit) in async_memcpy() argument
36 struct dma_chan *chan = async_tx_find_channel(submit, DMA_MEMCPY, in async_memcpy()
48 if (submit->cb_fn) in async_memcpy()
50 if (submit->flags & ASYNC_TX_FENCE) in async_memcpy()
70 async_tx_submit(chan, tx, submit); in async_memcpy()
76 async_tx_quiesce(&submit->depend_tx); in async_memcpy()
86 async_tx_sync_epilog(submit); in async_memcpy()
/Linux-v6.1/include/linux/
Dasync_tx.h103 __async_tx_find_channel(struct async_submit_ctl *submit,
118 async_tx_find_channel(struct async_submit_ctl *submit, in async_tx_find_channel() argument
133 async_tx_sync_epilog(struct async_submit_ctl *submit) in async_tx_sync_epilog() argument
135 if (submit->cb_fn) in async_tx_sync_epilog()
136 submit->cb_fn(submit->cb_param); in async_tx_sync_epilog()
159 struct async_submit_ctl *submit);
163 int src_cnt, size_t len, struct async_submit_ctl *submit);
168 int src_cnt, size_t len, struct async_submit_ctl *submit);
173 struct async_submit_ctl *submit);
179 struct async_submit_ctl *submit);
[all …]
/Linux-v6.1/drivers/dma/ti/
Dcppi41.c119 u16 submit; member
157 [ 0] = { .submit = 32, .complete = 93},
158 [ 1] = { .submit = 34, .complete = 94},
159 [ 2] = { .submit = 36, .complete = 95},
160 [ 3] = { .submit = 38, .complete = 96},
161 [ 4] = { .submit = 40, .complete = 97},
162 [ 5] = { .submit = 42, .complete = 98},
163 [ 6] = { .submit = 44, .complete = 99},
164 [ 7] = { .submit = 46, .complete = 100},
165 [ 8] = { .submit = 48, .complete = 101},
[all …]
/Linux-v6.1/drivers/gpu/drm/lima/
Dlima_gem.c275 static int lima_gem_add_deps(struct drm_file *file, struct lima_submit *submit) in lima_gem_add_deps() argument
279 for (i = 0; i < ARRAY_SIZE(submit->in_sync); i++) { in lima_gem_add_deps()
282 if (!submit->in_sync[i]) in lima_gem_add_deps()
285 err = drm_syncobj_find_fence(file, submit->in_sync[i], in lima_gem_add_deps()
290 err = drm_sched_job_add_dependency(&submit->task->base, fence); in lima_gem_add_deps()
300 int lima_gem_submit(struct drm_file *file, struct lima_submit *submit) in lima_gem_submit() argument
308 struct lima_bo **bos = submit->lbos; in lima_gem_submit()
310 if (submit->out_sync) { in lima_gem_submit()
311 out_sync = drm_syncobj_find(file, submit->out_sync); in lima_gem_submit()
316 for (i = 0; i < submit->nr_bos; i++) { in lima_gem_submit()
[all …]
Dlima_drv.c110 struct lima_submit submit = {0}; in lima_ioctl_gem_submit() local
124 bos = kvcalloc(args->nr_bos, sizeof(*submit.bos) + sizeof(*submit.lbos), GFP_KERNEL); in lima_ioctl_gem_submit()
128 size = args->nr_bos * sizeof(*submit.bos); in lima_ioctl_gem_submit()
156 submit.pipe = args->pipe; in lima_ioctl_gem_submit()
157 submit.bos = bos; in lima_ioctl_gem_submit()
158 submit.lbos = (void *)bos + size; in lima_ioctl_gem_submit()
159 submit.nr_bos = args->nr_bos; in lima_ioctl_gem_submit()
160 submit.task = task; in lima_ioctl_gem_submit()
161 submit.ctx = ctx; in lima_ioctl_gem_submit()
162 submit.flags = args->flags; in lima_ioctl_gem_submit()
[all …]
/Linux-v6.1/fs/iomap/
Ddirect-io.c45 } submit; member
71 dio->submit.poll_bio = bio; in iomap_dio_submit_bio()
167 struct task_struct *waiter = dio->submit.waiter; in iomap_dio_bio_end_io()
168 WRITE_ONCE(dio->submit.waiter, NULL); in iomap_dio_bio_end_io()
256 !bdev_iter_is_aligned(iomap->bdev, dio->submit.iter)) in iomap_dio_bio_iter()
287 orig_count = iov_iter_count(dio->submit.iter); in iomap_dio_bio_iter()
288 iov_iter_truncate(dio->submit.iter, length); in iomap_dio_bio_iter()
290 if (!iov_iter_count(dio->submit.iter)) in iomap_dio_bio_iter()
314 nr_pages = bio_iov_vecs_to_alloc(dio->submit.iter, BIO_MAX_VECS); in iomap_dio_bio_iter()
318 iov_iter_revert(dio->submit.iter, copied); in iomap_dio_bio_iter()
[all …]
/Linux-v6.1/drivers/gpu/drm/msm/adreno/
Da2xx_gpu.c13 static void a2xx_submit(struct msm_gpu *gpu, struct msm_gem_submit *submit) in a2xx_submit() argument
15 struct msm_ringbuffer *ring = submit->ring; in a2xx_submit()
18 for (i = 0; i < submit->nr_cmds; i++) { in a2xx_submit()
19 switch (submit->cmd[i].type) { in a2xx_submit()
25 if (gpu->cur_ctx_seqno == submit->queue->ctx->seqno) in a2xx_submit()
30 OUT_RING(ring, lower_32_bits(submit->cmd[i].iova)); in a2xx_submit()
31 OUT_RING(ring, submit->cmd[i].size); in a2xx_submit()
38 OUT_RING(ring, submit->seqno); in a2xx_submit()
47 OUT_RING(ring, submit->seqno); in a2xx_submit()
479 .submit = a2xx_submit,
Da5xx_gpu.c66 static void a5xx_submit_in_rb(struct msm_gpu *gpu, struct msm_gem_submit *submit) in a5xx_submit_in_rb() argument
68 struct msm_ringbuffer *ring = submit->ring; in a5xx_submit_in_rb()
73 for (i = 0; i < submit->nr_cmds; i++) { in a5xx_submit_in_rb()
74 switch (submit->cmd[i].type) { in a5xx_submit_in_rb()
78 if (gpu->cur_ctx_seqno == submit->queue->ctx->seqno) in a5xx_submit_in_rb()
83 obj = submit->bos[submit->cmd[i].idx].obj; in a5xx_submit_in_rb()
84 dwords = submit->cmd[i].size; in a5xx_submit_in_rb()
120 ring->memptrs->fence = submit->seqno; in a5xx_submit_in_rb()
124 static void a5xx_submit(struct msm_gpu *gpu, struct msm_gem_submit *submit) in a5xx_submit() argument
128 struct msm_ringbuffer *ring = submit->ring; in a5xx_submit()
[all …]
/Linux-v6.1/drivers/gpu/drm/i915/selftests/
Di915_active.c81 struct i915_sw_fence *submit; in __live_active_setup() local
90 submit = heap_fence_create(GFP_KERNEL); in __live_active_setup()
91 if (!submit) { in __live_active_setup()
109 err = i915_sw_fence_await_sw_fence_gfp(&rq->submit, in __live_active_setup()
110 submit, in __live_active_setup()
135 i915_sw_fence_commit(submit); in __live_active_setup()
136 heap_fence_put(submit); in __live_active_setup()
/Linux-v6.1/drivers/gpu/drm/tegra/
Dfirewall.c9 struct tegra_drm_submit_data *submit; member
31 for (i = 0; i < fw->submit->num_used_mappings; i++) { in fw_check_addr_valid()
32 struct tegra_drm_mapping *m = fw->submit->used_mappings[i].mapping; in fw_check_addr_valid()
142 u32 words, struct tegra_drm_submit_data *submit, in tegra_drm_fw_validate() argument
146 .submit = submit, in tegra_drm_fw_validate()

12345678