# Three-Output PTIC Control IC

### **Introduction**

TCC−303 is a three−output high−voltage digital to analog control IC specifically designed to control and bias ON Semiconductor's Passive Tunable Integrated Circuits (PTICs).

These tunable capacitor control circuits are intended for use in mobile phones and dedicated RF tuning applications. The implementation of ON Semiconductor's tunable circuits in mobile phones enables significant improvement in terms of antenna radiated performance.

The tunable capacitors are controlled through a bias voltage ranging from 1 V to 24 V. The TCC−303 high−voltage PTIC control IC has been specifically designed to cover this need, providing three independent high−voltage outputs that control up to three different tunable PTICs in parallel. The device is fully controlled through a MIPI RFFE digital interface.

### **Key Features**

- Controls ON Semiconductor's PTIC Tunable Capacitors
- Compliant with Timing Needs of Cellular and Other Wireless System Requirements
- 28 V Integrated Boost Converter with Three 24 V Programmable DAC Outputs
- Low Power Consumption
- MIPI RFFE Interfaces (1.8 V)
- Available in WLCSP (RDL ball arrays)
- Compliant with MIPI 26 MHz Read−Back
- This is a Pb−Free Device

### **Typical Applications**

- Multi−band, Multi−standard, Advanced and Simple Mobile Phones
- Tunable Antenna Matching Networks
- Compatible with Closed−loop and Open−loop Antenna Tuner Applications



### **ON Semiconductor®**

**[www.onsemi.com](http://www.onsemi.com/)**



**WLCSP12 CASE 567MW**





T33x= Specific Device Code

- $x = A$  or B
- A = Assembly Location
- $L = Water$  Lot
- $Y = Year$
- W = Work Week -
	- = Pb−Free Package

(Note: Microdot may be in either location)

### **ORDERING INFORMATION**

See detailed ordering and shipping information on page [31](#page-30-0) of this data sheet.

<span id="page-1-0"></span>

**Figure 1. Control IC Functional Block Diagram**



**Figure 2. RDL Padout, Bump Side View (left), PCB footprint (right), with RDL Bump Assignment**

### **RDL Pin Out**

### **Table 1. PAD DESCRIPTIONS**



**Legend: Pad Types** AIH= High Voltage Analog Input AO= Analog Output AOH= High Voltage Analog Output DI= Digital Input DIO= Digital Input/Output (IO) P= Power

1. To be grounded in normal operation.

### **ELECTRICAL PERFORMANCE SPECIFICATIONS**

### **Table 2. ABSOLUTE MAXIMUM RATINGS**



Stresses exceeding those listed in the Maximum Ratings table may damage the device. If any of these limits are exceeded, device functionality should not be assumed, damage may occur and reliability may be affected.

### <span id="page-3-0"></span>**Table 3. RECOMENDED OPERATING CONDITIONS**



Functional operation above the stresses listed in the Recommended Operating Ranges is not implied. Extended exposure to stresses beyond the Recommended Operating Ranges limits may affect device reliability.

# **Table 4. DC CHARACTERISTICS** (T<sub>A</sub> = –30 to +85°C; V<sub>OUTX</sub> = 15 V for each output; 2.3 V<VDDA< 5.5 V; V<sub>IO</sub> = 1.8 V; R<sub>LOAD</sub> =<br>equivalent series load of 5.6 kΩ and 2.7 nF; C<sub>HV</sub> = 22 nF; L<sub>BOOST</sub> = 15 μH; unless otherwi







Product parametric performance is indicated in the Electrical Characteristics for the listed test conditions, unless otherwise noted. Product performance may not be indicated by the Electrical Characteristics if operated under different conditions.

### **Table 5. BOOST CONVERTER CHARACTERISTICS**

(VDDA from 2.3 V to 5.5 V; V<sub>IO</sub> = 1.8 V; T<sub>A</sub> = -30 to +85°C; C<sub>HV</sub> = 22 nF; L<sub>BOOST</sub> = 15 µH; unless otherwise specified)



### **Table 6. ANALOG OUTPUTS (OUT A, OUT B, OUT C)**

(VDDA from 2.3 V to 5.5 V; V<sub>IO</sub> = 1.8 V; V<sub>HV</sub> = 26 V; T<sub>A</sub> = –30 to +85°C; R<sub>load</sub> = ∞ unless otherwise specified)



### **THEORY OF OPERATION**

### **Overview**

The control IC outputs are directly controlled by programming the three DACs (DAC A, DAC B, DAC C) through the digital interface.

The DAC stages are driven from a reference voltage, generating an analog output voltage driving a high−voltage amplifier supplied from the boost converter (see Figure [1](#page-1-0) − Control IC Functional Block Diagram).

The control IC output voltages are scaled from 0 V to 24 V, with 128 steps of 189 mV. The nominal control IC output can be approximated to 189 mV x (DAC value).

For performance optimization the boost output voltage (VHV) can be programmed to levels between 13 V and 28 V via the DAC boost register  $(4 \text{ bits with } 1 \text{ V steps})$ . The startup default level for the boosted voltage is VHV = 24 V.

For proper operation and to avoid saturation of the output devices and noise issues, it is recommended to operate the boosted VHV voltage at least 2 V (4 V if using Turbo− Charge Mode) above the highest programmed  $V_{\text{OUT}}$  voltage of any of the three outputs.

### **Operating Modes**

The following operating modes are available:

1. **Shutdown Mode:** All circuit blocks are off, the DAC outputs are disabled and placed in high Z state and current consumption is limited to minimal leakage current. The shutdown mode is entered upon initial application of VDDA or upon VIO being placed in the low state. The contents of the registers are not maintained in shutdown mode.

- 2. **Startup Mode:** Startup is only a transitory mode. Startup mode is entered upon a VIO high state. In startup mode all registers are reset to their default states, the digital interface is functional, the boost converter is activated, outputs OUT A, OUT B, OUT C are disabled and the DAC outputs are placed in a high Z state. Control software can request a full hardware and register reset of the TCC−303 by sending an appropriate PWR\_MODE command to direct the chip from either the active mode or the low power mode to the startup mode. From the startup mode the device automatically proceeds to the active mode.
- 3. **Active Mode:** All blocks of the TCC−303 are activated and the DAC outputs are fully controlled through the digital interface, DACs remain off until enabled. The DAC settings can be dynamically modified and the HV outputs will be adjusted according to the specified timing diagrams. Each DAC can be individually controlled and/or switched off according to application requirements. Active mode is automatically entered from the startup mode. Active mode can also be entered from the low power mode under control software command.
- 4. **Low Power Mode:** In low power mode the serial interface stays enabled, the DAC outputs are disabled and are placed in a high Z state and the boost voltage circuit is disabled. Control software can request to enter the low power mode from the active mode by sending an appropriate PWR\_MODE command. The contents of all registers are maintained in the low power mode.



**Figure 3. Modes of Operation**

### **VDDA Power−On Reset (POR)**

Upon application of VDDA, TCC−303 will be in shutdown mode. All circuit blocks are off and the chip draws only minimal leakage current.

### **VIO Power−On Reset and Startup Conditions**

A high level on VIO places the chip in startup mode which provides a POR to TCC−303. POR resets all registers to their default settings as described in Register Content Details. VIO POR also resets the serial interface circuitry. POR isnot a brown−out detector and VIO needs to be brought back to a low level to enable the POR to trigger again.



### **Table 7. VIO POWER−ON RESET AND STARTUP**

### **VIO Shutdown**

A low level at any time on VIO places the chip in shutdown mode in which all circuit blocks are off. The contents of the registers are not maintained in shutdown mode.





### **Power Supply Sequencing**

The VDDA input is typically directly supplied from the battery and thus is the first on. After VDDA is applied and before VIO is applied to the chip, all circuits are in the shutdown mode and draw minimum leakage currents. Upon application of VIO, the chip automatically starts up using default settings and is placed in the active state waiting for a command via the serial interface.







**Figure 4. Output Settling Diagram**



**Figure 5. Startup Timing Diagram**

#### **Boost Control**

TCC−303 integrates an asynchronous current control boost converter. It operates in a discontinuous mode and features spread−spectrum circuitry for Electro−Magnetic Interference (EMI) reduction. The average boost clock is 2 MHz and the clock is spread between 0.8 MHz and 4 MHz.

#### **Boost Output Voltage (VHV) Control Principle**

The asynchronous control starts the boost converter as soon as the VHV voltage drops below the reference set by the 4−bit DAC and stops the boost converter when the VHV voltage rises above the reference again.

Due to the slow response time of the control loop, the VHV voltage may drop below the set voltage before the control loop compensates for it. In the same manner, VHV can rise higher than the set value. This effect may reduce the maximum output voltage available. Please refer to Figure 6 below.

The asynchronous control reduces switching losses and improves the output (VHV) regulation of the DC/DC converter under light load, particularly in the situation where TCC–303 only maintains the output voltages to fixed values.





### **High Impedance (High Z) Feature**

In shutdown mode the OUT pins are set to a high impedance mode (high Z). Following is the principle of operation for the control IC:

1. The DAC output voltage  $V_{OUT}$  is defined by:

$$
V_{\text{OUT}} = \frac{\text{DAC code}}{127} \times 24 \text{ V} \tag{eq. 1}
$$

- 2. The voltage VHV defines the maximum supply voltage of the DAC supply output regulator and is set by a 4−bit control.
- 3. The maximum DAC DC output voltage  $V_{OUT}$  is limited to (VHV  $-$  2 V). DAC can achieve higher output voltages, but timing is not maintained for swings above VHV − 2 V.
- 4. The minimum output DAC voltage  $V_{OUT}$  is 1.0 V max.



**Figure 7. DAC Output Range Example A**



**Figure 8. DAC Output Range Example B**

#### **Digital Interface**

The control IC is fully controlled through a digital interface (DATA, CLK). The digital interface is described in the following sections of this document.

#### **Turbo−Charge Mode**

The TCC−303 control IC has a Turbo−Charge Mode that significantly shortens the system settling time when changing programming voltages.

In Turbo−Charge Mode the DAC output target voltage is temporarily set to either a delta voltage above or a delta voltage below the actual desired target. The delta voltage is 4 volts.

After the DAC value message is received, the delta voltage is calculated by hardware, and is applied in digital format to the input of the DAC, right after trigger is received. The period for which the delta voltage is maintained to the input of the DAC, the Turbo time, is calculated based on following considerations:

- DAC\_TIMER\_A[4:0] / DAC\_TIMER\_B[4:0] / DAC\_TIMER\_C[4:0]: These are the DAC timer configuration fields. For the turbo mode, they define the turbo latency value, when the target+delta voltage is active. If each DAC is updated over and over with the same turbo delay value, these fields do NOT need to be updated at each DAC update. The register has to hold a non−zero value for a Turbo update.
- DAC\_TC2X\_A / DAC\_TC2X\_B / DAC\_TC2X\_C: If these bits are set, the timer loads DAC\_TIMER  $X * 2$ value as opposed to DAC\_TIMER\_X value. This allows a turbo operation delay up to  $124 \mu s$ .
- DAC\_TCM\_A [1:0] / DAC\_TCM\_B [1:0] / DAC TCM  $C [1:0]$ : If the Turbo direction is down and the Turbo target is below 4 V, these multiplication factors are utilized to extend the turbo delay. Further formula provided below.
- GL  $A / GL$  B / GL C: These are the DAC update mode configuration fields, which need to be set to turbo mode at the new DAC value update and prior to the SW trigger (optional). These bits are part of the DAC value register. If they are set to 0, the DAC is in Turbo Mode, as long as the corresponding DAC\_TIMER register is non−zero. A DAC\_TIMER =0 means an immediate update independent of the GL\_A/B/C value.
- The Turbo UP or DOWN voltage is decided based on the comparison of the new DAC value and the old DAC value. If the new value is greater, the turbo direction will be UP. Otherwise it will be down. In case of both DAC values being equal, there is no DAC update applied.After a turbo request is received, any trigger will start the turbo output transition. The trigger could be:
	- ♦ A MIPI−RFFE software trigger controlled by RFFE\_PM\_TRIG register
	- ♦ An internal generated trigger after the corresponding DAC value is updated, as described in section **DAC Update Triggering.**

The DAC values send by digital turbo−charge logic to DACs are:

- During turbo−charge delay duration the value applied is "DAC new  $\pm$ 4 V" (the polarity of the 4 V turbo will depend on if turbo charge is up or down)
- If DAC new > DAC old, and DAC new+4 V is exceeding the word length of the DAC, it is saturated to max value possible.
- If DAC\_new < DAC\_old, and DAC\_new−4 V is a negative number, a DAC value of 0 is applied.
	- ♦ After turbo−charge delay duration the value applied is the actual DAC new.

<span id="page-10-0"></span>



The value of turbo delay time is deducted based on the hardware comparison of new DAC value in respect to old DAC value, as follows. In this calculation the decimal "21" value corresponds to 4 V DAC drive. As the DAC new value is closer to 0 V in a down Turbo, the delay time increases more.

If DAC new > DAC old, then  $T_{UP}$  = DAC\_TIMER\_A/B/C << DAC\_TC2X\_A/B/C

If DAC new < DAC old, and DAC new < 21, then  $T_{\text{DOWN}}$ = DAC\_TIMER\_A/B/C << DAC\_TC2X\_A/B/C +  $DAC_TCM_A/B/C$  \* (21 – DAC new)

If DAC new < DAC old, and DAC new  $> 21$ , then  $T_{\text{DOWN}}$ = DAC\_TIMER\_A/B/C << DAC\_TC2X\_A/B/C

If DAC new  $<$  DAC old, and DAC new = 21, then  $T_{\text{DOWN}}$ = DAC\_TIMER\_A/B/C << DAC\_TC2X\_A/B/C





### **Transition from Turbo to Turbo or Immediate Update**

In the event a new trigger is received during a turbo transition, the ongoing turbo operation is halted and the new DAC value is applied immediately. There won't be any Turbo and the hi\_slew is kept low.

#### **Transition from Turbo to Glide**

In the event that a new glide transition is triggered during a turbo event, then the turbo process is stopped and the current target value is set at the DAC output immediately without hi slew. The new glide is started from this value.

#### **DAC disable during Turbo (including active to low power mode transition)**

If the DAC, which is in Turbo is disabled, the target DAC value is immediately applied without hi\_slew. The DAC does not continue with the Turbo when it is re−enabled.

### **Glide Mode**

The TCC−303 control IC has a Glide Mode that significantly extends the system transition time when changing programming voltages.

Glide Mode is controlled by the following registers:

- DAC\_TIMER\_A[4:0] / DAC\_TIMER\_B[4:0] / DAC\_TIMER\_C[4:0]: These are the DAC timer configuration fields. For the glide mode they define the step duration. If each DAC is updated over and over with the same glide step, these fields do NOT need to be updated at each DAC update. The register has to hold a non−zero value for a Glide update.
- GL  $A / GL$  B / GL C: These are the DAC update mode configuration fields, which need to be set to glide mode at the new DAC value update and prior to the SW trigger (optional). These bits are part of the DAC value register. If they are set to 1, the DAC is in glide mode, as long as the corresponding DAC\_TIMER register is non−zero. A DAC\_TIMER =0 means an immediate update independent of the GL\_A/B/C value.

After a Glide request is received, any trigger will start the Glide output transition.

The trigger could be:

- a MIPI−RFFE software trigger controlled by RFFE\_PM\_TRIG register
- an internal generated trigger after the corresponding DAC value is updated, as described in a later section.

Immediately after the trigger, the DAC\_old value is loaded in the MSB's of the upper byte of a 15 bit accumulator, while the lower byte of accumulator is being reset to 0x00.

At the same time a count step is calculated:

GLIDE STEP[6:0] = DAC new  $-$  DAC old; if DAC\_new > DAC\_old

 $GLIDE$   $STEP[6:0] = DAC_0ld - DAC_new;$  if DAC\_new < DAC\_old

 $ACCUMULATOR[14:0] = DAC_old, 0x00;$ 

NOTE: Glide is disabled if DAC\_new = DAC\_old.

From the moment the trigger is received, a tick is generated internally, with a frequency controlled by the DAC\_TIMER\_A/B/C registers. Each DAC has its own tick generator running independently of the other DAC. Each time a trigger is received for a DAC, the setting of the DAC TIMER A/B/C register is sampled in a counter dedicated to that DAC. Any update of the DAC\_TIMER\_A/B/C register after trigger is received will be ignored until the next trigger is received

Each time a tick is generated, the content of the accumulator is either incremented or decremented, depending whether DAC\_new is either bigger or smaller than DAC\_old.

ACCUMULATOR[14:0] = ACCUMULATOR[14:0] + GLIDE\_STEP; if DAC\_new > DAC\_old

ACCUMULATOR[14:0] = ACCUMULATOR[14:0] − GLIDE\_STEP; if DAC\_new < DAC\_old

Each time a tick is generated, the output of the DAC[6:0] is updated with the value of ACCUMULATOR[14:8];

The Gliding process continues until, upper 7 bits of the accumulator matches the value of the DAC\_new.

 $ACCUMULATOR[14:8] \geq DAC$  new, when DAC new > DAC\_old

 $ACCUMULATION[14:8] \leq DAC$  new, when DAC new < DAC\_old

The Glide timer will reference the 2 MHz clock divided to provide between 2  $\mu$ s and 62  $\mu$ s per glide step.

Each DAC is independent in terms of its switching operation, thus each DAC may be independently programmed for Normal, Turbo or Glide regardless of the switching operation of the other DACs.

Use−case hint:

In a scenario where the Turbo delay needs to be set to 54 us and the glide should be taking  $\sim$ 7 ms, the DAC TIMER can be configured as  $7000/256 = 27 \,\mu s$  and the DAC TC2X configuration can be set. This way the timer value would not need to be updated during the glide – turbo switches, and only the GL\_X bit in DAC value update needs to be toggled.

#### **Transition from Glide to Glide**

In the event a new glide request is received during a glide transition, the ongoing glide operation is halted and the new glide operation is started from the DAC value, where the previous glide has left off. The DAC timers can be updated to a new value at the trigger.

#### **Transition from Glide to Turbo or Normal Switching**

In the event that a new Normal switching or Turbo DAC value is received during a Glide transition, then the Glide process is stopped and the DAC immediately switches to the newly received target value without Turbo or Glide. The hi slew is not applied.

### **DAC Disable during Glide (including active to low power mode transition)**

If the DAC, which is gliding is disabled, the DAC value holds on to the value where the glide stops. The DAC does

not continue with the glide when it is re−enabled. It drives the last calculated DAC value without a hi\_slew.

### **DAC Update Triggering**

The entire digital logic responsible for DAC updates is using the clock provided by the internal RC oscillator. In order to minimize the power consumption, the RC clock is set at a low frequency around 2 MHz.

### **DAC Writes**

Figure 9 shows the diagram of the DAC data path, from the moment data is written into DACx\_value register, until it is sent out to DAC.

After the DACx\_value register is written using MIPI−RFFE clock, the data is copied on RC clock domain, into the first data stage represented in Figure 9 as ëCompletedí. The data is moved into ëNewí and ëDAC−Outí stages by the DAC driver state machine, once the trigger is detected. The Turbo path also highlights the glide calculation.

If SW trigger is not enabled, then data will flow through the stages right after the corresponding DAC is updated, without waiting for a trigger (MIPI write is considered as the trigger).



**Figure 9. DACx Data Path**

To bypass the SW trigger and enable an immediate trigger the Mask bits under the RFFE\_PM\_TRIG register should be set according to the USID control of the DAC. Trigger Mask 2 is controller with USID\_2, Trigger Mask 1 is controlled with USID 1 and Trigger Mask 0 is controlled with USID 0. In MIPI−RFFE configuration, if RFFE\_PM\_TRIG / Trigger Mask  $2 = 1$ <sup>t</sup>, and RFFE PM TRIG / Trigger\_Mask\_1 =  $i1'$  and RFFE\_PM\_TRIG Trigger Mask  $0 = 1'$  (all software triggers are masked), then each DAC value is copied into 'Completed' stages of each DAC, after the messages RFFE\_REG\_0x06, RFFE\_REG\_0x07 or RFFE\_REG\_0x08 respectively are received, as shown in following sequence.

MIPI\_RFFE\_WRITE #1: send DAC\_A\_value and glide/turbo mode to RFFE\_REG\_0x06

MIPI\_RFFE\_WRITE #2: send DAC\_B\_value and glide/turbo mode to RFFE\_REG\_0x07

MIPI\_RFFE\_WRITE #3: send DAC\_C\_value and glide/turbo mode to RFFE\_REG\_0x08

The individual writes above could be combined into a single extended write with all DACs controlled with the same USID or the DURs of the DACs are sitting at "11" configuration. Right after MIPI RFEE WRITE #1 to RFFE\_REG\_0x06, above, is received the DAC\_A value register is copied in 'Completed' stage of DAC A. The timers DO NOT need to be updated for each DAC update. But if they need to be, they can be updated as part of a full extended write or single write prior to the DAC value updates without any timing limitation. Since the SW trigger is masked, next RC clock cycle after DAC values are copied in 'Completed' stage, the data will move in next stages ëNewí and ëDAC−Outí without waiting for any trigger.

The similar events occur for DAC\_B and DAC\_C after the MIPI\_RFEE\_WRITE  $#2$  and MIPI\_RFEE\_WRITE  $#3$ .

Due to the fact that the MIPI−RFFE master can send DAC updates messages at a higher frequency, than RC clock, the data buffer 'Completed', can be overwritten if new DAC updates occur in the same time when the buffer is loaded.

While data and configuration are copied from DACx\_value register into 'Completed' stage, the MIPI−RFFE master must not send any new DAC updates to DACx value registers or configurations. The time required for the data to be copied from DACx\_value register into 'Completed' stage is Max 1500 ns, which is defined by the three RC clock cycles required to synchronize data from MIPI−RFFE clock domain to RC clock domain.

In Figure 10, DAC\_UPDATE\_LAT represents the period when MIPI−RFFE master is not allowed to send any new DAC updates to DACx value registers and DAC configuration registers.

The DAC enables (RFFE REG 0x00) and Booster configurations (RFFE\_REG\_0x02) are applied immediately without waiting any trigger. These registers should be configured prior, so that the DAC updates are effective as fast as possible. In test mode the hi\_slew settings are sampled at the trigger similar to the dac timers.



**Figure 10. DAC\_UPDATE\_LAT Requirement**

The SW trigger as well as immediate trigger can be configured in many combinations using the DUR settings of the DACs and the USID values. The SW trigger masks can only be changed with the write access using the slave address of their corresponding USID. But the corresponding triggers can be set by accesses over broadcast, with broadcast ID (0x0) or GSID.

The triggering and DAC register access is governed by these rules:

- The DUR configuration assigns a DAC to a USID. The corresponding DAC registers can only be accessed with USID defined by its DUR.
- The immediate update of this DAC is enabled if the SW trigger mask of the corresponding USID is set (disabled).
- The PM TRIG register bit0 (SW trigger0) is masked by bit4 and assigned to DACs triggering, which are mapped to USID0 or all USIDs (the DAC DUR=0 or 3).
- The PM\_TRIG register bit1 (SW trigger1) is masked by bit5 and assigned to DACs triggering, which are mapped to USID1 or all USIDs (the DAC DUR=1 or 3).
- The PM\_TRIG register bit2 (SW trigger2) is masked by bit6 and assigned to DACs triggering, which are mapped to USID2 or all USIDs (the DAC DUR=2 or 3).
- For a DAC with DUR=3, all SW masks need to be set for that DAC to be triggered with direct access to its target register.

If all DACs are kept at DUR values of 3 and the USIDs are kept the same (reset condition), the part behaves according to the MIPI spec with single USID. If some of the USIDs are different while DUR=3, the part responds to the accesses with these different USIDs the same fashion.

If all USIDs are kept equal, the part functions with a single USID. But the DUR settings still control the SW trigger mapping for the DACs independent of the USID values. The DACs which are not holding a DUR value of 3 will be under the control of the SW trigger−mask duo mapped by their DUR setting.

In Table [12](#page-14-0) some example register settings for listed functionality are provided. For the given functionality the response of the part to DAC updates and SW triggers are tabulated. In this table the "DAC trigger" corresponds to a trigger happening at the time of the DAC value update. The "SW trigger" corresponds to a trigger happening with the PM\_TRIG register write. At this point, it is assumed that the DACs are enabled and the new DAC value is not matching to the existing pre−triggered DAC value in the active register. Some of the abbreviations utilized in the table are:

TRG = successful trigger of the new targets

HLD = no trigger, hold on to existing DAC drives

WR = The new DAC values are captured into RFFE shadow registers

NW = The RFFE write to shadow registers are blocked, no register update.

### <span id="page-14-0"></span>**Table 12. IMMEDIATE vs SOFTWARE TRIGGERING USING USIDs and DURs**



### **MIPI RFFE Interface**

TCC−303 is a slave device and is fully compliant to the MIPI Alliance Specification for RF Front−End Control Interface (RFFE) Version 1.10.00.

Following MIPI RFFE commands are supported:

- 1. Register 0 WRITE
- 2. Register WRITE
- 3. Register READ
- 4. Extended Register WRITE
- 5. Extended Register READ

Registers 0x00 to 0x1F are available to be read/written. At full−speed read with heavy load, the RFFE read mode bit RFFE\_RDM can be configured to  $'1'$ , to shift the data capture to falling edge. Otherwise it is recommended to keep this bit in its default state, since the falling edge read data capture is a violation for RFFE interface standard. The violation is due to the toggling during the  $2<sup>nd</sup>$  half of the bus park cycle, which could create bus contention with the master.

The extended register write long and read long commands are not supported. If an extended register write long command is received, no register is written and the RFFE\_STATUS.WURE flag is set. If an extended register read long command is received, the part responds with bus idle and the RFFE\_STATUS.RURE flag is set.

The read access to registers RFFE REG 0x03 to RFFE\_REG\_0x08 returns the active register content, which is the register updated after a trigger. The pre−trigger shadow register does not have read access.

#### **Table 13. MIPI RFFE INTERFACE SPECIFICATION**  (T<sub>A</sub> = −30 to +85°C; 2.3 V < VDDA < 5.5 V; 1.1 V < V<sub>IO</sub> < 1.8 V; unless otherwise specified)





**Figure 11. MIPI−RFFE Signal Timing during Master Writes to PTIC Control IC**



**Figure 12. MIPI−RFFE Signal Timing during Master Reads from PTIC Control IC**

**Figure 13. Bus Park Cycle Timing when MIPI−RFFE Master Reads from PTIC Control IC**

The control IC contains eighteen 8−bit registers. Register content is described in Table 14. Some additional registers implemented as provision, are not described in this document.



### **Table 14. MIPI RFFE ADDRESS MAP**

2. The least significant bits from the Product ID register are refined by OTP. The other seven bits of product ID are hardcoded in ASIC. 3. The manufacturer ID is hardcoded in ASIC, mapped in a READ−only register.

### **Register Content Details**





Bit [2:0] Each DAC is enabled when the corresponding bit is set. The enable or disable occurs immediately without waiting for a trigger. 0: Off (default) 1: enabled

Bit [7]: Register 0 write command excludes this bit. The extended writes to this address ignores bit 7. The bit is not utilized.





DUR x [1:0] (DAC x USID response)

ë00í: Responds only to USID\_0 in DAC register write. SW trigger0 mask defines the triggering source.

ë01í: Responds only to USID\_1 in DAC register write. SW trigger1 mask defines the triggering source.

ë10í: Responds only to USID\_2 in DAC register write. SW trigger2 mask defines the triggering source.

'11': Responds to any 3 USID in DAC register write. Any trigger mask cleared enables the SW triggering.



Bits a construct boost clk en constructed boost en boost en and boost voltage value Reset W−1 W−1 U−0 W−1 W−1 W−0 W−1 W−1

Bit [7]: Enables the booster clock. The clock should be disabled when the booster is turned off.

Bit [6]: Enables the boost oscillator pwm function. This signal should be turned off in case the booster generates low voltages to reduce the ripple.

Bit [4]: Enable/disable of the booster. Booster must be turned off when the high voltage is provided externally.

Bit [3:0]: **Boost voltage value**. Refer to Table 15 for values

### **Table 15. BOOST VOLTAGE SETTING**







Bit [7] If this bit is set, in Turbo mode dac timer \* 2 value is loaded into the DAC timer. The glide always sets the step delay to dac\_timer value independent of this bit.

Bit [6:5] It defines the multiplication factor of timer extension when the turbo−down value is below 4 V.

Bit [4:0] For the definition of dac timer field, see Table [10](#page-10-0).

NOTE: The read access to this register will return the active content post−trigger, not the shadow register.





Bit [7] If this bit is set, in Turbo mode dac timer \* 2 value is loaded into the DAC timer. The glide always sets the step delay to dac\_timer value independent of this bit.

Bit [6:5] Defines the multiplication factor of timer extension when the turbo−down value is below 4 V

Bit [4:0] For definition of dac\_timer field, see Table [10](#page-10-0).

NOTE: The read access to this register will return the active content post−trigger, not the shadow register.





Bit [7] If this bit is set, in Turbo mode dac\_timer \* 2 value is loaded into the DAC timer. The glide always sets the step delay to dac timer value independent of this bit.

Bit [6:5] Defines the multiplication factor of timer extension when the turbo−down value is below 4 V

Bit [4:0] For definition of dac timer field, see Table [10](#page-10-0).

NOTE: The read access to this register will return the active content post−trigger, not the shadow register.





Bit [7] If the GL\_A=1, a non−zero value in DAC timer in starts a glide. If GL\_A =0 and the DAC\_TIMER\_A is not zero, Turbo is started with the new DAC A value.

NOTE: The read access to this register will return the active content post−trigger, not the shadow register. The DAC value read−back is not the actual analog drive, it is the target level.



Bit [7] If the GL\_B=1, a non−zero value in DAC timer in starts a glide. If GL\_B =0 and the DAC\_TIMER\_B is not zero, Turbo is started with the new DAC B value.

NOTE: The read access to this register will return the active content post−trigger, not the shadow register. The DAC value read−back is not the actual analog drive, it is the target level.

Reset W−0 W−0 W−0 W−0 W−0 W−0 W−0 W−0





Bit [7] If the GL\_C=1, a non−zero value in DAC timer in starts a glide. If GL\_C =0 and the DAC\_TIMER\_C is not zero, Turbo is started with the new DAC C value.

NOTE: The read access to this register will return the active content post−trigger, not the shadow register. The DAC value read−back is not the actual analog drive, it is the target level.





Bit [0] this bit defines the read capture edge internal to the chip. If 1, the read data is released at the falling edge of the RFFE clock. In a system with very heavy load and 26 MHz speed, this bit can be set to gain some time .For speeds below full−speed and light load, it is recommended to keep this bit cleared to switch to rising edge read data release.





USID = Unique Slave Identifier Register

1. USID field can be changed by:

- ♦ MIPI−RFFE broadcast messages when USID field within the Register Write Command is 0b0000
- ♦ MIPI−RFFE individual messages when USID field within the Register Write Command equal with content of RFFE\_REG\_0x18[3:0]
- 2. In the sequence of writing USID field, the upper [7:4] must match the value 0b0001 hardcoded in the RFFE register 0x18







USID = Unique Slave Identifier Register

1. USID field can be changed by:

- ♦ MIPI−RFFE broadcast messages when USID field within the Register Write Command is 0b0000
- ♦ MIPI−RFFE individual messages when USID field within the Register Write Command equal with content of RFFE\_REG\_0x19[3:0]
- 2. In the sequence of writing USID field, the upper [7:4] must match the value 0b0001 hardcoded in the RFFE register 0x19

NOTE: USID\_2 value is NOT retained during SHUTDOWN power mode.





SWR Soft−Reset MIPI−RFFE registers

Write '1' to this bit to reset all the MIPI–RFFE registers, except RFFE\_PM\_TRIG, RFFE\_GROUP\_SID, RFFE\_USID\_0, RFFE\_USID\_1 and RFFE\_USID\_2.

This bit will always Read–back '0'.

The soft reset occurs in the last clock cycle of the MIPI–RFFE frame which Writes '1' to this bit.

Right immediately after this frame, all the MIPI−RFFE registers have the reset value and are ready to be reprogrammed as desired.

The OTP duplicated registers below the address 0x1F are reset to the values written in OTP.

RFFE\_STATUS Bits [6:0] are set '1' by hardware to flag when a certain condition is detected, as described below. RFFE\_STATUS Bits  $[6:0]$  cannot be written, but it is cleared to '0' under following conditions:

♦ Hardware Self−reset is applied after RFFE\_STATUS is READ

- $\bullet$  When SWR is written '1'
- $\bullet$  When power mode transitions through STARTUP mode '01'

♦ After Power−up Reset

**CFPE** 

1: Command frame with parity error received.

On the occurrence of this error, the slave will ignore the entire Command Sequence

CLE

1: Incompatible command length, due to unexpected SSC received before command length to be completed. On the occurrence of this error, the slave will accept Write data up to the last correct and complete frame. When MIPI−RFFE multi−byte Read command is detected, the slave will always replay with an extended Read command of length of one byte.

AFPE

1: Address frame with parity error received.

On the occurrence of this error, the slave will ignore the entire Command Sequence

### DFPE

1: Data frame with parity error received.

On the occurrence of this error, the slave will ignore only the erroneous data byte (s)

RURE

1: Read of non−existent register was detected.

On the occurrence of this error, the slave will not respond to the Read command frame. It will keep the bus idle. WURE

1: Write to non−existent register was detected.

On the occurrence of this error, the slave discards data being written, and on the next received frame, proceeds as normal BGE

1: Read using the Broadcast ID was detected

On the occurrence of this error, the slave will ignore the entire Command Sequence



<u>Reset Source:</u> nreset dig or PWR\_MODE = '01' (transition through STARTUP mode)



GSID = Group Slave Identifier Register

NOTE: The GSID [3:0] field can be written directly by messages using USID\_0, USID\_1 or USID\_2.

NOTE: GSID value is NOT retained during SHUTDOWN power mode.

NOTE: GSID value is not affected by SWR bit from RFFE\_STATUS register

NOTE: Frames using slave address = GSID, can write only to RFFE\_PM\_TRIG [7:6] and [2:0].

### NOTE: RFFE READ frames containing GSID will be ignored



### <u>Reset Source:</u> nreset\_dig or PWR\_MODE = '01' (transition through STARTUP mode)



4. The Trigger Mask 2 (bit [5]) can be changed, either set or cleared, only with an individual message using USID\_2. The Trigger Mask 1 (bit [4]) can be changed, either set or cleared, only with an individual message using USID\_1. The Trigger Mask 0 (bit [3]) can be changed, either set or cleared, only with an individual message using USID\_0.

5. During broadcast MIPI−RFFE accesses using Broadcast ID or GSID, Trigger bits [2:0] are masked by the pre−existent setting of Trigger Mask bits [5:3].

6. During Individual MIPI−RFFE accesses, Trigger bits [2:0] are masked by the incoming Trigger Mask bits [5:3] within the same write message to RFFE\_PM\_TRIG register according to the DAC DUR configurations.

7. Power mode field bits [7:6] and Triggers bits [2:0] can be changed by either MIPI−RFFE broadcast messages (with GSID or Broadcast ID slave address). The power mode can be changed by all USID accesses. The trigger bits can be set by individual messages when slave address fields within the Register Write Command is are equal to their corresponding control USIDs.

NOTE: None of the 8 bits of RFFE\_PM\_TRIG register bits are affected by SWR bit from RFFE\_STATUS register. The default reset values of the Trigger Masks are set to '1' violating the RFFE spec, but the trigger at DAC write is requested to be the default

### Bit [7:6]: **Power Mode**

00: **ACTIVE mode**, defined by following hardware behavior:

- ♦ Boost Control active, VHV set by Digital Interface
- ♦ Vout A, B, C enabled and controlled by Digital Interface
- 01: **STARTUP mode**, defined by following hardware behavior:
- ♦ Boost Control active, VHV set by Digital Interface
- $\rightarrow$  Vout A, B, C disabled
- 10: **LOW POWER** mode is defined by following hardware behavior:
- ♦ Digital interface is active, while all other circuits are in low power mode
- 11: Reserved (State of hardware does not change)

### Bit 5: **Mask trigger 2 (only USID\_2 write access)**

- 0: Trigger 2 not masked. The DACs, which are configured in their DUR to be controlled by USID 2 have their active registers updated after the Trigger 2 is written a value of 1.
- 1:Trigger 2 is masked. The DACs, which are configured in their DUR to be controlled by USID\_2 have their active registers updated as soon as their new DAC values are written in (default).

### Bit 4: **Mask trigger 1 (only USID\_1 write access)**

- 0: Trigger 1 not masked. The DACs, which are configured in their DUR to be controlled by USID 1 have their active registers updated after the Trigger 1 is written a value of 1.
- 1:Trigger 2 is masked. The DACs, which are configured in their DUR to be controlled by USID\_1 have their active registers updated as soon as their new DAC values are written in (default).

### Bit 3: **Mask trigger 0 (only USID\_0 write access)**

- 0: Trigger 0 not masked. The DACs, which are configured in their DUR to be controlled by USID 0 have their active registers updated after the Trigger 0 is written a value of 1.
- 1:Trigger 2 is masked. The DACs, which are configured in their DUR to be controlled by USID\_0 have their active registers updated as soon as their new DAC values are written in (default).

### Bit 2: **Trigger 2 (USID\_2 or broadcast write access)**

Write 1 to this bit, to move data in DACs, which are configured in their DUR under USID\_2 control, from shadow registers into active registers. This trigger can be masked by bit 5. The read back of this field returns DACC pending trigger status (from immediate or SW trigger).

### Bit 1: **Trigger 1 (USID\_1 or broadcast write access)**

Write 1 to this bit, to move data in DACs, which are configured in their DUR under USID\_1 control, from shadow registers into active registers. This trigger can be masked by bit 4. The read back of this field returns DACB pending trigger status (from immediate or SW trigger).

### Bit 0: **Trigger 0 (USID\_0 or broadcast write access)**

Write 1 to this bit, to move data in DACs, which are configured in their DUR under USID\_0 control, from shadow registers into active registers. This trigger can be masked by bit 3. The read back of this field returns DACA pending trigger status (from immediate or SW trigger).





Bits [7:1] are hardcoded in ASIC

Bit [0] depends on version – 0 for TCC−303A

PRODUCT Family ID History:





Reset Source: N/A



The 10 MPN bits (MPN0 to MPN9 partially residing under USID registers) are manufacturing ID bits unique to ON Semiconductor.





USID = Unique Slave Identifier Register

1. USID field can be changed by:

♦ MIPI−RFFE broadcast messages when USID field within the Register Write Command is 0b0000

- ♦ MIPI−RFFE individual messages when USID field within the Register Write Command equal with content of RFFE\_REG\_0x1F[3:0]
- 2. In the sequence of writing USID field, the upper [7:4] must match the value 0b0001 hardcoded in the RFFE register  $0x1F$

NOTE: USID value is NOT retained during SHUTDOWN power mode.

### **Register 0 Write Command Sequence**

The Command Sequence starts with an SSC which is followed by the Register 0 Write Command Frame. This Frame contains the Slave address, a logic one, and the seven bit word that will be written to Register 0. The Command Sequence is depicted below.



### **Figure 14. Register 0 Write Command Sequence**

### **Table 16. RFFE COMMAND FRAME FOR REGISTER 0 WRITE COMMAND SEQUENCE**



### **Single Register Write Command Sequence**

The Write Register command sequence may be used to access each register individually (addresses 0−31).



**Figure 15. Single Register Write Command Sequence**





This sequence can be used for Read/Write procedure for some other purposes as shown on the following table:



### **Table 18. OTHER RFFE COMMAND SEQUENCES**

#### **Extended Register Write Command Sequence**

In order to access more than one register in one sequence this message could be used. Most commonly it will be used for loading three DAC registers at the same time. The four LSBs of the Extended Register Write Command Frame determine the number of bytes that will be written by the Command Sequence. A value of 0b0000 would write one byte and a value of 0b1111 would write sixteen bytes.

If more than one byte is to be written, the register address in the Command Sequence contains the address of the first extended register that will be written to and the Slave's local extended register address shall be automatically incremented by one for each byte written up to address 0x1F, starting from the address indicated in the Address Frame.



**Figure 16. Extended Register Write Command Sequence**



### **Table 19. RFFE Command Frame for Extended Register Write Command Sequence for DACs Loading Procedure**

### **Extended or Single Register Read Command Sequence**

MIPI–RFFE Read operation can access any register from address 0x00 to 0x1F without the need to enter testkey. Both single Register Read and Extended Register Read commands are supported.



**Figure 17. Single Register Read Command Sequence**



**Figure 18. Extended Register Read Command Sequence**

### **Changing USIDs**

Changing USID is according to MIPI RFFE specifications. Same Manufacturer ID and Product ID apply for USID  $\frac{0}{1}$  2. Note that USID can be changed with broadcast commands, or commands targeting that particular USID. For example to change USID\_0, broadcast commands or commands addressing USID\_0 can be used.

### **Change USID\_0**

- RFFE\_WRITE\_REG 0x1D [0x10 + OTP[31]]
- RFFE\_WRITE\_REG 0x1E 0x2E
- RFFE\_WRITE\_REG 0x1F 0x1Z, where Z is the new USID 0 value

### **Change USID\_1**

- RFFE\_WRITE\_REG  $0x1D$   $[0x10 + OTP[31]]$
- RFFE\_WRITE\_REG 0x1E 0x2E
- RFFE\_WRITE\_REG 0x18 0x1Z, where Z is the new USID\_1 value

### **Change USID\_2**

- RFFE\_WRITE\_REG  $0x1D$   $[0x10 + OTP[31]]$
- RFFE\_WRITE\_REG 0x1E 0x2E
- RFFE\_WRITE\_REG 0x19 0x1Z, where Z is the new USID\_2 value

### **EXAMPLE DEVICE OPERATION**

### **Device Setup**

- 1. Enable all three  $DACs Write 0x07$  to Register 0x00
- 2. Change VHV voltage to 28 V (Default  $24$  V) Write 0xDF to Register 0x02

### **Change DACs**

- Change DACA voltage to 6.8 V; no Glide Write  $0x24$ to Register 0x06
- Change DACB voltage to 12.0 V; no Glide Write 0x40 to Register 0x07
- Change DACC voltage to 0.9 V; no Glide Write  $0x05$ to Register 0x08

### **Setup Glide**

- Set DACA Glide step duration to 28  $\mu$ s Write 0x0E to Register 0x03
- Set DACB Glide step duration to 20  $\mu$ s Write 0x0A to Register 0x04
- Set DACC Glide step duration to  $42 \mu s W$ rite 0x15 to Register 0x05

### **Change DACs with Glide**

- Keep DACA voltage at 6.8 V; Glide enabled  $-$  Write 0xA4 to Register 0x06 (Total Glide duration is  $28 \text{ }\mu\text{s}^2 256 \text{ }\mu\text{s} = 7168 \text{ }\mu\text{s}$ ; No output change since DAC\_OLD = DAC\_NEW
- Change DACB voltage to 16.4 V; Glide enabled -Write 0xD7 to Register 0x07 (Total Glide duration is  $20 \,\mu s*256 \,\mu s = 5120 \,\mu s$ ; Transitions from 12 V to 16.4 V over 5.12 ms
- Change DACC Voltage to 20.5 V; Glide enabled  $-$ Write 0xED to Register 0x08 (Total Glide Duration is 42  $\mu$ s\*256  $\mu$ s = 10752 us); Transitions from 0.9 V to 20.5 V over 10.75 ms
- NOTE: Any sequential registers (Eg. 0x03−0x08, as mentioned in Setup Glide and Change DACs with Glide sections) can be written with a single extended MIPI write, rather than individual write commands.

Following picture shows TCC−303 and all the necessary external components



**Figure 19. TCC−303 with External Components**

### **Table 20. RECOMMENDED EXTERNAL BOM**



8. Recommended in noise reduction only− not essential but place next to PTIC if used

9. These devices have not been fully tested; performance cannot be guaranteed.

### **TAPE & REEL DIMENSIONS**

<span id="page-30-0"></span>

**Figure 20. WLCSP Carrier Tape Drawings**



**Figure 21. Orientation in Tape**

### **Table 21. ORDERING INFORMATION**



ÜFor information on tape and reel specifications, including part orientation and tape sizes, please refer to our Tape and Reel Packaging Specifications Brochure, BRD8011/D.

### **ASSEMBLY INSTRUCTIONS**

Note: It is recommended that under normal circumstances, this device and associated components should be located in a shielded enclosure.

### **PACKAGE DIMENSIONS**





ON Semiconductor and ⊍") are trademarks of Semiconductor Components Industries, LLC dba ON Semiconductor or its subsidiaries in the United States and/or other countries.<br>ON Semiconductor owns me rights to a number of pate ON Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does ON Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation special, consequential or incidental damages.<br>Buyer is responsible for its pro application by customerís technical experts. ON Semiconductor does not convey any license under its patent rights nor the rights of others. ON Semiconductor products are not designed, intended, or authorized for use as a critical component in life support systems or any FDA Class 3 medical devices or medical devices with a same or similar classification<br>in a foreign jurisdiction or any devices application, Buyer shall indemnify and hold ON Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such<br>claim alleges that ON Semiconductor was literature is subject to all applicable copyright laws and is not for resale in any manner.

#### **PUBLICATION ORDERING INFORMATION**

#### **LITERATURE FULFILLMENT**:

Literature Distribution Center for ON Semiconductor 19521 E. 32nd Pkwy, Aurora, Colorado 80011 USA **Phone**: 303−675−2175 or 800−344−3860 Toll Free USA/Canada **Fax**: 303−675−2176 or 800−344−3867 Toll Free USA/Canada **Email**: orderlit@onsemi.com

**N. American Technical Support**: 800−282−9855 Toll Free USA/Canada **Europe, Middle East and Africa Technical Support:**

Phone: 421 33 790 2910 **Japan Customer Focus Center** Phone: 81−3−5817−1050

**ON Semiconductor Website**: **www.onsemi.com**

**Order Literature**: http://www.onsemi.com/orderlit

For additional information, please contact your local Sales Representative