Native code integration
In Membrane we try to make use of Elixir goodness as often as possible. However, sometimes it is necessary to write some native code, for example to integrate with existing native libraries. To achieve that, we use natives, which are either NIFs or CNodes. Both of them have their drawbacks: CNodes introduce inter-process communication, while NIFs can even crash entire VM in case of failure. That's why we use them only when necessary and created some tools to make dealing with them easier.
bundlex
Bundlex
To simplify and unify the process of writing and compiling natives, we use our own build tool - Bundlex. It is a multi-platform tool that provides a convenient way of compiling and accessing natives from Elixir code. For more information, see Bundlex's GitHub page.
unifex
Unifex
Process of creating natives is not only difficult but also quite arduous, because it requires using cumbersome Erlang APIs,
and thus a lot of boilerplate code. To make it more pleasant, Membrane Framework provides
Unifex, a tool that is responsible for generating interfaces between
simple C libraries and Elixir on the base of short .exs
configuration files. Unifex currently supports only NIFs,
but support for CNodes is planned.
A quick introduction to Unifex is available here.
membrane-common-c
Membrane Common C
Membrane Framework also delivers some useful C routines which might be useful for creating natives. Membrane Common C package exports the following functionalities:
- an interface to Membrane logger,
- a ringbuffer,
- implementation of
Membrane.Payload.Behaviour
wrapping Shmex) allowing to use shared memory segments as payload in Membrane elements.