diff --git a/Makefile b/Makefile
index d3bdfb065..47ed09b6d 100644
--- a/Makefile
+++ b/Makefile
@@ -88,8 +88,9 @@ endif
ifeq ($(PLAT),hp-ux)
CC = gcc
+ CFLAGS += -std=c99 -D_POSIX_C_SOURCE=200112L -D_XOPEN_SOURCE=600 -D_DEFAULT_SOURCE -D_BSD_SOURCE
LDFLAGS =
- LIBS = -lm -lX11 -lXi -lXext -L/opt/graphics/OpenGL/lib -lGL -lpthread
+ LIBS = -lm -lX11 -lXi -lXext -L/opt/graphics/OpenGL/lib/hpux32 -lGL -lpthread
BUILD_DIR = build/hpux
endif
diff --git a/readme.md b/readme.md
index 363a4027f..5ad5c02ae 100644
--- a/readme.md
+++ b/readme.md
@@ -74,6 +74,7 @@ And also runs on:
* Haiku - needs openal
package (if you have a GitHub account, can [download from here](https://github.com/ClassiCube/ClassiCube/actions/workflows/build_haiku.yml))
* BeOS - untested on actual hardware
* IRIX - needs openal
packages
+* HPUX - tested on 11v3 IA64
* SerenityOS - needs SDL2
* Classic Mac OS (System 7 and later)
* Dreamcast - unfinished, but usable (can [download from here](https://www.classicube.net/download/dreamcast))
diff --git a/src/Core.h b/src/Core.h
index 4e5226f3f..3848f3954 100644
--- a/src/Core.h
+++ b/src/Core.h
@@ -362,6 +362,7 @@ typedef cc_uint8 cc_bool;
#define CC_BIG_ENDIAN
#define CC_BUILD_NOMUSIC
#define CC_BUILD_NOSOUNDS
+ #define CC_BUILD_GL11_FALLBACK
#define DEFAULT_NET_BACKEND CC_NET_BACKEND_BUILTIN
#define DEFAULT_AUD_BACKEND CC_AUD_BACKEND_NULL
#define DEFAULT_GFX_BACKEND CC_GFX_BACKEND_GL1
diff --git a/src/Graphics_GL1.c b/src/Graphics_GL1.c
index 01b3e6e7e..a8d5fc9bf 100644
--- a/src/Graphics_GL1.c
+++ b/src/Graphics_GL1.c
@@ -207,27 +207,27 @@ void Gfx_SetDynamicVbData(GfxResourceID vb, void* vertices, int vCount) {
#define IB_PTR NULL
static void GL_SetupVbColoured(void) {
- _glVertexPointer(3, GL_FLOAT, SIZEOF_VERTEX_COLOURED, VB_PTR + 0);
- _glColorPointer(4, GL_UNSIGNED_BYTE, SIZEOF_VERTEX_COLOURED, VB_PTR + 12);
+ _glVertexPointer(3, GL_FLOAT, SIZEOF_VERTEX_COLOURED, (GLpointer)(VB_PTR + 0));
+ _glColorPointer(4, GL_UNSIGNED_BYTE, SIZEOF_VERTEX_COLOURED, (GLpointer)(VB_PTR + 12));
}
static void GL_SetupVbTextured(void) {
- _glVertexPointer(3, GL_FLOAT, SIZEOF_VERTEX_TEXTURED, VB_PTR + 0);
- _glColorPointer(4, GL_UNSIGNED_BYTE, SIZEOF_VERTEX_TEXTURED, VB_PTR + 12);
- _glTexCoordPointer(2, GL_FLOAT, SIZEOF_VERTEX_TEXTURED, VB_PTR + 16);
+ _glVertexPointer(3, GL_FLOAT, SIZEOF_VERTEX_TEXTURED, (GLpointer)(VB_PTR + 0));
+ _glColorPointer(4, GL_UNSIGNED_BYTE, SIZEOF_VERTEX_TEXTURED, (GLpointer)(VB_PTR + 12));
+ _glTexCoordPointer(2, GL_FLOAT, SIZEOF_VERTEX_TEXTURED, (GLpointer)(VB_PTR + 16));
}
static void GL_SetupVbColoured_Range(int startVertex) {
cc_uint32 offset = startVertex * SIZEOF_VERTEX_COLOURED;
- _glVertexPointer(3, GL_FLOAT, SIZEOF_VERTEX_COLOURED, VB_PTR + offset + 0);
- _glColorPointer(4, GL_UNSIGNED_BYTE, SIZEOF_VERTEX_COLOURED, VB_PTR + offset + 12);
+ _glVertexPointer(3, GL_FLOAT, SIZEOF_VERTEX_COLOURED, (GLpointer)(VB_PTR + offset + 0));
+ _glColorPointer(4, GL_UNSIGNED_BYTE, SIZEOF_VERTEX_COLOURED, (GLpointer)(VB_PTR + offset + 12));
}
static void GL_SetupVbTextured_Range(int startVertex) {
cc_uint32 offset = startVertex * SIZEOF_VERTEX_TEXTURED;
- _glVertexPointer(3, GL_FLOAT, SIZEOF_VERTEX_TEXTURED, VB_PTR + offset + 0);
- _glColorPointer(4, GL_UNSIGNED_BYTE, SIZEOF_VERTEX_TEXTURED, VB_PTR + offset + 12);
- _glTexCoordPointer(2, GL_FLOAT, SIZEOF_VERTEX_TEXTURED, VB_PTR + offset + 16);
+ _glVertexPointer(3, GL_FLOAT, SIZEOF_VERTEX_TEXTURED, (GLpointer)(VB_PTR + offset + 0));
+ _glColorPointer(4, GL_UNSIGNED_BYTE, SIZEOF_VERTEX_TEXTURED, (GLpointer)(VB_PTR + offset + 12));
+ _glTexCoordPointer(2, GL_FLOAT, SIZEOF_VERTEX_TEXTURED, (GLpointer)(VB_PTR + offset + 16));
}
void Gfx_SetVertexFormat(VertexFormat fmt) {
@@ -267,9 +267,9 @@ void Gfx_DrawVb_IndexedTris(int verticesCount) {
void Gfx_DrawIndexedTris_T2fC4b(int verticesCount, int startVertex) {
cc_uint32 offset = startVertex * SIZEOF_VERTEX_TEXTURED;
- _glVertexPointer(3, GL_FLOAT, SIZEOF_VERTEX_TEXTURED, VB_PTR + offset + 0);
- _glColorPointer(4, GL_UNSIGNED_BYTE, SIZEOF_VERTEX_TEXTURED, VB_PTR + offset + 12);
- _glTexCoordPointer(2, GL_FLOAT, SIZEOF_VERTEX_TEXTURED, VB_PTR + offset + 16);
+ _glVertexPointer(3, GL_FLOAT, SIZEOF_VERTEX_TEXTURED, (GLpointer)(VB_PTR + offset + 0));
+ _glColorPointer(4, GL_UNSIGNED_BYTE, SIZEOF_VERTEX_TEXTURED, (GLpointer)(VB_PTR + offset + 12));
+ _glTexCoordPointer(2, GL_FLOAT, SIZEOF_VERTEX_TEXTURED, (GLpointer)(VB_PTR + offset + 16));
_glDrawElements(GL_TRIANGLES, ICOUNT(verticesCount), GL_UNSIGNED_SHORT, IB_PTR);
}
@@ -585,7 +585,7 @@ static void APIENTRY gl10_colorPointer(GLint size, GLenum type, GLsizei stride,
static void APIENTRY gl10_texCoordPointer(GLint size, GLenum type, GLsizei stride, GLpointer offset) {
}
static void APIENTRY gl10_vertexPointer(GLint size, GLenum type, GLsizei stride, GLpointer offset) {
- gl10_vb = cur_vb->data + offset;
+ gl10_vb = cur_vb->data + (cc_uintptr)offset;
}
diff --git a/src/Logger.c b/src/Logger.c
index c1ffd251a..b614179b5 100644
--- a/src/Logger.c
+++ b/src/Logger.c
@@ -280,6 +280,12 @@ static void DumpFrame(cc_string* trace, void* addr) {
cc_uintptr addr_ = (cc_uintptr)addr;
String_Format1(trace, "%x", &addr_);
}
+#elif defined CC_BUILD_HPUX
+/* HP-UX doesn't expose a nice interface for dladdr */
+static void DumpFrame(cc_string* trace, void* addr) {
+ cc_uintptr addr_ = (cc_uintptr)addr;
+ String_Format1(trace, "%x", &addr_);
+}
#elif defined CC_BUILD_POSIX && !defined CC_BUILD_OS2
/* need to define __USE_GNU for dladdr */
#ifndef __USE_GNU
@@ -455,6 +461,11 @@ void Logger_Backtrace(cc_string* trace, void* ctx) {
String_AppendConst(trace, "-- backtrace unimplemented --");
/* There is no dladdr on Symbian */
}
+#elif defined CC_BUILD_HPUX
+/* HP-UX doesn't have unwind support */
+void Logger_Backtrace(cc_string* trace, void* ctx) {
+ String_AppendConst(trace, "-- backtrace unimplemented --");
+}
#elif defined CC_BUILD_POSIX
/* musl etc - rely on unwind from GCC instead */
#define CC_BACKTRACE_UNWIND
diff --git a/src/Platform_Posix.c b/src/Platform_Posix.c
index 1f5c0dfa9..b07d14b8e 100644
--- a/src/Platform_Posix.c
+++ b/src/Platform_Posix.c
@@ -800,9 +800,16 @@ cc_result Socket_Create(cc_socket* s, cc_sockaddr* addr, cc_bool nonblocking) {
if (*s == -1) return errno;
if (nonblocking) {
+#ifdef CC_BUILD_HPUX
+ int flags = fcntl(*s, F_GETFL, 0);
+ if (flags == -1) return errno;
+ int err = fcntl(*s, F_SETFL, flags | O_NONBLOCK);
+ if (err == -1) return errno;
+#else
int blocking_raw = -1; /* non-blocking mode */
int err = ioctl(*s, FIONBIO, &blocking_raw);
if (err == -1) return errno;
+#endif
}
return 0;
}
diff --git a/src/_GLShared.h b/src/_GLShared.h
index 40c2afa65..8eec7ec8d 100644
--- a/src/_GLShared.h
+++ b/src/_GLShared.h
@@ -80,6 +80,12 @@ static void ConvertRGBA(void* dst, const void* src, int numPixels) {
d[1] = s[2];
d[2] = s[3];
d[3] = s[0];
+#elif defined CC_BUILD_HPUX
+ /* HP-UX specific color channel mapping - try IRIX style G,B,A,R */
+ d[0] = s[1]; /* R = G */
+ d[1] = s[2]; /* G = B */
+ d[2] = s[3]; /* B = A */
+ d[3] = s[0]; /* A = R */
#else
d[0] = s[2];
d[1] = s[1];