| Decoder firmware API description | 
 | ================================ | 
 |  | 
 | Note: this API is part of the decoder firmware, so it's cx23415 only. | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_PING_FW | 
 | Enum 	0/0x00 | 
 | Description | 
 | 	This API call does nothing. It may be used to check if the firmware | 
 | 	is responding. | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_START_PLAYBACK | 
 | Enum 	1/0x01 | 
 | Description | 
 | 	Begin or resume playback. | 
 | Param[0] | 
 | 	0 based frame number in GOP to begin playback from. | 
 | Param[1] | 
 | 	Specifies the number of muted audio frames to play before normal | 
 | 	audio resumes. (This is not implemented in the firmware, leave at 0) | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_STOP_PLAYBACK | 
 | Enum 	2/0x02 | 
 | Description | 
 | 	Ends playback and clears all decoder buffers. If PTS is not zero, | 
 | 	playback stops at specified PTS. | 
 | Param[0] | 
 | 	Display 0=last frame, 1=black | 
 | 	Note: this takes effect immediately, so if you want to wait for a PTS, | 
 | 	then use '0', otherwise the screen goes to black at once. | 
 | 	You can call this later (even if there is no playback) with a 1 value | 
 | 	to set the screen to black. | 
 | Param[1] | 
 | 	PTS low | 
 | Param[2] | 
 | 	PTS high | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_SET_PLAYBACK_SPEED | 
 | Enum 	3/0x03 | 
 | Description | 
 | 	Playback stream at speed other than normal. There are two modes of | 
 | 	operation: | 
 | 	    Smooth: host transfers entire stream and firmware drops unused | 
 | 		    frames. | 
 | 	    Coarse: host drops frames based on indexing as required to achieve | 
 | 		    desired speed. | 
 | Param[0] | 
 | 	Bitmap: | 
 | 	    0:7  0 normal | 
 | 		 1 fast only "1.5 times" | 
 | 		 n nX fast, 1/nX slow | 
 | 	    30   Framedrop: | 
 | 		     '0' during 1.5 times play, every other B frame is dropped | 
 | 		     '1' during 1.5 times play, stream is unchanged (bitrate | 
 | 			 must not exceed 8mbps) | 
 | 	    31   Speed: | 
 | 		     '0' slow | 
 | 		     '1' fast | 
 | 	Note: n is limited to 2. Anything higher does not result in | 
 | 	faster playback. Instead the host should start dropping frames. | 
 | Param[1] | 
 | 	Direction: 0=forward, 1=reverse | 
 | 	Note: to make reverse playback work you have to write full GOPs in | 
 | 	reverse order. | 
 | Param[2] | 
 | 	Picture mask: | 
 | 	    1=I frames | 
 | 	    3=I, P frames | 
 | 	    7=I, P, B frames | 
 | Param[3] | 
 | 	B frames per GOP (for reverse play only) | 
 | 	Note: for reverse playback the Picture Mask should be set to I or I, P. | 
 | 	Adding B frames to the mask will result in corrupt video. This field | 
 | 	has to be set to the correct value in order to keep the timing correct. | 
 | Param[4] | 
 | 	Mute audio: 0=disable, 1=enable | 
 | Param[5] | 
 | 	Display 0=frame, 1=field | 
 | Param[6] | 
 | 	Specifies the number of muted audio frames to play before normal audio | 
 | 	resumes. (Not implemented in the firmware, leave at 0) | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_STEP_VIDEO | 
 | Enum 	5/0x05 | 
 | Description | 
 | 	Each call to this API steps the playback to the next unit defined below | 
 | 	in the current playback direction. | 
 | Param[0] | 
 | 	0=frame, 1=top field, 2=bottom field | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_SET_DMA_BLOCK_SIZE | 
 | Enum 	8/0x08 | 
 | Description | 
 | 	Set DMA transfer block size. Counterpart to API 0xC9 | 
 | Param[0] | 
 | 	DMA transfer block size in bytes. A different size may be specified | 
 | 	when issuing the DMA transfer command. | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_GET_XFER_INFO | 
 | Enum 	9/0x09 | 
 | Description | 
 | 	This API call may be used to detect an end of stream condition. | 
 | Result[0] | 
 | 	Stream type | 
 | Result[1] | 
 | 	Address offset | 
 | Result[2] | 
 | 	Maximum bytes to transfer | 
 | Result[3] | 
 | 	Buffer fullness | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_GET_DMA_STATUS | 
 | Enum 	10/0x0A | 
 | Description | 
 | 	Status of the last DMA transfer | 
 | Result[0] | 
 | 	Bit 1 set means transfer complete | 
 | 	Bit 2 set means DMA error | 
 | 	Bit 3 set means linked list error | 
 | Result[1] | 
 | 	DMA type: 0=MPEG, 1=OSD, 2=YUV | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_SCHED_DMA_FROM_HOST | 
 | Enum 	11/0x0B | 
 | Description | 
 | 	Setup DMA from host operation. Counterpart to API 0xCC | 
 | Param[0] | 
 | 	Memory address of link list | 
 | Param[1] | 
 | 	Total # of bytes to transfer | 
 | Param[2] | 
 | 	DMA type (0=MPEG, 1=OSD, 2=YUV) | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_PAUSE_PLAYBACK | 
 | Enum 	13/0x0D | 
 | Description | 
 | 	Freeze playback immediately. In this mode, when internal buffers are | 
 | 	full, no more data will be accepted and data request IRQs will be | 
 | 	masked. | 
 | Param[0] | 
 | 	Display: 0=last frame, 1=black | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_HALT_FW | 
 | Enum 	14/0x0E | 
 | Description | 
 | 	The firmware is halted and no further API calls are serviced until | 
 | 	the firmware is uploaded again. | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_SET_STANDARD | 
 | Enum 	16/0x10 | 
 | Description | 
 | 	Selects display standard | 
 | Param[0] | 
 | 	0=NTSC, 1=PAL | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_GET_VERSION | 
 | Enum 	17/0x11 | 
 | Description | 
 | 	Returns decoder firmware version information | 
 | Result[0] | 
 | 	Version bitmask: | 
 | 	    Bits  0:15 build | 
 | 	    Bits 16:23 minor | 
 | 	    Bits 24:31 major | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_SET_STREAM_INPUT | 
 | Enum 	20/0x14 | 
 | Description | 
 | 	Select decoder stream input port | 
 | Param[0] | 
 | 	0=memory (default), 1=streaming | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_GET_TIMING_INFO | 
 | Enum 	21/0x15 | 
 | Description | 
 | 	Returns timing information from start of playback | 
 | Result[0] | 
 | 	Frame count by decode order | 
 | Result[1] | 
 | 	Video PTS bits 0:31 by display order | 
 | Result[2] | 
 | 	Video PTS bit 32 by display order | 
 | Result[3] | 
 | 	SCR bits 0:31 by display order | 
 | Result[4] | 
 | 	SCR bit 32 by display order | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_SET_AUDIO_MODE | 
 | Enum 	22/0x16 | 
 | Description | 
 | 	Select audio mode | 
 | Param[0] | 
 | 	Dual mono mode action | 
 | 	    0=Stereo, 1=Left, 2=Right, 3=Mono, 4=Swap, -1=Unchanged | 
 | Param[1] | 
 | 	Stereo mode action: | 
 | 	    0=Stereo, 1=Left, 2=Right, 3=Mono, 4=Swap, -1=Unchanged | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_SET_EVENT_NOTIFICATION | 
 | Enum 	23/0x17 | 
 | Description | 
 | 	Setup firmware to notify the host about a particular event. | 
 | 	Counterpart to API 0xD5 | 
 | Param[0] | 
 | 	Event: 0=Audio mode change between mono, (joint) stereo and dual channel. | 
 | 	Event: 3=Decoder started | 
 | 	Event: 4=Unknown: goes off 10-15 times per second while decoding. | 
 | 	Event: 5=Some sync event: goes off once per frame. | 
 | Param[1] | 
 | 	Notification 0=disabled, 1=enabled | 
 | Param[2] | 
 | 	Interrupt bit | 
 | Param[3] | 
 | 	Mailbox slot, -1 if no mailbox required. | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_SET_DISPLAY_BUFFERS | 
 | Enum 	24/0x18 | 
 | Description | 
 | 	Number of display buffers. To decode all frames in reverse playback you | 
 | 	must use nine buffers. | 
 | Param[0] | 
 | 	0=six buffers, 1=nine buffers | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_EXTRACT_VBI | 
 | Enum 	25/0x19 | 
 | Description | 
 | 	Extracts VBI data | 
 | Param[0] | 
 | 	0=extract from extension & user data, 1=extract from private packets | 
 | Result[0] | 
 | 	VBI table location | 
 | Result[1] | 
 | 	VBI table size | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_SET_DECODER_SOURCE | 
 | Enum 	26/0x1A | 
 | Description | 
 | 	Selects decoder source. Ensure that the parameters passed to this | 
 | 	API match the encoder settings. | 
 | Param[0] | 
 | 	Mode: 0=MPEG from host, 1=YUV from encoder, 2=YUV from host | 
 | Param[1] | 
 | 	YUV picture width | 
 | Param[2] | 
 | 	YUV picture height | 
 | Param[3] | 
 | 	Bitmap: see Param[0] of API 0xBD | 
 |  | 
 | ------------------------------------------------------------------------------- | 
 |  | 
 | Name 	CX2341X_DEC_SET_PREBUFFERING | 
 | Enum 	30/0x1E | 
 | Description | 
 | 	Decoder prebuffering, when enabled up to 128KB are buffered for | 
 | 	streams <8mpbs or 640KB for streams >8mbps | 
 | Param[0] | 
 | 	0=off, 1=on |