1 #include "pipe/p_screen.h"
2 #include "pipe/p_inlines.h"
3 #include "util/u_simple_screen.h"
5 #include "nv04_context.h"
6 #include "nv04_screen.h"
9 nv04_screen_get_name(struct pipe_screen
*screen
)
11 struct nv04_screen
*nv04screen
= nv04_screen(screen
);
12 struct nouveau_device
*dev
= nv04screen
->nvws
->channel
->device
;
13 static char buffer
[128];
15 snprintf(buffer
, sizeof(buffer
), "NV%02X", dev
->chipset
);
20 nv04_screen_get_vendor(struct pipe_screen
*screen
)
26 nv04_screen_get_param(struct pipe_screen
*screen
, int param
)
29 case PIPE_CAP_MAX_TEXTURE_IMAGE_UNITS
:
31 case PIPE_CAP_NPOT_TEXTURES
:
33 case PIPE_CAP_TWO_SIDED_STENCIL
:
39 case PIPE_CAP_ANISOTROPIC_FILTER
:
41 case PIPE_CAP_POINT_SPRITE
:
43 case PIPE_CAP_MAX_RENDER_TARGETS
:
45 case PIPE_CAP_OCCLUSION_QUERY
:
47 case PIPE_CAP_TEXTURE_SHADOW_MAP
:
49 case PIPE_CAP_MAX_TEXTURE_2D_LEVELS
:
51 case PIPE_CAP_MAX_TEXTURE_3D_LEVELS
:
53 case PIPE_CAP_MAX_TEXTURE_CUBE_LEVELS
:
55 case PIPE_CAP_MAX_VERTEX_TEXTURE_UNITS
:
57 case PIPE_CAP_TEXTURE_MIRROR_CLAMP
:
59 case PIPE_CAP_TEXTURE_MIRROR_REPEAT
:
61 case NOUVEAU_CAP_HW_VTXBUF
:
62 case NOUVEAU_CAP_HW_IDXBUF
:
65 NOUVEAU_ERR("Unknown PIPE_CAP %d\n", param
);
71 nv04_screen_get_paramf(struct pipe_screen
*screen
, int param
)
74 case PIPE_CAP_MAX_LINE_WIDTH
:
75 case PIPE_CAP_MAX_LINE_WIDTH_AA
:
77 case PIPE_CAP_MAX_POINT_WIDTH
:
78 case PIPE_CAP_MAX_POINT_WIDTH_AA
:
80 case PIPE_CAP_MAX_TEXTURE_ANISOTROPY
:
82 case PIPE_CAP_MAX_TEXTURE_LOD_BIAS
:
85 NOUVEAU_ERR("Unknown PIPE_CAP %d\n", param
);
91 nv04_screen_is_format_supported(struct pipe_screen
*screen
,
92 enum pipe_format format
,
93 enum pipe_texture_target target
,
94 unsigned tex_usage
, unsigned geom_flags
)
96 if (tex_usage
& PIPE_TEXTURE_USAGE_RENDER_TARGET
) {
98 case PIPE_FORMAT_A8R8G8B8_UNORM
:
99 case PIPE_FORMAT_R5G6B5_UNORM
:
100 case PIPE_FORMAT_Z16_UNORM
:
107 case PIPE_FORMAT_A8R8G8B8_UNORM
:
108 case PIPE_FORMAT_X8R8G8B8_UNORM
:
109 case PIPE_FORMAT_A1R5G5B5_UNORM
:
110 case PIPE_FORMAT_R5G6B5_UNORM
:
111 case PIPE_FORMAT_L8_UNORM
:
112 case PIPE_FORMAT_A8_UNORM
:
123 nv04_surface_map(struct pipe_screen
*screen
, struct pipe_surface
*surface
,
127 struct nv04_miptree
*nv04mt
= (struct nv04_miptree
*)surface
->texture
;
129 map
= pipe_buffer_map(screen
, nv04mt
->buffer
, flags
);
133 return map
+ surface
->offset
;
137 nv04_surface_unmap(struct pipe_screen
*screen
, struct pipe_surface
*surface
)
139 struct nv04_miptree
*nv04mt
= (struct nv04_miptree
*)surface
->texture
;
141 pipe_buffer_unmap(screen
, nv04mt
->buffer
);
145 nv04_screen_destroy(struct pipe_screen
*pscreen
)
147 struct nv04_screen
*screen
= nv04_screen(pscreen
);
148 struct nouveau_winsys
*nvws
= screen
->nvws
;
150 nvws
->notifier_free(&screen
->sync
);
151 nvws
->grobj_free(&screen
->fahrenheit
);
152 nv04_surface_2d_takedown(&screen
->eng2d
);
157 static struct pipe_buffer
*
158 nv04_surface_buffer(struct pipe_surface
*surf
)
160 struct nv04_miptree
*mt
= (struct nv04_miptree
*)surf
->texture
;
166 nv04_screen_create(struct pipe_winsys
*ws
, struct nouveau_winsys
*nvws
)
168 struct nv04_screen
*screen
= CALLOC_STRUCT(nv04_screen
);
169 unsigned fahrenheit_class
= 0, sub3d_class
= 0;
170 unsigned chipset
= nvws
->channel
->device
->chipset
;
178 fahrenheit_class
= 0;
180 } else if (chipset
>=0x10) {
181 fahrenheit_class
= NV10_DX5_TEXTURED_TRIANGLE
;
182 sub3d_class
= NV10_CONTEXT_SURFACES_3D
;
184 fahrenheit_class
=NV04_DX5_TEXTURED_TRIANGLE
;
185 sub3d_class
= NV04_CONTEXT_SURFACES_3D
;
188 if (!fahrenheit_class
) {
189 NOUVEAU_ERR("Unknown nv04 chipset: nv%02x\n", chipset
);
193 /* 2D engine setup */
194 screen
->eng2d
= nv04_surface_2d_init(nvws
);
195 screen
->eng2d
->buf
= nv04_surface_buffer
;
198 ret
= nvws
->grobj_alloc(nvws
, fahrenheit_class
, &screen
->fahrenheit
);
200 NOUVEAU_ERR("Error creating 3D object: %d\n", ret
);
204 /* 3D surface object */
205 ret
= nvws
->grobj_alloc(nvws
, sub3d_class
, &screen
->context_surfaces_3d
);
207 NOUVEAU_ERR("Error creating 3D surface object: %d\n", ret
);
211 /* Notifier for sync purposes */
212 ret
= nvws
->notifier_alloc(nvws
, 1, &screen
->sync
);
214 NOUVEAU_ERR("Error creating notifier object: %d\n", ret
);
215 nv04_screen_destroy(&screen
->pipe
);
219 screen
->pipe
.winsys
= ws
;
220 screen
->pipe
.destroy
= nv04_screen_destroy
;
222 screen
->pipe
.get_name
= nv04_screen_get_name
;
223 screen
->pipe
.get_vendor
= nv04_screen_get_vendor
;
224 screen
->pipe
.get_param
= nv04_screen_get_param
;
225 screen
->pipe
.get_paramf
= nv04_screen_get_paramf
;
227 screen
->pipe
.is_format_supported
= nv04_screen_is_format_supported
;
229 screen
->pipe
.surface_map
= nv04_surface_map
;
230 screen
->pipe
.surface_unmap
= nv04_surface_unmap
;
232 nv04_screen_init_miptree_functions(&screen
->pipe
);
233 u_simple_screen_init(&screen
->pipe
);
235 return &screen
->pipe
;