summaryrefslogtreecommitdiff
path: root/dvb-spec/ISDB-T_and_ISDB-Tsb_with_S2API
diff options
context:
space:
mode:
Diffstat (limited to 'dvb-spec/ISDB-T_and_ISDB-Tsb_with_S2API')
-rw-r--r--dvb-spec/ISDB-T_and_ISDB-Tsb_with_S2API250
1 files changed, 250 insertions, 0 deletions
diff --git a/dvb-spec/ISDB-T_and_ISDB-Tsb_with_S2API b/dvb-spec/ISDB-T_and_ISDB-Tsb_with_S2API
new file mode 100644
index 000000000..2d90df5bb
--- /dev/null
+++ b/dvb-spec/ISDB-T_and_ISDB-Tsb_with_S2API
@@ -0,0 +1,250 @@
+Changelog
+=========
+
+latest:
+v1.3 - 2009-08-05
+- added reference to ARIB TR-B14
+
+v1.2 - 2009-08-04
+- removed DTV_BANDWIDTH from being a necessary parameter - now optional
+
+v1.1 - 2009-08-04
+- added DTV_FREQUENCY as a necessary parameter
+
+v1.0 - 2009-08-03
+- initial draft
+
+Proposal
+========
+
+This document describes shortly what are the possible parameters in the Linux
+DVB-API called "S2API" and now DVB API 5 in order to tune an ISDB-T/ISDB-Tsb
+demodulator:
+
+This ISDB-T/ISDB-Tsb API extension should reflect all information
+needed to tune any ISDB-T/ISDB-Tsb hardware. Of course it is possible
+that some very sophisticated devices won't need certain parameters to
+tune.
+
+The information given here should help application writers to know how
+to handle ISDB-T and ISDB-Tsb hardware using the Linux DVB-API.
+
+The details given here about ISDB-T and ISDB-Tsb are just enough to
+basically show the dependencies between the needed parameter values,
+but surely some information is left out. For more detailed information
+see the following documents:
+
+- ARIB STD-B31 - "Transmission System for Digital Terrestrial
+ Television Broadcasting" and
+- ARIB TR-B14 - "Operational Guidelines for Digital Terrestrial
+ Television Broadcasting".
+
+In order to read this document one has to have some knowledge the
+channel structure in ISDB-T and ISDB-Tsb. I.e. it has to be known to
+the reader that an ISDB-T channel consists of 13 segments, that it can
+have up to 3 layer sharing those segments, and things like that.
+
+Parameters used by ISDB-T and ISDB-Tsb.
+
+Existing parameters
+===================
+
+a) DTV_FREQUENCY
+
+Central frequency of the channel.
+
+For ISDB-T the channels are usally transmitted with an offset of 143kHz. E.g. a
+valid frequncy could be 474143 kHz. The stepping is bound to the bandwidth of
+the channel which is 6MHz.
+
+As in ISDB-Tsb the channel consists of only one or three segments the
+frequency step is 429kHz, 3*429 respectively. As for ISDB-T the
+central frequency of the channel is expected.
+
+b) DTV_BANDWIDTH_HZ (optional)
+
+Possible values:
+
+For ISDB-T it should be always 6000000Hz (6MHz)
+For ISDB-Tsb it can vary depending on the number of connected segments
+
+Note: Hardware specific values might be given here, but standard
+applications should not bother to set a value to this field as
+standard demods are ignoring it anyway.
+
+Bandwidth in ISDB-T is fixed (6MHz) or can be easily derived from
+other parameters (DTV_ISDBT_SB_SEGMENT_IDX,
+DTV_ISDBT_SB_SEGMENT_COUNT).
+
+c) DTV_DELIVERY_SYSTEM
+
+Possible values: SYS_ISDBT
+
+d) DTV_TRANSMISSION_MODE
+
+ISDB-T supports three carrier/symbol-size: 8K, 4K, 2K. It is called
+'mode' in the standard: Mode 1 is 2K, mode 2 is 4K, mode 3 is 8K
+
+Possible values: TRANSMISSION_MODE_2K, TRANSMISSION_MODE_8K,
+ TRANSMISSION_MODE_AUTO, TRANSMISSION_MODE_4K
+
+If DTV_TRANSMISSION_MODE is set the TRANSMISSION_MODE_AUTO the
+hardware will try to find the correct FFT-size (if capable) and will
+use TMCC to fill in the missing parameters.
+
+TRANSMISSION_MODE_4K is added at the same time as the other new parameters.
+
+e) DTV_GUARD_INTERVAL
+
+Possible values: GUARD_INTERVAL_1_32, GUARD_INTERVAL_1_16, GUARD_INTERVAL_1_8,
+ GUARD_INTERVAL_1_4, GUARD_INTERVAL_AUTO
+
+If DTV_GUARD_INTERVAL is set the GUARD_INTERVAL_AUTO the hardware will
+try to find the correct guard interval (if capable) and will use TMCC to fill
+in the missing parameters.
+
+New parameters
+==============
+
+1. DTV_ISDBT_PARTIAL_RECEPTION (1b)
+
+If DTV_ISDBT_SOUND_BROADCASTING is '0' this bit-field represents whether
+the channel is in partial reception mode or not.
+
+If '1' DTV_ISDBT_LAYERA_* values are assigned to the center segment and
+DTV_ISDBT_LAYERA_SEGMENT_COUNT has to be '1'.
+
+If in addition DTV_ISDBT_SOUND_BROADCASTING is '1'
+DTV_ISDBT_PARTIAL_RECEPTION represents whether this ISDB-Tsb channel
+is consisting of one segment and layer or three segments and two layers.
+
+Possible values: 0, 1, -1 (AUTO)
+
+2. DTV_ISDBT_SOUND_BROADCASTING (1b)
+
+This field represents whether the other DTV_ISDBT_*-parameters are
+referring to an ISDB-T and an ISDB-Tsb channel. (See also
+DTV_ISDBT_PARTIAL_RECEPTION).
+
+Possible values: 0, 1, -1 (AUTO)
+
+3. DTV_ISDBT_SB_SUBCHANNEL_ID
+
+This field only applies if DTV_ISDBT_SOUND_BROADCASTING is '1'.
+
+(Note of the author: This might not be the correct description of the
+ SUBCHANNEL-ID in all details, but it is my understanding of the technical
+ background needed to program a device)
+
+An ISDB-Tsb channel (1 or 3 segments) can be broadcasted alone or in a
+set of connected ISDB-Tsb channels. In this set of channels every
+channel can be received independently. The number of connected
+ISDB-Tsb segment can vary, e.g. depending on the frequency spectrum
+bandwidth available.
+
+Example: Assume 8 ISDB-Tsb connected segments are broadcasted. The
+broadcaster has several possibilities to put those channels in the
+air: Assuming a normal 13-segment ISDB-T spectrum he can align the 8
+segments from position 1-8 to 5-13 or anything in between.
+
+The underlying layer of segments are subchannels: each segment is
+consisting of several subchannels with a predefined IDs. A sub-channel
+is used to help the demodulator to synchronize on the channel.
+
+An ISDB-T channel is always centered over all sub-channels. As for
+the example above, in ISDB-Tsb it is no longer as simple as that.
+
+The DTV_ISDBT_SB_SUBCHANNEL_ID parameter is used to give the
+sub-channel ID of the segment to be demodulated.
+
+Possible values: 0 .. 41, -1 (AUTO)
+
+4. DTV_ISDBT_SB_SEGMENT_IDX
+
+This field only applies if DTV_ISDBT_SOUND_BROADCASTING is '1'.
+
+DTV_ISDBT_SB_SEGMENT_IDX gives the index of the segment to be
+demodulated for an ISDB-Tsb channel where several of them are
+transmitted in the connected manner.
+
+Possible values: 0 .. DTV_ISDBT_SB_SEGMENT_COUNT-1
+
+Note: This value cannot be determined by an automatic channel search.
+
+5. DTV_ISDBT_SB_SEGMENT_COUNT
+
+This field only applies if DTV_ISDBT_SOUND_BROADCASTING is '1'.
+
+DTV_ISDBT_SB_SEGMENT_COUNT gives the total count of connected ISDB-Tsb
+channels.
+
+Possible values: 1 .. 13
+
+Note: This value cannot be determined by an automatic channel search.
+
+6. Hierarchical layers
+
+ISDB-T channels can be coded hierarchically. As opposed to DVB-T in
+ISDB-T hierarchical layers can be decoded simultaneously. For that
+reason a ISDB-T demodulator has 3 viterbi and 3 reed-solomon-decoders.
+
+ISDB-T has 3 hierarchical layers which each can use a part of the
+available segments. The total number of segments over all layers has
+to 13 in ISDB-T.
+
+6.1 DTV_ISDBT_LAYER_ENABLED (3b)
+
+Hierarchical reception in ISDB-T is achieved by enabling or disabling
+layers in the decoding process. Setting all bits of
+DTV_ISDBT_LAYER_ENABLED to '1' forces all layers (if applicable) to be
+demodulated. This is the default.
+
+If the channel is in the partial reception mode
+(DTV_ISDBT_PARTIAL_RECEPTION=1) the central segment can be decoded
+independently of the other 12 segments. In that mode layer A has to
+have a SEGMENT_COUNT of 1.
+
+In ISDB-Tsb only layer A is used, it can be 1 or 3 in ISDB-Tsb
+according to DTV_ISDBT_PARTIAL_RECEPTION. SEGMENT_COUNT must be filled
+accordingly.
+
+Possible values: 0x1, 0x2, 0x4 (|-able)
+
+DTV_ISDBT_LAYER_ENABLED[0:0] - layer A
+DTV_ISDBT_LAYER_ENABLED[1:1] - layer B
+DTV_ISDBT_LAYER_ENABLED[2:2] - layer C
+DTV_ISDBT_LAYER_ENABLED[31:3] unused
+
+6.2 DTV_ISDBT_LAYER*_FEC
+
+Possible values: FEC_AUTO, FEC_1_2, FEC_2_3, FEC_3_4, FEC_5_6, FEC_7_8,
+
+6.3 DTV_ISDBT_LAYER*_MODULATION
+
+Possible values: QAM_AUTO, QPSK, QAM_16, QAM_64, DQPSK
+
+Note: If layer C is DQPSK layer B has to be DQPSK. If layer B is DQPSK
+and DTV_ISDBT_PARTIAL_RECEPTION=0 layer has to be DQPSK.
+
+6.4 DTV_ISDBT_LAYER*_SEGMENT_COUNT
+
+Possible values: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, -1 (AUTO)
+
+Note: Truth table for DTV_ISDBT_SOUND_BROADCASTING and
+DTV_ISDBT_PARTIAL_RECEPTION and LAYER*_SEGMENT_COUNT
+
+ PR | SB || layer A width | layer B width | layer C width | total
+----+----++---------------+---------------+---------------+-------
+ 0 | 0 || 1 .. 13 | 1 .. 13 | 1..13 | 13
+ 1 | 0 || 1 | 1 .. 13 | 1..13 | 13
+ 0 | 1 || 1 | 0 | 0 | 1
+ 1 | 1 || 1 | 2 | 0 | 3
+
+
+6.5 DTV_ISDBT_LAYER*_TIME_INTERLEAVING
+
+Possible values: 0, 1, 2, 3, -1 (AUTO)
+
+Note: The real inter-leaver depth-names depend on the mode (fft-size); the values
+here are referring to what can be found in the TMCC-structure -
+independent of the mode.