User:Mjb/Serviio

From Offset
< User:Mjb
Revision as of 00:36, 27 June 2019 by Mjb (talk | contribs) (Roku Stick support)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigationJump to search

Serviio is a streaming media server. I use it to allow UPnP/DLNA-capable devices to access video, audio and image files on my computer. For example, I can use my TV, through my Blu-Ray Disc (BD) player, to watch videos that are on a network drive accessible to the computer that runs Serviio.

Transcoding

DLNA devices are supposed to be able to tell Serviio what formats they can handle natively, but some do not, or they do but don't provide enough detail. For example, they might be able to play a certain format, but they don't mention that it's only if the video bitrate is under a certain threshold. Serviio can transcode these unplayable files, and it supports many devices out of the box. Still, you may well have to add custom support for your devices, depending on what you're trying to play.

The transcoding configuration is in device "profiles" in Serviio's %ProgramFiles%\Serviio\config\profiles.xml file. Nowadays, instead of editing that file directly, you should create a new file named user-profiles.xml, and put your enhancements in there. The format is the same as for profiles.xml, i.e.

<?xml version="1.0" encoding="UTF-8"?>
<Profiles version="1.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="http://www.serviio.org/xsd/profiles/v/1.9/Profiles.xsd">
...
</Profiles>

("..." is one or more Profile elements, as shown in the examples below.)

(You don't need a special XML editor; any simple text editor will do, although on Windows, Notepad is less than ideal due to quirky handling of line breaks. If you make a crucial mistake when editing, Serviio will not start. A message in the serviio.log file will tell you where the error is.)

More info: http://serviio.org/index.php?option=com_content&view=article&id=24

Something not clear in the documentation: For the most part, "extending" a profile means you are actually overriding any elements you specify. So if you add a Transcoding section, this replaces the entire Transcoding section of the source profile, except for the parts of the source profile which have forceInheritance="true". Those parts are inherited as if you had explicitly added that content to the end of your Transcoding section. If there are conflicts, the first match wins, so the inherited parts are always lowest priority.

My user-profiles.xml

Here's what I am using currently in my user-profiles.xml.

Samsung BD-C6500 support

To enhance support for my Blu-Ray player, a BD-C6500, which is one of the older Samsung "C" models. As compared to the Samsung B/C profile, which works pretty well, I am adding the following features:

  • Remux any FLV file which contains H.264 video (older YouTube rips mainly)
  • Transcode any of the following to an MPEG-TS stream with MPEG-2 video (max. 11 Mbps) + AC-3 audio:
    • Any other FLV file
    • Any MPEG-PS (VOB) file containing PCM audio (this player cannot play such audio correctly, at least when streamed)
    • Any file containing DTS audio (this player does its own DTS to DD transcoding if using optical out, but I prefer to do it myself)
    • Any file containing DTS-HD audio (I don't think this player handles it at all)
    • Any file containing non-QuickTime H.264 High 4.1 to 5.1 video (probably only 1080p content with bitrates too high to handle)
    • Any file containing H.264 level 4.0 to 5.1 video (QuickTime only due to the previous rule; e.g. 1080p30 iPhone videos)
    • Any file containing H.264 High 4:2:2, 4:4:4, or 10 video (I made some 4:2:2 versions of DV rips)
    • Any file containing VC-1 (despite being natively supported, the bitrate is likely to be too high for streaming)

Some 1080p and even 720p content can still have too-high of bitrate for this player to handle, even if it is not H.264 High 4.1, but Serviio does not yet have a way of matching files based on their bitrate. Matching the codec and profile/level combo is the best we can do. Further complicating things is that the profile or level is not always detected, so a High 4.1 video may fail to get transcoded.

When transcoding to MPEG, these particular Samsung players do not allow navigating forward and back within the stream.

<Profile id="SamsungBDC6500" name="Samsung BD-C6500" extendsProfileId="7">
	<!--
	The user manual says it supports the following:
		audio file types: MP3, WMA
		video must be 1920x1080 max
		AVI video: DivX 3.11/4.x/5.1/6.0, XviD, MP4v3, H.264 BP/MP/HP
		AVI audio: MP3, AC3, DTS, WMA, PCM
		MKV video: VC-1 AP, DivX 5.1/6.0, XviD, H.264 BP/MP/HP
		MKV audio: MP3, AC3, DTS
		WMV video: VC-1 AP, VC-1 SM
		WMV audio: WMA
		MP4 video: MP4, H.264 BP/MP/HP
		MP4 audio: AAC
		MPEG-PS/TS video: MPEG1, MPEG2, H.264 BP/MP/HP
		MPEG-PS/TS audio: MP1, MP2, AC3, DTS
	Observed limitations:
		max. video bitrate seems to be about 17 Mbps, and at 1080p more like 11 Mbps.
		1080p30 High 4.0 QuickTime (e.g. iPhone) MOVs won't play.
	-->
	<Detection>
		<HttpHeaders>
			<User-Agent>.*SEC_HHP_BD-C6500.*</User-Agent>
		</HttpHeaders>
	</Detection>
	<H264LevelCheck>ANY</H264LevelCheck><!--see http://forum.serviio.org/viewtopic.php?f=7&t=24645 -->
	<Transcoding>
		<Video targetContainer="mpegts">
			<Matches container="flv" vCodec="h264"/>
		</Video>
		<Video targetContainer="mpegts" targetVCodec="mpeg2video" targetACodec="ac3" aBitrate="448" maxVBitrate="11000" forceVTranscoding="true">
			<Matches container="flv"/>
			<Matches container="matroska" aCodec="lpcm"/>
			<Matches container="mpeg" aCodec="lpcm"/>
			<Matches container="*" aCodec="dca"/>
			<Matches container="*" aCodec="dts-hd"/>
			<Matches container="*" aCodec="eac3"/>
			<Matches container="*" vCodec="h264" profile="high" levelGreaterThan="4.0" ftypNotIn="qt"/>
			<Matches container="*" vCodec="h264" levelGreaterThan="3.2"/><!--will also match unknown profile-->
			<Matches container="*" vCodec="h264" profile="high_422"/>
			<Matches container="*" vCodec="h264" profile="high_444"/>
			<Matches container="*" vCodec="h264" profile="high_10"/>
			<Matches container="*" vCodec="theora"/>
			<Matches container="*" vCodec="vc1"/>
		</Video>
		<!--not inherited from profile 7 because it had no forceInheritance="true"-->
		<Video targetContainer="asf" targetACodec="ac3" aBitrate="256">
			<Matches container="asf" aCodec="wmapro"/>
		</Video>
		<!--not inherited from profile 7 because it had no forceInheritance="true"-->
		<Audio targetContainer="lpcm">
			<Matches container="flac"/>
			<Matches container="wav"/>
		</Audio>
	</Transcoding>
	<!--not inherited from profile 7 because it had no forceInheritance="true"-->
	<OnlineTranscoding>
		<Video targetContainer="mpegts" targetACodec="ac3" aBitrate="384">
			<Matches container="mp4" vCodec="h264"/>
			<Matches container="applehttp" vCodec="h264"/>
			<Matches container="flv" vCodec="h264"/>
		</Video>		
		<Video targetContainer="mpegts" targetVCodec="mpeg2video" targetACodec="ac3" aBitrate="384">
			<Matches container="mp4"/>
			<Matches container="asf"/> <!-- mms -->
		</Video>
	</OnlineTranscoding>
</Profile>

Roku Stick support

In 2018 I added Roku Sticks to my TVs, plugging them directly into the TVs' HDMI ports:

  • a Samsung "A" model from 2008 – this TV has no configurable audio options to speak of, but if connected via optical S/PDIF to an AVR, it does pass-through Dolby Digital and DTS.
  • an Insignia model from 2010 – this TV can be configured for PCM stereo or "RAW" pass-through, but I have only been able to pass-through Dolby Digital, not DTS, and the Roku does not want to send it Dolby Digital even if configured to do so.

I have two Denon AVRs (audio/video receivers):

  • a 2000 model with optical S/PDIF input, supporting basic 5.1 surround: Dolby Digital or DTS.
  • a 2005 model with HDMI input & output, supporting HD 7.1 surround including Dolby Digital, Dolby Digital Plus, DTS, DTS-HD, and several other flavors of DTS.

As of 2019, the Insignia TV is plugged into the HDMI output of the newer AVR, and the Roku Stick is plugged into an HDMI input on that AVR. This setup works much better, audio-wise, than having the Roku Stick plugged into the TV.

Anyway, I was not having much luck with the Roku profiles that came with Serviio, so I made my own:

<Profile id="RokuStick" name="Roku Media Player on Roku Stick" extendsProfileId="RokuNo4kApp">
	<!--
	A profile for my Roku Stick (model 3800, made in 2017).
	It assumes the TV/AVR can handle Dolby Digital (AC-3) and DTS.
	See RokuStickStereo profile for a Stereo-only configuration.

	The help screen in the app says these formats are supported:
	Video(H.264) - MKV, MOV, MP4
	Audio - AAC, MP3, WMA, WAV(PCM), AIFF, FLAC
	Audio - Ogg
	Photo - JPEG, PNG(2Kx2K), GIF(2Kx2K)

	The help screen also says "Dolby Digital is supported via pass through
	on MKV, MP4 and MOV files. DTS is supported via pass through on MKV."

	https://support.roku.com/article/208754908-how-to-use-roku-media-player-to-play-your-videos-music-and-photos
	has more info and more formats mentioned.

	Here is what I have found is actually supported:

		For DLNA-streamed transcoded video:
			Encapsulation: MPEG-TS only
			Video codec: H.264 (AVC), MPEG-4 ASP (DivX, XviD)
			Audio codec: E-AC-3 (Dolby Digital Plus), AC-3 (Dolby Digital), DTS, MP3, AAC

		For DLNA-served video files:
			Container: MP4, MOV, MKV, FLV
				Soft subtitles are supported (as "closed captions") if embedded in an MKV.
			Video codec: H.264, DivX, XviD
			Audio codec (stereo or mono): LPCM, E-AC-3, AC-3, MP3, AAC
			Audio codec (multichannel): DTS in MKV, E-AC-3 in MKV, AC-3 in MKV, AAC in MKV or MP4 (maybe in others too?)

		For DLNA-streamed transcoded audio:
			Audio codec: MP3 (maybe others, but not LPCM)

		For DLNA-served audio files:
			Audio codec/container: LPCM in WAV, AAC in MP4 (.m4a), MP3, WMA, AIFF, FLAC, Ogg Vorbis

		Restrictions:
			H.264 profile must not be High 4:2:2, High 4:4:4, or High 10.
			H.264 level must not be higher than 4.2.
			Bitrate must not be too high (not sure of limit but 100 Mbps is too high, 10 w/45 peaks is OK. SDK says 10 w/15 peaks supported by all Rokus).
			Bitrate must not be too high for your WiFi router to handle.
			Key frame interval must be less than 10 seconds (per SDK; I did not test this).
			Multichannel audio in an MP4 container must be AAC; AC-3 multichannel is only supported in MKV containers.
			If the Roku audio mode is Stereo, AC-3 & DTS audio streams are ignored, even if they are not multichannel.
			If the Roku HDMI audio mode does not include DTS, DTS audio streams are ignored.
			WMA, MP3, and AAC audio streams are output as PCM, and multichannel AAC is downmixed to stereo.
			(Some Roku models, but not the Stick, will automatically transcode ("decode") E-AC-3 or multichannel AAC to AC-3 if needed.)

		TODO:
			Test multichannel audio: which codec (DTS, E-AC-3, AC-3, AAC) is supported by which containers (MP4, MOV, MKV, FLV)?
			Test files on USB instead of DLNA
			Figure out how to get VOBsubs to come through as hardsubs (enabling hardsubs in console did not help)

	Serviio tells Roku Media Player what files exist and what formats they will be
	delivered in. If Roku Media Player does not support the delivery format, then the
	file won't show up in the Roku Media Player at all. So if you see the file, the	app
	will at least accept the stream and attempt to send its content to the Roku, and on
	to whatever the Roku is plugged in to. However, playback can still fail due to the
	settings and the capabilities of the Roku, TV, and audio gear.

	The Roku Stick has 2 audio settings:
		Audio mode (Stereo or Auto)
		HDMI (Auto, PCM-Stereo, Dolby D, Dolby D+, Dolby D & DTS, or Dolby D+ & DTS)

	Since this Roku model does not do "decoding" (transcoding) of multichannel formats,
	the audio mode you choose results in the following:
	 	Stereo: Stereo/mono audio is sent as stereo PCM; AC-3 & DTS (even if stereo) are silent.
		Auto: it uses what is chosen in the HDMI setting.
	
	In other words, if you choose Stereo mode, or you choose Auto mode with HDMI set to
	PCM-Stereo, then you must make Serviio transcode all your multichannel audio
	because the Roku will not do it for you.

	If the HDMI setting is Auto, the Roku tries to determine the capability of whatever
	it is plugged into. If it is plugged directly into an AVR, it should just work.
	But if it is plugged into a TV, it may only detect PCM-Stereo, which displays as
	Auto (Stereo), even if the TV is capable of and configured for Dolby/DTS raw
	bitstream pass-through to an AVR, soundbar, etc., so you may have to manually set
	this to whatever non-Auto setting actually works, keeping in mind that some TVs may
	only support some formats (both of mine seem to only support Dolby Digital
	pass-through, no DTS, Dolby Digital Plus, or DTS-HD). Furthermore, even when the TV
	supports Dolby Digital pass-through, I have found that on some TVs (e.g. a 2010
	Insignia TV configured for RAW audio pass-through, connected to an AVR), the Roku
	auto-detects Dolby D, or I can set Dolby D myself, but the Roku never actually
	outputs anything but stereo or mono PCM. The TV does Dolby pass-through from other
	devices (a BD player and a satellite receiver/PVR) without any problems. I asked
	around about it and no one knows for sure what is happening.

	If the Roku is plugged into a TV which can do audio transcoding (most can't), you
	could configure the Roku and your transcoding profile to simply send everything the
	TV can handle. Otherwise, you have to send only what your TV or TV+AVR combo can
	handle, and transcode everything else.
	-->
	<Transcoding>
		<!--unsupported container w/supported video and supported, remuxable audio: remux only-->
		<!--consider remuxing these types of files to MKV or MP4 so they will play natively!-->
		<Video targetContainer="mpegts" forceInheritance="true">
			<Matches container="avi" vCodec="h264" aCodec="aac" aMultichannel="false"/>
			<Matches container="avi" vCodec="h264" aCodec="mp3"/>
			<Matches container="avi" vCodec="mpeg4" aCodec="aac" aMultichannel="false"/>
			<Matches container="avi" vCodec="mpeg4" aCodec="mp3"/>
			<Matches container="avi" vCodec="msmpeg4" aCodec="aac" aMultichannel="false"/>
			<Matches container="avi" vCodec="msmpeg4" aCodec="mp3"/>
		</Video>
		<!--unsupported video but supported, remuxable audio: transcode video-->
		<Video targetContainer="mpegts" targetVCodec="h264" forceVTranscoding="true" forceInheritance="true">
			<Matches container="*" heightGreaterThan="1080" aCodec="aac" aMultichannel="false"/>
			<Matches container="*" heightGreaterThan="1080" aCodec="ac3"/>
			<Matches container="*" heightGreaterThan="1080" aCodec="mp3"/>
			<Matches container="*" vCodec="h264" profile="high_10" aCodec="aac" aMultichannel="false"/>
			<Matches container="*" vCodec="h264" profile="high_10" aCodec="ac3"/>
			<Matches container="*" vCodec="h264" profile="high_10" aCodec="mp3"/>
			<Matches container="*" vCodec="h264" profile="high_422" aCodec="aac" aMultichannel="false"/>
			<Matches container="*" vCodec="h264" profile="high_422" aCodec="ac3"/>
			<Matches container="*" vCodec="h264" profile="high_422" aCodec="mp3"/>
			<Matches container="*" vCodec="h264" profile="high_444" aCodec="aac" aMultichannel="false"/>
			<Matches container="*" vCodec="h264" profile="high_444" aCodec="ac3"/>
			<Matches container="*" vCodec="h264" profile="high_444" aCodec="mp3"/>
			<!--L5 is fine but I have an H.264 Main L5 file that is 100 Mbps (too high) and Serviio does not let us match by bitrate.-->
			<Matches container="*" vCodec="h264" profile="main" levelGreaterThan="4.2" aCodec="aac" aMultichannel="false"/>
			<Matches container="*" vCodec="h264" profile="main" levelGreaterThan="4.2" aCodec="ac3"/>
			<Matches container="*" vCodec="h264" profile="main" levelGreaterThan="4.2" aCodec="mp3"/>
			<Matches container="*" vCodec="h265" aCodec="aac" aMultichannel="false"/>
			<Matches container="*" vCodec="h265" aCodec="ac3"/>
			<Matches container="*" vCodec="h265" aCodec="mp3"/>
			<Matches container="*" vCodec="mpeg1video" aCodec="aac" aMultichannel="false"/>
			<Matches container="*" vCodec="mpeg1video" aCodec="ac3"/>
			<Matches container="*" vCodec="mpeg1video" aCodec="mp3"/>
			<Matches container="*" vCodec="mpeg2video" aCodec="aac" aMultichannel="false"/>
			<Matches container="*" vCodec="mpeg2video" aCodec="ac3"/>
			<Matches container="*" vCodec="mpeg2video" aCodec="mp3"/>
			<Matches container="*" vCodec="vc1" aCodec="aac" aMultichannel="false"/>
			<Matches container="*" vCodec="vc1" aCodec="ac3"/>
			<Matches container="*" vCodec="vc1" aCodec="mp3"/>
			<Matches container="*" vCodec="vp6" aCodec="aac" aMultichannel="false"/>
			<Matches container="*" vCodec="vp6" aCodec="mp3"/>
			<Matches container="*" vCodec="vp8" aCodec="aac" aMultichannel="false"/>
			<Matches container="*" vCodec="vp8" aCodec="mp3"/>
			<Matches container="*" vCodec="vp9" aCodec="aac" aMultichannel="false"/>
			<Matches container="*" vCodec="vp9" aCodec="mp3"/>
			<Matches container="*" vCodec="wmv2" aCodec="mp3"/>
		</Video>
		<!--supported non-H.264 video but unsupported audio: transcode audio-->
		<Video targetContainer="mpegts" targetACodec="ac3" aBitrate="512" forceInheritance="true">
			<Matches container="*" vCodec="mpeg4" aCodec="aac" aMultichannel="true"/>
			<Matches container="*" vCodec="mpeg4" aCodec="mp2"/>
			<Matches container="*" vCodec="msmpeg4" aCodec="aac" aMultichannel="true"/>
			<Matches container="*" vCodec="msmpeg4" aCodec="mp2"/>
		</Video>
		<!--unsupported video or audio not handled by the above: transcode audio (always, apparently) and video (if not H.264 already)-->
		<Video targetContainer="mpegts" targetVCodec="h264" targetACodec="ac3" aBitrate="512" forceInheritance="true">
			<Matches container="*" heightGreaterThan="1080"/>
			<Matches container="*" vCodec="h263"/>
			<Matches container="*" vCodec="h265"/>
			<Matches container="*" vCodec="mpeg1video"/>
			<Matches container="*" vCodec="mpeg2video"/>
			<Matches container="*" vCodec="theora"/>
			<Matches container="*" vCodec="vc1"/>
			<Matches container="*" vCodec="wmv2"/>
			<Matches container="*" aCodec="aac" aMultichannel="true"/>
			<Matches container="*" aCodec="flac"/>
			<Matches container="avi"/>
			<Matches container="mpeg"/>
			<Matches container="mpegvideo"/>
			<Matches container="wtv"/>
			<!--requires Servio 2.0-->
			<Matches container="*" vCodec="cinepak"/>
			<Matches container="*" vCodec="svq1"/>
			<Matches container="*" vCodec="svq3"/>
		</Video>
		<Audio targetContainer="mp3" aBitrate="320" forceInheritance="true">
			<Matches container="ape"/>
		</Audio>
		<!--inherited from ancestor profiles: nothing, because they don't have forceInheritance="true"-->
	</Transcoding>
	<!--untested (except AutomaticImageRotation), just copied from RokuNo4kApp profile-->
	<OnlineTranscoding>
		<Video targetContainer="applehttp">
			<Matches container="mp4"/>
			<Matches container="flv" vCodec="h264"/>
			<Matches container="applehttp" vCodec="h264"/>
		</Video>
	</OnlineTranscoding>
	<GenericTranscoding>
		<Video targetContainer="mpegts" targetVCodec="h264" targetACodec="ac3" aBitrate="512"/>
	</GenericTranscoding>
	<LimitImageResolution>false</LimitImageResolution>
	<AutomaticImageRotation>true</AutomaticImageRotation>
</Profile>
<Profile id="RokuStickBasicSurr" name="Roku Media Player on Roku Stick (Basic Surround)" extendsProfileId="RokuStick">
	<!--
		This is what I used with an early 2000s AVR which only supports Dolby Digital and DTS.

		Same as RokuStick configuration, except:
			all E-AC-3 and DTS-HD is transcoded to AC-3 (Dolby Digital 5.1)
	-->
	<Transcoding>
		<Video targetContainer="mpegts" targetVCodec="h264" targetACodec="ac3" aBitrate="512" forceInheritance="true">
			<Matches container="*" aCodec="dts-hd"/>
			<Matches container="*" aCodec="eac3"/>
		</Video>
	</Transcoding>
</Profile>
<Profile id="RokuStickStereo" name="Roku Media Player on Roku Stick (Stereo Only)" extendsProfileId="RokuStick">
	<!--
		UNTESTED!
		Same as RokuStick configuration, except:
			all AC-3 and DTS is transcoded
			all audio transcoding is to stereo AAC
	-->
	<Transcoding>
		<Video targetContainer="mpegts" targetACodec="aac" aBitrate="320" forceStereo="true">
			<Matches container="*" vCodec="mpeg4" aCodec="aac" aMultichannel="true"/>
			<Matches container="*" vCodec="mpeg4" aCodec="mp2"/>
			<Matches container="*" vCodec="msmpeg4" aCodec="aac" aMultichannel="true"/>
			<Matches container="*" vCodec="msmpeg4" aCodec="mp2"/>
		</Video>
		<Video targetContainer="mpegts" targetVCodec="h264" targetACodec="aac" aBitrate="320" forceStereo="true">
			<Matches container="*" vCodec="h263"/>
			<Matches container="*" vCodec="h265"/>
			<Matches container="*" vCodec="mpeg1video"/>
			<Matches container="*" vCodec="mpeg2video"/>
			<Matches container="*" vCodec="theora"/>
			<Matches container="*" vCodec="vc1"/>
			<Matches container="*" vCodec="wmv2"/>
			<Matches container="*" aCodec="aac" aMultichannel="true"/>
			<Matches container="*" aCodec="ac3" aMultichannel="true"/>
			<Matches container="*" aCodec="dca"/>
			<Matches container="*" aCodec="dts-hd"/>
			<Matches container="*" aCodec="eac3" aMultichannel="true"/>
			<Matches container="*" aCodec="flac"/>
			<Matches container="avi"/>
			<Matches container="mpeg"/>
			<Matches container="mpegvideo"/>
			<Matches container="wtv"/>
		</Video>
	</Transcoding>
</Profile>

Dish Hopper support

Here's what I added to create a profile matching the Dish Hopper:

<Profile id="Hopper" name="Dish Hopper" extendsProfileId="1">
	<!--
	video: mp2t, mp1s, mpeg2, mp4, x-matroska
	audio: mpeg, mpeg3, mp3, mp4, mp4-latm
	image: jpeg

		Does support AAC audio in a video stream.
		If multiple audio streams, only the last one is played.
		If an MJPEG stream exists (e.g. for thumbnail), file will not play.
		Image slideshow is broken (as of May 2018); you can view 1 at a time though.
		Does not support H.264 in an MPEG-TS stream, so must transcode to MPEG-2 video.
	-->
	<Detection>
		 <UPnPSearch>
			<ModelName>.*Hopper.*</ModelName>
			<Manufacturer>Echostar.*</Manufacturer>
		 </UPnPSearch>
	</Detection>
	<Transcoding>
		<Video targetContainer="mpegts" targetVCodec="mpeg2video" maxVBitrate="15000" maxHeight="720">
			<Matches container="*" vCodec="h264" levelGreaterThan="4.1" aCodec="aac"/>
			<Matches container="*" vCodec="h265" levelGreaterThan="4.1" aCodec="aac"/>
		</Video>
		<Video targetContainer="mpegts" targetVCodec="mpeg2video" maxVBitrate="15000">
			<!-- unsupported video with AAC or MP3 audio: transcode video only -->
			<Matches container="*" vCodec="h264" levelGreaterThan="4.1" aCodec="aac"/>
			<Matches container="*" vCodec="h264" profile="high_422" aCodec="aac"/>
			<Matches container="*" vCodec="h264" profile="high_444" aCodec="aac"/>
			<Matches container="*" vCodec="h264" profile="high_10" aCodec="aac"/>
			<Matches container="*" vCodec="h265" aCodec="aac"/>
			<Matches container="*" vCodec="mpeg4" aCodec="aac"/>
			<Matches container="*" vCodec="mpeg4" aCodec="mp3"/>
			<Matches container="avi" aCodec="aac"/>
			<Matches container="avi" aCodec="mp3"/>
			<Matches container="flv" aCodec="aac"/>
			<Matches container="flv" aCodec="mp3"/>
			<!--
			not working; see http://forum.serviio.org/viewtopic.php?f=7&t=24545
			<Matches container="*" vCodec="svq3" aCodec="aac"/>
			<Matches container="*" vCodec="svq3" aCodec="mp3"/>
			-->
		</Video>
		<Video targetContainer="mpegts" targetVCodec="mpeg2video" maxVBitrate="15000" targetACodec="ac3" aBitrate="448">
			<Matches container="*" aCodec="dca"/>
			<Matches container="*" aCodec="dts-hd"/>
			<Matches container="*" aCodec="eac3"/>
			<Matches container="*" aCodec="lpcm"/>
			<Matches container="*" vCodec="dvvideo"/>
			<Matches container="*" vCodec="h264" levelGreaterThan="4.1"/>
			<Matches container="*" vCodec="h264" profile="high_422"/>
			<Matches container="*" vCodec="h264" profile="high_444"/>
			<Matches container="*" vCodec="h264" profile="high_10"/>
			<Matches container="*" vCodec="h265"/>
			<Matches container="*" vCodec="mpeg4"/>
			<Matches container="*" vCodec="theora"/>
			<Matches container="*" vCodec="vc1"/>
			<Matches container="*" vCodec="wmv2"/>
			<Matches container="avi"/>
			<Matches container="flv"/>
			<!--
			not working; see http://forum.serviio.org/viewtopic.php?f=7&t=24545
			<Matches container="*" vCodec="cvid"/>
			<Matches container="*" vCodec="svq1"/>
			<Matches container="*" vCodec="svq3"/>
			-->
		</Video>
		<Audio targetContainer="mp3" aBitrate="320">
			<Matches container="ape"/>
			<Matches container="flac"/>
			<Matches container="lpcm"/>
			<Matches container="ogg"/>
		</Audio>
	</Transcoding>
</Profile>

H.264 levels above 3.1 can exceed 17 Mbps and 480p. Ideally we would only transcode those videos which actually need it, based on bitrate, but Serviio does not make this possible. So the question is, do you transcode all H.264 files above level 3.1, including those with lower bitrates which would play OK normally, or do you pick a higher level like 4.0 or 4.1 because those are more likely to have higher bitrates, taking the risk that some of your vids which need to be transcoded will not be? I am going with a 4.1 cutoff for now, and will see how it does.

nPlayer on iPad support

On iOS devices like the iPad or iPhone, there are various apps you can use as DLNA renderers. The iPad can even output HDMI via an adapter.

The free-of-charge options are quite limited. I found that the non-free but cheap nPlayer app works very well. It plays almost every format natively, so the default profile in Serviio works well enough; it natively plays pretty much everything, and is easy to use.

Strangely, my first-generation iPad does quite well with H.264 content in an MP4/MOV or MKV container, but H.264 in an MPEG-TS stream, like you get when transcoding, totally brings it to its knees if you don't massively constrain the bitrate. I wonder if there is a better way.

<Profile id="nPlayer-iPad1" name="nPlayer on iPad (1st Gen)" extendsProfileId="1">
	<!--
		nPlayer caches like crazy. If it doesn't show up in Serviio Console,
		try deleting the Serviio entry from nPlayer's UPnP/DLNA network servers,
		so it can find it again and let Serviio know it's out there.

		Working video:
			containers: MKV, MP4, AVI, MPEG-TS, MPEG-PS
			video codecs: H.264 up to High L5, MPEG-1, MPEG-2, MPEG4, VP6, WMV, MJPEG, Theora
			audio codecs: AC-3, AAC, MP2, MP3, WMA, PCM, ADPCM(CCITT), OGG
			audio in MPEG-TS: AC-3, MP3, MP2

		Non-working video codecs:
			DV drops frames and goes out of sync.
			H.263 does not show up when browsing.
			H.264 High L5.1 has no picture.
			H.264 High422 works but drops too many frames on this iPad (even at 480p 24fps).
			H.265 Main 10 L3.1 (at 480p 60fps) and L4 (at 1080p 24fps) stutters & drops many frames.
			VC-1 drops frames when the bitrate spikes (maybe 20 Mbps).
			transcoded video buffers like crazy when the bitrate goes much above 6 Mbps.
			transcoded video is silent if audio is AAC or PCM.

		Working audio:
			containers: FLAC, MP3

		Non-working audio:
			containers: APE
	-->
	<Detection>
		<HttpHeaders>
			<User-Agent>.*nPlayer.*</User-Agent>
		</HttpHeaders>
	</Detection>
	<Transcoding>
		<Video targetContainer="mpegts" targetVCodec="h264" forceVTranscoding="true" targetACodec="ac3" maxVBitrate="6000">
			<Matches container="*" vCodec="dvvideo"/>
			<Matches container="*" vCodec="h263"/>
			<Matches container="*" vCodec="h264" levelGreaterThan="5.0"/>
			<Matches container="*" vCodec="h264" profile="high_422"/>
			<Matches container="*" vCodec="h264" profile="high_444"/>
			<Matches container="*" vCodec="h264" profile="high_10"/>
			<Matches container="*" vCodec="h265"/>
			<Matches container="*" vCodec="vc1"/>
		</Video>
		<Audio targetContainer="lpcm">
			<Matches container="ape"/>
		</Audio>
	</Transcoding>
</Profile>

Logitech Media Server and Squeezebox Boom support

I don't think I will be using LMS or my Squeezebox Boom to access audio via DLNA devices, but if I ever do, here is what each supports (as reported by UPnP Spy):

Logitech Media Server:

http-get:*:audio/L16;rate=44100;channels=2:DLNA.ORG_PN=LPCM,
http-get:*:audio/mp4:DLNA.ORG_PN=AAC_ISO;DLNA.ORG_OP=01;DLNA.ORG_FLAGS=01700000000000000000000000000000,
http-get:*:audio/mp4:DLNA.ORG_PN=AAC_ISO_192;DLNA.ORG_OP=01;DLNA.ORG_FLAGS=01700000000000000000000000000000,
http-get:*:audio/mp4:DLNA.ORG_PN=AAC_ISO_320;DLNA.ORG_OP=01;DLNA.ORG_FLAGS=01700000000000000000000000000000,
http-get:*:audio/mpeg:DLNA.ORG_PN=MP3;DLNA.ORG_OP=11;DLNA.ORG_FLAGS=01700000000000000000000000000000,
http-get:*:audio/mpeg:DLNA.ORG_PN=MP3X;DLNA.ORG_OP=01;DLNA.ORG_FLAGS=01700000000000000000000000000000,
http-get:*:audio/x-ms-wma:DLNA.ORG_PN=WMABASE;DLNA.ORG_OP=11;DLNA.ORG_FLAGS=01700000000000000000000000000000,
http-get:*:image/jpeg:DLNA.ORG_PN=JPEG_TN;DLNA.ORG_OP=01;DLNA.ORG_FLAGS=00f00000000000000000000000000000,
http-get:*:image/png:DLNA.ORG_PN=PNG_TN;DLNA.ORG_OP=01;DLNA.ORG_FLAGS=00f00000000000000000000000000000,
http-get:*:audio/mp4:*,
http-get:*:audio/mpeg:*,
http-get:*:audio/x-flac:*,
http-get:*:audio/x-m4a-lossless:*,
http-get:*:audio/x-ogg:*

Squeezebox Boom:

http-get:*:audio/mpeg:*,
http-get:*:audio/L16;rate=8000;channels=1:*,
http-get:*:audio/L16;rate=8000;channels=2:*,
http-get:*:audio/L16;rate=11025;channels=1:*,
http-get:*:audio/L16;rate=11025;channels=2:*,
http-get:*:audio/L16;rate=12000;channels=1:*,
http-get:*:audio/L16;rate=12000;channels=2:*,
http-get:*:audio/L16;rate=16000;channels=1:*,
http-get:*:audio/L16;rate=16000;channels=2:*,
http-get:*:audio/L16;rate=22050;channels=1:*,
http-get:*:audio/L16;rate=22050;channels=2:*,
http-get:*:audio/L16;rate=24000;channels=1:*,
http-get:*:audio/L16;rate=24000;channels=2:*,
http-get:*:audio/L16;rate=32000;channels=1:*,
http-get:*:audio/L16;rate=32000;channels=2:*,
http-get:*:audio/L16;rate=44100;channels=1:*,
http-get:*:audio/L16;rate=44100;channels=2:*,
http-get:*:audio/L16;rate=48000;channels=1:*,
http-get:*:audio/L16;rate=48000;channels=2:*,
http-get:*:audio/vnd.dlna.adts:*,
http-get:*:audio/vnd.dlna.adts:*,
http-get:*:audio/mp4:*,
http-get:*:audio/mp4:*,
http-get:*:audio/mp4:*,
http-get:*:audio/x-ms-wma:*,
http-get:*:audio/x-ms-wma:*,
http-get:*:audio/x-ms-wma:*,
http-get:*:application/ogg:*,
http-get:*:audio/x-flac:*

Interlaced video

Serviio does not know how to recognize interlaced video, so it does not invoke FFmpeg with the correct parameters for transcoding it. The resulting video is always progressive scan, so it sometimes appears jumpy/jittery because the interlacing wasn't taken into account during transcoding.

The developer has said that part of the problem is that ffmpeg -i does not reliably report whether video is interlaced. He's right; see my notes about processing interlaced content with FFmpeg.

Still, I think it would be nice if Serviio would just trust the metadata when it does happen to say the video is interlaced, i.e. when ffmpeg -i mentions "bottom first" or "top first" or "tv" (I think). If the metadata is wrong or missing, this is a "not my problem" kind of problem.

Example of a file which does mention it:

Stream #0:1[0x1e0]: Video: mpeg2video (Main), yuv420p(tv, bottom first), 720x576 [SAR 16:15 DAR 4:3], 25 fps, 25 tbr, 90k tbn, 50 tbc

Unfortunately, this metadata is not always present, e.g. this DV video is interlaced, bottom first, but you wouldn't know it by the ffmpeg -i output:

Stream #0:0: Video: dvvideo (dvsd / 0x64737664), yuv411p, 720x480 [SAR 8:9 DAR 4:3], 28778 kb/s, 29.97 fps, 29.97 tbr, 29.97 tbn, 29.97 tbc

Somehow, MediaInfo reads something in this same file to know whether it is interlaced and which field is first. Why can't FFmpeg do this?

That said, I think you can know just by the fact that all DV video is interlaced and is bottom field first, unless it is DVCPRO Progressive (in which case it is progressive) or DVCPRO HD (in which case it could be either progressive or interlaced). I found some DVCPRO HD clips at http://www.gvgdevelopers.com/concrete/products/k2/test_clips/ and they are reported as "dvvideo (dvh1 / 031687664)" for both PAL and NTSC, so maybe Serviio could just assume all dvvideo is interlaced unless 'dvvideo (dvh' is spotted.

Well anyway, you have to transcode interlaced files yourself, for now.

If you deinterlace progressive content, the result is not horrible, but it's not ideal. It just makes motion blurrier.

Questions:

  • What happens when you blindly deinterlace telecine content? Are the results acceptable?
  • There is a related issue where FFmpeg may report an H.264 file's "tbr" frame rate as being double the "fps" rate. This happens when a progressive-scan input was converted to "PsF" interlaced for broadcast. Serviio tells FFmpeg to convert these videos to the tbr rate, which is incorrect. I don't know what effect this has on the video. See discussion and issue tracker. I am wondering whether you should deinterlace this type content.

Java updates

In the past, I had to completely shut down Serviio before updating Java (64-bit). See my notes on Java updates for more info.

Lately, I have not even had the 64-bit version of Java installed, and Serviio and Java both update just fine. *shrug*

Serviio disappeared after router change

After replacing my WiFi router with an AirPort Time Capsule, Serviio on my Win7 PC was no longer seen by my BD player. Serviio running on a Mac on the same network had no problem. Both computers are using a wired connection to the router. Disabling firewalls on the PC didn't make a difference. I eventually figured out a solution, but didn't make a note of what it was. Oh well.