**![](data:image/png;base64,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)**

165 Gibraltar Ct,

Sunnyvale, CA 94089

**DFE Low Level Driver**

**Software Design Specification (SDS)**

Revision A

<9/18/2013>

NOTICE OF CONFIDENTIAL AND PROPRIETARY INFORMATION

Information contained herein is subject to the terms of the Non-Disclosure Agreement between Texas Instruments Incorporated and your company, and is of a highly sensitive nature. It is confidential and proprietary to Texas Instruments Incorporated. It shall not be distributed, reproduced, or disclosed orally or in written form, in whole or in part, to any party other than the direct recipients without the express written consent of Texas Instruments Incorporated.

|  |  |
| --- | --- |
| Revision Record | |
| Document Title: **DFE LLD Software Design Specification** | |
| Revision | Description of Change |
| A | Initial Release |
|  |  |
|  |  |

Note: Be sure the Revision of this document matches the Approval record Revision letter. The revision letter increments only upon approval via the Quality Record System.

**TABLE OF CONTENTS**

1 Scope 1

2 References 1

3 Definitions 1

4 Overview 2

5 Design 3

5.1 Objects and Limitations 3

5.2 Software Resource Requirements 4

5.3 Interface Data Structures 4

5.4 DFE Peripheral Configuration 7

6 DFE LLD APIs 7

6.1 Open 7

6.2 Close 8

6.3 Load Target Configuration 9

6.4 Soft Reset 9

6.5 Initialization Sequence for Transmit Path 10

6.6 Initialization Sequence for Receive Path 11

6.7 Get Device Information 12

6.8 Issue Sync 13

6.9 Get Sync Status 14

6.10 Program Sync Counter 15

6.11 Issue Sync Start Sync Counter 16

6.12 Program BBTX Gain 16

6.13 Issue Sync Update BBTX Gain 17

6.14 Get BBTX Gain Update Complete 18

6.15 Program BBTX Power Meter 19

6.16 Issue Sync Update BBTX Power Meter 20

6.17 Clear BBTX Power Meter Done Status 21

6.18 Get BBTX Power Meter Done Status 21

6.19 Read BBTX Power Meter 22

6.20 Open BBTX Power Meter DMA 23

6.21 Close BBTX Power Meter DMA 24

6.22 Enable BBTX Power Meter DMA 25

6.23 Disable BBTX Power Meter DMA 25

6.24 Program BBRX Gain 26

6.25 Issue Sync Update BBRX Gain 27

6.26 Get BBRX Gain Update Complete 28

6.27 Program BBRX Power Meter 28

6.28 Issue Sync Update BBRX Power Meter 30

6.29 Clear BBRX Power Meter Done Status 30

6.30 Get BBRX Power Meter Done Status 31

6.31 Read BBRX Power Meter 32

6.32 Open BBRX Power Meter DMA 32

6.33 Close BBRX Power Meter DMA 34

6.34 Enable BBRX Power Meter DMA 34

6.35 Disable BBRX Power Meter DMA 35

6.36 Enable Disable BB AID Loopback 36

6.37 Program BB BUF Loopback 37

6.38 Set BB AID UL Strobe Delay 38

6.39 Program BB SigGen Ramp 38

6.40 Issue Sync Update BB SigGen 39

6.41 Program BB TestBus 40

6.42 Program DDUC Mixer NCO Frequency 41

6.43 Issue Sync Update DDUC Mixer NCO Frequency 41

6.44 Program DDUC Mixer Phase 42

6.45 Issue Sync Update DDUC Mixer Phase 43

6.46 Program DDUC Farrow Phase 44

6.47 Issue Sync Update DDUC Farrow Phase 44

6.48 Program Distributor Map 45

6.49 Issue Sync Update Distributor Map 46

6.50 Program Summer Shift 47

6.51 Program Summer Map 47

6.52 Issue Sync Update Summer Map 48

6.53 Program CFR Coefficients 49

6.54 Issue Sync Update CFR Coefficients 50

6.55 Program CFR preGain 50

6.56 Issue Sync Update CFR preGain 51

6.57 Program CFR postGain 52

6.58 Issue Sync Update CFR postGain 53

6.59 Program CFR Protection Gain 53

6.60 Program TX Mixer 54

6.61 Issue Sync Update TX Mixer 55

6.62 Program TX PA Protection 56

6.63 Get TX PA Protection Interrupt Status 57

6.64 Clear TX PA Protection Interrupt Status 58

6.65 Read TX PA Protection Power Status 59

6.66 Program JESD Tx to Lane Map 60

6.67 Program JESD Tx SigGen Ramp 61

6.68 Issue Sync Update JESDTX SigGen 62

6.69 Program JESD Tx Testbus 63

6.70 Get JESD Tx Link Status 63

6.71 Get JESD Tx Lane Status 64

6.72 Clear JESD Tx Link Errors 65

6.73 Clear JESD Tx Lane Errors 66

6.74 Program JESD Lane to Rx Map 67

6.75 Program JESD Loopback 68

6.76 Program JESD Rx Testbus 69

6.77 Get JESD Rx Link Status 69

6.78 Get JESD Rx Lane Status 70

6.79 Clear JESD Rx Link Error 72

6.80 Clear JESD Rx Lane Error 72

6.81 Program RX IBPM Global 73

6.82 Program RX IBPM 74

6.83 Issue Sync Update RX IBPM 75

6.84 Issue RX IBPM Read Request 76

6.85 Get RX IBPM Read Ack 77

6.86 Read RX IBPM Result 78

6.87 Program RX Equalizer 78

6.88 Issue Sync Update RX Equalizer 80

6.89 Program RX Mixer NCO 80

6.90 Issue Sync Update RX Mixer NCO Frequency 81

6.91 Program Rx Testbus 82

6.92 Program FB Equalizer 82

6.93 Issue Sync Update FB Equalizer 83

6.94 Program FB Mixer NCO 84

6.95 Issue Sync Update FB Mixer NCO 85

6.96 Program FB IO Mux 86

6.97 Program FB pre-CB Gain 86

6.98 Issue Sync Update Fb pre-CB Gain 87

6.99 Program CB Node Config 88

6.100 Program CB Buf Config 89

6.101 Arm CB and Issue Sync 90

6.102 Get CB Done Status 90

6.103 Read CB Buf 91

6.104 Open CB Buf DMA 92

6.105 Close CB Buf DMA 93

6.106 Enable CB Buf DMA 94

6.107 Disable CB Buf DMA 94

6.108 Disable All TestBus 95

6.109 Program DFE GPIO PinMux 95

6.110 Set DFE GPIO Sync Out Source 97

6.111 Set DFE GPIO Bank Output 97

6.112 Get DFE GPIO Bank Input 98

6.113 Open Generic IO DMA 99

6.114 Close Generic IO DMA 100

6.115 Prepare Generic DMA Embedded Header 100

6.116 Enable Lut toggle 102

6.117 SetSyncSel for Lut 102

6.118 Issue Sync Update Lut 103

6.119 Get Current Lut memory index 104

6.120 Program Lut table 104

6.121 Get Dpd configuration 105

6.122 Load DPDA image 106

6.123 Read DPDA IG register 107

6.124 Read DPDA parameters 108

6.125 Read DPDA scalar register 108

6.126 Start DPDA 109

6.127 Write DPDA IG register 110

6.128 Write DPDA samples 110

6.129 Write DPDA scalar register 111

7 Integration 112

7.1 OSAL 112

**7.1.1** Logging API 112

7.2 Integration on ARM Linux 112

7.3 Integration on DSP SysBios 113

8 Future Extensions 113

# Scope

This document describes the functionality, architecture, and operation of the Digital Radio Front-End (DFE) Low Level Driver (LLD).

# References

The following references are related to the feature described in this document and shall be consulted as necessary.

|  |  |  |  |
| --- | --- | --- | --- |
| No | Referenced Document | Control Number | Description |
| 1 | IQN2 User Guide | Version x.x.x | IQN2 User Guide |
| 2 | CPPI User Guide | Version x.x.x | CPPI User Guide |
| 3 | DEF CSL API Document | Version x.x.x | DOXYGEN generated API documentation located in the package under the “docs” directory in CHM format. |

Table 1. Referenced Materials

# Definitions

| **Acronym** | **Description** |
| --- | --- |
| DFE | Digital radio Front-End |
| API | Application Programming Interface |
| IQN2 | IQNet2 |
| CPPI | Communication Port Programming Interface |
| LLD | Low Level Driver |
| CTL | IQN2 ConTroL channel, for shipping non-iq data packets |
| CPP/DMA | CTL Packet Process, a DMA engine in DFE |
| CTL | Control data, non i/q stream |
| CB | Capture Buffer in DFE |
| BB | Baseband |
| DDUC | Digital Down/Up Convertor |
| SUM | Summer, map DDUC Tx Channels to a Tx stream |
| CFR | Crest Factor Reduction |
| DPD | Digital Pre-Distortion |
| JESD |  |
| FB | Feedback path in DFE |
| DIST | Distributor, map DDUC Rx channels to a Rx stream |
| TX | Transmit, an IP block between DPD and JESDTX |
| RX | Receive, an IP block between DDUC and JESDRX |
| NCO | Numeric Controlled Oscillator |

Table 2. Definitions

# Overview

DFE is a high performance wideband digital IF transmit and receive signal processing peripheral for small cell base station applications. It implements advanced algorithms for RF power amplifier linearization including crest factor reduction (CFR) and digital pre-distortion (DPD), and for correcting other receiver RF impairments like IQ imbalance, DC offset and distortion.

![](data:image/x-emf;base64,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)

Figure 1, DFE Diagram

In signal processing Tx path,

* BB TX has gain adjustment and power meter per carrier;
* DDUC TX setups carrier mixer frequency and phase, PFIR coefficients, Farrow channel phase;
* SUM maps DDUC Tx channel to Tx stream and then adjusts stream gain by shift control;
* CFR has preCFR gain, postCFR gain adjustments, CFR filter coefficients update;
* DPD LUTs are updated after software complete iteration;
* TX has a PA protection block which signals CFR to reduce gain when abnormal peak and/or power detected;
* JESDTX reports link/lane status for transmit connection.

In signal processing Rx path,

* JESDTX reports link/lane status for receiving connection, and controls JESD lane loopback;
* RX has programmable equalizer, NCO mixer;
* FB has programmable equalizer, NCO mixer, IO Mux, and gain adjustment before CB;
* DIST maps RX stream to DDUC Rx channel;
* BB RX has gain adjustment and power meter per carrier;

SoC reads/writes DFE via memory mapped registers. DFE has a built-in DMA engine, CPP/DMA, which allows big chunks of data move in/out very efficiently via PktDMA. Software should use CPP/DMA as much as possible.

CB can capture up to 32K complex samples at hardware nodes and test-bus positions in signal path. DPD adaptation uses CB to get reference and feedback buffers. CB is also a great tool to peek what is going on in signal path.

MISC block controls feedback switch GPIOs and top level interrupts aggregation.

# Design

## Objects and Limitations

DFE LLD just supports open single device instance for each DFE peripheral. The application software should take care of necessary serialization or arbitration in multi-cores multi-threads operation system. In Linux, the LLD is running in user mode.

DFE LLD just configures, controls, writes, reads DFE block. Any other block accessing is out of scope. IQN2 is the bridge between DFE and other parts of SoC; PktDMA is the preferred way to move data bulks into/out of DFE.

* For using IQN2, please refer to IQN2 User Guide
* For using PktDMA, please refer to CPPI User Guide

DFE LLD API should run to completion without any waiting loop longer than 1ms, especially no polling internally for any event, such as a sync event, a done interrupt event. One solution is to break the operation to several APIs, and let the calling thread do the waiting part. The example is capture buffer operation, whose pseudo calling sequence in high layer is like,

|  |
| --- |
| GetCB()  {  /\* setup CB Nodes and Buffers \*/  Setup();  /\* arm CB block with selected sync \*/  ArmCb();  /\* wait for CB done \*/  While(get\_done\_status() == FALSE) { /\* spin wait \*/ }  /\* read data back \*/  Read\_data();  } |

Another solution is using callback function when there need a waiting function. The example is DFE initialization sequence, which has many steps need wait for sync counter sync events.

To be flexible, DFE LLD doesn’t maintain antenna mapping, which should be taken care by high level software. On the other hand, it supports conversion between friendly arguments and hardware recognized values. For example, signal power reading API returns peak and rms power in floating number dB, rather than raw register values.

DFE LLD doesn’t have built-in interrupt service routines. To check if an interrupt event has come, high level software has to use polling method.

## Software Resource Requirements

In each direction, IQN2 has total 48 channels connect to DFE. Any channel can map to either BB(IQ) or CPP/DMA(CTL). In practice, first 32 ones are recommended mapping to BB, next 16 ones mapping to CPP/DMA. Enable all 16 CTL channels are highly recommended when configure IQN2.

|  |  |
| --- | --- |
| **Lamarr IQN2 Egress Queue** | **Recommend Map** |
| 832 ~ 863 | Transferring IQ packets to DFE BBTX |
| 864 ~ 879 | Transferring CTL packets to DFE CPP/DMA |

DFE LLD does not maintain any global object and context.

## Interface Data Structures

All LLD APIs are running within the device instance context DFE\_Obj, which is user allocated but initialized in DFE\_open().

|  |
| --- |
| typedef struct \_DFE\_Obj  {  // DFE CSL object  DfeFl\_Obj objDfe;  // DFE\_BB CSL object  DfeFl\_BbObj objDfeBb[DFE\_FL\_BB\_PER\_CNT];  // DFE\_DDUC CSL object  DfeFl\_DducObj objDfeDduc[DFE\_FL\_DDUC\_PER\_CNT];  // DFE\_SUMMER CSL object  DfeFl\_SummerObj objDfeSummer[DFE\_FL\_SUMMER\_PER\_CNT];  // DFE\_AUTOCP CSL object  DfeFl\_AutocpObj objDfeAutocp[DFE\_FL\_AUTOCP\_PER\_CNT];  // DFE\_CFR CSL object  DfeFl\_CfrObj objDfeCfr[DFE\_FL\_CFR\_PER\_CNT];  // DFE\_CDFR CSL object  DfeFl\_CdfrObj objDfeCdfr[DFE\_FL\_CDFR\_PER\_CNT];  // DFE\_DPD CSL object  DfeFl\_DpdObj objDfeDpd[DFE\_FL\_DPD\_PER\_CNT];  // DFE\_DPDA CSL object  DfeFl\_DpdaObj objDfeDpda[DFE\_FL\_DPDA\_PER\_CNT];  // DFE\_TX CSL object  DfeFl\_TxObj objDfeTx[DFE\_FL\_TX\_PER\_CNT];  // DFE\_RX CSL object  DfeFl\_RxObj objDfeRx[DFE\_FL\_RX\_PER\_CNT];  // DFE\_CB CSL object  DfeFl\_CbObj objDfeCb[DFE\_FL\_CB\_PER\_CNT];  // DFE\_JESD CSL object  DfeFl\_JesdObj objDfeJesd[DFE\_FL\_JESD\_PER\_CNT];  // DFE\_FB CSL object  DfeFl\_FbObj objDfeFb[DFE\_FL\_FB\_PER\_CNT];  // DFE\_MISC CSL object  DfeFl\_MiscObj objDfeMisc[DFE\_FL\_MISC\_PER\_CNT];    // DFE CSL context  DfeFl\_Context dfeCtx;  // DFE CSL param  DfeFl\_Param dfeParam;  // DFE CSL Handle  DfeFl\_Handle hDfe;  // DFE\_BB CSL Handle  DfeFl\_BbHandle hDfeBb[DFE\_FL\_BB\_PER\_CNT];  // DFE\_DDUC CSL Handle  DfeFl\_DducHandle hDfeDduc[DFE\_FL\_DDUC\_PER\_CNT];  // DFE\_SUMMER CSL Handle  DfeFl\_SummerHandle hDfeSummer[DFE\_FL\_SUMMER\_PER\_CNT];  // DFE\_AUTOCP CSL Handle  DfeFl\_AutocpHandle hDfeAutocp[DFE\_FL\_AUTOCP\_PER\_CNT];  // DFE\_CFR CSL Handle  DfeFl\_CfrHandle hDfeCfr[DFE\_FL\_CFR\_PER\_CNT];  // DFE\_CDFR CSL Handle  DfeFl\_CdfrHandle hDfeCdfr[DFE\_FL\_CDFR\_PER\_CNT];  // DFE\_DPD CSL Handle  DfeFl\_DpdHandle hDfeDpd[DFE\_FL\_DPD\_PER\_CNT];  // DFE\_DPDA CSL Handle  DfeFl\_DpdaHandle hDfeDpda[DFE\_FL\_DPDA\_PER\_CNT];  // DFE\_TX CSL Handle  DfeFl\_TxHandle hDfeTx[DFE\_FL\_TX\_PER\_CNT];  // DFE\_RX CSL Handle  DfeFl\_RxHandle hDfeRx[DFE\_FL\_RX\_PER\_CNT];  // DFE\_CB CSL Handle  DfeFl\_CbHandle hDfeCb[DFE\_FL\_CB\_PER\_CNT];  // DFE\_JESD CSL Handle  DfeFl\_JesdHandle hDfeJesd[DFE\_FL\_JESD\_PER\_CNT];  // DFE\_FB CSL Handle  DfeFl\_FbHandle hDfeFb[DFE\_FL\_FB\_PER\_CNT];  // DFE\_MISC CSL Handle  DfeFl\_MiscHandle hDfeMisc[DFE\_FL\_MISC\_PER\_CNT];  // DFE\_CPP CSL resource manager  DfeFl\_CppResMgr cppResMgr;  // BBTX power meter for CPP/DMA  uint32\_t bbtxPowmtr;  // dma handle for BBTX power meter  DfeFl\_CppDmaHandle hDmaBbtxPowmtr;  // descriptor handle for BBTX power meter  DfeFl\_CppDescriptorHandle hDescripBbtxPowmtr;  // IQN2 CTL Ingress Channel for BBTX power meter  uint32\_t bbtxPowmtrIqnChnl;    // BBRX power meter for CPP/DMA  uint32\_t bbrxPowmtr;  // dma handle for BBRX power meter  DfeFl\_CppDmaHandle hDmaBbrxPowmtr;  // descriptor handle for BBRX power meter  DfeFl\_CppDescriptorHandle hDescripBbrxPowmtr;  // descriptor handle for BBTX power meter  uint32\_t bbrxPowmtrIqnChnl;  // flag to read all 18 bit Cb  uint32\_t flag\_18bit;  // dma handle for cb  DfeFl\_CppDmaHandle hDmaCb;  // descriptor handle for cb  DfeFl\_CppDescriptorHandle hDescripCb[8];  // IQN2 CTL Channel  uint32\_t cbIqnChnl;  // sync counter ssel  DfeFl\_MiscSyncGenSig sync\_cnter\_ssel;  // bbtx siggen ssel  uint32\_t bbtx\_siggen\_ssel;  // bbrx checksum ssel  uint32\_t bbrx\_chksum\_ssel;  // ulStrobe strobe  DfeFl\_MiscSyncGenSig ulStrobe\_Sync;  // RX IBPM Unity Magnitude Sqaure value (=I^2 + Q^2)  uint64\_t rxIbpmUnityMagsq;    // generic DMA hndle  DfeFl\_CppDmaHandle hDmaGeneric;  // IQN2 CTL Egress channel for generic writing DMA  uint32\_t genericDmaIqnChnlDl;  // IQN2 CTL Ingress channel for generic reading DMA  uint32\_t genericDmaIqnChnlUl;  } DFE\_Obj;  typedef DFE\_Obj \* DFE\_Handle; |

User also defines CPP/DMA reserved channels and reserved descriptors in the resource management table, which will be saved to the device context in Dfe\_open(). Reserved channel/descriptor can only be opened using explicit Id of the resource; non-reserved resource can be opened using DFE\_FL\_CPP\_OPEN\_ANY.

|  |
| --- |
| /\*\* CPP resource manager \*/  typedef struct \_DFE\_CppResTbl  {  // reserved dma bitmask  Uint32 dmaRsvd;    // discrete trigger out  Uint32 discreteTrig[DFE\_FL\_CPP\_NUM\_DISCRETE\_TRIGGERS];    // four 32-bits words, each bit corresponding to one descriptor  // reserved descriptor bitmask  Uint32 descripRsvd[4];    } DFE\_CppResTbl; |

## DFE Peripheral Configuration

To properly configure DFE, the following sequence must be followed,

|  |  |  |
| --- | --- | --- |
| **Step** | **Description** | **DFE LLD API** |
| 1 | Program DFE PLL to correct operation rate |  |
| 2 | Power up IQN2 and DFE power domains |  |
| 3 | Program SERDES to corresponding rate |  |
| 4 | Program analogue front-end which connects with DFE |  |
| 5 | Open DFE LLD | Dfe\_open() |
| 5 | Load DFE target configuration | Dfe\_loadTgtCfg() |
|  | Soft Reset DFE peripheral | Dfe\_softReset() |
|  | Check and wait SERDES PLL\_OK |  |
| 6 | Do DFE initialization sequence for transmit path | Dfe\_initTgtTx() |
|  | Check and wait SERDES OK and !LOSS |  |
|  | Do DFE initialization sequence for receive path | Dfe\_initTgtRx() |
| 7 | QMSS, CPPI configuration |  |
| 8 | IQN2 configuration and enable |  |

# DFE LLD APIs

## Open

Open DFE LLD device.

**Prototype**

|  |
| --- |
| DFE\_Handle Dfe\_open  (  int dfeInst,  DFE\_Obj \*dfeObj,  DFE\_CppResTbl \*dfeResTbl,  DFE\_Err \*err  ); |

**Description**

|  |
| --- |
| Open DFE low level driver device instance. Before call the API, the caller should allocate the memory buffer for DFE\_Obj, which will be the context for the life of DFE LLD. The buffer shall not be allocated from stack.  Upon Dfe\_open() succeeds, the error code is set to DFE\_ERR\_NONE.   * DFE LLD object dfeObj has been initialized. * User defined resource management table has been saved to instance context. * A valid DFE\_Handle value is returned.   When the error code is DFE\_ERR\_INVALID\_DEVICE, the LLD doesn’t find the specified dfeInst device.  The API should only be called once. |

**Arguments**

|  |  |
| --- | --- |
| dfeInst | [in] DFE device instance number |
| dfeObj | [out] DFE LLD device context |
| dfeResTbl | [in] DFE resource management table |
| err | [out] exit error code |

**Return Value**

|  |
| --- |
| A valid DFE\_Handle value is returned when the call succeeds; otherwise a NULL is returned. |

**Constrains**

|  |
| --- |
| 1. dfeObj buffer shall not be allocated in stack. 2. Dfe\_open() should be called only once. |

## Close

Close DFE LLD device opened by Dfe\_open().

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_close  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| Close DFE low level driver device instance, which was opened by Dfe\_open(). |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if close properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). |

## Load Target Configuration

Load DFE target configuration, i.e. registers contents.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_loadTgtCfg  (  DFE\_Handle hDfe,  DFE\_RegPair tgtCfgPairs[]  ); |

**Description**

|  |
| --- |
| Write target configuration i.e. registers contents, to DFE hardware. The target config format is defined as,  // (addr, data) register pair  typedef struct  {  // offset address from DFE base address  Uint32 addr;  // data to/from addr  Uint32 data;  } DFE\_RegPair;    The last entity of tgtCfgPairs must be (0xffffffffu, 0xffffffffu), which is the end marker. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| tgtCfgPairs | [in] pointer to (addr, adta) pairs buffer |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if write to DFE properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. The last entity of tgtCfgPairs must be (0xffffffffu, 0xffffffffu) 3. DFE PLL and PSCs shall be already up running. |

## Soft Reset

Do soft reset for DFE peripheral.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_softReset  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| The API does a software reset for DFE peripheral. Like power up reset, soft reset does assert init\_clk\_gate, init\_state, and clear\_data to all sub-blocks in DFE. On the other hand unlike power up reset, soft reset keeps all registers values unchanged, except for init register in each block.  Soft reset should be done after Dfe\_loadTgtCfg() but before Dfe\_initTgtTx(), and Dfe\_initTgtRx(). |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if soft reset properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. Dfe\_loadTgtCfg() already called. |

## Initialization Sequence for Transmit Path

DFE initialization sequence for transmit path.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_initTgtTx  (  DFE\_Handle hDfe,  DFE\_CallbackContext waitSyncCtx,  DFE\_CallbackWaitSync waitSyncFxn  ); |

**Description**

|  |
| --- |
| The API runs initialization sequence for transmit path.  When JESD Tx lanes configured connecting to SERDES, this initialization shouldn’t be made until SERDES Tx lock (pll\_ok).  In the sequence, there’re many steps need wait a sync signal. This is done by callback waitSyncFxn().  // callback function for waiting sync signal  // return DFE\_ERR\_OK if sync signal come properly  // return DFE\_ERR\_TIMEDOUT if sync signal not come before timed out  typedef DFE\_Err (\*DFE\_CallbackWaitSync)  (  // callback context  DFE\_CallbackContext cbkCtx,  // DFE device handle  DFE\_Handle hDfe,  // sync signal to be waiting  DfeFl\_MiscSyncGenSig syncSig;  );  When complete with DFE\_ERR\_NONE, DFE transmit path is ready working, otherwise DFE peripheral is in unknown condition. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| waitSyncCtx | [in] callback context pass to waitSyncFxn |
| waitSyncFxn | [in] callback function for waiting a sync signal |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if initialization properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_SYNC\_NOT\_COME, if sync signal not come  DFE\_ERR\_CALLBACKFXN\_IS\_NULL, if callback function required but given a NULL pointer  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. Dfe\_softReset() already called. |

## Initialization Sequence for Receive Path

DFE initialization sequence for receive path.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_initTgtRx  (  DFE\_Handle hDfe,  DFE\_CallbackContext waitSyncCtx,  DFE\_CallbackWaitSync waitSyncFxn  ); |

**Description**

|  |
| --- |
| The API runs initialization sequence for receive path.  When JESD Rx lanes configured connecting to SERDES, this initialization shouldn’t be made until SERDES Rx OK bit set and LOSS bit cleared.  In the sequence, there’re many steps need wait a sync signal. This is done by callback waitSyncFxn().  // callback function for waiting sync signal  // return DFE\_ERR\_OK if sync signal come properly  // return DFE\_ERR\_TIMEDOUT if sync signal not come before timed out  typedef DFE\_Err (\*DFE\_CallbackWaitSync)  (  // callback context  DFE\_CallbackContext cbkCtx,  // DFE device handle  DFE\_Handle hDfe,  // sync signal to be waiting  DfeFl\_MiscSyncGenSig syncSig;  );  When complete with DFE\_ERR\_NONE, DFE receive path is ready working, otherwise DFE peripheral is in unknown condition. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| waitSyncCtx | [in] callback context pass to waitSyncFxn |
| waitSyncFxn | [in] callback function for waiting a sync signal |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if initialization properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_SYNC\_NOT\_COME, if sync signal not come  DFE\_ERR\_CALLBACKFXN\_IS\_NULL, if callback function required but given a NULL pointer  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. Dfe\_initTgtTx() already called. |

## Get Device Information

Get back DFE device information, such as PID, base address etc.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getDevInfo  (  DFE\_Handle hDfe,  DFE\_DevInfo \*devInfo  ); |

**Description**

|  |
| --- |
| Get back DFE device information, such as PID, base address etc.  Write target configuration i.e. registers contents, to DFE hardware. The target config format is defined as,  // DFE Device information  typedef struct  {  // DFE peripheral ID  Uint32 pid;  // DFE peripheral base address  void \*baseAddr;  // DFE LLD version  Uint32 version;  } DFE\_DevInfo; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| devInfo | [out] pointer to devInfo buffer |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if get info properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_INVALID\_PARAMS, if devInfo is NULL |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. |

## Issue Sync

Issue a sync signal.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSync  (  DFE\_Handle hDfe,  DfeFl\_MiscSyncGenSig syncSig,  Uint32 waitCnt  ); |

**Description**

|  |
| --- |
| Issue a sync signal.   * If waitCnt is DFE\_FL\_MISC\_SYNC\_NOWAIT, the function just does issue the sync and returns DFE\_ERR\_NONE immediately. Dfe\_getSyncStatus() can be called later to check if the sync has come. * If waitCnt is DFE\_FL\_MISC\_SYNC\_WAITFOREVER, the function waits until the signal has really come. And then returns DFE\_ERR\_NONE. * If waitCnt is DFE\_FL\_MISC\_SYNC\_WAIT(n), 0 < n < 0xfffffffu, the function waits until  1. either the signal has come before n loops complete, returns DFE\_ERR\_NONE; 2. or n loops complete but the signal not come, returns DFE\_ERR\_SYNC\_NOT\_COME   For performance and flexible considerations, using DFE\_FL\_MISC\_SYNC\_NOWAIT for waitCnt is recommended. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| syncSig | [in] sync signal to be issued |
| waitCnt | [in] wait loop count |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if issue sync done properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_SYNC\_NOT\_COME, if sync signal not coming within waitCnt loops.  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get Sync Status

Get a sync signal status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getSyncStatus  (  DFE\_Handle hDfe,  DfeFl\_MiscSyncGenSig syncSig,  Uint32 \*signaled  ); |

**Description**

|  |
| --- |
| Get status of a sync signal. When return, if \*signaled is 1, the sync has come; if \*signaled is 0, the sync hasn’t come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| syncSig | [in] sync signal to be issued |
| signalled | [out] pointer to signal status buffer |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if issue sync done properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program Sync Counter

Program a sync counter.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progSyncCounter  (  DFE\_Handle hDfe,  DfeFl\_MiscSyncGenCntr cntr,  Uint32 delay,  Uint32 period,  Uint32 pulseWidth,  Uint32 repeat,  Uint32 invert  ); |

**Description**

|  |
| --- |
| The API first resets the counter and then reprogram to specified parameters.  **NOTE,** Dfe\_issueSyncStartSyncCounter() should be then called to start the counter. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cntr | [in] sync counter number |
| delay | [in] number of clocks to wait after sync select source before sending initial sync. If set to 0, sync counter output will be high if sync select source is high |
| period | [in] number of clocks to wait between syncs when repeat is 1. Does nothing when repeat is 0. |
| pulseWidth | [in] set to X for pulse width of X clocks; 0 means it will never go high. |
| repeat | [in] If 0, counter counts down delay clocks once, sends a sync, and stops. If 1, it counts down delay clocks sends a sync, then continuously sends more syncs every period clocks. |
| invert | [in] set to 1 to invert entire bus |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if sync counter programmed properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncStartSyncCounter() should be called later to issue sync to start the counter. |

## Issue Sync Start Sync Counter

Issue sync to start the sync counter, and return without waiting.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_ issueSyncStartSyncCounter  (  DFE\_Handle hDfe,  DfeFl\_MiscSyncGenCntr cntr,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to start the sync counter that has been already programmed by Dfe\_progSyncCounter(). It programs the counter’s starting sync select with ssel (using ALWAYS sync signal) and returns immediately after issue the sync. So Dfe\_getSyncStatus() should be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cntr | [in] sync counter number |
| ssel | [in] sync select to re-start sync counter |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program BBTX Gain

Program BBTX AxCs with new gains.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progBbtxGain  (  DFE\_Handle hDfe,  Uint32 numAxCs,  Uint32 axc[],  float gain[]  ); |

**Description**

|  |
| --- |
| Write new BBTX AxCs’ gains to shadow memory. The range for a gain is  -84dB ~ +6dB. The API changes gain’s real part only.  **NOTE,** Dfe\_issueSyncUpdateBbtxGain should be called later to let hardware copy gains from shadow to working memory. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| numAxCs | [in] number of AxCs whose gains are to be changed |
| axc | [in] array of AxCs whose gains are to be changed |
| gain | [in] array of new real gains, in dB |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateBbtxGain () should be called later to copy gains to working memory. |

## Issue Sync Update BBTX Gain

Issue sync update BBTX gain to new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateBbtxGain  (  DFE\_Handle hDfe,  Uint32 ct,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to copy BBTX gains from shadow to working memory. Dfe\_getSyncStatus() should be called later to check if the sync has come.  This API also clears update complete interrupt status bit of the corresponding carrier type.  To check if update complete, call Dfe\_getBbtxGainUpdateComplete().  **NOTE,** Both axc\_valid bit and gain\_en bit (in register dfe.bb.bbtxif\_axc\_config0) have to be set ‘1’, in order to see effectiveness of the gains. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| ct | [in] carrier type |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get BBTX Gain Update Complete

Get BBTX gain update complete status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getBbtxGainUpdateComplete  (  DFE\_Handle hDfe,  Uint32 ct,  Uint32 \*complete  ); |

**Description**

|  |
| --- |
| Get BBTX gain update complete status. The API first reads txgain\_update\_status, if corresponding ct bit is clear, then the update is still in progress. Otherwise, it further reads back and returns the update complete interrupt status. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| ct | [in] carrier type |
| complete | [out] buffer of update complete status  0 = still in progress  1 = update complete |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL HwGetStatus() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program BBTX Power Meter

Program BBTX power meter with new configuration.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progBbtxPowmtr  (  DFE\_Handle hDfe,  Uint32 pmId,  DFE\_BbtxPowmtrConfig \*mtrCfg  ); |

**Description**

|  |
| --- |
| Write new BBTX power meter configuration.  // BBTX power meter config  typedef struct  {  // enable power meter function  DfeFl\_BbPowMtrEnable enable;  // carrier type  Uint32 countSource;  // power meter input source  DfeFl\_BbPowMtrInSource inSource;  // tdd mode  DfeFl\_BbPowMtrTddMode tddMode;  // delay from sync  Uint32 syncDly;  // meter interval  Uint32 interval;  // integration period  Uint32 intgPd;  // count of measurements, i.e. count of intervals  Uint32 powUptIntvl;  } DFE\_BbtxPowmtrConfig;  **NOTE,** Dfe\_issueSyncUpdateBbtxPowmtr should be called later to let hardware take the configuration. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] BBTX power meter Id, 0 ~ 15 |
| mtrCfg | [in] new meter configuration |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateBbtxPowmtr() should be called later to let hardware take new configuration. |

## Issue Sync Update BBTX Power Meter

Issue sync update BBTX power meter to new configuration.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateBbtxPowmtr  (  DFE\_Handle hDfe,  Uint32 pmId,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to let BBTX power meter run with new configuration. Dfe\_getSyncStatus() may be called later to check if the sync has come.  **NOTE,** Both axc\_valid bit and pm\_en bit (in register dfe.bb.bbtxif\_axc\_config0) have to be set ‘1’, in order to make power meter run measurement. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] BBTX power meter Id, 0 ~ 15 |
| ssel | [in] sync select to update power meter |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Clear BBTX Power Meter Done Status

Clear BBTX power meter complete interrupt status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_clearBbtxPowmtrDoneIntrStatus  (  DFE\_Handle hDfe,  Uint32 pmId  ); |

**Description**

|  |
| --- |
| Clear complete interrupt status of a BBTX power meter. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] BBTX power meter Id, 0 ~ 15 |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get BBTX Power Meter Done Status

Get BBTX power meter complete interrupt status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getBbtxPowmtrDoneIntrStatus  (  DFE\_Handle hDfe,  Uint32 pmId,  Uint32 \*complete  ); |

**Description**

|  |
| --- |
| Get complete interrupt status of a BBTX power meter. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] BBTX power meter Id, 0 ~ 15 |
| complete | [out] BBTX power meter complete status,  0 = measurement not complete yet  1 = measurement complete |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Read BBTX Power Meter

Read BBTX power meter result via CPU.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_readBbtxPowmtr  (  DFE\_Handle hDfe,  Uint32 pmId,  float \*peak,  float \*rms  ); |

**Description**

|  |
| --- |
| Read peak and RMS power results of a BBTX power meter via CPU. It reads DFE registers directly and convert them to friendly values in dB.  The API doesn’t wait for a new measurement; it read back whatever current result.  **NOTE,** Both axc\_valid bit and pm\_en bit (in register dfe.bb.bbtxif\_axc\_config0) have to be set ‘1’, in order to make power meter run measurement. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] BBTX power meter Id, 0 ~ 15 |
| peak | [out] peak power of AxC |
| rms | [out] RMS power of AxC |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete programmed properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Open BBTX Power Meter DMA

Open CPP/DMA for reading BBTX power meters.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_openBbtxPowmtrDma  (  DFE\_Handle hDfe,  Uint32 cppDmaId,  Uint32 cppDescripId,  Uint32 iqnChnl  ); |

**Description**

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Allocate CPP/DMA channel and descriptor for BBTX power meter results uploading.  Every power meter results 4 words, first twos for peak power, last twos for RMS power. Both peak power and RMS power are formatted in floating point (26 bit mantissa + 6 bit exponent). The mantissa is a <10.16> format.     |  |  |  | | --- | --- | --- | | Word# | Bit[31..16] | Bit[15..0] | | 0 | Not Used | Peak power  Bit[15..6], 10-bits integer portion of mantissa.  Bit[5..0], 6-bits exponent (of 2-based) | | 1 | Not Used | Peak power  16-bits fraction portion of mantissa. | | 2 | Not Used | RMS power  Bit[15..6], 10-bits integer portion of mantissa.  Bit[5..0], 6-bits exponent (of 2-based) | | 3 | Not Used | RMS power  16-bits fraction portion of mantissa. |   There’re total 16 power meters for BBTX, result total 64 words. A DMA transact uploads all 64 words in one shot.  When BBTX power meter DMA already opened, call this API again will get error DFE\_ERR\_ALREADY\_OPENED. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cppDmaId | [in] CPP/DMA channel Id  0 ~ 31, open with specified channel  DFE\_FL\_CPP\_OPEN\_ANY, open with any available channel |
| cppDescripId | [in] CPP/DMA descriptor Id  0 ~ 127, open with specified descriptor  DFE\_FL\_CPP\_OPEN\_ANY, open with any available descriptor |
| iqnChnl | [in] IQN2 CTL Ingress channel number, 0 ~ 15 |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_AVAILABLE, if CPP/DMA channel not available  DFE\_ERR\_CPP\_DESCRIP\_NOT\_AVAILABLE, if CPP/Descriptor not available  DFE\_ERR\_ALREADY\_OPENED, if BBTX power meter DMA already opened  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Close BBTX Power Meter DMA

Close BBTX Power Meter DMA and free recourses.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_closeBbtxPowmtr  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| Close BBTX power meter DMA and free resources allocated by Dfe\_openBbtxPowmtrDma(). |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_VALID, if CPP/DMA handle not valid |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_openBbtxPowmtrDma() has called OK. |

## Enable BBTX Power Meter DMA

Enable BBTX Power Meter DMA.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_enableBbtxPowmtr  (  DFE\_Handle hDfe,  Uint32 pmId  ); |

**Description**

|  |
| --- |
| Enable CPP/DMA for BBTX Power Meter DMA by doing following   1. Set dma\_ssel to sense ALT\_BBTX\_PWRMTR 2. Set txpm\_auxint\_mask to (1u << pmId)   When power meter of pmId completes a measurement, ALT\_BBTX\_PWRMTR interrupt will trigger CPP/DMA to start transferring. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] Id of BBTX power meter that triggers CPP/DMA |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_VALID, if CPP/DMA handle not valid  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_openBbtxPowmtrDma() has called OK. |

## Disable BBTX Power Meter DMA

Disable BBTX Power Meter DMA.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_disableBbtxPowmtr  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| Disable BBTX power meter DMA by doing following steps,   1. Clear txpm\_auxint\_mask, cut off BBTX power meter complete signal to CPP/DMA 2. Change dma\_ssel not to sense any signal |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_VALID, if CPP/DMA handle not valid  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_openBbtxPowmtrDma() has called OK. |

## Program BBRX Gain

Program BBRX AxCs with new gains.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progBbrxGain  (  DFE\_Handle hDfe,  Uint32 numAxCs,  Uint32 axc[],  float gain[]  ); |

**Description**

|  |
| --- |
| Write new BBRX AxCs’ gains to shadow memory. The range of gain is -48.16dB ~ +96.3dB. When gain less than -48.2dB, samples are clamped to 0.  **NOTE,** Dfe\_issueSyncUpdateBbrxGain should be called later to let hardware copy gains from shadow to working memory. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| numAxCs | [in] number of AxCs whose gains are to be changed |
| axc | [in] array of AxCs whose gains are to be changed |
| gain | [in] array of new gains, in dB |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateBbtxGain () should be called later to copy gains to working memory. |

## Issue Sync Update BBRX Gain

Issue sync update BBRX gain to new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateBbrxGain  (  DFE\_Handle hDfe,  Uint32 ct,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to copy BBRX gains from shadow to working memory. Dfe\_getSyncStatus() should be called later to check if the sync has come.  **NOTE,** in order to make gains effectively, dfe.bb.bbrxif\_axc\_config0.axc\_valid bit have be ‘1’, and dfe.bb.bbrxif\_axc\_config0.beagc\_mode value must be in range 0 ~ 3. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| ct | [in] carrier type |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get BBRX Gain Update Complete

Get BBRX gain update complete status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getBbrxGainUpdateComplete  (  DFE\_Handle hDfe,  Uint32 ct,  Uint32 \*complete  ); |

**Description**

|  |
| --- |
| Get BBRX gain update complete status. The API first reads rxgain\_update\_status, if corresponding ct bit is clear, then the update is still in progress. Otherwise, it further reads back and returns the update complete interrupt status. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| ct | [in] carrier type |
| complete | [out] buffer of update complete status  0 = still in progress  1 = update complete |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL HwGetStatus() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program BBRX Power Meter

Program BBRX power meter with new configuration.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progBbrxPowmtr  (  DFE\_Handle hDfe,  Uint32 pmId,  DFE\_BbrxPowmtrConfig \*mtrCfg  ); |

**Description**

|  |
| --- |
| Write new BBRX power meter configuration.  // BBTX power meter config  typedef struct  {  // enable power meter function  DfeFl\_BbPowMtrEnable enable;  // carrier type  Uint32 countSource;  // power meter input source  DfeFl\_BbPowMtrInSource inSource;  // tdd mode  DfeFl\_BbPowMtrTddMode tddMode;  // delay from sync  Uint32 syncDly;  // meter interval  Uint32 interval;  // integration period  Uint32 intgPd;  // count of measurements, i.e. count of intervals  Uint32 powUptIntvl;  // RX Maximum full scale power in dB for the programmed power interval time.  // Used by feed forward power update.  // Value is in units of 0.05dB resolution  Uint32 maxdB  } DFE\_BbrxPowmtrConfig;  **NOTE,** Dfe\_issueSyncUpdateBbrxPowmtr should be called later to let hardware take the configuration. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] BBRX power meter Id, 0 ~ 15 |
| mtrCfg | [in] new meter configuration |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateBbrxPowmtr() should be called later to let hardware take new configuration. |

## Issue Sync Update BBRX Power Meter

Issue sync update BBRX power meter to new configuration.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateBbrxPowmtr  (  DFE\_Handle hDfe,  Uint32 pmId,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to let BBRX power meter run with new configuration. Dfe\_getSyncStatus() may be called later to check if the sync has come.  **NOTE,** Both dfe.bb.bbrxif\_axc\_config0.axc\_valid bit and dfe.bb.bbrxif\_axc\_config1.pm\_en bit have to be set ‘1’, in order to make power meter run measurement. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] BBRX power meter Id, 0 ~ 15 |
| ssel | [in] sync select to update power meter |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Clear BBRX Power Meter Done Status

Clear BBRX power meter complete interrupt status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_clearBbrx PowmtrDoneIntrStatus  (  DFE\_Handle hDfe,  Uint32 pmId  ); |

**Description**

|  |
| --- |
| Clear complete interrupt status of a BBRX power meter. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] BBRX power meter Id, 0 ~ 15 |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get BBRX Power Meter Done Status

Get BBRX power meter complete interrupt status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getBbrxPowmtrDoneIntrStatus  (  DFE\_Handle hDfe,  Uint32 pmId,  Uint32 \*complete  ); |

**Description**

|  |
| --- |
| Get complete interrupt status of a BBRX power meter. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] BBRX power meter Id, 0 ~ 15 |
| complete | [out] BBRX power meter complete status,  0 = measurement not complete yet  1 = measurement complete |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Read BBRX Power Meter

Read BBRX power meter result via CPU.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_readBbrxPowmtr  (  DFE\_Handle hDfe,  Uint32 pmId,  float \*peak,  float \*rms  ); |

**Description**

|  |
| --- |
| Read peak and RMS power results of a BBRX power meter via CPU. It reads DFE registers directly and convert them to friendly values in dB.  The API doesn’t wait for a new measurement; it read back whatever current result.  **NOTE,** Both dfe.bb.bbrxif\_axc\_config0.axc\_valid bit and dfe.bb.bbrxif\_axc\_config1.pm\_en bit have to be set ‘1’, in order to make power meter run measurement. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] BBRX power meter Id, 0 ~ 15 |
| peak | [out] peak power of AxC |
| rms | [out] RMS power of AxC |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete programmed properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Open BBRX Power Meter DMA

Open CPP/DMA for reading BBTX power meters.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_openBbrxPowmtrDma  (  DFE\_Handle hDfe,  Uint32 cppDmaId,  Uint32 cppDescripId,  Uint32 iqnChnl  ); |

**Description**

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Allocate CPP/DMA channel and descriptor for BBRX power meter results uploading.  Every power meter results 4 words, first twos for peak power, last twos for RMS power. Both peak power and RMS power are formatted in floating point (26 bit mantissa + 6 bit exponent). The mantissa is a <10.16> format.     |  |  |  | | --- | --- | --- | | Word# | Bit[31..16] | Bit[15..0] | | 0 | Not Used | Peak power  Bit[15..6], 10-bits integer portion of mantissa.  Bit[5..0], 6-bits exponent (of 2-based) | | 1 | Not Used | Peak power  16-bits fraction portion of mantissa. | | 2 | Not Used | RMS power  Bit[15..6], 10-bits integer portion of mantissa.  Bit[5..0], 6-bits exponent (of 2-based) | | 3 | Not Used | RMS power  16-bits fraction portion of mantissa. |   There’re total 16 power meters for BBRX, result total 64 words. A DMA transact uploads all 64 words in one shot.  When BBRX power meter DMA already opened, call this API again will get error DFE\_ERR\_ALREADY\_OPENED. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cppDmaId | [in] CPP/DMA channel Id  0 ~ 31, open with specified channel  DFE\_FL\_CPP\_OPEN\_ANY, open with any available channel |
| cppDescripId | [in] CPP/DMA descriptor Id  0 ~ 127, open with specified descriptor  DFE\_FL\_CPP\_OPEN\_ANY, open with any available descriptor |
| iqnChnl | [in] IQN2 CTL Ingress channel number, 0 ~ 15 |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_AVAILABLE, if CPP/DMA channel not available  DFE\_ERR\_CPP\_DESCRIP\_NOT\_AVAILABLE, if CPP/Descriptor not available  DFE\_ERR\_ALREADY\_OPENED, if BBRX power meter DMA already opened  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Close BBRX Power Meter DMA

Close BBRX Power Meter DMA and free recourses.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_closeBbrxPowmtr  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| Close BBRX power meter DMA and free resources allocated by Dfe\_openBbrxPowmtrDma(). |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_VALID, if CPP/DMA handle not valid |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_openBbrxPowmtrDma() has called OK. |

## Enable BBRX Power Meter DMA

Enable BBRX Power Meter DMA.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_enableBbrxPowmtr  (  DFE\_Handle hDfe,  Uint32 pmId  ); |

**Description**

|  |
| --- |
| Enable CPP/DMA for BBRX Power Meter DMA by doing following   1. Set dma\_ssel to sense ALT\_BBRX\_PWRMTR 2. Set rxpm\_auxint\_mask to (1u << pmId)   When power meter of pmId completes a measurement, ALT\_BBRX\_PWRMTR interrupt will trigger CPP/DMA to start transferring. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] Id of BBRX power meter that triggers CPP/DMA |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_VALID, if CPP/DMA handle not valid  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_openBbrxPowmtrDma() has called OK. |

## Disable BBRX Power Meter DMA

Disable BBRX Power Meter DMA.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_disableBbrxPowmtr  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| Disable BBRX power meter DMA by doing following steps,   * Clear rxpm\_auxint\_mask, cut off BBRX power meter complete signal to CPP/DMA * Change dma\_ssel not to sense any signal |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_VALID, if CPP/DMA handle not valid DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_openBbrxPowmtrDma() has called OK. |

## Enable Disable BB AID Loopback

Enable/Disable BB AID loopback.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_enableDisableBbaidLoopback  (  DFE\_Handle hDfe,  Uint32 enable  ); |

**Description**

|  |
| --- |
| BB AID loopback is very useful to test IQ data flow before DFE.  **For LTE the loop is like**,  BB DL buffer 🡺 Queue 🡺 IQN2 (PktDMA, AID2) 🡺 DFE (BB\_AID) 🡺 IQN2 (AID2, PktDMA) 🡺 BB UL Buffer;  **For WCDMA the loop is like**,  BB DL buffer 🡺 IQN2 (DIO2, AID2) 🡺 DFE (BB\_AID) 🡺 IQN2 (AID2, DIO2) 🡺 BB UL buffer  Set enable to ‘1’ to enable BB AID loopback; clear it to ‘0’ to disable BB AID loopback.  **NOTE**, BB AID loopback isn’t working well when AxCs having different rates. In this case, BB Buf loopback can be used, see Dfe\_progBbbufLoopback(). |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| Enable | [in] 1 to enable BB AID loopback, 0 to disable |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program BB BUF Loopback

Program BB Buf loopback.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progBbbufLoopback  (  DFE\_Handle hDfe,  DfeFl\_BbLoopbackConfig \*bufLoopback  ); |

**Description**

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| BB Buf loopback loops back IQ data flow before DFE DDUC.  **For LTE,**  BB DL buffer 🡺 Queue 🡺 IQN2 (PktDMA, AID2) 🡺 DFE (BBAID, BBBUF) 🡺 DFE (BB\_BUF, BB\_AID) 🡺 IQN2 (AID2, PktDMA) 🡺 BB UL Buffer;  **For WCDMA,**  BB DL buffer 🡺 IQN2 (DIO2, AID2) 🡺 DFE (BB\_AID, BB\_BUF) 🡺 DFE (BB\_BUF, BB\_AID)🡺 IQN2 (AID2, DIO2) 🡺 BB UL buffer  Typical setup for argument bufLoopback,   |  |  |  | | --- | --- | --- | | **Use Case** | **bufLoopback**  **member setup** | **Description** | | No loopback | All = ‘0’ | Normal operation mode | | Two dducs loopback | duc0ToDdc1 = ‘1’; other = ‘0’ | dduc0 🡺 dduc1 | | Four dducs loopback | duc1ToDdc2 = ‘1’;  duc0ToDdc3 = ‘1’;  other = ‘0’ | dduc0 🡺 dduc3  dduc1 🡺 dduc2 | | Eight dducs loopback | duc3ToDdc4 = ‘1’; duc2ToDdc5 = ‘1’;  duc1ToDdc6 = ‘1’;  duc0ToDdc7 = ‘1’;  other = ‘0’ | dduc0 🡺 dduc7  dduc1 🡺 dduc6  dduc2 🡺 dduc5  dduc3 🡺 dduc4 | |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| bufLoopback | [in] Buf loopback configuration |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Set BB AID UL Strobe Delay

Set BB AID UpLink strobe delay for specified carrier type.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_setBbaidUlstrobeDelay  (  DFE\_Handle hDfe,  Uint32 ct,  Uint32 dly  ); |

**Description**

|  |
| --- |
| Set BB AID UL Strobe delay to adjust the time from the UL\_STROBE to when FRAME\_START is generated. This API is very useful to align uplink FRAME\_START to the first sample in radio frame out of BB AID. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| ct | [in] carrier type of the UL\_STROBE |
| dly | [in] Delay in carrier type samples |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program BB SigGen Ramp

Program BB Signal Generator to produce a ramp.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progBbsigGenRamp  (  DFE\_Handle hDfe,  DfeFl\_BbTestGenDev sigGenDev,  Uint32 enable,  Int16 startIq[2],  Int16 stopIq[2],  Int16 slopeIq[2]  ); |

**Description**

|  |
| --- |
| Program a BB signal geneator to produce a ramp. The startIq[0], stopIq[0], and slopeIq[0] are used to control I bus; startIq[1], stopIq[1], and slopeIq[1] are used to control Q bus. The rules should be followed,   1. startIq <= stopIq 2. (stopIq – startIq) % slopeIq = 0   When startIq equal to stopIq and slopeIq is 0, a constant is produced.  **NOTE:** BB AID signal generator produces same ramp to all BBTX channels. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| sigGenDev | [in] BB SigGen device |
| Enable | [in] 1 to enable; 0 to disable |
| startIq | [in] ramp start values for I bus and Q bus |
| stopIq | [in] ramp stop values for I bus and Q bus |
| slopeIq | [in] ramp step values for I bus and Q bus |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Issue Sync Update BB SigGen

Issue sync update BB Signal Generator.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateBbsigGen  (  DFE\_Handle hDfe,  DfeFl\_BbTestGenDev sigGenDev,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync update BB SigGen. Dfe\_getSyncStatus() can be called later to check if the sync has come.  When sync ssel comes, the ramp restarts from start value and step up the slope value per clock. When accumulated value equal to stop value, the ramp restarts again. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| sigGenDev | [in] BB SigGen device |
| ssel | [in] sync select to drive BB SigGen |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program BB TestBus

Program BB Test Bus.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progBbtestbus  (  DFE\_Handle hDfe,  DfeFl\_BbTestCbCtrl testCbCtrl,  Uint32 testCbAxc  ); |

**Description**

|  |
| --- |
| DFE has many test probe points scattered over all sub-modules. CB can be used to capture a train of IQ bus signals at the probe.  The API enables the specified BB probe to CB interface.  **NOTE,** all test probes “AND together” shares single CB interface. So software should enable no more than one probe at any time. LLD internally disables all probes first before arm a new one. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| testCbCtrl | [in] probe position |
| testCbAxc | [in] probe axc/buf number |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program DDUC Mixer NCO Frequency

Program DDUC Mixer NCO frequency.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progDducMixerNCO  (  DFE\_Handle hDfe,  Uint32 dducDev,  float refClock,  float freq[12]  ); |

**Description**

|  |
| --- |
| Write new DDUC Mixer NCO to shadow memory, this is only in the static frequency mode. The precision of the frequency is refClock/2^48.  **NOTE,** Dfe\_issueSyncUpdateDducMixerNCO () should be called later to let hardware copy gains from shadow to working memory. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| dducDev | [in] Dduc Id, 0 ~ 3 |
| refClock | [in] reference sample rate |
| freq | [in] array of frequency value |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateDducMixerNCO () should be called later to copy gains to working memory. |

## Issue Sync Update DDUC Mixer NCO Frequency

Issue sync update DDUC Mixer NCO frequency to new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateDducMixerNCO  (  DFE\_Handle hDfe,  Uint32 dducDev,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to copy DDUC Mixer NCO frequency from shadow to working memory. Dfe\_getSyncStatus() should be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| dducDev | [in] Dduc Id, 0 ~ 3 |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program DDUC Mixer Phase

Program DDUC Mixer phase with new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progDducMixerPhase  (  DFE\_Handle hDfe,  Uint32 dducDev,  float phase[12]  ); |

**Description**

|  |
| --- |
| Write new DDUC Mixer phase to shadow memory. The precision for the phase is 360/65536 degree.    **NOTE,** Dfe\_issueSyncUpdateDducMixerPhase () should be called later to let hardware copy gains from shadow to working memory. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| dducDev | [in] Dduc Id, 0 ~ 3 |
| phase | [in] array of new phase, in degree |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateDducMixerPhase () should be called later to copy gains to working memory. |

## Issue Sync Update DDUC Mixer Phase

Issue sync update DDUC Mixer phase to new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateDducMixerPhase  (  DFE\_Handle hDfe,  Uint32 dducDev,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to copy DDUC Mixer phase from shadow to working memory. Dfe\_getSyncStatus() should be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| dducDev | [in] Dduc Id, 0 ~ 3 |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program DDUC Farrow Phase

Program DDUC Farrow Phase with new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progDducFarrowPhase  (  DFE\_Handle hDfe,  Uint32 dducDev,  Uint32 fifo[12],  float phase[12]  ); |

**Description**

|  |
| --- |
| Write new DDUC Farrow phase to shadow memory. The fifo is from 0 ~ 63. The phase range is -0.5 ~ 0.5.  **NOTE,** Dfe\_issueSyncUpdateDducFarrowPhase () should be called later to let hardware copy gains from shadow to working memory. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| dducDev | [in] Dduc Id, 0 ~ 3 |
| fifo | [in] array of fifo |
| phase | [in] array of new phase |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateDducFarrowPhase () should be called later to copy gains to working memory. |

## Issue Sync Update DDUC Farrow Phase

Issue sync update DDUC Farrow phase to new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateDducFarrowPhase  (  DFE\_Handle hDfe,  Uint32 dducDev,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to copy DDUC farrow phase from shadow to working memory. Dfe\_getSyncStatus() should be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| dducDev | [in] Dduc Id, 0 ~ 3 |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program Distributor Map

Program DDUC distributor map.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progDducDistMap  (  DFE\_Handle hDfe,  Uint32 dducDev,  Uint32 rxSel[12],  Uint32 chanSel[12]  ); |

**Description**

|  |
| --- |
| Write new DDUC distributor map to shadow memory. Each rxSel and chanSel value is associated with one DDUC channel. The first 4 channels are for mixer0, the second 4 channels are for mixer1 and the last 4 channels are for mixer2. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| dducDev | [in] Dduc Id, 0 ~ 3 |
| rxSel | [in] array of rx selection  0: from Rx  1: from feedback |
| chanSel | [in] array of chan selection, which channel from selected rx. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateDducDistMap () should be called later to copy gains to working memory. |

## Issue Sync Update Distributor Map

Issue sync update DDUC distributor map to new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateDducDistMap  (  DFE\_Handle hDfe,  Uint32 dducDev,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to copy DDUC distributor map from shadow to working memory. Dfe\_getSyncStatus() should be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| dducDev | [in] Dduc Id, 0 ~ 3 |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program Summer Shift

Program Summer shift.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progSummerShift  (  DFE\_Handle hDfe,  Uint32 cfrId,  Uint32 strId,  int gain  ); |

**Description**

|  |
| --- |
| Write new Summer shift. The range of gain is -36dB ~ 6dB, with step 6dB. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cfrId | [in] cfr Id, 0 ~ 1 |
| StrId | [in] stream Id, 0 ~ 1 |
| gain | [in] new gain, in dB |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program Summer Map

Program Summer map.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progSummerMap  (  DFE\_Handle hDfe,  Uint32 cfrId,  Uint32 strId,  Uint32 sumMap[4]  ); |

**Description**

|  |
| --- |
| Write new Summer map configuration.  **NOTE,** Dfe\_issueSyncUpdateSummerMap () should be called later to let hardware take the configuration. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cfrId | [in] Cfr Id, 0 ~ 1 |
| strId | [in] stream Id, 0 ~ 1 |
| sumMap | [in] summer map for 4 DDUC. Each word uses the 12 LSB bits to map 12 carriers for each DDUC. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateSummerMap() should be called later to let hardware take new configuration. |

## Issue Sync Update Summer Map

Issue sync update Summer map to new configuration.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateSummerMap  (  DFE\_Handle hDfe,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to let Summer run with new configuration. Dfe\_getSyncStatus() may be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| ssel | [in] sync select to update power meter |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program CFR Coefficients

Program CFR coefficients.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progCfrCoeff  (  DFE\_Handle hDfe,  Uint32 cfrDev,  Uint32 numCoeffs,  Uint32int \*cfrCoeff\_i,  Uint32int \*cfrCoeff\_q  ); |

**Description**

|  |
| --- |
| Write new Cfr coefficients to the shadow memory. The range of each coefficient is 0 ~ 4095. The maximum number of coefficients is 256 for each Cfr instance. It is shared by all antennas in each Cfr instance.  **NOTE,** Dfe\_issueSyncUpdateCfrCoeff () should be called later to let hardware copy gains from shadow to working memory. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cfrDev | [in] Cfr device Id, 0 - 1 |
| numCoeffs | [in] number of coefficients |
| cfrCoeff\_i | [in] pointer to the real part coefficient |
| cfrCoeff\_q | [in] pointer to the image part coefficient |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateCfrCoeff () should be called later to copy gains to working memory. |

## Issue Sync Update CFR Coefficients

Issue sync update Cfr Coefficients.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateCfrCoeff  (  DFE\_Handle hDfe,  Uint32 cfrDev,  Uint32 coeffType,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync update Cfr coefficients. Dfe\_getSyncStatus() can be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cfrDev | [in] Cfr device Id, 0 - 1 |
| coeffType | [in] Cfr coefficient type,  0 means the base coefficient  1 means the half delay coefficient |
| ssel | [in] sync select to drive BB SigGen |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program CFR preGain

Program CFR preGain.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progCfrPreGain  (  DFE\_Handle hDfe,  Uint32 cfrDev,  DfeFl\_CfrPath cfrPath,  float gainGain  ); |

**Description**

|  |
| --- |
| Write new Cfr preGain to shadow memory. The range is –Inf ~ 6dB.  **NOTE,** Dfe\_issueSyncUpdateCfrPreGain () should be called later to let hardware copy gains from shadow to working memory. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cfrDev | [in] Cfr device Id, 0 - 1 |
| cfrPath | [in] Cfr path Id, 0 - 1 |
| gainGain | [in] Cfr pre gain value in dB |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateCfrPreGain() should be called later to let hardware take new configuration. |

## Issue Sync Update CFR preGain

Issue sync update CFR preGain.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdatCfrPreGain  (  DFE\_Handle hDfe,  Uint32 cfrDev,  DfeFl\_CfrPath cfrPath,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to copy CFR pre gain from shadow to working memory. Dfe\_getSyncStatus() should be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cfrDev | [in] Cfr device Id, 0 - 1 |
| cfrPath | [in] Cfr path Id, 0 - 1 |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program CFR postGain

Program CFR postGain.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progCfrPostGain  (  DFE\_Handle hDfe,  Uint32 cfrDev,  DfeFl\_CfrPath cfrPath,  float gainGain  ); |

**Description**

|  |
| --- |
| Write new Cfr postGain to shadow memory. The range is –Inf ~ 6dB.  **NOTE,** Dfe\_issueSyncUpdateCfrPostGain () should be called later to let hardware copy gains from shadow to working memory. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cfrDev | [in] Cfr device Id, 0 - 1 |
| cfrPath | [in] Cfr path Id, 0 - 1 |
| gainGain | [in] Cfr post gain value in dB |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateCfrPostGain() should be called later to let hardware take new configuration. |

## Issue Sync Update CFR postGain

Issue sync update CFR postGain.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdatCfrPostGain  (  DFE\_Handle hDfe,  Uint32 cfrDev,  DfeFl\_CfrPath cfrPath,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to copy CFR pre gain from shadow to working memory. Dfe\_getSyncStatus() should be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cfrDev | [in] Cfr device Id, 0 - 1 |
| cfrPath | [in] Cfr path Id, 0 - 1 |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program CFR Protection Gain

Program CFR protection Gain.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progCfrProtGain  (  DFE\_Handle hDfe,  Uint32 cfrDev,  DfeFl\_CfrPath cfrPath,  float gainGain  ); |

**Description**

|  |
| --- |
| Write new Cfr protection gain. It is a backoff gain when PA protection is in alarm mode. The range is –Inf ~ 6dB. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cfrDev | [in] Cfr device Id, 0 - 1 |
| cfrPath | [in] Cfr path Id, 0 - 1 |
| gainGain | [in] Cfr protection gain value in dB |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program TX Mixer

Program TX mixer.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progTxMixer  (  DFE\_Handle hDfe,  DfeFl\_TxPath txPath,  float refClock,  float freq[2]  ); |

**Description**

|  |
| --- |
| Write new Tx Mixer NCO frequency to shadow memory. The precision is refClock/2^48.  **NOTE,** Dfe\_issueSyncUpdateTxMixer () should be called later to let hardware copy gains from shadow to working memory. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| txPath | [in] Tx path Id, 0 - 1 |
| refClock | [in] reference clock |
| freq | [in] frequency value |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateTxMixer() should be called later to let hardware take new configuration. |

## Issue Sync Update TX Mixer

Issue sync update TX Mixer.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateTxMixer  (  DFE\_Handle hDfe,  DfeFl\_TxPath txPath,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to let TX Mixer run with new frequency. Dfe\_getSyncStatus() may be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| txPath | [in] Tx path Id, 0 ~ 1 |
| ssel | [in] sync select to update power meter |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program TX PA Protection

Program Tx PA protection.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progTxPaProtection  (  DFE\_Handle hDfe,  DfeFl\_TxDev txDev,  DFE\_TxPAprotPeak txPAprotPeak,  DFE\_TxPAprotRms txPAprotRms,  Uint32 mask  ); |

**Description**

|  |
| --- |
| Write new Tx PA protection configuration.  **typedef** **struct**  {  // square clipper threshold  Uint32 threshold;  // clipper counter threshold (C1)  Uint32 cc\_thr;  // peak threshold (TH0)  Uint32 TH0;  // peak counter threshold (C0)  Uint32 peak\_thr;  // peakgain counter threshold (C2)  Uint32 peakgain\_thr;  } DFE\_TxPAprotPeak;  **typedef** **struct**  {  // mu\_p for IIR  Uint32 mu0;  // mu\_q for IIR  Uint32 mu1;  // RMS threshold to reduce CFR gain(TH1)  Uint32 TH1;  // RMS threshold to shut down (TH2)  Uint32 TH2;  // RMS threshold to peak approaching saturation (TH4)  Uint32 TH4;  // threshold selection for a1  Uint32 th1Sel;  // threshold selection for a2  Uint32 th2Sel;  // threshold selection for a6  Uint32 th6Sel;  } DFE\_TxPAprotRms;  a1 = 1, RMS power is greater than TH1, the CFR gain will be reduced;  a2 = 1, RMS power is greater than TH2, the TX output will be shut down.  a3 = 1, RMS power gain is less than 1, the power is saturating.  a4 = 1, peak gain counter is greater than peakgain\_thr, peak is clipping.  a5 = 1, circular clipper counter is greater than cc\_thr, peak is clipping.  a6 = 1, RMS power is greater than TH4, power is approaching saturation.  a7 = 1, peak counter is greater than peak\_thr, peak is approaching saturation. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| txDev | [in] Tx Dev Id, 0 ~ 3 |
| txPAprotPeak | [in] Tx PA protection for peak adjustment |
| txPAProtRms | [in] Tx PA protection for rms adjustment |
| mask | [in] Tx PA protection mask configuration for stopDPD interrupt, the 5 LSB bits correspond to a5, a4, a3, a2 and a1 |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get TX PA Protection Interrupt Status

Get Tx PA protection interrupt status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getTxPAprotIntrStatus  (  DFE\_Handle hDfe,  DfeFl\_TxPaIntrpt \*txPAprotIntr  ); |

**Description**

|  |
| --- |
| Get Tx PA protection interrupt status of one Tx path.  Interrupt 1: a1 = 1;  Interrupt 2: a2 = 1;  Interrupt 3: a3 = 1;  Interrupt 4: a4 = 1 or a5 = 1;  Interrupt 5: a6 = 1;  Interrupt 6: a7 = 1;  Shutdown: a2 = 1;  lowCFRgain: a1 = 1;  stopDPD: programmable with a1, a2, a3, a4, a5 (programmable mask, then OR all unmasked bits) |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| txPAprotIntr | [out] Tx PA protection interrupt status |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Clear TX PA Protection Interrupt Status

Clear TX PA protection interrupt status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_clearTxPAprotIntrStatus  (  DFE\_Handle hDfe,  DfeFl\_TxDev txDev  ); |

**Description**

|  |
| --- |
| Clear complete interrupt status of a TX PA protection. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| txDev | [in] Tx device Id, 0 ~ 3 |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Read TX PA Protection Power Status

Read Tx PA protection internal power status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getTxPAprotPwrStatus  (  DFE\_Handle hDfe,  DfeFl\_TxDev txDev,  Uint32 clrRead,  DFE\_TxPAprotPwrStatus \*txPAprotPwrStatus  ); |

**Description**

|  |
| --- |
| Read Tx PA protection internal status of one Tx path.  **typedef** **struct**  {  // maximum magnitude of D3  Uint32 mag;  // IIR output at D50  Uint32 d50;  // IIR output at D51  Uint32 d51;  } DFE\_TxPAprotPwrStatus; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| txDev | [in] Tx device Id, 0 ~ 1 |
| clrRead | [in] flag to set clear after reading for magnitude  0 means no clear after reading  1 means clear after reading |
| txPAprotPwrStatus | [out] Tx PA protection internal status |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program JESD Tx to Lane Map

Program JESD Tx bus to lane map.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_mapJesdTx2Lane  (  Uint32 lane,  DFE\_JesdTxLaneMapPos laneMap[4]  ); |

**Description**

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Program how to fill time slots of a lane with Tx bus time slots.    A Tx bus consists of four time slots. A Tx bus time slot, an element of laneMap[], is selected by the bus# and slot# of the bus.  // Jesd Tx bus to lane map  typedef struct  {  // bus#, one of DfeFl\_JesdTxTxBus (I0, Q0, I1, Q1)  Uint32 bus;  // slot#, 0 ~ 3  Uint32 busPos;  } DFE\_JesdTxLaneMapPos;  A lane also consists of four time slots.   * laneMap[0] is mapping to lane time slot 0 * laneMap[1] is mapping to lane time slot 1 * laneMap[2] is mapping to lane time slot 2 * laneMap[3] is mapping to lane time slot 3     For example, TX0 has two interleaved antenna streams, A0 and A1, which are mapping to two lanes, lane0 and lane1, A0 => lane0, A1 => lane1.  TX0 bus format,   |  |  |  |  |  | | --- | --- | --- | --- | --- | | Bus# | Slot0 | Slot1 | Slot2 | Slot3 | | 0 (TX0\_I) | A0\_i | A1\_i | Don’t care | Don’t care | | 1 (TX0\_Q) | A0\_q | A1\_q | Don’t care | Don’t care |   Lane bus format   |  |  |  |  |  | | --- | --- | --- | --- | --- | | Lane# | Slot0 | Slot1 | Slot2 | Slot3 | | 0 (lane0) | A0\_i | A0\_q | Don’t care | Don’t care | | 1 (lane1) | A1\_i | A1\_q | Don’t care | Don’t care |   Then laneMap for lane0 should be,   |  |  |  |  |  | | --- | --- | --- | --- | --- | |  | laneMap[0] | laneMap[1] | laneMap[2] | laneMap[3] | | Bus# | 0 | 1 | Don’t care | Don’t care | | Slot# | 0 | 0 | Don’t care | Don’t care |   Then laneMap for lane1 should be,   |  |  |  |  |  | | --- | --- | --- | --- | --- | |  | laneMap[0] | laneMap[1] | laneMap[2] | laneMap[3] | | Bus# | 0 | 1 | Don’t care | Don’t care | | Slot# | 1 | 1 | Don’t care | Don’t care | |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| lane | [in] Tx lane# |
| laneMap | [in] Tx bus slot map |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program JESD Tx SigGen Ramp

Program JESDTX Signal Generator to produce a ramp.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progJesdTxSigGenRamp  (  DFE\_Handle hDfe,  DfeFl\_JesdTxSignalGen sigGenDev,  Uint32 enable,  Int32 start,  Int32 stop,  Int32 slope  ); |

**Description**

|  |
| --- |
| Program a JESDTX signal generator to produce a ramp. The rules should be followed,   1. start <= stop 2. (stop – start) % slope = 0 3. Start/stop/slope range, -131072 ~ 131071   When start equal to stop and slope is 0, a constant is produced. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| sigGenDev | [in] JESD TX SigGen device |
| Enable | [in] 1 to enable; 0 to disable |
| Start | [in] ramp start values for the bus |
| Stop | [in] ramp stop values for the bus |
| slope | [in] ramp step values for the bus |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Issue Sync Update JESDTX SigGen

Issue sync update JESDTX Signal Generator.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateJesdTxSigGen  (  DFE\_Handle hDfe,  CSL\_ DfeJesdTxSignalGen sigGenDev,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync update JESDTX SigGen. Dfe\_getSyncStatus() can be called later to check if the sync has come.  When sync ssel comes, the ramp restarts from start value and step up the slope value per clock. When accumulated value equal to stop value, the ramp restarts again. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| sigGenDev | [in] BB SigGen device |
| ssel | [in] sync select to drive BB SigGen |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program JESD Tx Testbus

Program JESDTX Test Bus.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progJesdTxTestbus  (  DFE\_Handle hDfe,  DfeFl\_JesdTxTestBusSel tp  ); |

**Description**

|  |
| --- |
| DFE has many test probe points scattered over all sub-modules. CB can be used to capture a train of IQ bus signals at the probe.  The API enables the specified JESDTX test probe to CB interface.  NOTE, all test probes “AND together” shares single CB interface. So software should enable no more than one probe at any time. LLD internally disables all probes first before arm a new one. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| tp | [in] probe position |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get JESD Tx Link Status

Get JESDTX link status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getJesdTxLinkStatus  (  DFE\_Handle hDfe,  DFE\_JesdTxLinkStatus \*linkStatus  ); |

**Description**

|  |
| --- |
| The API get back following Tx link status,  // Jesd Tx link status  typedef struct  {  // first sync request received for the link  // 0 – not seen first sync request  // 1 – seen first sync request  Uint32 firstSyncRequest[DFE\_FL\_JESD\_NUM\_LINK];  // error count as reported over SYNC~ interface.  Uint32 syncErrCount[DFE\_FL\_JESD\_NUM\_LINK];  // SYSREF alignment counter bits  Uint32 sysrefAlignCount;  // captured interrupt bit for sysref\_request\_assert  // 0 – sysref request not asserted  // 1 – sysref request asserted  Uint32 sysrefReqAssert;  // captured interrupt bit for sysref\_request\_deassert  // 0 – sysref request not de-asserted  // 1 – sysref request de-asserted  Uint32 sysrefReqDeassert;  // captured interrupt bit for sysref\_err on the link  // 0 – no sysref error  // 1 – sysref error  Uint32 sysrefErr[DFE\_FL\_JESD\_NUM\_LINK];  } DFE\_JesdTxLinkStatus; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| linkStatus | [out] pointer to link status buffer |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get JESD Tx Lane Status

Get JESDTX lanes status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getJesdTxLaneStatus  (  DFE\_Handle hDfe,  DFE\_JesdTxLaneStatus \*laneStatus  ); |

**Description**

|  |
| --- |
| The API get back following Tx lane status,  // Jesd Tx lane status  typedef struct  {  // synchronization state machine status for lane  Uint32 syncState[DFE\_FL\_JESD\_NUM\_LANE];  // FIFO status  // 0 - fifo not empty; 1 - fifo has been empty  Uint32 fifoEmpty[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - no read error; 1 - fifo read error  Uint32 fifoReadErr[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - fifo not full; 1 - fifo has been full  Uint32 fifoFull[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - no write error; 1 - fifo write error  Uint32 fifoWriteErr[DFE\_FL\_JESD\_NUM\_LANE];  } DFE\_JesdTxLaneStatus; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| laneStatus | [out] pointer to lane status buffer |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Clear JESD Tx Link Errors

Clear JESDTX link errors

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_clearJesdTxLinkErrors  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| The API clears following Tx link status,   * sysrefReqAssert * sysrefReqDeassert * sysrefErr[DFE\_FL\_JESD\_NUM\_LINK] for all links * syncErrCount[DFE\_FL\_JESD\_NUM\_LINK] for all links |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Clear JESD Tx Lane Errors

Clear JESDTX lane errors

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_clearJesdTxLaneErrors  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| The API clears following Tx lane status,   * fifoEmpty[DFE\_FL\_JESD\_NUM\_LANE] for all lanes * fifoReadErr[DFE\_FL\_JESD\_NUM\_LANE] for all lanes * fifoFull[DFE\_FL\_JESD\_NUM\_LANE] for all anes * fifoWriteErr[DFE\_FL\_JESD\_NUM\_LANE] for all lanes |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program JESD Lane to Rx Map

Program JESD lane to Rx bus map.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_mapJesdLane2Rx  (  DFE\_Handle hDfe,  Uint32 rxBus,  AVV\_JesdRxBusMapPos busMap[4]  ); |

**Description**

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Program how to fill time slots of a RX bus with lane time slots.    A Rx lane consists of four time slots. A Rx bus time slot, an element of busMap[], is selected by the lane# and slot# of the lane.  // Jesd Rx lane to bus map  typedef struct  {  // Rx lane#, 0 ~ 3  Uint32 lane;  // lane time slot  Uint32 lanePos;  // if zero data  Uint32 zeroBits;  } DFE\_JesdRxBusMapPos;  A Rx bus also consists of four time slots.   * busMap[0] is mapping to bus time slot 0 * busMap[1] is mapping to bus time slot 1 * busMap[2] is mapping to bus time slot 2 * busMap[3] is mapping to bus time slot 3     For example, two Rx lanes, lane0 and lane, are mapping to RX0, which will carry two interleaved antenna streams A0 and A1, lane0 => A0, lane1 => A1.  RX0 bus format,   |  |  |  |  |  | | --- | --- | --- | --- | --- | | Bus# | Slot0 | Slot1 | Slot2 | Slot3 | | 0 (RX0\_I) | A0\_i | A1\_i | Don’t care | Don’t care | | 1 (RX0\_Q) | A0\_q | A1\_q | Don’t care | Don’t care |   Lane bus format   |  |  |  |  |  | | --- | --- | --- | --- | --- | | Lane# | Slot0 | Slot1 | Slot2 | Slot3 | | 0 (lane0) | A0\_i | A0\_q | Don’t care | Don’t care | | 1 (lane1) | A1\_i | A1\_q | Don’t care | Don’t care |   Then busMap for RX0\_I should be,   |  |  |  |  |  | | --- | --- | --- | --- | --- | |  | busMap[0] | busMap[1] | busMap[2] | busMap[3] | | lane# | 0 | 1 | Don’t care | Don’t care | | Slot# | 0 | 0 | Don’t care | Don’t care |   Then busMap for RX0\_Q should be,   |  |  |  |  |  | | --- | --- | --- | --- | --- | |  | busMap[0] | busMap[1] | busMap[2] | busMap[3] | | lane# | 0 | 1 | Don’t care | Don’t care | | Slot# | 1 | 1 | Don’t care | Don’t care | |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| rxBus | [in] Rx bus# |
| busMap | [in] Rx lane slot map |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program JESD Loopback

Program JESD loopbacks for sync\_n, lanes or links.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progJesdLoopback  (  DFE\_Handle hDfe,  Uint32 lpbkSync[DFE\_FL\_JESD\_NUM\_LINK];  DfeFl\_JesdRxLoopbackConfig lpbkLaneLink;  ); |

**Description**

|  |
| --- |
| Enable/disable sync\_n, lanes/links loopback between JESDTX and JESDRX. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| lpbkSync | [in] 1: enable rx sync out loopback to tx sync\_n |
| lpbkLaneLink | [in] lane/link loopback config |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program JESD Rx Testbus

Program JESDRX Test Bus.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progJesdRxTestbus  (  DFE\_Handle hDfe,  DfeFl\_JesdRxTestBusSel tp  ); |

**Description**

|  |
| --- |
| DFE has many test probe points scattered over all sub-modules. CB can be used to capture a train of IQ bus signals at the probe.  The API enables the specified JESDRX test probe to CB interface.  **NOTE,** all test probes “AND together” shares single CB interface. So software should enable no more than one probe at any time. LLD internally disables all probes first before arm a new one. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| testCbCtrl | [in] probe position |
| testCbAxc | [in] probe axc/buf number |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get JESD Rx Link Status

Get JESDRX link status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getJesdRxLinkStatus  (  DFE\_Handle hDfe,  DFE\_JesdRxLinkStatus \*linkStatus  ); |

**Description**

|  |
| --- |
| The API get back following Rx link status,  // Jesd Rx link status  typedef struct  {  // SYSREF alignment counter bits  Uint32 sysrefAlignCount;  // captured interrupt bit for sysref\_request\_assert  // 0 – sysref request not asserted  // 1 – sysref request asserted  Uint32 sysrefReqAssert;  // captured interrupt bit for sysref\_request\_deassert  // 0 – sysref request not de-asserted  // 1 – sysref request de-asserted  Uint32 sysrefReqDeassert;  // captured interrupt bit for sysref\_err on the link  // 0 – no sysref error  // 1 – sysref error  Uint32 sysrefErr[DFE\_FL\_JESD\_NUM\_LINK];  } DFE\_JesdRxLinkStatus; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| linkStatus | [out] pointer to link status buffer |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get JESD Rx Lane Status

Get JESDRX lanes status.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getJesdRxLaneStatus  (  DFE\_Handle hDfe,  DFE\_JesdRxLaneStatus \*laneStatus  ); |

**Description**

|  |
| --- |
| The API get back following Tx lane status,  // Jesd Rx lane status  typedef struct  {  // code group synchronization state machine status for lane  Uint32 syncStatecodeState[DFE\_FL\_JESD\_NUM\_LANE];  // frame synchronization state machine status for lane  Uint32 frameState[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - no error; 1 - 8B/10B disparity error  Uint32 decDispErr[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - no error; 1 - 8B/10B not-in-table code error  Uint32 decCodeErr[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - no error; 1 - code group sync error  Uint32 codeSyncErr[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - no error; 1 - elastic buffer match error  //(first non-/K/ doesn't match match\_ctrl and match\_data)  Uint32 bufMatchErr[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - no error; 1 - elastic buffer overflow error (bad RBD value)  Uint32 bufOverflowErr[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - no error; 1 - link configuration error  Uint32 linkConfigErr[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - no error; 1 - frame alignment error  Uint32 frameAlignErr[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - no error; 1 - multiframe alignment error  Uint32 multiframeAlignErr[DFE\_FL\_JESD\_NUM\_LANE];  // FIFO status  // 0 - normal; 1 - fifo empty  Uint32 fifoEmpty[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - normal; 1 - fifo read error  Uint32 fifoReadErr[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - normal; 1 - fifo full  Uint32 fifoFull[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - normal; 1 - fifo write error  Uint32 fifoWriteErr[DFE\_FL\_JESD\_NUM\_LANE];  // 0 - normal; 1 - test sequence verification failed  Uint32 testSeqErr[DFE\_FL\_JESD\_NUM\_LANE];  } DFE\_JesdRxLaneStatus; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| laneStatus | [out] pointer to lane status buffer |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Clear JESD Rx Link Error

Clear JESDRX link errors

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_clearJesdRxLinkErrors  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| The API clears following Tx link status,   * sysrefReqAssert * sysrefReqDeassert * sysrefErr[DFE\_FL\_JESD\_NUM\_LINK] for all links |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Clear JESD Rx Lane Error

Clear JESDRX lane errors

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_clearJesdRxLaneErrors  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| The API clears following lane status for all Tx lanes,   * decDispErr[DFE\_FL\_JESD\_NUM\_LANE]; * decCodeErr[DFE\_FL\_JESD\_NUM\_LANE]; * codeSyncErr[DFE\_FL\_JESD\_NUM\_LANE]; * bufMatchErr[DFE\_FL\_JESD\_NUM\_LANE]; * bufOverflowErr[DFE\_FL\_JESD\_NUM\_LANE]; * linkConfigErr[DFE\_FL\_JESD\_NUM\_LANE]; * frameAlignErr[DFE\_FL\_JESD\_NUM\_LANE]; * multiframeAlignErr[DFE\_FL\_JESD\_NUM\_LANE]; * fifoEmpty[DFE\_FL\_JESD\_NUM\_LANE]; * fifoReadErr[DFE\_FL\_JESD\_NUM\_LANE]; * fifoFull[DFE\_FL\_JESD\_NUM\_LANE]; * fifoWriteErr[DFE\_FL\_JESD\_NUM\_LANE]; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program RX IBPM Global

Program global settings of Rx IBPM.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progRxIbpmGlobal  (  DFE\_Handle hDfe,  DfeFl\_RxPowmtrReadMode readMode,  float histThresh1,  float histThresh2,  CSL\_Uint64 unityMagsq  ); |

**Description**

|  |
| --- |
| Program global settings of RX IBPM. The power meters measure RMS and peak powers at Rx block input. There’re total 4 IBPMs, which can be individually configured by Dfe\_progRxIbpm() to meter one antenna.  IBPM has two reading modes, hardware interrupt mode and software handshake mode.  In the hardware interrupt mode, the power meters run per the programmed configuration and set interrupts on a per antenna basis when a new set of results have been computed and captured in the read registers. It is the responsibility of the user to read the results before the next set of results are computed and captured in the read registers. In the software handshake mode, the power meters run per the programmed configuration. The user makes a request to read a current set of results and waits until receiving an acknowledge signal from DFE hardware before reading. Upon receiving the request DFE completes the current power meter cycle, stores the results for reading, sets the acknowledge and halts any further updates until the user resets the request.  Each IBPM has two histogram counters to count number of samples whose magnitude is above the specified histThresh.  To convert between raw register values to friendly floatings in dB, LLD needs knowing the raw value of unity magnitude square (unityMagSq), i.e. I^2 + Q^2. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| readMode | [in] meter reading mode |
| histThread1 | [in] threshold in dB for histogram counter1 |
| histThread2 | [in] threshold in dB for histogram counter2 |
| unityMagsq | [in] raw value of unity magnitude square |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program RX IBPM

Program settings of an Rx IBPM.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progRxIbpm  (  DFE\_Handle hDfe,  Uint32 pmId,  Uint32 oneShot,  Uint32 meterMode,  Uint32 syncDelay,  Uint32 nSamples,  Uint32 interval  ); |

**Description**

|  |
| --- |
| Program settings of an individual RX IBPM, which meters RMS and peak power at Rx block input for one antenna.  When a sync event comes, IBPM starts a new meter cycle after syncDelay samples. The cycle completes at integration time of nSamples. When oneShot is enabled(1), IBPM does no more measurement until next sync event; when oneShot is disabled(0), IBPM starts a new measure after interval samples elapsed, and this repeats every interval. The interval shall be no less than integration time + syncDelay, otherwise IBPM never completes.  When meterMode is 0, IBPM is disabled; when meterMode is 1, IBPM is running according to configuration of sync delay, integration period and interval; when meter mode is 2, IBPM is running over a gated stream. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] power meter device ID |
| oneShot | [in] one shot mode |
| meterMode | [in] meter operational mode   * 0 = off * 1 = normal mode * 2 = gated mode |
| syncDelay | [in] delay from sync event, in samples |
| nSamples | [in] integration period, in samples |
| interval | [in] interval period, in samples |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Issue Sync Update RX IBPM

Issue sync updates an Rx IBPM.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateRxIbpm  (  DFE\_Handle hDfe,  Uint32 pmId,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync update a RX IBPM. Dfe\_getSyncStatus() can be called later to check if the sync has come.  When sync ssel comes, the power meter starts a new measurement cycle. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] Rx IBPM device Id |
| ssel | [in] sync select |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Issue RX IBPM Read Request

Issue read request to an Rx IBPM for software handshake mode.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueRxIbpmReadRequest  (  DFE\_Handle hDfe,  Uint32 pmId  ); |

**Description**

|  |
| --- |
| The API is applied for the software handshake mode only. In this mode, the user makes a request (via this API) to read a current set of results and waits until receiving an acknowledge signal (via polling Dfe\_getRxIbpmReadAck()) from DFE hardware before reading. Upon receiving the request DFE completes the current power meter cycle, stores the results for reading, sets the acknowledge and halts any further updates until the user resets the request (via Dfe\_readRxIbpmResult()). |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] Rx IBPM device Id |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get RX IBPM Read Ack

Get read acknowledge status of an Rx IBPM for software handshake mode.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getRxIbpmReadAck  (  DFE\_Handle hDfe,  Uint32 pmId,  Uint32 \*ackRead  ); |

**Description**

|  |
| --- |
| The API is applied for the software handshake mode only. In this mode, the user makes a request (via Dfe\_issueRxIbpmReadRequest()) to read a current set of results and waits until receiving an acknowledge signal (via polling this API) from DFE hardware before reading. Upon receiving the request DFE completes the current power meter cycle, stores the results for reading, sets the acknowledge and halts any further updates until the user resets the request (via Dfe\_readRxIbpmResult()). |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] Rx IBPM device Id |
| ackRead | [in] acknowledge status   * 0, still updating * 1, read acknowledged |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Read RX IBPM Result

Read back results of an Rx IBPM.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_readRxIbpmResult  (  DFE\_Handle hDfe,  Uint32 pmId,  float \*power,  float \*peak,  Uint32 \*histCount1,  Uint32 \*histCount2  ); |

**Description**

|  |
| --- |
| Read back results of a running RX IBPM. After retrieves all results, for hardware interrupt mode, the API writes done reading flag to DFE; for software handshake mode, the API clears read request, which was set by Dfe\_IssueRxIbpmReadRequest(). |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pmId | [in] Rx IBPM device Id |
| power | [out] Power value |
| peak | [out] peak value |
| histCount1 | [out] the number of samples which power is greater than the histogram one threshold |
| histCount2 | [out] the number of samples which power is greater than the histogram two threshold |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program RX Equalizer

Program RX Equalizer.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progRxEqr  (  DFE\_Handle hDfe,  Uint32 rxDev,  Uint32 shift,  Uint32 numCoeff,  DFE\_RxEqrTaps \*RxEqrTaps  ); |

**Description**

|  |
| --- |
| Write new RX Equalizer to shadow memory. The range of each tap is -1 ~ 0.9998. Eqr bypass needs to be disabled.  **NOTE,** Dfe\_issueSyncUpdateRxEqr () should be called later to let hardware copy gains from shadow to working memory.  typedef struct  {  // ii taps  float taps\_ii[DFE\_FL\_RX\_EQR\_LEN];  // iq taps  float taps\_iq[DFE\_FL\_RX\_EQR\_LEN];  // qi taps  float taps\_qi[DFE\_FL\_RX\_EQR\_LEN];  // qq taps  float taps\_qq[DFE\_FL\_RX\_EQR\_LEN];  } DFE\_RxEqrTaps; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| rxDev | [in] Rx Id, 0 ~ 3 |
| shift | [in] shift value, 0 ~ 3 |
| numCoeff | [in] number of coefficients |
| RxEqrTaps | [in] pointer to the Rx Eqr taps |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateRxEqr () should be called later to copy EQ taps to working memory. |

## Issue Sync Update RX Equalizer

Issue sync update RX equalizer to new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateRxEqr  (  DFE\_Handle hDfe,  Uint32 rxDev,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to copy Rx equalizer from shadow to working memory. Dfe\_getSyncStatus() should be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| rxDev | [in] Rx Id, 0 ~ 3 |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Only the FB block which matches with IO mux config will be updated. |

## Program RX Mixer NCO

Program RX Mixer NCO frequency.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progDducMixerNCO  (  DFE\_Handle hDfe,  Uint32 rxDev,  float refClock,  float freq  ); |

**Description**

|  |
| --- |
| Write new RX Mixer NCO to shadow memory. The precision of the frequency is refClock/2^48. NCO bypass needs to be disabled.  **NOTE,** Dfe\_issueSyncUpdateRxMixerNCO () should be called later to let hardware copy gains from shadow to working memory. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| rxDev | [in] Rx Id, 0 ~ 3 |
| refClock | [in] reference sample rate |
| freq | [in] frequency value |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateRxMixerNCO () should be called later to copy gains to working memory. |

## Issue Sync Update RX Mixer NCO Frequency

Issue sync update RX Mixer NCO frequency to new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateRxMixerNCO  (  DFE\_Handle hDfe,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to copy RX Mixer NCO frequency from shadow to working memory. Dfe\_getSyncStatus() should be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program Rx Testbus

Program RX Testbus.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateRxTestbus  (  DFE\_Handle hDfe,  Uint32 top\_ctrl,  Uint32 imb\_ctrl,  Uint32 feagc\_dc\_ctrl  ); |

**Description**

|  |
| --- |
| Program RX Test bus. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| top\_ctrl | [in] top testbus control. |
| imb\_ctrl | [in] imb testbus control. |
| feagc\_dc\_ctrl | [in] feagc\_dc testbus control. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program FB Equalizer

Program FB Equalizer.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progFbEqr  (  DFE\_Handle hDfe,  DfeFl\_FbBlk FbBlkId,  Uint32 numCoeff,  DFE\_FbEqrTaps \*FbEqrTaps  ); |

**Description**

|  |
| --- |
| Write new FB Equalizer to shadow memory. The range of each tap is -1 ~ 0.9998.  **NOTE,** Dfe\_issueSyncUpdateFbEqr should be called later to let hardware copy gains from shadow to working memory.  typedef struct  {  // ii taps  float taps\_ii[DFE\_FL\_FB\_EQR\_LEN];  // iq taps  float taps\_iq[DFE\_FL\_FB\_EQR\_LEN];  // qi taps  float taps\_qi[DFE\_FL\_FB\_EQR\_LEN];  // qq taps  float taps\_qq[DFE\_FL\_FB\_EQR\_LEN];  } DFE\_FbEqrTaps; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| FbBlkId | [in] Fb block Id, 0 ~ 4 |
| numCoeff | [in] number of coefficients |
| FbEqrTaps | [in] pointer to the Fb Eqr taps. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateFbEqr () should be called later to copy EQ taps to working memory. |

## Issue Sync Update FB Equalizer

Issue sync update FB equalizer to new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateFbEqr  (  DFE\_Handle hDfe,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to copy Fb equalizer from shadow to working memory. Dfe\_getSyncStatus() should be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Only the FB block which matches with IO mux config will be updated. |

## Program FB Mixer NCO

Program FB Mixer NCO.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progFbMixerNCO  (  DFE\_Handle hDfe,  DfeFl\_FbBlk FbBlkId,  float refClock,  float freq  ); |

**Description**

|  |
| --- |
| Write new FB Mixer NCO frequency to shadow memory. The precision is refClock/2^48.  **NOTE,** Dfe\_issueSyncUpdateFbMixerNCO should be called later to let hardware copy gains from shadow to working memory. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| FbBlkId | [in] Fb block Id, 0~4 |
| refClock | [in] Fb reference clock |
| freq | [in] frequence value in degree |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateFbMixerNCO () should be called later to copy NCO to working memory. |

## Issue Sync Update FB Mixer NCO

Issue sync update FB equalizer to new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateFbMixerNCO  (  DFE\_Handle hDfe,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to copy Fb mixer NCO from shadow to working memory. Dfe\_getSyncStatus() should be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Only the FB block which matches with IO mux config will be updated. |

## Program FB IO Mux

Program FB IO Mux.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progFbIOMux  (  DFE\_Handle hDfe,  DfeFl\_FbIoMux ioMux  ); |

**Description**

|  |
| --- |
| Write new FB IO mux.  **NOTE,** Additional sync needs to be issued to set new values for EQ, gain or NCO in the new Fb channel. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| ioMux | [in] io mux mapping. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program FB pre-CB Gain

Program FB pre-CB gain.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progFbGain  (  DFE\_Handle hDfe,  DfeFl\_FbBlk FbBlkId,  float FbGain[2]  ); |

**Description**

|  |
| --- |
| Write new FB pre-CB gain to shadow memory. The range of gain is -Inf ~ 6.02dB. To check the gain changing through capture buffer, the cb\_output\_select need to be enabled.  **NOTE,** Dfe\_issueSyncUpdateFbGain should be called later to let hardware copy gains from shadow to working memory. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| FbBlkId | [in] Fb block Id, 0 ~ 4 |
| FbGain | [in] Array of Fb gain, [0] is real part and [1] is image part. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_issueSyncUpdateFbGain () should be called later to copy gains to working memory. |

## Issue Sync Update Fb pre-CB Gain

Issue sync update FB gain to new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateFbGain  (  DFE\_Handle hDfe,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to copy Fb gains from shadow to working memory. Dfe\_getSyncStatus() should be called later to check if the sync has come. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Only the FB block which matches with IO mux config will be updated. |

## Program CB Node Config

Program CB node configuration.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progCbNodecfg  (  DFE\_Handle hDfe,  DfeFl\_CbNodeCfg \*nodeCfg  ); |

**Description**

|  |
| --- |
| Write new CB node configuration for one CB node.  **NOTE,** CB node ID defined as nodeCfg->cbNode is 0 ~ 8.  Node 0 = DPD input  Node 1 = DPD output  Node 2 = DDUC input (FB output, IQ interleaved)  Node 3 = FB, resampler input or output (FB input, IQ parallel)  Node 4 = CFR block0 input  Node 5 = CFR block1 input  Node 6 = CFR block0 output  Node 7 = CFR block1 output  Node 8 = testbus |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| nodeCfg | [in] CB node configuration |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program CB Buf Config

Program CB buf configuration.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progCbBufcfg  (  DFE\_Handle hDfe,  DFE\_CbBufCfg \*bufCfg  ); |

**Description**

|  |
| --- |
| Write new CB buf configuration for one CB buffer.  **NOTE,** CB buf ID defined as bufCfg->cbSet.cbBuf is 0 ~ 3.  // CB buf configuration  typedef struct  {  // cb buf mode set  DfeFl\_CbModeSet cbSet;  // cb buf delay from sync  Uint32 dly;  // 0 = 1s/1c mode; 1 = 2s/1c mode  Uint32 rate\_mode;  // capture buffer A fractional counter length minus 1; range 0-15; value depends on the relative sampling rates for different buffers  Uint32 frac\_cnt;  // fractional counter sync select  Uint32 frac\_cnt\_ssel;  // length counter sync select  Uint32 len\_cnt\_ssel;  // cb buf length, upto 8192 complex data  Uint32 length;  } DFE\_CbBufCfg; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| bufCfg | [in] CB buffer configuration |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Arm CB and Issue Sync

Arm CB and issue sync

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_armCbIssueSync  (  DFE\_Handle hDfe,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Arm CB and issue sync to prepare for capture. The cb buf mode is also changed to capture mode. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| ssel | [in] sync select to capture |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get CB Done Status

Get the capture buffer done status

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getCbDoneStatus  (  DFE\_Handle hDfe,  DfeFl\_CbArm \*cbDoneStatus  ); |

**Description**

|  |
| --- |
| The API gets back the cbDone Status. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cbDoneStatus | [out] pointer to cb done status |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Read CB Buf

Read CB buf data via CPU.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_readCbBuf  (  DFE\_Handle hDfe,  DfeFl\_CbBuf cbBufId,  Uint32 cbLength,  Uint32 flag\_18bit,  DfeFl\_CbComplexInt \*cbTemp,  DfeFl\_CbStatus \*cbStatus,  DFE\_CbData \*cbData  ); |

**Description**

|  |
| --- |
| Read CB buf data and CB status via CPU. It reads DFE registers directly.  The API changes to MPU mode and capture the 16MSB or total 18bit buffer based on requirement.  // CB data  typedef struct  {  // I data  Uint32 \*Idata;  // Q data  Uint32 \*Qdata;  } DFE\_CbData; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cBufId | [in] Cb Buffer Id, 0 ~ 3 |
| cbLength | [in] Cb length, 0 ~ 8192 |
| flag\_18bit | [in] flag to read 18bit buffer  0 = 16bit MSB  1 = 18bit |
| cbTemp | [in] pointer to the temporary buffer, size 8192\*4 bytes |
| cbStatus | [out] pointer to the cb status |
| cbData | [out] pointer to the cb data |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete programmed properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Open CB Buf DMA

Open CPP/DMA for reading CB buffer.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_openCbBufDma  (  DFE\_Handle hDfe,  Uint32 flag\_18bit,  Uint32 cppDmaId,  Uint32 cppDescripId[8],  Uint32 iqnChnl  ); |

**Description**

|  |
| --- |
| Allocate CPP/DMA channel and descriptor for CB buf reading.  Every CB buf has 8192 words for 16bit MSB and 8192 words for 2bit LSB.  Each word has I data in bit [31:16] and Q data in bit [15:0].  To transfer all 4 CB buffers, there are total 8 descriptors if all 18bit data are needed. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| flag\_18bit | [in] flag to read 18bit buffer  0 = 16bit MSB  1 = 18bit |
| cppDmaId | [in] CPP/DMA channel Id  0 ~ 31, open with specified channel  DFE\_FL\_CPP\_OPEN\_ANY, open with any available channel |
| cppDescripId | [in] pointer to CPP/DMA descriptor Id  0 ~ 127, open with specified descriptor  DFE\_FL\_CPP\_OPEN\_ANY, open with any available descriptor |
| iqnChnl | [in] IQN2 CTL Ingress channel number, 0 ~ 15 |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete programmed properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_AVAILABLE, if CPP/DMA channel not available  DFE\_ERR\_CPP\_DESCRIP\_NOT\_AVAILABLE, if CPP/Descriptor not available  DFE\_ERR\_ALREADY\_OPENED, if BBTX power meter DMA already opened |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Close CB Buf DMA

Close CB buf DMA and free recourses.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_closeCbBufDma  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| Close Cb Buf DMA and free resources allocated by Dfe\_openCbBufDma(). |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_VALID, if CPP/DMA handle not valid |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_openCbBufDma() has called OK. |

## Enable CB Buf DMA

Enable CB Buf DMA.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_enableCbBufDma  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| Enable CPP/DMA for CB Buf by setting dma\_ssel to sense MPU sync.  MPU sync will trigger CPP/DMA to start transferring. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_VALID, if CPP/DMA handle not valid  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_openCbBufDma() has called OK. |

## Disable CB Buf DMA

Disable CB Buf DMA.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_disableCbBufDma  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| Disable CB buf DMA by changing dma\_ssel not to sense any signal |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_VALID, if CPP/DMA handle not valid  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_openCbBufDma() has called OK. |

## Disable All TestBus

Disable all test bus probes.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_disableAllTestbus  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| DFE has many test probe points scattered over all sub-modules. CB can be used to capture a train of IQ bus signals at the probe.  All test probes “AND together” shares single CB interface. So software should enable no more than one probe at any time.  The API clears all test probes which was programmed before. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program DFE GPIO PinMux

Select pin function by programming DFE GPIO pinmux.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_progGpioPinMux  (  DFE\_Handle hDfe,  DfeFl\_MiscGpioPin pinId,  DfeFl\_MiscGpioMux muxSel  ); |

**Description**

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Select pin function by programming DFE GPIO pinmux. There’re total 18 GPIOs, every pin can be configured to be different function.   |  |  |  |  | | --- | --- | --- | --- | | **Pin Function** | **Value** | **Input/Output** | **Description** | | NOTHING | 0 | Input | Input only, not configured to a function | | GPIO\_SYNC\_IN0 | 1 | Input | General sync input 0 | | GPIO\_SYNC\_IN1 | 2 | Input | General sync input 1 | | JESD\_SYNC\_IN0 | 3 | Input | JESD sync inputs for interfacing to data converters which do not support LVDS syncs | | JESD\_SYNC\_IN1 | 4 | Input | | GPIO\_SYNC\_OUT0 | 8 | Output | General sync output 0 | | GPIO\_SYNC\_OUT1 | 9 | Output | General sync output 0 | | JESD\_SYNC\_OUT0 | 10 | Output | JESD sync outputs for interfacing to data converters which do not support LVDS syncs | | JESD\_SYNC\_OUT1 | 11 | Output | | FB\_MUX\_CNTL0 | 12 | Output | feedback mux control for Marconi 0 | | FB\_MUX\_CNTL1 | 13 | Output | | FB\_MUX\_CNTL2 | 14 | Output | | FB\_MUX\_CNTL3 | 15 | Output | feedback mux control for Marconi 1 | | FB\_MUX\_CNTL4 | 16 | Output | | FB\_MUX\_CNTL5 | 17 | Output | | DVGA\_CNTL0 | 18 | Output | 8 bits DVGA controls | | DVGA\_CNTL1 | 19 | Output | | DVGA\_CNTL2 | 20 | Output | | DVGA\_CNTL3 | 21 | Output | | DVGA\_CNTL4 | 22 | Output | | DVGA\_CNTL5 | 23 | Output | | DVGA\_CNTL6 | 24 | Output | | DVGA\_CNTL7 | 25 | Output | | SYSREF\_REQUEST | 26 | Output | JESD SYSREF request output | | MPU\_DRIVE | 27 | Output | Driven by MPU register write |   **Note:** ALL pins (including those set to "nothing") also function as mpu gpio read. If the pin is an output pin, the mpu gpio read will return whatever is being output. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| pinId | [in] GPIO pin ID |
| muxSel | [in] select function of the pin |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Set DFE GPIO Sync Out Source

Select sync source for GPIO Sync out pin.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_setGpioSyncOutSource  (  DFE\_Handle hDfe,  Uint32 syncoutId,  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Select sync source for GPIO\_SYNC\_OUT pin. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| syncoutId | [in] sync out pin, 0/1 |
| ssel | [in] sync select |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Set DFE GPIO Bank Output

Write GPIO pins in bank mode.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_setGpioBankOutput  (  DFE\_Handle hDfe,  Uint32 bankOutput  ); |

**Description**

|  |
| --- |
| Write MPU GPIO Drive register to drive pin output. For pins configured as MPU\_DRIVE, DFE drives those pins per bankOutput value. For other pins, it does no effective.  There’re total 18 GPIOs, one-to-one mapped to 18 LSBs of bankOutput. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| bankOutput | [in] pin output bitmap value, bit0 driving pin0, bit1 driving pin1, …, bit17 driving pin17.   * 0 = drive low * 1 = drive high |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get DFE GPIO Bank Input

Read GPIO pins in bank mode.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getGpioBankInput  (  DFE\_Handle hDfe,  Uint32 \*bankInput  ); |

**Description**

|  |
| --- |
| Read current input status of GPIO pins.  There’re total 18 GPIOs, one-to-one mapped to 18 LSBs of \*bankInput. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| bankInput | [out] pin input bitmap value, bit0 is for pin0, bit1 is for pin1, …, bit17 is for pin17.   * 0 = input low * 1 = input high |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_QUERY, if CSL GetHwStatus() failed  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Open Generic IO DMA

Open CPP/DMA for Generic IO.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_openGenericDma  (  DFE\_Handle hDfe,  Uint32 cppDmaId,  Uint32 iqnChnlDl,  Uint32 iqnChnlUl  ); |

**Description**

|  |
| --- |
| Open and allocate resources for generic IO DMA, which can be used to read/write DFE registers and memories.  Generic IO DMA is using CPP/DMA embedded address mode. The DMA descriptor is embedded at the beginning of the packet.  Generic IO DMA doesn’t support linked transfers. Each DMA packet can transfer data size from one 32-bits word to 16K 32-bits words.  Upon the API returns DFE\_ERR\_NONE, generic IO DMA has already been enabled and ready for use. Data available on iqnChnlDl starts CPP/DMA.  When generic IO DMA already opened, call this API again will get error DFE\_ERR\_ALREADY\_OPENED. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cppDmaId | [in] CPP/DMA channel Id  0 ~ 31, open with specified channel  DFE\_FL\_CPP\_OPEN\_ANY, open with any available channel |
| iqnChnlDl | [in] IQN2 CTL Egress channel number, 0 ~ 15 |
| iqnChnlUl | [in] IQN2 CTL Ingress channel number, 0 ~ 15 |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_AVAILABLE, if CPP/DMA channel not available  DFE\_ERR\_ALREADY\_OPENED, if generic IO DMA already opened  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Close Generic IO DMA

Close Cpp/DMA for Generic IO

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_closeGenericDma  (  DFE\_Handle hDfe  ); |

**Description**

|  |
| --- |
| Close generic IO DMA and free resources allocated by Dfe\_openGenericDma(). |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_VALID, if CPP/DMA handle not valid |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. 4. Dfe\_openGenericDma() has called OK. |

## Prepare Generic DMA Embedded Header

Prepare CPP/DMA embedded header for generic IO request.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_prepareGenericDmaHeader  (  DFE\_Handle hDfe,  Uint32 \*header  DFE\_GenericDmaReadWriteMode rwMode,  Uint32 offsetAddrInDref,  Uint32 sizeOrData  ); |

**Description**

|  |
| --- |
| The API helps building CPP/DMA embedded header that will be sent together with data payload block. The size of the header is fixed 16 bytes, then followed data payload block.  The API supports three read/write modes,   * DFE\_GENERIC\_DMA\_RW\_MODE\_WRITE\_SINGLE\_WORD, write single 32-bits word to DFE. The sizeOrData has the sending value that will be built into the embedded header. There’s no other payload to be sent. * DFE\_GENERIC\_DMA\_RW\_MODE\_WRITE\_MULTI\_WORDS, write multiple 32-bits words to DFE. The sizeOrData has the number of words of data payload, which is immediately following the header. If number of the payload words not multiples of 4, zero shall be padded to fill the remaining words in the final line. * DFE\_GENERIC\_DMA\_RW\_MODE\_READ, read from DFE. The sizeOrData has the number of words of read data, which will be received from IQN2 CTL ingress channel, iqnChnlUl, specified when Dfe\_openGenericDma().   For writing, offsetAddrInDref is the destination 26-bit address within DFE scope; for reading, it is the source 26-bit address within DFE scope. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| header | [out] pointer to packet header |
| rwMode | [in] generic IO read/write mode |
| offsetAddrInDref | [in] 26-bit address within DFE scope. |
| sizeOrData | [in] size or data. For single word writing, it is the data value; for other modes, it is number of payload words in 32-bits. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_CPP\_DMA\_NOT\_VALID, if CPP/DMA handle not valid |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Enable Lut toggle

Enable Lut toggle for one dpd block.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_enableToggle  (  DFE\_Handle hDfe,  Uint32 blkId  ); |

**Description**

|  |
| --- |
| Enable the Lut toggle for one dpd block |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| blkId | [in] block Id [0:3] |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## SetSyncSel for Lut

Set sync selection for one dpd block.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_setSyncSel  (  DFE\_Handle hDfe,  Uint32 blkId,  Uint32 synch  ); |

**Description**

|  |
| --- |
| Set synch selection for one dpd block |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| blkId | [in] block Id [0:3] |
| Synch | [in] Synch:  0: f\_synch  1: c\_synch  2: f\_synch || c\_synch  3: the 'combined sync' generated internally based on 'sync\_b' and sync from 'poly2LUT' |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Issue Sync Update Lut

Issue sync update Lut to new values.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_issueSyncUpdateLut  (  DFE\_Handle hDfe,  Uint32 numBlks,  Uint32 blkId[],  DfeFl\_MiscSyncGenSig ssel  ); |

**Description**

|  |
| --- |
| Issue sync to switch Lut table for one block. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| numBlks | [in] number of blocks which will be updated, [1:4] |
| blkId[] | [in] array of block Ids which will be updated, [0:3] |
| ssel | [in] sync select to copy gains from shadow to working memory. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_HW\_CTRL, if CSL HwControl() failed |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get Current Lut memory index

Get current Lut memory index for one dpd block.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_setSyncSel  (  DFE\_Handle hDfe,  Uint32 blkId,  Uint32 \*LutIdx  ); |

**Description**

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| Get the current Lut memory index for one dpd block. There are total 6 rows in one dpd block. There are total 3 cells in one row. Each cell will return the Lut memory index. 0 means the datapath is using LUT0 (bottom half of memory), 1 means the datapath is using LUT1 (top half of memory).  The LutIdx will store the results in bit masking format.   |  |  |  |  |  |  |  |  |  |  |  |  | | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | | MSB |  |  | B23 | B22 | B21 | B20 | … | B3 | B2 | B1 | B0 | |  |  |  | Not used | Row5, cell2 | Row5, cell1 | Row5, cell0 | … | Not used | Row0, cell2 | Row0, cell1 | Row0, cell0 | |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| blkId | [in] block Id [0:3] |
| LutIdx | [out] current Lut memory index |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Program Lut table

Program Lut table for one dpd cell.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_setSyncSel  (  DFE\_Handle hDfe,  Uint32 blkId,  Uint32 rowId,  Uint32 cellId,  DFE\_DpdData \*DpdData  ); |

**Description**

|  |
| --- |
| Program Lut table for one cell. The dpd lut will be used in dpd datapath after issue sync to update lut.  **typedef** **struct** \_DFE\_DpdData  {  // lutGain  DfeFl\_DpdComplexInt lutGain;  // lutSlope  DfeFl\_DpdComplexInt lutSlope;  } DFE\_DpdData; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| blkId | [in] block Id [0:3] |
| rowId | [in] row Id [0:5] |
| cellId | [in] cell Id [0:2] |
| DpdData | [in] pointer to the dpd data |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Get Dpd configuration

Read back dpd configuration.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_getDpdCfg  (  DFE\_Handle hDfe,  DFE\_DpdCfg \*dpdCfg  ); |

**Description**

|  |
| --- |
| Read back the dpd configuration  **typedef** **struct** \_DFE\_DpdCfg  {  // subchip mode  uint32\_t subchip\_mode;  // subsample  uint32\_t subsample;  // dpd input scale  uint32\_t dpdInputScale;  // x2 sqrt  uint32\_t x2\_sqrt;  } DFE\_DpdCfg; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| dpdCfg | [out] pointer to the dpd configure |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL |

**Constrains**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). 2. DFE PLL and PSCs shall be already up running. 3. DFE has loaded target config and completed initialize sequence. |

## Load DPDA image

Load image to DPDA instruction RAM and lookup tables. Reset and initialize DPDA.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_loadDpda  (  DFE\_Handle hDfe,  Uint32 imageSize,  DFE\_RegPair \*imagePtr  ) |

**Description**

|  |
| --- |
| The API   * disables the arbiter * resets DPDA * forces DPDA into the IDLE state * clears interrupt mask and status registers * clears command, test and debug registers * clears the scalar and IG register files * clears the stack * loads the given image * releases DPDA from reset   // (addr, data) register pair  typedef struct  {  // offset address from DFE base address  Uint32 addr;  // data to/from addr  Uint32 data;  } DFE\_RegPair; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| igId | [in] Identifies IG register, 0 ~ 63 |
| igPtr | [out] Points to value |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete programmed properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constraints**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). |

## Read DPDA IG register

Read value from DPDA IG register file.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_writeDpdaIg  (  DFE\_Handle hDfe,  Uint8 igId,  Uint32 \*igPtr  ) |

**Description**

|  |
| --- |
| The API reads a value from the given IG register. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| igId | [in] Identifies IG register, 0 ~ 63 |
| igPtr | [out] Points to value |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete programmed properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constraints**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). |

## Read DPDA parameters

Read complex parameters from DPDA solution RAM.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_readDpdaParams  (  DFE\_Handle hDfe,  Uint16 lineId,  Uint16 lineNum,  float \*paramTbl  ) |

**Description**

|  |
| --- |
| The API reads all parameters stored in the given lines from the solution RAM. Note that each line stores 24 complex parameters. It also converts the I and Q parts of each parameter from the custom floating point format used by the DPDA and re-orders the parameters as follows:  for (i = 0; i < lineNum; i++) {  for (j = 0; j < 8; j++) {  for (k = 0; k < 3; k++) {  paramTbl[24\*2\*i+8\*2\*k+2\*j] = tmpTbl[24\*2\*i+3\*2\*j+k\*2];  paramTbl[24\*2\*i+8\*2\*k+2\*j+1] = tmpTbl[24\*2\*i+3\*2\*j+k\*2+1];  }  }  } |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| lineId | [in] Identifies first line, 0 ~ 767 |
| lineNum | [in] Specifies number of lines, 0 ~ 767 |
| paramTbl | [out] Points to table of parameters. Even locations store the I parts of the corresponding parameters and odd locations the Q parts. |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete programmed properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constraints**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). |

## Read DPDA scalar register

Read complex value from DPDA scalar register file.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_writeDpdaScalar  (  DFE\_Handle hDfe,  Uint8 scalarId,  float \*iScalarPtr,  float \*qScalarPtr  ) |

**Description**

|  |
| --- |
| The API reads a complex value from the given scalar register and it converts the I and Q parts of the complex value from the custom floating point format used by DPDA. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| scalarId | [in] Identifies scalar register, 0 ~ 63 |
| iScalarPtr | [in] Points to I part of scalar value |
| qScalarPtr | [in] Points to Q part of scalar value |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete programmed properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constraints**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). |

## Start DPDA

Start DPDA.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_startDpda  (  DFE\_Handle hDfe,  Uint16 startAddress  ) |

**Description**

|  |
| --- |
| The API   * clears interrupt flag in the command register * clears idle status, read status and processed status * writes the given start address to the command register * sets the interrupt flag in the command register * polls the idle status until the DPDA returns to the idle state |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| Uint16 | [in] Specifies start address in the instruction RAM, 0 ~ 4095 |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete programmed properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constraints**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). |

## Write DPDA IG register

Write value to DPDA IG register file.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_writeDpdaIg  (  DFE\_Handle hDfe,  Uint8 igId,  Uint32 ig  ) |

**Description**

|  |
| --- |
| The API writes the given value to the given IG register. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| igId | [in] Identifies IG register, 0 ~ 63 |
| ig | [in] Value |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete programmed properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constraints**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). |

## Write DPDA samples

Write samples to capture buffer. DPDA will read them from capture buffer.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_writeDpdaSamples  (  DFE\_Handle hDfe,  DfeFl\_CbBuf cbBufId,  Uint8 fbFlag,  Uint16 cbLength,  DfeFl\_CbComplexInt \*cbTemp,  DFE\_CbData \*cbData  ) |

**Description**

|  |
| --- |
| For the given CB buffer, the API writes each given sample to the 16MSB of the corresponding 18-bit CB sample and clears the 2 LSB. It sets the buffer in fine mode and tags it as storing reference or feedback samples. It also makes sure that the buffer won't skip chunks.  // CB complex sample  typedef struct  {  // real value  Uint16 real;  // image value  Uint16 imag;  } DfeFl\_CbComplexInt;  // CB data  typedef struct  {  // I data  Uint32 \*Idata;  // Q data  Uint32 \*Qdata;  } DFE\_CbData; |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| cBufId | [in] Identifies CB buffer, 0 ~ 3 |
| fbFlag | [in] Indicates whether buffer is used for capturing feedback signal  0 = no feedback signal  1 = feedback signal |
| cbLength | [in] Specifies number of samples, 0 ~ 8192 |
| cbTemp | [in] Points to the temporary buffer, size 8192\*4 bytes |
| cbData | [in] Points to the cb data |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete programmed properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constraints**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). |

## Write DPDA scalar register

Write complex value to DPDA scalar register file.

**Prototype**

|  |
| --- |
| DFE\_Err Dfe\_writeDpdaScalar  (  DFE\_Handle hDfe,  Uint8 scalarId,  float iScalar,  float qScalar  ) |

**Description**

|  |
| --- |
| The API converts the I and Q parts of the given complex value to the custom floating point format used by DPDA and writes them to the given scalar register. |

**Arguments**

|  |  |
| --- | --- |
| hDfe | [in] DFE device handle |
| scalarId | [in] Identifies scalar register, 0 ~ 63 |
| iScalar | [in] I part of scalar value |
| qScalar | [in] Q part of scalar value |

**Return Value**

|  |
| --- |
| DFE\_ERR\_NONE, if API complete programmed properly  DFE\_ERR\_INVALID\_HANDLE, if hDfe is NULL  DFE\_ERR\_INVALID\_PARAMS, if invalid parameters |

**Constraints**

|  |
| --- |
| 1. hDfe should be a valid handle opened by Dfe\_open(). |

# Integration

## OSAL

The OSAL is the operating system abstraction layer which is used to port DFE LLD to a specific OS. The OSAL callouts are implemented in the “dfe\_osal.h” header file and need to be ported by the application developers to their specific operating system.

### Logging API

Internally DFE LLD uses the Dfe\_osalLog macro to perform all logging operations. The

OSAL adaptation layer ports this macro to the following API prototype:-

|  |
| --- |
| void Osal\_dfeLog( char\* fmt, ... ) |

The parameter ‘fmt’ is a printf style formatted string. This should only be defined and used for debugging purposes.

## Integration on ARM Linux

DFE LLD works on the top of DFE\_FL Function Level (FL) library. Both libraries are running from Linux user space. DFE\_FL FL API dfeFl\_GetBaseAddress() should be customized to use mmap() in un-cached mode to open the whole 48M-bytes window of DFE.

To move big chunks of data into/out of DFE memories, such as capture buffers and BBTX/RX power meter results, the application should use DFE LLD together with UDMA/IQN2 user mode driver.

## Integration on DSP SysBios

Both DFE LLD and CSL library are packaged in PDK. There’s no customization needed for CSL.

To move big chunks of data into/out of DFE memories, such as capture buffers and BBTX/RX power meter results, the application should use DFE LLD together with QMSS/CPPI/IQN2 LLDs.

# Future Extensions

* Support of programming DPD LUTs
* Support of programming Poly2Lut
* Support of programming TX filter coefficeints
* Support of programming BeAGC
* Support of programming FeAGC