diff options
author | Keith Packard <keithp@keithp.com> | 2010-12-03 13:00:46 -0800 |
---|---|---|
committer | Keith Packard <keithp@keithp.com> | 2010-12-06 20:08:48 -0800 |
commit | 82612045e11f2b882ae132e184a9629f43f1c424 (patch) | |
tree | db71c14343191f4dbd6c5916a3b40f5974a4327c /hw | |
parent | 86c489c319c705f710bee3897fe27600ce15008e (diff) |
randr: Add per-crtc pixmaps
This adds new driver hooks to allocate scanout pixmaps and
changes the mode setting APIs to pass the new scanout pixmaps
along from DIX. DIX is responsible for reference counting the pixmaps
by tracking them through RRCrtcNotify.
Signed-off-by: Keith Packard <keithp@keithp.com>
Reviewed-by: Aaron Plattner <aplattner@nvidia.com>
Diffstat (limited to 'hw')
-rw-r--r-- | hw/xfree86/modes/xf86Crtc.c | 20 | ||||
-rw-r--r-- | hw/xfree86/modes/xf86Crtc.h | 32 | ||||
-rw-r--r-- | hw/xfree86/modes/xf86RandR12.c | 61 |
3 files changed, 109 insertions, 4 deletions
diff --git a/hw/xfree86/modes/xf86Crtc.c b/hw/xfree86/modes/xf86Crtc.c index 3fccaeaa6..5bf12f01a 100644 --- a/hw/xfree86/modes/xf86Crtc.c +++ b/hw/xfree86/modes/xf86Crtc.c @@ -82,6 +82,17 @@ xf86CrtcSetSizeRange (ScrnInfoPtr scrn, config->maxHeight = maxHeight; } +void +xf86CrtcSetScanoutFormats(ScrnInfoPtr scrn, + int num_formats, + xf86CrtcScanoutFormat *formats) +{ + xf86CrtcConfigPtr config = XF86_CRTC_CONFIG_PTR(scrn); + + config->num_scanout_formats = num_formats; + config->scanout_formats = formats; +} + /* * Crtc functions */ @@ -265,6 +276,7 @@ xf86CrtcSet(xf86CrtcPtr crtc, xf86CrtcSetRec *set) Rotation saved_rotation; RRTransformRec saved_transform; Bool saved_transform_present; + PixmapPtr saved_scanout_pixmap; crtc->enabled = xf86CrtcInUse (crtc); @@ -284,6 +296,7 @@ xf86CrtcSet(xf86CrtcPtr crtc, xf86CrtcSetRec *set) saved_x = crtc->x; saved_y = crtc->y; saved_rotation = crtc->rotation; + saved_scanout_pixmap = crtc->scanoutPixmap; if (crtc->transformPresent) { RRTransformInit (&saved_transform); RRTransformCopy (&saved_transform, &crtc->transform); @@ -301,6 +314,8 @@ xf86CrtcSet(xf86CrtcPtr crtc, xf86CrtcSetRec *set) } if (set->flags & XF86CrtcSetRotation) crtc->rotation = set->rotation; + if (set->flags & XF86CrtcSetScanoutPixmap) + crtc->scanoutPixmap = set->scanout_pixmap; if (set->flags & XF86CrtcSetTransform) { if (set->transform) { @@ -399,6 +414,10 @@ done: crtc->active = TRUE; if (scrn->pScreen) xf86CrtcSetScreenSubpixelOrder (scrn->pScreen); + if (crtc->scanoutPixmap) + ++crtc->scanoutPixmap->refcnt; + if (saved_scanout_pixmap) + (*scrn->pScreen->DestroyPixmap)(saved_scanout_pixmap); if (scrn->ModeSet) scrn->ModeSet(scrn); } else { @@ -409,6 +428,7 @@ done: if (saved_transform_present) RRTransformCopy (&crtc->transform, &saved_transform); crtc->transformPresent = saved_transform_present; + crtc->scanoutPixmap = saved_scanout_pixmap; } if (adjusted_mode) { diff --git a/hw/xfree86/modes/xf86Crtc.h b/hw/xfree86/modes/xf86Crtc.h index c2e81315f..9a520fc4d 100644 --- a/hw/xfree86/modes/xf86Crtc.h +++ b/hw/xfree86/modes/xf86Crtc.h @@ -79,6 +79,7 @@ typedef enum _xf86CrtcSetFlags { XF86CrtcSetTransform = 8, /* transform */ XF86CrtcSetRotation = 16, /* rotation */ XF86CrtcSetProperty = 32, /* output property */ + XF86CrtcSetScanoutPixmap = 64, /* scanout pixmap */ } xf86CrtcSetFlags; typedef struct _xf86CrtcSet { @@ -87,6 +88,7 @@ typedef struct _xf86CrtcSet { Rotation rotation; RRTransformPtr transform; int x, y; + PixmapPtr scanout_pixmap; } xf86CrtcSetRec; typedef struct _xf86CrtcFuncs { @@ -277,6 +279,7 @@ struct _xf86Crtc { Rotation rotation; PixmapPtr rotatedPixmap; void *rotatedData; + PixmapPtr scanoutPixmap; /** * Position on screen @@ -670,6 +673,14 @@ typedef struct _xf86CrtcSetConfig { int pixmap_x, pixmap_y; } xf86CrtcSetConfigRec, *xf86CrtcSetConfigPtr; +typedef struct _xf86CrtcScanoutFormat { + int depth; + int bitsPerPixel; + int maxWidth, maxHeight; + Rotation rotations; + PictFormatShort format; +} xf86CrtcScanoutFormat; + typedef struct _xf86CrtcConfigFuncs { /** * Requests that the driver resize the screen. @@ -693,6 +704,17 @@ typedef struct _xf86CrtcConfigFuncs { RRScreenConfigPtr screen_config, xf86CrtcSetConfigPtr crtc_configs, int num_configs); + + /** + * Create a scanout pixmap + */ + PixmapPtr + (*create_scanout_pixmap)(ScrnInfoPtr scrn, + int width, + int height, + Rotation rotations, + xf86CrtcScanoutFormat *format); + } xf86CrtcConfigFuncsRec, *xf86CrtcConfigFuncsPtr; typedef void (*xf86_crtc_notify_proc_ptr) (ScreenPtr pScreen); @@ -752,6 +774,11 @@ typedef struct _xf86CrtcConfig { /* callback when crtc configuration changes */ xf86_crtc_notify_proc_ptr xf86_crtc_notify; + /* + * Supported scanout pixmap formats + */ + int num_scanout_formats; + xf86CrtcScanoutFormat *scanout_formats; } xf86CrtcConfigRec, *xf86CrtcConfigPtr; extern _X_EXPORT int xf86CrtcConfigPrivateIndex; @@ -797,6 +824,11 @@ xf86CrtcSetSizeRange (ScrnInfoPtr scrn, int minWidth, int minHeight, int maxWidth, int maxHeight); +extern _X_EXPORT void +xf86CrtcSetScanoutFormats (ScrnInfoPtr scrn, + int num_formats, + xf86CrtcScanoutFormat *formats); + /* * Crtc functions */ diff --git a/hw/xfree86/modes/xf86RandR12.c b/hw/xfree86/modes/xf86RandR12.c index e3330f48d..b0eabdd80 100644 --- a/hw/xfree86/modes/xf86RandR12.c +++ b/hw/xfree86/modes/xf86RandR12.c @@ -1083,7 +1083,7 @@ xf86RandR12CrtcNotify (RRCrtcPtr randr_crtc) ret = RRCrtcNotify (randr_crtc, randr_mode, x, y, rotation, crtc->transformPresent ? &crtc->transform : NULL, - numOutputs, randr_outputs); + numOutputs, randr_outputs, crtc->scanoutPixmap); free(randr_outputs); return ret; } @@ -1126,7 +1126,8 @@ xf86RandR12CrtcSet (ScreenPtr pScreen, int y, Rotation rotation, int num_randr_outputs, - RROutputPtr *randr_outputs) + RROutputPtr *randr_outputs, + PixmapPtr scanout_pixmap) { XF86RandRInfoPtr randrp = XF86RANDRINFO(pScreen); ScrnInfoPtr pScrn = xf86Screens[pScreen->myNum]; @@ -1157,6 +1158,9 @@ xf86RandR12CrtcSet (ScreenPtr pScreen, sizeof (transform->transform)) != 0) flags |= XF86CrtcSetTransform; + if (scanout_pixmap != crtc->scanoutPixmap) + flags |= XF86CrtcSetScanoutPixmap; + if (x != crtc->x || y != crtc->y) flags |= XF86CrtcSetOrigin; for (o = 0; o < config->num_output; o++) @@ -1203,6 +1207,7 @@ xf86RandR12CrtcSet (ScreenPtr pScreen, set.transform = transform; set.x = x; set.y = y; + set.scanout_pixmap = scanout_pixmap; set.flags = flags; if (!xf86CrtcSet(crtc, &set)) { @@ -1732,6 +1737,54 @@ xf86RandR12ChangeGamma(int scrnIndex, Gamma gamma) return Success; } +static RRScanoutPixmapInfo * +xf86RRQueryScanoutPixmaps(ScreenPtr screen, int *n_info) +{ + ScrnInfoPtr scrn = xf86Screens[screen->myNum]; + xf86CrtcConfigPtr config = XF86_CRTC_CONFIG_PTR(scrn); + RRScanoutPixmapInfo *info; + int f; + + info = calloc(config->num_scanout_formats, sizeof (RRScanoutPixmapInfo)); + if (config->num_scanout_formats && !info) { + *n_info = 0; + return NULL; + } + for (f = 0; f < config->num_scanout_formats; f++) { + info[f].maxWidth = config->scanout_formats[f].maxWidth; + info[f].maxHeight = config->scanout_formats[f].maxHeight; + info[f].depth = config->scanout_formats[f].depth; + info[f].rotations = config->scanout_formats[f].rotations; + info[f].format = PictureMatchFormat (screen, info[f].depth, + config->scanout_formats[f].format); + } + *n_info = config->num_scanout_formats; + return info; +} + +static PixmapPtr +xf86RRCreateScanoutPixmap(ScreenPtr screen, + int width, int height, int depth, + Rotation rotations, + PictFormatPtr format) +{ + ScrnInfoPtr scrn = xf86Screens[screen->myNum]; + xf86CrtcConfigPtr config = XF86_CRTC_CONFIG_PTR(scrn); + int f; + + if (!config->funcs->create_scanout_pixmap) + return NullPixmap; + + for (f = 0; f < config->num_scanout_formats; f++) + if (config->scanout_formats[f].depth == depth && + (config->scanout_formats[f].format & 0xffffff) == format->format) { + return (*config->funcs->create_scanout_pixmap) (scrn, width, height, + rotations, + &config->scanout_formats[f]); + } + return NullPixmap; +} + static void xf86RandR14SetCrtcSpriteTransform(ScreenPtr pScreen, RRCrtcPtr randr_crtc, @@ -1893,17 +1946,17 @@ xf86RandR12Init12 (ScreenPtr pScreen) rp->rrCrtcGetGamma = xf86RandR12CrtcGetGamma; rp->rrOutputSetProperty = xf86RandR12OutputSetProperty; rp->rrOutputValidateMode = xf86RandR12OutputValidateMode; -#if RANDR_13_INTERFACE rp->rrOutputGetProperty = xf86RandR13OutputGetProperty; rp->rrGetPanning = xf86RandR13GetPanning; rp->rrSetPanning = xf86RandR13SetPanning; -#endif rp->rrModeDestroy = xf86RandR12ModeDestroy; rp->rrSetConfig = NULL; pScrn->PointerMoved = xf86RandR12PointerMoved; pScrn->ChangeGamma = xf86RandR12ChangeGamma; rp->rrSetCrtcSpriteTransform = xf86RandR14SetCrtcSpriteTransform; rp->rrSetCrtcConfigs = xf86RRSetCrtcConfigs; + rp->rrQueryScanoutPixmaps = xf86RRQueryScanoutPixmaps; + rp->rrCreateScanoutPixmap = xf86RRCreateScanoutPixmap; randrp->orig_EnterVT = pScrn->EnterVT; pScrn->EnterVT = xf86RandR12EnterVT; |