diff options
author | Paul Gortmaker <paul.gortmaker@windriver.com> | 2015-08-04 01:07:55 -0400 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2015-08-09 00:13:59 -0700 |
commit | 177d463a8ae2e2fdffe1b3ad33d48c9f84c9d435 (patch) | |
tree | 973e6334935d7dee8a149efd77c8727a1fb1d40c /meta/recipes-graphics | |
parent | 37e78463e58c374ba2ff933acfc4441cbb666c1f (diff) | |
download | poky-177d463a8ae2e2fdffe1b3ad33d48c9f84c9d435.tar.gz |
xf86-video-intel: fix yocto/oe-core wreckage from libdrm upgrade
In commit a117fd5ecdd9973c7e4d772d1785f1f4e9b162c2,
from OE-Core rev: 88d60e70da0890184922056cef1f20171f716ace
"libdrm: Upgrade to 2.4.62" we managed to break X like this:
[3602662.736] (--) intel(0): Integrated Graphics Chipset: Intel(R) HD Graphics 4600
[3602662.736] (--) intel(0): CPU: x86-64, sse2, sse3, ssse3, sse4.1, sse4.2, avx, avx2
[3602662.736] (II) intel(0): Creating default Display subsection in Screen section
"Default Screen Section" for depth/fbbpp 24/32
[3602662.736] (==) intel(0): Depth 24, (--) framebuffer bpp 32
[3602662.736] (==) intel(0): RGB weight 888
[3602662.736] (==) intel(0): Default visual is TrueColor
[3602662.736] (EE)
[3602662.736] (EE) Backtrace:
[3602662.736] (EE) 0: /usr/bin/X (xorg_backtrace+0x49) [0x56ae09]
[3602662.736] (EE) 1: /usr/bin/X (0x400000+0x16ecd9) [0x56ecd9]
[3602662.736] (EE) 2: /lib64/libpthread.so.0 (0x3330600000+0x105e0) [0x33306105e0]
[3602662.736] (EE)
[3602662.736] (EE) Segmentation fault at address 0x0
[3602662.736] (EE)
Fatal server error:
[3602662.736] (EE) Caught signal 11 (Segmentation fault). Server aborting
A mix of a ~1 month old (working) image and the failing image led me
to determine /usr/lib64/xorg/modules/drivers/intel_drv.so was bad.
However nothing changed the parent package xf86-video-intel in
yocto for months.
So brute force bisecting yocto leads to the above commit. Inserting
libdrm as git and then bisecting the 2.4.59 --> 2.4.62 uprev content
leads to libdrm commit 8576527cfacaf42af8316e1030c192193e94225a
("intel: Merge latest i915_drm.h") -- specifically, the part of that
commit that adds __u64 flags to drm_i915_gem_mmap lands in our sysroot
and is used by the compile of xf86-video-intel.
With the specific trigger finally pinpointed, the final leap was to
correlate that trigger to the upstream xf86-video-intel commit that
accounts for the fallout of this libdrm header change, that we did
not yet have here. Fun times. Hopefully this complete description
here will ensure nobody else has to retrace these steps again.
Cc: Damien Lespiau <damien.lespiau@intel.com>
Cc: Neil Roberts <neil@linux.intel.com>
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Steffen Pankratz <steffen.pankratz@elektrobit.com>
Cc: Ross Burton <ross.burton@intel.com>
Cc: Richard Purdie <richard.purdie@linuxfoundation.org>
(From OE-Core rev: c1df1da2a71aeb5956952e44c5f4ad669b6e770f)
Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-graphics')
-rw-r--r-- | meta/recipes-graphics/xorg-driver/xf86-video-intel/sna-Protect-against-ABI-breakage-in-recent-versions-.patch | 70 | ||||
-rw-r--r-- | meta/recipes-graphics/xorg-driver/xf86-video-intel_2.99.917.bb | 1 |
2 files changed, 71 insertions, 0 deletions
diff --git a/meta/recipes-graphics/xorg-driver/xf86-video-intel/sna-Protect-against-ABI-breakage-in-recent-versions-.patch b/meta/recipes-graphics/xorg-driver/xf86-video-intel/sna-Protect-against-ABI-breakage-in-recent-versions-.patch new file mode 100644 index 0000000000..589d52e0f0 --- /dev/null +++ b/meta/recipes-graphics/xorg-driver/xf86-video-intel/sna-Protect-against-ABI-breakage-in-recent-versions-.patch | |||
@@ -0,0 +1,70 @@ | |||
1 | From 7fe2b2948652443ff43d907855bd7a051d54d309 Mon Sep 17 00:00:00 2001 | ||
2 | From: Chris Wilson <chris@chris-wilson.co.uk> | ||
3 | Date: Thu, 19 Mar 2015 23:14:17 +0000 | ||
4 | Subject: [PATCH] sna: Protect against ABI breakage in recent versions of | ||
5 | libdrm | ||
6 | |||
7 | commit 7fe2b2948652443ff43d907855bd7a051d54d309 upstream. | ||
8 | |||
9 | Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> | ||
10 | Upstream-Status: Backport | ||
11 | Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com> | ||
12 | |||
13 | diff --git a/src/sna/kgem.c b/src/sna/kgem.c | ||
14 | index 11f0828f2bbc..6f16cbac87f2 100644 | ||
15 | --- a/src/sna/kgem.c | ||
16 | +++ b/src/sna/kgem.c | ||
17 | @@ -182,6 +182,15 @@ struct local_i915_gem_caching { | ||
18 | #define LOCAL_IOCTL_I915_GEM_SET_CACHING DRM_IOW(DRM_COMMAND_BASE + LOCAL_I915_GEM_SET_CACHING, struct local_i915_gem_caching) | ||
19 | #define LOCAL_IOCTL_I915_GEM_GET_CACHING DRM_IOW(DRM_COMMAND_BASE + LOCAL_I915_GEM_GET_CACHING, struct local_i915_gem_caching) | ||
20 | |||
21 | +struct local_i915_gem_mmap { | ||
22 | + uint32_t handle; | ||
23 | + uint32_t pad; | ||
24 | + uint64_t offset; | ||
25 | + uint64_t size; | ||
26 | + uint64_t addr_ptr; | ||
27 | +}; | ||
28 | +#define LOCAL_IOCTL_I915_GEM_MMAP DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_GEM_MMAP, struct local_i915_gem_mmap) | ||
29 | + | ||
30 | struct local_i915_gem_mmap2 { | ||
31 | uint32_t handle; | ||
32 | uint32_t pad; | ||
33 | @@ -514,15 +523,15 @@ retry_wc: | ||
34 | |||
35 | static void *__kgem_bo_map__cpu(struct kgem *kgem, struct kgem_bo *bo) | ||
36 | { | ||
37 | - struct drm_i915_gem_mmap mmap_arg; | ||
38 | + struct local_i915_gem_mmap arg; | ||
39 | int err; | ||
40 | |||
41 | retry: | ||
42 | - VG_CLEAR(mmap_arg); | ||
43 | - mmap_arg.handle = bo->handle; | ||
44 | - mmap_arg.offset = 0; | ||
45 | - mmap_arg.size = bytes(bo); | ||
46 | - if ((err = do_ioctl(kgem->fd, DRM_IOCTL_I915_GEM_MMAP, &mmap_arg))) { | ||
47 | + VG_CLEAR(arg); | ||
48 | + arg.handle = bo->handle; | ||
49 | + arg.offset = 0; | ||
50 | + arg.size = bytes(bo); | ||
51 | + if ((err = do_ioctl(kgem->fd, LOCAL_IOCTL_I915_GEM_MMAP, &arg))) { | ||
52 | assert(err != EINVAL); | ||
53 | |||
54 | if (__kgem_throttle_retire(kgem, 0)) | ||
55 | @@ -536,10 +545,10 @@ retry: | ||
56 | return NULL; | ||
57 | } | ||
58 | |||
59 | - VG(VALGRIND_MAKE_MEM_DEFINED(mmap_arg.addr_ptr, bytes(bo))); | ||
60 | + VG(VALGRIND_MAKE_MEM_DEFINED(arg.addr_ptr, bytes(bo))); | ||
61 | |||
62 | DBG(("%s: caching CPU vma for %d\n", __FUNCTION__, bo->handle)); | ||
63 | - return bo->map__cpu = (void *)(uintptr_t)mmap_arg.addr_ptr; | ||
64 | + return bo->map__cpu = (void *)(uintptr_t)arg.addr_ptr; | ||
65 | } | ||
66 | |||
67 | static int gem_write(int fd, uint32_t handle, | ||
68 | -- | ||
69 | 2.4.4 | ||
70 | |||
diff --git a/meta/recipes-graphics/xorg-driver/xf86-video-intel_2.99.917.bb b/meta/recipes-graphics/xorg-driver/xf86-video-intel_2.99.917.bb index 26b68b461c..0ab7380506 100644 --- a/meta/recipes-graphics/xorg-driver/xf86-video-intel_2.99.917.bb +++ b/meta/recipes-graphics/xorg-driver/xf86-video-intel_2.99.917.bb | |||
@@ -11,6 +11,7 @@ LIC_FILES_CHKSUM = "file://COPYING;md5=8730ad58d11c7bbad9a7066d69f7808e" | |||
11 | 11 | ||
12 | SRC_URI += "file://disable-x11-dri3.patch \ | 12 | SRC_URI += "file://disable-x11-dri3.patch \ |
13 | file://always_include_xorg_server.h.patch \ | 13 | file://always_include_xorg_server.h.patch \ |
14 | file://sna-Protect-against-ABI-breakage-in-recent-versions-.patch \ | ||
14 | " | 15 | " |
15 | 16 | ||
16 | SRC_URI[md5sum] = "fa196a66e52c0c624fe5d350af7a5e7b" | 17 | SRC_URI[md5sum] = "fa196a66e52c0c624fe5d350af7a5e7b" |