mirror of
https://gitlab.freedesktop.org/xorg/xserver.git
synced 2026-02-08 18:30:30 +01:00
Merge branch 'modesettingfindcompatibledridevice' into 'master'
modesetting: find the first compatible dri device as default See merge request xorg/xserver!1496
This commit is contained in:
commit
79bf3cc30b
1 changed files with 17 additions and 2 deletions
|
|
@ -235,6 +235,7 @@ get_passed_fd(void)
|
|||
static int
|
||||
open_hw(const char *dev)
|
||||
{
|
||||
char drm_name[] = "/dev/dri/card0";
|
||||
int fd;
|
||||
|
||||
if ((fd = get_passed_fd()) != -1)
|
||||
|
|
@ -245,8 +246,22 @@ open_hw(const char *dev)
|
|||
else {
|
||||
dev = getenv("KMSDEVICE");
|
||||
if ((NULL == dev) || ((fd = open(dev, O_RDWR | O_CLOEXEC, 0)) == -1)) {
|
||||
dev = "/dev/dri/card0";
|
||||
fd = open(dev, O_RDWR | O_CLOEXEC, 0);
|
||||
int i;
|
||||
|
||||
for (i = 0, dev=drm_name; i < 8; i++) {
|
||||
drm_name[13] = '0' + i;
|
||||
|
||||
if ((fd = open(drm_name, O_RDWR | O_CLOEXEC, 0)) >= 0) {
|
||||
uint64_t check_dumb = 0;
|
||||
|
||||
if (drmGetCap(fd, DRM_CAP_DUMB_BUFFER, &check_dumb) >= 0 && check_dumb)
|
||||
break;
|
||||
|
||||
close(fd);
|
||||
|
||||
fd = -1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (fd == -1)
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue