SmolRTSP is a simple RTSP 1.0 server library tailored for embedded devices, such as IP cameras. It supports both TCP and UDP, allows any payload format, and provides a convenient and flexible API.
- Small. SmolRTSP is designed for use in embedded systems (e.g., IP cameras).
- Unopinionated. You can use SmolRTSP with bare POSIX sockets, libevent, or any other network framework.
- Zero-copy. SmolRTSP does not allocate or copy data while parsing.
- Battle-tested. SmolRTSP is used by Majestic, an IP camera streamer developed by OpenIPC.
- Supported protocols:
- Supported RTP payload formats:
- H.264 (RFC 6184)
- H.265 (RFC 7798)
- H.266 / VVC (RFC 9328)
- JPEG XS (RFC 9134) -- codestream and slice packetization modes
- AV1 (AOMedia AV1 RTP) -- one OBU per packet with Z/Y fragmentation
If you use CMake, the recommended way is FetchContent:
include(FetchContent)
FetchContent_Declare(
smolrtsp
URL https://github.com/OpenIPC/smolrtsp/archive/refs/tags/v1.2.3.tar.gz # v1.2.3
)
FetchContent_MakeAvailable(smolrtsp)
target_link_libraries(MyProject smolrtsp)| Option | Description | Default |
|---|---|---|
SMOLRTSP_SHARED |
Build a shared library instead of static. | OFF |
SMOLRTSP_FULL_MACRO_EXPANSION |
Show full macro expansion backtraces (DANGEROUS: may impair diagnostics and slow down compilation). | OFF |
A simple example server that streams H.264 video and G.711 Mu-Law audio can be found at examples/server.c. The same server can also advertise additional streams: pass -DENABLE_JPEGXS=ON for JPEG XS on the /jpegxs path, -DENABLE_AV1=ON for AV1 on the /av1 path, or -DENABLE_VVC=ON for H.266 / VVC on the /vvc path.
Run it as follows:
$ mkdir examples/build
$ cd examples/build
$ cmake .. && cmake --build .
$ sudo ./server
Then open a new terminal window to start playing:
$ ffplay rtsp://localhost
SmolRTSP is agnostic to a network backend: you can run it atop of any network/event loop framework. Currently, we support the following integrations:
Feel free to extend this list with your own integration code.
- Update the
PROJECT_NUMBERfield inDoxyfile. - Update
CHANGELOG.md. - Release the project in GitHub Releases.