Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mesa
Path: blob/21.2-virgl/src/gallium/drivers/virgl/virgl_screen.h
4570 views
1
/*
2
* Copyright 2014, 2015 Red Hat.
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
* on the rights to use, copy, modify, merge, publish, distribute, sub
8
* license, and/or sell copies of the Software, and to permit persons to whom
9
* the 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 NON-INFRINGEMENT. IN NO EVENT SHALL
18
* THE AUTHOR(S) AND/OR THEIR SUPPLIERS BE LIABLE FOR ANY CLAIM,
19
* DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
20
* OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
21
* USE OR OTHER DEALINGS IN THE SOFTWARE.
22
*/
23
#ifndef VIRGL_H
24
#define VIRGL_H
25
26
#include "pipe/p_screen.h"
27
#include "util/slab.h"
28
#include "util/disk_cache.h"
29
#include "virgl_winsys.h"
30
31
enum virgl_debug_flags {
32
VIRGL_DEBUG_VERBOSE = 1 << 0,
33
VIRGL_DEBUG_TGSI = 1 << 1,
34
VIRGL_DEBUG_NO_EMULATE_BGRA = 1 << 2,
35
VIRGL_DEBUG_NO_BGRA_DEST_SWIZZLE = 1 << 3,
36
VIRGL_DEBUG_SYNC = 1 << 4,
37
VIRGL_DEBUG_XFER = 1 << 5,
38
};
39
40
extern int virgl_debug;
41
42
struct virgl_screen {
43
struct pipe_screen base;
44
45
int refcnt;
46
47
/* place for winsys to stash it's own stuff: */
48
void *winsys_priv;
49
50
struct virgl_winsys *vws;
51
52
struct virgl_drm_caps caps;
53
54
struct slab_parent_pool transfer_pool;
55
56
uint32_t sub_ctx_id;
57
bool tweak_gles_emulate_bgra;
58
bool tweak_gles_apply_bgra_dest_swizzle;
59
int32_t tweak_gles_tf3_value;
60
61
struct disk_cache *disk_cache;
62
};
63
64
65
static inline struct virgl_screen *
66
virgl_screen(struct pipe_screen *pipe)
67
{
68
return (struct virgl_screen *)pipe;
69
}
70
71
bool
72
virgl_has_readback_format(struct pipe_screen *screen, enum virgl_formats fmt);
73
74
/* GL_ARB_map_buffer_alignment requires 64 as the minimum alignment value. In
75
* addition to complying with the extension, a high enough alignment value is
76
* expected by various external GL clients. For example, wined3d doesn't like
77
* maps that don't have a 16 byte alignment.
78
*/
79
#define VIRGL_MAP_BUFFER_ALIGNMENT 64
80
81
#endif
82
83