Go to file
2016-02-29 15:43:58 +01:00
inc add option to send Transport Stream instead of Elementary Stream + rename option -T -> -p in order to use -T for TS 2016-01-16 21:15:14 +01:00
src remove useless include 2016-02-21 23:43:35 +01:00
v4l2wrapper@95a99a01ab upgrade v4l2wrapper 2015-09-06 20:07:24 +02:00
.coveralls.yml add coveralls 2016-01-30 11:19:10 +01:00
.gitignore try to build raspberry on travis 2015-10-31 22:58:30 +01:00
.gitmodules extract V4L2 wrapper 2015-01-22 19:42:08 +00:00
.travis.yml install python-yaml for coveralls 2016-02-29 15:43:58 +01:00
CMakeLists.txt add first test running help 2016-01-30 12:43:46 +01:00
LICENSE Initial commit 2013-11-09 15:08:44 -08:00
raspberry.toolchain fix cross-compiling package 2015-11-21 19:03:31 +01:00
README.md add license of dependencies in readme and add download link 2016-02-07 17:16:10 +00:00

Build status Coverity Scan Build Status Coverage Status

h264_v4l2_rtspserver

This is an RTSP server feed from an Video4Linux device that support H264 capture.

The RTSP server support :

  • RTP/UDP unicast
  • RTP/UDP multicast
  • RTP/TCP
  • RTP/RTSP/HTTP

License

Domain public

Dependencies

Download

Latest build

Build

cmake . && make

If it fails you will need to install libv4l-dev liblivemedia-dev liblog4cpp5-dev.
If it still not work you will need to read Makefile.

Install

make install

Build Package

cpack .
dpkg -i h264_v4l2_rtspserver*.deb

Using Raspberry Pi Camera

This RTSP server works using Raspberry Pi camera with :

Using with v4l2loopback

For camera providing uncompress format v4l2tools can compress the video to an intermediate virtual V4L2 device v4l2loopback:

/dev/video0 (camera device)-> v4l2compress_h264 -> /dev/video10 (v4l2loopback device) -> h264_v4l2_rtspserver

This workflow could be set using :

modprobe v4l2loopback video_nr=10
v4l2compress_h264 /dev/video0 /dev/video10 &
h264_v4l2_rtspserver /dev/video10 &

Usage

./h264_v4l2_rtspserver [-v[v]] [-Q queueSize] [-O file] \
		       [-I interface] [-P RTSP port] [-T RTSP/HTTP port] [-m multicast url] [-u unicast url] [-M multicast addr] [-c] [-t timeout] \
		       [-r] [-s] [-W width] [-H height] [-F fps] [device1] [device2]
	 -v       : verbose
	 -vv      : very verbose
	 -Q length: Number of frame queue  (default 10)
	 -O output: Copy captured frame to a file or a V4L2 device
	 RTSP options :
	 -I addr  : RTSP interface (default autodetect)
	 -P port  : RTSP port (default 8554)
	 -T port  : RTSP over HTTP port (default 0)
	 -u url   : unicast url (default unicast)
	 -m url   : multicast url (default multicast)
	 -M addr  : multicast group:port (default is random_address:20000)
	 -c       : don't repeat config (default repeat config before IDR frame)
	 -t secs  : RTCP expiration timeout (default 65)
	 V4L2 options :
	 -r       : V4L2 capture using read interface (default use memory mapped buffers)
	 -s       : V4L2 capture using live555 mainloop (default use a separated reading thread)
	 -f       : V4L2 capture using current format (-W,-H,-F are ignored)
	 -W width : V4L2 capture width (default 640)
	 -H height: V4L2 capture height (default 480)
	 -F fps   : V4L2 capture framerate (default 25)
	 device   : V4L2 capture device (default /dev/video0)