Revert "internal/graphicsdriver/gl: use PureGo for Linux and UNIX"

This reverts commit 5701206229.

Reason: error on Android:

```
/Users/runner/go/pkg/mod/github.com/ebitengine/purego@v0.8.0-alpha.0.20240404024320-d0aedd0f4393/func.go:301:4: too few values in struct literal of type syscall15Args
```

https://github.com/hajimehoshi/ebiten/actions/runs/8582651053/job/23521003819
This commit is contained in:
Hajime Hoshi 2024-04-07 03:00:13 +09:00
parent 9dc103491a
commit 9c070eb2f3
3 changed files with 44 additions and 33 deletions

View File

@ -2,7 +2,7 @@
// SPDX-FileCopyrightText: 2014 Eric Woroshow // SPDX-FileCopyrightText: 2014 Eric Woroshow
// SPDX-FileCopyrightText: 2022 The Ebitengine Authors // SPDX-FileCopyrightText: 2022 The Ebitengine Authors
//go:build nintendosdk //go:build !darwin && !js && !windows && !playstation5
package gl package gl

View File

@ -12,7 +12,7 @@
// See the License for the specific language governing permissions and // See the License for the specific language governing permissions and
// limitations under the License. // limitations under the License.
//go:build (darwin || freebsd || linux || netbsd || openbsd || windows) && !nintendosdk && !playstation5 //go:build darwin || windows
package gl package gl

View File

@ -16,18 +16,38 @@
package gl package gl
// #cgo LDFLAGS: -ldl
//
// #include <dlfcn.h>
// #include <stdlib.h>
//
// static void* getProcAddressGL(void* libGL, const char* name) {
// static void*(*glXGetProcAddress)(const char*);
// if (!glXGetProcAddress) {
// glXGetProcAddress = dlsym(libGL, "glXGetProcAddress");
// if (!glXGetProcAddress) {
// glXGetProcAddress = dlsym(libGL, "glXGetProcAddressARB");
// }
// }
// return glXGetProcAddress(name);
// }
//
// static void* getProcAddressGLES(void* libGLES, const char* name) {
// return dlsym(libGLES, name);
// }
import "C"
import ( import (
"fmt" "fmt"
"os" "os"
"runtime" "runtime"
"strings" "strings"
"unsafe"
"github.com/ebitengine/purego"
) )
var ( var (
libGL uintptr libGL unsafe.Pointer
libGLES uintptr libGLES unsafe.Pointer
) )
func (c *defaultContext) init() error { func (c *defaultContext) init() error {
@ -49,8 +69,10 @@ func (c *defaultContext) init() error {
if !preferES { if !preferES {
// Usually libGL.so or libGL.so.1 is used. libGL.so.2 might exist only on NetBSD. // Usually libGL.so or libGL.so.1 is used. libGL.so.2 might exist only on NetBSD.
for _, name := range []string{"libGL.so", "libGL.so.2", "libGL.so.1", "libGL.so.0"} { for _, name := range []string{"libGL.so", "libGL.so.2", "libGL.so.1", "libGL.so.0"} {
lib, err := purego.Dlopen(name, purego.RTLD_LAZY|purego.RTLD_GLOBAL) cname := C.CString(name)
if err == nil { lib := C.dlopen(cname, C.RTLD_LAZY|C.RTLD_GLOBAL)
C.free(unsafe.Pointer(cname))
if lib != nil {
libGL = lib libGL = lib
return nil return nil
} }
@ -59,8 +81,10 @@ func (c *defaultContext) init() error {
// Try OpenGL ES. // Try OpenGL ES.
for _, name := range []string{"libGLESv2.so", "libGLESv2.so.2", "libGLESv2.so.1", "libGLESv2.so.0"} { for _, name := range []string{"libGLESv2.so", "libGLESv2.so.2", "libGLESv2.so.1", "libGLESv2.so.0"} {
lib, err := purego.Dlopen(name, purego.RTLD_LAZY|purego.RTLD_GLOBAL) cname := C.CString(name)
if err == nil { lib := C.dlopen(cname, C.RTLD_LAZY|C.RTLD_GLOBAL)
C.free(unsafe.Pointer(cname))
if lib != nil {
libGLES = lib libGLES = lib
c.isES = true c.isES = true
return nil return nil
@ -72,32 +96,19 @@ func (c *defaultContext) init() error {
func (c *defaultContext) getProcAddress(name string) (uintptr, error) { func (c *defaultContext) getProcAddress(name string) (uintptr, error) {
if c.isES { if c.isES {
return getProcAddressGLES(name) return getProcAddressGLES(name), nil
} }
return getProcAddressGL(name) return getProcAddressGL(name), nil
} }
var glXGetProcAddress func(name string) uintptr func getProcAddressGL(name string) uintptr {
cname := C.CString(name)
func getProcAddressGL(name string) (uintptr, error) { defer C.free(unsafe.Pointer(cname))
if glXGetProcAddress == nil { return uintptr(C.getProcAddressGL(libGL, cname))
if _, err := purego.Dlsym(libGL, "glXGetProcAddress"); err == nil {
purego.RegisterLibFunc(&glXGetProcAddress, libGL, "glXGetProcAddress")
} else if _, err := purego.Dlsym(libGL, "glXGetProcAddressARB"); err == nil {
purego.RegisterLibFunc(&glXGetProcAddress, libGL, "glXGetProcAddressARB")
}
}
if glXGetProcAddress == nil {
return 0, fmt.Errorf("gl: failed to find glXGetProcAddress or glXGetProcAddressARB in libGL.so")
}
return glXGetProcAddress(name), nil
} }
func getProcAddressGLES(name string) (uintptr, error) { func getProcAddressGLES(name string) uintptr {
proc, err := purego.Dlsym(libGLES, name) cname := C.CString(name)
if err != nil { defer C.free(unsafe.Pointer(cname))
return 0, err return uintptr(C.getProcAddressGLES(libGLES, cname))
}
return proc, nil
} }