1 /**************************************************************************
3 * Copyright 2008 Tungsten Graphics, Inc., Cedar Park, Texas.
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:
14 * The above copyright notice and this permission notice (including the
15 * next paragraph) shall be included in all copies or substantial portions
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.
26 **************************************************************************/
30 #include "glapi/glthread.h"
31 #include "util/u_debug.h"
32 #include "util/u_math.h"
33 #include "pipe/p_screen.h"
34 #include "state_tracker/st_public.h"
37 #include "trace/tr_screen.h"
38 #include "trace/tr_texture.h"
41 #include "stw_device.h"
42 #include "stw_winsys.h"
43 #include "stw_pixelformat.h"
46 #include "stw_framebuffer.h"
49 extern _glthread_Mutex OneTimeLock
;
50 extern void FreeAllTSD(void);
54 struct stw_device
*stw_dev
= NULL
;
58 * XXX: Dispatch pipe_screen::flush_front_buffer to our
59 * stw_winsys::flush_front_buffer.
62 stw_flush_frontbuffer(struct pipe_screen
*screen
,
63 struct pipe_surface
*surface
,
64 void *context_private
)
66 HDC hdc
= (HDC
)context_private
;
67 struct stw_framebuffer
*fb
;
69 fb
= stw_framebuffer_from_hdc( hdc
);
71 /* fb can be NULL if window was destroyed already */
77 /* ensure that a random surface was not passed to us */
78 struct pipe_surface
*surface2
;
80 if(!st_get_framebuffer_surface( fb
->stfb
, ST_SURFACE_FRONT_LEFT
, &surface2
))
83 assert(surface2
== surface
);
87 stw_framebuffer_present_locked(hdc
, fb
, ST_SURFACE_FRONT_LEFT
);
92 stw_init(const struct stw_winsys
*stw_winsys
)
94 static struct stw_device stw_dev_storage
;
95 struct pipe_screen
*screen
;
97 debug_printf("%s\n", __FUNCTION__
);
103 stw_dev
= &stw_dev_storage
;
104 memset(stw_dev
, 0, sizeof(*stw_dev
));
107 stw_dev
->memdbg_no
= debug_memory_begin();
110 stw_dev
->stw_winsys
= stw_winsys
;
113 _glthread_INIT_MUTEX(OneTimeLock
);
116 screen
= stw_winsys
->create_screen();
120 if(stw_winsys
->get_adapter_luid
)
121 stw_winsys
->get_adapter_luid(screen
, &stw_dev
->AdapterLuid
);
124 stw_dev
->screen
= trace_screen_create(screen
);
125 stw_dev
->trace_running
= stw_dev
->screen
!= screen
? TRUE
: FALSE
;
127 stw_dev
->screen
= screen
;
130 stw_dev
->screen
->flush_frontbuffer
= &stw_flush_frontbuffer
;
132 pipe_mutex_init( stw_dev
->ctx_mutex
);
133 pipe_mutex_init( stw_dev
->fb_mutex
);
135 stw_dev
->ctx_table
= handle_table_create();
136 if (!stw_dev
->ctx_table
) {
140 stw_pixelformat_init();
151 stw_init_thread(void)
153 return stw_tls_init_thread();
158 stw_cleanup_thread(void)
160 stw_tls_cleanup_thread();
169 debug_printf("%s\n", __FUNCTION__
);
174 pipe_mutex_lock( stw_dev
->ctx_mutex
);
176 /* Ensure all contexts are destroyed */
177 i
= handle_table_get_first_handle(stw_dev
->ctx_table
);
180 i
= handle_table_get_next_handle(stw_dev
->ctx_table
, i
);
182 handle_table_destroy(stw_dev
->ctx_table
);
184 pipe_mutex_unlock( stw_dev
->ctx_mutex
);
186 stw_framebuffer_cleanup();
188 pipe_mutex_destroy( stw_dev
->fb_mutex
);
189 pipe_mutex_destroy( stw_dev
->ctx_mutex
);
191 stw_dev
->screen
->destroy(stw_dev
->screen
);
194 _glthread_DESTROY_MUTEX(OneTimeLock
);
199 debug_memory_end(stw_dev
->memdbg_no
);
209 stw_lookup_context_locked( DHGLRC dhglrc
)
217 return (struct stw_context
*) handle_table_get(stw_dev
->ctx_table
, dhglrc
);
231 size
= MIN2(nProcs
* sizeof *pProcs
, sizeof stw_dev
->callbacks
);
232 memcpy(&stw_dev
->callbacks
, pProcs
, size
);
242 /* TODO: get the expected version from the winsys */
243 return ulVersion
== 1;