diff options
author | Eric Anholt <eric@anholt.net> | 2008-12-14 16:09:25 -0800 |
---|---|---|
committer | Eric Anholt <eric@anholt.net> | 2008-12-16 10:21:59 -0800 |
commit | ecdd706873c1f990f4a78fbaecf7380411edabcd (patch) | |
tree | 2ff9d2a4e46782ebb47f88b885708b7cdc3c3aa4 /uxa | |
parent | e6479f96e5d8da39fcbb5376c4a66a1f924ec4e4 (diff) |
uxa: Correctly prepare/finishaccess of stipple in ValidateGC (and only it)
This avoids prepare/finish_access_gc overhead when we're not changing things
(since GCTile is already handled) and get us the RW flag for the prepare on
of the stipple pixmap so thing will be synced correctly.
Diffstat (limited to 'uxa')
-rw-r--r-- | uxa/uxa.c | 13 |
1 files changed, 10 insertions, 3 deletions
@@ -237,9 +237,16 @@ uxa_validate_gc (GCPtr pGC, unsigned long changes, DrawablePtr pDrawable) changes &= ~GCTile; } - uxa_prepare_access_gc(pGC); - fbValidateGC (pGC, changes, pDrawable); - uxa_finish_access_gc(pGC); + if (changes & GCStipple && pGC->stipple) { + /* We can't inline stipple handling like we do for GCTile because it sets + * fbgc privates. + */ + uxa_prepare_access(&pGC->stipple->drawable, UXA_ACCESS_RW); + fbValidateGC (pGC, changes, pDrawable); + uxa_finish_access(&pGC->stipple->drawable); + } else { + fbValidateGC (pGC, changes, pDrawable); + } pGC->ops = (GCOps *) &uxa_ops; } |