Skip to content

A simple wrapper for sokol_gfx enabling multithreaded rendering.

Notifications You must be signed in to change notification settings

oviano/sokol-multithread

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 

Repository files navigation

A simple wrapper for sokol_gfx (see https://github.com/floooh/sokol) enabling multithreaded rendering.

Typically you would use it as follows:

Render thread

  • create renderer instance, passing sg_desc to initialise sokol graphics
  • call renderer->set_default_pass_size() and again whenever back buffer size changes
  • call renderer->execute_commands() in render loop
  • call renderer->wait_for_flush() on termination
  • delete renderer instance

Update thread

  • call renderer->add_command_xxx() commands in a similar manner to how you would call sg_xxx() commands
  • call renderer->commit_commands() when you're done for the frame
  • call renderer->flush_commands() on termination, before exiting the thread

Resources

When creating or updating resources (buffers, images etc) it is up to the caller to ensure that any pointers passed into an add_command_xxx() call made in the update thread remain valid until the underlying sg_xxx() command has been issued from the render thread.

To help with this, you can optionally schedule clean-ups via the renderer->schedule_cleanup() function which allows user-provided callbacks to be called after all the commands to create the resources have been executed.

These cleanup calls can be used to free up the memory or clean-up any objects that own the memory and avoids the need for the wrapper to make any copies of data. For convenience, these calls are also made from the update thread from inside a later commit_commands() call.

About

A simple wrapper for sokol_gfx enabling multithreaded rendering.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages