## **ON Semiconductor** ### Is Now To learn more about onsemi™, please visit our website at www.onsemi.com onsemi and ONSEMI. and other names, marks, and brands are registered and/or common law trademarks of Semiconductor Components Industries, LLC dba "onsemi" or its affiliates and/or subsidiaries in the United States and/or other countries. onsemi owns the rights to a number of patents, trademarks, copyrights, trade secrets, and other intellectual property. A listing of onsemi product/patent coverage may be accessed at www.onsemi.com/site/pdf/Patent-Marking.pdf. onsemi reserves the right to make changes at any time to any products or information herein is provided "as-is" and onsemi makes no warranty, representation or guarantee regarding the accuracy of the information, product features, availability, functionality, or suitability of its products for any particular purpose, nor does onsemi assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation special, consequential or incidental damages. Buyer is responsible for its products and applications using onsemi products, including compliance with all laws, regulations and safety requirements or standards, regardless of any support or applications information provided by onsemi. "Typical" parameters which may be provided in onsemi data sheets and/ or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. onsemi does not convey any license under any of its intellectual property rights nor the rights of others. onsemi products are not designed, intended, or authorized for use as a critical component in life support systems or any FDA Class 3 medical devices or medical devices with a same or similar classification in a foreign jurisdiction or any devices intended for implantation in the human body. Should Buyer purchase or use onsemi products for any such unintended or unauthorized application, ## **AND9309/D** # **Forward Error Correction** (FEC) #### Overview Forward Error Correction (FEC) is a method to make a transceiver more robust against noise. This is achieved by inserting redundant bits, i.e. bits that are computed from other bits and therefore do not contain independent information, which allow the receiver to correctly decode the bitstream even if some bits have been corrupted by noise. The AX5042 supports FEC. If enabled, two new blocks are inserted into the transmit chain between encoder and modulator: - 1. An encoder adds redundant bits to the bitstream - 2. An interleaver reorders the bitstream The inverse operations are inserted into the receive chain: - A deinterleaver and its associated synchronization circuitry re-reorders the bits into their natural order - 2. A Viterbi decoder recovers the original transmit bits #### Operation The encoder and the decoder operate fully automatically and do not need any software intervention. The de-interleaver synchronization circuitry however needs some help from the microcontroller software. While the encoder and the decoder operate independent from any framing format, the deinterleaver synchronization requires HDLC Flags. That is, in order to use FEC, the framing format must be HDLC, and the differential encoder, inverter, scrambler and Manchester must be off. Note that the scrambler is not necessary with FEC, since the convolutional encoder already removes DC content and shapes the output spectrum. Whenever two or more sequential (back-to-back) HDLC flags enter the FEC encoder, it aligns the second and all following flags to the interleaver by inserting up to 7 zeros. The De-interleaver synchronization circuitry in the receiver then searches for this aligned and interleaved flag sequence. It is therefore recommended to transmit two flags between packets, to allow a receiver that missed the first packet the chance to synchronize for the second packet. The receiver automatically searches for the synchronization sequence. It needs to be prevented by the microcontroller from the following: - 1. from changing the synchronization during reception - from falsely locking and keeping lock on the wrong phase ON Semiconductor® www.onsemi.com #### **APPLICATION NOTE** The receiver is prevented from changing the synchronization when both FECPOS and FECNEG in the FEC register are zero. Restarting the synchronization after false lock is achieved by first clearing both FECPOS and FECNEG in the FEC register, and then re-enable either FECPOS or FECNEG or both. The microcontroller firmware has to implement a heuristic that balances the following conflicting goals: - Freeze synchronization as soon as a correct reception is likely going on, otherwise a correct packet might be corrupted by a false relock - Restart synchronization as soon as possible if it is locked falsely, otherwise the receiver might miss a packet. The following criteria may be used as part of this heuristic: - If a sequence of say 10 back-to-back flags is received, that likely indicates that the receiver is correctly synchronized and receives the transmitter preamble, so synchronization should be frozen. - Most frame formats employ a destination address at the beginning of the frame. If a HDLC frame start is received and the destination address does not match the local station, this either indicates an "uninteresting" packet or false lock, and therefore synchronization should be restarted. The details of the heuristic are very much dependent on the actual frame format and the timing of the system, so they should be tuned accordingly. #### AND9309/D #### **FEC Specific Register Bank Description** This section describes the bits of the parts of the register bank related to FEC in detail. The registers are grouped by functional block to facilitate programming. No checks are made whether the programmed combination of bits makes sense! Bit 0 is always the LSB. NOTES: Whole registers or register bits marked as reserved should be kept at their default values. All addresses not documented here must not be accessed, neither in reading nor in writing. **Table 1. CONTROL REGISTER MAP** | | | | | Bit | | | | | | | | | |--------------------------|-----------|-----|----------|-----------------------|------------|--------|--------|---|---|------------|---------------------------------------------|-------------| | Add | Name | Dir | Reset | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Description | | Forward Error Correction | | | | | | | | | | | | | | 18 | FEC | RW | 00000000 | SHORTMEM | RSTVITERBI | FECNEG | FECPOS | | | | FEC (Viterbi)<br>Configuration | | | 19 | FECSYNC | RW | 01100010 | ( ) | | | | | | | Interleaver<br>Synchronization<br>Threshold | | | 1A | FECSTATUS | RW | | FECINV MAXMETRIC(6:0) | | | | | | FEC Status | | | #### Register Descriptions **Table 2. FEC**The register controls the operation of the forward error correction (FEC) block. | Name | Bits | R/W | Reset | Description | |-------------|------|-----|-------|------------------------------------------------| | FECENA | 0 | RW | 0 | Enable FEC (Encoder) | | FECINPSHIFT | 3:1 | RW | 000 | Attenuate soft Rx Data by 2-FECINPSHIFT | | FECPOS | 4 | RW | 0 | Enable noninverted Interleaver Synchronization | | FECNEG | 5 | RW | 0 | Enable inverted Interleaver Synchronization | | RSTVITERBI | 6 | RW | 0 | Reset Viterbi Decoder | | SHORTMEM | 7 | RW | 0 | Shorten Backtrack Memory | FECENA enables the Forward Error Correction and the Interleaver. For PSK, enable both FECPOS and FECNEG. For all other modulations, only FECPOS should be enabled. In the TX, HDLC flags are aligned (by inserting zero bits) to the interleaver. In the RX, a convolver to the encoded / interleaved flag sequence establishes deinterleaver synchronization and inversion detection. Therefore, FEC only works together with HDLC framing. The Viterbi decoder uses soft metric. #### **Table 3. FECSYNC** This register specifies the interleaver synchronization threshold. | Name | Bits | R/W | Reset | Description | |---------|------|-----|----------|---------------------------------------| | FECSYNC | 7:0 | RW | 01100010 | Interleaver Synchronization Threshold | #### Table 4. FECSTATUS This register reports the synchronization status. | Name | Bits | R/W | Reset | Description | |-----------|------|-----|-------|--------------------------------------------| | MAXMETRIC | 6:0 | R | | Metric increment of the survivor path | | FECINV | 7 | R | _ | Inverted Synchronization Sequence received | #### AND9309/D #### References - [1] AX5042 Datasheet, see <a href="http://www.onsemi.com">http://www.onsemi.com</a> - [2] AX5042 Programming Manual, see <a href="http://www.onsemi.com">http://www.onsemi.com</a> - [3] AX5042 Evaluation Software, see <a href="http://www.onsemi.com">http://www.onsemi.com</a> - [4] Wikipedia. High-Level Data Link Control. <a href="http://en.wikipedia.org/wiki/HDLC">http://en.wikipedia.org/wiki/HDLC</a> ON Semiconductor and in are trademarks of Semiconductor Components Industries, LLC dba ON Semiconductor or its subsidiaries in the United States and/or other countries. ON Semiconductor owns me rights to a number of patents, trademarks, copyrights, trade secrets, and other intellectual property. A listing of ON Semiconductor's product/patent coverage may be accessed at <a href="www.onsemi.com/site/pdf/Patent-Marking.pdf">www.onsemi.com/site/pdf/Patent-Marking.pdf</a>. ON Semiconductor reserves the right to make changes without further notice to any products herein. ON Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does ON Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation special, consequential or incidental damages. Buyer is responsible for its products and applications using ON Semiconductor products, including compliance with all laws, regulations and safety requirements or standards, regardless of any support or applications information provided by ON Semiconductor. "Typical" parameters which may be provided in ON Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. ON Semiconductor does not convey any license under its patent rights nor the rights of others. ON Semiconductor products are not designed, intended, or authorized for use as a critical component in life support systems or any FDA Class 3 medical devices or medical devices with a same or similar classification in a foreign jurisdiction or any devices intended for implantation in the human body. Should Buyer purchase or use ON Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold #### **PUBLICATION ORDERING INFORMATION** #### LITERATURE FULFILLMENT: Literature Distribution Center for ON Semiconductor 19521 E. 32nd Pkwy, Aurora, Colorado 80011 USA Phone: 303-675-2175 or 800-344-3860 Toll Free USA/Canada Fax: 303-675-2176 or 800-344-3867 Toll Free USA/Canada Email: orderlit@onsemi.com N. American Technical Support: 800-282-9855 Toll Free USA/Canada Europe, Middle East and Africa Technical Support: Europe, Middle East and Africa Technical Support: Phone: 421 33 790 2910 Japan Customer Focus Center Phone: 81-3-5817-1050 ON Semiconductor Website: www.onsemi.com Order Literature: http://www.onsemi.com/orderlit For additional information, please contact your local Sales Representative