Lines Matching +full:video +full:- +full:decoder

1 .. SPDX-License-Identifier: GPL-2.0
7 -----------------------
12 .. note:: the memory long words are little-endian ('intel format').
21 .. code-block:: none
23 ivtvctl -O min=0x02000000,max=0x020000ff
26 register space :-).
35 .. code-block:: none
37 0x00000000-0x00ffffff Encoder memory space
38 0x00000000-0x0003ffff Encode.rom
39 ???-??? MPEG buffer(s)
40 ???-??? Raw video capture buffer(s)
41 ???-??? Raw audio capture buffer(s)
42 ???-??? Display buffers (6 or 9)
44 0x01000000-0x01ffffff Decoder memory space
45 0x01000000-0x0103ffff Decode.rom
46 ???-??? MPEG buffers(s)
47 0x0114b000-0x0115afff Audio.rom (deprecated?)
49 0x02000000-0x0200ffff Register Space
57 .. code-block:: none
59 DMA Registers 0x000-0xff:
61 0x00 - Control:
63 0x04 - DMA status:
65 0x08 - pci DMA pointer for read link list
66 0x0c - pci DMA pointer for write link list
67 0x10 - read/write DMA enable:
69 0x14 - always 0xffffffff, if set any lower instability occurs, 0x00 crashes
70 0x18 - ??
71 0x1c - always 0x20 or 32, smaller values slow down DMA transactions
72 0x20 - always value of 0x780a010a
73 0x24-0x3c - usually just random values???
74 0x40 - Interrupt status
75 0x44 - Write a bit here and shows up in Interrupt status 0x40
76 0x48 - Interrupt Mask
77 0x4C - always value of 0xfffdffff,
79 0x50 - always 0xffffffff
80 0x54 - always 0xffffffff (0x4c, 0x50, 0x54 seem like interrupt masks, are
83 0x60-0x7C - random values
84 0x80 - first write linked list reg, for Encoder Memory addr
85 0x84 - first write linked list reg, for pci memory addr
86 0x88 - first write linked list reg, for length of buffer in memory addr
88 0x8c-0xdc - rest of write linked list reg, 8 sets of 3 total, DMA goes here
91 0xe0 - first (and only) read linked list reg, for pci memory addr
92 0xe4 - first (and only) read linked list reg, for Decoder memory addr
93 0xe8 - first (and only) read linked list reg, for length of buffer
94 0xec-0xff - Nothing seems to be in these registers, 0xec-f4 are 0x00000000.
96 Memory locations for Encoder Buffers 0x700-0x7ff:
101 - 0x07F8: Encoder SDRAM refresh
102 - 0x07FC: Encoder SDRAM pre-charge
104 Memory locations for Decoder Buffers 0x800-0x8ff:
109 - 0x08F8: Decoder SDRAM refresh
110 - 0x08FC: Decoder SDRAM pre-charge
114 - 0x2800: Video Display Module control
115 - 0x2D00: AO (audio output?) control
116 - 0x2D24: Bytes Flushed
117 - 0x7000: LSB I2C write clock bit (inverted)
118 - 0x7004: LSB I2C write data bit (inverted)
119 - 0x7008: LSB I2C read clock bit
120 - 0x700c: LSB I2C read data bit
121 - 0x9008: GPIO get input state
122 - 0x900c: GPIO set output state
123 - 0x9020: GPIO direction (Bit7 (GPIO 0..7) - 0:input, 1:output)
124 - 0x9050: SPU control
125 - 0x9054: Reset HW blocks
126 - 0x9058: VPU control
127 - 0xA018: Bit6: interrupt pending?
128 - 0xA064: APU command
138 - bit 31 Encoder Start Capture
139 - bit 30 Encoder EOS
140 - bit 29 Encoder VBI capture
141 - bit 28 Encoder Video Input Module reset event
142 - bit 27 Encoder DMA complete
143 - bit 24 Decoder audio mode change detection event (through event notification)
144 - bit 22 Decoder data request
145 - bit 20 Decoder DMA complete
146 - bit 19 Decoder VBI re-insertion
147 - bit 18 Decoder DMA err (linked-list bad)
150 ---------------------
152 - Encoder API post(?)
153 - Decoder API post(?)
154 - Decoder VTRACE event
158 ---------------------------
170 - Each firmware image is 256k bytes.
171 - The 1st 32-bit word of the Encoder image is 0x0000da7
172 - The 1st 32-bit word of the Decoder image is 0x00003a7
173 - The 2nd 32-bit word of both images is 0xaa55bb66
178 - Issue the FWapi command to stop the encoder if it is running. Wait for the
180 - Issue the FWapi command to stop the decoder if it is running. Wait for the
182 - Issue the I2C command to the digitizer to stop emitting VSYNC events.
183 - Issue the FWapi command to halt the encoder's firmware.
184 - Sleep for 10ms.
185 - Issue the FWapi command to halt the decoder's firmware.
186 - Sleep for 10ms.
187 - Write 0x00000000 to register 0x2800 to stop the Video Display Module.
188 - Write 0x00000005 to register 0x2D00 to stop the AO (audio output?).
189 - Write 0x00000000 to register 0xA064 to ping? the APU.
190 - Write 0xFFFFFFFE to register 0x9058 to stop the VPU.
191 - Write 0xFFFFFFFF to register 0x9054 to reset the HW blocks.
192 - Write 0x00000001 to register 0x9050 to stop the SPU.
193 - Sleep for 10ms.
194 - Write 0x0000001A to register 0x07FC to init the Encoder SDRAM's pre-charge.
195 - Write 0x80000640 to register 0x07F8 to init the Encoder SDRAM's refresh to 1us.
196 - Write 0x0000001A to register 0x08FC to init the Decoder SDRAM's pre-charge.
197 - Write 0x80000640 to register 0x08F8 to init the Decoder SDRAM's refresh to 1us.
198 - Sleep for 512ms. (600ms is recommended)
199 - Transfer the encoder's firmware image to offset 0 in Encoder memory space.
200 - Transfer the decoder's firmware image to offset 0 in Decoder memory space.
201 - Use a read-modify-write operation to Clear bit 0 of register 0x9050 to
202 re-enable the SPU.
203 - Sleep for 1 second.
204 - Use a read-modify-write operation to Clear bits 3 and 0 of register 0x9058
205 to re-enable the VPU.
206 - Sleep for 1 second.
207 - Issue status API commands to both firmware images to verify.
211 ----------------------------
214 mailboxes are basically a fixed length array that serves as the call-stack.
216 Firmware mailboxes can be located by searching the encoder and decoder memory
217 for a 16 byte signature. That signature will be located on a 256-byte boundary.
221 .. code-block:: none
226 The firmware implements 20 mailboxes of 20 32-bit words. The first 10 are
237 4-19 Parameter/Result
252 The command is a 32-bit enumerator. The API specifics may be found in this
255 The return value is a 32-bit enumerator. Only two values are currently defined:
257 - 0=success
258 - -1=command undefined.
260 There are 16 parameters/results 32-bit fields. The driver populates these fields
286 ----------------------------
288 .. note:: this API is part of the decoder firmware, so it's cx23415 only.
348 - 0=8bit index
349 - 1=16bit RGB 5:6:5
350 - 2=16bit ARGB 1:5:5:5
351 - 3=16bit ARGB 1:4:4:4
352 - 4=32bit ARGB 8:8:8:8
369 - Bit 0 0=off, 1=on
370 - Bits 1:2 alpha control
371 - Bits 3:5 pixel format
400 Retrieve coordinates of OSD area blended with video
437 Assign the coordinates of the OSD area to blend with video
506 Assign the coordinates of the screen area to blend with video
648 .. code-block:: none
673 - '01' source_alpha
674 - '10' destination_alpha
675 - '11' source_alpha*destination_alpha+1
681 .. code-block:: none
689 (255 - source_alpha)*destination_pixel)/256
694 output_pixel = ((255 - destination_alpha)*source_pixel +
961 --------------------------------
983 Commences the capture of video, audio and/or VBI data. All encoding
992 - 0=MPEG
993 - 1=Raw
994 - 2=Raw passthrough
995 - 3=VBI
1003 - Bit 0 when set, captures YUV
1004 - Bit 1 when set, captures PCM audio
1005 - Bit 2 when set, captures VBI (same as param[0]=3)
1006 - Bit 3 when set, the capture destination is the decoder
1008 - Bit 4 when set, the capture destination is the host
1027 - 0=stop at end of GOP (generates IRQ)
1028 - 1=stop immediate (no IRQ)
1067 Set video transport stream ID
1072 Video stream ID
1101 Set video frames per second. Change occurs at start of new GOP.
1106 - 0=30fps
1107 - 1=25fps
1119 Select video stream encoding resolution.
1141 Assign average video stream bitrate.
1199 For example: IBBPBBPBBPBB --> GOP size: 12, number of B frames: 2+1 = 3
1203 GOP size must be a multiple of (B-frames + 1).
1221 - '0000' forbidden
1222 - '0001' 1:1 square
1223 - '0010' 4:3
1224 - '0011' 16:9
1225 - '0100' 2.21:1
1226 - '0101' to '1111' reserved
1251 - 0=Disabled
1252 - 1=Horizontal
1253 - 2=Vertical
1254 - 3=Horiz/Vert
1255 - 4=Diagonal
1333 - 0=Off
1334 - 1=1D Horizontal
1335 - 2=1D Vertical
1336 - 3=2D H/V Separable (default)
1337 - 4=2D Symmetric non-separable
1344 - 0=Off
1345 - 1=1D Horizontal (default)
1362 - Bits 0:4 line number
1363 - Bit 31 0=top_field, 1=bottom_field
1364 - Bits 0:31 all set specifies "all lines"
1410 - 0=Program stream
1411 - 1=Transport stream
1412 - 2=MPEG1 stream
1413 - 3=PES A/V stream
1414 - 5=PES Video stream
1415 - 7=PES Audio stream
1416 - 10=DVD stream
1417 - 11=VCD stream
1418 - 12=SVCD stream
1419 - 13=DVD_S1 stream
1420 - 14=DVD_S2 stream
1434 (pvrusb and cx88-blackbird).
1439 - 0=Memory (default)
1440 - 1=Streaming
1441 - 2=Serial
1467 - '11' Layer I
1468 - '10' Layer II
1469 - '01' Layer III
1470 - '00' Undefined
1481 .. code-block:: none
1493 ------+-------------+------------
1513 and mode are allowed. See ISO11172-3 3-Annex B,
1514 Table 3-B.2
1528 '00' subbands 4-31 in intensity_stereo, bound==4
1529 '01' subbands 8-31 in intensity_stereo, bound==8
1530 '10' subbands 12-31 in intensity_stereo, bound==12
1531 '11' subbands 16-31 in intensity_stereo, bound==16
1580 - Bits 0:15 build
1581 - Bits 16:23 minor
1582 - Bits 24:31 major
1599 - 0=Open
1600 - 1=Closed
1641 .. code-block:: c
1647 u32 mask1; // Bits 0-2 are the type mask:
1666 - 0=No index capture
1667 - 1=I frames
1668 - 3=I,P frames
1669 - 7=I,P,B frames
1705 .. code-block:: none
1828 - 0 read completed
1829 - 1 write completed
1830 - 2 DMA read error
1831 - 3 DMA write error
1832 - 4 Scatter-Gather array error
1886 Initializes the video input
1920 - 0=Pause encoding
1921 - 1=Continue encoding
1933 Refreshes the video input
1951 - 0=Stream is not copyrighted
1952 - 1=Stream is copyrighted
1985 Mailbox slot, -1 if no mailbox required.
1997 Depending on the analog video decoder used, this assigns the number
2004 - 0x00EF for SAA7114
2005 - 0x00F0 for SAA7115
2006 - 0x0105 for Micronas
2012 - 0x00EF for SAA7114
2013 - 0x00F0 for SAA7115
2014 - 0x0106 for Micronas
2031 - 0=extension & user data
2032 - 1=private packet with stream ID 0xBD
2100 Video muting
2107 .. code-block:: none
2109 0 '0'=video not muted
2110 '1'=video muted, creates frames with the YUV color defined below
2131 - 0=audio not muted
2132 - 1=audio muted (produces silent mpeg audio stream)
2171 .. code-block:: none
2186 9=set history parameters of the video input module
2201 Decoder firmware API description
2202 --------------------------------
2204 .. note:: this API is part of the decoder firmware, so it's cx23415 only.
2252 Ends playback and clears all decoder buffers. If PTS is not zero,
2290 - Smooth: host transfers entire stream and firmware drops unused
2292 - Coarse: host drops frames based on indexing as required to achieve
2298 .. code-block:: none
2330 .. code-block:: none
2345 Adding B frames to the mask will result in corrupt video. This field
2542 Returns decoder firmware version information
2548 - Bits 0:15 build
2549 - Bits 16:23 minor
2550 - Bits 24:31 major
2562 Select decoder stream input port
2589 Video PTS bits 0:31 by display order
2594 Video PTS bit 32 by display order
2622 0=Stereo, 1=Left, 2=Right, 3=Mono, 4=Swap, -1=Unchanged
2628 0=Stereo, 1=Left, 2=Right, 3=Mono, 4=Swap, -1=Unchanged
2647 - 0=Audio mode change between mono, (joint) stereo and dual channel.
2648 - 3=Decoder started
2649 - 4=Unknown: goes off 10-15 times per second while decoding.
2650 - 5=Some sync event: goes off once per frame.
2665 Mailbox slot, -1 if no mailbox required.
2722 Selects decoder source. Ensure that the parameters passed to this
2755 Decoder prebuffering, when enabled up to 128KB are buffered for
2763 PVR350 Video decoder registers 0x02002800 -> 0x02002B00
2764 -------------------------------------------------------
2782 decoder will fail. A firmware reload will often recover, but sometimes a reset
2787 .. code-block:: none
2789 --------------------------------------------------------------------------------
2792 Decoder enable
2795 --------------------------------------------------------------------------------
2798 Decoder horizontal Y alias register 1
2799 ---------------
2802 Decoder horizontal Y alias register 2
2803 ---------------
2806 Decoder horizontal Y alias register 3
2807 ---------------
2810 Decoder horizontal Y alias register 4
2811 ---------------
2814 Decoder horizontal Y alias register 5
2815 ---------------
2818 Decoder horizontal Y alias trigger
2826 times. The actual register contents are copied from a lookup-table in the
2829 --------------------------------------------------------------------------------
2832 Decoder horizontal UV alias register 1
2833 ---------------
2836 Decoder horizontal UV alias register 2
2837 ---------------
2840 Decoder horizontal UV alias register 3
2841 ---------------
2844 Decoder horizontal UV alias register 4
2845 ---------------
2848 Decoder horizontal UV alias register 5
2849 ---------------
2852 Decoder horizontal UV alias trigger
2858 --------------------------------------------------------------------------------
2861 Decoder Y source width in pixels
2864 Decoder Y destination width in pixels
2865 ---------------
2868 Decoder UV source width in pixels
2871 Decoder UV destination width in pixels
2877 --------------------------------------------------------------------------------
2881 Decoder Y horizontal scaling
2883 ---------------
2886 Decoder ?? unknown - horizontal scaling
2888 ---------------
2891 Decoder UV horizontal scaling
2893 ---------------
2896 Decoder ?? unknown - horizontal scaling
2898 ---------------
2901 Decoder ?? unknown - Y plane
2903 ---------------
2906 Decoder ?? unknown - UV plane
2908 ---------------
2911 Decoder 'master' value for horizontal scaling
2912 ---------------
2915 Decoder ?? unknown
2917 ---------------
2920 Decoder ?? unknown
2922 ---------------
2925 Decoder ?? unknown
2927 ---------------
2930 Decoder ?? unknown
2932 ---------------
2935 Decoder ?? unknown
2957 --------------------------------------------------------------------------------
2960 Decoder horizontal Y buffer offset
2963 Decoder horizontal UV buffer offset
2965 Offset into the video image buffer. If the offset is gradually incremented,
2968 --------------------------------------------------------------------------------
2971 Decoder horizontal Y output offset
2974 Decoder horizontal UV output offset
2976 Offsets the actual video output. Controls output alignment of the Y & UV
2980 --------------------------------------------------------------------------------
2983 Decoder horizontal Y output size divider
2989 Decoder horizontal UV output size divider
2995 Decoder ?? unknown
2997 1 = Affects video output levels
3000 Decoder ?? unknown
3004 --------------------------------------------------------------------------------
3015 Decoder + osd video timing
3023 Decoder + osd
3026 --------------------------------------------------------------------------------
3029 Decoder & osd ?? unknown
3039 --------------------------------------------------------------------------------
3040 2880 -------- ?? unknown
3041 2884 -------- ?? unknown
3042 --------------------------------------------------------------------------------
3045 Decoder + osd ?? unknown
3057 --------------------------------------------------------------------------------
3062 more unstable it becomes. Decoder output remains stable.
3068 --------------------------------------------------------------------------------
3071 Decoder output horizontal offset.
3073 Horizontal offset moves the video image right. A small left shift is
3077 NOTE: Video corruption will occur if video window is shifted off the right
3079 --------------------------------------------------------------------------------
3082 Decoder output video surround colour.
3084 Contains the colour (in yuv) used to fill the screen when the video is
3086 --------------------------------------------------------------------------------
3089 Decoder video window colour
3090 Contains the colour (in yuv) used to fill the video window when the
3091 video is turned off.
3094 Decoder video output
3095 0 = Video on
3096 1 = Video off
3099 Decoder plane order
3104 Decoder second plane byte order
3113 --------------------------------------------------------------------------------
3116 Decoder vertical field offset 1
3119 Decoder vertical field offset 2
3124 --------------------------------------------------------------------------------
3127 Decoder & osd width in pixels
3130 Decoder & osd height in pixels
3132 All output from the decoder & osd are disabled beyond this area. Decoder
3135 --------------------------------------------------------------------------------
3140 Has a range of 0x770->0x7FF. With the exception of 0, any value outside of
3142 --------------------------------------------------------------------------------
3153 --------------------------------------------------------------------------------
3154 28AC -------- ?? unknown
3157 28BC -------- ?? unknown
3158 --------------------------------------------------------------------------------
3169 --------------------------------------------------------------------------------
3170 28C4 -------- ?? unknown
3173 28F8 -------- ?? unknown
3174 --------------------------------------------------------------------------------
3179 1 = Breaks decoder & osd output
3180 --------------------------------------------------------------------------------
3183 Decoder vertical Y alias register 1
3184 ---------------
3187 Decoder vertical Y alias register 2
3188 ---------------
3191 Decoder vertical Y alias trigger
3199 --------------------------------------------------------------------------------
3202 Decoder vertical UV alias register 1
3203 ---------------
3206 Decoder vertical UV alias register 2
3207 ---------------
3210 Decoder vertical UV alias trigger
3214 --------------------------------------------------------------------------------
3217 Decoder Y source height in pixels
3220 Decoder Y destination height in pixels
3221 ---------------
3224 Decoder UV source height in pixels divided by 2
3227 Decoder UV destination height in pixels
3234 --------------------------------------------------------------------------------
3237 Decoder Y vertical scaling
3239 ---------------
3242 Decoder Y vertical scaling
3244 ---------------
3247 Decoder UV vertical scaling
3250 ---------------
3253 Decoder UV vertical scaling
3255 ---------------
3258 Decoder 'master' value for vertical scaling
3259 ---------------
3262 Decoder ?? unknown - Y vertical scaling
3263 ---------------
3266 Decoder Y vertical scaling
3268 ---------------
3271 Decoder ?? unknown - Y vertical scaling
3272 ---------------
3275 Decoder UV vertical scaling
3278 ---------------
3281 Decoder ?? unknown - UV vertical scaling
3282 ---------------
3285 Decoder UV vertical scaling
3287 ---------------
3290 Decoder ?? unknown - UV vertical scaling
3309 --------------------------------------------------------------------------------
3312 Decoder Y line index into display buffer, first field
3315 Decoder Y vertical line skip, first field
3316 --------------------------------------------------------------------------------
3319 Decoder Y line index into display buffer, second field
3322 Decoder Y vertical line skip, second field
3323 --------------------------------------------------------------------------------
3326 Decoder UV line index into display buffer, first field
3329 Decoder UV vertical line skip, first field
3330 --------------------------------------------------------------------------------
3333 Decoder UV line index into display buffer, second field
3336 Decoder UV vertical line skip, second field
3337 --------------------------------------------------------------------------------
3340 Decoder destination height minus 1
3343 Decoder destination height divided by 2
3344 --------------------------------------------------------------------------------
3347 Decoder Y vertical offset, second field
3350 Decoder Y vertical offset, first field
3354 --------------------------------------------------------------------------------
3357 Decoder UV vertical offset, second field
3360 Decoder UV vertical offset, first field
3364 --------------------------------------------------------------------------------
3367 Decoder vertical Y output size divider
3373 Decoder vertical UV output size divider
3377 --------------------------------------------------------------------------------
3380 Decoder ?? unknown
3382 1 = Affect video output levels
3385 Decoder ?? unknown
3389 --------------------------------------------------------------------------------
3390 2974 -------- ?? unknown
3393 29EF -------- ?? unknown
3394 --------------------------------------------------------------------------------
3438 When the bits-per-pixel is set to 8, the colour mode is ignored and
3439 assumed to be 8 bit indexed. For 16 & 32 bits-per-pixel the colour depth
3451 bit indexed, local alpha is a per-pixel 256 step transparency, with 0 being
3460 --------------------------------------------------------------------------------
3467 ---------------
3480 --------------------------------------------------------------------------------
3487 --------------------------------------------------------------------------------
3494 --------------------------------------------------------------------------------
3502 --------------------------------------------------------------------------------
3508 --------------------------------------------------------------------------------
3513 Contains the global alpha value (equiv ivtvfbctl --alpha XX)
3514 --------------------------------------------------------------------------------
3515 2A20 -------- ?? unknown
3518 2A2C -------- ?? unknown
3519 --------------------------------------------------------------------------------
3523 ---------------
3530 so the index range is 0x00-0xFF
3531 --------------------------------------------------------------------------------
3532 2A38 -------- ?? unknown
3533 2A3C -------- ?? unknown
3534 --------------------------------------------------------------------------------
3540 --------------------------------------------------------------------------------
3546 --------------------------------------------------------------------------------
3552 --------------------------------------------------------------------------------
3558 --------------------------------------------------------------------------------
3564 --------------------------------------------------------------------------------
3570 --------------------------------------------------------------------------------
3571 2A58 -------- ?? unknown
3574 2AFC -------- ?? unknown
3575 --------------------------------------------------------------------------------
3585 --------------------------------------------------------------------------------
3588 ----------------------
3603 Therefore, it also supports a technique called "scatter-gather". The card can
3611 urged to choose a smaller block size and learn the scatter-gather technique.
3615 Note: the hardware expects little-endian data ('intel format').
3623 - The card raises the Encoder interrupt.
3624 - The driver reads the transfer type, offset and size from Mailbox #10.
3625 - The driver constructs the scatter-gather array from enough free dma buffers
3627 - The driver schedules the DMA transfer via the ScheduleDMAtoHost API call.
3628 - The card raises the DMA Complete interrupt.
3629 - The driver checks the DMA status register for any errors.
3630 - The driver post-processes the newly transferred buffers.
3640 - Name: Mailbox #10
3641 - Results[0]: Type: 0: MPEG.
3642 - Results[1]: Offset: The position relative to the card's memory space.
3643 - Results[2]: Size: The exact number of bytes to transfer.
3649 Scatter-Gather Array
3652 The scatter-gather array is a contiguously allocated block of memory that
3653 tells the card the source and destination of each data-block to transfer.
3657 Each S-G array element is a struct of three 32-bit words. The first word is
3660 count. The high-bit of the third word is the "last" flag. The last-flag tells
3671 - 32-bit Source Address
3672 - 32-bit Destination Address
3673 - 14-bit reserved (high bit is the last flag)
3674 - 18-bit byte count
3681 - bit 0: read completed
3682 - bit 1: write completed
3683 - bit 2: DMA read error
3684 - bit 3: DMA write error
3685 - bit 4: Scatter-Gather array error