mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-25 02:12:03 +01:00
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:
parent
9dc103491a
commit
9c070eb2f3
@ -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
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user