3727 Commits

Author SHA1 Message Date
Michel Dänzer
0a12bf1085 Call drmmode_set_desired_modes from a WindowExposures hook
This is the earliest opportunity where the root window contents are
guaranteed to be initialized, and prevents drmmode_set_mode_major from
getting called before drmmode_set_desired_modes via RADEONUnblank ->
drmmode_crtc_dpms. Also, in contrast to the BlockHandler hook, this is
called when running Xorg with -pogo.

Fixes intermittently showing garbage on server startup or after server
reset.

As a bonus, this avoids trouble due to higher layers (e.g. the tigervnc
Xorg module) calling RADEONBlockHandler_oneshot repeatedly even after
we set pScreen->BlockHandler = RADEONBlockHandler_KMS.

v2:
* Drop spaces between XORG_VERSION_NUMERIC arguments
* Call radeon_bo_wait after radeon_cs_flush_indirect

Bugzilla: https://bugs.freedesktop.org/99457
Reviewed-by: Alex Deucher <alexander.deucher@amd.com> (v1)
2017-03-02 16:05:55 +09:00
Michel Dänzer
df2d749a4d Fix bogus indentation
Trivial.

Fixes: 58cd160005 ("Allow toggling TearFree at runtime via output property")
2017-03-02 16:05:42 +09:00
Michel Dänzer
9035b6abea present: Flush before flipping
This isn't necessary for DRI clients, but the Present extension can also
be used for presenting normal pixmaps rendered to via the X11 protocol.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-03-01 16:58:03 +09:00
Michel Dänzer
0a4eb0e12f present: Use async flip for unflip if possible
In that case, unflip operations should finish faster in general.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-03-01 16:57:34 +09:00
Michel Dänzer
9a951a3e55 present: Also flush before using a flip to unflip
Not doing so might result in intermittently scanning out stale contents
of the screen pixmap.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-03-01 16:57:29 +09:00
Michel Dänzer
f2bc882f1c Handle rotation in the driver also with Xorg 1.12-1.18
We cannot use the HW cursor in that case, but in turn we get more
efficient and less teary updates of rotated outputs.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-03-01 16:57:13 +09:00
Michel Dänzer
ae921a3150 Fold drmmode_crtc_scanout_allocate into drmmode_crtc_scanout_create
Not used anywhere else anymore.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-03-01 16:56:53 +09:00
Michel Dänzer
987a34adb3 Call drmmode_crtc_scanout_create in drmmode_crtc_shadow_allocate as well
Calling drmmode_crtc_scanout_allocate in drmmode_crtc_shadow_allocate
resulted in drmmode_crtc_scanout_create called from
drmmode_crtc_shadow_create passing an uninitialized pitch value to
drmmode_create_bo_pixmap.

Fixes issues such as failure to allocate the scanout pixmap or visual
corruption and GPUVM faults when attempting to use rotation with Xorg
<1.19.

Bugzilla: https://bugs.freedesktop.org/99916
Fixes: ea30d856ba ("Pass pitch from drmmode_crtc_scanout_allocate to drmmode_create_bo_pixmap")
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-02-28 17:17:20 +09:00
Michel Dänzer
244d4bc7f8 present: Wait for screen pixmap BO idle before setting modes for unflip
To make sure the screen pixmap contents are up to date when it starts
being scanned out.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-02-22 18:30:12 +09:00
Michel Dänzer
3ff29e5a14 present: Only call drmModeRmFB after setting modes for unflip
Fixes display intermittently blanking when a modeset is used for unflip.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-02-22 18:29:53 +09:00
Michel Dänzer
0c29deb5a9 Use drmmode_crtc_scanout_free in drmmode_fini
We were leaking drmmode_crtc->scanout_damage, which caused trouble on
server reset. Fixes server reset with active separate scanout pixmaps.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-02-22 18:29:11 +09:00
Michel Dänzer
58cd160005 Allow toggling TearFree at runtime via output property
Option "TearFree" now sets the default value of the output property.
See the manpage update for details.

TearFree is now enabled by default for outputs using rotation or other
RandR transforms, and for RandR 1.4 slave outputs.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-02-22 18:27:37 +09:00
Michel Dänzer
305e2cbf33 Factor out drmmode_crtc_scanout_update helper
Cleanup in preparation for following change, no functional change
intended.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-02-22 18:27:19 +09:00
Michel Dänzer
649644a883 Factor out radeon_prime_dirty_to_crtc helper
Cleanup in preparation for the following change, no functional change
intended.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-02-14 17:36:31 +09:00
Michel Dänzer
1351e48efe Don't destroy current FB if drmModeAddFB fails
It would probably result in a black screen.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-02-08 16:02:56 +09:00
Michel Dänzer
481394e3c9 Fix flip event data leak if calloc or drmModeAddFB fails
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-02-08 16:01:24 +09:00
Michel Dänzer
80fc786339 Don't handle Option "SwapbuffersWait" at all with glamor
It never had any effect with glamor.

v2: Better formatting, no functional change from v1.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com> (v1)
2017-01-31 16:25:37 +09:00
Michel Dänzer
d611d21d9b Enable tiling by default with glamor on PALM
The DFS check is only relevant for EXA.

The lack of tiling prevented DRI3 clients from using page flipping,
resulting in tearing.

Bugzilla: https://bugs.freedesktop.org/99491
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-01-26 18:38:03 +09:00
Michel Dänzer
55a33205cb Add 10-radeon.conf xorg.conf.d snippet
This instructs Xorg >= 1.16 to try loading the radeon driver for devices
managed by the radeon kernel driver, even if the ati wrapper driver
isn't available.

Copied from the amdgpu driver.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-01-26 18:27:30 +09:00
Mihail Konev
8e6a4e96b7 autogen: add default patch prefix
Signed-off-by: Mihail Konev <k.mvc@ya.ru>
2017-01-26 14:00:22 +10:00
Emil Velikov
e062933b54 autogen.sh: use quoted string variables
Place quotes around the $srcdir, $ORIGDIR and $0 variables to prevent
fall-outs, when they contain space.

Signed-off-by: Emil Velikov <emil.l.velikov@gmail.com>
Reviewed-by: Peter Hutterer <peter.hutterer@who-t.net>
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
2017-01-26 11:48:03 +10:00
Peter Hutterer
4fe183111f autogen.sh: use exec instead of waiting for configure to finish
Syncs the invocation of configure with the one from the server.

Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
Reviewed-by: Emil Velikov <emil.velikov@collabora.com>
2017-01-26 11:48:03 +10:00
Michel Dänzer
a1787e4615 ati: Support loading the amdgpu driver from the ati wrapper
If .../share/X11/xorg.conf.d/10-amdgpu.conf doesn't exist, but the ati
wrapper is loaded, it will otherwise try to use the radeon driver even
for GPUs driven by the amdgpu kernel driver. This can only fail,
potentially in bad ways.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-01-24 18:15:12 +09:00
Michel Dänzer
41b82c776b .editorconfig: src/ati.c only uses spaces for indentation
Trivial.
2017-01-24 18:14:23 +09:00
Michel Dänzer
ea30d856ba Pass pitch from drmmode_crtc_scanout_allocate to drmmode_create_bo_pixmap
radeon_bo_get_tiling can fail, e.g. for linear BOs.

Fixes TearFree not working in those cases.

Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=97873
Fixes: 040a7b80e1 ("Explicitly set the fbcon pixmap pitch again")
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2017-01-06 17:36:05 +09:00
Jammy Zhou
720dd07e79 Use render node for DRI3 if available
Signed-off-by: Jammy Zhou <Jammy.Zhou@amd.com>
(ported from amdgpu commit ea558e645786b08d75307716036045170e97b43e)
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
[ Second attempt, let's see if there's any fallout this time... ]
2016-12-19 17:27:19 +09:00
Michel Dänzer
92fc387a62 Simplify drmmode_handle_uevents
No functional change intended.

Reviewed-by: Jim Qu <Jim.Qu@amd.com>
(Cherry picked from amdgpu commit edd276185d42962a13faf9ec9eeebc754ef284e7.)
2016-12-15 12:44:47 +09:00
jimqu
404c647527 udev_monitor_receive_device() will block when hotplug monitor
udev_monitor_receive_device() will block and wait for the event of udev
use select() to ensure that this will not block.

Signed-off-by: JimQu <Jim.Qu@amd.com>
Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
(Cherry picked from amdgpu commit 732cf4d3a248b288532ad0f3443da49e08dc7507)
2016-12-14 11:46:16 +09:00
Jochen Rollwagen
a89c0bced4 Calculate log base 2 in radeon.h based on clz for all platforms
This commit replaces the inline assembler code (for x86 platforms) and
loop (for non-x86 platforms) in RADEONLog2 with a one-liner version
based on clz (count leading zeroes).

Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
2016-12-05 11:06:28 +09:00
Michel Dänzer
e294244917 Call radeon_drm_abort_entry on failure to flip to a scanout pixmap
Fixes leaking the corresponding struct radeon_drm_queue list entry in
that case.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-11-30 15:33:07 +09:00
Michel Dänzer
14c3f59f51 Call ValidateGC after ChangeClip in radeon_sync_scanout_pixmaps
The wrong order meant that the clipping region wasn't actually applied,
so it always copied the full contents from the other scanout pixmap.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-11-30 15:32:31 +09:00
Michel Dänzer
a995f58309 Fix radeon_scanout_extents_intersect for GPU screens
Fixes incorrect screen updates with TearFree enabled on PRIME slave
outputs which are not located at (0, 0).

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-11-30 15:31:49 +09:00
Michel Dänzer
e543ef3a2f Take current scanout_id into account everywhere involved with TearFree
Fixes various potential issues with TearFree enabled, e.g. outputs
freezing after display configuration changes.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-11-29 17:41:10 +09:00
Michel Dänzer
f130b10e63 Add radeon_is_gpu_screen helper
This will hopefully decrease the chance of accidentally breaking the
build against xserver < 1.13 in the future.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-11-25 18:12:40 +09:00
Jochen Rollwagen
487aa62a2a fix build for xserver < 1.13
same procedure every few patches.....

Fixes: 13c6bc5e38 ("Don't install Flush/EventCallback for GPU screens")
Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
2016-11-25 17:50:24 +09:00
Michel Dänzer
5fea5ef2f0 Pass fb_id into drmmode_page_flip_target_absolute/relative
drmmode->fb_id isn't what we need in the TearFree case. Fixes TearFree
freezing with

(WW) RADEON(0): flip queue failed in radeon_scanout_flip: No such file or directory

in the log file.

Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=98834
Fixes: 1106b2f773 ("Use DRM_MODE_PAGE_FLIP_TARGET_ABSOLUTE/RELATIVE flags when available")
2016-11-24 18:45:22 +09:00
Michel Dänzer
13c6bc5e38 Don't install Flush/EventCallback for GPU screens
Their purpose is to flush GPU rendering commands corresponding to damage
events, but there can be no damage events corresponding to GPU screen
rendering operations.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-11-22 16:25:48 +09:00
Michel Dänzer
f11531c99f Enable glamor by default with >= R600 and Xorg >= 1.18.3
glamor should now perform at least as well as EXA in general, and this
allows DRI3 to be enabled by default for >= R600.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-11-22 16:25:10 +09:00
Michel Dänzer
1106b2f773 Use DRM_MODE_PAGE_FLIP_TARGET_ABSOLUTE/RELATIVE flags when available
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-11-18 12:11:50 +09:00
Michel Dänzer
aab80d2203 Post-release version bump 2016-11-18 12:11:38 +09:00
Michel Dänzer
5cbe1ee8e4 Bump version for 7.8.0 release xf86-video-ati-7.8.0 2016-11-17 11:32:56 +09:00
Michel Dänzer
68023e0184 Update manpage entry for Option "TearFree"
It's now effective for arbitrary transforms as well.
2016-11-17 11:32:56 +09:00
Michel Dänzer
9760ef33cb Use pRADEONEnt to find both screens of a GPU in radeon_mode_hotplug
Fixes misbehaviour when hotplugging DisplayPort connectors on secondary
GPUs.

Fixes: c801f9f10a ("Handle Zaphod mode correctly in radeon_mode_hotplug")
Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=98626
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-11-10 12:25:20 +09:00
Michel Dänzer
35bec4937d Refactor radeon_mode_hotplug
Preparation for the next change, no functional change intended.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-11-10 12:24:46 +09:00
Michel Dänzer
be9f67339a Reindent code in radeon_dri2_create_buffer2
Fixes warning about misleading indentation from recent versions of gcc:

../../src/radeon_dri2.c: In function ‘radeon_dri2_create_buffer2’:
../../src/radeon_dri2.c:224:2: warning: this ‘if’ clause does not guard... [-Wmisleading-indentation]
  if (flags & RADEON_CREATE_PIXMAP_TILING_MACRO)
  ^~
../../src/radeon_dri2.c:227:6: note: ...this statement, but the latter is misleadingly indented as if it is guarded by the ‘if’
      if (aligned_width == front_width)
      ^~

No functional change intended.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-11-09 16:02:11 +09:00
Michel Dänzer
350a2645a1 Check Xorg version at runtime instead of build time in two places
This means that all possible paths can be handled as intended, no matter
which Xorg version the driver happened to be compiled against.

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-11-01 16:30:42 +09:00
Michel Dänzer
5df36de399 Require xserver 1.10 or newer
1.10.0 was released in February 2011.

We've been accidentally requiring 1.10 or newer since 121a6de72d ("Keep
track of damage event related flushes per-client v2").

Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-10-27 11:40:13 +09:00
Michel Dänzer
22b5ce9548 Consume all available udev events at once
We get multiple udev events for actions like docking a laptop into its
station or plugging a monitor to the station. By consuming as many
events as we can, we reduce the number of output re-evalutions.

It depends on the timing how many events can be consumed at once.

(Inspired by xserver commit 363f4273dd4aec3e26cc57ecb6c20f27e6c813d8)
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-10-26 16:00:09 +09:00
Hans de Goede
82d3c8f550 PRIME: Fix swapping of provider sink / source capabilities
When a card has import capability it can be an offload _sink_, not a
source and vice versa for export capability.

This went unnoticed sofar because most gpus have both import and export
capability.

Signed-off-by: Hans de Goede <hdegoede@redhat.com>
(Ported from xserver commit 94a1c77259ce39ba59ad87615df39b570ffab435)
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-10-26 15:59:36 +09:00
Michel Dänzer
6c940446dd Always call PixmapStopDirtyTracking in drmmode_set_scanout_pixmap
Otherwise, we may leak screen->pixmap_dirty_list entries if
drmmode_set_scanout_pixmap is called repatedly with ppix != NULL, which
can happen from RRReplaceScanoutPixmap.

(Inspired by xserver commit b773a9c8126222e5fed2904d012fbf917a9f22fd)
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
2016-10-26 15:58:26 +09:00