blob: 12b93468da2eea73f0a6a2bb9541a9c0d5612abb [file] [log] [blame]
Brian Paule0542512015-08-13 11:00:58 -07001 /**********************************************************
Jakob Bornecrantz31926332009-11-16 19:56:18 +01002 * Copyright 2008-2009 VMware, Inc. All rights reserved.
3 *
4 * Permission is hereby granted, free of charge, to any person
5 * obtaining a copy of this software and associated documentation
6 * files (the "Software"), to deal in the Software without
7 * restriction, including without limitation the rights to use, copy,
8 * modify, merge, publish, distribute, sublicense, and/or sell copies
9 * of the Software, and to permit persons to whom the Software is
10 * furnished to do so, subject to the following conditions:
11 *
12 * The above copyright notice and this permission notice shall be
13 * included in all copies or substantial portions of the Software.
14 *
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
16 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
17 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
18 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
19 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
20 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
21 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22 * SOFTWARE.
23 *
24 **********************************************************/
25
26#ifndef SVGA_SCREEN_H
27#define SVGA_SCREEN_H
28
29
30#include "pipe/p_screen.h"
José Fonseca2aaca1d2010-02-02 15:18:01 +000031#include "os/os_thread.h"
Jakob Bornecrantz31926332009-11-16 19:56:18 +010032
Jakob Bornecrantz31926332009-11-16 19:56:18 +010033#include "svga_screen_cache.h"
34
35
36struct svga_winsys_screen;
37struct svga_winsys_context;
38struct SVGACmdMemory;
39
Jakob Bornecrantz31926332009-11-16 19:56:18 +010040/**
41 * Subclass of pipe_screen
42 */
43struct svga_screen
44{
45 struct pipe_screen screen;
46 struct svga_winsys_screen *sws;
47
José Fonseca83082722011-02-23 18:30:27 +000048 SVGA3dHardwareVersion hw_version;
49
Brian Paulccd6bf82013-12-09 10:46:56 -080050 /** Device caps */
Brian Paule0542512015-08-13 11:00:58 -070051 boolean haveProvokingVertex;
Brian Paulccd6bf82013-12-09 10:46:56 -080052 boolean haveLineStipple, haveLineSmooth;
53 float maxLineWidth, maxLineWidthAA;
José Fonseca97733702012-02-27 11:12:12 +000054 float maxPointSize;
Brian Paul34ce1a82013-11-07 17:28:33 -070055 unsigned max_color_buffers;
Brian Paule0542512015-08-13 11:00:58 -070056 unsigned max_const_buffers;
57 unsigned ms_samples;
José Fonseca97733702012-02-27 11:12:12 +000058
Jakob Bornecrantz31926332009-11-16 19:56:18 +010059 struct {
60 boolean force_level_surface_view;
61 boolean force_surface_view;
62 boolean no_surface_view;
63 boolean force_sampler_view;
64 boolean no_sampler_view;
Brian Paul4f74b372016-08-31 14:49:41 -060065 boolean no_cache_index_buffers;
Jakob Bornecrantz31926332009-11-16 19:56:18 +010066 } debug;
67
Jakob Bornecrantz31926332009-11-16 19:56:18 +010068 unsigned texture_timestamp;
Timothy Arceri2efddc62017-03-05 12:32:01 +110069 mtx_t tex_mutex;
José Fonsecab8459092010-05-02 23:54:42 +010070
Timothy Arceri2efddc62017-03-05 12:32:01 +110071 mtx_t swc_mutex; /* Used for buffer uploads */
José Fonsecab8459092010-05-02 23:54:42 +010072
Jakob Bornecrantz4e0ae3e2011-04-07 18:46:09 +010073 /* which formats to translate depth formats into */
74 struct {
75 enum SVGA3dSurfaceFormat z16;
Brian Paule0542512015-08-13 11:00:58 -070076
Jakob Bornecrantz4e0ae3e2011-04-07 18:46:09 +010077 /* note gallium order */
78 enum SVGA3dSurfaceFormat x8z24;
79 enum SVGA3dSurfaceFormat s8z24;
80 } depth;
81
Jakob Bornecrantz31926332009-11-16 19:56:18 +010082 struct svga_host_surface_cache cache;
Brian Paulac114c62013-04-03 10:23:57 -060083
Neha Bhende9bc7e312015-10-09 16:10:16 -060084 /** HUD counters */
85 struct {
86 /** Memory used by all resources (buffers and surfaces) */
87 uint64_t total_resource_bytes;
88 uint64_t num_resources;
Brian Paule3f5b8a2017-06-16 16:36:43 -060089 uint64_t num_failed_allocations;
Neha Bhende9bc7e312015-10-09 16:10:16 -060090 } hud;
Jakob Bornecrantz31926332009-11-16 19:56:18 +010091};
92
93#ifndef DEBUG
94/** cast wrapper */
Ilia Mirkina2a1a582015-07-20 19:58:43 -040095static inline struct svga_screen *
Jakob Bornecrantz31926332009-11-16 19:56:18 +010096svga_screen(struct pipe_screen *pscreen)
97{
98 return (struct svga_screen *) pscreen;
99}
100#else
101struct svga_screen *
102svga_screen(struct pipe_screen *screen);
103#endif
104
Jakob Bornecrantz31926332009-11-16 19:56:18 +0100105#endif /* SVGA_SCREEN_H */