GLdc: an OpenGL implementation for the SEGA Dreamcast
Go to file
Luke Benstead aa383913cd Merge branch 'nonPOT2glTexSubImage2D' into 'master'
update for glTexSubImage2D, now checks the active texture size and not the...

See merge request simulant/GLdc!136
2024-12-07 23:27:52 +00:00
containers Move aligned_vector_reserve onto cold path since it should rarely be called 2024-10-05 11:34:14 +10:00
GL Merge branch 'nonPOT2glTexSubImage2D' into 'master' 2024-12-07 23:27:52 +00:00
include/GL Fix lines 2024-10-02 19:00:05 +10:00
samples Fix bug in allocations (thanks @skmp) 2024-12-07 19:35:40 +00:00
tests Fix continuous free count 2024-12-07 19:54:16 +00:00
toolchains Fix .elf extension on C example executables 2023-03-04 16:11:11 -06:00
tools Implement defragmenting the memory 2023-09-08 17:49:46 +01:00
.gitattributes Ignore the noise... Just testing something. 2014-08-30 13:33:02 -04:00
.gitignore Add dcbuild & pcbuild folders to .gitignore 2023-03-04 16:10:34 -06:00
.gitlab-ci.yml Build out to libGL.a instead of libGLdc.a 2023-11-29 11:25:52 +00:00
CMakeLists.txt Add primitive modes sample, quad strips partially work 2024-10-02 19:28:02 +10:00
LICENSE Create LICENSE 2018-05-20 19:51:36 +01:00
README.md Update README 2023-04-17 19:35:06 +02:00

GLdc

Development of GLdc has moved to Gitlab

This is a partial implementation of OpenGL 1.2 for the SEGA Dreamcast for use with the KallistiOS SDK.

It began as a fork of libGL by Josh Pearson but has undergone a large refactor which is essentially a rewrite.

The aim is to implement as much of OpenGL 1.2 as possible, and to add additional features via extensions.

Things left to (re)implement:

  • Spotlights (Trivial)
  • Framebuffer extension (Trivial)
  • Texture Matrix (Trivial)

Things I'd like to do:

  • Use a clean "gl.h"
  • Define an extension for modifier volumes
  • Add support for point sprites
  • Optimise, add unit tests for correctness

Compiling

GLdc uses CMake for its build system, it currently ships with two "backends":

  • kospvr - This is the hardware-accelerated Dreamcast backend
  • software - This is a stub software rasterizer used for testing testing and debugging

To compile a Dreamcast debug build, you'll want to do something like the following:

mkdir dcbuild
cd dcbuild
cmake -DCMAKE_TOOLCHAIN_FILE=../toolchains/Dreamcast.cmake -G "Unix Makefiles" ..
make

For a release build, replace the cmake line with with the following:

cmake -DCMAKE_TOOLCHAIN_FILE=../toolchains/Dreamcast.cmake -G "Unix Makefiles" -DCMAKE_BUILD_TYPE=Release ..

You will need KallistiOS compiled and configured (e.g. the KOS_BASE environment variable must be set)

To compile for PC:

mkdir pcbuild
cd pcbuild
cmake -G "Unix Makefiles" ..
make

Special Thanks!

  • Massive shout out to Hayden Kowalchuk for diagnosing and fixing a large number of bugs while porting GL Quake to the Dreamcast. Absolute hero!