[PATCH] Don't set TILE_SPLIT flags if surface.tile_split == 0.
Michel Dänzer
michel at daenzer.net
Sun Jun 21 23:48:59 PDT 2015
On 22.06.2015 07:09, Mario Kleiner wrote:
> On pre-Evergreen hw, libdrm's r6_surface_best() helper
> for the surface managers radeon_surface_best() routine
> is a no-op and therefore doesn't assign any tile_split
> settings to created surfaces, so it leaves
> surface.tile_split on its "undefined" value of 0.
>
> Mesa's DRI3/Present backend creates DRI3 Pixmaps via
> the DRIImage extension and the radeon gallium driver
> implementation of that extension uses the libdrm
> surface manager for backing bo creation and treats
> an undefined surface.tile_split==0, as returned by
> the surface manager for pre-evergreen, as a signal
> to not assign any tile_split flags to the DRI3 Pixmaps
> bo.
>
> The ddx also uses libdrm surface manager to create the
> x-screen pixmap, but so far treated the returned undefined
> surface.tile_split==0 by mapping it to eg_tile_split()'s
> default tile_split flags, which are different from Mesa's
> tiling flags for DRI3 pixmaps. Under DRI3/Present this
> causes a mismatch of src pixmap and destination root
> pixmaps tiling flags and thereby prevents page flipping
> for pixmap presents.
>
> Change the ddx code to treat surface.tile_split==0 the
> same way as the radeon gallium driver to avoid mismatched
> tiling flags and thereby allow DRI3/Present page-flip to
> work on pre-Evergreen hw.
>
> Tested on RV730 and Evergreen "Juniper".
>
> Signed-off-by: Mario Kleiner <mario.kleiner.de at gmail.com>
Reviewed and pushed, thanks!
--
Earthling Michel Dänzer | http://www.amd.com
Libre software enthusiast | Mesa and X developer
More information about the xorg-driver-ati
mailing list