xref: /aosp_15_r20/external/mesa3d/src/gallium/drivers/freedreno/a4xx/fd4_rasterizer.c (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1 /*
2  * Copyright © 2014 Rob Clark <[email protected]>
3  * SPDX-License-Identifier: MIT
4  *
5  * Authors:
6  *    Rob Clark <[email protected]>
7  */
8 
9 #include "pipe/p_state.h"
10 #include "util/u_memory.h"
11 #include "util/u_string.h"
12 
13 #include "fd4_context.h"
14 #include "fd4_format.h"
15 #include "fd4_rasterizer.h"
16 
17 void *
fd4_rasterizer_state_create(struct pipe_context * pctx,const struct pipe_rasterizer_state * cso)18 fd4_rasterizer_state_create(struct pipe_context *pctx,
19                             const struct pipe_rasterizer_state *cso)
20 {
21    struct fd4_rasterizer_stateobj *so;
22    float psize_min, psize_max;
23 
24    so = CALLOC_STRUCT(fd4_rasterizer_stateobj);
25    if (!so)
26       return NULL;
27 
28    so->base = *cso;
29 
30    if (cso->point_size_per_vertex) {
31       psize_min = util_get_min_point_size(cso);
32       psize_max = 4092;
33    } else {
34       /* Force the point size to be as if the vertex output was disabled. */
35       psize_min = cso->point_size;
36       psize_max = cso->point_size;
37    }
38 
39    /*
40            if (cso->line_stipple_enable) {
41                    ??? TODO line stipple
42            }
43            TODO cso->half_pixel_center
44            if (cso->multisample)
45                    TODO
46    */
47    so->gras_cl_clip_cntl = 0x80000; /* ??? */
48    so->gras_su_point_minmax = A4XX_GRAS_SU_POINT_MINMAX_MIN(psize_min) |
49                               A4XX_GRAS_SU_POINT_MINMAX_MAX(psize_max);
50    so->gras_su_point_size = A4XX_GRAS_SU_POINT_SIZE(cso->point_size);
51    so->gras_su_poly_offset_scale =
52       A4XX_GRAS_SU_POLY_OFFSET_SCALE(cso->offset_scale);
53    so->gras_su_poly_offset_offset =
54       A4XX_GRAS_SU_POLY_OFFSET_OFFSET(cso->offset_units * 2.0f);
55    so->gras_su_poly_offset_clamp =
56       A4XX_GRAS_SU_POLY_OFFSET_CLAMP(cso->offset_clamp);
57 
58    so->gras_su_mode_control =
59       A4XX_GRAS_SU_MODE_CONTROL_LINEHALFWIDTH(cso->line_width / 2.0f);
60    so->pc_prim_vtx_cntl2 = A4XX_PC_PRIM_VTX_CNTL2_POLYMODE_FRONT_PTYPE(
61                               fd_polygon_mode(cso->fill_front)) |
62                            A4XX_PC_PRIM_VTX_CNTL2_POLYMODE_BACK_PTYPE(
63                               fd_polygon_mode(cso->fill_back));
64 
65    if (cso->fill_front != PIPE_POLYGON_MODE_FILL ||
66        cso->fill_back != PIPE_POLYGON_MODE_FILL)
67       so->pc_prim_vtx_cntl2 |= A4XX_PC_PRIM_VTX_CNTL2_POLYMODE_ENABLE;
68 
69    if (cso->cull_face & PIPE_FACE_FRONT)
70       so->gras_su_mode_control |= A4XX_GRAS_SU_MODE_CONTROL_CULL_FRONT;
71    if (cso->cull_face & PIPE_FACE_BACK)
72       so->gras_su_mode_control |= A4XX_GRAS_SU_MODE_CONTROL_CULL_BACK;
73    if (!cso->front_ccw)
74       so->gras_su_mode_control |= A4XX_GRAS_SU_MODE_CONTROL_FRONT_CW;
75    if (!cso->flatshade_first)
76       so->pc_prim_vtx_cntl |= A4XX_PC_PRIM_VTX_CNTL_PROVOKING_VTX_LAST;
77 
78    if (cso->offset_tri)
79       so->gras_su_mode_control |= A4XX_GRAS_SU_MODE_CONTROL_POLY_OFFSET;
80 
81    if (!cso->depth_clip_near)
82       so->gras_cl_clip_cntl |= A4XX_GRAS_CL_CLIP_CNTL_ZNEAR_CLIP_DISABLE |
83                                A4XX_GRAS_CL_CLIP_CNTL_ZFAR_CLIP_DISABLE;
84    if (cso->clip_halfz)
85       so->gras_cl_clip_cntl |= A4XX_GRAS_CL_CLIP_CNTL_ZERO_GB_SCALE_Z;
86 
87    return so;
88 }
89