xref: /aosp_15_r20/external/mesa3d/src/gallium/drivers/panfrost/pan_jm.h (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1 /*
2  * Copyright (C) 2023 Collabora Ltd.
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 (including the next
12  * paragraph) shall be included in all copies or substantial portions of the
13  * Software.
14  *
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21  * SOFTWARE.
22  *
23  */
24 
25 #ifndef __PAN_JM_H__
26 #define __PAN_JM_H__
27 
28 #include "pan_jc.h"
29 
30 struct panfrost_jm_batch {
31    /* Job related fields. */
32    struct {
33       /* Vertex/tiler/compute job chain. */
34       struct pan_jc vtc_jc;
35 
36       /* Fragment job, only one per batch. */
37       mali_ptr frag;
38    } jobs;
39 };
40 
41 #if defined(PAN_ARCH) && PAN_ARCH < 10
42 
43 #include "genxml/gen_macros.h"
44 
45 struct panfrost_batch;
46 struct panfrost_context;
47 struct pan_fb_info;
48 struct pipe_draw_info;
49 struct pipe_grid_info;
50 struct pipe_draw_start_count_bias;
51 
52 static inline int
GENX(jm_init_context)53 GENX(jm_init_context)(struct panfrost_context *ctx)
54 {
55    return 0;
56 }
57 
58 static inline void
GENX(jm_cleanup_context)59 GENX(jm_cleanup_context)(struct panfrost_context *ctx)
60 {
61 }
62 
63 void GENX(jm_init_batch)(struct panfrost_batch *batch);
64 
65 static inline void
GENX(jm_cleanup_batch)66 GENX(jm_cleanup_batch)(struct panfrost_batch *batch)
67 {
68 }
69 
70 int GENX(jm_submit_batch)(struct panfrost_batch *batch);
71 
72 void GENX(jm_preload_fb)(struct panfrost_batch *batch, struct pan_fb_info *fb);
73 void GENX(jm_emit_fragment_job)(struct panfrost_batch *batch,
74                                 const struct pan_fb_info *pfb);
75 
76 void GENX(jm_launch_xfb)(struct panfrost_batch *batch,
77                          const struct pipe_draw_info *info, unsigned count);
78 
79 void GENX(jm_launch_grid)(struct panfrost_batch *batch,
80                           const struct pipe_grid_info *info);
81 
82 void GENX(jm_launch_draw)(struct panfrost_batch *batch,
83                           const struct pipe_draw_info *info,
84                           unsigned drawid_offset,
85                           const struct pipe_draw_start_count_bias *draw,
86                           unsigned vertex_count);
87 void GENX(jm_launch_draw_indirect)(struct panfrost_batch *batch,
88                                    const struct pipe_draw_info *info,
89                                    unsigned drawid_offset,
90                                    const struct pipe_draw_indirect_info *indirect);
91 
92 void GENX(jm_emit_write_timestamp)(struct panfrost_batch *batch,
93                                    struct panfrost_resource *dst,
94                                    unsigned offset);
95 
96 #endif /* PAN_ARCH < 10 */
97 
98 #endif
99