Details | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
3770 | Serge | 1 | /************************************************************************** |
2 | * |
||
3 | * Copyright 2007-2009 VMware, Inc. |
||
4 | * All Rights Reserved. |
||
5 | * |
||
6 | * Permission is hereby granted, free of charge, to any person obtaining a |
||
7 | * copy of this software and associated documentation files (the |
||
8 | * "Software"), to deal in the Software without restriction, including |
||
9 | * without limitation the rights to use, copy, modify, merge, publish, |
||
10 | * distribute, sub license, and/or sell copies of the Software, and to |
||
11 | * permit persons to whom the Software is furnished to do so, subject to |
||
12 | * the following conditions: |
||
13 | * |
||
14 | * The above copyright notice and this permission notice (including the |
||
15 | * next paragraph) shall be included in all copies or substantial portions |
||
16 | * of the Software. |
||
17 | * |
||
18 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
||
19 | * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
||
20 | * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. |
||
21 | * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR |
||
22 | * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
||
23 | * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
||
24 | * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
||
25 | * |
||
26 | **************************************************************************/ |
||
27 | |||
28 | /** |
||
29 | * @file |
||
30 | * Software rasterizer winsys. |
||
31 | */ |
||
32 | |||
33 | |||
34 | #ifndef SW_WINSYS_H |
||
35 | #define SW_WINSYS_H |
||
36 | |||
37 | |||
38 | #include "pipe/p_compiler.h" /* for boolean */ |
||
39 | #include "pipe/p_format.h" |
||
40 | |||
41 | |||
42 | #ifdef __cplusplus |
||
43 | extern "C" { |
||
44 | #endif |
||
45 | |||
46 | |||
47 | struct winsys_handle; |
||
48 | struct pipe_screen; |
||
49 | struct pipe_context; |
||
50 | struct pipe_resource; |
||
51 | |||
52 | |||
53 | /** |
||
54 | * Opaque pointer. |
||
55 | */ |
||
56 | struct sw_displaytarget; |
||
57 | |||
58 | |||
59 | /** |
||
60 | * This is the interface that sw expects any window system |
||
61 | * hosting it to implement. |
||
62 | * |
||
63 | * sw is for the most part a self sufficient driver. The only thing it |
||
64 | * does not know is how to display a surface. |
||
65 | */ |
||
66 | struct sw_winsys |
||
67 | { |
||
68 | void |
||
69 | (*destroy)( struct sw_winsys *ws ); |
||
70 | |||
71 | boolean |
||
72 | (*is_displaytarget_format_supported)( struct sw_winsys *ws, |
||
73 | unsigned tex_usage, |
||
74 | enum pipe_format format ); |
||
75 | |||
76 | /** |
||
77 | * Allocate storage for a render target. |
||
78 | * |
||
79 | * Often surfaces which are meant to be blitted to the front screen (i.e., |
||
80 | * display targets) must be allocated with special characteristics, memory |
||
81 | * pools, or obtained directly from the windowing system. |
||
82 | * |
||
83 | * This callback is invoked by the pipe_screen when creating a texture marked |
||
84 | * with the PIPE_BIND_DISPLAY_TARGET flag to get the underlying |
||
85 | * storage. |
||
86 | */ |
||
87 | struct sw_displaytarget * |
||
88 | (*displaytarget_create)( struct sw_winsys *ws, |
||
89 | unsigned tex_usage, |
||
90 | enum pipe_format format, |
||
91 | unsigned width, unsigned height, |
||
92 | unsigned alignment, |
||
93 | unsigned *stride ); |
||
94 | |||
95 | /** |
||
96 | * Used to implement texture_from_handle. |
||
97 | */ |
||
98 | struct sw_displaytarget * |
||
99 | (*displaytarget_from_handle)( struct sw_winsys *ws, |
||
100 | const struct pipe_resource *templat, |
||
101 | struct winsys_handle *whandle, |
||
102 | unsigned *stride ); |
||
103 | |||
104 | /** |
||
105 | * Used to implement texture_get_handle. |
||
106 | */ |
||
107 | boolean |
||
108 | (*displaytarget_get_handle)( struct sw_winsys *ws, |
||
109 | struct sw_displaytarget *dt, |
||
110 | struct winsys_handle *whandle ); |
||
111 | |||
112 | /** |
||
113 | * \param flags bitmask of PIPE_TRANSFER_x flags |
||
114 | */ |
||
115 | void * |
||
116 | (*displaytarget_map)( struct sw_winsys *ws, |
||
117 | struct sw_displaytarget *dt, |
||
118 | unsigned flags ); |
||
119 | |||
120 | void |
||
121 | (*displaytarget_unmap)( struct sw_winsys *ws, |
||
122 | struct sw_displaytarget *dt ); |
||
123 | |||
124 | /** |
||
125 | * @sa pipe_screen:flush_frontbuffer. |
||
126 | * |
||
127 | * This call will likely become asynchronous eventually. |
||
128 | */ |
||
129 | void |
||
130 | (*displaytarget_display)( struct sw_winsys *ws, |
||
131 | struct sw_displaytarget *dt, |
||
132 | void *context_private ); |
||
133 | |||
134 | void |
||
135 | (*displaytarget_destroy)( struct sw_winsys *ws, |
||
136 | struct sw_displaytarget *dt ); |
||
137 | }; |
||
138 | |||
139 | |||
140 | |||
141 | #ifdef __cplusplus |
||
142 | } |
||
143 | #endif |
||
144 | |||
145 | #endif /* SW_WINSYS_H */ |