FreeCalypso > hg > themwi-system-sw
annotate doc/RTP-TRAUlike-format @ 234:44f178901a46
libnumdb2: port refresh.c
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 14 Aug 2023 13:17:07 -0800 |
parents | f0b90591f67c |
children |
rev | line source |
---|---|
207
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
1 TRAU-UL-like RTP transport format for FR & EFR codecs |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
2 ===================================================== |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
3 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
4 The generally accepted industry standard format for RTP transport of FR and EFR |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
5 codec frames in an IP-based GSM RAN is given in ETSI TS 101 318; the same format |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
6 is also codified in IETF RFC 3551. However, when compared to the classic |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
7 TRAU-UL format of 3GPP TS 48.060, the standard RTP format of RFC 3551 exhibits |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
8 the following two shortcomings: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
9 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
10 1) no way to indicate a BFI condition and still send frame data bits; |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
11 2) no way to transport the Time Alignment Flag (TAF). |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
12 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
13 Both of these shortcomings will be explained in detail further in this document; |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
14 however, the primary purpose of this document is to propose a new, regrettably |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
15 non-standard, RTP transport format for FR & EFR codecs, for use only within a |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
16 GSM RAN and the immediately attached CN transcoder ("soft TRAU"), that provides |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
17 the same functionality as the classic TRAU-UL format of TS 48.060, but is |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
18 carried over RTP in IP rather than a 16 kbps TDM subchannel. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
19 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
20 The non-standard RTP transport format presented in this document is implemented |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
21 in OsmoBTS on a private feature branch: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
22 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
23 https://cgit.osmocom.org/osmo-bts/log/?h=falconia/rtp_traulike |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
24 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
25 OsmoBTS versions that include this code always accept TRAUlike FR/EFR packets |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
26 on their RTP input, following the principle of being liberal in what you accept |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
27 while being conservative in what you send, but emit such packets on their RTP |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
28 output only when this non-default vty config option is given: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
29 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
30 rtp fr-efr-traulike |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
31 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
32 The recently added (mainline) "rtp continuous-streaming" vty config option also |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
33 needs to be enabled. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
34 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
35 The present document serves as the formal specification for the TRAUlike RTP |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
36 transport format for FR and EFR. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
37 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
38 Detailed description of shortcomings of standard RTP transport for FR & EFR |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
39 =========================================================================== |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
40 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
41 These shortcomings are solved in the TRAUlike RTP transport format defined in |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
42 this document; understanding these shortcomings provides the essential rationale |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
43 for TRAU-like RTP. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
44 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
45 Indicating BFI along with data bits |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
46 ----------------------------------- |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
47 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
48 The only way to indicate a BFI condition in standard RTP (for FR/EFR) is to |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
49 either send no packet at all in the 20 ms window in question (industry standard |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
50 behavior and OsmoBTS default) or send an RTP packet with a zero-length payload |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
51 ("rtp continuous-streaming" option in OsmoBTS). The latter option provides a |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
52 timing tick for a CN-attached transcoder relying on the BTS-originating RTP |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
53 stream as its timing source, but there is still no way to send a frame of |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
54 marked-erroneous data bits. Contrast with TS 48.060 TRAU-UL format: in this |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
55 format the Dn bits carrying FR or EFR frame bits and the C12 bit carrying BFI |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
56 are orthogonal. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
57 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
58 Why would one care about known-bad or deemed-to-be-bad frame data bits? They |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
59 do matter at least in the case of EFR: the official reference C-source EFR |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
60 decoder from ETSI makes use of the "fixed codebook excitation pulses" portion |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
61 of its EFR frame bits input (140 bits out of 244) even when BFI=1. This |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
62 portion of reference C-source behavior is declared to be a non-normative example |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
63 by the text of GSM 06.61 spec, thus there may be other compliant EFR decoder |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
64 implementations that never look at marked-erroneous data bits - but given the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
65 ease of simply using the C code from ETSI as-is, or recoding it more efficiently |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
66 but keeping unchanged all bit-exact algorithms, including non-normative ones, |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
67 we should expect that the behavior of ETSI reference code is retained in many |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
68 production implementations and deployments. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
69 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
70 Consider the case where a traditional E1-based BTS with a classic TRAU interface |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
71 is attached to an IP-based Osmocom RAN by way of OsmoMGW, and the resulting RTP |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
72 stream then (after passing through another OsmoMGW instance at the MSC) goes to |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
73 a "soft TRAU" transcoder (TC) in the CN. The TC will feed its RTP input to FR |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
74 and EFR decoders, and at least the EFR decoder makes use of "fixed codebook |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
75 excitation pulses" bits from erroneous frames. Furthermore, the TC may |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
76 implement in-band TFO (3GPP TS 28.062) inside its G.711 RTP output, in which |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
77 case it will need to insert a slightly modified TRAU-UL frame into that output. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
78 The bits that would ideally be fed to the ETSI EFR decoder and emitted to the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
79 outside world in TFO frames already exist at the output of the E1-based BTS, |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
80 but they get lost in the RTP transport when the industry standard RTP payload |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
81 format is used. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
82 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
83 Consider another case where OsmoBTS does have an FR/EFR traffic frame that |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
84 could potentially be sent out, but it is suppressed by the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
85 (tch_ind->lqual_cb >= bts->min_qual_norm) check in l1sap_tch_ind() in |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
86 src/common/l1sap.c. In this case it would be ideal to send out that frame |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
87 along with a BFI=1 indication, if the RTP transport format were to allow such |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
88 representation. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
89 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
90 Lack of TAF bit in standard RTP transport |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
91 ----------------------------------------- |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
92 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
93 The TRAU-UL frame format of TS 48.060 for FR and EFR includes a bit called TAF, |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
94 for Time Alignment Flag. Per the specs (TS 48.060 refers to TS 46.031 for |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
95 definition and coding of frame indicators) this bit shall be set to 1 in one |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
96 particular position in the 480 ms SACCH multiframe (the particular 20 ms frame |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
97 position in which a valid frame is always transmitted, even during DTX pauses) |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
98 and set to 0 in all other frames. This flag factors into the Rx DTX handler |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
99 logic prescribed in GSM 06.31 and 06.81 specs for FR and EFR, respectively, and |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
100 there exist production decoders for these codecs that implement their Rx DTX |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
101 handler function exactly to the letter of the specs, including the use of TAF |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
102 bit when deciding what to do with a BFI=1 frame received in the comfort noise |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
103 generation state. (These spec-compliant decoders include the reference ETSI |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
104 C-source decoder for EFR and Themyscira libgsmfrp for FR.) |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
105 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
106 This TAF bit does not exist in the standard RTP transport for FR & EFR. The |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
107 lack of this TAF bit causes the following problems for the CN-attached "soft |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
108 TRAU" transcoder: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
109 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
110 1) The ability to implement spec-compliant handling of GSM 06.11 or 06.61 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
111 section 5.4 requirement (same section in both specs) is lost; |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
112 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
113 2) The TC won't know when to set the TAF bit in its outgoing TFO frames, if it |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
114 implements in-band TFO per 3GPP TS 28.062. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
115 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
116 The TFO problem is particularly concerning because these TFO frames are emitted |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
117 to the outside world, outside of administrative and technical control of the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
118 party implementing the Osmocom-based GSM network and the TC at its edge. The |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
119 resulting G.711 octet stream with TFO frames embedded inside can be carried |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
120 half-way around the world by the international toll telephone network, and there |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
121 is no telling what kind of implementation may be receiving and decoding these |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
122 bits on the other end. For this reason, "poor man's" workarounds in the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
123 RTP-fed, TFO-generating TC are very unattractive: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
124 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
125 * If the TC were to set TAF=0 in all TFO frames it generates, the receiver's |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
126 expectation of seeing TAF=1 in every 24th frame will be violated. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
127 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
128 * If the TC were to arbitrarily set TAF=1 in every 24th frame by its own free- |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
129 running count, without knowledge of the actual SACCH alignment in the original |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
130 GSM call leg, these TAF-marked frames won't coincide with those frame |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
131 positions where the MS sends its SID frames, and the resulting TFO frame |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
132 stream will be invalid to the receiving Rx DTX handler on the far end. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
133 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
134 The knowledge of which frames need to be marked with TAF=1 exists inside the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
135 entity that generates the FR/EFR RTP stream: if this entity is a converter from |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
136 E1-based Abis to RTP, the TRAU-UL frames from the BTS contain this TAF bit, and |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
137 if the RTP-generating entity is a native IP BTS, it knows the frame number for |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
138 which it generates each RTP packet. The only problem is that there is no place |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
139 to insert this TAF bit in the standard RTP transport format of TS 101 318. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
140 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
141 Why TRAU-UL and not TRAU-DL |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
142 =========================== |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
143 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
144 The present document argues the case that the industry standard RTP transport |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
145 format for FR & EFR is functionally crippled compared to the TRAU-UL transport |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
146 format of 3GPP TS 48.060, and defines an alternative RTP transport format that |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
147 can be used by those who desire TRAU-UL-like functionality badly enough to |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
148 accept the price of going totally non-standard in their IP RAN transport. The |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
149 new RTP transport format defined in this document explicitly mimics the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
150 functionality and semantics of TS 48.060 TRAU-UL for FR and EFR. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
151 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
152 At this point a reader may reasonably ask: why TRAU-UL and not TRAU-DL? The |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
153 answer is TFO: 3GPP TS 28.062 and its predecessor GSM 08.62 define the TFO frame |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
154 format as being based on TRAU-UL frames with only a few bits changed, and no |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
155 change in semantics of any of the frame indicator bits of TRAU-UL (C12 through |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
156 C17). Whereas the Abis interface is inherently asymmetric (TRAU-UL frames in |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
157 one direction, TRAU-DL frames in the other direction), end-to-end TFO is |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
158 directionally symmetric. If we imagine a TFO call between Alice in America and |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
159 Bob in Britain, there will be TRAU-UL frames flowing in both directions of the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
160 trans-oceanic G.711 toll connection, one set coming almost unchanged from |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
161 Alice's BTS CCU and the other coming almost unchanged from Bob's BTS CCU. Of |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
162 course each party's GSM call DL will require TRAU-DL frames to be fed to it, |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
163 not TRAU-UL, but the necessary UL-to-DL conversion is the responsibility of the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
164 TFO receiver on each end. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
165 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
166 The general rules for turning a TRAU-UL frame into one for TRAU-DL are specified |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
167 in TS 28.062 section C.3.2.1.1; it should be noted that this section spells out |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
168 the requirements of what the UL-to-DL converter must do, but does not specify |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
169 exactly how to do it algorithmically - the wording it uses is "subject to |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
170 manufacturer dependent future improvements and is not part of this |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
171 recommendation." Implementing all of these section C.3.2.1.1 rules (hereafter |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
172 called C3211 rules for short) exactly to the letter is quite easy for the FR |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
173 codec (Themyscira libgsmfrp does everything that is needed, and is a simple and |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
174 lightweight FLOSS function library), but much harder for EFR. At the present |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
175 time it is unclear to the author of this document whether real historical T1/E1 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
176 TRAU implementations for which GSM 08.62 TFO was originally specified really did |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
177 implement C3211 rules to the letter, particularly for EFR, or if they cut some |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
178 corners. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
179 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
180 Because the TRAUlike RTP transport format defined in this document is |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
181 semantically equivalent to TRAU-UL, any entity that receives such RTP packets |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
182 but internally needs to generate either TRAU-DL or some private functional |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
183 equivalent thereof will need to perform the same UL-to-DL conversion as called |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
184 for in TFO. The lack of a readily available function library that implements |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
185 the onerous rules of C3211 for EFR is certainly an obstacle, but it is also |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
186 possible to "cut corners" by doing the following: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
187 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
188 1) Ignore Table C.3.2.1-1 case 1 and treat it like case 2, at least for EFR: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
189 whenever SID frames are received on the incoming TRAU-UL or TRAUlike RTP |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
190 interface, forward them to call leg B even when that destination call leg |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
191 has no DTXd. Given that DTX and SID support has been an integral part of |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
192 the EFR codec from the beginning, as opposed to an after-addition in the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
193 case of FR, every GSM MS that supports EFR can be expected to understand |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
194 SID frames on the downlink. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
195 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
196 2) During speech pauses following transmission of a SID frame on call leg B DL, |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
197 if real DTXd (turning off Tx) is not allowed, do "fake DTXd" by transmitting |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
198 dummy FACCH with an L2 fill frame in the same 20 ms traffic frame windows in |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
199 which real DTXd would have been exercised if it were allowed. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
200 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
201 3) Whenever a BFI condition is encountered in the incoming TRAU-UL or TRAUlike |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
202 RTP frame stream outside of SID, i.e., the case described in the first |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
203 paragraph of section C.3.2.1.1, induce an intentional BFI condition in the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
204 receiving GSM MS by transmitting a dummy FACCH frame as above, instead of |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
205 trying to devise a parameter-level ECU for EFR. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
206 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
207 It should be noted that the just-outlined "cut corners" method is exactly what |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
208 OsmoBTS (and a "pure" Osmocom network in general) does currently, hence nothing |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
209 is lost and no regression is introduced by continuing to do the same. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
210 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
211 Seen another way, by making our RTP transport semantically equivalent to |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
212 TRAU-UL, we achieve harmonization between TFO and TrFO. TrFO (Transcoder-Free |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
213 Operation) is a scenario in which the RTP output from one IP BTS for call leg A |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
214 goes directly to the RTP input of another IP BTS for call leg B, possibly |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
215 passing through simple RTP forwarders like OsmoMGW, but never passing through |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
216 any transcoder. TrFO is what happens in a self-contained Osmocom network |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
217 without any external MNCC connected to OsmoMSC. The principal rules of what |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
218 transformations are inherently necessary in order to produce a fully proper DL |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
219 for call leg B from the UL of call leg A remain the same whether the transport |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
220 in between is old-fashioned TFO or modern TrFO, hence the same conversions that |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
221 are codified in TS 28.062 section C.3.2.1.1 are still needed - the only question |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
222 is where in the network are they to be performed. The original TDM-based GSM |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
223 designers at ETSI gave us a superb architecture end to end; by employing an RTP |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
224 transport that is semantically equivalent to TRAU-UL, we can preserve that whole |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
225 architecture fully intact in an all-IP implementation. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
226 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
227 Specification for TRAUlike RTP payload format for FR and EFR |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
228 ============================================================ |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
229 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
230 The modified RTP payload format shall consist of a single octet called TRAUlike |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
231 Extension Header (TEH), followed (most of the time) by the standard (same as in |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
232 RFC 3551) 33 octets for FR or 31 octets for EFR. The TEH octet has the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
233 following structure: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
234 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
235 +----+----+----+----+----+----+----+----+ |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
236 Hex mask | 0xF0 |0x08|0x04|0x02|0x01| |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
237 +----+----+----+----+----+----+----+----+ |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
238 Meaning | signature |DTXd|NDF |BFI |TAF | |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
239 +----+----+----+----+----+----+----+----+ |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
240 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
241 (Bit numbers are identified by hex masks in order to avoid getting into an |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
242 argument over which bit numbering convention should be used.) |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
243 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
244 The following bit fields are defined within the TEH octet: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
245 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
246 signature: the upper nibble of the TEH octet shall be set to 0xE. This |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
247 signature allows RTP packet receivers to identify the payload format by the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
248 upper nibble of the first octet: if it equals 0xC, the format is EFR without |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
249 TEH, if it equals 0xD, the format is FR without TEH, and if it equals 0xE, then |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
250 the first octet is TEH. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
251 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
252 DTXd: this bit is strictly identical with TRAU-UL frame bit C17. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
253 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
254 No_Data flag (NDF): this bit shall be set to 1 if the TRAUlike payload consists |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
255 solely of TEH, with the standard 33-octet FR frame or 31-octet EFR frame |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
256 entirely omitted, and shall be 0 otherwise. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
257 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
258 BFI: this bit is strictly identical with TRAU-UL frame bit C12. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
259 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
260 TAF: this bit is strictly identical with TRAU-UL frame bit C15. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
261 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
262 There are two possibilities for full composition of a TRAUlike RTP payload: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
263 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
264 Possibility 1: TEH with NDF=0 is followed by a standard 33-octet FR frame or a |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
265 standard 31-octet EFR frame. The signature in the upper nibble of the octet |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
266 immediately following TEH shall be correct: 0xD for FR or 0xC for EFR. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
267 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
268 Possibility 2: TEH with NDF=1 constitutes the entirety of the RTP payload for |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
269 the 20 ms time window in question. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
270 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
271 If the No_Data flag is set, BFI must also be set: the combination of NDF=1 and |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
272 BFI=0 is invalid. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
273 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
274 Per this specification, the sender of a BFI packet has the choice of sending it |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
275 in one of two forms: with or without presumed-erroneous frame bits. If the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
276 TRAUlike RTP packet is generated from bits received in an actual TRAU-UL frame |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
277 (E1 Abis or TFO), erroneous frame bits shall be included, unchanged from the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
278 TRAU-UL source. However, if the entity generating the TRAUlike RTP packet is |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
279 the ultimate point of origin (e.g., a native IP BTS), then it shall choose one |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
280 form or the other based on the situation at hand: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
281 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
282 a) if the sender does have an FR or EFR frame "on hand" but that frame is |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
283 considered to be erroneous (for example, the link quality check in |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
284 l1sap_tch_ind() in OsmoBTS), the long form of BFI shall be sent, with the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
285 presumed-erroneous frame bits included. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
286 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
287 b) if the sender does not have any FR or EFR frame at all that could be sent |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
288 (for example, if the reason for the BFI condition is because FACCH was |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
289 successfully received and decoded instead of a traffic frame), then the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
290 No_Data form of BFI shall be sent. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
291 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
292 The option of No_Data BFI is provided in this RTP transport format specification |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
293 because if this option were disallowed, senders would be tasked with an |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
294 additional burden of having to artificially generate dummy or "garbage" frame |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
295 bits. This task is slightly complicated, as explained in the following section, |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
296 and the present design moves that task from all senders to only those receivers |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
297 that need it. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
298 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
299 Lack of SID classification bits matching TRAU-UL C13 & C14 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
300 ---------------------------------------------------------- |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
301 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
302 TRAU-UL frame format includes two bits C13 & C14 that carry the ternany SID flag |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
303 (0, 1 or 2) as defined in GSM 06.31 and 06.81 section 6.1.1 (same section in |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
304 both specs). No equivalent bits are included in the TRAUlike RTP transport |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
305 format as defined by this specification - however, these bits are redundant. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
306 The rules of section 6.1.1 in GSM 06.31 and 06.81, hereafter called S611 rules, |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
307 specify a strictly deterministic, unambiguous formula by which these C13 & C14 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
308 bits derive their values from the bit content of the FR/EFR frame payload - |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
309 thus if a TRAU-UL frame is received in which these C13 & C14 bits fail to match |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
310 the S611 value derived from the contained payload, then that TRAU-UL frame is |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
311 defective. There is no need to include such redundant bits in our TRAUlike RTP |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
312 format, only to create confusion for receivers as to which source of SID S611 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
313 classification they should use. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
314 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
315 Feeding received TRAUlike BFI frames to an EFR decoder |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
316 ====================================================== |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
317 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
318 If an EFR decoder implementation is based on the reference C source from ETSI, |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
319 this decoder requires that _some_ frame bits input be fed to it at all times, |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
320 even when BFI=1. But what if the BFI packet came in as No_Data? In that case |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
321 the receiver must synthesize its own fake "bad data" bits to feed to the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
322 standard decoder. When synthesizing "bad data" bits in this manner, the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
323 following rules should be observed: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
324 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
325 * The 140 bits corresponding to "fixed codebook excitation pulses" (35 bits in |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
326 each of the 4 subframes) shall be filled using a PRNG. These bits are the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
327 ones used by the standard decoder when its internal state, based on previous |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
328 good frames, puts it in GSM 06.61 substitution/muting mode as opposed to |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
329 GSM 06.62 comfort noise generation mode. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
330 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
331 * The remaining 104 bits of the EFR frame shall be set to 0. These bits are |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
332 never used by the standard decoder under the condition of BFI=1, and setting |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
333 them to 0 prevents the possibility of S611 rules classifying the frame as SID |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
334 even if the PRNG output in the other 140 bits happens to be all 1s in those |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
335 SID codeword bit positions (70 out of 140) that fall within the "fixed |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
336 codebook excitation pulses" portion. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
337 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
338 Converting from TRAU-UL to TRAUlike RTP |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
339 ======================================= |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
340 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
341 There will be a need to convert from standard TS 48.060 TRAU-UL frames to our |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
342 TRAUlike RTP format in the following two scenarios: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
343 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
344 1) When interfacing an E1 BTS to Osmocom RAN, when and if such support is to be |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
345 added to OsmoMGW; |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
346 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
347 2) In the CN transcoder operating in TFO mode, when forwarding received TFO |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
348 frames to the local RAN. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
349 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
350 In both cases the conversion is straightforward: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
351 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
352 * Always generate full-length TRAUlike RTP payloads, never generate No_Data in |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
353 the case of a properly received TRAU-UL speech (not idle) frame. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
354 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
355 * Forward the payload bits directly from TRAU-UL to TRAUlike RTP, for both good |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
356 and bad frames. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
357 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
358 * Directly forward BFI, TAF and DTXd frame indicator bits from TRAU-UL C-bits |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
359 to TEH octet bits. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
360 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
361 * Ignore TRAU-UL C13 & C14 bits. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
362 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
363 Converting from TRAUlike RTP to TRAU-UL |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
364 ======================================= |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
365 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
366 This direction of conversion will need to be performed in the CN transcoder when |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
367 emitting TFO frames toward the outside world. The following rules will need to |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
368 be applied: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
369 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
370 * If the incoming TRAUlike RTP payload is full-length, as opposed to No_Data, |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
371 simply copy the payload bits into the constructed TRAU-UL frame, for both |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
372 good (BFI=0) and bad (BFI=1) frames. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
373 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
374 * If the incoming TRAUlike RTP payload is No_Data, put the following filler in |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
375 the data bits portion of the TRAU-UL frame: |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
376 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
377 - For FR codec, use the silence frame of 3GPP TS 46.011 Table 1 as the filler. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
378 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
379 - For EFR codec, perform the same PRNG procedure as detailed earlier in this |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
380 document for the case of feeding a No_Data BFI packet to the standard ETSI |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
381 decoder for EFR. Given that a TFO-frame-emitting transcoder still needs to |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
382 run its regular speech decoder in order to fill the upper 6 bits of each |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
383 outgoing G.711 sample octet, the same No_Data PRNG handler will typically |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
384 be run just once for both internal decoding and TFO frame output. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
385 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
386 * Algorithmically set C13 & C14 bits in the generated TRAU-UL frame per the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
387 rules of S611. This step can be done using osmo_{fr,efr}_sid_classify() |
208
f0b90591f67c
doc/RTP-TRAUlike-format: osmo_{fr,efr}_sid_classify() merged
Mychaela Falconia <falcon@freecalypso.org>
parents:
207
diff
changeset
|
388 functions in libosmocodec, or using equivalent functions in Themyscira |
f0b90591f67c
doc/RTP-TRAUlike-format: osmo_{fr,efr}_sid_classify() merged
Mychaela Falconia <falcon@freecalypso.org>
parents:
207
diff
changeset
|
389 libgsmefr and libgsmfrp. |
207
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
390 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
391 * Directly forward BFI, TAF and DTXd frame indicator bits from TEH octet bits |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
392 to TRAU-UL C12, C15 and C17, respectively. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
393 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
394 Mixing standard RFC 3551 and TRAUlike RTP payloads |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
395 ================================================== |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
396 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
397 An RTP stream receiver for FR/EFR codecs that supports the present non-standard |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
398 extension to the RTP payload format shall behave gracefully when it receives a |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
399 mixture of standard RFC 3551 payloads and TRAUlike payloads in the same RTP |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
400 stream. A receiver that has no interest in the additional information carried |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
401 in the TRAUlike Extension Header shall simply strip the TEH octet when one is |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
402 received, reducing the received payload to standard RFC 3551; if a BFI or |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
403 No_Data payload is received, treat it the same as if nothing at all was |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
404 received. A receiver that is interested in the TRAUlike Extension Header but |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
405 receives an FR/EFR payload without one should behave as if it received a TEH |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
406 with BFI=0, TAF=0, and a received zero-length RTP payload should be treated the |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
407 same as receiving a No_Data TRAUlike payload with TAF=0. |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
408 |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
409 There may even be cases when an RTP sender may alternate between sending |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
410 standard RFC 3551 payloads and TRAUlike payloads in the same session: for |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
411 example, a TFO-supporting CN transcoder may emit "plain" RFC 3551 payloads when |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
412 supplying the output of its free-running speech encoder, but switch to sending |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
413 TRAUlike payloads when it switches to forwarding bits received in TFO frames |
185225722714
doc: new extended RTP format
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
414 from the far end. |