diff options
author | Dave Airlie <[email protected]> | 2012-06-06 15:20:24 +0100 |
---|---|---|
committer | Dave Airlie <[email protected]> | 2012-06-06 15:22:50 +0100 |
commit | 2bb2e6a6e3017d462be0ae9308955f37c5ee03c6 (patch) | |
tree | 70a1f11b4e5e32d969a25f2cbdb57f4e5f8d184b /src/gallium/state_trackers/xorg/xorg_driver.c | |
parent | ec19bdd16c3d4070af69fd865042babe0a627595 (diff) |
xorg: port to new compat API.
Signed-off-by: Dave Airlie <[email protected]>
Diffstat (limited to 'src/gallium/state_trackers/xorg/xorg_driver.c')
-rw-r--r-- | src/gallium/state_trackers/xorg/xorg_driver.c | 75 |
1 files changed, 37 insertions, 38 deletions
diff --git a/src/gallium/state_trackers/xorg/xorg_driver.c b/src/gallium/state_trackers/xorg/xorg_driver.c index eb9d7f075ef..4b128221b75 100644 --- a/src/gallium/state_trackers/xorg/xorg_driver.c +++ b/src/gallium/state_trackers/xorg/xorg_driver.c @@ -67,14 +67,13 @@ */ static Bool drv_pre_init(ScrnInfoPtr pScrn, int flags); -static Bool drv_screen_init(int scrnIndex, ScreenPtr pScreen, int argc, - char **argv); -static Bool drv_switch_mode(int scrnIndex, DisplayModePtr mode, int flags); -static void drv_adjust_frame(int scrnIndex, int x, int y, int flags); -static Bool drv_enter_vt(int scrnIndex, int flags); -static void drv_leave_vt(int scrnIndex, int flags); -static void drv_free_screen(int scrnIndex, int flags); -static ModeStatus drv_valid_mode(int scrnIndex, DisplayModePtr mode, Bool verbose, +static Bool drv_screen_init(SCREEN_INIT_ARGS_DECL); +static Bool drv_switch_mode(SWITCH_MODE_ARGS_DECL); +static void drv_adjust_frame(ADJUST_FRAME_ARGS_DECL); +static Bool drv_enter_vt(VT_FUNC_ARGS_DECL); +static void drv_leave_vt(VT_FUNC_ARGS_DECL); +static void drv_free_screen(FREE_SCREEN_ARGS_DECL); +static ModeStatus drv_valid_mode(SCRN_ARG_TYPE arg, DisplayModePtr mode, Bool verbose, int flags); typedef enum @@ -149,7 +148,7 @@ xorg_tracker_have_modesetting(ScrnInfoPtr pScrn, struct pci_device *device) */ static Bool drv_init_front_buffer_functions(ScrnInfoPtr pScrn); -static Bool drv_close_screen(int scrnIndex, ScreenPtr pScreen); +static Bool drv_close_screen(CLOSE_SCREEN_ARGS_DECL); /* @@ -543,7 +542,7 @@ drv_pre_init(ScrnInfoPtr pScrn, int flags) void xorg_flush(ScreenPtr pScreen) { - modesettingPtr ms = modesettingPTR(xf86Screens[pScreen->myNum]); + modesettingPtr ms = modesettingPTR(xf86ScreenToScrn(pScreen)); if (ms->ctx) { int j; @@ -605,14 +604,13 @@ void xorg_flush(ScreenPtr pScreen) #endif } -static void drv_block_handler(int i, pointer blockData, pointer pTimeout, - pointer pReadmask) +static void drv_block_handler(BLOCKHANDLER_ARGS_DECL) { - ScreenPtr pScreen = screenInfo.screens[i]; - modesettingPtr ms = modesettingPTR(xf86Screens[pScreen->myNum]); + SCREEN_PTR(arg); + modesettingPtr ms = modesettingPTR(xf86ScreenToScrn(pScreen)); pScreen->BlockHandler = ms->blockHandler; - pScreen->BlockHandler(i, blockData, pTimeout, pReadmask); + pScreen->BlockHandler(BLOCKHANDLER_ARGS); pScreen->BlockHandler = drv_block_handler; xorg_flush(pScreen); @@ -621,7 +619,7 @@ static void drv_block_handler(int i, pointer blockData, pointer pTimeout, static Bool drv_create_screen_resources(ScreenPtr pScreen) { - ScrnInfoPtr pScrn = xf86Screens[pScreen->myNum]; + ScrnInfoPtr pScrn = xf86ScreenToScrn(pScreen); modesettingPtr ms = modesettingPTR(pScrn); PixmapPtr rootPixmap; Bool ret; @@ -636,7 +634,7 @@ drv_create_screen_resources(ScreenPtr pScreen) ms->noEvict = FALSE; - drv_adjust_frame(pScrn->scrnIndex, pScrn->frameX0, pScrn->frameY0, 0); + drv_adjust_frame(ADJUST_FRAME_ARGS(pScrn, pScrn->frameX0, pScrn->frameY0)); #ifdef DRM_MODE_FEATURE_DIRTYFB rootPixmap = pScreen->GetScreenPixmap(pScreen); @@ -741,9 +739,9 @@ static void drv_load_palette(ScrnInfoPtr pScrn, int numColors, static Bool -drv_screen_init(int scrnIndex, ScreenPtr pScreen, int argc, char **argv) +drv_screen_init(SCREEN_INIT_ARGS_DECL) { - ScrnInfoPtr pScrn = xf86Screens[pScreen->myNum]; + ScrnInfoPtr pScrn = xf86ScreenToScrn(pScreen); modesettingPtr ms = modesettingPTR(pScrn); VisualPtr visual; CustomizerPtr cust = ms->cust; @@ -889,13 +887,13 @@ drv_screen_init(int scrnIndex, ScreenPtr pScreen, int argc, char **argv) if (serverGeneration == 1) xf86ShowUnusedOptions(pScrn->scrnIndex, pScrn->options); - return drv_enter_vt(scrnIndex, 1); + return drv_enter_vt(VT_FUNC_ARGS); } static void -drv_adjust_frame(int scrnIndex, int x, int y, int flags) +drv_adjust_frame(ADJUST_FRAME_ARGS_DECL) { - ScrnInfoPtr pScrn = xf86Screens[scrnIndex]; + SCRN_INFO_PTR(arg); xf86CrtcConfigPtr config = XF86_CRTC_CONFIG_PTR(pScrn); xf86OutputPtr output = config->output[config->compat_output]; xf86CrtcPtr crtc = output->crtc; @@ -909,15 +907,16 @@ drv_adjust_frame(int scrnIndex, int x, int y, int flags) } static void -drv_free_screen(int scrnIndex, int flags) +drv_free_screen(FREE_SCREEN_ARGS_DECL) { - drv_free_rec(xf86Screens[scrnIndex]); + SCRN_INFO_PTR(arg); + drv_free_rec(pScrn); } static void -drv_leave_vt(int scrnIndex, int flags) +drv_leave_vt(VT_FUNC_ARGS_DECL) { - ScrnInfoPtr pScrn = xf86Screens[scrnIndex]; + SCRN_INFO_PTR(arg); modesettingPtr ms = modesettingPTR(pScrn); xf86CrtcConfigPtr config = XF86_CRTC_CONFIG_PTR(pScrn); CustomizerPtr cust = ms->cust; @@ -960,9 +959,9 @@ drv_leave_vt(int scrnIndex, int flags) * This gets called when gaining control of the VT, and from ScreenInit(). */ static Bool -drv_enter_vt(int scrnIndex, int flags) +drv_enter_vt(VT_FUNC_ARGS_DECL) { - ScrnInfoPtr pScrn = xf86Screens[scrnIndex]; + SCRN_INFO_PTR(arg); modesettingPtr ms = modesettingPTR(pScrn); CustomizerPtr cust = ms->cust; @@ -972,7 +971,7 @@ drv_enter_vt(int scrnIndex, int flags) if (!ms->create_front_buffer(pScrn)) return FALSE; - if (!flags && !ms->bind_front_buffer(pScrn)) + if (!ms->bind_front_buffer(pScrn)) return FALSE; if (!xf86SetDesiredModes(pScrn)) @@ -985,17 +984,17 @@ drv_enter_vt(int scrnIndex, int flags) } static Bool -drv_switch_mode(int scrnIndex, DisplayModePtr mode, int flags) +drv_switch_mode(SWITCH_MODE_ARGS_DECL) { - ScrnInfoPtr pScrn = xf86Screens[scrnIndex]; + SCRN_INFO_PTR(arg); return xf86SetSingleMode(pScrn, mode, RR_Rotate_0); } static Bool -drv_close_screen(int scrnIndex, ScreenPtr pScreen) +drv_close_screen(CLOSE_SCREEN_ARGS_DECL) { - ScrnInfoPtr pScrn = xf86Screens[scrnIndex]; + ScrnInfoPtr pScrn = xf86ScreenToScrn(pScreen); modesettingPtr ms = modesettingPTR(pScrn); CustomizerPtr cust = ms->cust; @@ -1031,17 +1030,17 @@ drv_close_screen(int scrnIndex, ScreenPtr pScreen) /* calls drop master make sure we don't talk to 3D HW after that */ if (pScrn->vtSema) { - drv_leave_vt(scrnIndex, 0); + drv_leave_vt(VT_FUNC_ARGS); } pScrn->vtSema = FALSE; pScreen->CloseScreen = ms->CloseScreen; - return (*pScreen->CloseScreen) (scrnIndex, pScreen); + return (*pScreen->CloseScreen) (CLOSE_SCREEN_ARGS); } static ModeStatus -drv_valid_mode(int scrnIndex, DisplayModePtr mode, Bool verbose, int flags) +drv_valid_mode(SCRN_ARG_TYPE arg, DisplayModePtr mode, Bool verbose, int flags) { return MODE_OK; } @@ -1110,7 +1109,7 @@ drv_create_front_buffer_ga3d(ScrnInfoPtr pScrn) pScrn->frameX0 = 0; pScrn->frameY0 = 0; - drv_adjust_frame(pScrn->scrnIndex, pScrn->frameX0, pScrn->frameY0, 0); + drv_adjust_frame(ADJUST_FRAME_ARGS(pScrn, pScrn->frameX0, pScrn->frameY0)); pipe_resource_reference(&ms->root_texture, tex); pipe_resource_reference(&tex, NULL); @@ -1222,7 +1221,7 @@ drv_create_front_buffer_kms(ScrnInfoPtr pScrn) pScrn->frameX0 = 0; pScrn->frameY0 = 0; - drv_adjust_frame(pScrn->scrnIndex, pScrn->frameX0, pScrn->frameY0, 0); + drv_adjust_frame(ADJUST_FRAME_ARGS(pScrn, pScrn->frameX0, pScrn->frameY0)); ms->root_bo = bo; ms->fb_id = fb_id; |