# <span id="page-0-0"></span>**Design of a Fully Integrated Buck-Boost Converter ASIC**

A small buck-boost converter ASIC with integrated switches on a commercial 0.35 um process node for use in a charging case for hearing devices

**Autors** Matthias Meyer, Patrick Jansky **Professor** Prof. Dr. Paul Zbinden **Experts** Lars Kamm **Study** Electrical Engineering (ElE) **Subject Area Microelectronics** 

OST RJ Ostschweizer Fachhochschule Rapperswil

July 14, 2023

## **Abstract**

This document focuses on the pre-layout phase of a project, which was divided into prelayout and post-layout stages. The project was initiated by Sonova AG, with the objective of designing a compact 200 mA DC/DC converter for potential integration into the charging case of their hearing devices. This first part of the documentation provides a comprehensive overview of the key steps undertaken during the pre-layout phase, including DC/DC topology selection, circuit architecture/design, and chip interface considerations. By examining these crucial aspects, this documentation offers valuable insights into the initial phase of the project, providing a solid foundation for the subsequent layout and manufacturing, and testing stages.



## **Acknowledgements**

We are immensely grateful to our supervisor, Lars Kamm, for his invaluable feedback and guidance throughout this project. His profound expertise in the field of ASIC design has been crucial in directing us and shaping the project, enabling us to present our results here today.

We would like to express our gratitude to the faculty members of IMES (Institut für Mikroelektronik und Embedded Systems) at OST for lending us a helping hand in times of need. A special thanks goes out to Lukas Leuenberger, Simon Walker and Roman Willi for their endless hours helping us get acquainted with the tools we required and answering our many questions regarding analog circuit design.

Finally, we are profoundly grateful to Prof. Dr. Paul Zbinden for giving us this rare opportunity, to design a fully custom integrated circuit as part of our masters program. Thank you all.

## **Contents**







## <span id="page-6-0"></span>**1** | **Assignment**

### <span id="page-6-1"></span>**1.1** | **Introduction**

The goal of this project is to create a prototype Application Specific Integrated Circuit [\(ASIC\)](#page-73-4) to be used inside a charging cradle for Hearing Instruments [\(HI\)](#page-73-5) from Sonova AG. The main objective for the [ASIC](#page-73-4) is to safely charge the [HI](#page-73-5) from a standard USB power cable. Since there are two [HI](#page-73-5) in a cradle, it must be possible to charge both [HI](#page-73-5) simultaneously at their maximum charging speed. There should be a serial port to read and write data to the chip, in allow for external monitoring and configuration.

In a first step the specification shall be created and a system design proposal with ideal components should be designed and simulated. To make the chip manufacturable, these ideal components shall one by one be replaced with implementable designs from libraries or custom made, while still being able to meet the specifications. Based on the system design a layout shall be created in such a way that an [ASIC](#page-73-4) can be manufactured.

Once the [ASIC](#page-73-4) has been manufactured and packaged, the chip shall be validated and characterized. The measured specifications shall be compared with the requirements.

### <span id="page-6-2"></span>**1.2** | **Technical Requirements**

The main technical requirements of the [ASIC](#page-73-4) concern the charging of the [HI.](#page-73-5) The [ASIC](#page-73-4) should provide a constant voltage of 5 V off of a Universal Serial Bus [\(USB\)](#page-74-0) power supply, which can have a wide voltage range of 4.3 V to 5.3 V. As the input voltage can be higher or lower than the output, the charger must be able step up as well as step down the voltage.

Each [HI](#page-73-5) can pull a maximum charging current of 80 mA, the chip therefore needs to be able to supply around 100 mA per output, in order to have some margin. Additional functionalities and safety features are allowed but not a must.

| Input Voltage Range   4.3 V - 5.3 V |                     |
|-------------------------------------|---------------------|
| Output Voltage                      | 4.9 V-5.1 V         |
| <b>Output Current</b>               | $200 \,\mathrm{mA}$ |

*Table 1: Main requirements for the charger [ASIC](#page-73-4)*

The full technical requirements can be found in the attachments.

### <span id="page-6-3"></span>**1.3** | **Background of Application**

<span id="page-6-4"></span>The project idea originally came from Sonova AG, therefore most of the requirements were provided by them. Since the scope of the requirements is large and it's not possible to fulfil all of them in the given time and with the given resources, the focus shall be on the basic functionalities mentioned above.



### **1.4** | **Scope of Work**

#### <span id="page-7-0"></span>**1.4.1** | **Project Thesis 1**

- Literature study
- Specifications
- Verification
- Design for test

#### <span id="page-7-1"></span>**1.4.2** | **Project Thesis 2**

- Layout
- Post Layout Simulations
- Tape out
- Validation plan
- PCB for validation
- Validation
- Test report

### <span id="page-7-2"></span>**1.5** | **Goals**

- Getting familiar with the various tools required for [ASIC](#page-73-4) design
- Document the project and provide reasoning for important design decisions
- Understand and complete the entire [ASIC](#page-73-4) design flow consisting of:
	- **–** System design
	- **–** Layout
	- **–** Tape out
	- **–** Validation
	- **–** (optional) Redesign

### <span id="page-7-3"></span>**1.6** | **Mile stones**



### <span id="page-7-4"></span>**1.7** | **Organization**





# <span id="page-8-0"></span>**2** | **Introduction**

The goal of this project is to create prototype [ASIC,](#page-73-4) which can be used inside a charging cradle of a [HI.](#page-73-5) Thereby the [ASIC](#page-73-4) should deliver a constant voltage of 5V to reliably charge the [HI](#page-73-5) from any [USB](#page-74-0) supply. Which means according to the [USB](#page-74-0) specification the circuit should be fully functional down to a voltage of 4.35 V. The reason of this requirement comes from the fact that the new [HI'](#page-73-5)s have a lithium battery inside, which require a charging voltage of up to 4.2 V. When the [USB](#page-74-0) supply is then as low as 4.35 V the battery will not fully charge any more or only very slow, since the Low Drop-Out [\(LDO\)](#page-73-6) regulator has a certain headroom and the charger also contains some contact resistances from the charger pins to the [HI](#page-73-5) pins. So if one wants to charge at full speed and one assumes that the charging resistance can be several ohms this causes a significant voltage drop. [\[1\]](#page-79-0)

The project of designing and testing such an [ASIC](#page-73-4) was divided in two parts "pre-layolut phase" and "post-layolut phase", since the project was executed in a master program which requires two separate stages.



## <span id="page-9-0"></span>**3** | **Literature Study**

### <span id="page-9-1"></span>**3.1** | **Intro**

Since the specifications for the project were already well-defined, the primary focus of the literature research was not directed towards market analysis and existing solutions. Instead, the emphasis was placed on exploring the implementation aspects of designing an [ASIC](#page-73-4) for such a specialized application.

### <span id="page-9-2"></span>**3.2** | **Project Organization**

For project organization, we utilized [Jira.](subsec:jira) We chose this platform because one of our project participants was already familiar with it. It is a freely available tool for teams of up to ten people [\[2\]](#page-79-1) and offers a user-friendly and transparent project management experience. Moreover, *[Jira](subsec:jira)* enables time tracking, allowing us to analyze time allocation and make informed decisions for future projects.

#### <span id="page-9-3"></span>**3.2.1** | **Schedule**

The schedule was given by the master program. Which means start was summer 2022 and end is summer 2024. Furthermore, the tape-in date of the [ASIC](#page-73-4) manufacturer defined the date until when the [ASIC](#page-73-4) design must have been completed.

### <span id="page-9-4"></span>**3.3** | **Jira**

Jira is an issue tracking and project management software [\[3\]](#page-79-2) to which one finds more information on the following [page.](https://www.atlassian.com/de/software/jira)



### <span id="page-10-0"></span>**3.4** | **Process Evaluation**

In the process evaluation process for this project, several criteria were considered due to its affiliation with a master's program:

- The feasibility of implementing the project using a specific process.
- Familiarity of university personnel with the manufacturer and the chosen process.
- Cost-effectiveness.

Since the university has experience with processes offered by [X-Fab](https://www.xfab.com/) (refer to [subsec](#page-10-2)[tion 3.6\)](#page-10-2), and [X-Fab](https://www.xfab.com/) provides a process that meets the project's requirements, it was determined to proceed with [X-Fab.](https://www.xfab.com/) Consequently, no other manufacturers were considered during the evaluation phase. The primary technology requirement was the support for 5 V. Therefore, the decision was made to implement the project using the Multi Project Waver [\(MPW\)](#page-73-7) approach with the «XH035 0.35 µm HV Complementary Metal–Oxide–Semiconductor [\(CMOS\)](#page-73-8) 4M» process and the MOS and MOS5A module. Additional information about this process can be found in [subsection 3.5](#page-10-1) and **??**.

### <span id="page-10-1"></span>**3.5** | **XH035 Process**

The XH035 process has four main process modules, which can be combined with one or more additional modules. An overview can be found below:

- MOS (3.3 V)
- MOS5  $(5 V)$
- MOSLL (3.3 V low leakage)
- MOSLT (3.3 V low threshold)

For this project, the MOS5 module would be the most suitable, but since there is no [MPW](#page-73-7) available one of the others must be chosen with the addition of MOS5A [\[4\]](#page-79-3).  $^1$  $^1$ 

## <span id="page-10-2"></span>**3.6** | **X-FAB**

[X-Fab](https://www.xfab.com/) it as pure play foundry, which means they only manufacture devices for other companies, without designing them [\[5\]](#page-79-4), Specialized in analog/mixed-signal semiconductor technologies [\[6\]](#page-79-5).

### <span id="page-10-3"></span>**3.7** | **DC**/**DC Topology**

There are multiple topologies of DC-to-DC converters in active use with step-up (boost) and step-down (buck) capabilities as required in this project. In this chapter we are going to introduce various topologies, their advantages and disadvantages in order to find a suitable fit for our requirements. Our main criteria are as follows:

- Few external components
- Few connections to external components
- Non inverting

The selected topology will be implemented on a single [ASIC,](#page-73-4) therefore we have additional requirements as opposed to a discrete implementation. Large capacitors and inductors

<sup>1</sup> All the information mentioned can also be found in the datasheet [\[4\]](#page-79-3)



can't be integrated into the chip and have to be external to the design. External components obviously need to connected to the chip and require pads, which adds size and complicates routing. This leads to a strong incentive to keep the number external components to a minimum and is our main concern. The other listed requirements are of lower priority.

#### <span id="page-11-0"></span>**3.7.1** | **SEPIC**

A Single-Ended Primary-Inductor Converter [\(SEPIC\)](#page-73-9) is type of switching converter which is able to operate from an input voltage lesser, greater or equal to the output voltage as need in this application. It requires only one active component, Q1 as it can be seen in [Figure 1](#page-11-2) [\[7\]](#page-79-6). It however requires two external inductors, an external coupling capacitor and an output smoothing capacitor. The [SEPIC](#page-73-9) topology has widespread adoption and has been extensively researched and documented. Its high efficiency [\[8\]](#page-79-7) and lower stress on components compared to Cuk and buck-boost converters [\[9\]](#page-79-8) are large advantages, however this topology is not well suited for high levels of integration as needed in this application. The number of external components is quite high with two inductors, two capacitors and depending the implementation one diode. The diode could be integrated into the [ASIC,](#page-73-4) this however makes little sense, since both electrical connections are exclusively connected to external components.

| <b>Switching Elements</b> |    |
|---------------------------|----|
| Ext. Inductors            | 2  |
| Ext. Capacitors           | 2  |
| Ext. Diodes               | 1* |

*Table 2: Elements of a [SEPIC](#page-73-9) converter*

<span id="page-11-2"></span>

*Figure 1: Example of a [SEPIC](#page-73-9) converter*

### <span id="page-11-1"></span>**3.7.2** | **Cuk**

The Cuk converter is another type of buck-boost converter, which has the main advantage of reducing the ripple current on the input and output. It therefore has near continuous input and output currents which is its main advantage in comparison with the other converter topologies introduced in this chapter. The number and types of components are identical to the [SEPIC](#page-73-9) design and only differs in their wiring. Thus it suffers from the same drawback of being difficult to integrate into a single chip.





*Table 3: Elements of Cuk*



*Figure 2: Example of a Cuk converter*

#### <span id="page-12-0"></span>**3.7.3** | **Cascaded Boost-Buck Converter**

Using the basic building blocks of simple buck and boost converters, it is possible to cascade the two in order to create a Boost-Buck-Cascaded or a Buck-Boost-Cascaded converter. The Boost-Buck-Cascaded topology uses a basic boost converter followed by a basic buck converter. This design requires a minimum 2 switching transistors and uses 2 external inductors. This design requires a large capacitor after the first stage, which would have to external to meet the capacitance required.

Switching Elements 2 Ext. Inductors 2 Ext. Capacitors 2

*Table 4: Elements of Boost-Buck-Cascaded*



*Figure 3: Example of a cascaded boost-buck converter*

#### <span id="page-12-1"></span>**3.7.4** | **Cascaded Buck-Boost Converter**

Switching the order of the simple buck and boost converters we get the Buck-Boost-Cascaded topology. In this configuration one single inductor is shared for both the upand down-conversion. Additionally the only capacitor required is an output smoothing capacitor, as is the case with all other topologies. This configuration also lends itself for the use of synchronous rectification to further improve efficiency.



| Switching Elements 2<br>Ext. Inductors 2<br>Ext. Capacitors 2 |  |
|---------------------------------------------------------------|--|

*Table 5: Elements of a cascaded buck-boost-converter*



*Figure 4: Example of a cascaded buck-boost converter*

### <span id="page-13-0"></span>**3.8** | **Controller structure**

The main objective of the DC/DC converter is to create a stable output voltage, regardless of the input voltage and load present on the output. It therefore may seem appealing to only use the output voltage of as a regulation variable. Such a scheme would have no regard for the current flowing in the inductor, which leads to bad regulation characteristics and could have catastrophic consequences, if the current exceeds the current ratings of the used components. Therefore many commercial converter designs additionally measure the current flowing in the inductor and use regulation loop to control it. This control loop can be quite rudimentary for instance only ensuring, the current doesn't exceed a certain value or they can be elaborate by regulating the output current with a sophisticated regulator design. The former control scheme is referred to as peak current-mode control, while the latter is called average current-mode control. Both approaches are in commercial use today.

#### <span id="page-13-1"></span>**3.8.1** | **General Current-Mode Control**

The basic idea of current-mode control is to have two superimposed controllers, one for the inductor current and one for the output voltage. The faster inner control loop regulates the inductor current to a value set by the outer voltage control loop. The slower outer control loop aims to regulate the output voltage. Using these superimposed control loops allows both to be tuned independently in order to improve the regulator performance. This method actively regulates the current in the inductor and by extension the switching devices, making it possible effectively limit and control the inductor current.

<span id="page-13-2"></span>As an example, if the inner loop is in steady-state, but the output voltage is to low, the outer loop increases the set current of the inner loop. The increased inductor current thus leads to more energy being transferred in to the output capacitor, increasing the output voltage. The main difference between the peak and average current-mode control is in how the inner current control loop is implemented. Both operate with the same two loop operating principle.





*Figure 5: Schematic prepresentaion of current-mode control*

#### **3.8.2** | **Peak Current-Mode Control**

The older of the two approaches is peak current-mode control first described by T. A. Froeschle in 1967 and Cecil of Bell Labs/Western Electric in 1978 [\[10\]](#page-79-9) in order to prevent transformer cores from saturating. In this type of current-mode control, the inductor current is allowed to increase until a threshold is reached. This is usually done by using a comparator to compare the current through the inductor and a threshold given by the outer loop. The output of the comparator is then used to reset the latch driving generating the drive signals for the power stage. This control scheme is still in use and is available in most integrated buck-boost converters such as the LM5175 from Texas Instruments[\[11\]](#page-79-10). Peak current-mode control is well understood and has the advantage of only requiring the measurement of the inductor current when it is rising. It also implicitly acts a current limiting circuit, since as soon as the current exceeds the predetermined value, the transistor charging the inductor switches off, thus limiting the current flow through the inductor. This scheme is also more suitable for low inductor currents. This is due to the peak current level being significantly higher than the average current level, thus having greater signal levels. The peak current-code control and its analog the valley currentmode control are however inherently susceptible to noise on the feedback line, since noise spikes can cause the comparator to switch prematurely thus resetting the latch[\[10\]](#page-79-9). There are ways around this problem, for instance using emulated current-mode control, this however further increases design complexity. For duty-cycles greater than 50 % peak current-mode control also requires an additional slope compensation circuit to eliminate subharmonic oscillations[\[10\]](#page-79-9)[\[12\]](#page-79-11).



<span id="page-14-0"></span>*Figure 6: Structure of the control loop for peak current-mode control*



#### **3.8.3** | **Average Current-Mode Control**

The more modern approach is to use a filter network to approximate the average current flowing in the inductor and regulate the inductor current based on this value. This technique has multiple advantages. By filtering the inductor current signal, the regulator becomes less susceptible to noise on the feedback line. It also removes the need for slope compensation at high duty-cycles and allows the use of a high gain amplifier in the current feedback loop[\[10\]](#page-79-9). Average current-mode control however requires the sensing of the entire inductor current waveform. This eliminates the possibility of using the *RDS*,*on* of a single switching transistor as a current shunt.



*Figure 7: Structure of the control loop for average current-mode control*

### <span id="page-15-0"></span>**3.9** | **Slope Compensation and Sub-Harmonic Oscillations**

Switching Converters based on a fixed frequency peak current-mode control are susceptible to phenomenon called sub-harmonic oscillations when operating at a duty-cycle greater then 50 Other control modes are also effected from this phenomenon with varying conditions in which it takes place, in this chapter we will only be evaluating its effects on peak current-mode control. Sub-harmonic oscillations is the name given to this phenomenon of oscillations in the inductor current when operating in a steady state as can be seen in figure [Figure 8B](#page-16-2). These oscillations occur in a lower frequency than the switching frequency of the converter and are caused by the inductor current not returning to the start value at the end of the switching cycle. The inductor current should have triangular waveform, oscillating from some minimum value to some maximum value and back in one switching period. As can be seen in figure [Figure 8B](#page-16-2), this is not the case when sub-harmonic oscillations are present. Sub-harmonic oscillations are generally not harmful[\[13\]](#page-79-12), but they can cause audible noise if the oscillations lie in the audible frequency spectrum.

To guarantee a sub-harmonic oscillation free operation using peak current-mode control at high duty-cycles, a technique called slope compensation is employed. Slope compensation reduces the peak current threshold proportional to the pulse width of the ongoing



<span id="page-16-2"></span>switching cycle. When correctly implemented, this ensures the inductor current always returns to the value at the start of the switching cycle, eliminating sub-harmonic oscillations in the process. The formulas to calculate the ideal magnitude of slope compensation required are well documented and can be found for most switching converter topologies. Slope compensation eliminating sub-harmonic oscillations can be seen in [Figure 8C](#page-16-2).



C.) DUTY CYCLE > 0.5 WITH SLOPE COMPENSATION

*Figure 8: Subharmonic oscillations in peak current-mode control with D > 0.5 and how slope compensation can eliminate them[\[14\]](#page-79-13)*

### <span id="page-16-0"></span>**3.10** | **Synchronous Rectification**

The diodes in switching converter designs are often replaced with active switches in practice called active or synchronous rectification. This is done to improve efficiency by reducing the power dissipation of the circuit. The diodes in switching converters are used to allow current flow in one direction, but not the other. These diodes are suitable for the this task, have the drawback of producing a forward voltage drop of around 0.6 V when conducting current. In scenarios in which currents are sufficiently high and the converter requires high efficiencies, the power dissipation created in the diodes becomes non negligible. To reduce the power dissipation of the circuit, the diodes are often replaced with [MOSFETs](#page-73-2) as an active switch. By turning on the [MOSFET](#page-73-2) during the time when the diode would be conducting and turning it off when the diode would be blocking the function of the diode can be replicated. The power dissipation from this practice is often less than the power dissipation from a diode, as the inequality [Equation 1](#page-16-3) holds for most realistic applications. In practice, this drive pattern is simple to implement and can greatly improve the overall efficiency, which explains its the widespread use. All buck-boost converters with integrated switches examined as part of this project employ synchronous rectification.

<span id="page-16-3"></span><span id="page-16-1"></span>
$$
P_{diss, MOSFET} \approx R_{DS,on} * I_L^2 < P_{diss, diode} \approx V_F * I_L \tag{1}
$$



### **3.11** | **Modulation Schemes in Switch-Mode Power Supplies**

There are multiple different modulation schemes in use in switch-mode power supplies, each with a different advantages and disadvantages. The simplest scheme is pulse width modulation, where the amount of energy transferred from the input to the output is modulated with the width of the pulse. Pulse-Width Modulation [\(PWM\)](#page-73-10) schemes switch in a fixed frequency and change the on time depending on how much power is supposed to be transferred. A simple pulse-width modulation can be achieved by comparing to be modulated signal with a sawtooth waveform. Such [PWM](#page-73-10) based control schemes are found in simple converter designs and in more complex converters, when sufficient load is present. These more complex converters often use pulse frequency modulation under light loads. In Pulse-Frequency Modulation [\(PFM\)](#page-73-11) the pulse width is fixed width and instead the frequency or the time in between pulses is varied. Controllers such as the TPS63900 employ completely different modulation schemes.

Converters such as the cascaded buck-boost converter in [9,](#page-17-1) can generally be used in three modes of operation, depending on how the two transistors are driven. It is possible to use the circuit in buck, boost and buck-boost mode. If both switches are modulated on and off it is possible to boost the output voltage as well es buck it. By only driving one of the switches, the circuit turns in to the conventional boost-topology or buck-topology, depending on which switch is is actively driven. The static switch obviously needs be in the correct state for the required mode of operation. Only driving one transistor reduces switching losses, at the cost of only being able to do one type of conversion.

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

*Figure 9: Circuit of two switch cascaded buck-boost converter*

### <span id="page-17-0"></span>**3.12** | **Multi Mode Controllers**

A common sight in modern buck-boost converters are controllers with multiple operating modes. The use of multiple operating modes is done to improve efficiency and improve regulation characteristics in different scenarios. A common occurrence is the use of [PWM](#page-73-10) based operating modes for normal operation and [PFM](#page-73-11) operation for light loads. As it can be challenging to accurately sense currents around 0 A, it is easier to change to [PFM](#page-73-11) and rely entirely on voltage feedback. [PFM](#page-73-11) is also employed due to its higher efficiency, as is requires fewer switching cycles when operating with small loads compared to [PWM.](#page-73-10) Another approach is used in converters with very wide operating ranges. They include up to three different modes, one for pure buck conversions, one for buck-boost



operating mode for when the input and output voltages are similar and one for pure boost conversions[\[15\]](#page-79-14). More common are controller with only a buck converting mode and a buck-boost converting mode as boost operation is seldomly used and the slight efficiency penalty is a worthwhile trade of for the simpler design[\[15\]](#page-79-14). A multi mode controller greatly increases design complexity as it not only requires the implementation of multiple different control schemes, but requires a smooth transitions between them.[\[15\]](#page-79-14) In design with narrow operating ranges, the number of operating modes are often reduced to simplify the design. The Integrated Circuit [\(IC\)](#page-73-12) designer as Texas Instruments recognized this problem and found an interesting solution. [ICs](#page-73-12) such as the TPS63900 use their own modulation scheme, which is more complicated than the modulation schemes presented here, but this scheme allows them to achieve high efficiency over the whole input and output range. In this way, they do not have to implement multiple operating modes and ensure safe transition between them, but were able to created one complex operating for the whole operating range.

### <span id="page-18-0"></span>**3.13** | **Blanking Time**

The process of switching the large switching devices in switching power supplies can cause a lot of noise, especially on nodes with high impedances [\[16\]](#page-79-15). In the case of peak current-mode control, this noise could cause the controller to register the current exceeding the peak prematurely[\[16\]](#page-79-15). Additionally various capacitances on the large switching devices need to charged or discharged, causing large currents flow for short periods after the switching event. It also possible, that the current measurement needs some amount of time to start tracking the current accurately. Do to these reasons it is often beneficial to implement a blanking time in controllers using peak current-mode control. The blanking time is the name given to a brief time, in which the circuit disregards some or all of its inputs. For peak current-mode control a RS latch creates [PWM](#page-73-10) drive signals for the switching devices. The latch is set from a timer in a fixed interval and reset once the current limit is reached. In this case, a blanking time is used in between the time the latch was set and the earliest time it is allowed to be reset. This guarantees a minimum duty-cycle and inhibits premature resetting of the latch. The amount of blanking time needed is implementation dependent, but is typically in the order of tens to hundreds of nano seconds.

### <span id="page-18-1"></span>**3.14** | **Current Sensing**

An essential part of any control approach using current-mode control is the ability to accurately measure current. In switch mode power supplies in particular, it is important to accurately measure the current flowing in the inductor. The list methods presented here are by no means exhaustive, but represent the methods considered for this project. The probably most straight-forward means to measure the current flowing in the inductor, is to add a shunt resistor in series to the inductor and measure the voltage drop over it. While on the surface this method may seems very simple, it brings a lot of hidden technical challenges. First of all, the shunt resistor constantly dissipates power, lowering efficiency. Additionally it is difficult to embed the sense resistor on the chip, due to



difficulties to design it into the layout. It would also require the operational amplifier amplifying the voltage drop to have very high common mode rejection ratio. This is due to the node voltage switching from around  $0 \, \text{V}$  to  $5 \, \text{V}$  and back during each switching cycle. The error introduced would have to be small enough to not negatively effect the current measurement, even when measuring low currents.

The second method considered is the SenseFET technique, which measures the current in the large switching Field-Effect Transistor [\(FET\)](#page-73-13)s by mirroring the current flowing through them. The current in the large transistor mirrored with some large scaling factor into the SenseFET, from where it can be easily be further mirrored or turned into a voltage. For the SenseFET to operate in a mirroring manner, additional circuitry is obviously required. This method is well explored and there are many papers with example implementations available. This technique introduces to no additional external components or power dissipating resistors into the design, which are very desirable characteristics.



*Figure 10: Schematic representation of a SenseFET based current measurement*

Another method is to use the on resistance of the switching device  $R_{DS,on}$  as a shunt resistor. The on resistance of the transistor can be obtained by running simulations and is therefore a known quantity. It is therefore sufficient to amplify the voltage drop over the transistor and measure that, to obtain information on the current flowing through the device. The on resistance is unfortunately temperature dependent and can change over the process corners. While this is not ideal, it is far less complex to implement compared with the SenseFET method. If required, it can implemented in a way, which also allows the measurement of bidirectional current flow. As this method utilizes an intrinsic property of the switch, no additional components and heat dissipating devices are introduced.





*Figure 11: Schematic representation of a R<sub>DS,on</sub> based current measurement* 

### <span id="page-20-0"></span>**3.15** | **Over-Current Protection**

Current limiting or over-current protection is the practice of limiting the current that may be delivered to a load in order to protect the load and the source. In power supplies the is often achieved by measuring the output current or an other value proportional to it and modifying the converters behavior if an overload condition is recognized. Based on the type of controller different, different ways are used to recognize over load conditions. Average current-mode controller generally recognize an overload condition based on the average current in the inductor and peak current-mode controller recognize over current based on the peak current flowing in the inductor. In some high power peak current-mode controllers, an additional average current measurement is used to allow for constant current behavior[\[11\]](#page-79-10).

A current limit can behave in a variety of different ways. The simplest, is to have a hard current limit that can not be exceeded. The source behaves as a constant voltage source until the current rises above the threshold, after which the source switches to a constant current operation, delivering the maximum current allowed. Increasing the load any further only reduces the output voltage, the current stays the same. Even with a complete short circuit on the output, only the set maximum current is allowed to flow.

When the maximum output current is further decreased with increasing load, this called foldback behavior. Reducing the output current with increasing loads allows for a reduction in component stresses during an overload condition compared with the hard current limit. In the extreme case of a short circuit on the output, the current can be limited to small proportion of the current in normal operation.

While the previous two approaches are useable for switching as well as linear supplies, the hiccup current limitation technique is only applicable to switching supplies. In the previous two approaches, current was still supplied to the output during in overload conditions, even though the overload condition is in many cases only present when an error occurred. As such, it makes sense to recognize this as an error condition and stop the power going to the load. During hiccup operation, the converter tries to supply power to the load and if the converter detects an overload condition it stops the switching[\[17\]](#page-80-0). After waiting some time and it tries to start back up. Many specifics are implementation dependent, but often a counter is used to count the number of switching cycles, where an over-current event was detected. After reaching the limit, the switching operation is



halted for some time, before it tries to supply power to the load again[\[17\]](#page-80-0). The limit is often user selectable. If the large load is removed, the converter starts back up in normal operation, otherwise it counts back up to the maximum number of over current events allowed before turning back off, leading to a behavior that resembles hiccups.



*Figure 12: Overload handling behaviors: foldback, constant current, unlimited*

### <span id="page-21-0"></span>**3.16** | **Soft-Start**

A common feature of modern switching controllers is a so called soft-start behavior, which aims to limit inrush currents by slowly ramping up the output current after the converter is turned on. The two main implementations are either time or output voltage based. In time based implementations, the output current is ramped up for a set time interval, after it reaches its nominal value. This approach is more common in high power designs and makes it simple to have user configurable time, which can be set with an external capacitor. The other approach is to dynamically limit the current based on the current output voltage of the converter and can be found in smaller more integrated converter designs. Limiting the output current based on the output voltage can have the additional benefit of creating a foldback current limiting characteristic. This foldback characteristic limits the output current more, the higher the overload condition, as described in [subsection 3.15.](#page-20-0) Both approaches are in widespread use and can found in a plethora of converts on the market.

### <span id="page-21-1"></span>**3.17** | **Hardware Communication Protocol**

To enable the transmission of status information to an external microcontroller or facilitate specific configurations of the DC/DC converter, it was decided to incorporate a communication protocol. The evaluation process aimed to identify the most suitable protocol for the project, considering the following requirements:

- Compatibility with a wide range of microcontrollers available on the market.
- Ease of implementation.

Three interfaces, namely Universal Asynchronous Receiver/Transmitter [\(UART\)](#page-74-1), Inter-



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

| SPI mode | Clock polarity<br>(CPOL/CKP) | Clock phase<br>(CPHA) | Clock edge<br>(CKE/NCPHA) |
|----------|------------------------------|-----------------------|---------------------------|
|          |                              |                       |                           |
|          |                              |                       |                           |
|          |                              |                       |                           |
| 2        |                              |                       |                           |

*Table 6: SPI modes [\[18\]](#page-80-1)*

Integrated Circuit [\(I2C\)](#page-73-14), and Serial Peripheral Interface [\(SPI\)](#page-73-15), fulfilled these requirements. However, after careful consideration, [SPI](#page-73-15) was chosen as the preferred option. It proved to be the easiest to implement while still meeting all necessary criteria. Additionally, [SPI](#page-73-15) offers the following advantages:

- Synchronous
- Addressing is very easy  $\Rightarrow$  read the status of a pin
- Receiving and sending data  $\Rightarrow$  like a shift register

By selecting [SPI,](#page-73-15) the project achieves a reliable and efficient hardware communication protocol that satisfies its requirements.

#### <span id="page-22-0"></span>**3.17.1** | **SPI**

[SPI](#page-73-15) stands for Serial Peripheral Interface. The interface consists of four logic signals:

- SCLK, SCK, CLK or SCL: Serial Clock (output from master)
- MOSI: Master Out Slave In (data output from master)
- MISO: Master In Slave Out (data output from slave)
- CS /SS: Chip/Slave Select (often active low, output from master to indicate that data is being sent)

Furthermore it can be operated in four different modes, which depend on the clock phase and the clock polarity as it can be seen in [Table 6](#page-22-1) and [Figure 14](#page-23-2) [\[18\]](#page-80-1). In this project it was decided to go with [SPI](#page-73-15) mode zero, to which one can find an example sequence in [Figure 13.](#page-22-2)

<span id="page-22-2"></span>

*Figure 13: SPI mode zero overview [\[19\]](#page-80-2)*

<span id="page-23-2"></span>

*Figure 14: SPI modes overview [\[19\]](#page-80-2)*

### <span id="page-23-0"></span>**3.18** | **Auxiliary Blocks**

In addition to the main functionality provided by the DC/DC converter, a comprehensive analysis was conducted to identify the necessary auxiliary blocks required for a fully functional chip. Several essential blocks were identified, including:

- Reference Current: To feed the amplifiers utilized in the DC/DC converter and other blocks with a constant current.
- Reference Voltage: A consistent reference voltage is required to maintain an accurate DC voltage on the output.
- [POR](#page-73-0) Circuit: A [POR](#page-73-0) circuit is vital to ensure the system starts in a well-defined state. It generates the enable signal that initializes the chip upon power-up, guaranteeing a reliable and predictable starting condition.
- Clock Generation: Both the DC/DC converter and the digital part of the chip require a clock/sawtooth.
- Electrostatic Discharge [\(ESD\)](#page-73-16) protection: To protect the circuit from voltage spikes.

<span id="page-23-1"></span>Considering the limited time available for the project, it was decided to thoroughly investigate the implementation options for each of these auxiliary blocks. By examining and addressing the design considerations and methodologies specific to each element, the aim was to integrate them seamlessly into the overall chip design, enabling a functional and efficient system.

OST



#### **3.18.1** | **Bandgap Reference**

In the literature review, an analysis was conducted to determine if a bandgap reference was already available in the design kit provided by  $X$ -Fab. It was discovered that a bandgap reference was indeed available; however, it was designed for the 3.3 V process, while the project required a 5V reference. Despite this discrepancy, it was decided to utilize the bandgap design and architecture from X-Fab as a starting point, with the intention of modifying and replacing the existing 3.3 V components with suitable 5 V parts.

Consequently, no further literature research was conducted specifically on bandgap designs. However, it is important to acknowledge that a thorough understanding of the bandgap concept is necessary in order to successfully adapt the design from 3.3 V to 5 V. Simply replacing the 3.3 V transistors with 5 V transistors is not a sufficient solution.

#### <span id="page-24-0"></span>**3.18.2** | **Reference Current, [POR](#page-73-0) Circuit, Clock generator**

As the Bandgap Reference also those blocks are very often used in an [ASIC.](#page-73-4) Therefore no special literature research was conducted on those components too. Instead it was analyzed what kind of standard circuits are available. Thereby it turned out that it is not possible to adapt a circuit from [X-Fab,](subsec:x-fab) therefore another source was required. For the clock it was decided to go straight forward and to generate it with a sawtooth generator. The [POR](#page-73-0) and reference current circuits were adapted from designs provided by Lars Kamm.

#### <span id="page-24-1"></span>**3.18.3** | **ESD protection**

In this project [ESD](#page-73-16) requirements were not specified, as we do not have the required infrastructure to test [ESD](#page-73-16) susceptibility adequately. Nevertheless [ESD](#page-73-16) an important topic and [ESD](#page-73-16) protection should be investigated when possible. Therefore a special literature research was done on this topic.

Since large P-type Metal-Oxide Semiconductor [\(PMOS\)](#page-73-17) transistor were used inside the DC/DC converter of the charger some [ESD](#page-73-16) functions could possibly be implemented in those switches of the charger. To clarify the possibility the topics latchup and snap back were investigated [\[20\]](#page-80-3).

#### <span id="page-24-2"></span>**3.18.3.1** | **Snapback**

The Snapback effect is related to the Bipolar Junction Transistor [\(BJT\)](#page-73-18) and is a mechanism where an avalanche breakdown or impact ionization provides a base current to turn on the transistor. When one speaks from Snapback it is mostly an effect that is wanted, for example for [ESD](#page-73-16) protection. Instead of the Snapback effect one could use a [ESD](#page-73-16) protection device with a turn on characteristic, like a Zener diode. A comparison between the two protection methods can be found in [Figure 15.](#page-25-1) Where one finds on the left the I-V characteristic of an turn on [ESD](#page-73-16) protection and on the right the I-V characteristic of an [ESD](#page-73-16) protection based on the Snapback effect [\[21\]](#page-80-4).



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

**Figure 3.2.1** Typical turn-on and snap-back characteristics of ESD protection structures *Figure 15: Typical turn-on and snap-back characteristics of ESD protection structures ([\[20\]](#page-80-3) p.22)*

**Functional Description of the Snapback effect** A high voltage occurs at the I/O pad in [Figure 17.](#page-26-2) This voltage is higher than the reverse breakdown voltage of the diode that is formed between the substrate/bulk and the drain. Since the p-well has some resistance the base of the NPN [BJT](#page-73-18) has a higher voltage than the emitter  $\Rightarrow$  the NPN BJT starts to conduct and therefore reduces the resistance from the drain/emitter to the source/collector.  $\Rightarrow$  The voltage on the I/O pad drops from  $I_{t1}$  to  $I_H$  even if the current on the pad increases. After that one is in the snap-back region and the current can be increased until the second breakdown voltage where the transistor gets finally destroyed.

<span id="page-25-2"></span>

*Figure 16: Cross section of a [BJT](#page-73-18) ([\[22\]](#page-80-5))*

[Figure 16](#page-25-2) shows an overview of the [BJT](#page-73-18) transistor, which is the parasitic transistor which exists in the N-Type Metal-Oxide Semiconductor [\(NMOS\)](#page-73-19) and should help to imagine the snapback effect.

[Figure 17](#page-26-2) shows on the left an [NMOS](#page-73-19) transistor with its parasitic [BJT](#page-73-18) transistor and on the right the I-V characteristic of it.

#### <span id="page-25-0"></span>**3.18.4** | **Latchup**

Latchup is a phenomena that occurs in the [CMOS](#page-73-8) technology and is mostly unwanted. It can happen due to various reason, whereby the most common is injecting a current into its gate (G1 or G2 from [Figure 18\)](#page-26-3).



<span id="page-26-2"></span>

*Figure 17: Cross section of a Gate-Ground-NMOS [\(GgNMOS\)](#page-73-20) and I-V characteristic ([\[20\]](#page-80-3) p.28)* MN Q1

In [Figure 18](#page-26-3) one can see the the [NMOS](#page-73-19) on the left side and the [PMOS](#page-73-17) in the n-well on the right side. Furthermore one sees the parasitic pnp [BJT](#page-73-18) on the left and the npn BJT on the right side. From [Figure 18](#page-26-3) one can then extract [Figure 19.](#page-27-0) Whereby R1 is the resistance of the substrate and R2 the resistance of the n-well. [Figure 19](#page-27-0) also shows that a [CMOS](#page-73-8) forms a Silicon Controlled Rectifier [\(SCR\)](#page-73-21) [\[20\]](#page-80-3) [\[23\]](#page-80-6). potruit and reverse residence of the H went T gave T and drows that

<span id="page-26-3"></span>A good video with an explanation can be found under the following  $\text{link}^2$  $\text{link}^2$  $\text{link}^2$  $\text{link}^2$ .



**Figure 8.1.3** Cross section of a CMOS output buffer and parasitic components. *Figure 18: Cross section of a [CMOS](#page-73-8) output bu*ff*er and parasitic components ([\[20\]](#page-80-3) p.60)*

#### <span id="page-26-0"></span>**3.18.5** | **Thyristor**

A thyristor is also called [SCR](#page-73-21) and acts as a bistable switch/latch, conducting when the gate receives a current trigger, and continuing to conduct until the voltage across the device is reversed biased, or until the voltage is removed [\[24\]](#page-80-7).

#### <span id="page-26-1"></span>**3.18.6** | **Latchup Snapback**

degradation of the NMOS.

of G1.

The literature study has show that it is very common to implement a snapback [ESD](#page-73-16) protection with a [GgNMOS](#page-73-20) on all output pins. Furthermore the large transistors which were used in the design could be modified according to the recommendations given in ([\[20\]](#page-80-3) p.28 bottom) to have the snapback already implemented.

https://youtu.be/EYHFLBI5fjg



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

**Figure 8.1.1**  *Figure 19:* Bipolar model of a SCR circuit and I-V characteristic *Bipolar model of a [SCR](#page-73-21) circuit and I-V characteristic ([\[20\]](#page-80-3) p.69)*



# <span id="page-28-0"></span>**4** | **Implementation**

In this chapter we will focus on actual implementation of many of the concepts discussed in the previous chapter. The goal is to describe the inner workings of the chip on a conceptual level as well as in a second step the workings of the individual sub-circuits. In a first subchapter we will explore how the control loop was design from a high level perspective. Especially the high-level workings of the controller, some of the problems we encountered and how we over came them. In the second part we will have a detailed look into the underlying sub-circuits that make up the chip and will have a detailed look into design decisions at a single transistor level.

### <span id="page-28-1"></span>**4.1** | **High-Level Regulator Design**

In this subchapter we will give a look in to the design of the control loop on a high level, without getting caught up with the details of the analog circuits. We will try to explain the reasons behind our design decisions, why we changed the controller topology late in the design process and how the converter works. All sub circuits can generally be considered ideal in this subsection with occasional references to the ruff underlying implementation considerations where needed.

#### <span id="page-28-2"></span>**4.1.1** | **Converter Overview**

The converter we ended up building is a cascaded buck-boost converter based design. As most other highly integrated buck-boost converters use the converter topology, we felt strongly, that this is the right approach. For the structure of the control loop itself, we opted to use peak current-mode control, but only after first implementing average current-mode control and running into problems. We have also implemented synchronous rectification and are using the *RDS*,*on* of our power [MOSFETs](#page-73-2) to measure the current flowing the inductor. To ensure stable operation regardless of the duty-cycle, we implemented a slope compensation circuit. The voltage feedback of the converter is done internally with high impedance resistive voltage dividers. The feedback node is also connected to an external pin, which allows with trimming of the output voltage or to completely overwrite the internal divider with a lower impedance external one. This also allows for external compensation of the feedback loop if required. The regulator uses peak current-mode control is implemented using a low *g<sup>m</sup>* Operational Transconductance Amplifier [\(OTA\)](#page-73-22) with an internal type-II compensation network. The goal is to have bandwidth of 30 kHz while maintaining a phase margin of 60°. For external components we only need a 10  $\upmu$ F input capacitor *C<sup>i</sup>* , a 20 µF output capacitor *C<sup>o</sup>* and a 47 µH external inductor.

#### <span id="page-28-3"></span>**4.1.2** | **Loop Compensation for Average Current-Mode Control**

As we first built the a controller on the average current approach, we designed loop compensation based on the modelling provided by [\[10\]](#page-79-9). Based on the modelling provided in the book, we created MATLAB script, which allowed us to quickly model the loop behavior based on various variables like output capacitance, loop bandwidth and switching frequency. The script can found in [section 11.](#page-81-0)The script creates a transfer function for every component in the loop and calculates its bode plots. The script takes as an input the





*Figure 20: Functional block diagram of the buck-boost converter*

desired bandwidth and phases of the control loops and calculate the required type-II compensation network. This allowed us to quickly determine which variable constellations lead to a compensation network that is implementable on an [IC.](#page-73-12) We achieved satisfactory results with a 200 kHz RC low-pass filter for the current averaging, 30 kHz current loop bandwidth and 10 kHz voltage loop bandwidth. This was done at a switching frequency of 500 kHz with a 47 µH inductor.

#### <span id="page-29-0"></span>**4.1.3** | **Issue with Average Current-Mode Control**

When we switched out our ideal current measurement for the SenseFET based implementation at transistor level, the regulation behavior became discontinuous for small loads. The problem caused by the inability for the circuit to sense negative currents. With small loads the regulator would normally be operating in Discontinous Conduction Mode [\(DCM\)](#page-73-23). As we are using synchronous rectification instead of conventional diodes, we are not operating in [DCM](#page-73-23) but always in Continous Conduction Mode [\(CCM\)](#page-73-24)



as we do not explicitly prevent reverse current flow. In [CCM](#page-73-24) the current in the inductor has a triangular shape oscillating from some minimum to some maximum around the average DC current value. When small loads are applied, the average current is close to 0 A, leading to 50 % of the current to be positive with the other 50 % to be negative. The problem becomes exacerbated as soon as the inductor current starts oscillating, as control loop has no feedback in the time the inductor current is negative. The voltage loop increases the required current continually and the current loop follows, but it only is able to measure the real current flowing in the inductor when it becomes significantly positive, thus leading to an overshoot. This behavior can be seen in [Figure 21,](#page-30-2) the legend is as follows: output voltage, inductor current, output of the outer control loop, measured output current.

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

*Figure 21: Oscillating behavior of the average current-mode controller after starting up with a small load*

#### <span id="page-30-0"></span>**4.1.4** | **Loop Compensation for Peak Current-Mode Control**

<span id="page-30-1"></span>The implementation of the regulator peak current-mode control was conducted similar to the one already done with average current-mode control. As basis we took the calculations and modelling from [\[12\]](#page-79-11). The script can found in [section 11.](#page-81-0) We once again created MATLAB script to do all the calculations an plotting. After running some simulations based on the values from the script, we noticed a large current ripple in the inductor of about 100 mA. Instead of further increasing the inductors size, we would increase the switching frequency to 1 MHz. We settled on the value of a 30 kHz bandwidth and 60° phase margin as it leads to good regulation characteristics, while requiring a compensation network that is manufacturable on a chip.



#### **4.1.5** | **Protection Features**

Lastly we implemented various protection features. The first of which is the inductor current limit. The inductor current has hard limit implemented of around 600 mA. This limit is dependent on the current duty-cycle, as the slope compensation interferes with it. Additionally we implemented another inductor current limit, which is dependent on the output voltage. The current limit is lower then the other limit at output voltages lower then 1.2 V. This current limit is proportional to the output voltage and limits to inductor current to less then 300 mA if the output is shorted to GND. The entire current limiting circuit behaves therefore as a constant current source under light overload conditions, but has foldback behavior if the load is significantly to high.

As we are potentially generating a lot of heat in the power transistors, we implemented an over-temperature protection circuit. This circuit should be placed close to the switching transistors and disables the converter if the temperature fo the chip exceeds a threshold. This thermal shutdown circuit also has hysteresis to prevent the converter from quickly turning on and off again if it reaches the temperature threshold.

### <span id="page-31-0"></span>**4.2** | **Implementation of Transistor-Level Circuits**

Upon completion of the literature research, a comprehensive understanding of the required components and their functionalities was gained. Utilizing a top-down approach, the design of the [ASIC](#page-73-4) commenced, wherein the different functionalities were divided into distinct blocks, as depicted in [Figure 22.](#page-31-2) Initially, these blocks were implemented at a high abstraction level, and subsequently, in greater detail at the semiconductor level. This subsection provides an overview and description of each individual block, shedding light on their specific roles and characteristics.

<span id="page-31-2"></span>

*Figure 22: Our implementation of cascaded Buck Boost converter with active switches instead of diodes*

#### <span id="page-31-1"></span>**4.2.1** | **Simulations**

For all the blocks mentioned in this subsection corner and Monte Carlo simulations were executed with the parameters mentioned below, when not otherwise mentioned. Thereby



the shortcuts have the following meaning (further explanation can be found in [Table 7](#page-32-4) and ([\[25\]](#page-80-8) p.7)):



<span id="page-32-4"></span>

| <b>Model Class</b>         | Parameter   | wp   | <b>WS</b> | <b>WO</b> | <b>WZ</b> |
|----------------------------|-------------|------|-----------|-----------|-----------|
| <b>MOS</b>                 | <b>NMOS</b> | fast | slow      | fast      | slow      |
|                            | <b>PMOS</b> | fast | slow      | slow      | fast      |
| <b>Bipolar Transistors</b> | speed       | high | low       |           |           |
|                            | beta        | high | low       |           |           |
| Capacitors                 | capacitance | low  | high      |           |           |
| Varactors                  | capacitance | low  | high      |           |           |

*Table 7: parameter mix in predefined X-FAB corners [\[25\]](#page-80-8)*

#### <span id="page-32-0"></span>**4.2.1.1** | **Corner Simulations**

param.scs= 3s xh035.scs=wo wz ws wp Vdd=4.3 5 5.5 Temperature=0 70

#### <span id="page-32-1"></span>**4.2.1.2** | **Monte Carlo Simulation**

param.scs= 3s xh035.scs=mc\_g

#### <span id="page-32-2"></span>**4.2.2** | **Input**

The input block includes a [POR](#page-73-0) circuit which makes sure that the circuit turns only on when the input voltage reaches a certain level, a current reference which provides an input voltage and more or less temperature independent current source, a bandgap reference which provides a input voltage and temperature independent voltage reference and an oscillator which provides a clock for the [FSM.](#page-73-1)

#### <span id="page-32-3"></span>**4.2.2.1** | **Current Source**

Having a power supply (input voltage) independent current source is one of the key functionality for this project. Due to the fact that current sources are needed for multiple amplifier circuits which are included in function blocks such as the bandgap reference. Since this problem was solved already multiple times before it was decided to go with a pre-existing solution/schematic as already mentioned in [section 3.](#page-9-0) Lars Kamm therefore provided us with such a circuit, which was afterwards slightly adapted and will be discussed in this section.



**Circuit** At first glance comprehending a circuit like the one depicted in [Figure 28](#page-37-0) may present some difficulties. Therefore, the following section provides a step-by-step description of the circuit.

<span id="page-33-0"></span>
$$
I_D = \frac{\mu_n C_{ox}}{2} \frac{W}{L} (V_{GS} - V_T)^2 \underbrace{(1 + \lambda V_{DS})}_{\text{Can be neglected for simplicity}}
$$
 (2)

<span id="page-33-2"></span>
$$
\Delta V_{GS} = V_{GS} - V_T \tag{3}
$$

<span id="page-33-3"></span>
$$
\Delta V_{GS} = \sqrt{\frac{I_0}{\frac{\mu \cdot C_{ox}}{2}} \frac{W}{L}}
$$
 (4)

<span id="page-33-1"></span>The concept behind the current reference circuit is to leverage the threshold voltage  $(V_T)$ of the [MOSFET,](#page-73-2) as this parameter remains unaffected by the supply voltage, as indicated in [Equation 2,](#page-33-0) which shows the current through a [MOSFET](#page-73-2) in saturation region. To fully comprehend the circuit in [Figure 26,](#page-35-0) it is essential to grasp basic circuits such as the one shown in [Figure 23.](#page-33-1) In this particular circuit, the voltage at the gate of  $M_0$  is zero, resulting in the absence of a voltage  $V_T$  anywhere. In order to establish the desired voltage  $V_T$ across the transistor, a certain current  $i_D$  must flow. Achieving this can be accomplished by introducing a current mirror into the circuit. When doing that one ends up with [Figure 24.](#page-34-0)



*Figure 23: Current reference intro*

In [Figure 24](#page-34-0) one has on the gate of  $M_0$  the voltage  $\Delta V_{GS} + V_T$  whereby  $\Delta V_{GS} = V_{GS} - V_T$ as indicated in [Equation 3.](#page-33-2) When one now increases the ratio of  $\frac{W}{L} \Delta V_{GS}$  decreases as one can see from [Equation 4,](#page-33-3) which says:  $\Delta V_{GS} = \sqrt{\frac{I_0}{\frac{\mu C_{CX}}{2} \frac{W}{L}}}$ . Therefore when the ratio  $\frac{W}{L}$  goes to infinity one would have a stable current through *R* and a stable voltage on the gate of  $M_0$ , when one does not consider that  $V_T$  is dependent on the temperature and the process. But the issue with the circuit in [Figure 24](#page-34-0) is that one has a positive feedback loop, which means when the gate voltage on  $M_0$  increases the current on  $M_1$  and  $M_2$  increases too, which increases the gate voltage of  $M_0$  even more ( $\Rightarrow$  Circuit is unstable). To prevent that one would need to insert an additional [MOSFET](#page-73-2) below *M*2. But as one can see from this circuit one is still dependent on  $V_{GS}$  when the ratio of  $\frac{W}{L}$  is not infinity. Let's therefore see if it gets better when one makes sure that the voltage is the same on the gate and the drain of *M*0. One achieves this with the circuit in [Figure 25.](#page-34-1) The gate voltage of *M*<sup>0</sup> is



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

*Figure 24: Current reference example one*

<span id="page-34-1"></span> $\Delta V_{GS} + V_T$  and on  $M_3$  and  $M_4$  2  $\Delta V_{GS}$  + 2  $\cdot$   $V_T$ . Therefore the voltage over R is  $\Delta V_{GS} + V_T$ . But when one decreases the ratio of  $\frac{W}{L}$  of  $M_4$  by a factor of 4 the voltage over R reduces to *V<sup>T</sup>* which means one gets rid of ∆*VGS* and should therefore be completely independent of *VDD* [\[26\]](#page-80-9). When one tries to control the temperature dependency too one could add



*Figure 25: Current reference example two*

an additional [NMOS](#page-73-19) ( $M_5$ ) above R with a  $\frac{W}{L}$  x times larger than the one from  $M_0$ , as it can be seen in [Figure 26.](#page-35-0) Since one knows that the voltage and the current on the source of *M*<sup>3</sup> and *M*<sup>4</sup> is the same one can write the following equations:

<span id="page-34-2"></span>
$$
I_R = \frac{U_R}{R}
$$
  

$$
\sqrt{\frac{I_{S_{M_0}}}{\frac{\mu \cdot C_{ox} W}{2} (1 + \lambda V_{DS})}} + V_T = \sqrt{\frac{I_{S_{M_5}}}{\frac{\mu \cdot C_{ox} W}{2} (1 + \lambda V_{DS}) \cdot x}} + V_T + U_r
$$
  
(5)

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



*Figure 26: Current reference*



$$
\beta_0 = \mu_n C_{ox} \tag{6}
$$

$$
\beta = \frac{W}{L} \cdot \beta_0 \tag{7}
$$

- *x*: factor  $\frac{W}{L}$  of  $M_5$  is larger than  $M_0$ • *U<sub>R</sub>*: Voltage over resistor  $\bullet$   $\beta$ : Transconductance Parameter • *W*: Width of the [MOSFET](#page-73-2)
- *L*: Length of the [MOSFET](#page-73-2)
- $\mu_n$ : Mobility of an electron  $\propto \frac{1}{T}$
- $C_{ox}$ : Capacitance per unit area of the oxide =  $\frac{t_{ox}}{\epsilon_{ox}}$  $\epsilon_{os}$

The result of [Equation 5](#page-34-2) is then (when one neglects the trivial solution where  $I_{S_{M_0}}=I_{S_{M_5}}=$ 0 and the channel length modulation):

$$
I_{S_{M_0}} = I_{S_{M_5}} = \frac{2 \cdot (x \pm 2\sqrt{x} + 1)}{\beta_0 \cdot \frac{W}{L} \cdot R^2 \cdot x} :
$$

$$
U_R = \frac{2 \cdot (x \pm 2\sqrt{x} + 1)}{\beta_0 \cdot \frac{W}{L} \cdot R \cdot x} :
$$

One solution from the equations above is an extraneous solutions. The solutions that are really correct are:  $I_{S_{M_0}} = I_{S_{M_5}} = \frac{2 \cdot (x - 2\sqrt{x} + 1)}{\beta_0 \cdot \frac{W}{t} \cdot R^2 \cdot x}$  $\frac{(x-2\sqrt{x}+1)}{\beta_0 \cdot \frac{W}{L} \cdot R^2 \cdot x}$  and  $U_R = \frac{2 \cdot (x-2\sqrt{x}+1)}{\beta_0 \cdot \frac{W}{L} \cdot R \cdot x}$  $\frac{w}{\beta_0} \frac{w}{L} R x$ . As one can see from those equations the current is depending on the factor of x and R one can therefore set it with setting x and R respectively. Furthermore it is worth to mention that R has a positive temperature coefficient and *VGS* a negative one. Therefore when the temperature increases the resistance  $R$  gets higher while  $V_{GS}$  gets lower. Due to that one could chose  $R$  and  $x$  in such a way that the circuit is more or less temperature independent. Due to the fact the amplifiers in the other circuits are also temperature


dependent one chooses the ratio in such a way the the amplifiers are in the end not temperature dependent. But since this goes really deep into semiconductor physics no formulas for the temperature dependency of this circuits were derived. Nevertheless the simulation results were verified with the temperature independent equations which have shown that the calculations and simulations are quite similar.

When inserting the values of the circuit one gets the following result:

$$
I_{S_{M_0}} = I_{S_{M_5}} = \frac{2 \cdot (16 - 2\sqrt{16} + 1)}{103 \times 10^{-6} \text{ A V}^{-2} \cdot 16 \cdot 22.5 \times 10^{-3} \Omega^2 \cdot 16} = 2.697 \times 10^{-6} \text{ A}
$$

$$
U_R = \frac{2 \cdot (16 - 2\sqrt{16} + 1)}{103 \times 10^{-6} \text{ A V}^{-2} \cdot 16 \cdot 22.5 \times 10^{-3} \Omega \cdot 16} = 168.554 \text{ mV}
$$

with:



*x* 16

This similar to the simulation (simulation $3:4.9\,\mu\text{A}$  $3:4.9\,\mu\text{A}$ , calculation: 2.7  $\mu\text{A}$ ).



*Figure 27: Monte Carlo distribution of Current reference. X-axis shows current through "IPRB0" in [Figure 29](#page-37-0) (param.scs*=*3s, xh035.scs*=*mcg)*

The implemented design on the chip can be seen in [Figure 28.](#page-37-1) For simplicity one can neglect in a first step M89, M10, M13, M19 and M21. When doing that one sees in [Figure 28](#page-37-1) the same circuit as in [Figure 26](#page-35-0) with some additions (M51 and M52 are not needed they were introduced in the layout for a common centroid design). This additions are needed since one has two operating points as one saw before. To be in the right operating point a so called start up circuit is needed which will be explained in more detail. On the left of [Figure 28](#page-37-1) one finds the enable signal EN and its inverted signal ENN. In turned

 $3$  Simulation result can be found in [Figure 74](#page-81-0) in the appendix



off state M15 is conducting an therefore M14 discharged, furthermore VB4 is pulled to VDDA which forces the bootstrap to be in state zero (state where no current is flowing). When the circuit is turned on M8, M9 and M11 are conducting, since their gate voltage is zero which leads to the fact that the node voltage of N2 is pulled to VDDA. Furthermore VB4 is not any more pulled to VDDA. The voltage in N2 causes a current in the current reference which is mirrored to M5, which charges the capacitor M14 and finally stops N2 to be pulled to VDDA. The current reference is now in its operating state where current is flowing. This current can then be further mirrored to other components with VB4, VB3, VB2 and VB1. [Figure 29](#page-37-0) shows the testbench used to test the current reference circuit.

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

*Figure 28: Current reference Implemented*

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

*Figure 29: Current reference test bench*

[Figure 30](#page-38-0) shows the current in dependency of the supply voltage. [Figure 31](#page-38-1) shows the transresistance of the input voltage to the output current. It is visible from this plot that the current reference should be operated with a voltage greater than 3.3V to have a input voltage independent current.

[Figure 32](#page-39-0) shows the output resistance of the current reference  $(V_4$  in [Figure 29\)](#page-37-0) divided by the current that goes into the source of *V*<sup>4</sup> at different voltages. This allows to estimate



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

<span id="page-38-1"></span>*Figure 31: Current reference trans resistance* <sup>∆</sup>*Vin* ∆*Iout*

how many diode voltage one is allowed to use to mirror the reference current. It shows that the voltage of the diode must be at least 0.8V below the supply voltage. The summarized specification of the block can be found in [Table 8.](#page-38-2)

<span id="page-38-2"></span>

| Description                                                       | Min | Max  | Unit    |
|-------------------------------------------------------------------|-----|------|---------|
| Reference current                                                 | 8.4 | 13.5 | μA      |
| Current<br>consump-                                               | 50  | 81   | $\mu A$ |
| tion                                                              |     |      |         |
| Min voltage (volt- $ $ 3                                          |     | 3.33 | V       |
| age where the trans                                               |     |      |         |
| resistance $\left(\frac{\Delta V_{in}}{\Delta I_{out}}\right)$ is |     |      |         |
| higher than $1 \text{M}\Omega$ )                                  |     |      |         |

*Table 8: Current reference characteristics*



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

*Figure 32: Current reference output resistance* <sup>∆</sup>*Vout* ∆*Iout*



#### **4.2.2.2** | **Bandgap**

For the [Bandgap reference](https://youtu.be/ncZzxvG4XOM) a given implementation of a 3.3 V circuit from X-Fab was taken and adapted for the 5 V technology as mentioned in [section 2.](#page-8-0) The final design can be seen in [Figure 33.](#page-40-0)

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

*Figure 33: Bandgap schematic*

For the test the schematic in [Figure 34](#page-40-1) was used, where EN is set to 5 V and ENN to 0 V furthermore VDDA was sweept from 0 V to 5.5 V

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

*Figure 34: Bandgap testbench*

[Figure 35](#page-41-0) shows that the bandgap voltage is quite stable over the corners, but slight variations can be seen in [Figure 36](#page-41-1) the Monte Carlo simulation. But since the exact output voltage of the DC/DC converter can be exactly set by a external resistor the variance over the temperature and supply voltage plays a major role. Which is very low as can be seen in [Figure 35](#page-41-0) and [Figure 37.](#page-42-0)

[Figure 37](#page-42-0) shows the dependency of the bandgap voltage vs the temperature.

<span id="page-40-2"></span>[Table 9](#page-40-2) Show the characteristics of the bandgap design used in this project.



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



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

*Figure 36: Bandgap voltage Monte Carlo simulation (param.scs*=*3s, xh035.scs*=*mcg)*



*Table 9: Bandgap characteristic*



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

*Figure 37: Bandgap voltage vs temperature*



#### **4.2.2.3** | **Oscillator**

For the digital part of the circuit there is a clock required to process the data received over the [SPI.](#page-73-0)  $^4$  $^4$  Since the [SPI](#page-73-0) standard does not define a certain clock speed the frequency generated in the [ASIC](#page-73-1) plays a minor role. Due to that it was decided to generate the clock with a sawtooth generator (a capacitor gets charged with a certain current and as soon as it reaches a threshold it gets discharged) due to the fact that this approach is very easy to implement and fully compatible with the [CMOS](#page-73-2) process used.

Since also the DC/DC converter uses a sawtooth generator with some additions (slope compensation) it was not yet decided which design is used in the final [ASIC.](#page-73-1) What is already sure is that one wants to use in both designs the same topology since then only the capacitor size has to be changed and one can use the same layout. Due to that no concrete layout is mentioned here, but when one would use a very simple sawtooth generator one would reach the specs which are listed in [Table 10.](#page-43-0) To compensate the large variation in frequency it is planned to make the capacitor which determines the frequency configurable over the SPI interface with three switches, which means one can configure 8 different frequencies/capacitance values. The most important values can be read from [Table 10.](#page-43-0)

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

*Table 10: Specification*

<sup>4</sup> It was decided to generate an internal clock although it would have been possible to build a finite state machine which uses the [SPI](#page-73-0) signal only to read and write the registers.



#### **4.2.2.4** | **[POR](#page-73-3)**

For the [POR](#page-73-3) circuit an example was provided by Lars Kamm and afterwards adapted, so that it has the right power on voltage and delay time. The final design can be seen in [Figure 38.](#page-44-0)

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

*Figure 38: POR schematic*

The test bench with which the design was tested is visible in [Figure 39.](#page-44-1) In [Figure 41](#page-45-0) the

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

*Figure 39: POR testbench schematic*

test sequence for the delay measurement is visible. In pink one sees the supply voltage and in red the PORB signal. Which is on high when the circuit should work. [Figure 41](#page-45-0) show the test output of the test-bench. It's output is summarized in [Table 11.](#page-44-2)

<span id="page-44-2"></span>

| Description         | Min   | Max | Unit    |
|---------------------|-------|-----|---------|
| input delay         | 26    | 44  | $\mu$ s |
| output delay        | 4.4   | 6.8 | $\mu$ s |
| Current<br>consump- | 13    | 31  | μA      |
| tion                |       |     |         |
| Min voltage         | 3.176 | 3.7 |         |

*Table 11: POR characteristic*





*Figure 40: POR transient simulation*

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

| maestro<br>$-26$ | <b>E</b> POR th                               | <b>20 10 (POR)</b> |                       |                    |                          |                          |                |                       |                       |                |                |                 |                |                 |
|------------------|-----------------------------------------------|--------------------|-----------------------|--------------------|--------------------------|--------------------------|----------------|-----------------------|-----------------------|----------------|----------------|-----------------|----------------|-----------------|
| Outputs Setup    | Results                                       |                    |                       |                    |                          |                          |                |                       |                       |                |                |                 |                |                 |
| Detail           | $\blacksquare$ $\odot$ $\odot$ $\blacksquare$ |                    |                       |                    | 學學 M-                    |                          |                |                       |                       |                |                |                 |                |                 |
|                  | Parameter                                     | Nominal            |                       |                    |                          |                          | TO_O           | TO 1                  | TO <sub>2</sub>       | TO 3           | T0 4           | TO <sub>S</sub> | TO 6           | TO 7            |
|                  | bip.scs                                       | tm                 |                       |                    |                          |                          | tm             | tm                    | tm                    | tm             | tm             | tm              | tm             | tm              |
|                  | bsim3v3.scs                                   | tm                 |                       |                    |                          |                          | tm             | tm                    | tm                    | tm             | tm             | tm              | tm             | tm              |
|                  | cap.scs                                       | tm                 |                       |                    |                          |                          | tm             | tm                    | tm                    | tm             | tm             | tm              | tm             | tm              |
|                  | dio.scs                                       | tm                 |                       |                    |                          |                          | tm             | tm                    | tm                    | tm             | tm             | tm              | tm             | tm              |
|                  | ind.scs                                       | tm                 |                       |                    |                          |                          | tm             | tm                    | tm                    | tm             | tm             | tm              | tm             | tm              |
|                  | param.scs                                     | 3s                 |                       |                    |                          |                          | 3s             | 3s                    | 3s                    | 3s             | 3s             | 3s              | 3s             | 3s              |
|                  | res.scs                                       | tm                 |                       |                    |                          |                          | tm             | tm                    | tm                    | tm             | tm             | tm              | tm             | tm              |
|                  | temperature                                   | 27                 |                       |                    |                          |                          | $\circ$        | 70                    | $\circ$               | 70             | $\circ$        | 70              | $\Omega$       | 70              |
|                  | xh035.scs                                     | mc_g               |                       |                    |                          |                          | wo             | WO                    | WZ                    | wz             | <b>WS</b>      | ws              | wp             | wp              |
| 26/37 rows       |                                               |                    |                       |                    |                          |                          |                |                       |                       |                |                |                 |                |                 |
| Test             | Output                                        | Nominal            | <b>Spec</b>           | Pass/Fail<br>Veigh | Min                      | Max                      | <b>TO 0</b>    | TO 1                  | TO 2                  | TO 3           | T0 4           | TO <sub>5</sub> | TO 6           | TO 7            |
| ilter            | ×<br>Filter                                   | It m               | $\blacksquare$ Filter | FilterFilter       | $\blacksquare$ Filter    | $\blacksquare$ Filter    | Filter         | $\blacksquare$ Filter | $\blacksquare$ Filter | Filter         | $F$ Filter     | Filter          |                | E<br>ы<br>ilter |
| Lib1_POR_tb_1    | VS("/POR")                                    | Ł                  |                       |                    |                          |                          | Ł              | Ł                     | Ł                     | Ł              | Ł              | Ł               | ピ              | Ł               |
| Lib1_POR_tb_1    | VS("/PORB")                                   | Ł                  |                       |                    |                          |                          | Ł              | Ŀ                     | Ł                     | Ł              | Ł              | Ł               | Ł              | Ŀ               |
| Lib1_POR_tb_1    | VS("/10/net6")                                | Ŀ                  |                       |                    |                          |                          | E              | Ŀ                     | Ł                     | Ł              | Ŀ              | Ł               | Ł              | Ł               |
| Lib1_POR_tb_1    | IS("/I0/VDDA")                                | E                  |                       |                    |                          |                          | E              | И                     | R                     | E              | E              | Þ.              | $\overline{V}$ | E               |
| Lib1_POR_tb_1    | POR                                           | 3.453              | range 3.15 3.9        | pass               | 3.174                    | 3.653                    | 3,453          | 3.184                 | 3.653                 | 3.384          | 3,633          | 3.374           | 3.443          | 3.174           |
| Lib1_POR_tb_1    | PORB                                          | 3.457              | range 3.15 3.9        | pass               | 3.176                    | 3.657                    | 3.457          | 3.186                 | 3.657                 | 3.386          | 3.637          | 3.376           | 3.447          | 3.176           |
| Lib1_POR_tb_1    | Max current con                               | 14.15u             | $<$ 40 $u$            | pass               | 13.42u                   | 30.87u                   | 17.98u         | 16.83u                | 30.87u                | 22u            | 23.92u         | 13.42u          | 27.45u         | 16.43u          |
| Lib1_POR_tb_1    | POR tran                                      | Ł                  |                       |                    |                          |                          | Ł              | Ł                     | M                     | Ł              | Ł              | Ł               | Ł              | Ł               |
| Lib1 POR tb 1    | POR delay out                                 | 5.54u              | range 4u 7u           | pass               | 4.422u                   | 6.796u                   | 4.78u          | 6.796u                | 5.112u                | 6.64u          | 5.382u         | 6.479u          | 4.422u         | 6.561u          |
| Lib1_POR_tb_1    | PORB tran                                     | Ł                  |                       |                    |                          |                          |                | Ŀ                     | Ŀ                     | Ł              | Ŀ              | tz.             | Ł              | Ŀ               |
| Lib1_POR_tb_1    | copy2                                         | Ł                  |                       |                    |                          |                          | Ł              | Ŀ                     | Ł                     | Ł              | Ŀ              | Ł               | Ł              | Ł               |
| Lib1_POR_tb_1    | Current_tran                                  | E                  |                       |                    |                          |                          | E              | E                     | E                     | E              | Ŀ              | E               | E              | E               |
| Lib1_POR_tb_1    | PORB delay                                    | 59.65n             | $< 1e-3$              | pass               | 49.81n                   | 83.06n                   | 63.82n         | 72.57n                | 61.63n                | 83.06n         | 64.43n         | 67.63n          | 49.81n         | 65.69n          |
| Lib1_POR_tb_1    | peak current co                               | 360.3u             | < 1m                  | pass               | <b>296u</b>              | 439.4u                   | 407.1u         | 332.2u                | 374.2u                | 336.7u         | 346.6u         | 296u            | 439.4u         | 368.4u          |
| Lib1_POR_tb_1    | POR delay                                     | 5                  | >4.9                  | pass               | $\overline{\phantom{a}}$ | $\overline{\phantom{a}}$ | 5 <sup>1</sup> | 5 <sup>1</sup>        | $\overline{5}$        | $\overline{5}$ | 5 <sub>1</sub> | 5               | 5 <sup>1</sup> | 5               |
| Lib1 POR tb 1    | IT("/I0/M1/D")                                | Ł                  |                       |                    |                          |                          |                | Ł                     | Ł                     | Ł              | Ł              | Ł               | Ł              | Ŀ               |
| Lib1_POR_tb_1    | IT("/I0/M3/D")                                | E                  |                       |                    |                          |                          | Ł              | Ŀ                     | E                     | Ł              | Ŀ              | Ŀ               | Ł              | Ŀ               |
| Lib1_POR_tb_1    | IT("/I0/M6/D")                                | Ł                  |                       |                    |                          |                          | Ł              | Ŀ                     | Ł                     | Ł              | Ŀ              | Ŀ               | Ł              | Ł               |
| Lib1 POR tb_1    | IT("/I0/M7/G")                                | Ł                  |                       |                    |                          |                          | Ł              | Ŀ                     | Ł                     | Ł              | Ŀ              | Ł               | Ł              | Ł               |
| Lib1_POR_tb_1    | IT("/I0/11/A")                                | Ŀ                  |                       |                    |                          |                          | Ł              | E                     | E                     | Ł              | Ŀ              | Е               | E              | Ł               |
| Lib1_POR_tb_1    | <b>IT("/I0/I0/O")</b>                         | Ŀ                  |                       |                    |                          |                          | M              | e                     | Þ                     | E              | ь              | Е               | M              | Е               |
| Lib1_POR_tb_1    | PORB rising                                   | 33.23u             | >15u                  | pass               | 26.18u                   | 43.49u                   | 30.58u         | 35.48u                | 31.86u                | 36.9u          | 37.75u         | 43.49u          | 26.18u         | 30.53u          |
| Lib1 POR tb 1    | POR falling                                   | 33.23u             | >15u                  | pass               | 26.18u                   | 43.49u                   | 30.58u         | 35.48u                | 31.86u                | 36.9u          | 37.75u         | 43.49u          | 26.18u         | 30.53u          |
| Lib1_POR_tb_1    | Supply voltage                                | ĸ                  |                       |                    |                          |                          | Ł              | Ł                     | v                     | Ł              | Ł              | Ł               | Ľ              | e               |
| Lib1_POR_tb_1    | cross(VT("/PORB                               | 126.5u             |                       |                    | 125.4u                   | 127.8u                   | 125.8u         | 127.8u                | 126.1u                | 127.6u         | 126.4u         | 127.5u          | 125.4u         | 127.6u          |
| Lib1_POR_tb_1    | cross(VT("/PORB                               | 121u               |                       |                    | 121u                     | 121u                     | 121u           | 121u                  | 121u                  | 121u           | 121u           | 121u            | 121u           | 121u            |

*Figure 41: POR test output*



#### **4.2.2.5** | **Conclusion Input Blocks**

As seen in the previous section, we have successfully designed, simulated, and tested all the input blocks. While a comprehensive explanation of the current reference circuit was provided, we have not delved into the same level of detail for the other blocks. This is because these blocks are less complex and are already well-documented in publicly available resources. Additionally, for the reader, the precise implementation and calculations may not be crucial. The simulation results hold greater significance since they utilize more accurate transistor models compared to our manual calculations. Nonetheless, manual analysis and understanding of the circuits underlying concepts remain helpful in conjunction with the simulation results.

#### **4.2.3** | **Pads**

In order to achieve the required 200 mA output, it became apparent that a single pad per input and output on the [ASIC](#page-73-1) is insufficient to handle such high currents. According to the data sheet, each pad can handle up to 50 mA. As a result, it was decided to utilize a chip with 48 pads, distributed evenly with 12 on each side. This arrangement allows that the Inductor, hearing instruments, GND and VDD pad have multiple pads.

<span id="page-46-0"></span>Referring to [Table 12,](#page-48-0) it is evident that 40 pads are definitely necessary, and an additional 8 pads remain unassigned but could potentially be utilized in the layout phase to further decrease the input resistance of the high current connections. According to ([\[27\]](#page-80-0) p.292)



*Figure 42: Pad ring*

the cell size for a pad limited chip is about 321  $\mu$ m times 62  $\mu$ m and for a core limited chip about 210  $\mu$ m times 216  $\mu$ m. Since we need huge transistors in our design to switch the current we will use core limited pads as it can be seen in [Figure 42.](#page-46-0) The exact name and schematic of the pads used can be seen in [Figure 43.](#page-47-0)



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

Figure 43: All the d s used in the design Figure 43: All the different pads used in the design



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

*Table 12: Specification*



#### <span id="page-49-1"></span>**4.2.4** | **[FSM](#page-73-4)**

An overview of the [FSM](#page-73-4) can be seen in [Figure 44.](#page-49-0) It is connected to three other blocks: the oscillator, the master [\(SPI\)](#page-73-0) and the analog design. For the [SPI](#page-73-0) interface an existing

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

*Figure 44: Oscillator*

[SPI](#page-73-0) slave module was used, which can also be seen in listening [2](#page-83-0) [\[28\]](#page-80-1). For the controller it was decided to have a separate clock although it would be possible to use the [SPI](#page-73-0) CLK only. The controller logic was implemented as a moore finite state machine as it can be seen in [Figure 45.](#page-50-0)

To check if the syntheses was correct the amount of flip-flops expected was compared to the amount of flip-flops implemented in the design. The controller was implemented with eight registers from which six are read and write capable and two are read only. Furthermore the previous [SPI](#page-73-0) command is always stored in register zero. Therefore one has in the end 7 registers that can be used to store data  $\Rightarrow$  one expects that the hardware requires  $\underbrace{8}{.8}$  + registers finite state machine states 2  $=$  58 flip-flops for the finite state machine

(the controller and its registers). The [SPI](#page-73-0) block itself has two register (data to send and

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

*Figure 45: [FSM](#page-73-4) states*

data received) + the busy flag and therefore  $\sqrt{8}$ data to send data received busy flag  $+$ 8  $+\underbrace{1}_{\sim}$  = 17 flip flops.

So total number of flip-flops is 73 which is also what one sees in the synthesis tool.

#### **4.2.4.1** | **Register Description**

<span id="page-50-1"></span>Register zero which can be seen in [Figure 46](#page-50-1) contains the current command.



*Figure 46: r0*

Register one which can be seen in [Figure 47](#page-50-2) contains the status registers. Whereby one must say that in the current implementation non of those are implemented on the analogue side an therefore not used. But for a extended project they could be used.

- $T_F$ : Over temperature.
- *BBF*<sup>1</sup> : Buck boost fault one
- <span id="page-50-2"></span>• *BBF*<sup>1</sup> : Buck boost fault two





Register two which can be seen in [Figure 48](#page-51-0) contains the analogue mux configurations. It allows to bring different internal analogue signals to the output. Thereby it is worthwhile to mention that only one analogue pin at the time can be put to the output, so it is not possible by wrong configuration to make a shortcut on the chip. The eight bits in this register can mux up to 256 different signal to the output, but the analogue design only uses ten different signals, as it can be seen in [Figure 54](#page-53-0)

- $\bullet$  *AM*<sub>1</sub>:
- $\bullet$   $AM_2$ :
- *AM*3:
- *AM*4:

Register three which can be seen in [Figure 49](#page-51-1) contains the digital mux configurations, whereby one must say that with the current implementable one can only say if one wants

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

| $\left  AM_{7} \right AM_{6} \left  AM_{5} \right AM_{4} \left  AM_{3} \right AM_{2} \left  AM_{1} \right AM_{0} \left $ |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------|--|--|--|--|

*Figure 48: r2*

|  |  |  |  | $\left[DM_{7}\right]DM_{6}\left[DM_{5}\right]DM_{4}\left[DM_{3}\right]DM_{2}\left[DM_{1}\right]DM_{0}\right]$ |
|--|--|--|--|---------------------------------------------------------------------------------------------------------------|

*Figure 49: r3*

<span id="page-51-1"></span>to output the clock or not.

- $\bullet$  *DM*<sub>1</sub>:
- $\bullet$  *DM*<sub>2</sub>:
- $\bullet$  *DM*<sub>3</sub>:
- *DM*4:

Register six contains the tuning parameters of the oscillator capacitors. An example for writing and reading a register can be found in [Figure 51](#page-51-2) and [Figure 50.](#page-51-3)

<span id="page-51-3"></span>

*Figure 50: Write example*

<span id="page-51-2"></span>

*Figure 51: Read example*

#### **4.2.4.2** | **Top Testbench**

To verify the functionality of the [ASIC](#page-73-1) in mixed signal mode, a comprehensive test bench was created, encompassing all blocks except the DC/DC converter. The test bench is illustrated in [Figure 52,](#page-52-0) [Figure 53,](#page-52-1) and [Figure 54.](#page-53-0) During the test, a SPI sequence was generated to configure the analog testpin output of the [ASIC.](#page-73-1) The goal of this emulation of the configuration process was to make the test as similar as with the physical [ASIC](#page-73-1) in front of oneself. Since in the end one can also only measure the signals on the analog testpin. Additionally, it was examined what happens when the reset signal of the [ASIC](#page-73-1) was pressed. The results of the test demonstrated that the [ASIC](#page-73-1) operates as expected, allowing the multiplexing of different analog test signals to the output for measurement purposes.

To evaluate the functionality of the digital part of the circuit only, an additional test



bench was implemented using Vivado only. A screenshot of the test bench results can be observed in [Figure 55.](#page-53-1) It is evident from [Figure 55](#page-53-1) that the [SPI](#page-73-0) generator attempted to write the value 0xAA to register one, which is invalid since register one is designated as read-only as it can be read in [subsubsection 4.2.4.](#page-49-1) So as expected in this case register one remained unwritten.

Subsequently, the content of register two was modified, as depicted in [Figure 56](#page-54-0) and [Figure 57,](#page-54-1) yielding the expected results. The content of register two determines the multiplexing of a corresponding analog signal to the output and is therefore very important to have a testable chip.

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

*Figure 52: Top test bench schematic, on the left the signal generator and on the right the [ASIC](#page-73-1)*

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

*Figure 53: [ASIC](#page-73-1) top design with analog block, digital block and pad ring*

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

*Figure 54: Analog top with POR, Current reference, bandgap, linear regulator (to make sure bandgap signal has low impedance), transmission gates and oscillator, but without DC*/*DC converter*

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

*Figure 55: [SPI](#page-73-0) sequence that tries to write 0xAA to register one which is not possible as the screenshot shows.*

OST )<br>stschweizer<br>jachhochschu



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

*Figure 56: [SPI](#page-73-0) sequence that tries to write 0x02 to register two which is possible as the screenshot shows (R2 has value 0x02 in the end).*

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

*Figure 57: [SPI](#page-73-0) sequence that tries to write 0x03 to register two after it was already initialized to 0x02 which is possible as the screenshot shows (R2 has value 0x03 in the end).*



#### **4.2.5** | **Operational Transconductance Amplifiers (OTA)**

As part of this design we required several [OTAs](#page-73-5). In total we designed four different designs, one with a [NMOS](#page-73-6) royal differential pair, one with a [PMOS](#page-73-7) royal differential pair and each with a variant with a reduced  $g_m$ . The [OTAs](#page-73-5) with [PMOS](#page-73-7) inputs are used in applications, where we need to amplify voltages close to GND. Those with [NMOS](#page-73-6) inputs are used for applications, where the common-mode voltage is close to VDDA. The reduced  $g_m$  variants are needed in the control loop, in order to reduce the size of the compensation network (without the reduced *gm*, the capacitors would not be manufacturable). A low *g<sup>m</sup>* [OTA](#page-73-5) with [NMOS](#page-73-6) inputs is also used to amplify the voltage drop over the input power [PMOS](#page-73-7) in the current sensing circuit. In this case, we take advantage of the linearization of the input transistor pair of the low *g<sup>m</sup>* [OTA.](#page-73-5) All [OTAs](#page-73-5) we designed are simple folded cascode based circuits and are therefore very similar to each other. As such we will only present the figures for the low *g<sup>m</sup>* [OTA](#page-73-5) with [PMOS](#page-73-7) inputs.

| Characteristic                   | Nominal Value            |
|----------------------------------|--------------------------|
| <b>GBP</b>                       | $2.2 \,\mathrm{MHz}$     |
| Phase Margin                     | $83^\circ$               |
| Open Loop Gain                   | 70.9 dB                  |
| Transconductance                 | $14 \mu S$               |
| <b>Output Resistance</b>         | $250 \,\mathrm{M}\Omega$ |
| Input Offset Voltage $(3\sigma)$ | $21.1 \,\mathrm{mV}$     |
| Quiescent Current                | $41.8 \mu A$             |

*Table 13: Key specifications of the low g<sup>m</sup> [OTA](#page-73-5) with [PMOS](#page-73-7) inputs and a* 1 pF *load*



*Figure 58: Our implementation of a folded cascode [OTA](#page-73-5) with [PMOS](#page-73-7) inputs and a reduced g<sup>m</sup>*



#### **4.2.6** | **Comparator**

A comparator was originally to be used as the modulator in an average current-mode control scheme and we based our requirements on that application. The comparators in the A\_CELLs library are not usable in this application, as they are optimized for low current consumption and not high speeds. They have propagation delay of around 500 ns, which is unacceptable for a switching frequency of 1 MHz. We therefore set out on making our own. The design we implemented is based on the circuit in Hans Camenzinds "Designing Analog Chips", which itself is a fairly typical simple comparator circuit. Additionally we added a second output to make it have a differential output and increased the reference current of the circuit, until the comparator had a propagation delay of around 50 ns. The key specifications of the comparator we design can found in [Table 14.](#page-56-0)

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

| Characteristic               | Nominal Value        |
|------------------------------|----------------------|
| Propagation Delay            | $51$ ns              |
| Rise Time $(10\%$ to $90\%)$ | $8.5$ ns             |
| Hysteresis                   | $19.5 \,\mathrm{mV}$ |
| Quiescent Current            | $27 \mu A$           |

*Table 14: Key specifications of the comparator*



*Figure 59: Our implementation of a di*ff*erential output comparator*

#### **4.2.7** | **SR Latch with Blanking Time**

For the latch the blanking time we created our own out of basic [CMOS](#page-73-2) components from the D\_CELLS\_L5V library. From the current sensing circuit we got the requirement for a 120 ns blanking time. We started by creating a simple SR latch out of two NOR logic gates. Instead of connecting the reset directly to the reset input, we added a AND gate to disable it. By using a discrete SR latch and a time delay circuit we are able to disable the reset input for a fixed amount of time, after the rising edge of the set input, thus creating a blanking time. For the delay elements we used 8 ns delay elements from the library and added extra capacitance to the output to further slow down the circuit. The blanking time directly effects the minimum [PWM](#page-73-8) pulse-width, we therefore aimed to have the blanking time as short as possible, while still being longer than the minimum time required by the current measurement. The blanking time over our process corners can be found in



OST

<span id="page-57-0"></span>[Table 15.](#page-57-0)

| Characteristic     | Value            |
|--------------------|------------------|
| Min. Blanking Time | $117$ ns         |
| Typ. Blanking Time | $145 \text{ ns}$ |
| Max. Blanking Time | $189$ ns         |

*Table 15: Blanking time of the SR latch over the process corners*



*Figure 60: Our implementation of a SR latch with blanking time*

#### **4.2.8** | **Current Measurement**

For the current measurement we designed two different approaches. We will introduce both approaches as it took an extensive amount of time and it gave us a lot of insight into the advantages and disadvantages of both approaches. Firstly we will look at SenseFET based current measuring approach we implemented first, before switching to  $R_{DS,on}$  current sensing.

In order to measure the current flowing through the inductor, we first implemented a SenseFET based current sensing circuit based on the proposed circuit in [\[29\]](#page-80-2). This circuit features some clever ideas like mirroring the measured current from the [NMOS](#page-73-6) transistor into the [PMOS](#page-73-7) SenseFET, in order for the upper control loop to already be in the correct operating region, when the switching transistors. As the circuit is already in the correct operating region, the loop requires less time to start tracking the current accurately. Using this approach the circuit tracks the inductor current accurately after a round 100 ns. This circuit unfortunately is not able to measure a reverse current flow, as in such a case, the COM voltage would be outside of the supply rails. We found no simple way to modify the circuit to allow for the measuring of the reverse current, we therefor had to abandon this approach.

After implementing the SenseFET based current measuring approach, we changed the regulator type to peak current-mode control, which lessened the requirements for the current measurement. We no longer had to measure the entire waveform, as we only



*Figure 61: Our implementation of a senseFET based full wave current sensing circuit*

need to know the peak current. This allows us to only measure the current flow during the rising period. By sensing and amplifying the voltage drop over the input [PMOS,](#page-73-7) we can measure the rising edge of the inductor current. Using the *R<sub>DS,on</sub>* the input [PMOS](#page-73-7) as a current shunt simplifies the design and also allows for the measurement of reverse current flow. For the amplifier we are using the low *g<sup>m</sup>* [NMOS](#page-73-6) input [OTA](#page-73-5) we previously designed. As the input is linearized, the [OTA](#page-73-5) has fairly constant  $g_m$  for small differential voltage applied to the input. We achieved a  $g_m$  of around 11  $\mu$ S over the expected differential input range of  $-10$  mV to 60 mV. These values correspond to a current flow of about  $-100$  mA to 600 mA in the switch, which is the range we expect to be operating in. In order to measure reverse current flow, we had to add an offset current to the output for the [OTA](#page-73-5) to sink in such a case. The main characteristics of this circuit are listed in [Table 16.](#page-58-0)

| Characteristic               | Value            |
|------------------------------|------------------|
| <b>Tracking Delay</b>        | $120 \text{ ns}$ |
| Transresistance              | 2 V/A            |
| <b>Output Offset Voltage</b> | 580 mV           |

<span id="page-58-0"></span>*Table 16: Characteristics of the R<sub>DS,on</sub> based current sensing circuit using a nominal* 180 kΩ *resistor to convert the output current into a voltage, as need by subsequent circuits*





*Figure 62: Our implementation of a R<sub>DS,<i>on*</sub> based current sensing circuit

#### **4.2.9** | **Timing and Slope Compensation**

The DC/DC converter requires a 1 MHz clock to set the SR latch in the peak currentmode control loop and to generate the slope compensation required to make the loop stable. For the clock generator, we used the basic principle of charging a capacitor with a constant current and discharging it, as soon a it reaches a threshold voltage. The threshold was set to 2.4 V, as the circuit has to work with an input voltage as low as 4.3 V. Charging the capacitor like this creates a sawtooth voltage at the positive node of the capacitor and the discharge signal can be used as a pulse generator. For the slope compensation we want to create a sawtooth signal, which we can add to the value from the current measurement. As an addition of voltages is more difficult than the addition of two currents, we decided to have both outputs be current outputs. Over the capacitor we already have a sawtooth voltage, but as previously discussed, we need a sawtooth current for the slope compensation. In [\[30\]](#page-80-3) they propose using two [NMOS](#page-73-6) transistors to mirror the voltage from the capacitor onto a resistor, thus creating sawtooth current. This current can be modified by changing the value of the resistor. By mirroring the resistor to an output, we can create our slope compensation output current. Now we can connect the current output from the inductor current measurement, the current from thr slope compensation and a resistor to ground, in order to create a voltage representing the slope compensated inductor current.



*Figure 63: Our implementation of a clock generator with a slope compensation output*

#### **4.2.10** | **Power [MOSFETs](#page-73-9)**

In order to switch the large inductor currents of over 400 mA, the switching transistors need to be sized accordingly. Our goal was to design switching transistors with a on resistance *RDS*,*on* of around 100 mΩ. It was however important, that the transistors have a good size and shape for the layout. We firstly designed small unit transistors, out of which we could later build a mosaic, in order to create the large switching devices. Each unit transistors contains two transistors and have the such that, when ordered in a mosaic, all transistors are automatically correctly connected to each other and no design rules are violated. To protect the transistors from the snapback effect, we extended the drain, as recommended in the XFAB documentation. This forced us to widened the gate of the transistors to 800 nm from 600 nm, to not violate any design rules. The lengthened gate increased the  $R_{DS, on}$ , but we were still able to reach out target of around 100 m $\Omega$ .

| Characteristic   | Value                             |
|------------------|-----------------------------------|
| Typ. $R_{DS,on}$ | $113 \,\mathrm{m}\Omega$          |
| # of Transistors | 4834                              |
| Width            | 96.7 mm                           |
| <b>Size</b>      | $1000.2 \mu m \times 486.8 \mu m$ |

*Table 17: Specifications of the power [PMOS](#page-73-7)*

| Characteristic   | Value                                |
|------------------|--------------------------------------|
| Typ. $R_{DS,on}$ | 72.8 m $\Omega$                      |
| # of Transistors | 2800                                 |
| Width            | 56 mm                                |
| <b>Size</b>      | $641.4 \,\mu m \times 483.1 \,\mu m$ |

*Table 18: Specifications of the power [NMOS](#page-73-6)*



*Figure 64: The layout of our unit [NMOS](#page-73-6) transistor containing two* 20 µm/800 nm *[NMOS](#page-73-6) transistors with extended drains*

#### **4.2.11** | **Level Shifter**

In order to correctly drive the output [PMOS](#page-73-7) correctly, the have to drive its gate with the voltage at its source which is connected to the output node. As all internal supplies are directly connected to input node, we have to cross voltage domains to drive the output transistors, thus requiring a level shifter. Even though the level shifter is only needed of the output half-bridge, we want to only create one gate driver circuit for both half-bridges and are therefore using level shifters at the input of the each gate driver. As the output voltage can higher or lower than the input, the conventional level shifter from the XFAB libraries can not be used, as it requires the output voltage to always be higher than the input. A single supply level shifter solves this problem by only needing one supply connected to the output. We designed our level shifter based on the circuit described in [\[31\]](#page-80-4), while sizing the transistor based on the default sizes and drive strengths of [CMOS](#page-73-2) circuits in XFAB libraries.





*Figure 65: Our implementation of a single supply level shifter*

#### **4.2.12** | **Non-overlapping Gate Driver**

The function of the gate driver is to convert the low power output signal from the flipflop to a high-current output capable of driving the the power [MOSFETs](#page-73-9). As the power [MOSFETs](#page-73-9) have a significant size the have a significant gate capacitance which stores a significant gate charge. At every switching cycle the gate charge needs be completely added and removed. As this process takes time, it is important to ensure that both power [MOSFETs](#page-73-9) are not conducting at the same time, as this would cause a large current flowing from the supply through the [MOSFETs](#page-73-9) directly to ground in process called shoot-through. The prevent this we have to ensure the [PMOS](#page-73-7) is competently turned off before turning on the [NMOS](#page-73-6) and vice-versa. To do this we use a non-overlapping driver circuit, which introduces a fixed delay between both drive signals.

We have implemented the typical non-overlapping control circuit out of digital cells from XFAB library. In order to drive the large gates of the switching transistors, we used a series of inverters with increasing drive strength. The last stage uses one inverter with X4 drive strength to drive each gate strand of [PMOS](#page-73-7) transistors and one inverter with X2 drive strength for the [NMOS](#page-73-6) transistors. In addition we have an enable pin to turn off the both power [MOSFETs](#page-73-9) to turn off all switching transistors, bringing them into a safe state. As it possible for the output voltage to be greater than the supply voltage of the chip, we need to translate the voltage levels from the drive signals to the supply level of the gate driver. For this we used the previously described single supply level shifters we designed.

#### **4.2.13** | **Thermal Shutdown**

In order to protect circuits from sustained overload load conditions a thermal shutdown circuits is often employed. The goal is to measure the silicon temperature near the most heat generating parts of the chip and turn off the heat generating sub-circuits if the temperature exceeds a predefined limit. A crude temperature measurement often suffices. Thermal Shutdown [\(TSD\)](#page-74-0) circuits also use hysteresis to prevent the circuit from rapidly shutting down and turning on again. We found the hysteresis of [ICs](#page-73-10) on the market to be around 20 $\rm{^{\circ}C}$  to 40 $\rm{^{\circ}C}$  and have a trip point of 140 $\rm{^{\circ}C}$  to 170 $\rm{^{\circ}C}$ . We based our thermal shutdown circuit on the circuit found in the XFAB A\_CELLS Library. As this circuit is





*Figure 66: Our implementation of a gate driver with non-overlapping drive signals*

not suitable for a 5 V supply and requires their complementary circuitry to work, we modified it to work in our design. Firstly we changed all [MOSFETs](#page-73-9) to their 5 V variants, used or own folded cascode to generate a reference current in the circuit and used the comparator we already designed. In addition we added M9 to the circuit to increase the current in one strand in the case of an over temperature event to increase the hysteresis of the circuit. Without it the hysteresis is only  $7^{\circ}$ C and we wanted to increase it to around  $30^{\circ}$ C to be more in line with the values seen in other designs.

The circuit works by comparing the forward voltage of two strands of bipolar transistors wired in a diode configuration. The two stands are designed such that both have similar forward voltages at room temperature, but different temperature coefficients. The strands with higher temperature coefficient starts hat a higher voltage at room temperature, but at some higher temperature falls bellow the voltage created by the other strand. This crossover is detected with a comparator, and we will call the temperature at with this crossover happens the crossover temperature. The different temperature coefficients are achieved by using one strand with three series diodes and another with four. By sending a significantly smaller current through the strand with four transistors, the forward voltages are set to level slightly higher then the one in the other strand. As the strand with four transistors has more transistors in series, its forward voltage has larger temperature dependence. By varying the the current through both strands it possible to relatively precisely set the crossover temperature of the circuit. As the voltage of both strands is generated by using the forward voltage of bipolar transistors, both are subjected to the same process variations with can be seen in the very stable crossover temperature over the process corners. We have set the currents such that we get a crossover temperature of



140 $\,^{\circ}$ C and a hysteresis of 30 $\,^{\circ}$ C.

| Device                     |                 | Trip point   Hysteresis |
|----------------------------|-----------------|-------------------------|
| Texas Instruments TPS63000 | $140^{\circ}$ C | $20^{\circ}$ C          |
| Renesas ISL9122A           | $130^{\circ}$ C | $25^{\circ}C$           |
| Maxim MAX8625A             | $165^{\circ}$ C | $15^{\circ}C$           |
| ST Microelectronics STBB2  | $150^{\circ}$ C | $20^{\circ}$ C          |
| This Design                | $140^{\circ}$ C | $30^{\circ}C$           |

*Table 19: Overview of thermal shutdown settings of various buck-boost converters*



*Figure 67: Our implementation of an over-temperature protection circuit*



# **5** | **Specifications**



*Table 20: Specification*



# **6** | **Results**

In this chapter we will present main result as we have simulated so far. As the layout is not yet finished, all results presented here done pre post-layout-simulation and are subject to change. The focus of the results here are in relation to the performance of the buckboost converter. While all sub-circuits were simulated over all expected process corners and some where necessary with Monte-Carlo simulations, the system level simulations presented here only done under nominal circumstances due to time constraints. We have identified three key areas of interest that we will discuss further. The first is regarding the start up behavior of the circuit. The converter should be able to start and regulate the output voltage and current sufficiently, without a significant load present as well as under maximum specified out. The next area of interest is regarding the dynamic regulation characteristics. Here we are applying a step to the input voltage and conducting a load step to the output. Lastly we want to test the behavior of the converter, when a short circuit to ground is applied to the output. In all following waveforms the output voltage is yellow and the inductor current is in red.

### **6.1** | **Startup Behaviour**

The first test shows the circuit starting up without a load present. For this test we apply the nominal 5 V to the input and enable the converter, while pulling only 1 mA from the output. The current limiting works as expected, limiting the current to roughly 550 mA while starting. The output voltage overshoots the 5 V target by about 230 mV. While this is more then we previously expected, this is not surprising, as all the energy stored in the inductor gets dumped into the output capacitor.



*Figure 68: Results of starting up the converter with a* 1 mA *load*

| Characteristic  | Value               |
|-----------------|---------------------|
| Overshoot       | $230 \,\mathrm{mV}$ |
| Average Voltage | 5.009 V             |
| Output Ripple   | $5.8\,\mathrm{mV}$  |

*Table 21: Results of starting up the converter with a* 1 mA *load*

The results from starting the converter with a 200 mA load are more pleasing. The output voltage overshoot is significantly less at 49 mV. In [Figure 69](#page-67-0) it is possible to see the foldback current limit working. For low output voltages under 1.2 V the current is proportionally limited in accordance with the output voltage. After reaching the output voltage threshold, the current is, more or less, limited to a constant value before the regulator starts taking over. In both startup cases the average output voltage as well as the output voltage ripple are at satisfactory levels. The efficiency of the converter under full load is 91.6 %.

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

*Figure 69: Results of starting up the converter with a* 200 mA *load*

| Characteristic               | Value                |
|------------------------------|----------------------|
| Overshoot                    | $49 \,\mathrm{mV}$   |
| Average Voltage              | 5.049 V              |
| Output Ripple                | $10.2 \,\mathrm{mV}$ |
| <b>Conversion Efficiency</b> | $91.6\%$             |

*Table 22: Results of starting up the converter with a* 200 mA *load*

### **6.2** | **Dynamic Regulation Behavior**

The following two test can be categorized as dynamic regulation behavior. In both cases the regulator is allowed to reach steady-steady before applying a violent change at the input or output respectively. In the first case we step the input voltage from 4.3 V to 5.5 V and back, e.g from the minimum value specified value to the maximum. In the second case will step the load current from 1 mA to 200 mA and back, again from the minimum value specified value to the maximum. Our goal is to examine the effects on the output



voltage and current regulation. The input voltage step only leads to a small disturbance to the output voltage and is quickly eliminated.



*Figure 70: Results of applying a input voltage step of*  $4.3 \text{ V} \rightarrow 5.5 \text{ V} \rightarrow 4.3 \text{ V}$ 

| Characteristic | Value                |
|----------------|----------------------|
| Overshoot      | $34.8 \,\mathrm{mV}$ |
| Droop          | $20 \,\mathrm{mV}$   |

**Table 23:** Results of applying a input voltage step of  $4.3 \text{ V} \rightarrow 5.5 \text{ V} \rightarrow 4.3 \text{ V}$ 

Applying the load step causes a more severe disturbance to the output, which is to be expected. The output voltage droops around 175 mV bellow its target, when the load is applied and overshoots the target by 185 mV when the load is removed. Nonetheless the disturbance is corrected in less than 200 µs.



*Figure 71: Results of applying a load step of*  $1 \text{ mA} \rightarrow 200 \text{ mA} \rightarrow 1 \text{ mA}$ 



| Characteristic | Value               |
|----------------|---------------------|
| Overshoot      | $185 \,\mathrm{mV}$ |
| Droop          | $175 \,\mathrm{mV}$ |

**Table 24:** Results of applying a load step of  $1 \text{ mA} \rightarrow 200 \text{ mA} \rightarrow 1 \text{ mA}$ 

## **6.3** | **Current Limiting**

In order to test the current limiting behavior of the circuit, we simulated the startup behavior of the circuit with the output short circuited to ground. The simulated waveforms can be seen in [Figure 72](#page-69-0) and shows the current being limited to 286 mA. This value is lower then the general current limit of 550 mA, showing the circuit operating as intended and keep the component stresses low in the case of a shorted output.

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

*Figure 72: Results of starting up the converter with a shorted output*



*Table 25: Results of starting up the converter with a shorted output*



# **7** | **Conclusion**

We were able to achieve our goal of designing a highly integrated buck-boost converter [IC,](#page-73-10) which meets the specifications given to us by the Sonova AG. The peak-current control based converter is able to accurately create a output voltage both higher and lower than its input. The output voltage can be maintained over the whole specified input voltage range and regulator can quickly react to changes on the input and output. To ensure save operation the design features a foldback over-current protection, which leads to a short circuit safe output and basic soft-start functionality. To protect the switching transistor from over-temperature induced failure, we implemented thermal shutdown mechanism, which safely shuts off the converter if the transistors get to hot. We were not able to meet the deadline for the the tape-out, as we had to change the converter topology late in the process and due to the significant time required in the layout stage of the design.

We faced a steep learning curve as both of us were unfamiliar we the tools as we started the project. Consequently, our initial timeline was to optimistic and had to be adjusted as the design and layout efforts required more time than anticipated. We sincerely appreciate the opportunity given to us by the university and department IMES to work on such an [ASIC](#page-73-1) project. However, we acknowledge the scope of the project was overly ambitious for a master's project, resulting in a significant higher time investment than anticipated. Therefore, we recommend to our supervisor and expert that future projects should be smaller in scale, particularly if the participants are not proficient users of the design tools required, as a substantial amount of time was dedicated to learning the program and troubleshooting errors, rather than focusing on design aspects.

Having completed the pre-layout phase, we have successfully defined all the parameters necessary for measuring the ASIC. The system design simulation has indicated that the [ASIC](#page-73-1) should function as intended, giving us confidence that the final ASIC will work accordingly and we can proceed as planned.



# **8** | **Outlook**

## **8.1** | **Time-plan**

Since the pre-layout phase is finished with this document. The next important phase is the layout phase and then the tape-out. According to our actual plan which can also be found online under the following [link](https://asic-project.atlassian.net/jira/software/projects/MAP/boards/3/timeline)<sup>[5](#page-0-0)</sup> the tape out is planned in October 2023. So that we get the first physical [ASIC'](#page-73-1)s somewhere in April. During the time period where we wait on the [ASIC'](#page-73-1)s we will already prepare the test script and adapter PCBs to test all the specified parameters on the chip.

### **8.2** | **Hours**

[Jira,](subsec:jira) which allows time tracking, was utilized by one project participant to monitor the hours dedicated to specific tasks. This feature provides a high-level overview, as shown in [Figure 73,](#page-71-0) depicting the distribution of hours across different project segments, referred to as epics in [Jira.](subsec:jira) It is important to note that this data reflects the input from only one participant, as the other participant ceased reporting his hours. Notably, a significant portion of time was invested in system design. However, it is worth mentioning that this category encompasses time spent on debugging and configuring Cadence for accurate simulations. Additionally, 108 hours have been allocated to layout work, although only a few blocks have been completed thus far. Considering future planning, it is evident that the period leading up to tapeout will be demanding, leaving no room for additional implementations on the ASIC before tape-out.

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

*Figure 73: Project hours and distribution of one participant only so far (05.07.2023)*

<sup>5</sup> https://asic-project.atlassian.net/jira/software/projects/MAP/boards/3/timeline


# **9** | **Declaration of Authorship**

#### **Declaration**

We hereby declare that we have independently completed the present work without any assistance from third parties that were not mentioned in this document. We have only used the resources and tools that we have specified. Thoughts and ideas taken from external sources, whether directly or indirectly, have been appropriately acknowledged. The work has not been submitted to any other examination authority or previously published.

**Place Date** Rapperswil July 14, 2023

**Signature** Matthias Meyer **Patrick Jansky** 

# OST

# **10** | **Listings**

#### **List of Abbreviations**

- <span id="page-73-6"></span>**[ASIC](#page-6-0)** [Application Specific Integrated Circuit](#page-6-0)
- <span id="page-73-1"></span>**[BJT](#page-24-0)** [Bipolar Junction Transistor](#page-24-0)
- **[CCM](#page-29-0)** [Continous Conduction Mode](#page-29-0)
- <span id="page-73-3"></span>**[CMOS](#page-10-0)** [Complementary Metal–Oxide–Semiconductor](#page-10-0)
- **[DCM](#page-29-1)** [Discontinous Conduction Mode](#page-29-1)
- **[ESD](#page-23-0)** [Electrostatic Discharge](#page-23-0)
- **[FET](#page-19-0)** Field-Eff[ect Transistor](#page-19-0)
- <span id="page-73-5"></span>**[FSM](#page-5-0)** [Finite-State Machine](#page-5-0)
- <span id="page-73-2"></span>**[GgNMOS](#page-26-0)** [Gate-Ground-NMOS](#page-26-0)
- **[HI](#page-6-1)** [Hearing Instruments](#page-6-1)
- **[IC](#page-18-0)** [Integrated Circuit](#page-18-0)
- **[I2C](#page-21-0)** [Inter-Integrated Circuit](#page-21-0)
- **[LDO](#page-8-0)** [Low Drop-Out](#page-8-0)
- **MOS** Metal-Oxide Semiconductor
- **[MOSFET](#page-5-1)** [Metal-Oxide Semiconductor Field-E](#page-5-1)ffect Transistor
- **[MPW](#page-10-1)** [Multi Project Waver](#page-10-1)
- <span id="page-73-10"></span>**[NMOS](#page-25-0)** [N-Type Metal-Oxide Semiconductor](#page-25-0)
- <span id="page-73-8"></span>**[OTA](#page-28-0)** [Operational Transconductance Amplifier](#page-28-0)
- **[PFM](#page-17-0)** [Pulse-Frequency Modulation](#page-17-0)
- <span id="page-73-9"></span>**[PMOS](#page-24-1)** [P-type Metal-Oxide Semiconductor](#page-24-1)
- **[POR](#page-4-0)** [Power-on-Reset](#page-4-0)
- **[PWM](#page-17-1)** [Pulse-Width Modulation](#page-17-1)
- <span id="page-73-4"></span>**[SCR](#page-26-1)** [Silicon Controlled Rectifier](#page-26-1)
- <span id="page-73-0"></span>**[SEPIC](#page-11-0)** [Single-Ended Primary-Inductor Converter](#page-11-0)
- <span id="page-73-7"></span>**[SPI](#page-22-0)** [Serial Peripheral Interface](#page-22-0)



- **[TSD](#page-62-0)** [Thermal Shutdown](#page-62-0)
- **[UART](#page-21-1)** [Universal Asynchronous Receiver](#page-21-1)/Transmitter
- **[USB](#page-6-2)** [Universal Serial Bus](#page-6-2)



OST<br>Ostschweizer<br>Fachhochschule









### **List of Tables**



#### **Bibliography**

OST

- [1] Analog Devices, *USB Battery Charging Guide*, [Online; accessed 3-Mai-2023], -. [Online]. Available: [{https://www.analog.com/en/technical-articles/usb-battery-charging-guide.]({https://www.analog.com/en/technical-articles/usb-battery-charging-guide.html}) [html}]({https://www.analog.com/en/technical-articles/usb-battery-charging-guide.html}).
- [2] Atlassian, *Jira software*. [Online]. Available: <https://www.atlassian.com/de/software/jira> (visited on 07/10/2022).
- [3] Wikipedia contributors, *Jira (software) Wikipedia, the free encyclopedia*, [Online; accessed 7- October-2022], 2022. [Online]. Available: [https://en.wikipedia.org/w/index.php?title=](https://en.wikipedia.org/w/index.php?title=Jira_(software)&oldid=1114234274) [Jira\\_\(software\)&oldid=1114234274](https://en.wikipedia.org/w/index.php?title=Jira_(software)&oldid=1114234274) (visited on 07/10/2022).
- [4] *Process and device specification xh035 0.35* µ*m modular cmos*, PDS\_035\_03, Release 6.6.3, X-FAB Global Services GmbH, Jul. 2021.
- [5] Wikipedia contributors, *Foundry model Wikipedia, the free encyclopedia*, [Online; accessed 7- October-2022], 2022. [Online]. Available: [https://en.wikipedia.org/w/index.php?title=](https://en.wikipedia.org/w/index.php?title=Foundry_model&oldid=1099806912) [Foundry\\_model&oldid=1099806912](https://en.wikipedia.org/w/index.php?title=Foundry_model&oldid=1099806912).
- [6] X-FAB Silicon Foundries SE, *X-fab*. [Online]. Available: <https://www.xfab.com/> (visited on 07/10/2022).
- [7] John Betten, *Benefits of a coupled-inductor SEPIC converter*, [Online; accessed 3-November-2022], 2011. [Online]. Available: <{https://www.ti.com/lit/an/slyt411/slyt411.pdf}>.
- [8] Brian King, *SEPIC Converter Design*, [Online; accessed 3-November-2022], 2010. [Online]. Available: [{https://www.powersystemsdesign.com/articles/sepic- converter- design/22/]({https://www.powersystemsdesign.com/articles/sepic-converter-design/22/4215}) [4215}]({https://www.powersystemsdesign.com/articles/sepic-converter-design/22/4215}).
- [9] Brian King, *What is SEPIC Converter? Circuit Design, Operation Advantages*, [Online; accessed 3-November-2022], 2022. [Online]. Available: [{https://www.electronicsmind.com/what-is]({https://www.electronicsmind.com/what-is-sepic-converter})[sepic-converter}]({https://www.electronicsmind.com/what-is-sepic-converter}).
- [10] Marian K. Kazimierczuk, Dalvir K. Saini, Agasthya Ayachit, *Average Current-Mode Control of DC-DC Power Converters*. John Wiley and Sons Ltd, 2022, isbn: 9781119525561.
- [11] *Lm5175 42-v wide vin synchronous 4-switch buck-boost controller*, Texas Instruments. [Online]. Available: <https://www.ti.com/lit/ds/symlink/lm5175.pdf> (visited on 02/26/2023).
- [12] *Understanding and applying current-mode control theory*, Texas Instruments. [Online]. Available: <https://www.ti.com/lit/an/snva555/snva555.pdf> (visited on 02/26/2023).
- [13] B. Dobkin and J. Williams, *Analog Circuit Design*. Newnes, 2011, isbn: 978-0-12-385185-7.
- <span id="page-79-0"></span>[14] *Modelling, analysis and compensation of the current-mode converter*, Texas Instruments. [Online]. Available: <https://www.ti.com/lit/an/slua101/slua101.pdf> (visited on 07/13/2023).
- [15] *Design tips for an e*ffi*cient non-inverting buck-boost converter*, Texas Instruments. [Online]. Available: <https://www.ti.com/lit/an/slyt584/slyt584.pdf> (visited on 07/13/2023).
- [16] *Digital peak current mode control with slope compensation using the tms320f2803x*, Texas Instruments. [Online]. Available: [https : / / www . ti . com / lit / an / sprabe7a / sprabe7a . pdf](https://www.ti.com/lit/an/sprabe7a/sprabe7a.pdf) (visited on 07/13/2023).
- [17] *Improve power converter reliability using hiccup-mode current limiting*, Texas Instruments. [Online]. Available: <https://www.ti.com/lit/an/snva604/snva604.pdf> (visited on 07/12/2023).
- <span id="page-80-3"></span>[18] Wikipedia contributors, *Serial peripheral interface — Wikipedia, the free encyclopedia*, [Online; accessed 21-October-2022], 2022. [Online]. Available: [https://en.wikipedia.org/w/index.](https://en.wikipedia.org/w/index.php?title=Serial_Peripheral_Interface&oldid=1112714519) [php?title=Serial\\_Peripheral\\_Interface&oldid=1112714519](https://en.wikipedia.org/w/index.php?title=Serial_Peripheral_Interface&oldid=1112714519).
- <span id="page-80-0"></span>[19] Li–Pro.Net, *Tikz-timing*. [Online]. Available: [https : / / lpn - doc - sphinx - primer - devel .](https://lpn-doc-sphinx-primer-devel.readthedocs.io/extensions/tikz/tikztiming.html) [readthedocs.io/extensions/tikz/tikztiming.html](https://lpn-doc-sphinx-primer-devel.readthedocs.io/extensions/tikz/tikztiming.html) (visited on 07/10/2022).
- <span id="page-80-1"></span>[20] *Basic esd design guidelines*, Revision: 003, X-FAB Semiconductor Foundries, Dec. 2005.
- [21] Wikipedia contributors, *Snapback (electrical) Wikipedia, the free encyclopedia*, [Online; accessed 28-October-2022], 2019. [Online]. Available: [https : / / en . wikipedia . org / w / index . php ?](https://en.wikipedia.org/w/index.php?title=Snapback_(electrical)&oldid=913562816) [title=Snapback\\_\(electrical\)&oldid=913562816](https://en.wikipedia.org/w/index.php?title=Snapback_(electrical)&oldid=913562816).
- <span id="page-80-2"></span>[22] Wikipedia contributors, *Bipolar junction transistor — Wikipedia, the free encyclopedia*, [Online; accessed 28-October-2022], 2022. [Online]. Available: [https://en.wikipedia.org/w/index.](https://en.wikipedia.org/w/index.php?title=Bipolar_junction_transistor&oldid=1115672915) [php?title=Bipolar\\_junction\\_transistor&oldid=1115672915](https://en.wikipedia.org/w/index.php?title=Bipolar_junction_transistor&oldid=1115672915).
- [23] Wikipedia contributors, *Latch-up Wikipedia, the free encyclopedia*, [Online; accessed 4-November-2022], 2021. [Online]. Available: [https://en.wikipedia.org/w/index.php?title=Latch](https://en.wikipedia.org/w/index.php?title=Latch-up&oldid=1034960002)[up&oldid=1034960002](https://en.wikipedia.org/w/index.php?title=Latch-up&oldid=1034960002).
- [24] Wikipedia contributors, *Thyristor Wikipedia, the free encyclopedia*, [Online; accessed 28-October-2022], 2022. [Online]. Available: [https://en.wikipedia.org/w/index.php?title=Thyristor&](https://en.wikipedia.org/w/index.php?title=Thyristor&oldid=1104215440) [oldid=1104215440](https://en.wikipedia.org/w/index.php?title=Thyristor&oldid=1104215440).
- <span id="page-80-4"></span>[25] *Spice models and simulations*, Release: 2.0.1, X-FAB Global Services GmbH, Erfurt, May 2021.
- [26] A. Hajimiri. "133n process, supply, and temperature independent biasing," Youtube. (2019), [Online]. Available: <https://youtu.be/rZ8WBV8OYMI>.
- [27] *Xh035 io library manual*, Revision: V10.2.0, X-FAB Global Services GmbH, Sep. 2020.
- [28] "Spi slave vhdl design," surf-vhdl. (2021), [Online]. Available: [https://surf-vhdl.com/spi](https://surf-vhdl.com/spi-slave-vhdl-design/)[slave-vhdl-design/](https://surf-vhdl.com/spi-slave-vhdl-design/).
- [29] Y. Jiang, M. Swilam, S. Asar, and A. Fayed, *An accurate sense-fet-based inductor current sensor with wide sensing range for buck converters,* 2018, pp. 1–4. poi: [10.1109/ISCAS.2018.8351083](https://doi.org/10.1109/ISCAS.2018.8351083).
- [30] Y. Hu, Y. Wei, J. Wang, and M. Sun, *Design of slope compensation for a high-e*ffi*ciency high-current dc-dc converter*, 2016, pp. 1306–1308. doi: [10.1109/ICSICT.2016.7998722](https://doi.org/10.1109/ICSICT.2016.7998722).
- [31] Q. Khan, S. Wadhwa, and K. Misri, *A single supply level shifter for multi-voltage systems*. 2006, 4 pp.-. por: [10.1109/VLSID.2006.24](https://doi.org/10.1109/VLSID.2006.24).
- [32] *Commercial and industrial-grade products*, CTWP011, Cactus Technologies Limited. [Online]. Available: [https://www.cactus- tech.com/wp- content/uploads/2019/03/Commercial](https://www.cactus-tech.com/wp-content/uploads/2019/03/Commercial-and-Industrial-Grade-Products.pdf)[and-Industrial-Grade-Products.pdf](https://www.cactus-tech.com/wp-content/uploads/2019/03/Commercial-and-Industrial-Grade-Products.pdf) (visited on 11/31/2022).
- [33] Wesley T. Honeycutt, *LaTeX: Drawing MOSFET in TikZ Labels and Animation*, [Online; accessed 3-November-2022], 2022. [Online]. Available: [{http://wesleythoneycutt.com/latex]({http://wesleythoneycutt.com/latex-mosfet-tikz-labels-animation/})[mosfet-tikz-labels-animation/}]({http://wesleythoneycutt.com/latex-mosfet-tikz-labels-animation/}).

## **11** | **Appendix**

### **11.1** | **Graphics**

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

*Figure 74: Monte Carlo distribution of the first Current reference, which had a reference current of* 5 µA*.*

### **11.2** | **Code**

```
1 -- Created by Matthias Meyer
2 - - 16/12/20223
4 library ieee;
5 use ieee.std_logic_1164.all;
6 use ieee.numeric_std.all;
7 library work;
8 use work.ctrl_pkg.all;
9
10 entity ctrl is
11 --generic(); -- Data width of a register
12 Port (
13 o_busy : in std_logic; - spi
       \rightarrow is receiving data if '1' ==> i_data_from_spi is not stable
14 --o_data_to_spi : out std_logic_vector(c_DW-1 downto 0);
       \rightarrow register which is sent to spi
15 --i_data_from_spi : in std_logic_vector(c_DW-1 downto 0);
       \rightarrow register received from spi
16 o_data_to_spi : out std_logic_vector(7 downto 0); -- register
       \rightarrow which is sent to spi
17 i_data_from_spi : in std_logic_vector(7 downto 0); -- register
       \rightarrow received from spi
```

```
18 clk : in std_logic; -- clk
       \rightarrow for module
19 rst \qquad \qquad: in std_logic;
       \rightarrow reset signal for module
20 --o_register : out std_logic_vector(2**c_AW*c_DW-1 downto 0)
       \rightarrow --output register
21 o_register : out std_logic_vector(63 downto 0) --output
       \rightarrow register
22 );
23 end ctrl;
24
25 architecture rtl of ctrl is
26 type state is (S0, S1, S2, S3);
27 signal c_st, n_st : state;
28 --define ctrl_reg
29 signal ctrl_reg : t_register := ((others \Rightarrow (others \Rightarrow '0')));30 begin
31 - -32 o_register \leq to_slv(ctrl_reg);
33 -- memorizing process
34 p_seq: process (rst, clk)
35 begin
36 if rst = '1' then
37 c st \leq S0:
38 -- ctrl_reg <= (others=> (others=>'0'));
39 elsif rising_edge(clk) then
40 c_st \langle = n \, \text{st};41 end if;
42 end process;
43 -- memoryless process
44 p_com: process (o_busy,i_data_from_spi, ctrl_reg, c_st, rst)
45 begin
46 -- default assignments
47 n_st \leq c_st; -- remain in current state
48 --data to spi is value of the register with the address stored in register zero
49 o_data_to_spi <= ctrl_reg(to_integer(unsigned(ctrl_reg(0)(3 downto 1))));
50 -- specific assignments
51 case c_st is
52 when S0 \Rightarrow53 if o_busy = '1' then n_st <= S1;
54 end if;
55 --if write is set to one and register address is larger than one then
              \rightarrow write register.
```

```
56 if ctrl_reg(\mathbf{0})(\mathbf{0}) = '1' and unsigned(ctrl_reg(\mathbf{0})(3 downto 1)) >
               \rightarrow to_unsigned(1,3) then
57 ctrl_reg(to_integer(unsigned(ctrl_reg(0)(3 downto 1)))) <=
                   \rightarrow i_data_from_spi;
58 end if;
59 when S1 =>
60 if o_busy = '0' then
61 n st \leq S2;
62 end if;
63 when S2 \Rightarrow\textbf{if} \space \textbf{o\_busy} = '1' \space \textbf{then} \space \textbf{n\_st} \leq S3;65 end if;
66 ctrl_reg(\emptyset) \leq i_data_from_spi;
67 when S3 \Rightarrow68 if o\_busy = '0' then n\_st \leq S0;
69 end if;
70 when others \Rightarrow71 n_st <= S0; -- handle parasitic states
72 end case;
73 end process;
74 end rtl;
75
76
77
```
Listing 1: ctrl

```
1
2 -- Source code from https://surf-vhdl.com/spi-slave-vhdl-design/
3 -- Modified by Matthias Meyer
4 - - 16/12/20225
6
7 library ieee;
8 use ieee.std_logic_1164.all;
9 use ieee.numeric_std.all;
10
11 entity spi_slave is
12 generic(
13 N : integer := 8; -- number of bit to serialize
14 CPOL : std_logic := '0' ); -- clock polarity
15 port (
```

```
16 o_busy : out std_logic; -- receiving data if '1'
17 i_data_parallel : in std_logic_vector(7 downto 0); -- data to sent
18 o_data_parallel : out std_logic_vector(7 downto 0); -- received data
19 i_sclk : in std_logic;
20 i_ss : in std_logic;
21 i_mosi : in std_logic;
22 o_miso : out std_logic);
23 end spi slave:
24
25 architecture rtl of spi_slave is
26
27 signal r_shift_ena : std_logic;
28 signal r_tx_data : std_logic_vector(N-2 downto 0); --
   \rightarrow data to sent
29 signal r_rx_data : std_logic_vector(N-1 downto 0); --
   \rightarrow received data
30
31 begin
32 o_data_parallel \leq r_rx_data;
33 o_busy \leq r_shift_ena;
3435 p_spi_slave_input : process(i_sclk)
36 begin
37 if(i_sclk'event and i_sclk=CPOL) then -- CPOL='0' => falling edge; CPOL='1' =>
     \rightarrow risinge edge
38 if(i_ss='0') then
39 r_rx_data <= r_rx_data(N-2 downto 0)&i_mosi;
40 end if;
41 end if;
42 end process p_spi_slave_input;
\overline{43}44 p_spi_slave_output : process(i_sclk,i_ss)
45 begin
46 if(i_ss='1') then
47 \mathbf{r}\_\text{shift\_ena} \langle 0',48 		 O\_miso 		 \langle = \ ^{\dagger}Z^{\dagger};
49 elsif(i_sclk'event and i_sclk= not CPOL) then -- CPOL='0' => falling edge; CPOL='1'
     \rightarrow => risinge edge
50 r\_shift\_ena \langle z \rangle' \downarrow51 if(r_shift_ena='0') then
52 o_miso \langle = i_data_parallel(N-1);
53 r_t x_ddata \langle \rangle = i_d x_d ata_parallel(N-2 downto 0);
54 else
```

```
55 		 o_miso 		 \leq r_tx_data(N-2);
56 r_t x_ddata \langle r_t x_d \rangle \langle x_d \rangle = r_t x_d ata(N-3 downto 0)&'0';
57 end if;
58 end if;
59 end process p_spi_slave_output;
60
61 end rtl;
```


```
1 clear
2 %pkg load control;
3 %% Controller Parameters
4 % RC Low Pass
5 Rf = 200e3;
6 phitp = 0.5; %phitp = fctp/fs7
8 %Inner Current Controller
9 gmi = 13.56e-6;
10 R1i = 1/gmi;
11 %R1i = 1e3;
12 fci = 100e3; % Bandwidth %30k
13 PMi = 60; % Phase margin
14
15 %Outer Voltage Controller
16 gmv = 13.56e-6;
17 R1v = 1/gmv;
18 %R1v = 1e3;
19 fcv = 10e3; % Bandwidth %10k
20 PMv = 72; % Phase margin
21
22 %Current Sensor Voltage Offset
23 VOFF = 0.5;
24
25 %% Physical Parameters
26 Vi = 5;
27 Vo = -5;
28 L = 47e-6;
29 C = 22e-6; %120
30 fs = 500e3;
31 RL = 25;
32 rC = 0.01;
```

```
33 rL = 0.01;
3435 D = 0.5;
36 \quad \text{\%}D = 0.3213;37 IL = -Vo/(RL*(1-D));
38
39 \text{ r} = 0.1;
40 \t% RF = 0.07:
41 % rDS = 0.11;
42 % r = D^*rDS + (1-D)^*RF + rL;
43
44 VTm = 3:
45 %RS = 1;46 VRV = 1.25;
47
48 %% Duty Cycle-to-Output Voltage Transfer Function Tp
49
50 Tp0 = -(\sqrt{6}/(\sqrt{D^*(-D)})^*(\sqrt{D^*r}-((1-D)^2))^*RL)/(r+(1-D)^2)^*RL); %DC Gain
51 Tpx = (-Vo/(1-D))^*(rC/(RL+rC));52 omega0 = \sqrt{(r+(1-D)^2)^*R}L/(L^*C^*(R L+rC));
53 zeta = (L+C*(r*(RL+rC)+((1-D)^2)*RL*rC))/(2*sqrt(L*C*(RL+rC)*(r+((1-D)^2)*RL)));
54 omegazn = 1/(C^*rC);
55 omegazp = (RL^*((1-D)^2)^{-D^*}r)/(D^*L);
56
57 fo = omega0/(2*pi);
58 fzn = \omega_0 azn/(2*pi);
59 fzp = omegazp/(2 \nmid p);
60
61 Tp = Tpx*tf([1 omegazn-omegazp -omegazn*omegazp], [1 2*zeta*omega0 omega0^2]);
62 bode(Tp, {1e1, 1e6})
6364 %% Duty Cycle-to-Inductor Current Transfer Function Tpi
65 Tpix = (-\text{Vo}^*(\text{RL}+\text{r}C^*\text{D}^*\text{r}C))/(D^*\text{L}^*(\text{RL}+\text{r}C));66 Tpi0 = -Vo*(1+D)/(D*r+RL*(1-D)^2);
67 omegazi = (1+D)/(C*(RL+rC+D*rC));68 fzi = \omegagazi/(2 \pi \pi i);
69 Tpi = Tpix*tf([1 omegazi], [1 2*zeta*omega0 omega0^2]);
70 bode(Tpi, {1e1, 1e6})
71
72 %% Transfer Function of Filter and Non-inverting Amplifier Tf
\frac{1}{73} %normally 50% attenuation @ fs -> ftp = 0.575*fs
74 fpf = fs*sqrt((phitp^2)/(1-phitp^2));
75 Cf = 1/(2*pi*fpf*RF);
```

```
76 omegapf = fpf*2*pi;
\pi Tf = tf(1, [Rf*Cf 1]);
78 bode(Tf, {1e1, 1e6})
79
80 %% Transfer Function of Pulse-Width Modulator Tm
81
82 Tm = 1/VTm;
83 VCI = D*VTm:
84
85 RS = (VCI-VOFF)/IL;86 \quad \%[Rs] = V/A = currentsensor gain
87
88 %% Uncompensated Loop Gain Tki
89
90 Tki0 = (Rs/VTm)*(-Vo*(1+D))/(D*(r+RL*(1-D)^2));
91 Tki = Tm*Tpi*Rs*Tf;92 bode(Tki, {1e1, 1e6})
93
94 %% Transfer Function of Control Circuit for Inner-Current Loop Tci
95
96 omegac = fci*2*pi;
97
98 % Tkifc = 1.3228;
99 % PhiTkifc = -95.4;
100 [Tkifc,PhiTkifc] = bode(Tki,omegac);
101
102 phimi = PMi-PhiTkifc-90;
103
_{104} K = tand(phimi/2 + 45);
105
106 C2i = Tkifc/(omegac*x*R1i);107 C1i = C2i*(K^2-1);108 R2i = K/(omegac*C1i);
109
110 Tcio = 1/(R1i*(C1i+C2i));111 omegazci = 1/(R2i*C1i);
112 omegapci = (C1i+C2i)/(R2i*C1i*C2i);
113
114 Tci = Tcio * tf([1/\text{omegazci 1}], [1/\text{omegazoci 1 0}]);
115 bode(Tci, {1e1, 1e7})
116
117 %% Compensated Loop Gain of Inner-Current Loop Ti
118 Ti = Tki*Tci;
```

```
119 %Ti0 = (Rs/VTm) - ((Vo*(1+D))/(D*(r+RL(1-D)^{2})))*(1/(R1i*(C1i+C2i)));
120 bode(Ti, {2e1, 1e7})
121
122 %% Reference Voltage-to-Inductor Current Transfer Function Ticl
123
124 Ticl = (Tci*Tm*Tpi)/(1+Ti);125 bode(Ticl, {2e1, 1e7})
126
127 %% Reference Voltage-to-Output Voltage Transfer Function Tpicl
128
129 Tpicl = (Tci*Tm*Tp)/(1+Ti);130 bode(Tpicl, {2e1, 1e7})
131
132 %% Transfer Function of Feedback Network
133
134 beta = VRV/Vo;
135
136 %% Uncompensated Loop Gain Tkv
137
138 Tkv = beta * Tpicl;
139 bode(Tkv, {1e2, 1e7})
140
141 %% Transfer Function of Control Circuit for Outer-Current Loop Tcv
142
143 omegacv = fcv^*2*pi;
144
145 [Tkvfc, PhiTkvfc] = bode(Tkv, omegacv);
146 PhiTkvfc = PhiTkvfc-360;
147
148 phimv = PMv-PhiTkvfc-90;
149
150 Kv = \tan(\phi \frac{\sin v}{2} + 45);
151
152 C2v = Tkvfc/(omegacv*Kv*R1v);
153 CV = C2v * (Kv^2-1);154 R2v = Kv/(omegacv*C1v);
155
156 % C2V = 700e-9;157 % C1v = 3.5e-9;158 \quad \% R2v = 324e3;13.56u159
160
161 Tcvo = 1/(R1v*(C1v+C2v));
```

```
162 omegazcv = 1/(R2v*C1v);
163 omegapcv = (C1v+C2v)/(R2v*C1v*C2v);
164
165 Tcv = Tcvo * tf([1/megazcv 1], [1/megapcv 1 0]);166 bode(Tcv, {1e1, 1e7});
167
168 %% Compensated Loop Gain Tv
169
170 Tv = Tkv*Tcv;
171 bode(Tv, {1e2, 1e7});
172
173 %% Reference Voltage-to-Output Voltage Transfer Function Tpcl
174
175 Tpcl = (Tcv*Tpicl)/(1+Tv);
176 %bode(Tpcl, {1e2, 1e7});
177
178 %% Print Values
179
180 C1i
181 C2i
182 R2i
183
184 C1v
185 C2v
186 R2v
```
Listing 3: Average Current-Mode Regulator Calculations

```
1 % based on snva555
2 % https://www.ti.com/lit/an/snva555/snva555.pdf
3
4 %% Parameters
5
6 Vin = 5;
7 \text{ Vo} = 5;
8 \t Ro = 25;9 fs = 1000e3;
10
11 Ci = 10e-6;
12
13 L = 47e-6;
14 Rl = 100e-3; % Inductor series resistance
```

```
15
16 Gi = 20;
17 Rs = 100e-3; % Shunt resistor
18
19 Co = 20e-6;
20 Rc = 100e-3; % Output capacitor series resistance
21
22 fc = 30e3; % Crossover frequency
23 omega_fc = fc*2*pi;
24
25 PM = 60;
26
27 Io = Vo/Ro;
28
29 \quad Q = \frac{2}{pi};
30
31 VRamp = 3; % V
32
33 Gv = 3300; % 70 dB
34 GBW = 10e6;
35
36 gm = 13.56e-6;
37 R1i = 1/gm;
38
39 T = 1/fs;
40
41 %% Linear Model Coefficients
42 Vap = Vin + Vo;
43 D = \text{Vo}/(\text{Vin+Vo});
44 D_= 1-D;
45 R = Vo/Io;46
47 %% Buck-Boost Design Example – Control-to-Output
48 Ri = Gi * Rs;
49 Vsl =Vo*Ri*(T/L);
50
51 Km = 1/((0.5-D)*Ri*(T/L)+(Vsl/Vap));52 K = 0.5 * Ri * (T/L) * D * D_;
53 KD = 1+(Ro * D)/R+((Ro * D_2^2)/Ri)*(1/Km+K/D_);54
55 vo_vc = (Ro * D) / (Ri * KD);
56 vo_vc_dc = 20*log10(vo\_vc);
57
```

```
58 omega_p = KD/(Co*Ro);
59 omega_z = 1/(Co*RC);
60 omega_r = (R * D_2 / (L * D);
61 omega_L = (Km * Ri)/L;
62 omega_n =omega_L/Q;
63
64 fp = \text{omega\_p}/(2 \text{ *pi});65 fz = \text{omega}_2/(2 \text{Npi});
66 fr = \text{omega}_r/(2 \text{pi});
67
68 f1_Q = (1/(4*T*Q))*(\text{sqrt}(1+4*Q*Q)-1);69
70 tf_p = tf(1, [1/omega_p 1]);
71 tf_r = tf([(-1/omega_r) 1], 1);
72 \text{ tf}_z = tf([1/omega_z z_1], 1);\tau_3 tf_n = tf(1,[1/(omega_n^2) 1/(omega_n<sup>*</sup>Q) 1]);
74
75 %% Uncompensated Loop Gain
v_0 vo_vc_tf = ((Ro * D_-)/(Ri * KD))*tf_r * tf_z * tf_p * tf_n;77
78 %subplot(2,1,1);
79 bode(vo_vc_tf, {1e1, 1e7})
80
81
82
83 %% Transfer Function of Control Circuit for Outer-Current Loop
84 [Gfc, Phifc] = bode(vo_vc_tf, omega_fc);
85
86 Phifc = Phifc-360;
87 PM_max = 180 +Phifc
ss phim = PM-Phifc-90;
89
90 K = \tan(\phi \frac{\theta}{m/2} + 45);
91
92 \quad \text{\%R1i} = 3740;
93 C2i = Gfc/(omegaga_fc*K*R1i);94 Cli = C2i*(K^2-1);
95 R2i = K/(omega_5 \text{-(}C*)^2);
96
97 % R1i = 3740;
98 % C2i = 10e-12;
99 % C1i = 6.8e-9;
100 % R2i = 8.2e3;
```

```
101
102 Tcio = 1/(R1i*(C1i+C2i));103 omegazci = 1/(R2i*C1i);
104 omegapci = (C1i+C2i)/(R2i*C1i*C2i);
105
106 Tci = Tcio * tf([1/\text{omegazci 1}], [1/\text{omegazci 1 0}]);
107 %subplot(2,1,2);
108 bode(Tci, {1e1, 1e7})
109
110 %% Compensated Loop Gain Tv
111 %subplot(3,1,3);
112 bode((Tci*vo_vc_tf), {1e1, 1e8})
113
114 %[fc_real, phi_real] = bode((Tci*vo_vc_tf), omega_fc)
115
116 %% Print Values
117
118 C1i
119 C2i
120 R2i
121
122
123
```
Listing 4: Peak Current-Mode Regulator Calculations