[PATCH libdrm] libdrm: Fix issue about differrent domainID but same BDF
Deng, Emily
Emily.Deng at amd.com
Fri Feb 15 08:59:02 UTC 2019
Ping ......
Best wishes
Emily Deng
>-----Original Message-----
>From: Deng, Emily <Emily.Deng at amd.com>
>Sent: Friday, February 15, 2019 11:51 AM
>To: Deng, Emily <Emily.Deng at amd.com>; amd-gfx at lists.freedesktop.org
>Subject: RE: [PATCH libdrm] libdrm: Fix issue about differrent domainID but same
>BDF
>
>Ping ......
>
>>-----Original Message-----
>>From: amd-gfx <amd-gfx-bounces at lists.freedesktop.org> On Behalf Of
>>Emily Deng
>>Sent: Thursday, February 14, 2019 3:54 PM
>>To: amd-gfx at lists.freedesktop.org
>>Cc: Deng, Emily <Emily.Deng at amd.com>
>>Subject: [PATCH libdrm] libdrm: Fix issue about differrent domainID but
>>same BDF
>>
>>For multiple GPUs which has the same BDF, but has different domain ID,
>>the drmOpenByBusid will return the wrong fd when startx.
>>
>>The reproduce sequence as below:
>>1. Call drmOpenByBusid to open Card0, then will return the right fd0,
>>and the
>>fd0 is master privilege;
>>2. Call drmOpenByBusid to open Card1. In function drmOpenByBusid, it
>>will open
>>Card0 first, this time, the fd1 for opening Card0 is not master
>>privilege, and will call drmSetInterfaceVersion to identify the domain
>>ID feature, as the fd1 is not master privilege, then
>>drmSetInterfaceVersion will fail, and then won't compare domain ID, then
>return the wrong fd for Card1.
>>
>>Solution:
>>First loop search the best match fd about drm 1.4.
>>
>>Signed-off-by: Emily Deng <Emily.Deng at amd.com>
>>---
>> xf86drm.c | 23 +++++++++++++++++++++++
>> 1 file changed, 23 insertions(+)
>>
>>diff --git a/xf86drm.c b/xf86drm.c
>>index 336d64d..b60e029 100644
>>--- a/xf86drm.c
>>+++ b/xf86drm.c
>>@@ -584,11 +584,34 @@ static int drmOpenByBusid(const char *busid, int
>type)
>> if (base < 0)
>> return -1;
>>
>>+ /* We need to try for 1.4 first for proper PCI domain support */
>> drmMsg("drmOpenByBusid: Searching for BusID %s\n", busid);
>> for (i = base; i < base + DRM_MAX_MINOR; i++) {
>> fd = drmOpenMinor(i, 1, type);
>> drmMsg("drmOpenByBusid: drmOpenMinor returns %d\n", fd);
>> if (fd >= 0) {
>>+ sv.drm_di_major = 1;
>>+ sv.drm_di_minor = 4;
>>+ sv.drm_dd_major = -1; /* Don't care */
>>+ sv.drm_dd_minor = -1; /* Don't care */
>>+ if (!drmSetInterfaceVersion(fd, &sv)) {
>>+ buf = drmGetBusid(fd);
>>+ drmMsg("drmOpenByBusid: drmGetBusid reports %s\n", buf);
>>+ if (buf && drmMatchBusID(buf, busid, 1)) {
>>+ drmFreeBusid(buf);
>>+ return fd;
>>+ }
>>+ if (buf)
>>+ drmFreeBusid(buf);
>>+ }
>>+ close(fd);
>>+ }
>>+ }
>>+
>>+ for (i = base; i < base + DRM_MAX_MINOR; i++) {
>>+ fd = drmOpenMinor(i, 1, type);
>>+ drmMsg("drmOpenByBusid: drmOpenMinor returns %d\n", fd);
>>+ if (fd >= 0) {
>> /* We need to try for 1.4 first for proper PCI domain support
>> * and if that fails, we know the kernel is busted
>> */
>>--
>>2.7.4
>>
>>_______________________________________________
>>amd-gfx mailing list
>>amd-gfx at lists.freedesktop.org
>>https://lists.freedesktop.org/mailman/listinfo/amd-gfx
More information about the amd-gfx
mailing list