Приложение GLFW пытается загрузить драйвер через libGL, даже если он связан с libGLESv2 - PullRequest
0 голосов
/ 14 апреля 2019

Я пытаюсь создать приложение на основе GLFW для платы на основе Rockchip (точнее, Rock64). Rockchip реализует OpenGL ES, но не стандарт OpenGL. Таким образом, я настроил GLFW следующим образом (это Go, однако я сомневаюсь, что язык программирования имеет значение):

if err := glfw.Init(); err != nil {
  panic(err)
}
defer glfw.Terminate()

glfw.WindowHint(glfw.ClientAPI, glfw.OpenGLESAPI)

window, err := glfw.CreateWindow(640, 480, "Testing", nil, nil)

Когда я пытаюсь запустить это, я получаю:

libGL error: unable to load driver: rockchip_dri.so
libGL error: driver pointer missing
libGL error: failed to load driver: rockchip
2019/04/14 16:46:56 Link error in program Program(0): ""

Таким образом, похоже, что приложение пытается использовать обычный libGL, и оно терпит неудачу, поскольку оно недоступно. Я посмотрел на связанные библиотеки через ldd:

linux-vdso.so.1 (0x0000007f959b7000)
libGLESv2.so => /usr/lib/aarch64-linux-gnu/libGLESv2.so (0x0000007f957ec000)
libX11.so.6 => /usr/lib/aarch64-linux-gnu/libX11.so.6 (0x0000007f956c3000)
libXrandr.so.2 => /usr/lib/aarch64-linux-gnu/libXrandr.so.2 (0x0000007f956a9000)
libXcursor.so.1 => /usr/lib/aarch64-linux-gnu/libXcursor.so.1 (0x0000007f95690000)
libm.so.6 => /lib/aarch64-linux-gnu/libm.so.6 (0x0000007f955d6000)
libXinerama.so.1 => /usr/lib/aarch64-linux-gnu/libXinerama.so.1 (0x0000007f955c3000)
libdl.so.2 => /lib/aarch64-linux-gnu/libdl.so.2 (0x0000007f955ae000)
libpthread.so.0 => /lib/aarch64-linux-gnu/libpthread.so.0 (0x0000007f95582000)
libc.so.6 => /lib/aarch64-linux-gnu/libc.so.6 (0x0000007f95429000)
/lib/ld-linux-aarch64.so.1 (0x0000007f9598c000)
libdrm.so.2 => /usr/lib/aarch64-linux-gnu/libdrm.so.2 (0x0000007f9540a000)
libXfixes.so.3 => /usr/lib/aarch64-linux-gnu/libXfixes.so.3 (0x0000007f953f4000)
libXext.so.6 => /usr/lib/aarch64-linux-gnu/libXext.so.6 (0x0000007f953d4000)
libXdamage.so.1 => /usr/lib/aarch64-linux-gnu/libXdamage.so.1 (0x0000007f953c1000)
librt.so.1 => /lib/aarch64-linux-gnu/librt.so.1 (0x0000007f953aa000)
libxcb.so.1 => /usr/lib/aarch64-linux-gnu/libxcb.so.1 (0x0000007f9537a000)
libXrender.so.1 => /usr/lib/aarch64-linux-gnu/libXrender.so.1 (0x0000007f95361000)
libXau.so.6 => /usr/lib/aarch64-linux-gnu/libXau.so.6 (0x0000007f9534e000)
libXdmcp.so.6 => /usr/lib/aarch64-linux-gnu/libXdmcp.so.6 (0x0000007f95339000)
libbsd.so.0 => /lib/aarch64-linux-gnu/libbsd.so.0 (0x0000007f95317000)

Таким образом, исполняемый файл правильно связан с libGLESv2, а не с libGL (как и ожидалось; я настроил флаг компоновщика -lGLESv2). Поскольку libGL отсутствует в возвращаемом списке, он не должен загружаться исполняемым файлом. Как это возможно, что я все еще получаю эту ошибку? Я предполагаю, что это как-то связано с конфигурацией X11, но разве об этом не позаботится GLFW?

...