bsnes/libco/doc/targets.md

1.7 KiB

Supported targets

In the following lists, supported targets are only those that have been tested and confirmed working. It is quite possible that libco will work on more processors, compilers and operating systems than those listed below.

The "Overhead" is the cost of switching co-routines, as compared to an ordinary C function call.

libco.x86

  • Overhead: ~5x
  • Supported processor(s): 32-bit x86 *** Supported compiler(s**): any
  • Supported operating system(s):
    • Windows
    • Mac OS X
    • Linux
    • BSD

libco.amd64

  • Overhead: ~10x (Windows), ~6x (all other platforms)
  • Supported processor(s): 64-bit amd64 *** Supported compiler(s**): any
  • Supported operating system(s):
    • Windows
    • Mac OS X
    • Linux
    • BSD

libco.ppc

  • Overhead: ~20x
  • Supported processor(s): 32-bit PowerPC, 64-bit PowerPC
  • Supported compiler(s): GNU GCC
  • Supported operating system(s):
    • Mac OS X
    • Linux
    • BSD
    • Playstation 3

Note: this module contains compiler flags to enable/disable FPU and Altivec support.

libco.fiber

This uses Windows' "fibers" API.

  • Overhead: ~15x
  • Supported processor(s): Processor independent
  • Supported compiler(s): any
  • Supported operating system(s):
    • Windows

libco.sjlj

This uses the C standard library's setjump/longjmp APIs.

  • Overhead: ~30x
  • Supported processor(s): Processor independent
  • Supported compiler(s): any
  • Supported operating system(s):
    • Mac OS X
    • Linux
    • BSD
    • Solaris

libco.ucontext

This uses the POSIX "ucontext" API.

  • Overhead: ~300x
  • Supported processor(s): Processor independent
  • Supported compiler(s): any
  • Supported operating system(s):
    • Linux
    • BSD