xref: /aosp_15_r20/external/libdrm/radeon/radeon_cs.c (revision 7688df22e49036ff52a766b7101da3a49edadb8c)
1*7688df22SAndroid Build Coastguard Worker #include "libdrm_macros.h"
2*7688df22SAndroid Build Coastguard Worker #include <stdio.h>
3*7688df22SAndroid Build Coastguard Worker #include "radeon_cs.h"
4*7688df22SAndroid Build Coastguard Worker #include "radeon_cs_int.h"
5*7688df22SAndroid Build Coastguard Worker 
6*7688df22SAndroid Build Coastguard Worker drm_public struct radeon_cs *
radeon_cs_create(struct radeon_cs_manager * csm,uint32_t ndw)7*7688df22SAndroid Build Coastguard Worker radeon_cs_create(struct radeon_cs_manager *csm, uint32_t ndw)
8*7688df22SAndroid Build Coastguard Worker {
9*7688df22SAndroid Build Coastguard Worker     struct radeon_cs_int *csi = csm->funcs->cs_create(csm, ndw);
10*7688df22SAndroid Build Coastguard Worker     return (struct radeon_cs *)csi;
11*7688df22SAndroid Build Coastguard Worker }
12*7688df22SAndroid Build Coastguard Worker 
13*7688df22SAndroid Build Coastguard Worker drm_public int
radeon_cs_write_reloc(struct radeon_cs * cs,struct radeon_bo * bo,uint32_t read_domain,uint32_t write_domain,uint32_t flags)14*7688df22SAndroid Build Coastguard Worker radeon_cs_write_reloc(struct radeon_cs *cs, struct radeon_bo *bo,
15*7688df22SAndroid Build Coastguard Worker                       uint32_t read_domain, uint32_t write_domain,
16*7688df22SAndroid Build Coastguard Worker                       uint32_t flags)
17*7688df22SAndroid Build Coastguard Worker {
18*7688df22SAndroid Build Coastguard Worker     struct radeon_cs_int *csi = (struct radeon_cs_int *)cs;
19*7688df22SAndroid Build Coastguard Worker 
20*7688df22SAndroid Build Coastguard Worker     return csi->csm->funcs->cs_write_reloc(csi,
21*7688df22SAndroid Build Coastguard Worker                                            bo,
22*7688df22SAndroid Build Coastguard Worker                                            read_domain,
23*7688df22SAndroid Build Coastguard Worker                                            write_domain,
24*7688df22SAndroid Build Coastguard Worker                                            flags);
25*7688df22SAndroid Build Coastguard Worker }
26*7688df22SAndroid Build Coastguard Worker 
27*7688df22SAndroid Build Coastguard Worker drm_public int
radeon_cs_begin(struct radeon_cs * cs,uint32_t ndw,const char * file,const char * func,int line)28*7688df22SAndroid Build Coastguard Worker radeon_cs_begin(struct radeon_cs *cs, uint32_t ndw,
29*7688df22SAndroid Build Coastguard Worker                 const char *file, const char *func, int line)
30*7688df22SAndroid Build Coastguard Worker {
31*7688df22SAndroid Build Coastguard Worker     struct radeon_cs_int *csi = (struct radeon_cs_int *)cs;
32*7688df22SAndroid Build Coastguard Worker     return csi->csm->funcs->cs_begin(csi, ndw, file, func, line);
33*7688df22SAndroid Build Coastguard Worker }
34*7688df22SAndroid Build Coastguard Worker 
35*7688df22SAndroid Build Coastguard Worker drm_public int
radeon_cs_end(struct radeon_cs * cs,const char * file,const char * func,int line)36*7688df22SAndroid Build Coastguard Worker radeon_cs_end(struct radeon_cs *cs,
37*7688df22SAndroid Build Coastguard Worker               const char *file, const char *func, int line)
38*7688df22SAndroid Build Coastguard Worker {
39*7688df22SAndroid Build Coastguard Worker     struct radeon_cs_int *csi = (struct radeon_cs_int *)cs;
40*7688df22SAndroid Build Coastguard Worker     return csi->csm->funcs->cs_end(csi, file, func, line);
41*7688df22SAndroid Build Coastguard Worker }
42*7688df22SAndroid Build Coastguard Worker 
radeon_cs_emit(struct radeon_cs * cs)43*7688df22SAndroid Build Coastguard Worker drm_public int radeon_cs_emit(struct radeon_cs *cs)
44*7688df22SAndroid Build Coastguard Worker {
45*7688df22SAndroid Build Coastguard Worker     struct radeon_cs_int *csi = (struct radeon_cs_int *)cs;
46*7688df22SAndroid Build Coastguard Worker     return csi->csm->funcs->cs_emit(csi);
47*7688df22SAndroid Build Coastguard Worker }
48*7688df22SAndroid Build Coastguard Worker 
radeon_cs_destroy(struct radeon_cs * cs)49*7688df22SAndroid Build Coastguard Worker drm_public int radeon_cs_destroy(struct radeon_cs *cs)
50*7688df22SAndroid Build Coastguard Worker {
51*7688df22SAndroid Build Coastguard Worker     struct radeon_cs_int *csi = (struct radeon_cs_int *)cs;
52*7688df22SAndroid Build Coastguard Worker     return csi->csm->funcs->cs_destroy(csi);
53*7688df22SAndroid Build Coastguard Worker }
54*7688df22SAndroid Build Coastguard Worker 
radeon_cs_erase(struct radeon_cs * cs)55*7688df22SAndroid Build Coastguard Worker drm_public int radeon_cs_erase(struct radeon_cs *cs)
56*7688df22SAndroid Build Coastguard Worker {
57*7688df22SAndroid Build Coastguard Worker     struct radeon_cs_int *csi = (struct radeon_cs_int *)cs;
58*7688df22SAndroid Build Coastguard Worker     return csi->csm->funcs->cs_erase(csi);
59*7688df22SAndroid Build Coastguard Worker }
60*7688df22SAndroid Build Coastguard Worker 
radeon_cs_need_flush(struct radeon_cs * cs)61*7688df22SAndroid Build Coastguard Worker drm_public int radeon_cs_need_flush(struct radeon_cs *cs)
62*7688df22SAndroid Build Coastguard Worker {
63*7688df22SAndroid Build Coastguard Worker     struct radeon_cs_int *csi = (struct radeon_cs_int *)cs;
64*7688df22SAndroid Build Coastguard Worker     return csi->csm->funcs->cs_need_flush(csi);
65*7688df22SAndroid Build Coastguard Worker }
66*7688df22SAndroid Build Coastguard Worker 
radeon_cs_print(struct radeon_cs * cs,FILE * file)67*7688df22SAndroid Build Coastguard Worker drm_public void radeon_cs_print(struct radeon_cs *cs, FILE *file)
68*7688df22SAndroid Build Coastguard Worker {
69*7688df22SAndroid Build Coastguard Worker     struct radeon_cs_int *csi = (struct radeon_cs_int *)cs;
70*7688df22SAndroid Build Coastguard Worker     csi->csm->funcs->cs_print(csi, file);
71*7688df22SAndroid Build Coastguard Worker }
72*7688df22SAndroid Build Coastguard Worker 
73*7688df22SAndroid Build Coastguard Worker drm_public void
radeon_cs_set_limit(struct radeon_cs * cs,uint32_t domain,uint32_t limit)74*7688df22SAndroid Build Coastguard Worker radeon_cs_set_limit(struct radeon_cs *cs, uint32_t domain, uint32_t limit)
75*7688df22SAndroid Build Coastguard Worker {
76*7688df22SAndroid Build Coastguard Worker     struct radeon_cs_int *csi = (struct radeon_cs_int *)cs;
77*7688df22SAndroid Build Coastguard Worker     if (domain == RADEON_GEM_DOMAIN_VRAM)
78*7688df22SAndroid Build Coastguard Worker         csi->csm->vram_limit = limit;
79*7688df22SAndroid Build Coastguard Worker     else
80*7688df22SAndroid Build Coastguard Worker         csi->csm->gart_limit = limit;
81*7688df22SAndroid Build Coastguard Worker }
82*7688df22SAndroid Build Coastguard Worker 
radeon_cs_space_set_flush(struct radeon_cs * cs,void (* fn)(void *),void * data)83*7688df22SAndroid Build Coastguard Worker drm_public void radeon_cs_space_set_flush(struct radeon_cs *cs,
84*7688df22SAndroid Build Coastguard Worker                                           void (*fn)(void *), void *data)
85*7688df22SAndroid Build Coastguard Worker {
86*7688df22SAndroid Build Coastguard Worker     struct radeon_cs_int *csi = (struct radeon_cs_int *)cs;
87*7688df22SAndroid Build Coastguard Worker     csi->space_flush_fn = fn;
88*7688df22SAndroid Build Coastguard Worker     csi->space_flush_data = data;
89*7688df22SAndroid Build Coastguard Worker }
90*7688df22SAndroid Build Coastguard Worker 
radeon_cs_get_id(struct radeon_cs * cs)91*7688df22SAndroid Build Coastguard Worker drm_public uint32_t radeon_cs_get_id(struct radeon_cs *cs)
92*7688df22SAndroid Build Coastguard Worker {
93*7688df22SAndroid Build Coastguard Worker     struct radeon_cs_int *csi = (struct radeon_cs_int *)cs;
94*7688df22SAndroid Build Coastguard Worker     return csi->id;
95*7688df22SAndroid Build Coastguard Worker }
96