1 /**********************************************************
2 * Copyright 2009 VMware, Inc. All rights reserved.
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:
12 * The above copyright notice and this permission notice shall be
13 * included in all copies or substantial portions of the Software.
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
24 **********************************************************/
28 * Contains the init code for the VMware Xorg driver.
30 * @author Jakob Bornecrantz <jakob@vmware.com>
34 #include "vmw_driver.h"
35 #include <pipe/p_context.h>
37 #include "cursorstr.h"
39 void vmw_winsys_screen_set_throttling(struct pipe_screen
*screen
,
40 uint32_t throttle_us
);
43 /* modified version of crtc functions */
44 xf86CrtcFuncsRec vmw_screen_crtc_funcs
;
47 vmw_screen_cursor_load_argb(xf86CrtcPtr crtc
, CARD32
*image
)
49 struct vmw_customizer
*vmw
=
50 vmw_customizer(xorg_customizer(crtc
->scrn
));
51 xf86CrtcConfigPtr config
= XF86_CRTC_CONFIG_PTR(crtc
->scrn
);
52 xf86CrtcFuncsPtr funcs
= vmw
->cursor_priv
;
53 CursorPtr c
= config
->cursor
;
55 /* Run the ioctl before uploading the image */
56 vmw_ioctl_cursor_bypass(vmw
, c
->bits
->xhot
, c
->bits
->yhot
);
58 funcs
->load_cursor_argb(crtc
, image
);
62 vmw_screen_cursor_init(struct vmw_customizer
*vmw
)
64 ScrnInfoPtr pScrn
= vmw
->pScrn
;
65 xf86CrtcConfigPtr config
= XF86_CRTC_CONFIG_PTR(pScrn
);
68 /* XXX assume that all crtc's have the same function struct */
70 /* Save old struct need to call the old functions as well */
71 vmw
->cursor_priv
= (void*)(config
->crtc
[0]->funcs
);
72 memcpy(&vmw_screen_crtc_funcs
, vmw
->cursor_priv
, sizeof(xf86CrtcFuncsRec
));
73 vmw_screen_crtc_funcs
.load_cursor_argb
= vmw_screen_cursor_load_argb
;
75 for (i
= 0; i
< config
->num_crtc
; i
++)
76 config
->crtc
[i
]->funcs
= &vmw_screen_crtc_funcs
;
80 vmw_screen_cursor_close(struct vmw_customizer
*vmw
)
82 xf86CrtcConfigPtr config
= XF86_CRTC_CONFIG_PTR(vmw
->pScrn
);
85 vmw_ioctl_cursor_bypass(vmw
, 0, 0);
87 for (i
= 0; i
< config
->num_crtc
; i
++)
88 config
->crtc
[i
]->funcs
= vmw
->cursor_priv
;
92 vmw_context_throttle(CustomizerPtr cust
,
93 struct pipe_context
*pipe
,
94 enum xorg_throttling_reason reason
)
98 vmw_winsys_screen_set_throttling(pipe
->screen
, 20000);
101 vmw_winsys_screen_set_throttling(pipe
->screen
, 0);
106 vmw_context_no_throttle(CustomizerPtr cust
,
107 struct pipe_context
*pipe
,
108 enum xorg_throttling_reason reason
)
110 vmw_winsys_screen_set_throttling(pipe
->screen
, 0);
114 vmw_pre_init(CustomizerPtr cust
, int fd
)
116 struct vmw_customizer
*vmw
= vmw_customizer(cust
);
124 vmw_screen_init(CustomizerPtr cust
)
126 struct vmw_customizer
*vmw
= vmw_customizer(cust
);
129 ver
= drmGetVersion(vmw
->fd
);
131 (ver
->version_major
== 1 && ver
->version_minor
< 1)) {
132 cust
->swap_throttling
= TRUE
;
133 cust
->dirty_throttling
= TRUE
;
134 cust
->winsys_context_throttle
= vmw_context_no_throttle
;
136 cust
->swap_throttling
= TRUE
;
137 cust
->dirty_throttling
= FALSE
;
138 cust
->winsys_context_throttle
= vmw_context_throttle
;
139 debug_printf("%s: Enabling kernel throttling.\n", __func__
);
145 vmw_screen_cursor_init(vmw
);
147 vmw_ctrl_ext_init(vmw
);
149 /* if gallium is used then we don't need to do anything more. */
150 if (xorg_has_gallium(vmw
->pScrn
))
159 vmw_screen_close(CustomizerPtr cust
)
161 struct vmw_customizer
*vmw
= vmw_customizer(cust
);
166 vmw_screen_cursor_close(vmw
);
168 vmw_video_close(vmw
);
174 vmw_screen_enter_vt(CustomizerPtr cust
)
176 debug_printf("%s: enter\n", __func__
);
182 vmw_screen_leave_vt(CustomizerPtr cust
)
184 struct vmw_customizer
*vmw
= vmw_customizer(cust
);
186 debug_printf("%s: enter\n", __func__
);
188 vmw_video_stop_all(vmw
);
194 * Functions for setting up hooks into the xorg state tracker
197 static Bool (*vmw_screen_pre_init_saved
)(ScrnInfoPtr pScrn
, int flags
) = NULL
;
200 vmw_screen_pre_init(ScrnInfoPtr pScrn
, int flags
)
202 struct vmw_customizer
*vmw
;
205 vmw
= xnfcalloc(1, sizeof(*vmw
));
211 cust
->winsys_pre_init
= vmw_pre_init
;
212 cust
->winsys_screen_init
= vmw_screen_init
;
213 cust
->winsys_screen_close
= vmw_screen_close
;
214 cust
->winsys_enter_vt
= vmw_screen_enter_vt
;
215 cust
->winsys_leave_vt
= vmw_screen_leave_vt
;
219 pScrn
->driverPrivate
= cust
;
221 pScrn
->PreInit
= vmw_screen_pre_init_saved
;
222 if (!pScrn
->PreInit(pScrn
, flags
))
229 vmw_screen_set_functions(ScrnInfoPtr pScrn
)
231 assert(!vmw_screen_pre_init_saved
);
233 vmw_screen_pre_init_saved
= pScrn
->PreInit
;
234 pScrn
->PreInit
= vmw_screen_pre_init
;