tree: 0823245641278943435571f48fe782b1088bae9e [path history] [tgz]
  1. alsa/
  2. bsd/
  3. deviceauth/
  4. dlmalloc/
  5. egl/
  6. ffmpeg/
  7. gcc/
  8. gles/
  9. input/
  10. iso/
  11. lib/
  12. libaom/
  13. libdav1d/
  14. libde265/
  15. libevent/
  16. libjpeg/
  17. libvpx/
  18. linux/
  19. media_session/
  20. nouser/
  21. opus/
  22. posix/
  23. pthread/
  24. pulse/
  25. signal/
  26. speechd/
  27. starboard/
  28. stub/
  29. test_webapi_extension/
  30. widevine/
  31. x11/
  32. __init__.py
  33. _env.py
  34. internal_only.h
  35. README.md
starboard/shared/README.md

Starboard Shared Implementations

src/starboard/shared and subdirectories contain all implementation code that could concievably be shared between platforms.

Organization

As much code as possible is pushed into the shared directory. Each subdirectory foo means “files in here depend on foo.”

All source locations are specified relative to src/starboard/.

  • shared/iso/ - Implementation files that follow ISO C and C++ standards, but standards that are either new, or have historically had poor support on a variety of embedded platforms. Platforms that are ISO-compliant with the latest standards should be able to use these.
  • shared/libevent/ - libevent-specific implementation files, for platforms that can build and run libevent. See shared/libevent/README.md for more information.
  • shared/posix/ - POSIX-specific implementation files. Starboard implementations may pull some or all of this directory to implement Starboard APIs, if the platform is POSIX-compliant.
  • shared/pthread/ - pthread-specific implementation files, for platforms that provide a reasonable implementation of POSIX threads. This is called out separately from POSIX, because we've found that there are some platforms that are fairly POSIX-y, except in their threading APIs.
  • shared/starboard/ - Implementations of Starboard API functions that only rely on other Starboard API functions. Code in here should be reusable on any platform that implements the needed APIs.