### RENESAS

# ne GreenPAK<sup>TM</sup> ookpook



**Introduction to GreenPAK** 

Basic Blocks
Functions

2. Sequential

Conditioning

4. Safety

**Communication Protocols** 

6. Pulse-based Control

Renesas Electronics GreenPAK ICs are a family of Programmable Mixed-signal ICs that provide a small, costfriendly, and personalized solution to common problems that system-level circuit designers face. GreenPAK provides a means of considerably reducing PCB size, BOM cost, and design time.





### Design reduced by

- 5 IC
  - 2 NMOS transistors
- 14 passive components

Example of Size Reduction w/ GreenPAK

Due to the features and configurability of GreenPAK narrowing the scope of possible applications can be difficult.

With the right motivation a designer can use a GreenPAK in almost any application within most industries. This document is designed to bolster this motivation and know-how: we provide a "cookbook" to designers to highlight where a GreenPAK can be used within their projects. We outline different techniques and provide completed applications to help designers use GreenPAK on their own.

### **Cookbook Structure**

The majority of subsections within this document are organized into two categories: Techniques and Applications. Techniques focus on a task accomplished using only one or a few macrocells. Application sections describe how techniques can be meshed together to create real, valuable applications. Generally, the easiest techniques and applications will be at the beginning of a chapter.

Each application has an associated GreenPAK Designer file that can be viewed and edited.

9. Advanced

7. Power Management

### 2. Sequential Logic

.Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

. Communication Protocols

6. Pulse-based Control

### Making Your Own Design With the Cookbook

The applications outlined in the Cookbook are simple realizations of real-world applications. However, GreenPAK ICs have the macrocells and functionality to add far more value than the designs in this cookbook. Renesas Electronics has helped designers create thousands of unique designs, where simple applications both similar and different to the cookbook applications were expanded, combined, and personalized.

For example, the <u>Application: Basic Sequencer</u> can be combined with many of the applications within <u>Chapter 4: Safety Features</u> to create a self-regulating, customized sequencing application.



Overtemperature Detection

The resulting integrated solution is more complex yet still doesn't incorporate all available macrocells. With the full GreenPAK family of ICs at your disposal, the number of permutations and modifications available for the designs in this cookbook are endless. Whether you wish to completely reuse a design shown in this cookbook, or you'd rather incorporate some of the techniques in this paper into your own design, feel free. After all, it's your recipe.



2. Sequential

3. Signal Conditioning

4. Safety Features

5. Communication Protocols

6. Pulse-based Control

7. Power Management

### **Table of Contents**

| Contents                                                    |    |
|-------------------------------------------------------------|----|
| Introduction to GreenPAK                                    | 2  |
| Cookbook Structure                                          | 2  |
| Making Your Own Design With the Cookbook                    | 3  |
| Chapter 1 Basic Blocks & Functions                          | 8  |
| Technique: Learning More About a Macrocell                  | 9  |
| Overview: Digital Macrocells                                | 9  |
| Technique: Configuring Standard Logic w/ LUT Macrocells     | 10 |
| Overview: Oscillators                                       | 10 |
| Overview: Analog Comparators                                | 10 |
| Overview: I/Os                                              | 11 |
| Overview: Interconnections                                  | 11 |
| Technique: Simulation and Emulation Using GreenPAK Designer | 12 |
| Technique: GreenPAK Programming                             | 13 |
| Technique: OE Pin                                           | 14 |
| Application: Parity Bit Generator                           | 15 |
| Application: 8-bit Multiplexer                              | 16 |
| Application: Demultiplexer                                  | 17 |
| Technique: Changing I2C Address                             | 18 |
| Chapter 2 Sequential Logic                                  | 19 |
| Technique: Optimizing CNT/DLY Accuracy                      | 20 |
| Technique: Sequencing CNT/DLY Blocks                        | 21 |
| Application: System Reset                                   | 22 |
| Application: Several Button Reset                           | 23 |
| Application: Basic Sequencer                                | 24 |
| Application: Cascaded Sequencer                             | 25 |
| Application: Voltage Monitoring Power Sequencer             | 26 |
| Application: Ship Mode Controller                           | 27 |
| Technique: Creating a Synchronous State Machine from an ASM | 28 |
| Application: N-Length Bitstream                             | 29 |
| Technique: Multiplexing a Bitstream                         | 30 |
| Application: 10 Year Counter                                | 31 |
| Application: Square Wave Generator                          | 32 |
| Application: Two Event Button Press                         | 33 |
| Chapter 3 Signal Conditioning                               | 34 |
| Technique: Using a CNT/DLY Block as a Deglitch Filter       | 35 |
| Technique: Edge Detector                                    | 36 |
| Application: Interrupt Controller                           | 37 |
| Technique: Creating a Bi-directional Counter                | 38 |
| Application: Encoder                                        | 39 |
| Application: Distance Sense                                 | 40 |
| Application: Frequency Range Detector                       | 41 |
| Application: Frequency Divider                              | 42 |
| Technique: Zero-Voltage Cross Detection                     | 43 |

Analog Features

9. Advanced

2. Sequential Logic

3. Signal Conditioning

4. Safety Features

5. Communication Protocols

6. Pulse-based Control

7. Power Management

8. Motor Control

9. Advanced

| Application: Analog Storage Element                                     | 44 |
|-------------------------------------------------------------------------|----|
| Chapter 4 Safety Features                                               | 45 |
| Technique: Reducing ACMP Power Consumption                              | 46 |
| Technique: Wake-Sleep Controller                                        | 47 |
| Application: Window Comparator                                          | 48 |
| Application: Over Temperature Protection                                | 49 |
| Application: Battery Charge Indicator                                   | 50 |
| Application: Low Voltage Indicator for Infotainment                     | 51 |
| Application: Watchdog Timer                                             | 52 |
| Application: Voltage Level Detection                                    | 53 |
| Application: Power Backup Management                                    | 54 |
| Application: N-pulse Presence Watchdog                                  | 55 |
| Technique: Using the Temperature Sensor Block                           | 56 |
| Application: Current Detection Through External Sense Resistor          | 57 |
| Application: Monitor Four Levels for One Analog Signal With One MS ACMP | 58 |
| Application: Monitor Four Separate Analog Signals With One MS ACMP      | 59 |
| Chapter 5 Communication Protocols                                       | 60 |
| Technique: Changing Your Design with I2C                                | 61 |
| Technique: Creating an I2C command                                      | 62 |
| Technique: Using the Serial to Parallel Interface (SPI) Block           | 63 |
| Technique: Level Shifting                                               | 64 |
| Technique: Sending a Preset Number of Pulses                            | 65 |
| Technique: Building a Shift Register                                    | 66 |
| Application: I2C GPIO Expansion                                         | 67 |
| Application: Serial to Parallel (External Clock)                        | 68 |
| Application: Serial to Parallel (Internal Clock)                        | 69 |
| Application: Parallel to Serial                                         | 70 |
| Application: Bi-Directional Communication (Transmit First)              | 71 |
| Application: Bi-Directional Communication (Receive First)               | 72 |
| Application: 7-Segment Display Using ASM and I2C                        | 73 |
| Application: Communication MUX Using I2C                                | 74 |
| Application: I2C Level Shifter                                          | 75 |
| Application: Connection Detect                                          | 76 |
| Application: Custom Pattern Generator                                   | 77 |
| Technique: Sending Serial Protocols Using Duty Cycle Detection          | 78 |
| Technique: Reading Serial Protocols with a Shift Register               | 79 |
| Technique: Reading Serial Protocols with a Pipe Delay                   | 80 |
| Technique: Using the Digital-to-Analog Converter (DAC)                  | 81 |
| Technique: EPG                                                          | 82 |
| Application: I2C Master Read Command with ACK Check and Data Comparison | 83 |
| Application: I2C Master Write Command with ACK Check                    | 84 |
| Application: I2C Programable Pattern Generator Using Shift Registers    | 85 |
| Application: Long Length Pattern Using EPG                              | 86 |
| Application: Basic SPI Master                                           | 87 |
| Chapter 6 Pulse-based Control                                           | 88 |
| Technique: Setting a Constant Duty Cycle                                | 89 |

5

RENESAS

### The GreenPAK Cookbook

| Technique: One Shot Implementation                                                   | 90  |
|--------------------------------------------------------------------------------------|-----|
| Application: Constant Current LED Driver                                             | 91  |
| Application: RGB LED Control via I2C                                                 | 92  |
| Technique: Creating a Breathing LED Pattern                                          | 93  |
| Application: Breathing RGB LED                                                       | 94  |
| Application: Breathing RGB LED Control with I2C                                      | 95  |
| Technique: Using DCMP/PWM Macrocell in PWM Mode                                      | 96  |
| Application: PWM Selection                                                           | 97  |
| Application: PWM Generator Using ACMP and DAC                                        | 98  |
| Application: PWM Generator Using ADC                                                 | 99  |
| Technique: Duty Cycle Detection                                                      | 100 |
| Application: Frequency to Analog Voltage Converter                                   | 101 |
| Application: Frequency to Duty Cycle Converter                                       | 102 |
| Application: Linear Frequency Modulation                                             | 103 |
| Application: Voltage-Controlled Oscillator                                           | 104 |
| Chapter 7 Power Management                                                           | 105 |
| Technique: Output Discharge                                                          | 106 |
| Application: Charge Pump                                                             | 107 |
| Application: Two-Stage Charge Pump                                                   | 108 |
| Application: Charge Pump with Output Regulation                                      | 109 |
| Technique: Using the LDO Regulators                                                  | 110 |
| Application: Flexible Power Island                                                   | 111 |
| Application: Boost (Step-up) Converter                                               | 112 |
| Application: Buck (Step-down) Converter                                              | 113 |
| Application: Back-to-Back Reverse Current Blocking                                   | 114 |
| Technique: Remote Sense Functionality                                                | 115 |
| Technique: LDO Explained                                                             | 116 |
| Technique: Delay Macrocells                                                          | 117 |
| Technique: Crash Sequence Block                                                      | 118 |
| Technique: GPIOs Features                                                            | 119 |
| Technique: Protection Features                                                       | 120 |
| Technique: Power Sequencer Explained                                                 | 121 |
| Technique: SLG51002 HC LDOs Auto Bypass Mode Explained                               | 122 |
| Technique: SLG51002, SLG51003 I2C Control Code Selection                             | 123 |
| Technique: SLG5100x Device Interrupt Request Block                                   | 124 |
| Application: Scenario of Two Independent Sequences Using the SLG51002                | 125 |
| Application: Powering Two Cameras with Sequencer and Two Scenarios for the SLG51000C | 126 |
| Application: SLG51002/3 I2C Address Configuration without                            | 127 |
| Reprogramming                                                                        | 127 |
| Chapter 8 Motor Control                                                              | 128 |
| Application: H-Bridge Control                                                        | 129 |
| Technique: Using the HV OUT CTRL Blocks                                              | 130 |
| Technique: Using the SLG47105 PWM Blocks in Regular Mode                             | 131 |
| Technique: Using the SLG47105 PWM Blocks in Preset Registers Mode                    | 132 |
| Application: Constant Voltage Brushed DC Motor Driver                                | 133 |
| Application: Constant Current Brushed DC Motor Driver                                | 134 |

### The GreenPAK Cookbook



| Application: Constant Current Using the PWM Chopper           | 135 |
|---------------------------------------------------------------|-----|
| Application: Unidirectional DC Motor Control with Soft ON/OFF | 136 |
| Application: Push-to-Start/Hold-to-Stop                       | 137 |
| Application: Bipolar Stepper Motor Driver                     | 138 |
| Chapter 9 Advanced Analog Features                            | 139 |
| Application: Adjustable Active Filter Using OpAmp             | 140 |
| Application: Adjustable Inverting OpAmp                       | 141 |
| Application: Adjustable Non-Inverting Op Amp                  | 142 |
| Application: Instrumentation Amplifier                        | 143 |
| Application: Voltage Follower Using OpAmp                     | 144 |
| Application: Current Sink Using OpAmp and N-channel FET       | 145 |
| Application: Auto-Trim                                        | 146 |
| Application: Current Source Using OpAmp and P-channel FET     | 147 |
| Application: Voltage Regulator Using OpAmp                    | 148 |
| Technique: Using Chopper ACMP with Digital Rheostats          | 149 |
| Application: Sample and Hold Circuit                          | 150 |
| Application: Finding Maximum Point of Input Voltage           | 151 |
| Technique: Using Power Controller in the SLG47011             | 152 |
| Application: Waveform Generator Using Memory Table            | 153 |
| Technique: ADC Calibration Procedure                          | 154 |
| Application: Signal Generator Using Memory Table              | 155 |
| Application: Signal Modulation Using MathCore (PWM)           | 156 |
| Application: Signal Modulation Using MathCore                 | 157 |
| Application: DC Power Measurement                             | 158 |
| Application: 4 Channel ADC Measurement with Data Buffer Table | 159 |
| Application: Analog to Parallel Converter                     | 160 |
| Technique: MathCore Usage                                     | 161 |
| Application: Frequency Multiplier                             | 162 |
| Application: Arithmetic Operation f(x)=kx+b                   | 163 |
| Application: ADC with Memory Table in Storage Mode            | 164 |
| Technique: Multichannel DCMP                                  | 165 |
| Technique: Reading/Writing Data via SPI                       | 166 |
| Technique: Different Modes in PGA                             | 167 |
| Technique: Using Data Buffer                                  | 168 |
| Application: ADC ON/OFF Function                              | 169 |
| Technique: ADC Delay Between Channels                         | 170 |

1.Basic Blocks & Functions

2. Sequential Logic

3. Signal Conditioning

4. Safety Features

5. Communication Protocols

6. Pulse-based Control

7. Power Management

8. Motor Control

9. Advanced Analog Features



## Chapter 1 Basic Blocks & Functions

This chapter introduces many of the basic building blocks found in the GreenPAK that will be used throughout the Cookbook. It will also present a few simple combinational logic designs that utilize look-up tables (LUTs).

Basic Blocks & Functions

### 2. Sequential Logic

1.Basic Blocks Functions

### 3. Signal Conditioning

### 4. Safety Features

### Communication Protocols

### **Technique: Learning More About a Macrocell**

This technique works with any version of GreenPAK Designer.

While using GreenPAK Designer you may wish to learn more about a specific macrocell. This can be done by selecting the macrocell in the GreenPAK Designer, then clicking the Information button at the bottom-left of the Properties window.



**Info Button** 

### **Overview: Digital Macrocells**

Digital Macrocells are the basic functional components of any GreenPAK. They include:

Common Digital Macrocells:

- Look-Up Table (LUT)
- D Flip-Flop (DFF) / Latch
- Counter / Delay (CNT/DLY)

#### Communication:

- I2C (many devices)
- SPI (select devices)

### Less Common:

- Pattern Generator (PGEN)
- Pipe Delay
- Programmable delay (PDLY)
- Filter / Edge Detector



**Digital Macrocells** 

Many of the components in GreenPAK Designer can be configured to be one of multiple types of macrocells. This is indicated by the name of the digital macrocell: for example, 2-bit LUTO/DFF/LATCHO can be, as the name implies, a LUT, DFF, or Latch. The selection of macrocell type is configured using the Type option in the Properties window.

# 1.Basic Blocks &

**Functions** 

2. Sequential

Conditioning

4. Safety

Communication **Protocols** 

6. Pulse-based Control

Management 7. Power

### Technique: Configuring Standard Logic w/ LUT Macrocells

This technique works with any GreenPAK.

Look-up tables are used in GreenPAK Designer to configure any digital logic for a two, three or four input, single output logic macrocell. The logic configuration is edited in the Properties window.

Most logic implemented in GreenPAK designs is standardized logic, such as MUX, AND, OR, etc... To expedite these common configurations, the Properties window has a Standard gates option that automatically convert the logic table into a standard gate configuration. If the Regular shape option is left unchecked the LUT shape will change to the standardized gate symbol.



**Config for 3-bit LUT0** 

### **Overview: Oscillators**

GreenPAK ICs contain at least two oscillators. Many GreenPAKs, such as the SLG46826, have three oscillators. The most common, non-divided frequencies of the oscillators within GreenPAK are:

- 2KHz low speed, low power oscillator
- 2MHz medium speed
- 25MHz high speed

Each oscillator has several outputs, each with several pre-dividers to allow flexibility in clocking. To save power Auto-power on allows you to turn off the oscillator when the clock is not needed.

More information about oscillators can be found by using the Information button when the component is selected.



**Oscillators** 

### **Overview: Analog Comparators**

Almost every GreenPAK is equipped with two or more analog comparators [ACMPs], each with two input sources; IN+ and IN-. The input source to each is configured in the Properties window.

More information about analog comparators can be found by using the Information button when the component is selected.



**ACMPs** 

### Overview: I/Os

I/Os within GreenPAK are very flexible. The I/O capabilities vary from pin to pin and part to part, so a design should be mapped to the necessary pin configuration before choosing a specific GreenPAK.

Outputs can configure to be Push-pull or opendrain in either a NMOS or PMOS configuration. A scaling factor, such as 2x, indicates that the output strength is doubled.

Additionally, pull-up and pull-down resistor options of  $10k\Omega$ ,  $100k\Omega$ , and  $1M\Omega$  are available on output pins.

Multiple input options are available as well, such as: Digital-In, Digital-In with Schmitt trigger, Low Voltage Digital-In and Analog-In. Analog in is used as an input to an ACMP.

# Push-pull (1x) Open Grain (1x) Push-pull (2x) Push-pull (2x) Push-pull (2x) Res\_set(10) Open drain (2x) Open drain (2x)

Typical I/O Structure

### **Overview: Interconnections**

Interconnection with GreenPAK Designer is easy. The system will guide you on which connections you can make. When you click on any connection point, the system:

- Highlights all available connections in green
- Gives you a "rubber band" connection that you can stretch to any of these green connection
- This results in a green wire to show you interconnections you have made



Interconnections

9. Advanced Analog Features

Sequential

Conditioning

. Safety

Communication

6. Pulse-based

Control

Management

**Protocols** 

### Technique: Simulation and Emulation Using GreenPAK Designer

Emulation is available for all GreenPAK parts and Simulation is available on many GreenPAK ICs.



Toolbar

When developing a design, it is important to be able to quickly test the functionality. GreenPAK Designer makes debugging effective and easy.

There are two ways to quickly check your design:

- 1. Simulation
- 2. Emulation

Simulation simulates the operation of the circuit in conditions depictive of reality without the need of a physical IC. It should be kept in mind that simulation can't provide for all the nuances of a real-world system.

Emulation allows, with the presence of a demo board and the GreenPAK chip, to check the operation of your design directly in the hardware without permanently programming a part. This allows you to quickly make changes to the project and use your emulation to check your guesswork.

- 1. If the design is ready for debug select the Debug button (boxed in red in the figure above) to go to the emulation/simulation selection
- menu.
- 2. Next, select the platform with which you want to check your design.
- 3. After selecting a platform, go to the debug menu, where further actions will be suggested depending upon the platform you choose.
- 4. If you need to change the platform, you can do this at any time by selecting Change platform.





**Debugging Menu** 

Platform Selection Menu

9. Advanced Analog Features

### **Technique: GreenPAK Programming**

Debugging control is available for all GreenPAKs.



### Toolbar in GreenPAK Designer

When developing a design, it is important to be able to quickly test the functionality. GreenPAK Designer makes debugging effective and easy.

### **Change platform**

Select the type of hardware platform with the supported features.

### **Import configuration**

Import user configuration of test points from other platforms.

### **Device**

Allows a user to work with an external chip on a specified device address.

#### **I2C Reset**

Suppose I2C serial communication is established with the device. In that case, it is possible to reset the device to initial power-up conditions, including the configuration of all macrocells and all connections provided by the Connection Matrix. This is implemented by setting the register I2C reset bit to "1", which causes the device to re-enable the Power-On Reset (POR) sequence, including the reload of all register data from NVM.

#### **Emulation**

- Emulation of the current project will be loaded to the chip (but not programmed) and will be ready for a test on the hardware board.
- Emulation (sync).In addition to Emulation, each change made in the project will be immediately loaded onto the chip.

#### Test mode

Test mode is used for connecting or disconnecting the chip's I/O pads to TP controls configured by a user. Also, a user can check a programmed chip using the test mode without emulation. To do this: turn on the test mode and internal VDD button. The test mode can work without power on the chip. The user will control the power manually.

#### Read

Read chip data using the hardware board.

#### **Program**

Program chip with the current project. For some chip models, a user can configure the programming process by clicking the Programming options at the Program button. Available programming options:

- Program NVM (Program the chip's NVM)
- Program EEPROM (Program the chip's EEPROM)

### **Project Data**

The table of NVM and EEPROM (available for specific chip revisions) bits.



Typically, GreenPAK I/O are configured as an input or output. Output enable (OE) pins are select pins within most GreenPAK that allow the pin to dynamically change between a Digital input and Digital output. When the OE GPIO is set as a permanent input the OE pin is set to ground and if the GPIO is set as a permanent output the OE pin is set to VDD. Setting the GPIO as a "Digital input/output" allows for this selection to be made in the matrix.



Setting a GPIO as a digital input/output allows for two-way communication. It also allows for the GPIO to be set to Hi-Z in addition to a logical high and low.

If the GPIO is used for two-way communication, it's important to implement a timing circuit for OE selection. In the example circuit below the OE pins of CLK\_IO and Data\_IO are switched from low to high after CNT2 sees 8 clocks, consequently setting the OE pins as outputs to transmit the internal signals. After another 8 clocks the OE pins are reset low, setting them as inputs again to receive an external signal.



2. Sequential Logic

Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

**Communication Protocols** 

6. Pulse-based Control

7. Power Management

### **Application: Parity Bit Generator**

Parity Bit Generators are used to check the integrity of a signal; it is the simplest implementation of a Cyclic Redundancy Check (CRC). Parity Bits are used prior to committing data to an MCU or other control unit to ensure the incoming data hasn't been corrupted.

### **Ingredients**

- Any GreenPAK
- No other components are needed

#### SLG46826 PIN 1 (VDD1) PIN 20 PIN 2 **PIN 19** INO [ PIN 3 IN1 ( **PIN 18** PIN 4 **PIN 17** □ ENABLE IN2 PIN 5 **PIN 16** IN3 PIN 6 **PIN 15** (VDD2) PIN 14 PIN 7 IN5 [ PIN 8 PIN 13 PIN 9 **PIN 10** (GND) PIN 11 ODD ( GND

### **GreenPAK Diagram**



- Connect input pins using XOR gates using <u>Technique</u>: <u>Configuring Standard Logic w/ LUT Macrocells</u>. XOR gates are used to calculate the running sum of 1's.
- 2. Add logic for the ENABLE signal.

### **Application: 8-bit Multiplexer**

A Multiplexer, or MUX, is used to select an output from multiple input signals. This is used in applications where several communication lines need to be sent across a single line. By using a GreenPAK as a MUX the latency time in transmission can be in nanoseconds, comparable to discrete logic IC's.



### **Ingredients**

- Any GreenPAK
- No other components are needed

### **GreenPAK Diagram**



- 1. Connect input pins to 4 LUT's configured as multiplexers using <u>Technique</u>: <u>Configuring Standard Logic</u> <u>w/ LUT Macrocells</u>. INx should connect to A or B, SELO should connect to S on all 4 mux's.
- 2. Add second and third stage cascading multiplexer blocks to create the more significant SEL bits.
- 3. Add an output pin connected to the last-stage multiplexer.

### **Application: Demultiplexer**

A demultiplexer is used to select which of several channels is sent an input signal. A demux is used in applications where it is needed to send several different types of data across one line and is commonly found in communication systems.



### **Ingredients**

- Any GreenPAK
- No other components are needed

### **GreenPAK Diagram**



- 1. Configure input pins for a signal input (IN), two select lines (SELx) and four output pins (OUTx).
- 2. Configure the LUTs to each pass the signal from IN upon a specific logic input on the select lines. For example, 3-L3 will be HIGH when SELO, SEL1 and IN are HIGH.

### 2. Sequential

1.Basic Blocks **Functions** 

Conditioning

4. Safety

Communication **Protocols** 

### **Technique: Changing I2C Address**

This technique describes the I2C address selection options for the SLG46855 device. The I2C Serial Communication Macrocell allows flexible configuration of its slave address (Control Code), providing two distinct methods for address selection:

### 1. Register-Based Address Selection (Default)

By default, the 4-bit I2C Control Code is sourced directly from an internal configuration register. This method is typically used when the I2C slave device will operate with a fixed, predefined address set during programming.

### Advantages:

- 1.1. Fixed and predictable address.
- 1.2. Suitable for systems with a single I2C slave or where address conflicts are unlikely.
- 1.3. Simpler hardware setup—no additional pins required for address selection.

### 2. External Pin-Based Address Selection

Alternatively, each bit of the I2C Control Code can be sourced from external GPIO pins (PIN 2, PIN 5, PIN 9, and PIN 10). When external addressing is enabled, the binary value of the address is determined by the voltage levels on these pins at runtime:

- PIN 2 Least Significant Bit (LSB)
- PIN 10 Most Significant Bit (MSB)

### **Advantages:**

- 2.1. Provides flexibility to change the I2C address without reprogramming the device.
- 2.2. Enables easy integration of multiple identical devices on the same I2C bus by assigning unique

addresses via hardware configuration (e.g., pull-up/pull-down resistors).

2.3. Useful in modular or configurable systems where address conflicts might occur.

Note: This feature is specific to the SLG46855. Not all Renesas GreenPAK or AnalogPAK devices support external I2C address configuration. Always consult the product Datasheet to verify whether this feature is available for the specific chip you are using.





# **Chapter 2 Sequential Logic**

This chapter presents applications that involve sequential logic. Some sequential logic applications are counters, system reset circuits, power sequencers, and state machines

3. Signal Conditioning

1.Basic Blocks & Functions

2. Sequential

4. Safety Features

5. Communication Protocols

6. Pulse-based Control

7. Power Management

### **Technique: Optimizing CNT/DLY Accuracy**

This technique works with any GreenPAK. The accuracy of the oscillator and CNT/DLY blocks vary from part-to-part.

GreenPAK ICs, like all chips with internal oscillators, have inherent variation in timing. This is attributed to factors like manufacturing, temperature and, in the case of GreenPAK, user design practices. By using simple design principles the accuracy of counters and delays within a GreenPAK design can be improved.

The relationship between the oscillators and CNT/DLY blocks should be considered. The oscillators are global oscillators; they are used for any number of CNT/DLY blocks and aren't initially synchronized to the start/stop of a delay or counter. Consequently, when a counter or delay is enabled it will only begin to increment on the next clock edge. This is depicted in figure below, where an enable signal for a delay is activated mid-clock-cycle and doesn't begin to decrement until the next rising edge.



**Behavior of Rising Enable for Delay** 

This is factored into the typical delay time calculation for the CNT/DLY blocks:

where t is between 0 and 1

Thus, as the value of "Counter\_Data" increases, the influence of "t" on the delay time will be proportionately less. Additionally, the absolute value of the delay time is kept the same, despite using a larger "Counter\_Data" value, if a faster "clock" value is used. In the Properties window of the selected CNT/DLY block both the Counter Data value and the Clock Source can be modified.

Additionally, the timing characteristics within the datasheet of the respective GreenPAK should be referenced to ensure factors such as Power-ON time, frequency settling time and percent deviation across temperature are considered.

### 2. Sequential Logic

1.Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

**Communication Protocols** 

### **Technique: Sequencing CNT/DLY Blocks**

This technique will work with any GreenPAK.

Delay blocks can be chained together to sequence signals. By chaining the output of one delay block to the input of another a sequential set of delays is made.



**Sequential Rising Edge Delays** 

The CNT/DLY blocks in the sequential set should be set to "Delay" in the Mode setting within the Properties window. Typically, the Edge select setting should be the same for all sequenced components. The figure below shows the effect of the two sequential CNT/DLY blocks set to rising edge, 8ms delays of the Power-On-Reset (POR) signal.



**Sequential Delay Simulation** 

One can also chain together CNT blocks for a longer counted time. When Chaining CNT blocks together, the CLK of the CNT should be driven by the output of the previous counter. This is done in the properties by selecting a CNT block and in the Properties window, choosing the Clock connection to be sourced from the previous CNTx/DLYx.



**Sequential Counters** 

PIN 20

PIN 1

PIN 18

PIN 17

PIN 16

PIN 15

**PIN 13** 

PIN 1

SLG46826

PIN 1 (VDD1)

PIN 2

PIN 3

PIN 4

nWD [

Basic Blocks & **Functions** 

SOC

nRESET

### **Application: System Reset**

System Reset ICs are used to provide a reset to a microprocessor during faults, manual resets, brown-outs and more.

### PIN 5 PIN 6 PIN 7 PIN 8 PIN 9

### **Ingredients**

- Any GreenPAK
- No other components are needed

### **GreenPAK Diagram**



- 1. Configure an I/O as an input for each input signal.
- 2. Add LUT logic to create a HIGH signal when any of the lines are active. The logic is dependent on whether each signal is active-high or active-low.
- 3. Configure a CNT/DLY block to "One shot" mode, with Edge select configured to "Rising." Set the Counter data to create the desired length of pulse. For an active-low pulse change the Output polarity to "Inverted (nOUT)."
- 4. Connect the CNT/DLY block's output to an output pin.

I.Basic Blocks Functions

### **Application: Several Button Reset**

Pressing and holding several buttons to initiate a hard reset is a common interface in many devices. Implementing this application in a separate IC ensures the reset will be acknowledged and acted upon, even if the rest of the system is experiencing one or more software, firmware, or hardware issues.



### **Ingredients**

- Any GreenPAK
- No other components are needed

### **GreenPAK Diagram**



- 1. Configure an I/O as an input for each button.
- 2. Add LUT logic to create a HIGH signal when both buttons are active. The logic is dependent on whether each signal is active-high or active-low.
- 3. Configure a CNT/DLY block to "Delay" mode, with Edge select configured to "Rising". Set the Counter data to create the desired length of button hold time. For an active-low pulse change the Output polarity to "Non-inverted (OUT)."
- 4. Configure a second CNT/DLY block to "One shot" mode, with Edge select configured to "Rising." Set the Counter data to create the desired length of pulse. For an active-low pulse change the Output polarity to "Inverted (nOUT)."
- 5. Connect the CNT/DLY block's output to an output pin

### **Application: Basic Sequencer**

Sequencers are used when a designer needs to sequentially activate different portions of a system. This is critical for applications that require several power rails.



### **Ingredients**

- Any GreenPAK
- No other components are needed

### **GreenPAK Diagram**



- 1. Use LUTs to configure the desired start-up condition.
- 2. Use a latch or DFF to maintain the start-up signal so it can be read by DLY blocks.
- 3. Chain the Delays using Technique: Sequencing CNT/DLY Blocks.
- 4. Connect each delay channel to the desired output pins.

### **Application: Cascaded Sequencer**

Sequencers are used when a designer needs to sequentially activate different portions of a system. It is typical to have a cascaded sequence, such that a rail does not turn off until all the rails below it have turned off.



### **Ingredients**

- Any GreenPAK
- No other components are needed

### **GreenPAK Diagram**



- 1. Configure input structure. Here you can select between level and latching control with PIN17.
- 2. Multiplex inputs to DLYs within a Multi-function block to achieve a cascaded effect.
- 3. Connect the DLY outputs to push pull output pins.

### LOG

2. Sequential Logic

Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

Protocols

6. Pulse-based Control

7. Power Management

9. Advanced Analog Features

### **Application: Voltage Monitoring Power Sequencer**

Sequencers are used when a designer needs to sequentially activate different portions of a system. It is typical to have a cascaded sequence, such that a rail does not turn off until all the rails below it have turned off.



- Any GreenPAK with 3 ACMPs
- Six resistors

### **GreenPAK Diagram**





- 1. Configure input pins for the EN and voltage monitoring.
- 2. Configure output pins to sequence system.
- 3. Power on ACMPs, connecting POR to PWR UP and configure the IN- source of each with the desired voltage threshold levels.
- 4. Configure DLYs with the desired delay times.
- 5. Configure LUTs with the proper logic functions.



### **Application: Ship Mode Controller**

An ultra-low power button monitor can save battery life while a product is not yet with the end user. This enables a better first experience by the user.



### **Ingredients**

- Any GreenPAK
- External PMOS load switch

### **GreenPAK Diagram**



- 1. Configure PIN2 as an input with  $1M\Omega$  pullup.
- 2. Set desired Button delay time in CNT1/DLY1.
- 3. Modify LUT contents for correct polarity in and out of ship mode.

### Technique: Creating a Synchronous State Machine from an ASM

Synchronous state machines (SSM) transitios on the edge of an incoming clock if the transition condition is met. The generic approach to convert a GreenPAK Asynchronous State Machine (ASM) macrocell into a SSM uses a clock signal with a pulse width greater than the ASM transition time.





Consider the SSM in the 3-bit counter example above. CNT2 and 2-bit LUT1 are used to generate the clock. The ASM uses 8 states connected in series. 2-bit LUT0 and 2-bit LUT3 are used to prevent a logic high signal on two near state transitions. The value of the ASM output for every state is shown below.



The ASM changes from the reset state (State 0) to the next state (State 1) when PIN6 goes high. The following transitions through the states occur as CNT2 toggles first high, then low, and so on.

For more a detailed information about the process of creating an SSM with the ASM see <u>AN-1126 ASM to Synchronous Conversion</u>.

### **Application: N-Length Bitstream**

A bitstream is a sequence of bits transmitted continuously over a communications path. The GreenPAK can create a repeating string of up to 64 bits.

### **Ingredients**

Any GreenPAK with an ASM



### **GreenPAK Diagram**





- 1. Configure a generator and 8-bit Multiplexer using Application: 8-bit Multiplexer.
- 2. Configure CNT1 to determine the length of the bitstream.
- 3. Configure the ASM using Technique: Creating a Synchronous State Machine from an ASM.
- 4. Connect the outputs of the 8-bit multiplexer and generator to the desired output PINs.
- 5. The length of the bitstream (counter data of CNT1) can be changed using I2C.
- 6. The DATA stored in the ASM output RAM can be changed using I2C.

### **Technique: Multiplexing a Bitstream**

This technique can be used in any GreenPAK.

GreenPAKs are often used to transfer a data pattern. If the data is transferred from the GreenPAK or the data is transmitted along several lines from the SoC, they must be amalgamated for transmission on one line. Below is an example of the GreenPAK multiplexing a bitstream originating from the ASM output RAM.



The generator circuit is shown above. The generator implements the operation of the CLK line for the synchronous data transmission, enabled by the EN signal. The generator also implements the multiplexer operation algorithm for the correct combination of the transmitted data on one line.



| IN3 | IN2 | IN1 | INO | OUT |
|-----|-----|-----|-----|-----|
| 0   | 0   | 0   | 0   | 0   |
| 0   | 0   | 0   | 1   | 1   |
| 0   | 0   | 1   | 0   | 0   |
| 0   | 0   | 1   | 1   | 1   |
| 0   | 1   | 0   | 0   | 0   |
| 0   | 1   | 0   | 1   | 0   |
| 0   | 1   | 1   | 0   | 1   |
| 0   | 1   | 1   | 1   | 1   |
| 1   | 0   | 0   | 0   | 0   |
| 1   | 0   | 0   | 1   | 0   |
| 1   | 0   | 1   | 0   | 0   |
| 1   | 0   | 1   | 1   | 0   |
| 1   | 1   | 0   | 0   | 0   |
| 1   | 1   | 0   | 1   | 0   |
| 1   | 1   | 1   | 0   | 0   |
| 1   | 1   | 1   | 1   | 0   |

The 8-bit multiplexer circuit is shown above. All LUTs are configured collectively as an 8-bit multiplexer (see AN-1003) the MUX truth table is also shown above. The multiplexer outputs the combination of bits from the ASM block outputs according to the algorithm of the generator and the data is transmitted on one line to DATA. The DATA output will always be the same as the MSB of the ASM output RAM. when EN is LOW. The ASM output RAM can be changed via I2C. logic can also be implemented to change the state of the ASM in order to change the data bits. If the ASM isn't available, the inputs can be pulled high or low for the data values.

31

### **Application: 10 Year Counter**

Ultra-long counters can be used to determine the lifetime of a product without requiring a large tax on the power budget.

### Ingredients

- Any GreenPAK
- No other components are needed



### **GreenPAK Diagram**



- 1. Chain the Counters using Technique: Sequencing CNT/DLY Blocks.
- 2. Connect input pins and output pin.
- 3. Set timing in CNT properties.

### **Application: Square Wave Generator**

Square waves are essential for clocking digital systems. They can easily be implemented in GreenPAK with the oscillator blocks or a delayed logic for a customized frequency.

### **Ingredients**

- Any GreenPAK
- No other components needed



### **GreenPAK Diagram**



### **Design Steps**

- 1. Configure the EN input and the square wave outputs.
- 2. Use an internal oscillator to generate a square wave on PIN20. The 'CLK' predivider and 'OUT0' second divider can be altered to customize the frequency.
- 3. Use a both edge delay and a LUT to generate a square wave on PIN19. This configuration allows the user to divide down the frequency of the square wave by a finer adjustment.

 $Division\ Coefficient = Counter\ Data + 2$ 

SLG46537

### 2. Sequential Logic

1.Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

GND

Communication Protocols

### **Application: Two Event Button Press**

Using a single button to generate several events is a common solution to save on external control components. Using one button and predetermined time intervals you can organize control of an LED flashlight.



### **Ingredients**

- Any GreenPAK
- One LED
- One resistor

### **GreenPAK Diagram**



- 1. Configure GPIO pins as an input for button and an output for LED control.
- 2. Add CNTO/DLYO, CNT1/DLY1, and a DFF to remember the last state.
- 3. Configure the CNT/DLY blocks to "Delay" mode, with Edge select configured to "Rising."
- 4. Configure the CNTO/DLYO output as "nOUT."



# **Chapter 3 Signal Conditioning**

This chapter presents applications that interpret an external signal and condition it to be useful for an operation within a system. Some applications that involve this are frequency division/multiplication, filters, and sensor controllers.

### 2. Sequential Logic

1.Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

### Technique: Using a CNT/DLY Block as a Deglitch Filter

This technique can be used in any GreenPAK

Deglitch / debounce filters are used to eliminate glitches - spurious signal transitions. Glitches occur in situations like a button being pressed/released or when a voltage is very close to a threshold of a hysteresis-less PIN.

There are 3 possible edge-triggered options to configure a deglitch delay: rising, falling or both. In this case delay block will filter pulses shorter then delay value with corresponding polarity: active high for rising edge, active low for falling edge, both High and Low for both edge delay.



**Example Deglitch Delay Options** 

See diagram below:



**Edge Delay Behavior** 

### **Technique: Edge Detector**

This technique can be used in any GreenPAK.

Edge detectors are important components in digital electronics. It is a simple circuit with one input and one output. Edge detectors create a short pulse when a defined edge (rising, falling, or both) is detected. It's useful for implementing a reset function, watchdog timer, or other edge-dependent applications. There are several ways to implement an edge detector (see figure below). To read a detailed description on how to build edge detectors and see more examples see <u>AN-1046 Various Edge Detector Circuits</u>.



**Edge Detector Implementation** 

Option 1 uses the built-in edge detector feature in EDGE DET, P DLY, and CNT/DLY blocks. These blocks have the benefit of producing a longer duration pulse compared to Option 2 (figure below).



**Different Edge Detectors Timings** 

Option 2 uses the small delay caused by signal propagation through a buffer. This delayed signal is compared by a 2-bit XOR to the original input, whose propagation time is exceptionally small. The short delay through the buffer causes a difference between the XOR's inputs, which generates a short pulse on its output. Because of the internal structure of the LUTs their inputs have different propagation delay time.

#### **Application: Interrupt Controller**

The GreenPAK can be configured to monitor multiple different interruptible signals and aggregate that information for the host processor to act on. The microprocessor or SOC can read the output of each DFF via I2C to determine the source of the fault.



#### **Ingredients**

- Any GreenPAK
- No other components are needed

#### **GreenPAK Diagram**



- 1. Configure PINs 16, 17, and 18 as "Analog Input/Output."
- 2. Configure levels of ACMPs to proper threshold.
- 3. Wire DFFs to OR gate and set PIN4 as output.
- 4. Configure DLY1 to desired debounce time.

#### **Technique: Creating a Bi-directional Counter**

This technique can be used within any GreenPAK that includes an SPI interface. Alternatives to this technique can be accomplished using other GreenPAKs with an FSM block and storing the counter information using an I2C read command, parallel output, or other method.

A Counter is a basic digital circuit used for counting input events (pulses, edges), often constructed using a cascade of digital flip-flops. In GreenPAK some CNT/DLY blocks are more robust, and can be used as a finite state machine (FSM) that is not only capable of incrementing but can decrement or hold the current value, dictated by interconnects in the GreenPAK matrix. This technique exemplifies this behaviour by using two FSM blocks in GreenPAK to monitor a pulse input (Clock) and output the corresponding 16-bit sequence via the SPI macrocell.



16-bit FSM with SPI Output

The 16-bit FSM with an output to the SPI block counts input clock pulses in a constructed 16-bit register (FSM0, FSM1). At any time a user can read the value via SPI, reset the 16-bit register, or change the count direction.

The 16-bit counter is implemented using two counters (FSM0 and FSM1 blocks) with additional logic. Bits [15:8] are stored in FSM0, [7:0] in FSM1. Both FSMs are connected to the SPI block, which can output serial data via SPI. The count direction is controlled by an Up/Down pin, directly connected to the FSM blocks' UP matrix output. If this pin is HIGH, the system counts UP, if this pin is LOW, the system counts DOWN. Gen Reset pin is used to reset both counter values (active HIGH).

The Clock input pin is applied simultaneously at the CLK input of FSM1 and FSM0. FSM1 counts each clock, whereas FSM0 counts only when FSM1 counter value is 255 and Up/Down signal is HIGH or when FSM1 counter value is 0 and Up/Down signal is LOW. This functionality is achieved using the KEEP input of the FSM0. When this signal is HIGH the counter value of the FSM0 is not changing despite the clock signal. KEEP is connected to FSM1 output through an inverter. In turn, FSM1's output is only HIGH when counter value is 0 and Up/Down signal is LOW, or when counter value is 255 and Up/Down signal is HIGH.

2. Sequential Logic

1.Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

**Communication Protocols** 

6. Pulse-based Control

7. Power Management

#### **Application: Encoder**

Encoders are used to convert rotary or linear motion to a digital signal. This design is optimized for mouse wheels and volume control in headsets.



#### **Ingredients**

- Any GreenPAK
- No other components are needed

#### **GreenPAK Diagram**



- 1. Configure pins as digital inputs.
- 2. Configure two pins as output to designate direction of encoder.
- 3. Set CNT3/DLY3 and CNT5/DLY5 to the "One shot" mode with the desired filter time.
- 4. Configure DFFs to detect direction (Up or Down).
- 5. Set CNT1/DLY1 and CNT2/DLY2 to the "One shot" mode with the desired output pulse width.

#### **Application: Distance Sense**

Ultrasonic ranging modules provide a non-contact measurement function. This design is a controller for an ultrasonic rangefinder based on the HC-SR04.

#### **Ingredients**

- Any GreenPAK
- LED for each distance measurement
- Resistor for each distance measurement

#### SLG46537 PIN 1 (VDD) PIN 20 EN [ PIN 2 **PIN 19** PIN 3 **PIN 18** ЕСНО [ PIN 4 **PIN 17** TRIG ( PIN 5 PIN 7 PIN 8 PIN 9 PIN 10 (GND) PIN 11 GND

#### **GreenPAK Diagram**



- 1. Configure GPIO input for Echo and output for Trig.
- 2. Add LUT logic and CNT/DLY0 to create a generator with ENABLE signal.
- 3. Add Pipe Delay and CNT/DLY2 to create a generator for detect distance.
- 4. Configure CNT/DLY blocks as a rising edge delay to measure varied distances.
- 5. Add and configure DFFs to latch distance data.
- 6. Connect each DFF output to the desired output pins and configure as open drain.

#### **Application: Frequency Range Detector**

Many devices have a specific frequency range in which they operate and require the input clock to stay within this range. This application is used to detect if the input clock frequency is within the desired range.



#### **Ingredients**

Any GreenPAK

#### **GreenPAK Diagram**





- 1. Configure GPIO pins as an input for the clock and output for the flag.
- 2. Configure CNT/DLY blocks to the "Frequency detect" mode with a rising edge detect.
- 3. Set each CNT/DLY block respectively to the minimum and maximum frequency values.
- 4. Configure a LUT to go high when the frequency is outside the desired frequency range.

#### **Application: Frequency Divider**

Frequency dividers are used to divide the input frequency into different coefficients. It can used for improving the performance of electronic countermeasure equipment, communication systems and laboratory instruments.



#### **Ingredients**

- Any GreenPAK
- No other components are needed

#### **GreenPAK Diagram**



- 1. Configure inputs for each inputs signal (Input frequency, coefficient).
- 2. Use DFF and Pipe Delay to divide the frequency for the first stage.
- 3. Use another DFF to divide the signal by a factor for the second stage.
- 4. Configure LUT logic to decide outputs into specified coefficient.

## 2. Sequential Logic

Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

Communication **Protocols** 

6. Pulse-based Control

#### **Technique: Zero-Voltage Cross Detection**

This technique can be used in GreenPAKs that include ACMP's.

Zero-voltage cross detection is commonly used as an accurate method of detecting AC characteristics, such as frequency and phase.

GreenPAKs have a pin voltage range of OV to a VDD value of 5.5V. To interpret an AC signal that crosses at the OV point using the GreenPAK a DC offset shift should be implemented between the AC signal and the GreenPAK pin. This can be accomplished by a 1:1 resistor divider between VDD of the GreenPAK and the AC signal, shown in the Basic DC Offset figure.

Zero-voltage cross detection requires, at minimum, one or two comparators and a counter. The comparators check the incoming AC signal against a reference voltage, which can either come from the GreenPAK's available reference voltages or an external reference point. If a desired ZVCD voltage is greater than the available GreenPAK reference voltages the AC signal may instead be reduced by using the IN+ gain option within the comparator's property settings and comparing the reduced AC value to a similarly scaled scaled reference.



**Basic DC Offset** 



Using the IN+ Gain to Measure a 1.7V Crossing

#### **Application: Analog Storage Element**

This application can be used to store the analog voltage on an output until the rising edge is applied to the Store input. The input and output analog voltages lie within the range of 0-1V.



#### **Ingredients**

Any GreenPAK with an ADC, SPI, and DAC

#### **GreenPAK Diagram**





#### **Design Steps**

R11TB0003CE0000

- Configure SPI to "ADC/FSM buffer" mode, change the PAR input data source to "ADC".
- 2. Configure FSM0 to "Set (counter value = FSM data)" and change the FSM data source to "SPI [7:0]."
- 3. Configure DAC Input selection to "From DCMP1's input" and VREF Source selector to "DAC0 out".
- 4. Connect Store input directly to SPI SCLK and FSM1 SET IN through P DLY set as a both edge delay.

Basic Blocks & Functions

2. Sequential Logic

3. Signal Conditioning

4. Safety Features

Communication Protocols

6. Pulse-based Control

7. Power Management



### Chapter 4 **Safety Features**

This chapter presents applications that are intended to respond to fault conditions in a system and protect it from damage. Some applications that provide safety to electronic systems are battery indicators, watchdog timers, and temperature sensors.

Basic Blocks & **Functions** 

2. Sequential

Conditioning

4. Safety

Communication **Protocols** 

6. Pulse-based

Management

### Sequential

1.Basic Blocks & **Functions** 

Conditioning

4. Safety

Communication **Protocols** 

#### **Technique: Reducing ACMP Power Consumption**

This technique can be used in GreenPAKs that include ACMP's. The reduction in power consumption will vary.

GreenPAKs are often used in projects to reduce the system's current consumption. However, several components within GreenPAKs, when active, can cause a noticeable change in current consumption. Amongst the most consumptive macrocells are the analog comparators. Table 1 is taken from the SLG46826 datasheet to highlight the ACMP's consumption.

Luckily, ACMPs can be shut down when not in use. This is done in two ways:

- 1. Through the PWR UP input of the ACMP.
- 2. Enabling a wake-sleep controller (WS Ctrl) for the ACMP.

| Note                                                                                                      | V <sub>DD</sub> = 2.5 V | V <sub>DD</sub> = 3.3 V | V <sub>DD</sub> = 5.0 V | Unit |
|-----------------------------------------------------------------------------------------------------------|-------------------------|-------------------------|-------------------------|------|
| Chip Quiescent                                                                                            | 0.39                    | 0.43                    | 0.53                    | μΑ   |
| Vref OUT0 (Source none, Source Temp<br>Sensor, Buffer On)                                                 | 12.79                   | 12.95                   | 13.57                   | μА   |
| Vref OUT0 (Source none, Source Temp<br>Sensor, Buffer Off)                                                | 7.62                    | 7.67                    | 7.87                    | μА   |
| Vref OUT1 (Source none, Buffer On)                                                                        | 6.53                    | 6.61                    | 7.02                    | μΑ   |
| Vref OUT1 (Source none, Buffer Off)                                                                       | 1.40                    | 1.44                    | 1.54                    | μΑ   |
| Vref (ACMPxH, 0.32 mV, Buffer On)                                                                         | 12.24                   | 12.59                   | 12.21                   | μΑ   |
| Vref (ACMPxL, 0.32 mV, Buffer On)                                                                         | 6.93                    | 7.01                    | 7.43                    | μΑ   |
| ACMP0H, 1H, 2L, 3L,hysteresis<br>disabled, gain = 1, +IN - IO11, 12, 13, 14<br>Pull Up 1M, Vref = 32 mV   | 65.86                   | 67.12                   | 70.77                   | μА   |
| ACMP0H, 1H, 2L, 3L,hysteresis<br>disabled, gain = 1, +IN - IO11, 12, 13, 14<br>Pull Down 1M, Vref = 32 mV | 37.34                   | 38.05                   | 40.29                   | μА   |
| ACMP0H, 1H, 100 μA disabled,<br>hysteresis disabled, gain = 1, +IN - IO13,<br>14 Pull Up 1M               | 63.85                   | 65.11                   | 68.71                   | μА   |
| ACMP0H, 1H, 100 μA disabled,<br>hysteresis disabled, gain = 1, +IN - IO13,<br>14 Pull Down 1M             | 35.97                   | 36.68                   | 38.87                   | μА   |
| ACMP0H, 100 μA disabled,<br>hysteresis disabled, gain = 1, +IN - VDD,<br>Vref = 32 mV                     | 36.30                   | 36.96                   | 38.85                   | μА   |
| ACMP0H, 100 μA enabled, hysteresis<br>disabled, gain = 1, +IN - IO14 Pull Up 1M,<br>Vref = 32 mV          | 46.77                   | 47.31                   | 49.23                   | μА   |
| ACMP0H, 100 μA enabled, hysteresis<br>disabled, gain = 1, +IN - IO14<br>Pull Down 1M, Vref = 32 mV        | 49.02                   | 50.29                   | 53.75                   | μА   |

**Table 1 SLG46826 Current Consumption** 

Wake-sleep control requires a dedicated counter configured to "Wake sleep controller" mode. This is available in many (but not all) GreenPAKs. PWR UP control can be used in any GreenPAK with ACMPs. When the signal is HIGH the ACMP is on; using logic, counters or other macrocells to turn off the ACMP can drastically reduce power consumption. For example, if two different voltage thresholds are needed the higher-threshold ACMP can be kept inactive until the lower threshold is met.



(a) Logic



(b) Duty Cycle

A CMP0H HV detect A CMP2L LV Detect

(c) Cascaded

**Common PWR UP Configurations** 

#### **Technique: Wake-Sleep Controller**

Waking and sleeping analog macrocells is useful for reducing power consumption. It is possible to accomplish this with the wake-sleep controller for analog macrocells like ACMPs and ADCs.

Wake-sleep involves switching analog macrocells on and off periodically. For some GreenPAKs this function can be implemented using the WS Ctrl block. For those that don't have this block, it can be implemented using two counters (one counter if there is no need to change the wake time), a D flip-flop, and an inverter. The figures below display examples using these respective methods.



**WS Ctrl Method** 



Two Counter Method

Without wake -sleep implemented, the total current consumption consists of:

- Quiescent current
- ACMP current



**Behavior of Wake-Sleep** 

With wake-sleep implemented, the quiescent current is approximated as follows:

$$I_{WS} = \frac{System \ Wake}{System \ Wake + System \ Sleep} *I_{without \ WS} = \frac{System \ Wake}{WS \ Period} *I_{without \ WS}$$

The total current with wake-sleep implemented is:

Total Current = 
$$I_{Quiescent} + I_{OSC} + I_{Wake\ Sleep}$$

#### **Application: Window Comparator**

Window comparators are an essential part of any design that runs off a depletable power source, like a battery or supercapacitor. By monitoring battery voltage, a device can opt to stop using nonessential resources at low battery levels. This can prevent permanent damage to the device.



#### **Ingredients**

- Any GreenPAK w/ ACMP's
- No other components are needed

#### **GreenPAK Diagram**



- 1. Configure the High-side ACMP2L by using the IN- source and IN+ gain options to set the desired high-side threshold.
- 2. Repeat step 1 for the low side ACMP with the low-side threshold.
- 3. Change the IN+ source for the second comparator to ACMP2L IN+ source.
- 4. Add the LUT logic to trigger an interrupt when the LOW-side comp is low or high-side is high.

#### **Application: Over Temperature Protection**

An over temperature protection circuit is widely used to alert a system of high temperatures. This circuit protects the system from overheating when the internal temperature exceeds a safe threshold.



#### **Ingredients**

- Any GreenPAK w/ ACMP's
- One resistor
- One NTC thermistor

#### **GreenPAK Diagram**



- 1. Set the IN+ source of ACMP2L to PIN18 and IN- source to the desired threshold.
- Connect one node of the resistor to VDD and the second node to PIN18.
- 3. Connect one node of the NTC thermistor to PIN18 and the second node to GND.

#### **Application: Battery Charge Indicator**

Battery charge indicators are used in battery-powered devices to indicate the state of charge. This design is optimized for a lithium-ion battery.



#### **Ingredients**

- Any GreenPAK w/ ACMP's
- No other components are needed

#### **GreenPAK Diagram**



- 1. Connect pin to PWR UP pin of ACMP0H, ACMP1H, ACMP2L, and ACMP3L.
- 2. Set IN+ source of all the ACMPs to "VDD/PIN20" and each IN- source to the desired threshold level.

#### **Application: Low Voltage Indicator for Infotainment**

Voltage indicators are used in battery-powered devices to indicate the state of charge. This device monitors the voltage levels of a car battery and adjusts infotainment activities as needed to conserve power.



#### **Ingredients**

- Any GreenPAK
- Two resistors for voltage divider

#### **GreenPAK Diagram**



- 1. Configure the ACMPOH IN+ source as "PIN 20" and the other ACMPs as "ACMPOH IN+ source".
- 2. Add a voltage divider on PIN 20 to handle high voltage from the car battery.
- 3. Configure the IN- source to the desired voltage threshold values.
- 4. Configure logic to determine the voltage level windows for the outputs.
- 5. Add a debounce delay in between ACMP2L and 3-bit LUTO.

#### **Application: Watchdog Timer**

Watchdog timers are used for automatically generating a system reset signal if the microcontroller or microprocessor neglects to periodically send a pulse. Monitoring for low supply voltage is an additional, common feature of watchdog ICs.



#### **Ingredients**

- Any GreenPAK w/ ACMP's
- No other components are needed

#### **GreenPAK Diagram**



- 1. Set undervoltage threshold with an ACMP.
- 2. Configure two CNT/DLY blocks to the "Frequency detect" mode.
- 3. Design the digital logic to combine active signals from undervoltage and watchdog timeout.
- 4. Add a one shot block to trigger the reset pulse. It can be inverted to be active low.

#### **Application: Voltage Level Detection**

Some applications require multiple voltage levels to be evaluated, rather than a few distinct levels. This application shows how to use of ACMPs, DCMPs, and an ADC to monitor the voltage amplitude.



#### **Ingredients**

- Any GreenPAK with ACMPs, DCMPs, and an ADC
- Up to eight LEDs and resistors

#### **GreenPAK Diagram**



#### **Design Steps**

R11TB0003CE0000

- 1. Power on the ADC, DCMPs, and ACMPs.
- 2. Configure the DCMPs using <u>Technique</u>: <u>Using DCMP/PWM Macrocell in PWM Mode</u>.
- 3. Set the IN- of each ACMP and DCMP with the desired voltage threshold levels.
- 4. Add LUT and DFF logic to select and write data of the amplitude of the analog voltage from DCMP1.

#### **Application: Power Backup Management**

Power Backup management is used when a designer must guarantee the non-interrupted power supply of a system from different sources.



#### **Ingredients**

- Any GreenPAK with three ACMPs.
- External resistor dividers to attenuate input signal to the operating value range of ACMPs.

#### **GreenPAK Diagram**



- 1. Use three ACMPs to detect power input signals.
- 2. Use CNT/DLY blocks configured as a delay to implement a debounce filter.
- 3. Add logic cells to create switching priority between input sources.

#### **Application: N-pulse Presence Watchdog**

Watchdog timers are used for automatically generating a system reset signal if the microcontroller or microprocessor neglects to periodically send a pulse. This application monitors the number of pulses that go to the GreenPAK during a watchdog period. If the number is less than the predefined pulse number, a system reset will be triggered.



#### **Ingredients**

Any GreenPAK

#### **GreenPAK Diagram**





- 1. Configure CNTO/DLYO/FSMO as a one shot with the desired watchdog period.
- 2. Define the pulse number in the Pipe Delay (Note: Pulse number = OUT1 PD num + 1).
- 3. Invert the output of the one shot and connect it to the CLK input of DFFO.
- 4. Connect nOUT1 of the Pipe Delay to the D input of DFFO.

#### **Technique: Using the Temperature Sensor Block**

This technique can be used with any GreenPAK that has a Temperature Sensor macrocell inside.

Some ICs have an analog Temperature Sensor (TS) with an output voltage linearly proportional to the Centigrade temperature. The TS is rated to operate in a temperature range of -40°C to 85°C. The error in the whole temperature range does not exceed  $\pm 0.85\%$ . The TS output can be connected directly to the Analog Output or to the ACMP positive input. The TS may have two output voltage ranges and a Power Up input. The Power Up optionally can be activated using the matrix input or from the register. The TS can also be activated and the range can be changed via I2C. The TS output voltage at a constant temperature has very low variations over VDD changes (for example, in the SLG46826, the output voltage error is less than  $\pm 0.08\%$  at all temperatures).



**Temperature Sensor Macrocell** 

The TS output voltage can be calculated using the following formula:

 $Vts = K \times T + V0$ 

Where:

Vts - TS Output Voltage;

K - Coefficient;

T - Temperature in °C;

V0 - Output Voltage at 0 °C.



**Temperature Sensor Connected to Analog** 

The temperature proportional voltage signal can be applied to the Analog Output (PIN16). The Power down source configuration should be set to "From register".

Temperature Sensor output signal can be compared to the reference voltage in the ACMP block (See the figure below), which generates a twostate signal at the discrete output. In order to decrease the power consumption TS\_EN is used. TS\_EN enables the Temperature Sensor and switches the ACMP3L on. Power down source should be set to "From matrix."



**Temperature Comparator** 

GreenPAK with TS can:

- measure PCB components temperature
- measure FET or BJT case temperature
- create an alarm signal for SoC or in closed-loop applications
- minimize errors for ADCs, DACs, OpAmps and other temperature dependent schematics

The GreenPAK can be used to sense the current going through a device by sensing the voltage across a sense resistor. This application outputs a serial code to represent the value it has sensed.



#### **Ingredients**

- Any GreenPAK with a PGA, ADC, and SPI
- One resistor

#### **GreenPAK Diagram**



- 1. Power up the ADC by removing VDD from the PWR DOWN input.
- 2. Configure the PGA to "Differential" mode. It will automatically connect to the ADC, PIN6, and PIN7.
- 3. Configure SPI to the "P2S" mode and change the PAR input data source to "ADC."

### **Application: Monitor Four Levels for One Analog Signal With One MS ACMP**

Monitoring four levels for one analog signal with a GreenPAK can be useful in a variety of applications. For instance, it can be used for battery management, fluid level control, temperature, light, proximity, pressure, humidity sensing, etc



#### **Ingredients**

SLG46811V or any GPAK with appropriate number of ACMPs

#### **GreenPAK Diagram**



- 1. Configure MS ACMP to Multi-channel mode and choose 4-channels.
- 2. Choose Rising Edge Activation to Enable MS ACMP.
- 3. Adjust the IN- source for Channel 0 Channel 3.
- 4. Configure PIN6 as digital input and connect it to Enable input of MS ACMP. By every rising edge applied to PIN6 MS ACMP will measure the VDD voltage output the result to PIN9-PIN12.
- 5. I2C can rewrite the ACMPs' threshold values.

### **Application: Monitor Four Separate Analog Signals With One MS ACMP**

Monitoring four separate analog signals with a GreenPAK can be useful in a number applications, where four independent voltage signals change slowly.



#### **Ingredients**

SLG46811V or any GPAK with appropriate number of ACMPs

#### **GreenPAK Diagram**



- 1. Configure MS ACMP to Multi-channel mode and choose 4 channels.
- 2. Choose High-Level Activation and connect POR (MS ACMP will be continuously sampling) to ENABLE input of MS ACMP.
- 3. Adjust the IN-source for Channel 0 Channel 3. The voltage at PIN8 PIN11 is compared to the reference, and the output to PIN3-PIN6 accordingly.
- 4. I2C can rewrite the ACMPs' threshold values.

## 2. Sequential Logic

Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

Communication Protocols

6. Pulse-based Control

7. Power Management

# **Chapter 5 Communication Protocols**

This chapter presents applications that involve communication between devices. The following applications and techniques involve I2C, serial, parallel communication protocols.

Many of the techniques and applications available in this section rely upon a GreenPAK's I2C capability. To learn about I2C within a GreenPAK please consult the chip's Datasheet.

9. Advanced Analog Features

#### **Technique: Changing Your Design with I2C**

This technique can be used in any I2C compatible device.

If a GreenPAK device is I2C compatible its behavior can be edited even after it has been programmed. However, a device must be MTP-compatible and undergo In-System Programming [ISP] to retain design changes after it has lost power. This technique outlines a fast way to determine which I2C commands need to be performed to change a design.

- 1. Complete your initial design. This is the design the IC will use whenever it's booted up.
- 2. In GreenPAK Designer, select the I2C Reconfigurator.



**I2C Tools Button** 

- 3. In the I2C Reconfigurator select the snapshot button (boxed in red), or press SHIFT+A. This will take an I2C commandlist "snapshot" of your current design.
- 4. Change your design to the next configuration.
- 5. Take a snapshot using the method in step 3 to create the second snapshot.
- Click the Snapshot diffs button (boxed in green). This will show the I2C commands necessary to create this design. It is not necessary to program these, since they are instantiated on the boot-up of the GreenPAK.
- 7. Scroll down the Snapshot diffs list, where you will find the second snapshot. This will show only the values that have changed between the first and second snapshot.
- 8. These values, shown in the red box on the right, correlate to the hexadecimal address and data value that need to be sent in I2C to change the threshold value of the ACMP (or any other change that may occur).



**I2C Reconfigurator** 



**Snapshot Diffs** 

### 2. Sequential Logic

Basic Blocks & Functions

3. Signal Conditioning

4. Safety
Features

. Communication Protocols

#### **Technique: Creating an I2C command**

This technique can be used in any GreenPAK with an I2C macrocell With the I2C generator a user can create an I2C signal based on logic generators. It consists of two logic generators acting as SDA and SCL lines. The user can combine predefined I2C primitives to generate the needed waveform and choose an SCL frequency: 1k, 2.5k, and 5 kHz for the GreenPAK Advanced Development Platform and 1k, 2.5k, 5k, 10k, 20k, 50k, 100k, 200k, 400k, 1000 kHz for the GreenPAK Pro Development Platform.

To create an I2C signal using the I2C Generator:

- 1. Select the Debug button.
- 2. Select "I2C generator" on the SDA input external connector setting of the I2C block.
- 3. Go to Signal Wizard by clicking EDIT.
- 4. Select PIN8 as SCL and set the speed of the clock.
- 5. Choose Read or Write composite commands.
- Open composite command and set the Slave address and Word address. For a Read command set byte count. For a Write command set data to write.





**I2C Write Command** 



**I2C Read Command** 

I.Basic Blocks Functions

2. Sequential

Conditioning

4. Safety

Communication Protocols

6. Pulse-based

Control

Management

7. Power

#### Technique: Using the Serial to Parallel Interface (SPI) Block

This technique is for the Serial to Parallel Interface (SPI) block, available in the SLG46140, SLG46620, and SLG46621.

The block is a special macrocell that can be used for communication between a GreenPAK and a SOC. It can either translate serial data to parallel or parallel data to serial. The inputs are standard SPI I/O connections (MOSI, MISO, nCSB, SCLK, and INTR). nCSB is an active low chip select. SCLK is the serial clock which clocks the SPI macrocell.

The SPI can be used to transfer data to such blocks as:

- FSM
- DCMP
- DAC (through DCMP)

The same SPI can be used to transfer data from:

- ADC
- FSM

All this can be used with other macrocells for functionality like:

- Pulse Width Modulation
- Analog to Digital Comparison
- Digital to Analog Comparison
- Comparing two results with DCMP
- SDIO and LCD

The SPI can be selected to work in either 8-bits or 16-bits. Remember that the SPI macrocell cannot send and receive serial data in the same program file. It must be set up either in the "S2P" or "P2S" mode. In the "P2S" mode the INTR pin pulses high for one clock period each time data after transmission completes. Otherwise, the SPI implemented in GreenPAK meets the generally accepted standard. It is possible to set the clocking frequency up to 2 MHz. It is also possible to configure the clock polarity with the CPOL bit and clock phase with the CPHA bit. When CPHA = 0, data can only be transmitted from serial to parallel, not from parallel to serial.

When CPHA = 1, data can be transmitted both from serial to parallel and from parallel to serial.



SPI macrocell



**SPI Macrocell in Serial to Parallel Mode** 

9. Advanced Analog Features

## 2. Sequential

1.Basic Blocks **Functions** 

Conditioning 3. Signal

4. Safety

Communication **Protocols** 

#### **Technique: Level Shifting**

This technique will work with any GreenPAK that has dual voltage rails, such as the SLG46826V.

Often in a system-level design it's necessary to combine the data from two signals that operate at different voltage levels. For example, the analog rails in a system might operate at 5.0V while the digital rails operate at 3.3V.

Many GreenPAK ICs solve this problem by using dual voltage rails: signals that operate at different rails can be input into the GreenPAK, manipulated, then output from the GreenPAK at either of the voltage rail levels.

When starting a new GreenPAK Designer design using a dual rail part you'll be asked to input the voltage range of both rails. The available ranges of both rails will vary from part-to-part. The higher voltage rail should be designated as VDD, not VDD2.



**Dual Rail Project Info** 



**Dual Rail Logic Example** 

In dual rail parts the GPIO connections to the first and second rails are indicated by the color of the IO PIN within GreenPAK Designer. VDD will be indicated by blue pins and VDD2 will be indicated by amber pins. Once inside the GreenPAK matrix the signals from the different voltage levels will behave identically.

## 2. Sequential Logic

1.Basic Blocks Functions

3. Signal Conditioning

4. Safety Features

**Communication Protocols** 

#### **Technique: Sending a Preset Number of Pulses**

This technique can be done in any GreenPAK. Multi-function blocks within some GreenPAKs help reduce the component count.

In many communication protocols a set number of bits must be sent to or received by another IC. Typically, this requires the GreenPAK must track the number of pulses sent or received. For example, in a shift register receiving data, the number of bits must be monitored to ensure that the expected data is in the correct register, rather than skewed incorrectly or relentlessly continuing to shift.

There are many ways to set a predetermined number of pulses in GreenPAK. A scalable, efficient way is described in this technique. This method also has the added benefit of limiting clock skew between the other IC and the GreenPAK by resetting the clock skew after every transaction. The figure below shows a series of blocks to send a preset number of pulses. There are a pulse number stage and a pulse generator stage.



**Preset Pulse Generator Design** 

The pulse number stage consists of a one shot block that is clocked by the output pulses of the pulse generator. On a rising edge on PIN 4 (Start), the CNT1/DLY1 output will be set HIGH until it is clocked by the number of pulses set in the Counter data. After the set number of pulses, it will return LOW.

The pulse generator is made by MF0. Within MF0, CNT0/DLY0 is a both edge delay with an inverted output. Its delay time sets the period of the pulse generator. The output is fed back to 4-bit LUT0 that is configured to only invert the signal from CNT0/DLY0 while CNT/DLY1's output is HIGH. After the one shot pulse is finished the pulse generator will stop sending pulses.

9. Advanced Analog Features

## 2. Sequential Logic

Basic Blocks & Functions

3. Signal Conditioning

#### **Technique: Building a Shift Register**

This technique can be used within any GreenPAK. The size of the shift register is dependent upon the components available within the specific GreenPAK.

Shift registers are a critical component for serializing or deserializing data. A shift register is a chain of flip-flops that can be sequentially linked and whose outputs can be individually accessed. Each has a connection to a shared clock; on the rising edge of the clock the registers will "shift" their data to the next flip-flop in the sequence. The figure below shows a basic, 4-bit shift register. The D flip-flops can be globally reset using a shared reset signal.



**Basic Shift Register** 

Often, shift registers must be loaded within the GreenPAK. This can be done by adding a MUX standard logic cell before each DFF. When data is ready to be loaded the MUX select input (S in GreenPAK Designer) is toggled and the DFF clock input is triggered to commit the value for each register. The figure below shows the addition of a MUX on 2 of the bits in above figure's basic shift register. LOAD\_EN shares the CLK input to commit the loaded values to DFF3 and DFF4.



**Loading a Shift Register** 

#### **Application: I2C GPIO Expansion**

GPIO expansion is used to change the data originating from a few lines into data sent across many. I2C is a common input for this type of application, since one or more addresses can be changed into multiple, dedicated lines used by different ICs.



#### **Ingredients**

- Any GreenPAK with I2C
- No other components are necessary

#### **GreenPAK Diagram**



- 1. Configure GPIO pins as output.
- 2. Connect to I2C virtual inputs.
- 3. I2C virtual inputs can be changed individually or simultaneously using the I2C virtual output address, found in the GreenPAK's datasheet.

#### **Application: Serial to Parallel (External Clock)**

Deserialization ICs are used for data to be sent across one wire and read as multiple bits of data by the receiver. They often use an external clock tied to the same device as the data line to avoid clocking the data at an incorrect time.



#### **Ingredients**

- Any GreenPAK
- An IC an external clock output

#### **GreenPAK Diagram**



- 1. Configure the shift register as shown in <u>Technique</u>: <u>Building a Shift Register</u>.
- 2. Add an Input connection for the internal clock and connect it to the CLK input of the shift registers.
- 3. Add an Input connection for the reset function and connect it to the nRESET of the shift registers.

2. Sequential

Conditioning

4. Safety

**Communication Protocols** 

6. Pulse-based Control

7. Power Management

Deserialization ICs are used for data to be sent across one wire and read as multiple bits of data by the receiver. When adding an external clock isn't realistic, the GreenPAK can use an internal oscillator triggered from an action on the input line, such as a LOW signal that's held for a pre-determined period.

**Application: Serial to Parallel (Internal Clock)** 



#### **Ingredients**

- Any GreenPAK
- An IC an external clock output

#### **GreenPAK Diagram**



- Configure the shift register as shown in <u>Technique: Building a Shift Register</u>.
- 2. Add an Input connection for the reset function and connect it to the nRESET of the shift registers.
- 3. Configure a preset number of pulses to match the number of shift registers. This is outlined in <u>Technique</u>: <u>Sending a Preset Number of Pulses</u>.

#### **Application: Parallel to Serial**

Parallel to Serial convertors are commonly used to send data from one IC to another using one or two wires (Data and Clock). Internal or external clock can be used here, and number of parallel bits is limited by number of GPAK I/Os and internal blocks available.



#### **Ingredients**

- Any GreenPAK
- An IC an external clock output

#### **GreenPAK Diagram**



- 1. Configure the shift register as shown in <u>Technique</u>: <u>Building a Shift Register</u>.
- 2. Add and configure 3-bit LUTs for each DFF to operate as MUX using <u>Technique</u>: <u>Configuring Standard Logic w/ LUT Macrocells</u>.
- 3. Configure Load/Shift function and connect internal blocks to inputs, output.

I.Basic Blocks Functions

#### **Application: Bi-Directional Communication (Transmit First)**

Bi-directional communication systems are critical in applications where board area is scarce, or limited contacts are used to connect between devices (for example, a wearable and charger). A transmit-first design indicates that this device will always be enabled first in the transaction.



#### **Ingredients**

- Any GreenPAK
- An IC an external clock output

#### **GreenPAK Diagram**



- 1. Configure two GPIO pins as a "Digital input/output," one for the data line and one for the clock.
- 2. Create an internal clock signal using a CNT/DLY block configured as a "Reset counter."
- 3. Configure a shift register to store incoming data, shown in <u>Technique</u>: <u>Building a Shift Register</u>. Shift registers can be read with I2C.
- 4. Add PGEN to send outgoing data. The PGEN contents can be changed using I2C.
- 5. Configure DFF to enable transmission. Connect output to transmit clock signal and OE of I/O pins.
- 6. Add CNT/DLY block to disable transmission, with CLK input from DFF. Connect Edge Det block to reset DFF after set number of clock pulses.
- 7. Connect the external clock to the shift register and connect the internal clock to PGEN and I/O pins.

### Application: Bi-Directional Communication (Receive First)

Bi-directional communication systems are critical in applications where board area is scarce, or limited contacts are used to connect between devices (for example, a wearable and charger). A receive-first design indicates that this device will always be enabled second in the transaction.



#### **Ingredients**

- Any GreenPAK with OE pins
- An IC an external clock output

#### **GreenPAK Diagram**



#### **Design Steps**

- 1. Configure two GPIO pins as a "Digital input/output," one for the data line and one for the clock.
- 2. Create an internal clock signal using a CNT/DLY block configured as a "Reset counter."
- 3. Configure a shift register to store incoming data, shown in <u>Technique</u>: <u>Building a Shift Register</u>. Shift registers can be read with I2C.
- 4. Add PGEN to send outgoing data. The PGEN contents can be changed using I2C.
- 5. Configure DFF to enable transmission. Connect output to transmit clock signal and OE of I/O pins.
- 6. Add CNT/DLY block as a "Reset counter" to disable transmission, with CLK input from DFF. Connect Edge Det block to reset DFF after set number of clock pulses.
- 7. Add CNT/DLY block as a "Reset counter," with input as external clock and output to enable transmission DFF.
- 8. Connect the external clock to the shift register and connect the internal clock to PGEN and I/O pin.

Basic Blocks
Functions

2. Sequential

**72** 

#### **Application: 7-Segment Display Using ASM and I2C**

A 7-segment indicator is a common numerical display. The GreenPAK asynchronous state machine and I2C can be used to provide directions to the segments as to which number should be displayed. The provided example is compatible with a 4-digit, 4 decimal display.



#### **Ingredients**

- Any GreenPAK with I2C and ASM
- 7-segment display
- Eight resistors

#### **GreenPAK Diagram**



- 1. Configure GPIO pins as output and connect them to the ASM output.
- 2. Add shift register using Technique: Building a Shift Register.
- 3. Create a logic generator using the PGEN block, corresponding the required number of digits.
- 4. Add and configure ASM to match the initial digital sequence.
- 5. Update one or more digits to an ASM state via I2C.

#### **Application: Communication MUX Using I2C**

An I2C Communication MUX is used when a designer needs to combine several I2C input signals and forward them into a single output line.



#### **Ingredients**

- Any GreenPAK with I2C
- Two resistors
- Two capacitors

#### **GreenPAK Diagram**



- 1. Configure a 1:3 demux with LUTs to share the TX signal from the MCU, sent to external UART ports.
- 2. Configure a 3:1 mux with LUTs to receive an RX signal from the external UART ports to the MCU.
- 3. Use the I2C to select the input port.

#### **Application: I2C Level Shifter**

I2C level-shifters allow two I2C-enabled devices to communicate to each other across two different voltage levels. The given example level shifts from 3.3V to 1.8V.



#### **Ingredients**

- Any GreenPAK
- Four resistors

#### **GreenPAK Diagram**



- 1. Configure four GPIO pins as digital input/outputs with the output mode set to open drain NMOS.
- 2. Configure one pin as a digital input for the enable signal.
- 3. Add an AND gate to each input/output.
- 4. Configure four multi-function blocks (or four LUTs and four CNT/DLY blocks if Multi-function blocks aren't available) as a NOR gate feeding into a falling edge delay.
- 5. Select OSC2 as the clock source for the delay blocks and set it to "Force Power On."

I.Basic Blocks Functions

#### **Application: Connection Detect**

This application detects the presence of a cable by measuring the voltage proportional to its resistance. The ACMP's 100uA current source is used to produce the voltage drop across the cable. This configuration is also able to determine which type of connection is being made based on different wire lengths or connected loads.



#### **Ingredients**

- Any GreenPAK
- Four resistors

#### **GreenPAK Diagram**



- 1. Enable the input 100uA current source in ACMP1 and configure the IN- source.
- 2. Configure ADC and PGA blocks.
- 3. Enable DCMP/PWM blocks (delete VDD from SHARED PD input). Set DCMP/PWM power register to Power on. Make sure that IN+ selector is connected to ADC and IN- selector is connected to an internal register.
- 4. Set needed value of register in DCMP/PWM blocks and configure MTRX SEL inputs.
- 5. Configure 2-bit LUT0 and 2-bit LUT1;
- 6. Set CNT1-CNT3 to rising edge delay mode.
- 7. Configure PIN10-PIN12 as Digital output 1x push pull.



#### **Application: Custom Pattern Generator**

The pattern generator (PGEN) in the GreenPAK stores a pattern of logic 1's and 0's (up to 16 bits) that can be sent to the internal matrix serially. This design outputs a 16-bit code after a rising edge on an input. It can be used in sequential logic applications.



#### **Ingredients**

- Any GreenPAK with PGEN
- No other components needed

#### **GreenPAK Diagram**



- 1. Configure the custom N\_bits pattern in the PGEN.
- 2. Configure CNT1/DLY1 mode as a One Shot. Set Counter Data to Counter Data=N\_bits-1.
- 3. Configure CNT2/DLY2 mode as a One Shot and set Counter Data to Counter Data=N bits-2.
- 4. Configure CNT3/DLY3 as rising edge delay and create the generator using 2-bit LUT1.
- 5. The design can be improved by using a GreenPAK with I2C to dynamically modify the PGEN data, clock frequency and Counter Data.

### 2. Sequential Logic

I.Basic Blocks Functions

3. Signal Conditioning

4. Safety Features

**Communication Protocols** 

#### **Technique: Sending Serial Protocols Using Duty Cycle Detection**

This technique can be used with any GreenPAK consisting of PGEN, Counter/Delay blocks and I2C. Read <u>Technique: Reading Serial Protocols with a Shift Register</u> and <u>Technique: Reading Serial Protocols with a Pipe Delay</u> for how to read the protocol discussed here with the GreenPAK.

Serial data transmission has a wide variety of communication applications including power lines, wireless systems, and MCUs. A single-wire data transmission can transfer data using distinct duty cycles for another GreenPAK or MCU to read.

The duty cycle detection topology is shown in the figure below. Each bit is represented by a periodic pulse with a particular duty cycle range. Within this design a transacted bit is set "0" when the pulse duration is  $\leq 1/5$  of the period and "1" when  $\geq 4/5$  of the period. Other duty cycle ranges can be used, provided there is sufficient distance between the duty cycle ranges for Logic "0" and Logic "1".



Logic 0 and Logic 1 Detection

In the design displayed below, data transmission is initiated by Enable, which can be supported through an external GPIO or an I2C Virtual Input. CNT4/DLY4 sets the bit period for data transmission. MF1 and MF2 blocks determine the duty cycle to transmit. Data to be transmitted is written in the PGEN via I2C or non-volatile memory. The PGEN can transmit up to 16 bits, but this design demonstrates 8-bit data transmission on the single-wire output. For more information on how to write different patterns through PGEN via I2C, refer to Application: Custom Pattern Generator.



The data packet length is determined by CNT3/DLY3, which in this case it is set to transmit 8-bits. 4-bit LUT0 transmits the data on the Single-Wire output after the data is embedded into the duty cycle of the transmission signal. After data transmission is completed, PGEN can be re-written through I2C.

If the user wishes to bit bang the transmission, CNT5/DLY5 generates an interrupt signal to indicate to an external MCU that the transmitted package is completed.

### 2. Sequential Logic

Basic Blocks
Functions

3. Signal Conditioning

4. Safety Features

#### Technique: Reading Serial Protocols with a Shift Register

This technique can be used within any GreenPAK equipped with enough DFF blocks, a Ripple Counter, and three CNT/DLY blocks. It explains a method to read the single-wire protocol discussed in <u>Technique</u>: <u>Sending Serial Protocols Using Duty Cycle Detection</u>.

Serial data transmission has a wide variety of communication applications including power lines, wireless systems, and MCUs. A shift register can be used as a highly versatile serial receiver for a single-wire transmission.



The figure above shows the single-wire topology discussed in <u>Technique</u>: <u>Sending Serial Protocols Using Duty Cycle Detection</u>. A delayed edge detect on the rising edge is used to sample halfway into the signal period (bit length). When the shift register of this particular design is clocked, the signal will be LOW at points where the pulse is  $\leq 1/5$  of a bit period and HIGH where the pulse is  $\geq 4/5$  of a bit period.

The figure above shows a method for obtaining the single-wire data in 8-bit increments. Each time the shift register is clocked, the Ripple Counter is also incremented. When the Ripple Counter receives 8 pulses, CNT2/DLY2 outputs a high pulse on DATA READY to signify to an MCU that the complete single-wire transmission has been read and is ready to be read by I2C. This design reads transmissions with a 1ms period since CNT1/DLY1 delays the rising edge by 500µs, but this can be easily changed by adjusting its counter value.



#### Technique: Reading Serial Protocols with a Pipe Delay

This technique can be used within any GreenPAK. It explains a method to read the single-wire protocol discussed in <u>Technique</u>: <u>Sending Serial Protocols Using Duty Cycle Detection</u>.

Serial data transmission has a wide variety of communication applications including power lines, wireless systems, and MCUs. A single Pipe Delay block can be used in the place of a resource heavy shift register as a serial receiver for a single-wire transmission. However, it must be noted that unlike the shift register method, this Pipe Delay method can only output its data serially and doesn't have parallel output capability.

The Pipe Delay can be thought of as a 16-bit shift register with three available outputs. Two are configurable to output any of the Pipe Delay's sixteen internal D flip-flops. For this 16-bit implementation, shown below, OUTO of the Pipe Delay is set to represent the 16th DFF output. An input for an MCU to externally clock the Pipe Delay is multiplexed with the Single-Wire In input to allow it to unload the Pipe Delay's data without incrementing the bit counter.

This design utilizes the same delayed data sampling mechanism as <u>Technique</u>: <u>Reading Serial Protocols</u> <u>with a Shift Register</u>, but it instead keeps track of its data bits with a counter block rather than a Ripple Counter. This counter increments each time a data bit is detected. Upon reaching 16 bits, it will set the DATA\_READY pin HIGH until the next data bit is sent. It is important to note that this counter block must be reset before any data is sent to ensure proper operation, which can be done internally by POR or externally by an input (as in this design).



2. Sequential Logic

1.Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

5. Communication Protocols

6. Pulse-based Control

### 2. Sequential Logic

1.Basic Blocks Functions

3. Signal Conditioning

4. Safety Features

Communication Protocols

6. Pulse-based Control

#### **Technique: Using the Digital-to-Analog Converter (DAC)**

This technique can be used with SLG46140, SLG46620, and SLG46621 GreenPAKs.

Some GreenPAK devices contain Digital-to-Analog Converters (DAC). They are 8-bit DACs which operate at maximum sampling speed of 100 ksps. The DAC's differential non-linearity is less than 1LSB and integral non-linearity is less than 1LSB. The DAC output-to-PIN resistance is 1 k $\Omega$ . Load resistance is recommended to be no less than 10k $\Omega$  and load capacitance to be no more than 100 pF. Typically, the DAC output range is from 0V to 1V, but in the SLG46620/1 the DAC1 output range is from 50mV to 1.05V.

Either the register, SPI, or FSMs can be configured as an input for the DAC. The DAC's output can be configured to the VREF's output pin, PGA, or ACMP.

In some ICs DAC0 is used as a part of the pseudo-differential mode of the PGA macrocell. Therefore, DAC0 is not available when the PGA is in pseudo-differential mode. Also, DAC1 is shared with an ADC macrocell. Therefore, it is impossible to use DAC1 when ADC is used. To connect the DAC macrocell output to a VREF macrocell, it is necessary to configure this pin as analog input/output and configure the Source selector for the VREF to be a DAC.



Sawtooth Generator

The DAC can be used to create a simple Sawtooth Generator shown above. In this case DAC0 uses FSM1 as its data source. The DAC output is connected to the VREF which is connected to PIN3 (DAC\_OUTPUT). The output signal period and resolution are set by the counter data and clock frequency of FSM1. Also, you can add a toggling DFF and connect it to the UP input of an FSM to produce a triangle wave generator shown below. The counter data value changes up and down in time, depending on DFF0's output.



**Triangle Wave Generator** 

The DAC can be used as a reference for an ACMP or PGA negative input in "Differential" and "Pseudo-differential" mode. If the ACMP reference uses a DAC, the user can compare the analog signal to discrete data without using the ADC block.

The GreenPAK DAC:

- can be used to create waveform generators;
- create reference voltage source controlled via SPI;
- can be used in different converters as it converts temperature, humidity and other digitized values to analog voltage.

#### **Technique: EPG**

The Extended Pattern Generator (EPG) is capable of producing a range of outputs that is 92 bytes in size. It retrieves data from non-volatile memory (NVM) and outputs one byte at a time every time the CLK input signal encounters a rising edge. Additionally, the EPG shares its outputs with I2C Virtual Inputs. The maximum clock frequency is up to 1 MHz.

Upon power-up of the system, the EPG behaves differently based on the signal received at the nReset input. Specifically, when the nReset input is active LOW, the EPG will display the initial value at the output. Conversely, if the nReset input is active HIGH, the EPG will display user-defined patterns at the output. This feature enables the user to customize the output of the EPG to their specific needs.

EPG can work continuously when CLK is being applied in Overflow mode or keep at the last byte in Stop at boundary mode.



The EPG Waveforms Editor lets a user select from a variety of predefined Generators, such as SPI, I2C, PWM, or manual, and assign the output accordingly. Each of these generators offers a range of tunable settings, making it easier for the user to build their desired pattern.



The resource bar is a visual representation that indicates the number of bits used in the pattern. It provides the user with a clear understanding of the amount of memory and resources that have been allocated to the current pattern.

### **Application: I2C Master Read Command with ACK Check and Data Comparison**

This application demonstrates how to build a simple I2C master which can read the slave data and compare it with the reference data using SLG46811.



#### **Ingredients**

- SLG46811V
- Two resistors

#### **GreenPAK Diagram**



- Configure EPG generator (see EPG technique) to create I2C Read command and set several SDA and SCL patterns.
- 2. Add one channel in EPG to check the ACK bit every 9th clock at SCL
- 3. Create a 4-bit Multiplexer, as was described in Application: 8-bit Multiplexer. SEL0 and SEL1 choose which data (SDA) will be output.
- 4. Create frequency generator based on CNT1/DLY1 and LUT9, which performs clocks for EPG
- 5. Deglitch filter based on CNTO/DLYO which triggers the I2C pattern.
- 6. Design monitors if the ACK bit check was present during the I2C command, if the I2C slave doesn't respond, the transmission stops.
- 7. When the I2C slave starts sending the data back, they are compared with the reference data stored in SHR 0. At every clock during comparison the data in SHR0 is shifted and compared with the data received. DFF7 stores the comparison result until the read command.

I.Basic Blocks Functions

#### **Application: I2C Master Write Command with ACK Check**

This application demonstrates building a simple I2C master using the SLG46811 device. The I2C master built using this device is capable of rewriting one or multiple bytes, making it a great solution for systems that do not require a complex implementation.



#### **Ingredients**

- SLG46811V
- Two resistors

#### **GreenPAK Diagram**



- Configure EPG generator (see <u>EPG technique</u>) to create I2C Write command and set several SDA and SCL patterns.
- 2. Add one channel in EPG to check the ACK bit every 9th clock at SCL.
- 3. Create a 4-bit Multiplexer, as was described in Application: 8-bit Multiplexer. SEL0 and SEL1 choose the data (SDA) to be outputted.
- 4. Create frequency generator based on CNT1/DLY1 and LUT9, which performs as clocks for EPG.
- 5. Deglitch filter based on CNTO/DLYO which triggers the I2C pattern.
- 6. Design monitors if the ACK bit check was present during the I2C command if the I2C slave doesn't respond, the transmission stops.

#### **Application: I2C Programable Pattern Generator Using Shift Registers**

This application demonstrates the construction of a simple pattern generator with a capacity of up to 32 bits, utilizing the SLG46811 device. Such an approach can prove to be beneficial for cost-effective and energy-efficient applications.



#### **Ingredients**

SLG46811V or any GreenPAK with Shift Registers

#### **GreenPAK Diagram**



- 1. Configure Shift Register blocks and connect them serially.
- 2. Connect the output of SHR3 with the D input of SHR0
- 3. Create clock generator using CNT1/DLY1 and LUT9 in MF1
- 4. Use I2C virtual inputs to clear the SHR0-SHR3 and start sending the pattern
- 5. Add PIN9 to output CLK to distinguish the data

#### **Application: Long Length Pattern Using EPG**

This application demonstrates the construction of a pattern generator with a capacity of up to 736 bits, utilizing the SLG46811 device. Such an approach can prove to be beneficial for cost-effective and energyefficient applications.



#### **Ingredients**

SLG46811V

#### **GreenPAK Diagram**



- 1. Configure the EPG generator (see EPG technique) and set the data that should be outputted
- 2. Create an 8-bit Multiplexer, as was described in Application: 8-bit Multiplexer, and connect to appropriate outputs of EPG
- 3. Create a frequency generator based on CNTO/DLYO and LUTO, which performs clocks for EPG.
- 4. Configure CNT3/DLY3 to count 92 clocks generated by the frequency generator.
- 5. 3-bit counter-based DFF8, DFF9, and DFF11 select data outputted from EPG see Technique: Multiplexing a Bitstream.
- 6. Add EN PIN5 to start the pattern when HIGH and stop when LOW.

#### **Application: Basic SPI Master**

This application demonstrates how to build a simple SPI master using the SLG46811 device. With this device, the SPI master is capable of rewriting one or multiple bytes, making it a good solution for systems that do not require a complex implementation.



#### **Ingredients**

SLG46811V

#### **GreenPAK Diagram**



- 1. Configure the EPG generator (see <u>EPG technique</u>) to create an SPI generator, choose the outputs for MOSI, SCL, and CS signals.
- 2. Create a frequency generator based on CNT1/DLY1 and LUT9, which performs as clocks for EPG.
- 3. Deglitch the filter based on CNTO/DLYO, which triggers the SPI pattern by clocking DFF10.
- 4. To reset DFF10, use EDGE DET with inverted output polarity. When CS goes high, EDGE DET performs inverted peak, which resets the EN signal to stop the pattern.



### Chapter 6 **Pulse-based Control**

This chapter presents applications that control the pulse width of a signal. This most commonly involves PWM, which is commonly used for LED controllers, motor controllers, sound.

Basic Blocks &

2. Sequential

Conditioning

4. Safety

5. Communication

6. Pulse-based

Control

Management

**Analog Features** 

Properties

I.Basic Blocks Functions

#### **Technique: Setting a Constant Duty Cycle**

This technique will work with any GreenPAK.

Setting an immutable duty cycle requires one CNT/DLY block, an oscillator, and a DFF. The macrocells should be configured as shown in figure below.



**Simple Duty Cycle Configuration** 

The oscillator determines the period, the DFF is a rising edge detector, and the CNT/DLY block determines the duty cycle. When the rising edge from the oscillator is registered by the DFF it will send a LOW pulse to the CNT/DLY block. This will set the CNT/DLY output LOW, and the output will only rise after the Delay Counter data has been met.

From the DFF's initial configuration change the Q output polarity to "Inverted (nQ)" and connect the output of the DFF. This will allow it to operate as a rising edge detector; it will remain HIGH until a rising edge is detected on the clock, whereupon it will briefly drop LOW. The FILTER/EDGE DET block can also be configured for this purpose.

The oscillator OUTO or OUT1 is connected to the DFF's clock input to generate the period. The period should always be greater than the duty cycle. In this example the period, set by 'OUT1' second divider by, is set to "OSC/64." The CNT/DLY block's Counter data option sets the duty cycle. The delay time sets the duration of the low signal.

The duty cycle is calculated as:  $D=(T_{period} - T_{delay})/T_{period}$ 



CNT/DLY Config



Basic Blocks &

#### **Technique: One Shot Implementation**

This technique can be used in any GreenPAK.

A one shot circuit generates an output pulse with a pre-defined duration. After the circuit produces a pulse, it returns to its stable state and produces no more pulses until it is triggered again. It is a very important component for reset functions, watchdog timers, and many other applications. One shot can be easily implemented in the GreenPAK. Figure below shows a few methods of creating a one shot impulse triggered by the rising edge of input EN. The pulse duration can be adjusted by changing the counter data value in the DLY blocks used.



**Different One-shot Circuit Implementation** 

In many GreenPAKs (see figure below), implementing one shot only takes one DLY block. The only thing that the user needs to do is to switch the mode in block properties window to "One shot" and to select the edge it will detect. It can be either rising, falling, or both.



**One-shot Implementation in SLG46826** 

9. Advanced Analog Features

I.Basic Blocks Functions

#### **Application: Constant Current LED Driver**

This application detects the presence of a cable by measuring the voltage proportional to its resistance. The ACMP's 100uA current source is used to produce the voltage drop across the cable. This configuration is also able to determine which type of connection is being made based on different wire lengths or connected loads.

# PIN 1 (VDD1) PIN 20 PIN 2 PIN 19 PIN 3 PIN 18 PIN 4 PIN 17 PIN 5 PIN 16 PIN 6 PIN 15 PIN 7 (VDD2) PIN 14 PIN 7 (VDD2) PIN 14 PIN 8 PIN 13 SDA PIN 9 PIN 12 PIN 9 PIN 12 PIN 10 (GND) PIN 11 GND

#### **Ingredients**

- Any GreenPAK
- Four capacitors
- Four diodes (2 LEDs, 2 silicon diodes)
- Two resistors

#### **GreenPAK Diagram**



- 1. Configure two ACMPs, each with their IN- source set to the desired threshold.
- 2. Configure LUTs to enable the LED outputs.
- 3. Connect LED1\_1 and LED1\_2 to the anode of a silicon diode and connect the cathode of the silicon diode to the anode of an LED.
- 4. Connect a resistor between the cathode of the LED and ground.
- 5. Connect a capacitor between the anode of the LED and ground.
- 6. Repeat steps 3-5 for the LED2 outputs.
- 7. Connect V SENSE1 and V SENSE2 to the cathode of LED1 and LED2 respectively.

#### **Application: RGB LED Control via I2C**

RGB LEDs are used to add complexity to LED indication systems and can be controlled with a GreenPAK. I2C is used in this application as an easy way to change the duty cycle to produce different colors.



#### **Ingredients**

- Any GreenPAK with I2C
- RGB LED
- Three resistors

#### **GreenPAK Diagram**



- 1. Configure GPIO pins as open-drain outputs for RGB cathode connection.
- 2. Add LUT logic and CNT/DLY2 to create a generator with EN signal.
- 3. Configure a CNT/DLY block to rising-edge delay.
- 4. Add and configure LUTs for each output using <u>Technique</u>: <u>Configuring Standard Logic w/ LUT</u> Macrocells.
- 5. Connect each LUT output to the desired output pins.
- 6. I2C virtual inputs can be changed individually or simultaneously using the I2C virtual output address.
- 7. Counter data of CNT/DLY blocks can be changed individually or simultaneously using the I2C.

#### **Technique: Creating a Breathing LED Pattern**

This technique can be used within any GreenPAK. The quantity of independent Soft ON/OFF channels depends on the number of counters available within the particular part.

A breathing LED pattern can be generated through a consistent difference in pace between two counters. Each counter outputs a high pulse for one clock cycle of their programmed period. Two CNT/DLY blocks are programmed with different counter data settings to provide a small offset between their outputs. These output signals are used to set and reset a flip-flop within the device. The figure below depicts a basic implementation, wherein CNT2/DLY2 sets the ON period and CNT3/DLY3 sets the duty cycle.



**LED Breathing Implementation** 

In the implementation within the figure above the frequency of the PWM is set by CNT2 and can be calculated with the equation:



The effect of the small offset is shown through the waveforms of the figure below. The PWM cycle ends when the counters' outputs coincide. This causes a short high impulse on AND gate and DFF flops. The NXOR gate makes the inversion of the PWM, which provides a soft OFF. PIN2 is the enable signal and while it is HIGH the counters are in high level reset.

#### **Application: Breathing RGB LED**

RGB LEDs are used to add complexity to LED indication systems and can be controlled with a GreenPAK. They can be paired with a soft ON/OFF circuit for a breathing pattern.



#### **Ingredients**

- Any GreenPAK
- One RGB LED
- Three resistors

#### **GreenPAK Diagram**



- 1. Configure GPIO pins as open drain NMOS outputs.
- 2. Create soft ON/OFF circuit as shown in Technique: Creating a Breathing LED Pattern.
- 3. Configure Ripple Counter set Functionality mode to Range: SV-EV cycles (SV=1, EV=3).
- 4. Configure LUTs collectively as a demultiplexer.
- 5. Add enable (EN) signal to start/stop RGB breathing.

#### **Application: Breathing RGB LED Control with I2C**

RGB LEDs are used to add complexity to LED indication systems They can be paired with a soft ON/OFF circuit for a breathing pattern and further controlled with I2C. Changing the CNTO counter data changes the breathing period.



#### **Ingredients**

- Any GreenPAK with I2C
- One RGB LED
- Three resistors

#### **GreenPAK Diagram**



- Create a soft ON circuit as shown in <u>Technique</u>: <u>Creating a Breathing LED Pattern</u> but instead set the counter data for CNT1 and CNT2 to the same value.
- 2. Add MF0 which adds a small offset between CNT1 and CNT2.
- 3. Configure LUT3-LUT5 as a multiplexer switched by the EN signal controlled via I2C.
- 4. Configure LUT0-LUT2 as a demultiplexer which passes the breathing signal according to the timing diagram.





#### Technique: Using DCMP/PWM Macrocell in PWM Mode

This technique is for the DCMP block, available in the SLG46140, SLG46620, and SLG46621.

#### Overview of the DCMP/PWM Macrocell

The DCMP/PWM macrocell is used to compare two 8-bit values or generated PWM signals. There are three DCMP/PWM blocks per IC that can operate independently, and each DCMP/PWM has two 8-bit inputs (IN+, IN-) that can be used to generate a PWM signal. Inputs MTRX SEL#0 and MTRX SEL#1 are used during static PWM generation to select one of the four available registers. Input SHARED PD is used to power on or off the device. The PWM output duty cycle range can be configured to range from 0% to 99.61% or 0.39% to 100%.

#### **Creating the PWM Signal**

One input of the PWM generator is a linearly cycled ramp of data. This is from a counter that counts from 255 down to 0 or vice versa.

The other input should be stable for at least 1 PWM signal period (PWM ramp counter period). It could be data from the SPI, ADC, FSM blocks, or from an internal register of the DCMP/PWM.

The figure shown to the right displays the operation of a DCMP/PWM when IN- is connected to a CNT/DLY block that counts from 255 down to 0 (PWM ramp counter) and the IN+ source is an internal register set to 250.

The IN+ setting is the key to the operation of the macrocell. Static PWM values can be made using the internal registers. PWM dynamic feedback can be made using the ADC. An MCU-controlled PWM can be set by using the SPI interface.

The output OUT- and OUT+ has dead band time that can be from 10 to 80 ns and set in the properties pane of the DCMP/PWM.

R11TB0003CE0000





DCMP/PWM in PWM mode



Deadband time OUT- and OUT+

Basic Blocks & Functions

2. Sequential Logic

3. Signal Conditioning

4. Safety Features

Protocols

6. Pulse-based Control

#### **Application: PWM Selection**

PWM selection is commonly used for functions like adjusting LED brightness and controlling fan speed. In this implementation two LEDs are adjusted to discrete brightness levels based upon the input of two switches.



#### **Ingredients**

- GreenPAK with DCMP
- No other components are needed

#### **GreenPAK Diagram**



- 1. Enable the DCMP by removing VDD from SHARED PD input. Set DCMP/PWM power register to "Power on". Set IN+ selector to "Register selected through the matrix." Set IN- selector to "FSM1 [7:0]." Set the registers of DCMP0: register 0 51; register 1 102; register 2 154; register 3 0.
- 2. Add CNT/DLY block configured as Counter/FSM. Set counter data to 255.
- 3. Configure RC OSC power mode to "Force power on."
- 4. Configure PIN10 and PIN9 to open drain NMOS.
- 5. Add LUT as an inverter.
- Connect input pins to the MTRX SEL pins of a DCMP/PWM block.



### 2. Sequential Logic

Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

**Communication Protocols** 

6. Pulse-based Control

9. Advanced
Analog Features

#### **Application: PWM Generator Using ACMP and DAC**

PWM generators can be used to control devices such as DC motors and LEDs. This implementation uses an analog signal that an ACMP compares with the signal of DACO. CNT3 is used to generate the value for the DAC.



#### **Ingredients**

- GreenPAK with DAC
- No other components are needed

#### **GreenPAK Diagram**



- Connect ACMP0 PWR UP input to POR. Set IN- source to "Ext. Vref (DAC0 out)."
- 2. Set DACO power on signal to "Power on" and Input selection to "From DCMP1's input."
- 3. Configure FSM-compatible CNT/DLY to "Counter/FSM" mode with counter data = 255.
- 4. Set RC OSC power mode to "Force power on."



### 2. Sequential Logic

Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

Communication Protocols

6. Pulse-based Control

#### **Application: PWM Generator Using ADC**

PWM generators can be used to control devices such as DC motors and LEDs. This implementation uses an analog signal connected to an ADC to compare with the value of CNT2 in PWM0. If the CNT2 value is less than the digitized analog signal, the output of PWM0 is high. After CNT2 value is 0 the output of PWM0 is low.



#### **Ingredients**

- GreenPAK with ADC
- No other components are needed

#### **GreenPAK Diagram**



- 1. Remove VDD from the ADC's PWR DOWN input and set PGA Power on signal to "Power on."
- 2. Set PIN6 to "Analog input/output."
- Configure DCMP0/PWM0 by deleting VDD from SHARED PD input. DCMP/PWM power register set Power on. Check that IN+ selector connect to "ADC [7:0]" and IN- selector connect to "FSM0 [7:0]."
- 4. Configure 4-bit LUT1/14-bit CNT2/DLY2/FSM0 as "Counter/FSM" with counter data equal to 255.
- 5. Connect DCMP0/PWM0 OUT+ to output pin.



#### **Technique: Duty Cycle Detection**

This technique can be used within any GreenPAK. Since the input frequency range is limited by the maximum FSM counter data, it is better to use a 16-bit FSM. The PWM detection input frequency should be much slower than the duty cycle reference frequency to improve the accuracy.

Duty cycle detection is important for functions like overload protection, DC/DC conversion, servo motor control, and protocol detection. This design can be easily implemented using a GreenPAK with an FSM block (For the below example a SLG46826 chip is used, see the figure below).



In the implementation shown above, when PIN4 goes HIGH, FSM0 starts counting DOWN, clocked by the internal oscillator. FSM0 is set to 65535 by a rising edge on PIN4. When PIN4 goes LOW, FSM0 starts counting UP with the frequency from internal oscillator divided by CNT1's data value. If FSM0 reaches 65535, DFF3 will be set LOW by the next edge rising edge from PIN4, which flags that the duty cycle is below the set threshold.



The duty cycle reference frequency can be adjusted by changing the CNT1 counter data value via I2C. To calculate the duty cycle threshold, the following formula is used:

$$Duty\ Cycle\ Threshold = \frac{100}{CNT1\ Counter\ data + 2}\ (\%)$$

2. Sequential

Conditioning

4. Safety

Communication **Protocols** 

6. Pulse-based Control

Management

7. Power

This application can be used to convert input frequency to analog voltage. The input frequency is in some predefined range, which can be chosen and adjusted by the design components.



#### **Ingredients**

Any GreenPAK with SPI and a DAC

#### **GreenPAK Diagram**





- Configure SPI to the "ADC/FSM Buffer" mode, change the PAR input data source to "FSM0 [15:8]."
- Configure FSM0 block to "Set (counter value)," change the clock source to CNT1.
- 3. Configure the DAC Input selector "From DCMP1's input" and VREF Source selector to "DACO out."
- 4. To find input frequency range and output analog voltage use the following formulas:

$$f_{min} = \frac{f_{osc}}{(\textit{cNT}1+1) \cdot \textit{FSM0}} \qquad \qquad f_{max} = \frac{f_{osc}}{(\textit{cNT}1+1)} \qquad \qquad \textit{An\_output}_{operating} = V_{ref\_max} - \frac{f_{min} \cdot V_{ref\_max}}{f_{operating}}$$

2. Sequential

Conditioning

4. Safety

**Communication Protocols** 

6. Pulse-based Control

Management

7. Power

This application can be used to convert input frequency to a certain duty cycle. The input frequency is within some predefined range and can be changed by adjusting the counters. The output PWM frequency is constant but can be changed according a given requirement.



#### **Ingredients**

Any GreenPAK with SPI and DCMP

#### **GreenPAK Diagram**





- 1. Configure SPI to the "ADC/FSM buffer" mode and change the PAR input data source to "FSM0[15:8] FSM1[7:0]."
- 2. Configure FSM0 block to "Set (counter value)", change the clock source to "8-bit CNT1/DLY1 (OUT)."
- 3. Configure DCMP0 to compare "SPI [15:8]" data" and "FSM1 [7:0]" data.
- 4. Calculate the input frequency range and operating duty cycle using the following formulas:

$$f_{min} = \frac{f_{osc}}{(\textit{CNT1}+1) \cdot \textit{FSM1}} \hspace{1cm} f_{max} = \frac{f_{osc}}{(\textit{CNT1}+1)} \hspace{1cm} \textit{Duty Cycle}_{operating} = \left(1 - \frac{f_{min}}{f_{operating}}\right) \cdot 100\%.$$

This application can be used to produce a frequency, which can be changed gradually from fmin to fmax and vice versa during a specific time. The frequency does not change linearly for large frequency range.

#### SLG46140 PIN 1 (VDD) PIN 2 **PIN 13** PIN 3 **PIN 12** DIRECTION PIN 4 **PIN 11** PIN 5 **PIN 10** PIN 9 PIN 6 (GND) PIN 8 PIN 7 GND

#### **Ingredients**

Any GreenPAK with DCMPs

#### **GreenPAK Diagram**





#### **Design Steps**

- 1. Configure desired GPIO pins.
- 2. Add, connect, and configure LUTs, P DLY, DFF, DCMPs and CNT/DLY/FSM blocks as shown above.
- 3. Counter data for minimum and maximum frequency and the period of rising/falling are calculated as follows:

$$Counter\ Data_{\max{(min)}} = 255 - \left(\frac{f_{osc}}{f_{\max{(min)}}} - 1\right) \qquad \qquad T_{step} = \frac{t \cdot f_{max} \cdot f_{min}}{f_{osc} \cdot (f_{max} - f_{min})}$$

- 4. Set the appropriate counter data for particular DCMPs selector.
- 5. Set the appropriate CNT/DLY0 counter data for step time Tstep.

.Basic Blocks & Functions

2. Sequential

Conditioning

4. Safety

**Communication Protocols** 

#### **Application: Voltage-Controlled Oscillator**

This application can be used to convert input analog voltage to frequency. The frequency is generated by FSMO, where the counter data is set by ADC. Counter data of FSMO determines the frequency division coefficient. In order to increase the frequency range CNT1 is used as a frequency pre-divider.



#### **Ingredients**

Any GreenPAK with ADC

#### **GreenPAK Diagram**





- 1. Configure PIN6 as "Analog input/output."
- 2. Change the connections of FSM0: FSM data source to "ADC" and Clock to "8-bit CNT1/DLY1(OUT)."
- 3. Power up the ADC block and change the PGA Gain from "x0.25" to "x1."
- 4. In order to find output frequency range and operating frequency use the following formulas:

$$fmax = \frac{fosc \cdot Vinp\_max}{2 \cdot (CNT1 + 1)} \qquad fmin = \frac{fosc}{256 \cdot (CNT1 + 1)} \qquad Frequency(operating) = fmax \cdot \frac{Vinp\_max}{Voltage(operating)}$$



## Chapter 7 Power Management

This chapter presents applications that manage the power usage of an electronic system. Some applications that involve power management are charge pumps, LDOs, discharge circuits.

2. Sequentia Logic

1.Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

5. Communication Protocols

6. Pulse-based Control

105

#### **Technique: Output Discharge**

This technique can be used within any GreenPAK.

An output discharge circuit is a method to prevent an output pin from floating or a brownout of the system. It ensures that the output pin is set to a known "zero" state when there is a condition that should disable the device but that there is no leakage during operation.





The figure above shows the implementation of a quick discharge circuit for a load switch output VOUT. An open drain NMOS output in the GreenPAK has it's drain connected to VOUT. The gate of the NMOS is inverted within the GPIO structure, so there is no need to invert the VOUT\_EN signal within the matrix. When VOUT\_EN is HIGH, the load switch is turned on and the discharge path to GND is open to prevent leakage. When VOUT\_EN is LOW the load switch is turned off and the discharge path to GND is closed to quickly discharge VOUT. To limit the current through the FETs and control the discharge two resistors Rlim and Rdisch are added.



The figure above shows an example of a conditional output discharge circuit within a power sequencer that monitors the level of the power supply that preceded it. Configure PS2\_EN as a push pull output and DISCH as an open drain NMOS output. When V\_PS1 drops below 1024mV, this circuit will turn off the power supply and will discharge the output to GND. A 50µS deadband time is added with CNT/DLY1.

#### **Application: Charge Pump**

A charge pump is a DC-DC converter that uses capacitors for energetic charge storage to create different voltage levels. It can be used to provide additional voltage levels for powering specific interface circuits, sensors etc. Schottky diodes are recommended for best performance.



#### **Ingredients**

- Any GreenPAK
- Two capacitors
- Two diodes

#### **GreenPAK Diagram**



- 1. Set the divider in OSC1 obtain the desired output frequency.
- 2. Configure logic to provide a shutdown function, either through IO or I2C (if available)
- 3. Connect a diode (D1) and Cpump between VDD and CP DRIVE.
- 4. Connect the anode of D2 to the cathode of D1.
- 5. Connect Cout and Rload in parallel between the cathode of D2 and ground.

#### **Application: Two-Stage Charge Pump**

A charge pump is a DC-DC converter that uses capacitors for energetic charge storage to create different voltage levels. It can be used to provide additional voltage levels for powering specific interface circuits, sensors etc. Schottky diodes are recommended for best performance.



#### **Ingredients**

- Any GreenPAK
- Three capacitors
- Three diodes

#### **GreenPAK Diagram**



- 1. Create a basic charge pump design using the steps in Application: Charge Pump.
- 2. Configure logic to add an inverter. Connect the inverter between an output pin and the oscillator.
- 3. Connect an additional diode and capacitor between the first stage and the output stage of the charge pump. The new capacitor and diode should be the same type and value as the first stage's components.

2. Sequential

Conditioning

4. Safety

**Communication Protocols** 

6. Pulse-based

Control

#### **Application: Charge Pump with Output Regulation**

A charge pump is a DC-DC converter that uses capacitors for energetic charge storage to create different voltage levels. This charge pump with output regulation circuit can change the output voltage level via I2C. Schottky diodes are recommended for the best performance.



#### **Ingredients**

- Any GreenPAK w/ ACMPs
- Two capacitors
- Two diodes
- Two resistors

#### **GreenPAK Diagram**



#### **Design Steps**

- 1. Create a basic charge pump design using the steps in Application: Charge Pump.
- 2. Set the IN+ source of ACMP3L to PIN17 (FEEDBACK) and IN- source to the desired Vref.
- 3. Using two resistors R1 and R2 create a voltage divider and connect the divider output to PIN17.
- 4. The output voltage can be calculated using the formula: V\_out= V\_ref R1/R2.
- 5. The GreenPAK can change the output voltage with I2C by setting the Vref for the IN- source of ACMP3L. The feedback resistor divider coefficient can also be changed to regulate the output voltage to a different value.

109

# Sequential Logic

1.Basic Blocks Functions

3. Signal Conditioning

110

#### **Technique: Using the LDO Regulators**

This technique describes the low dropout (LDO) regulator macrocells, available in the SLG46580, SLG46582, SLG46583, and SLG46585.

Low dropout (LDO) regulators maintain the output voltage of a supply at a stable value despite changes in load impedance or supply voltage variations with a minimal dropout voltage. This makes them useful for portable devices that rely on dissipating batteries and RF systems which must handle periodic ripples. Some GreenPAK devices are equipped with LDO regulator macrocells.

Each LDO macrocell has access to 32 possible output voltage levels ranging from 0.90V to 4.35V. Two

different output voltages (VOUT1 and VOUT2) can be programmed. The state of the VOUT1/VOUT2 input selects which voltage level is outputted. Refer to the SLG46580 datasheet for the minimum VIN and VDD values for each output voltage level. Setting the LP MODE EN input LOW (default) selects the High Power (HP) Mode and setting it HIGH selects the Low Power (LP) mode. HP Mode can handle the highest rated output currents, but the LP Mode has a smaller quiescent current which provides a higher efficiency within its smaller rating. The LDOs are only stable in HP Mode when a >2 $\mu$ F capacitor is attached to each LDO's VOUT.



In the properties pane, the slew rate of each LDO can be changed to set a soft start. Each LDO has the option to enable a 300 Ohm

discharge resistor on their output. Each LDO can also collectively enable a 210mA over-current limit and a short-circuit detection that limits the current to 20mA if the output voltage drops below 0.5V while it is in HP Mode.

Enabling the UVLO connection in an LDO sets an ACMP to probe its VIN and shut down the LDO if it drops

below a certain undervoltage lockout (UVLO) threshold (ACMP IN- level). The thermal limitations of the device must be considered when setting up the LDO regulator. The devices are rated at 0.6W of power dissipation at 85°C ambient. Enabling the Temp sensor connection sets ACMP2 to probe the GreenPAK's temperature sensor so it can shut down the LDO if it surpasses the properly programmed temperature and restarts the LDO after it cools down.

#### **Device Specifications**

- SLG46580/SLG46585:
- 4x LDO regulators;
- Imax: HP Mode = 150mA, LP Mode = 100µA
- SLG46582:
- 2x LDO regulators;
- HP Mode Imax = 300mA, LP Mode Imax = 200µA
- SLG46583:
- 1x LDO regulator
- HP Mode Imax = 600mA, LP Mode Imax = 400μA



#### **Application: Flexible Power Island**

A flexible power island can help a designer divide up a power system into small "islands" of power regions that can be spread across a system. It can provide different level regulated voltages to fulfill specific system requirements.



#### **Ingredients**

- Any GreenPAK with internal LDOs
- 7 capacitors

#### **GreenPAK Diagram**



- 1. Set the VOUTO voltage and VOUT1 voltage for each LDO channel.
- 2. Connect POR to each LDO's ENABLE pin.
- 3. Configure an LDO to the "VOUTO/PWR switch" mode and set the OUT MODE pin HIGH to set it as a Power Switch Output.

#### **Application: Boost (Step-up) Converter**

In this application, the SLG47105 is used as a driver for a boost converter. In this design example, the converter steps up VDD2 voltage from 3 to 5V.

#### **Ingredients**

- SLG47105
- MOSFET
- Schottky diode
- Inductor
- Three capacitors
- Four resistors

# SLG47105 VDD2 PIN 1(VDD2, A) PIN 6 (VDD2, B) PIN 11 (GND HV) PIN 1 PIN 2 PIN 3 PIN 14 PIN 7 PIN 8 PIN 9 PIN 17 PIN 8 PIN 9 PIN 10 PIN 1

#### **GreenPAK Diagram**



- 1. Complete the circuit. Connect all components as shown on the circuit diagram.
- 2. Enable HV OUT CTRLO connecting OEO/1 to POR and set their Modes as "Fast for pre-drive" and "Half-Bridge".
- 3. Configure PIN7 and PIN8 as "HIGH and LOW side on"
- 4. Enable ACMP0H. Set its IN- source to "1920 mV" to regulate the output voltage to 5 V. Connect its output to INO of the 2-bit LUT2.
- 5. Configure CNT1/DLY1 as a Delay and connect its output to DFF10's nRESET and IN1 of the 2-bit LUT2. Connect DLY IN to Flex-Div OUT of the OSC1. Set the Flexible divider to 125.
- 6. Connect DFF's D to POR and its CLK to 2-bit LUT2's output.
- 7. Connect DFF's output to both INO and IN1 of the HV OUT CTRLO.

#### **Application: Buck (Step-down) Converter**

In this application, the SLG47105 is used as a buck converter. In this design example, the converter steps down VDD2 voltage to 3.3 V. Also, this design shows how to build an analog PWM block.

#### **Ingredients**

- SLG47105
- Inductor
- Three capacitors



#### **GreenPAK Diagram**



- 1. Complete the circuit: connect one pin of L1 to both PIN7 and PIN8, connect PIN5 to GND; connect PIN19 to the other pin of L1 and C2, connect the other C2 pin to GND; connect the load in parallel to C2.
- 2. Enable HV OUT CTRLO connecting OEO/1 to POR and set their Modes as "Fast for pre-drive" and "Half-Bridge".
- 3. Configure PIN7 and 8 as "HIGH and LOW side on"
- 4. Enable ACMPOH by connecting to POR. Set its IN + gain to x0.5 and IN source to "1664 mV" to regulate the output voltage to 3.3 V. Connect its output to INO of the 2-bit LUT2.
- 5. Configure CNT1/DLY1 as a Delay and connect its output to DFF10's nRESET and IN1 of the 2-bit LUT2. Connect DLY IN to Flex-Div OUT of the OSC1. Set the Flexible divider to 125.
- 6. Connect DFF's D to POR and its CLK to 2-bit LUT2's output.
- 7. Connect DFF's output to both INO and IN1 of the HV OUT CTRLO.

#### **Application: Back-to-Back Reverse Current Blocking**

Back-to-back reverse current blocking is used to prevent reverse current flow. It typically involves two MOSFETs connected in opposite directions to block current in the reverse direction. This configuration is widely used in power supplies, battery-powered devices, and DC-DC converters to enhance efficiency and prevent damage from reverse currents.



#### **Ingredients**

GreenPAK with two PMOS

#### **GreenPAK Diagram**





- 1. Configure P-FET Power Switch0 and Switch1 control mode to "Internal (ON input)"
- 2. Connect PIN 7 to PIN 10
- 3. Connect load to PIN 11

#### **Technique: Remote Sense Functionality**

This technique can be used within SLG51003.

When there is a significant voltage drop across long or high-resistance power supply lines, the SLG51003 with Remote Sense functionality can compensate for it, by sensing the voltage at the load, rather than directly at the output of the LDO and thus, ensuring that the load receives the correct voltage.



Remote Sense Mode Implementation

Remote Sense mode can be utilized by LDO1 (LDO\_HP) to regulate the voltage at the load side. In this mode, the GPIO1 pin is configured as an analog input to serve as the remote sense pin. GPIO1 should be connected to the load side that is being powered by LDO1. Because GPIO1 relies on VDDIO, the VDDIO voltage should be higher than the voltage at the LDO1 output.



In the image above, a comparison of the LDO1 operation mode with Remote Sense and without it is shown. As the load current increases, a voltage drop is observed. This occurs due to parasitic parameters on the PCB. In Remote Sense mode, this drop can be compensated. The LDO1 will maintain the set voltage level relative to the voltage at the load by increasing or decreasing the output voltage if needed. You can find more information about this mode in <a href="AN-CM-405 SLG51003 Remote Sense Functionality">AN-CM-405 SLG51003 Remote Sense Functionality</a>. Load regulation performance depends on the parasitic parameters of the system and electrical specifications can be affected for LDO1 in remote sense mode operation.

#### **Technique: LDO Explained**

This technique can be used within SLG51000/1/2/3.

Low Dropout Regulator (LDO), it is a type of voltage regulator that can maintain a constant output voltage even when the input voltage is very close to the output voltage. The SLG51000/1/2/3 product line is comprised of 3 to 8 LDOs in a single package compact and is designed for advanced sensor applications and other battery powered equipment. With the help of such LDOs, voltage from 0.8 V to 3.75 V and current up to 1.3 A can be supported for different projects.

LDOx block has an Enable/Disable input for the LDO, as well as output flags for VOUT OK and Current Limit, which can be used with other blocks for creating flexible design.



LDOs contains settings for parameters such as output voltage, minimum and maximum voltage, current limit settings, and others. This block is configurable, LDO settings may vary according to type and specification, and it has the following settings: Output voltage, Startup and Functional Current Limit, Slew Rate, Pull-down resistor and other.



#### **Technique: Delay Macrocells**

This technique can be used within SLG51002 and SLG51003.

The delay block used in this IC allows the setting of UP and DOWN times, making it convenient to create a power sequencer for controlling LDO and GPIO. This block has sensitivity settings for the UP and DOWN signals, delay settings, and the ability to select a different Clock (CLK).



Additionally, an extra CNT/DLY block can be used as a divider, significantly increasing the range of delay time settings. Below is an example of how the DLY1 block is used in a customer design. A frequency of 125 kHz is used as the CLK with a divider of 255 through an additional CNT block. At the input of the DLY1 block, the CLK frequency is 500 Hz, after which the register value can be selected from 1 to 31 using the settings, thereby setting the delay time for the UP and DOWN signals.



On the timing diagram below, it can be seen how this block works. By using a single block, different on and off times can be set. The UP and DOWN signals can be tied. More information about this functionality can be found in this application note (AN-CM-357 Power Profile for Advanced Sensor Applications).



#### **Technique: Crash Sequence Block**

This technique can be used within SLG51003.

A crash sequence digital block operates as a configurable watchdog that allows to perform the soft power-down sequence. It can be triggered either from System State Machine error conditions or from its inputs from the matrix interconnect. Both Crash detect and Force reset inputs are OTP configurable as an active-high or active-low input.



The block is composed of two inputs and one output. When a high level is received at the "Crash Detect" input or one of the conditions that puts the chip into Reset state (CS de-assertion, Over Temperature Detection, Crash Detection, Software Reset Request, or UVLO Detection) is triggered the block's output is immediately raised. This signal can be used to Disable the LDOs/GPIOs or something else. After a configurable delay (10 ms, 50 ms, 100 ms, 200 ms), the chip enters Reset mode and turns off all internal blocks and all digital logic.

The "Force Reset" block input immediately turns off all blocks and digital logic, bypassing the configured delay (10 ms, 50 ms, 100 ms, 200 ms).



#### **Technique: GPIOs Features**

This technique can be used within any SLG5100x.

The entire line of SLG5100x chips is equipped with GPIOs. Two of which are used for I2C (SCL, SDA), while the rest are available for use. If I2C is not used, these GPIOs can also be utilized in the project. All GPIOs have a configurable internal debouncer and edge debouncer settings. Additionally, GPIOs can be configured as inverted if needed.



In SLG51002 and SLG51003, enhanced GPIOs are used, which have a higher voltage range, pull-up resistors, and additional operating modes.



Below can see a table comparing the GPIO functionality for SLG5100x line product.

| Part Number           | SLG51000                     | SLG51001                     | SLG51002                                                                                                                                          | SLG51003                                                                                                                                          |
|-----------------------|------------------------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Total number of GPIOs | 6                            | 4                            | 6                                                                                                                                                 | 5                                                                                                                                                 |
| Slave Adress Selector | No                           | No                           | Yes                                                                                                                                               | Yes                                                                                                                                               |
| Debounce              | Yes                          | Yes                          | Yes Yes                                                                                                                                           |                                                                                                                                                   |
| Debounce Edge         | Yes                          | Yes                          | Yes                                                                                                                                               | Yes                                                                                                                                               |
| Debounce Time         | 30 us, 5 ms, 10 ms,<br>50 ms | 30 us, 5 ms, 10 ms,<br>50 ms | ns, 30 us, 5 ms, 0 ms, 5<br>10 ms, 50 ms 10 ms, 5                                                                                                 |                                                                                                                                                   |
| Inversion             | Yes                          | Yes                          | Yes                                                                                                                                               | Yes                                                                                                                                               |
| Bypass                | Yes                          | Yes                          | Yes                                                                                                                                               | Yes                                                                                                                                               |
| Resistor              | No                           | No                           | Floating, Pull Up, Pull<br>Down                                                                                                                   | Floating, Pull Up Pull Down                                                                                                                       |
| Input Mode            | Input                        | Input                        | Ultra Low Voltage Digital<br>Input,<br>Low Voltage Digital Input,<br>Digital in with Schmitt<br>Trigger,<br>Digital in without Schmitt<br>Trigger | Ultra Low Voltage Digital<br>Input,<br>Low Voltage Digital Input,<br>Digital in with Schmitt<br>Trigger,<br>Digital in without Schmitt<br>Trigger |
| Output Mode           | Open-drain                   | Open-drain                   | Push-pull, Push-pull, Open-Drain NMOS/PMOS Open-Drain NMOS/I                                                                                      |                                                                                                                                                   |
| Voltage Range         | 1.2 V or 1.8 V               | 1.2 V or 1.8 V               | from 1.2 V to 5 V                                                                                                                                 | from 1.2 V to 5 V                                                                                                                                 |

#### **Technique: Protection Features**

This technique can be used within any SLG5100x.

SLG5100x devices have start-up and functional current limits, under-voltage lockout (UVLO), thermal shutdown, and configurable temperature alerts. I2C is implemented in these devices which allow the user to read various states of the device such as the state of current limits, VOUT\_OK, temperature sensor (on the GPIO), and other various registers.



Information about errors can be obtained through I2C or GPIO in SLG5100x devices, and PMIC can also disable LDOs in a programmed sequence during an emergency. A brief overview of the protection features in SLG5100x can be found in the table below. Please refer to the application note (<u>AN-CM-377 Introduction to SLG5100x Protection Features</u>) for more information.

| Туре                                   | Trigger                                                                                                                                                                      | Programmability                                     |
|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|
| Under-voltage Lock-<br>out (UVLO)      | An internal UVLO monitor with a programmable threshold monitors the VDD input voltage and shuts down the system if the voltage drops below the threshold                     | 2.215 V — 2.658 V                                   |
| Thermal Shutdown                       | Thermal shutdown or over-temperature protection activates when the temperature of the device has reached 140 °C                                                              | The shutdown temperature is set to 140 °C           |
| Configurable<br>Temperature Alerts     | Temperature warning flag is triggered at temperatures above the set threshold                                                                                                | Temp Warning = 90 / 100 / 110 / 120°C Debounce time |
| Voltage Output OK<br>flag for each LDO | When VOUT reaches 90% of its target value                                                                                                                                    | Debounce time                                       |
| Current Limit flag for each LDO        | Current limitation detected                                                                                                                                                  | Functional and startup current limits Debounce time |
| Device Interrupt<br>Request            | <ul> <li>LDOs current limits</li> <li>Power-on reset</li> <li>System reset</li> <li>Power sequencer crash</li> <li>Over-temperature</li> <li>Matrix event (input)</li> </ul> | Event sensitivity                                   |

#### **Technique: Power Sequencer Explained**

This technique can be used within SLG51000/1/2.

The SLG51000/1/2 PMIC Power Sequencer is designed to control the power-up and power-down timings for six resource enable outputs. The power sequencer as the supplies/resources controller is only enabled in the READY (the power sequencer can control the supplies/resources and all digital resources



are enabled) and SEQUENCE DOWN states (CS de-assertion, over-temperature, power sequencer crash request, UVLO fault condition, software reset). Triggering and control of the power sequencer function may be performed directly from the input signals or via logic functions of the input signals using the pool of LUTs.



Two dedicated configurable sequences (up and down) are initiated with the Trigger up and Trigger down control signals from the matrix interconnect. The Trigger up and Trigger down inputs are only acted upon in the Idle and Seq up states, respectively. Triggering of a power-up sequence from Idle is prevented if a Trigger down is simultaneously requested. If a Trigger down occurs during the power-up sequence (at slots 0 through 5), the sequencer will keep powering up until it reaches the Seq up state. In the Seq up state, the trigger-down signal is then re-evaluated. In the event triggered in the Seq up state, the power sequencer crashes down to the Idle state through states PS5 to PS0. The power sequencer also provides a crash sequence which is triggered either from the main FSM error conditions or from the power sequencer's trigger-crash input from the matrix interconnect. The trigger-crash input is OTP configurable as an active-high or active-low input to the power sequencer. The crash sequence operates in the same way as a power-down sequence with the exception that only the minimum (delay) slot timer is used to control slot advancing. The power-down enable inputs from the matrix interconnect are ignored during crash sequences.

To find out a detailed description on how to customize power sequencer and see more examples read <u>AN-CM-356 SLG51000</u>, <u>SLG51001</u> and <u>SLG51002 Power Sequencer</u>.

#### Technique: SLG51002 HC LDOs Auto Bypass Mode Explained

Auto-bypass mode in HC LD04&LD05 allows automatically switch between LD0 and Load Switch modes.



Auto Bypass mode entry: starting with LDO mode, VIN decreases, at the point where the VOUT no longer able to regulate against further decrease of VIN, the LDO will automatically enter the bypass mode

- The pass device PMOS is fully on
- VOUT follows VIN, VOUT = VIN ILOAD \* RDS<sub>ON</sub>

Auto Bypass mode exit: starting with Bypass mode, when VIN increases, VOUT will initially follow VIN to go up, as soon as VOUT reaches the regulated voltage, the LDO will automatically go back to the LDO mode

- The pass device PMOS is regulated
- VOUT is regulated at the target value

#### Force Bypass mode:

- The pass device PMOS is always fully on
- VOUT not regulated anymore, always follow VIN, VOUT
   VIN ILOAD \* RDS<sub>ON</sub>



# Sequential Logic

Basic Blocks Functions

3. Signal Conditioning

4. Safety Features

**Communication Protocols** 

#### Technique: SLG51002, SLG51003 I2C Control Code Selection

SLG51002/SLG51003 have an I2C slave address with the default set to 0x75. The slave base address can be OTP programmed. For four LSBs of the slave address in SLG51002 and for three LSBs in SLG51003, each bit

can be sourced independently from the OTP or by a value defined externally by GPIO1 - GPIO4 and GPIO1 - GPIO3 respectively. I2C slave address controlled by GPIOs depends on its state.

The logic level of each bit in the control code can be independently selected from either a register or a GPIO. The table below shows the GPIOs and PINs that correspond to each bit. The LSB of the slave address is defined by the value of GPIO1. Possible use 16 cases controlled by GPIO 1, 2, 3, 4 for SLG51002 and 8 cases for SLG51003.

|       | SLG51 | 1002    | SLG51003 |         |  |
|-------|-------|---------|----------|---------|--|
| GPIO  | PIN   | Control | PIN      | Control |  |
| driu  | FIIN  | Code    | ГП       | Code    |  |
| GPI01 | D2    | I2C_SA1 | 14       | I2C_SA0 |  |
| GPI02 | D3    | I2C_SA2 | 13       | I2C_SA1 |  |
| GPI03 | C3    | I2C_SA3 | 12       | I2C_SA2 |  |
| GPI04 | B2    | I2C_SA4 |          |         |  |

I2C slave address control steps:

- Change I2C\_ADDR\_SEL to non-zero for selected GPIO or GPIOs;
- Change I2C address by external logic level on inputs of GPIOs when it needed.

Example: The SLG51002 has an I2C slave address with the default set to 0x75. Setting I2C\_ADDR\_SEL to 0x0F defines GPI01-GPI04 for external I2C slave address control by the logic level on its inputs. The table of correspondence of I2C\_ADDR\_SEL register bits with GPI0 pins are shown below.

| Control code selection: |       |       |       |       |  |  |  |
|-------------------------|-------|-------|-------|-------|--|--|--|
| #3 #2 #1 #0             |       |       |       |       |  |  |  |
| Reg                     | 0     | 1     | 0     | 1     |  |  |  |
| PIN                     | GPI04 | GPI03 | GPI02 | GPI01 |  |  |  |

To have default 0x75 device address, GPI01 and GPI03 should be pulled HIGH. If GPI01 pulls to LOW, GPI03 keeps HIGH the I2C became 0x74. GPI01 corresponds bit[0] of I2C\_ADDR\_SEL. Keep GPI01 pulled LOW, GPI03 HIGH and pull GPI02 HIGH. GPI02 corresponds to bit[1] of I2C\_ADDR\_SEL which increases I2C address on 2 bits respectively and became 0x76. Min device address value is 0x70 when GPI01-GPI04 pulled LOW, max device address value is 0x7F when GPI01-GPI04 pulled HIGH.





Sequential

Conditioning

4. Safety

**Communication Protocols** 

6. Pulse-based

Control

Management

### Technique: SLG5100x Device Interrupt Request Block

This technique can be used with SLG51000/1/2/3.

The device interrupt request is the logical OR of the unmasked event register signals. Each event register has an associated interrupt mask register, which controls whether or not the event register signal contributes to the device interrupt request via the logical OR. The output (or Interrupt) of the DIR block that can be configured to feed the matrix interconnect is active high (fault = 1) in the chip.

The "Matrix event" detects events on a single output from the matrix interconnect. It has configurable sensitivity and provides a method to latch and retain short time frame signal events.



I2C slave address control steps:

- Change I2C\_ADDR\_SEL to non-zero for selected GPIO or GPIOs;
- Change I2C address by external logic level on inputs of GPIOs when it needed.

Example: The SLG51002 has an I2C slave address with the default set to 0x75. Setting I2C\_ADDR\_SEL to 0x0F defines GPI01-GPI04 for external I2C slave address control by the logic level on its inputs. The table of correspondence of I2C\_ADDR\_SEL register bits with GPI0 pins are shown below.

Controls the sensitivity of the "Matrix event" Field:

- Events Disabled
- Rising edge Event Sensitive
- Falling edge Event Sensitive
- Both edges sensitive
- Level sensitive event HIGH, stuck until sig rises
- Level sensitive event LOW, stuck until sig falls

Table of Interrupts, Status and Mask Registers

| Interrupts (Logical OR of EVENTs) |                          |                                            |        |   |        | STATUS (Read Only) |         | MASK (Default 0×00) |  |
|-----------------------------------|--------------------------|--------------------------------------------|--------|---|--------|--------------------|---------|---------------------|--|
| EVENT Name                        | EVENT Symbol             | EVENT Symbol EVENT Description Address Bit |        |   |        |                    | Address | Bit                 |  |
|                                   | FLT_POR                  | Power-on reset event occured               |        | 5 |        |                    |         |                     |  |
|                                   | FLT_RST                  | System reset event occured                 |        | 4 |        |                    |         |                     |  |
| SYSCTL_FAULT_LOG1                 | FLT_POWER_SEQ_ CRASH_REQ | Power sequencer requested shutdown occured | 0×1115 | 2 | -      | -                  | -       | -                   |  |
|                                   | FLT_OVER_TEMP            | Over temperature shutdown occured          |        | 1 |        |                    |         |                     |  |
| LD01_EVENT                        | EVT_ILIM_FLAG            | Current Limit Flag Event Detected          | 0×20C0 | 0 | 0×20C1 | 0                  | 0×20C2  | 0                   |  |
| LD02_EVENT                        | EVT_ILIM_FLAG            | Current Limit Flag Event Detected          | 0×22C0 | 0 | 0×22C1 | 0                  | 0×22C2  | 0                   |  |
| LD03_EVENT                        | EVT_ILIM_FLAG            | Current Limit Flag Event Detected          | 0×23C0 | 0 | 0×23C1 | 0                  | 0×23C2  | 0                   |  |
| LD04_EVENT                        | EVT_ILIM_FLAG            | Current Limit Flag Event Detected          | 0×25C0 | 0 | 0×25C1 | 0                  | 0×25C2  | 0                   |  |
| LD05_EVENT                        | EVT_ILIM_FLAG            | Current Limit Flag Event Detected          | 0×27C0 | 0 | 0×27C1 | 0                  | 0×27C2  | 0                   |  |
| LD06_EVENT                        | EVT_ILIM_FLAG            | Current Limit Flag Event Detected          | 0×29C0 | 0 | 0×29C1 | 0                  | 0×29C2  | 0                   |  |
| LD07_EVENT                        | EVT_ILIM_FLAG            | Current Limit Flag Event Detected          | 0×31C0 | 0 | 0×31C1 | 0                  | 0×31C2  | 0                   |  |
| LD08_EVENT                        | EVT_ILIM_FLAG            | Current Limit Flag Event Detected          | 0×32C0 | 0 | 0×32C1 | 0                  | 0×32C2  | 0                   |  |
| CVCCTI EVENT                      | EVT_MATRIX               | Matrix input event Detected                | 0×1116 | 1 | 0×1117 | 1                  | 0 1110  | 1                   |  |
| SYSCTL_EVENT                      | EVT_HIGH_TEMP_ WARNING   | High temperature warning Detected          | 0×1116 | 0 | 0×1117 | 0                  | 0×1118  | 0                   |  |

Event: Triggered by Status signal. Status (Read Only): Current signal.

R11TB0003CE0000

Mask: Enable Mask to IRQ. Default = 0x00



9. Advanced Analog Features

Technique: SLG5100x Device Interrupt Request Block

# Application: Scenario of Two Independent Sequences Using the

This application can be used within the SLG51002.

Using the SLG51002, up to eight voltage rails can be powered, with few sequences set up for independent control. This allows the PMIC to be used in applications where independent, stable power is required for two devices.

#### **Ingredients**

**SLG51002** 

- SLG51002
- Capacitors

#### SLG51002 (GPIO3) C3 B3 (VDD) T EN CAM1 C2 (VDDIO (GPIO4) R2 ☐ EN CAM2 **B4** (cs) B5 (VIN1 2) A1 (VIN5) E5 (VIN6) (VOUT4) D1 (VOUT7) C5 CAM1 READY < CAM2\_READY < (GND) C1

#### **GreenPAK Diagram**



#### **Design Steps**

- 1. Set the VOUT, Slew Rate, Current limits and other settings for each LDO.
- Set up the power sequencer for delay time between power rails for Camera 1 using the Power Sequencer block.
- 3. Set up the power sequencer for delay time between power rails for Camera 2 using the delay (DLYx) blocks.
- 4. Configure the GPIO to trigger UP/DOWN sequencers for each camera.

125

2. Sequential Logic

.Basic Blocks
Functions

3. Signal Conditioning

4. Safety Features

5. Communication Protocols

6. Pulse-based Control

7. Power Management

9. Advanced Analog Features

## **Application: Powering Two Cameras with Sequencer and Two Scenarios for the SLG51000C**

In this application, the configured design of SLG51000 have two schematics functions:

- GPIO1-2 control is included, and LDO outputs are based on the GPIOs state. Feature: turning on the second camera will reset Power Sequencer and turn on both cameras with programmed delays and sequence.
- 2. GPIO3 controls all LDO outputs enabled, GPIO1-2 states ignored.

#### 

SLG51000

#### **Ingredients**

- SLG51000
- 13 Capacitors

#### **GreenPAK Diagram**



#### **Design Steps**

- 1. Complete the circuit. Connect all components as shown on the circuit diagram.
- 2. Set the output voltages, startup and functional current limits for each LDO channel.
- 3. Set up Power Sequencer and LUTs as shown on the circuit diagram.



Read more on how to customize power sequencer and see more examples in <u>AN-CM-356 SLG51000</u>, <u>SLG51001 and SLG51002 Power Sequencer</u>.

## 9. Advanced Analog Features

# **Application: SLG51002/3 I2C Address Configuration without Reprogramming**

Procedure of changing I2C slave address without reprogramming OTP with using external signal on GPIO/s. May be applicated when two PMICs with the same OTP are used in one system.



#### **Ingredients**

- SLG51002
- SLG51003

#### **GreenPAK Diagram**



- 1. Power VDD and CS for one of the SLG51003.
- 2. If the Control Code Selection isn't enabled on default OTP, send command to change 0x1149 register with 0x01 value. Now GPIO1 controls I2C slave address by external logic level on it.
- 3. Power the second SLG51003 VDD and CS or only CS if VDD tight together for both at least after 10 ms when first already powered.
- 4. Pull logic level to LOW on GPIO1 to change address to 0x74 on first SLG51003 part. The second part keeps default 0x75 address.
- 5. Configure each PMIC separately via I2C bus within the allowed register map by datasheet.



# **Chapter 8 Motor Control**

This chapter presents applications that control DC motors. It centers on using the integrated H-Bridge of the SLG47105 and its accompanying blocks to provide current and voltage regulation.

2. Sequential Logic

1.Basic Blocks &

3. Signal Conditioning

4. Sarety Features

5. Communication Protocols

6. Pulse-based Control

7. Power Management

#### **Application: H-Bridge Control**

An H-bridge is an electronic circuit constructed of four transistors that reverses the polarity of the voltage across a load. They are often used to control DC motors.



#### **Ingredients**

- Any GreenPAK
- Four transistors
- Four diodes

#### **GreenPAK Diagram**



- 1. Add and configure inputs and outputs.
- 2. Add delay blocks using Technique: Optimizing CNT/DLY Accuracy.
- 3. Add and configure LUTs for each output using Technique: <a href="Configuring Standard Logic w/ LUT Macrocells">Configuring Standard Logic w/ LUT Macrocells</a>.

#### **Technique: Using the HV OUT CTRL Blocks**

This technique describes the use of HV OUT CTRL blocks in the SLG47105V.

SLG47105V consists of 2 HV OUT CTRL macrocells namely HV OUT CTRL0 and HV OUT CTRL1. Each macrocell can be used to drive 2 unidirectional DC motors or 1 bidirectional DC motor. Both HV OUT CTRL0/1 can be used to drive a stepper motor.

To enable HV OUT CTRLO/1 connect Sleep 0/1 to an active LOW. Each Sleep pin can be activated separately. To drive unidirectional select HV OUT mode as "Half-Bridge" and for bidirectional motors select "Full-Bridge". In "Full-Bridge" mode select Mode control as "IN-IN" or "PH-EN". Table 2 displays the "Half-Bridge" control logic. Table 2



**HV OUT CTRL0/1** 

and Table 4 respectively describe "IN-IN" and "PH-EN" mode controls. Pin 7/8/9/10 (Hi-Z by default) are used to control motor speed using PWM. These pins can be pulled up/down externally. In "Full Bridge" mode, Pin 7/9 and Pin 8/10 can be connected in parallel externally.

To control DC motor with "IN-IN" mode control using PWM0/1, connect IN1 to an active LOW signal in fast mode and an active HIGH signal in slow decay mode. Connect IN0 to PWM0/1 output. Fast decay mode is used to instantly reduce inductive current and coast motor towards zero velocity. The slow decay mode causes a slow reduction in inductive current and rapid deceleration.

IN-IN Mode Logic for Full Bridge Mode

| Sleep 0/1 | INO | IN1 | Pin 7/9 | Pin 8/10 | Function |
|-----------|-----|-----|---------|----------|----------|
| 1         | Χ   | Χ   | Hi-Z    | Hi-Z     | Off      |
| 0         | 0   | 0   | Hi-Z    | Hi-Z     | Coast    |
| 0         | 0   | 1   | L       | Н        | Reverse  |
| 0         | 1   | 0   | Н       | L        | Forward  |
| 0         | 1   | 1   | L       | L        | Brake    |

Half-Bridge Mode

| Sleep<br>0/1 | 0E | INO/1 | Pin<br>7/8 | Function    |
|--------------|----|-------|------------|-------------|
| 1            | Χ  | Х     | Hi-Z       | Off         |
| 0            | 0  | Х     | Hi-Z       | Off (Coast) |
| 0            | 1  | 0     | L          | Brake       |
| 0            | 1  | 1     | Н          | Forward     |

#### PH-EN Mode Logic for Full Bridge Mode

| Sleep 0/1 | Decay    | EN/PWM | PH/Direct | Pin 7/9 | Pin 8/10 | Function    |
|-----------|----------|--------|-----------|---------|----------|-------------|
| 1         | Χ        | Χ      | Χ         | Hi-Z    | Hi-Z     | Off (Coast) |
| 0         | 0 (fast) | 0      | Χ         | Hi-Z    | Hi-Z     | Coast       |
| 0         | 1 (slow) | 0      | X         | L       | L        | Brake       |
| 0         | Χ        | 1      | 0         | Н       | L        | Forward     |
| 0         | Χ        | 1      | 1         | L       | Н        | Reverse     |

When any fault occurs, Fault A/B pins go HIGH and HV OUT CTRL0/1 are disabled. When the fault pins go LOW, normal operation is restored. Fault A and Fault B consist of all fault signals for VDD2\_A and VDD2\_B separately. When an overcurrent condition occurs, OCP Fault A/B goes HIGH. An OCP deglitch time can be enabled on Pin 7/8/9/10. The OCP deglitch time enable is shared among Pin 7/8 and Pin 9/10. The retry time for OCP is user selectable and separate for each pin. When die temperature exceeds safe limits, Thermal Fault turns HIGH. VDD2\_A and VDD2\_B have separate UVLO (undervoltage lock out) enable.

# 2. Sequential Logic

1.Basic Blocks Functions

3. Signal Conditioning

4. Safety Features

Communication Protocols

131

#### Technique: Using the SLG47105 PWM Blocks in Regular Mode

This technique is for the PWM blocks, available in the SLG47105.

PWM is commonly used in DC motor control, LED brightness control, and other applications. SLG47105 is equipped with advanced PWM blocks to handle higher voltage level dedicated PINs. PWM blocks have already been implemented in other GreenPAKs as discussed in <a href="Technique: Using DCMP/PWM Macrocell in PWM Mode">Technique: Using DCMP/PWM Macrocell in PWM Mode</a>, but the two PWM blocks in the SLG47105 integrate the counters involved in their operation while in "Regular Mode" and include more advanced settings.



The first 8-bit counter included in the block is PWM Period CNT, which sets the frequency of the PWM signal and counts from 0 to 255 and so on. There are two PWM outputs: "OUT+" and "OUT-". OUT+ is logic HIGH at the start of the period and once the PWM period counter reaches the duty cycle value, the output changes to logic LOW until the PWM period ends, as shown in the figure below. OUT+ is the positive PWM output and OUT- is the negative PWM output that is inverted to OUT+ and shifted for deadband time if defined. Both can invert their output by register settings.

In Regular Mode (described in this article) the Duty cycle source is set to "Duty Cycle CNT". The second 8-bit counter included, named Duty Cycle CNT, increments or decrements the duty cycle value for the next PWM period dependently on UP/DOWN input. The Duty Cycle CLK is an external clock from the matrix by default. It changes the duty cycle value by the rising edge. It can also be set to be clocked by the period counter overflow or every 2nd or 8th pulse of the overflow.

The PWM block has an 8-bit resolution by default, but a 7-bit resolution can be selected instead to allow for a higher PWM frequency. The PWM duty cycle changes at a step of 0.4 % for the 8-bit resolution and 0.8 % for the 7-bit resolution. The duty cycle can change from true 0% to true 100%. PWM starts from the Initial duty cycle value. The block has an UP/DOWN internal connection that defines the direction of the duty cycle change. The duty cycle will increase if set HIGH and decrease if set LOW.



The Keep/Stop connection can either be selected to

hold the duty cycle ("Keep" setting) or to hold the duty cycle and the OUT+ and OUT- outputs constant ("Stop" setting) when it is set HIGH. The Continuous/Autostop mode is either set to "Continuous" where the PWM output duty cycle overflows when it reaches the full range value (default setting) or to" Autostop" where the PWM output stops when it reaches 0% or 100% of the duty cycle. When "Autostop" is selected, the "Boundary OSC disable" option can be activated. This allows disabling Oscillator, used by PWM cell, automatically when 0% or 100% of the duty cycle is reached.

#### Technique: Using the SLG47105 PWM Blocks in Preset Registers Mode

This technique is for the PWM blocks, available in the SLG47105. More information on how the block works can be found in <u>Technique</u>: <u>Using the SLG47105 PWM Block in Regular Mode</u>.

The previous technique explained how to use the SLG47105 PWM block in "Regular Mode" with the Duty Cycle Source set to "Duty Cycle CNT." This technique will instead explain how to use the block in "Preset Registers Mode" where the duty cycle cycles through 16 predefined values (Reg File). Using the "Preset Registers Mode" allows for non-linear PWM patterns for motor control (i.e. sinusoidal or logarithmic).

Selectable preset registers are reserved to determine 16 different PWM duty cycle values. Duty Cycle CLK can be selected to Clock from Matrix or PWM period CNT ovf (overflow). A clock on the Duty Cycle CNT CLK input changes which register's value is applied to compare with the Period CNT. Reg File is shared between the two PWM macrocells. Either all 16 bytes, the least significant 8 bytes, or the most significant bytes can be used. The initial byte is limited by the unique ranges of each setting.



The internal connections have a similar function as Regular Mode but apply to the 16-byte structure rather than the 8-bit counter. The polarity of Up/Down decides whether the next register (HIGH) or the previous (LOW) is applied. The Keep/Stop operates the same way but halts the sequence of registers.

#### **Application: Constant Voltage Brushed DC Motor Driver**

Maintaining a constant voltage over a brushed DC motor ensures it maintains a constant speed. In this design, Differential Amplifier with Integrator and Comparator controls the PWM block to regulate the voltage across the load.



#### **Ingredients**

- SLG47105V
- Brushed DC Motor

#### **GreenPAK Diagram**



- 1. Enable HV OUT CTRLO with PIN2 and set its Mode as "Full bridge" and Mode control as "PH-EN".
- 2. To change motor direction, connect PIN3 to PH of HV OUT CTRLO.
- 3. Enable Differential Amplifier with Integrator and Comparator and select integrator reference voltage to the desired threshold (Threshold=V REF·4 ).
- 4. For correct Differential Amplifier with Integrator and Comparator operation, enable PWM0 through PIN2 and set Duty Period CLK to "OSC1". PWM frequency must be 44 kHz or higher to make sure that Integrator operates correctly. Connect UPWARD and Equal outputs to UP/DOWN and Keep of PWM0 respectively.
- 5. Set PWM0 Resolution to "8-bits", Duty Cycle Source to "Duty Cycle CNT", Duty Cycle CLK to "Period CNT ovf/8", and Initial Duty Cycle Value to "50%".
- 6. Connect PWM0 OUT+ to EN of HV OUT CTRL0 to drive the motor at a constant speed.

Basic Blocks

2. Sequential

Conditioning

4. Safety

**Communication Protocols** 

6. Pulse-based Control

7. Power Management

#### otor Driver

#### **Application: Constant Current Brushed DC Motor Driver**

Maintaining a constant current over a brushed DC motor ensures it maintains a constant torque. In this design, the current sense comparator (CCMPO) is used to limit the current through the sense resistor to turn OFF motor when the current exceeds a specified limit.



#### **Ingredients**

- SLG47105V
- Brushed DC Motor
- One resistor

#### **GreenPAK Diagram**



#### **Design Steps**

- 1. Connect a brushed DC motor across PIN7 and PIN8, and sense resistor from PIN5 to GND
- 2. Enable HV OUT CTRLO by connecting inverted PIN2 signal to its Sleep 0/1.
- 3. Configure HV OUT CTRLO's mode as "Full bridge" and Mode control as "PH-EN."
- 4. To allow change of motor direction, connect Pin 3 to PH of HV OUT CTRLO.
- 5. Enable CCMP0 by changing Sleep CTRL to "Auto."
- 6. Select CCMPO's IN- source to "192mV" to limit current to 0.218mA:
- 7. Configure CNT1/DLY1 to turn OFF motor for 100ms when current exceeds the specified limit.
- 8. Configure 3-bit LUT7 to turn ON the motor only when current is within range and PIN2 is HIGH.
- 9. Connect the 3-bit LUT7 output to EN of HV OUT CTRLO.

134

#### **Application: Constant Current Using the PWM Chopper**

Maintaining a constant current over a brushed DC motor ensures it maintains a constant torque. This application shows how to limit the current with the PWM chopper block.



#### **Ingredients**

- SLG47105V
- Brushed DC Motor
- One resistor

#### **GreenPAK Diagram**



- 1. Connect a brushed DC motor across PIN7 and PIN8, and sense resistor from Pin 5 to GND
- 2. Configure HV OUT CTRLO's mode as "Full bridge" and Mode control as "PH-EN"
- 3. Enable CCMP0 by changing Sleep CTRL to "Auto"
- 4. Select CCMP0's IN- source to "320mV" to limit current to ~0.36mA
- 5. Add PWM0 block and set the initial duty cycle to 230 and adjust the OSC1 predivider
- 6. Configure CNT1/DLY1 as a falling edge delay to set the Blanking Time
- 7. Add PWM Chopper 0 and make the appropriate connections with PWM0, CNT1/DLY1, and CCMP0 to create the duty cycle chopper and limit the motor current
- 8. Add PIN2 as an enable button to start/stop the motor and internal motor controlling blocks.
- 9. Connect the 3-bit LUT7 output to EN of HV OUT CTRLO.

#### **Application: Unidirectional DC Motor Control with Soft ON/OFF**

Soft ON/OFF can be used to decrease the starting current and load torque of a brushed DC motor. This application is for unidirectional DC motors that allow a single direction for mechanical elements, and either run or stop. This regulation is important because the load torque must not exceed the torque on the motor shaft as it starts and stops.



#### **Ingredients**

- An SLG47105
- Unidirectional brushed motor
- Two capacitors

#### **GreenPAK Diagram**





- 1. Set PIN9 and PIN10 Output mode to "High and Low side." HV OUT CTRL1 set to "Half Bridge" HV OUT mode.
- 2. Set Duty Cycle CLK in PWM1 block to "Period CNT ovf/2". Period CLK set to "Ext.Clk." Connect OSC1 Flex-DIV OUT to PWM1 Period Clock input. Set the value of flexible divider in OSC1 properties.
- 3. Configure DFF1 Initial Polarity to High and the Q Output Polarity to "Inverted (nQ)." Connect the output of the DFF to the PWM1 UP/DOWN input.
- 4. Add CNT1/DLY1 to design. Configure that to the "Falling Edge Delay" with an inverted output. The signal from this delay disables the PWM1 block and enables the sleep mode of HV OUT CTRL1 after the Stop signal comes.
- 5. 2-bit LUT2 used to forming Hi-Z and Stop signals on HV Outputs.

#### **Application: Push-to-Start/Hold-to-Stop**

In this application, the SLG47105 is used as a driver for the Brushed DC Motor with Push-to-Start/Hold-to-Stop functions. This feature can be used for electrical toys, tools, and others.

#### **Ingredients**

- An SLG47105
- A Brushed DC Motor
- Two resistors



#### **GreenPAK Diagram**



- 1. Connect a Brushed DC Motor: first winding across PIN7, second winding across PIN8 with a Pull-down resistor of 10 k $\Omega$ , and sense resistor from PIN5 to GND. Configure Output modes of PIN 7 and 8 as "HIGH and LOW side".
- 2. Enable HV OUT CTRLO connecting Sleep0/1 to an active LOW (HV Sleep output of CNT4/DLY4) and set its Mode as "Full Bridge" and Mode control as "PN-EN". Connect POR to Decay and GND to PH.
- 3. Enable CCMP0 by changing Sleep CTRL to "Auto". Select its IN source to "736 mV" to adjust the Hold-to-Stop function.
- 4. Configure CNT2/DLY2 as a Delay, and connect its output to CNT3/DLY3 (Delayed edge detect Mode) to ensure the system shut down after more than 500 ms of overcurrent Hold-to-Stop.
- Configure PIN20 as Analog input/output and connect it to ACMP1H IN source, select 128 mV In source, and connect comparator's output to DFF13 (Q Output Polarity – Inverted (nQ), Initial Polarity – Low) – Push-to-Start.
- 6. Configure CNT4/DLY4 as a Delay to ensure 300 ms motor stop time (HV Sleep signal).
- 7. Add PWM0 and make the appropriate connections with Differential Amplifier (reference voltage 352 mV) to maintain a constant voltage over a brushed DC motor (see <u>Application Constant Voltage Brushed DC Motor Driver</u>), DFF13, and HV OUT CTRL0 to create the duty cycle.

Sequentia

Conditioning

. Safety

Communication **Protocols** 

6. Pulse-based Control

Management

9. Advanced

#### **Application: Bipolar Stepper Motor Driver**

In this application, the SLG47105 is used as a driver for the stepper motor. In this design example, the driver has full step mode in both directions. Also, this design shows how to limit the current with the PWM Chopper block

#### <u>VDD</u> VDD2 SLG47105 PIN 1(VDD) (VDD2\_A) PIN (VDD2\_B)PIN 1 (GND HV) PIN \_/L Start/Stop [ PIN 2 (GND HV)PIN 13 GND\_HV PIN 3 PIN Direction [ **PIN 14 PIN 17** PIN **PIN 19** PIN 9 **PIN 20 PIN 15 PIN 10 PIN 16** PIN PIN 1 PIN 18 (GND) GND\_HV

#### **Ingredients**

- SLG47105
- Stepper Motor
- Two resistors

#### **GreenPAK Diagram**



- 1. Connect a Stepper Motor:
- First winding across PIN7 and PIN8, and sense resistor from PIN5 to GND;
- Second winding across PIN9 and PIN10, and sense resistor from PIN12 to GND.
- 2. Enable HV OUT CTRLO/1 connecting Sleep0/1 to an active LOW and set their Modes as "Full Bridge" and Mode controls as "PN-EN".
- 3. Enable CCMP0/1 by changing Sleep CTRL to "Auto". Select its IN-source to "64 mV" to limit current to  $\sim 80 \text{ mA}.$
- 4. Configure CNT2/DLY2 as a Reset Counter, and connect its output to CNT1/DLY1 (Delay Mode) to set the Blanking Time.
- 5. Add PWM0/1 Chopper and make the appropriate connections with POR, CNT1/DLY1, and CCMP0/1 to create the duty cycle chopper and limit the motor current. Connect its output to EN of HV OUT CTRLO/1.
- 6. Configure PIN2 (Start/Stop) and PIN14 (Direction) as Digital Inputs and make appropriate connections with Delay on CNT3/DLY3, DFF3, DFF7, and DFF6 (Q Output Polarity – Inverted (nQ), Initial Polarity – Low), 2-bit LUT0 set as Invertor, and 3-bit Multiplexers LUT5 and LUT6. Connect LUT5/6's Multiplexer Output to PH of HV OUT CTRL0/1 to Start/Stop the motor and to change the motor's direction.

# **Chapter 9 Advanced Analog Features**

This chapter presents applications that manage analog features using components in AnalogPAK. Applications involve the most common circuit topologies using built-in operational amplifiers, digital rheostats, Chopper ACMP, etc.

#### **Application: Adjustable Active Filter Using OpAmp**

There are many applications where signals from different sources (i.e. sensors) can be sensed with one ADC. These systems require an analog multiplexer with analog filters for each channel because each signal source may have its own set of filter requirements (for example, cutoff frequency). In this design, one filter serves many analog inputs and provides different cutoff frequencies to them. I2C master can write data to rheostat registers and adjust the cutoff frequency of the filter.



#### **Ingredients**

- SLG47004V
- Two resistors
- Two capacitors

#### **GreenPAK Diagram**



- 1. Enable OpAmp0 and Opamp1. Set bandwidths to 8 MHz and enable Charge Pumps. Set OpAmp1 Vref connection to IN+.
- 2. Enable Vref OA1, set input voltage to VDD and output selection to VDD \* (16/64).
- 3. Set Digital Rheostat 1 in Rheostat mode. Disable Auto-Trim, connect FIFO nRST input to POR and set desired resistance (initial data) for both rheostats.

# 2. Sequential Logic

.Basic Blocks
Functions

3. Signal Conditioning

4. Safety Features

Communication Protocols

#### **Application: Adjustable Inverting OpAmp**

An inverting amplifier is a type of operational amplifier circuit which produces an output that is out of phase for its input by 180o. It means that if the input pulse is positive, the output pulse will be negative, and vice versa External control signals allow a user to adjust the gain of the inverting amplifier both downward and upward.



#### **Ingredients**

- SLG47004V
- One resistor

#### **GreenPAK Diagram**



 $G=V_out/V_inp = -(RH0+RH1)/R_1$ 

- 1. Enable OpAmp0. Set bandwidth to 8 MHz, enable Charge Pump and set Vref connection to IN+.
- 2. Enable Vref OAO, set input voltage to 2.048 V and output selection to 512 mV.
- 3. Set Digital Rheostat 1 in Rheostat mode. Disable Auto-Trim, connect FIFO nRST input to POR and set desired resistance (initial data) for both rheostats.
- 4. Configure LUT0 to output the OSC1 clock signal when LEVEL UP or LEVEL DOWN signals are HIGH. Configure LUT1 to output a High-level signal when LEVEL UP is HIGH.

#### **Application: Adjustable Non-Inverting Op Amp**

A non-inverting amplifier is an op amp-based amplifier with positive voltage gain. When you apply any signal to the non-inverting input, it does not change its polarity when it gets amplified at the output terminal. So, in that case, the gain of the amplifier is always positive. External control signals allow a user to adjust the gain of the non-inverting amplifier both downward and upward.



#### **Ingredients**

- SLG47004V
- One resistor

#### **GreenPAK Diagram**



 $G=V_out/V_inp = (1+(RHO+RH1)/R_1).$ 

- 1. Enable OpAmp0. Set bandwidth to 8 MHz, enable Charge Pump and set Vref connection to IN+.
- 2. Enable Vref OAO, set input voltage to 2.048 V and output selection to 256 mV.
- 3. Set Digital Rheostat 1 in Rheostat mode. Disable Auto-Trim, connect FIFO nRST input to POR and set desired resistance (initial data) for both rheostats.
- 4. Configure LUT0 to output the OSC1 clock signal when LEVEL UP or LEVEL DOWN signals are HIGH. Configure LUT1 to output a High-level signal when LEVEL UP is HIGH.

#### **Application: Instrumentation Amplifier**

An instrumentation amplifier is a type of differential amplifier equipped with input buffer amplifiers, eliminating the need for input impedance matching. Anong other characteristics are a very low DC offset, low drift, low noise, a very high open-loop gain, very high common-mode rejection ratio, and very high input impedance.



#### **Ingredients**

- SLG47004V
- Three resistors

#### **GreenPAK Diagram**



$$V_{OUT} = (1 + \frac{R_1 + R_2}{R_{H1}})(V_{IN+} - V_{IN-}) + V_{DD} \frac{R_3}{R_{H0} + R_3}$$

- 1. Enable OpAmp0, OpAmp1 and OpAmp Internal. Set bandwidths to 128 kHz and enable Charge Pumps. Set Vref connection for OpAmp Internal to RHO PIN B.
- 2. Set Digital Rheostat 1 to Rheostat mode. Disable Auto-Trim, connect FIFO nRST input to POR and set desired resistance (initial data) for both rheostats.

#### **Application: Voltage Follower Using OpAmp**

A voltage follower (also known as a buffer amplifier) is an op amp circuit whose output voltage is equal to the input voltage. Hence a voltage follower op amp does not amplify the input signal and has a voltage gain of 1. A voltage follower circuit has a very high input impedance. This characteristic makes it a popular choice in many different types of circuits that require isolation between the input and output signal.



#### **Ingredients**

SLG47004V

#### **GreenPAK Diagram**



- 1. Enable OpAmp0. Set bandwidth to 8 MHz, enable Charge Pump and set Vref connection to IN+.
- 2. Enable Vref OAO, set input voltage to VDDA and output selection to VDDA\*(8/64).

## 2. Sequential Logic

.Basic Blocks
Functions

3. Signal Conditioning

4. Safety Features

. Communication Protocols

#### **Application: Current Sink Using OpAmp and N-channel FET**

With a particular connection an operational amplifier can work as a current sink. This sink keeps up constant voltage across a constant sense resistor. As a result, the current flowing through the load, irrespective of the load resistance, is constant as well.



#### **Ingredients**

- SLG47004V
- One resistor

#### **GreenPAK Diagram**



- 1. Enable OpAmp1. Set bandwidth to 128 kHz, enable Charge Pump and set Vref connection to IN+.
- 2. Enable Vref OA1. Set input voltage to 2.048 V and output selection to 96 mV. Reference voltage defines current via the load
- 3. Set Switch1 mode to Analog Switch and Big NMOS Control to setting by OpAmp.

#### **Application: Auto-Trim**

In this application, the SLG47004 is configured as an Auto-Trim Function Example For One-Point Trim.

#### **Ingredients**

- SLG47004
- Resistor

### **GreenPAK Diagram**







#### **Design Steps**

- 1. Set VSET pulse to "SET" input of RH0 via PIN12 "Trim".
- 2. Connect PIN7 to the GND and resistor R1 (gas sensor, thermistor, etc.) to PIN6 and VDD. Ensure the feedback connection VDIV from PIN6 to PIN15.
- 3. Set internal Vref value for Chopper ACMP reference of 1024 mV. Select Channel0, CH0 clock 0SC0, and IN+ CH0 source external Vref PIN 15. Connect Chopper ACMP output to nUP/Down of RH0.
- 4. Configure the RH0: Auto-Trim Enable, Active level for UP/D0WN Up when L0W, Resistance (initial data) -511 ( $\sim 50.7096$  k $\Omega$ ).

.Basic Blocks
Functions

146

## Application: Current Source Using OpAmp and P-channel FET

An operational amplifier at a certain connection can work as a current source. This source keeps up a constant voltage across the constant sense resistor. As a result, the current flowing through the load, irrespective of the load resistance, is constant as well.



#### **Ingredients**

- SLG47004
- Resistor

#### **GreenPAK Diagram**



$$I_{load} = \frac{V_{ref}}{R_{sense}}$$

#### **Design Steps**

- 1. Enable OpAmpO. Set bandwidth to 128 kHz, enable Charge Pump and set Vref connection to IN-.
- 2. Enable Vref OAO. Set input voltage to 2.048 V and output selection to 96 mV.
- 3. Set Switch0 mode to Analog Switch and Big PMOS Control to setting by OpAmp.

Basic Blocks & Functions

## Application: Voltage Regulator Using OpAmp

An OpAmp-based voltage regulator is a circuit that uses operational amplifier to regulate and stabilize the output voltage. By comparing the output voltage to a reference voltage, the OpAmp adjusts its output to maintain a constant voltage level. This feedback mechanism allows the voltage regulator to compensate for input voltage variations and provide a consistent and reliable output voltage.

#### **Ingredients**

- SLG47004V
- No other components needed



#### **GreenPAK Diagram**



#### **Design Steps**

- 1. Enable OpAmpO. Set bandwidth to 128 kHz, enable Charge Pump and set Vref connection to IN-.
- 2. Enable Vref OAO. Set input voltage to 2.048 V and output selection to 1792 mV.
- 3. Set Switch0 mode to Analog Switch and Big PMOS Control to setting by OpAmp.
- 4. After applying the input voltage, the output voltage remains stable and equal to VOUT = VREF, regardless of input voltage variations.

2. Sequential Logic

Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

Protocols

6. Pulse-based Control

1.Basic Blocks **Functions** 

2. Sequential

Conditioning

4. Safety

Communication **Protocols** 

6. Pulse-based

Control

Management 7. Power

### **Technique: Using Chopper ACMP with Digital Rheostats**

There is one Chopper Rail-to-Rail Analog Comparator (ACMP) macrocell in the SLG47004. It is possible to use Chopper ACMP to do in-system trim by changing the Rheostat resistance in Auto-Trim mode (see Application: Auto-Trim function).

#### Activation

When used in Auto-Trim mode, the Chopper ACMP is automatically enabled by the Auto-Trim control logic when Rheostat calibration is in progress.



#### For using the Auto-Trim function the following preliminary steps must be taken:

- Enable Auto-Trim in Digital Rheostat0/1 Properties.
- Choose IN+ CHO/1 of the Chopper ACMP. It can be user system voltage feedback. If the Auto-Trim function is used for two rheostats, IN+ CH0/1 must be configured for both rheostats (for cases when SETO is latched and when SET1 is latched).
- Configure IN- CH0/1. It can be user desired set point threshold. If the Auto-Trim function is used for two rheostats, IN- CH0/1 must be configured for both rheostats (for cases when Set0 is latched and when Set1 is latched).
- Select Channel in Chopper ACMP Properties to work with Chopper ACMP.
- Configure inverting or non-inverting Chopper ACMP output.
- Select clock source (internal clock from internal pre-dividers or from connection matrix). Note that in Auto-Trim mode clock source frequency is limited by the Chopper Comparator time response. Therefore, the clock source frequency must not be greater than <fChACMP> kHz.
- Start the Auto-Trim process by setting the SETO/1 input of the

RHO/1 block to a HIGH level. The Trim process starts with a rising edge on Set input. This Set signal is latched until the end of the Auto-Trim process. The SET signal will enable the Chopper ACMP and the Vref if they were not enabled earlier. The counter starts to count up or down depending on the level at the UP/ nDOWN input of the RHO/1 (Chopper ACMP output). If the user selected the "Internal Clock" option for Clock input, these clock pulses are generated automatically during the trim time. Each rising edge of the Clock pulse changes the value of the counter and, consequently, the value of the rheostat.

#### The Auto-Trim process stops if one of three stop conditions occur:

- 1) A subsequent change on Up/Down input in the moment of rising edge on Clock input.
- 2) the value of rheostat reaches its maximum (1023).
- 3) the value of rheostat reaches its minimum (0).

Stop conditions result in a change of the IDLE/nACTIVE signal, which resets the internal Auto-Trim logic. Note that the SET input is edge sensitive, but if the user keeps a HIGH logic level at this input after reaching the set point, the Programmable Trim block will continue to operate and continue to switch rheostat around the set point.

- To start a new Auto-Trim process user should reapply a HIGH level on Set input.

CH PUMP EN IDLE/nACTIVE

**Analog Features** 

9. Advanced

Basic Blocks
Functions

#### **Application: Sample and Hold Circuit**

In this application, the SLG47004 is configured as a Sample and Hold Circuit which consists of an analog switch, capacitor, and buffer.



#### **Ingredients**

- SLG47004
- Capacitor

#### **GreenPAK Diagram**



- 1. Configure "Enable by Matrix" Small PMOS enable of SWITCH1.
- 2. Set the S&H En signal and connect it to PIN16 (Digital Input, Pull Down 1M).
- 3. Enable SWITCH1 by connecting to PIN16.
- 4. Connect PIN17 (Analog In/Out, Floating) to the Vin signal source, PIN18 to PIN 12 (both Analog In/Out, Floating), and provide the connection with a 100 nF capacitor.
- 5. Configure 2-L1 as an Inverter and connect its INO to PIN16 and OUT to PWR UP of ACMP1L and TEMP SENSOR.
- 6. Configure the ACMP1L: Vref source selection VDDA, IN+ source TEMP SENSOR output, In- Low to High/High to Low source Ext. Vref PIN12.
- 7. Configure the power down source of TEMP SENSOR as "From matrix".
- 8. PIN15 is Vout of the Sample and Hold Circuit.

Basic Blocks & Functions

#### **Application: Finding Maximum Point of Input Voltage**

This application demonstrates how to use the SLG47011 to find the maximum point of the input voltage.

#### **Ingredients**

SLG47011



#### **GreenPAK Diagram**



- 1. Add and configure the ADC (<u>Technique</u>: <u>ADC Delay between channels</u>; <u>ADC Calibration Procedure</u>) and PGA (<u>Technique</u>: <u>Different Modes in PGA</u>).
- 2. Configure Data Buffer0 and Data Buffer1 (<u>Technique: Using Data Buffer</u>) to Moving Average, then connect Data Buffer0 to the ADC and Data Buffer1 to the output of Data Buffer0.
- 3. Add and configure Multichannel DCMP. Connect Data Buffer0 to IN+ CHO and Data Buffer1 to IN- CHO.
- 4. Add LUT and CNT7/DLY7, CNT8/DLY8 to implement the Data Buffer1 reset function.
- 5. The maximum voltage value can be read from Data Buffer1 using I2C.

# 2. Sequential Logic

1.Basic Blocks Functions

3. Signal Conditioning

4. Safety Features

. Communication Protocols

6. Pulse-based Control

#### **Technique: Using Power Controller in the SLG47011**

The SLG47011 has a Power Controller macrocell that allows management of power modes and implementation of the Wake-Sleep controller to reduce current consumption. There are two user-controlled matrix outputs from the Power Controller: SLP and RET. This macrocell allows setting one of three power modes: All ON, RETENTION or SLEEP, which control the respective Power Domains: Always ON, Retention, and Sleep.

In All ON mode all Power Domain are active, and the current consumption is maximum. In the RETENTION mode the only



Always ON and Retention Power Domain are active. In this mode, the data in the Buffer and Memory Table in Storage mode will not be reset and remain unchanged after transition between All ON and RETENTION mode. In other case, when the transition to SLEEP mode occurs this data will be reset after each transition. The transition from SLEEP to RETENTION power mode follows this sequence: switching to All ON mode, loading data from NVM to RAM, and then transitioning to RETENTION mode. All operations involving the Memory Table or Data Buffers must be completed at least 5 µs before entering SLEEP or RETENTION modes. Table below presents the configuration of Power Controller matrix outputs, power domain states, power consumption, and transition times from SLEEP and RETENTION modes to All ON mode.

|               | Matrix Inputs<br>Configuration |     | Power Domains State |           |       | ADC (in Analog)  |                                              | Power<br>Consumption       | Mode Transition Delay                                     |
|---------------|--------------------------------|-----|---------------------|-----------|-------|------------------|----------------------------------------------|----------------------------|-----------------------------------------------------------|
| Power<br>Mode | SLP                            | RET | Always<br>ON        | Retention | Sleep | CV <sub>DD</sub> | $AV_{ m DDIO}$ , $AV_{ m DD}$ , $V_{ m REF}$ |                            |                                                           |
| All ON        | 0                              | X   | ON                  | ON        | ON    | ON               | ON/OFF                                       | 30.36 μA at<br>VDD = 2.5 V | RETENTION to All ON<br>0.41 ms SLEEP to All<br>ON 1.37 ms |
| RETENTION     | 1                              | 1   | ON                  | ON        | OFF   | ON               | OFF                                          | 4.75 µA at<br>VDD = 2.5 V  |                                                           |
| SLEEP         | 1                              | 0   | ON                  | OFF       | OFF   | OFF              | OFF                                          | 0.50 μA at<br>VDD = 2.5 V  |                                                           |

Power Modes, Power Domains State, Power Consumption, and Mode Transition Delays

During device startup and transitions from SLEEP or RETENTION modes to All ON mode, Memory Table data can be loaded from NVM to RAM or bypassed. This behavior is controlled by the Skip NVM Load memory setting:

- No Skip: Memory Table data is loaded from NVM to RAM during device startup and when transitioning from SLEEP or RETENTION modes to All ON mode.
- Skip: Memory Table data loading is bypassed. If the Memory Table macrocell is not used in the design, the Skip option must be selected.



I.Basic Blocks & Functions

### **Application: Waveform Generator Using Memory Table**

This application demonstrates how to use the SLG47011 to generate sine wave signal.

#### **Ingredients**

SLG47011



#### **GreenPAK Diagram**



- 1. Add and configure the DAC (Technique: Using the Digital-to-Analog Converter (DAC)).
- 2. Add Memory Table and fill it with the code that represents output waveform. In this example we use sine wave, but you can customize the design and have any output waveform signal
- 3. Connect the DAC Input source to Memory Table.
- 4. Add and configure Memory Control Counter and connect it to the Memory Table, by choosing the proper Address source select option.

1.Basic Blocks Functions

#### **Technique: ADC Calibration Procedure**

There are two types of offset calibration in the ADC:

Internal Offset Calibration inherent SAR ADC calibration.

System Offset Calibration specially designed customer calibration to simplify some differential mode measurements.

The Internal Calibration measures the ADC offset and then subtracts it from the ADC conversion data. Internal Calibration of the ADC is initiated automatically after the device power-up and after the transition from SLEEP to All ON mode. The Internal Offset Calibration procedure requires 6415 ADC clock periods and should be considered in the user design. In the design the ADC should be used in combination with DLY on ADC Conversion start to ensure that internal calibration is finished. The time of this DLY needs to be calculated depending on ADC CLK.

System Offset Calibration considers the entire signal path, including the external source, the internal input MUX, and the PGA. To initiate the system offset calibration, the external device or sensor must be in its zero signal state and the ADC Start Calibration signal must be set.

There are two options, for channel 0, 1 and channel 2, 3 to configure which pair of differential GPIO ports will be calibrated and which differential channel will be corrected during operation. System Offset Calibration starts with a rising edge at the Start Calibration input. While the conversion is running, the signal ADC Start Calibration will be blocked. Likewise, while the system calibration is running, the incoming ADC Conversion Start signal will be ignored. When the System Offset Calibration is complete, the system offset calibration value is stored, and the ADC internal offset calibration value will be subtracted from the ADC conversion data. An example of a design that uses System Offset Calibration is shown in the figure below.



An Example of a Design that Uses System Offset Calibration

The ADC configuration registers should not be changed while the ADC is operating or in calibration mode. If ADC is operating in combination with PGA, the ADC should wait for the PGA signal to settle after PGA power-up.

If PGA differential mode is selected, all measurements will be sampled from the voltage level VREF/2. The ADC's zero output code is also half of its code range. The system offset calibration result is equal ADC data after Calibration Start minus Midscale value

For example, if the zero scale output code for 10-bit resolution is measured to be 500, the offset code will be 500 - 512 = -12. This value will be subtracted from the ADC raw data (ADC raw data - (-12), which will add 12 to the ADC raw data). The calibration registers can be used to subtract the desired values from each ADC sample.

# 2. Sequential Logic

I.Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

Communication Protocols

6. Pulse-based Control

### **Application: Signal Generator Using Memory Table**

This application demonstrates how to use the SLG47011 to generate logic pattern using memory table and Width Converter.

#### **Ingredients**

SLG47011



#### **GreenPAK Diagram**



- 1. Add and configure the Width Converter.
- 2. Add the MF2 block and configure it as a frequency generator, then connect the CNT2/DLY2 output to the Clk IN input of the Width Converter.
- 3. Add Memory Table and fill it with the code that represents output logic pattern.
- 4. Connect the Width Converter Input source to Memory Table.
- 5. Add and configure Memory Control Counter and connect it to the Memory Table, by choosing the proper Address source select option.

2. Sequential Logic

Basic Blocks & Functions

3. Signal Conditioning

4. Safety Features

Protocols Protocols

6. Pulse-based Control

7. Power Management

contr

9. Advanced Analog Features

#### **Application: Signal Modulation Using MathCore (PWM)**

In this application, the SLG47011 is configured as a PWM Modulation Example with Smooth Duty Cycle Variation.

#### **Ingredients**

SLG47011



#### **GreenPAK Diagram**





- 1. Configure the desired signal shape in the Memory Table.
- 2. Set the Upper Limit for the Memory Control Counter.
- 3. Set the counter data for CNT2/DLY2 according to the required modulation.
- 4. Set the counter data for FSM1 according to the required duty cycle.
- 5. Configure the Multichannel DCMP using Technique: Multichannel DCMP.

Basic Blocks & Functions

#### **Application: Signal Modulation Using MathCore**

In this application, the SLG47011 is configured as a Sine Wave Modulation Example with Smooth Amplitude Variation.



#### **Ingredients**

SLG47011

#### **GreenPAK Diagram**





- 1. Configure the signal shape in the Memory Table.
- 2. Set the Upper Limit for the Memory Control Counter.
- 3. Set the counter data for DLY2 according to the required modulation.
- 4. Set the MathCore using Technique: MathCore Usage
- 5. Configure the DAC: 1) Select the input source MathCore. 2) Set Math selection to: Math OUT [11:0]. Since the Math Core output is 16-bit and the DAC input is 12-bit, Math selection is used to match them. Math OUT [11:0] uses only the first twelve bits of the Math Core output, while the remaining bits [12:15] are ignored.

Basic Blocks
Functions

#### **Application: DC Power Measurement**

In this application, the SLG47011 is configured as an example of a DC Power measurement.

#### **Ingredients**

SLG47011

#### SLG47011V (VDD) PIN 1 **PIN 16** (GND) PIN 2 PIN 15 PIN 3 PIN 14 PIN 4 **PIN 13** PIN 5 **PIN 12** PIN 6 **PIN 11** PIN 7 **PIN 10** PIN 8 R1 20mOhm GND

#### **GreenPAK Diagram**



#### **Design Steps**

- 1. Turn on the ADC using Application ADC ON
- 2. Set up the PGA: 1st channel Single ended, for voltage measurement; 2nd channel Differential (5a Vref/2 biased) for current measurement. It is also important to select the gain so that the voltage range after amplification is within +- 0.810V
- 3. Set the ADC using Application: 4 channel ADC Measurement with Data Buffer
- 4. Set the Data Buffers using Technique: Using Data Buffer
- 5. Set the Math Core to Subtractor → Multiplier

Since in differential mode the ADC has a constant offset equal to Vref/2 (which corresponds to 8192 in digital format), to obtain the actual measured current value, it is first necessary to subtract the offset of 8192 from the second channel. After this, the Math Core multiplies the voltage and current values. Since multiplying the maximum current value (8192) by the maximum voltage value (16384) produces a result that exceeds 16 bits, in order to correctly store the data in the Buffer, the result must be shifted right by 12 bits (equivalent to dividing by  $2^{12}$ ).

The resulting power value can then be converted using the following formula:

X = Buffer 1 value

$$P = X * 4096 * (\frac{1.62 * 0.81 * Gain}{16384 * 8192})$$

### **Application: 4 Channel ADC Measurement with Data Buffer Table**

This application demonstrates how to configure SLG47011 to have 4 channel ADC in combination with Data Buffer to measure.

#### **Ingredients**

SLG47011



#### **GreenPAK Diagram**



#### **Design Steps**

- 1. Add and configure the ADC (<u>Technique</u>: <u>ADC Delay between channels</u>; <u>ADC calibration procedure</u>), PGA (<u>Technique</u>: <u>Different modes in PGA</u>) and <u>CNT2/DLY2</u>.
- 2. Configure Data Buffer 0, 1, 2, 3 (<u>Technique: Using Data Buffer</u>) to Moving Average, then connect all Data Buffers to the ADC.
- 3. The measured voltage value of each channel can be read from Data Buffers using I2C. Each Data Buffer has a 16-bit input and output data bus and a word length of 16 bits. However, the ADC can have different output resolutions: 8, 10, 12, or 14 bits. For data alignment, the ADC offers two options: LSB or MSB. When LSB alignment is selected, the data is written to the first 8, 10, 12, or 14 bits of the word in the buffer. If MSB is selected, the data is written starting from bits D6, D4, D2, or D0, depending on the resolution. An example of writing a 10-bit word to the Data Buffer is shown below.



Example of writing a word to a Buffer for 10-bit ADC resolution

2. Sequential Logic

I.Basic Blocks Functions

3. Signal Conditioning

4. Safety Features

Frotocols

6. Pulse-based Control

7. Power Management

> 8. Moto Control

9. Advanced Analog Features

159

Basic Blocks & Functions

#### **Application: Analog to Parallel Converter**

In this application, the SLG47011 is configured as an example of a 10 bit ADC to parallel converter.

#### **Ingredients**

SLG47011



#### **GreenPAK Diagram**



- 1. Power up the ADC using <u>Application: ADC ON/OFF Function</u>.
- 2. Set the LSB in the Data alignment of the ADC and Memory truncate of the Memory Table.
- 3. Configure the Memory Table to replicate the data from ADC.
- 4. Set up the Width Converter to  $12 \rightarrow 12$  mode. For 10 bits analog to parallel conversion only 10 of 12 outputs will be used.

1.Basic Blocks Functions

#### **Technique: MathCore Usage**

This technique applies to GreenPAK devices that include Math Core, such as the SLG47011. Math Core can perform four mathematical operations: addition, subtraction, multiplication, division (cyclic shift), as well as their combinations.



Mathematical operations

There are four basic modes:

- Multiplier mode (Math\_OUT = K \* X function)
- Adder/Subtractor mode (Math\_OUT = A + B or Math\_OUT = A - B function)
- Multiplier + Adder/Subtractor mode (Math\_OUT = K \* X + B or Math\_OUT = K \* X - B function)
- Adder/Subtractor + Multiplier mode (Math\_OUT = (A + B) \* K or Math\_ OUT = (A - B) \*K function).



- 1. In Multiplier mode, the output is obtained by multiplying two input values provided at the "K" and "X" inputs of the Multiplier/Shifter unit. Since multiplying two 16-bit numbers produces a 32-bit result, a cyclic shift operation is required to convert it into a 16-bit value compatible with the data bus width.
- 2. In Adder/Subtractor mode, the output is derived from the sum or difference of two input values supplied at the "A" and "B" inputs of the Adder/Subtractor unit.
- 3. In Multiplier + Adder/Subtractor mode, the operation is carried out in two stages. First, the values at the "K" and "X" inputs of the Multiplier/Shifter are multiplied. Then, in the second stage, the resulting value (F\_out) from the Multiplier/Shifter is passed to the "A" input of the Adder/Subtractor unit, where it is either added to or subtracted from the value at the "B" input. In this mode, the Multiplier/Shifter output (F out) is automatically assigned as the source for the "A" input of the Adder/Subtractor unit.
- 4. The Adder/Subtractor + Multiplier mode also follows a two-stage process. Initially, the sum or difference of two input values at the "A" and "B" inputs of the Adder/Subtractor unit is computed. The resulting value (Y\_out) is then fed into the "X" input of the Multiplier, where it is multiplied by the value at the "K" input. In this mode, the output of the Adder/Subtractor unit (Y\_out) is automatically designated as the source for the "A" input of the Multiplier/Shifter unit.

If the result of any operation exceeds the maximum 16-bit value (0xFFFF), the output value is set to 0xFFFF. MathCore does not operate with negative numbers. If the value at input "A" is less than the value at input "B" (i.e., the result of subtraction is less than 0), the output value will be 0x0000.

Basic Blocks & Functions

#### **Application: Frequency Multiplier**

In this application, the SLG47011 is configured as an example of a frequency multiplier with multiple variation.



#### **Ingredients**

SLG47011

#### **GreenPAK Diagram**



#### **Design Steps**

- 1. Set the Memory Table to replicate the data from Math Core (for example Math Core Out = 399, and Memory table Out = 399).
  - Data Buffer 1 used for convert the result from Math Core to address for Memory Table.
- 2. Set the counter data for CNT9/DLY9 from the Memory Table.
- Set the CNT11/DLY11 with Data Buffer 0.
   Data Buffer 0 is used to transfer the counted data from CNT11/DLY11 to the input of the Math Core.
- 4. Configure the Math Core using Technique: MathCore Usage.

CNT11/DLY11 measures the input frequency, after which the Math Core can process the obtained values mathematically. To multiply the frequency, we use a Right Shift operation, and for division, we use multiplication.

For example, to double the frequency, we need to set Right Shift = 1 (which is equivalent to dividing by 2). Thus, if the CNT11/DLY11 counter data equals 240, after processing by the Math Core we will get a value of 120, which will be written into CNT9/DLY9. As a result, we will have twice the output frequency.

I.Basic Blocks Functions

#### Application: Arithmetic Operation f(x)=kx+b

These applications describe the design and simulation of a voltage monitoring system implemented on the SLG47011V. The design allows you to measure the input voltage, convert it to a digital value using an ADC, and mathematically process the result (K×X+B).

#### **Ingredients**

- SLG47011
- No other components needed

#### SLG47011V <u>VDD</u> (VDD) PIN 1 **PIN 16** C1 (GND) 100n **PIN 15** PIN 3 **PIN 14** PIN 4 **PIN 13** SDA < PIN 5 **PIN 12** PIN 6 **PIN 11** Buffer\_ready < **PIN 10** PIN 7 PIN 8 PIN 9

#### **GreenPAK Diagram**



- 1. Configure the PGA block to buffered the input voltage signal (V\_in) for further processing (More detailed information about PGA settings can be found in <a href="Technique: Different Modes in PGA">Technique: Different Modes in PGA</a>).
- 2. Connect the buffered signal to the ADC block and configure it to operate in single-ended mode with 12-bit resolution.
- 3. Enable the ADC clock source using the internal oscillator and configure the sampling time to ensure stable and accurate conversion results regardless of the selected sampling rate.
- 4. Configure Math Core to implement the mathematical operation Result = K×X+B (see <u>Technique: Math Core Usage</u>).
- 5. Set the multiplication factor (K) to 3 and the offset value (B) to 100 in the Math Core settings.
- 6. Add a Data Buffer block to store the processed result from the Math Core (see <u>Technique</u>: <u>Using Data Buffer</u>). Configure a GPIO pin (for example, PIN 6) as a digital output to monitor when the buffer is ready to process the next value.

# 2. Sequential Logic

I.Basic Blocks Functions

3. Signal Conditioning

4. Safety Features

Communication Protocols

6. Pulse-based Control

#### **Application: ADC with Memory Table in Storage Mode**

The project is implemented in GreenPAK Designer and demonstrates the use of an ADC with a Memory Table in Storage Mode. The main goal is to digitize the input analog signal, store the values in the memory table.



#### **Ingredients**

- SLG47011
- No other components are needed

#### **GreenPAK Diagram**



#### **Design Steps**

- 1. Set up the analog input signal. Set the input voltage range and define the sampling rate for the ADC conversion. For the external power ON/OFF control see Application: ADC ON/OFF Function.
- 2. Set the PGA to mode 6 (see <u>Technique</u>: <u>Different modes in PGA</u>).
- 3. Arrange for the ADC values to be stored in a memory table, using the Memory Table in Storage Mode to store the digitalized values.
- 4. Use the I2C to read the stored values, and implement a data ready PIN (PIN 14) to indicate when new data is available.

Note: The ADC continues sampling signals until the Conversion Start input becomes LOW. After the HIGH to LOW transition of the Conversion Start input, the ADC will finish the current sampling sequence and then stops (the sampling process will stop only after the entire Memory Table of the configured size is filled with ADC samples). The ADC has a Data Ready output that is set HIGH when the ADC is idle, set LOW when the conversion is in process, and is a high-level pulse when the ADC has finished sampling the current channel. The ADC Data ready pulse duration is at least one ADC clock cycle time in continuous conversion operation.

1.Basic Blocks Functions

#### **Technique: Multichannel DCMP**

The SLG47011 device offers a 16-bit multichannel digital comparator (DCMP) capable of performing periodic comparisons across up to four input channels, with outputs latched to four separate output channels. The DCMP supports two modes of operation and can be configured with selectable input sources, hysteresis control, and synchronization options.

Input Channels and Sources

Each of the four DCMP channels can be configured with specific positive and negative input sources. Selectable input sources for each of four positive inputs of the multichannel DCMP are:

- Memory Table output;
- MathCore output;
- Data Buffer 0–3 outputs;
- Fixed register value (one static threshold per channel).

Selectable negative inputs:

- Data Buffer 0–3 outputs;
- Fixed register value.

Hysteresis Modes

The DCMP allows configuration of a 16-bit hysteresis value for each channel. There are two hysteresis modes available:

Regular hysteresis mode: when active, the multichannel DCMP operates like an analog comparator with hysteresis

- Output transitions from LOW to HIGH when In+ > (In- + Hysteresis);
- Output transitions from HIGH to LOW when In+ ≤ In-.

Offset adding mode: in this mode, the In+ source is always compared with the value (In- + Hysteresis)

- Output transitions from LOW to HIGH when In+ > (In- + Hysteresis);
- Output transitions from HIGH to LOW when In+ ≤ (In- + Hysteresis).

The user can also select the 'equal' = DCMP output instead of 'greater than' > output. This option is selected for each channel. This function is only available in Offset adding mode, and the function is defined as follows:

- High logic level occurs when In+ = (In- + Hysteresis);
- Low logic level occurs when In+ < (In- + Hysteresis) or In+ > (In- + Hysteresis).

**DCMP Operation Modes** 

The DCMP offers different modes to control how comparisons are performed:

Continuous Mode: the DCMP continuously compares data at the inputs after receiving an Enable signal. It finishes comparison when the Enable signal is released.

Sequence Conversion Mode (Activated by Enable Signal): comparisons are done on a channel sequence once the Enable signal transitions from LOW to HIGH. A new comparison can be started by reapplying the Enable signal.

Sequence Conversion Mode (Activated by Buffer Ready Signal): the DCMP performs a comparison when a Buffer Ready signal (or Memory Table Data Ready) transitions from LOW to HIGH. This mode is useful when data from ADC or memory buffers is involved.

Note: the DCMP can be reset using the Reset input, clearing the output channels (OUTO-OUT3) and Data Ready outputs, aborting any ongoing comparison, and restoring the DCMP to its initial state.



I.Basic Blocks Functions

### Technique: Reading/Writing Data via SPI

The SPI (Serial Peripheral Interface) in the SLG47011 provides a high-speed communication interface between the GreenPAK device and an external microcontroller or peripheral. It supports both reading and writing operations, enabling seamless data transfer for control, monitoring, and configuration tasks.

**SPI Interface and Operating Conditions** 

The SPI macrocell in SLG47011 operates in Slave mode and uses the following signals:

- nCS (Chip Select) Activates SPI communication when pulled LOW.
- CLK (Clock) Synchronizes data transfer.
- MOSI (Master Out Slave In) Carries data from the master to the SLG47011.
- MISO (Master In Slave Out) Sends data from the SLG47011 to the master.

SPI Clock Polarity and Phase (CPOL, CPHA)

The SLG47011 supports four SPI modes based on CPOL (Clock Polarity) and CPHA (Clock Phase):

| Properties                |               | × | Matrix0 to Matrix1 Connections: 0/6 Matrix1 to Matrix0 Connections: 0/9 |
|---------------------------|---------------|---|-------------------------------------------------------------------------|
| Host Interface (I2C/SPI)  |               |   | matrix to matrix connections.                                           |
| Interface<br>Enable:      | Enable        | ¥ |                                                                         |
| Interface<br>Selection:   | SPI           | * | CLK                                                                     |
| Clock polarity<br>(CPOL): | 0             | ~ | Host                                                                    |
| Clock phase<br>(CPHA):    | 0             | * | (SPI)                                                                   |
| SPI Mode: 4               | 0             |   | O PIN 4                                                                 |
| Host Virtual Input        | s             |   | MISO                                                                    |
|                           | Initial value |   | o—PIN 6                                                                 |
| Virtual OUT0              | 0             |   |                                                                         |
| Virtual OUT1              | 0             |   | MDD AND AND AND AND AND AND AND AND AND A                               |
| Virtual OUT2              | 0             |   |                                                                         |
| Virtual OUT3              | 0             |   | nCS                                                                     |
| Virtual OUT4              | 0             |   |                                                                         |
| Virtual OUT5              | 0             |   | O— PIN 3                                                                |
| Virtual OUT6              | 0             |   |                                                                         |
| Virtual OUT7              | 0             |   |                                                                         |

| The deal of the dapper to real of the day of the deal of the deal of the day of the deal of the deal of the day of the da |      |                                 |                       |                       |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------------|-----------------------|-----------------------|--|--|--|
| CPOL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | СРНА | Clock Polarity<br>at Idle State | Data Capture Edge     | Data Propagation Edge |  |  |  |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0    | Logic Low                       | Rising (LOW to HIGH)  | Falling (HIGH to LOW) |  |  |  |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1    | Logic Low                       | Falling (HIGH to LOW) | Rising (LOW to HIGH)  |  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0    | Logic High                      | Falling (HIGH to LOW) | Rising (LOW to HIGH)  |  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1    | Logic High                      | Rising (LOW to HIGH)  | Falling (HIGH to LOW) |  |  |  |

CPHA = "0" results in sampling on the leading (first) clock edge, while CPHA = "1" results in sampling on the trailing (second) clock edge, regardless of whether that clock edge is rising or falling.





Note that with CPHA = "0" the data must be stable for a half cycle before the first clock cycle.

To write to a register on an SPI slave, the first write bit is sent first. The register address (0xA202) is then sent, followed by the data (MSB).

To read registers on an SPI slave, the first read bit is sent first, followed by the register address (0x2202). The slave will return the contents of the register when MISO is connected. In the above case, the registers are 8 bits long, so 8 bits of data are returned to the master.

Note: There are variations of the SPI write commands, so it is important to consult the device's datasheet before using them.

Basic Blocks
Functions

#### **Technique: Different Modes in PGA**

This technique applies to GreenPAK devices with a Programmable Gain Amplifier (PGA), including the SLG47011. The PGA enhances weak analog signals before they are converted by the ADC, offering flexibility in gain selection and input configurations.

#### SPI Interface and Operating Conditions

The PGA in the SLG47011 supports multiple modes, which allow users to configure it for different signal types and amplification needs. These modes include:

- 1. Single-Ended Mode the PGA amplifies a signal referenced to ground, useful for direct voltage measurements.
- 2. Differential Mode the PGA amplifies the voltage difference between two input signals, reducing common-mode noise.
- 3. Pseudo-Differential Mode similar to differential mode, but one input is internally fixed to a reference voltage.



#### Choosing the Right Mode

- Mode 1a, 1b Used for sources with a high signal level or in cases of low sampling frequency and moderate accuracy requirements;
- Mode 2 (Single-ended mode) Suitable when a high input impedance PGA (HiZ) is needed and there are no strict accuracy requirements;
- Mode 3 (Differential mode) Recommended mode for differential signals, providing minimal offset and high input impedance. The best choice for measuring signals in noisy environments or sensor applications where common-mode signal rejection is important;
- Mode 4 (Pseudo-differential mode) Pseudo-differential mode with an extended common-mode voltage range. Can be used instead of Mode 2 to improve accuracy and enhance noise immunity;
- Mode 5a, 5b Differential amplifier with low input impedance and reference voltage VREF/2 (Mode 5a – Single-ended output, Mode 5b – Differential output);
- Mode 6 (Buffer mode) The basic recommended mode for SAR ADC. It provides minimal load on the signal source.

By selecting the appropriate mode, users can optimize signal integrity and ADC accuracy in their applications.

Data Buffer1

Data Buffer2

Data Buffer0

Data Buffer3

1.Basic Blocks & Functions

### **Technique: Using Data Buffer**

Applicable to GreenPAK devices like the SLG47011, Data Buffers temporarily store ADC readings or other data for processing, averaging, and transfer.

**Data Buffer Functionality** 

The SLG47011 includes four independent 8-word (16-bit) data buffers with three modes:

1. Storage Mode

The Storage Mode operates on a FIFO (First In, First Out) principle, where new data overwrites the oldest stored values.

- Buffers can be daisy-chained to extend storage capacity from 8 to 32 words, useful for applications requiring larger data windows;
- In a daisy chain setup, Data Buffer0's output feeds into Data Buffer1's input, with an internal connection ensuring seamless data transfer;
- The LOAD signal of one buffer can be triggered directly by the READY signal of the previous buffer, bypassing the connection matrix for efficiency.

#### 2. Moving Average Mode

The Moving Average Mode smooths signal variations by computing the average of the most recent N samples.



#### **Daisy Chain for Averaging 4096 Equivalent Samples**

- Each time a new sample is added, the average is updated dynamically;
- Up to 4096 equivalent samples can be averaged by chaining four Data Buffers;
- In a daisy chain, the LOAD signal of the next buffer is triggered every X clock cycles, where X is the previous buffer's length.

#### 3. Oversampling Mode

The Oversampling Mode enhances ADC resolution by accumulating multiple samples and averaging them.

- A 14-bit ADC can achieve 15-bit resolution with oversampling. Two chain buffers can further increase the resolution to 16 bits. This means that each data buffer adds +1 bit to the resolution:
- Available for buffer lengths of 4 or 8 words:
  - 4-word buffer: adds 4 samples, then divides by 2;
  - 8-word buffer: adds 8 samples, then divides by 4.
- Like other modes, daisy chaining is supported, ensuring seamless data flow without extra routing through the connection matrix.

#### Configuration and Optimization

- Register-driven. Data is written to a new sample;
- SPI/I2C read. Overflow causes interrupt/halt;
- Select modes as needed: noise filtering, higher resolution, or raw data logging.

Proper buffer usage improves signal stability, reduces noise, and improves data acquisition.

(GND) PIN 2

PIN 3

PIN 4

PIN 5

PIN 7

PIN 8

SLG47011V

PIN 1

PIN 1

**PIN 13** 

PIN 12

**PIN 10** 

PIN 9

.Basic Blocks **Functions** 

# Conditioning

# Communication **Protocols**

## 6. Pulse-based Control

#### **Application: ADC ON/OFF Function**

Ensuring a proper power-up, initialization, and shutdown sequence of the Analog-to-Digital Converter (ADC) in the SLG47011 device is crucial for achieving stable operation, reliable sampling, and minimal measurement errors. This application note provides a structured implementation to manage the ADC power sequence efficiently.

#### **Ingredients**

SLG47011

#### **GreenPAK Diagram**



#### **Design Steps**

- 1. Connect the PWR UP input signal to pin 6 and the Vin to pin 7;
- 2. Set the ADC conversion delay using CNT5/DLY5, CNT6/DLY6, CNT7/DLY7;
- 3. Set the ADC turn-on delay using CNT5/DLY5, CNT7/DLY7;
- 4. Set the ADC turn-off delay using CNT7/DLY7.
- 5. Configuring the data buffer for moving average mode (refer to Technique: Using Data Buffer).
- 6. Configuring the PGA for Mode 6: Buffer Mode with Single-Ended Input (see <u>Technique</u>: <u>Different Modes</u> in PGA).

#### The Calculation Part

1) 
$$ext{CNT5/DLY5} = rac{ ext{ADC}_{ ext{clocks}}}{F_{ ext{base}}} + t_{V_{ ext{ref}}} + t_{ ext{delay}_{ ext{min}}}$$
 2)  $ext{CNT6/DLY6} = t_{V_{ ext{ref}}} + t_{ ext{SC}}$ 

3)  $ext{CNT7/DLY7} = ext{n\_cycles} \cdot t_{ ext{ADC}_{ ext{clock}}} = n_{ ext{CH}} \cdot n_{ ext{Sample per CH}} \cdot t_{ ext{ADC}_{ ext{clock}}}$ where  $\mathrm{ADC_{clocks}} = 6415$ ;  $F_\mathrm{base} = 20~\mathrm{MHz}$  – the base frequency of the selected source (Oscillator1 or matrix out clock);  $t_{V_{\rm ref}}=60~\mu {\rm s}$  – Vref power-up time;  $t_{
m delay_{min}}=20~\mu {\rm s}$  minimum delay;  $t_{
m SC}$  – system calibration time (refer to section 11.3 ADC Offset Calibration); n\_cycles – the number of cycles required to turn off or enter a power-saving mode;  $n_{\mathrm{CH}} = 1 \dots 4$  – the number of active channels;  $n_{
m Sample~per~CH}=1/2/4/8$  – the number of samples for each channel;  $t_{
m ADC_{clock}}$  – the time duration of a single ADC clock sample.

Note: The calculations represent the minimum required latency values. In the design, these values were increased by a factor of 2.5 to ensure performance.

# Sequential Logic

Basic Blocks Functions

q

3. Signal Conditioning

4. Safety Features

Communication Protocols

## Technique: ADC Delay Between Channels

This technique applies to the SLG47011. The ADC in this device can sample multiple channels sequentially, but to ensure accurate sampling, a delay between switching channels is often necessary.

Settling Delay for Accurate Sampling

When switching between channels, the input signal requires time to stabilize due to residual charge effects and gain settling in the Programmable Gain Amplifier (PGA). To handle this, SLG47011 includes the delay between channels, which controls the delay between channel switches.

By default, this delay is set to 7 ADC clock cycles (if the register value is 0), but it can be extended up to 65535 cycles to allow more time for stabilization



**ADC** set delay between channels

Configuring the delay between channels

The delay value defines the number of ADC clock cycles before the next channel conversion begins. A higher value ensures better signal stability but reduces the overall sampling rate.

The optimal delay depends on:

- The PGA gain setting (higher gain may require longer settling time, see <u>Technique</u>: <u>Different Modes in PGA</u>).
- The impedance of the signal source affects the settling time, with higher impedance leading to slower settling.
- The desired accuracy of the ADC conversion.

To adjust the delay, write the desired value to the delay between channels via the device configuration interface. This ensures that each channel has sufficient time to stabilize before the next conversion, improving measurement accuracy.

9. Advanced Analog Features



© 2025 Renesas Electronics America Inc. (REA). All rights reserved. All trademarks are the property of their respective owners. REA believes the information herein was accurate when given but assumes no risk as to its quality or use. All information is provided as—is without warranties of any kind, whether express, implied, statutory, or arising from course of dealing, usage, or trade practice, including without limitation as to merchantability, fitness for a particular purpose, or non—infringement. REA shall not be liable for any direct, indirect, special, consequential, incidental, or other damages whatsoever, arising from use of or reliance on the information herein, if advised of the possibility of such damages. REA reserves the right, without notice, to discontinue products or make changes to the design or specifications of its products or other information herein. All contents are protected by U.S. and international copyright laws. Except as specifically permitted herein, no portion of this material may be reproduced in any form, or by any means, without prior written permission from Renesas Electronics America Inc. Visitors or users are not permitted to modify, distribute, publish, transmit or create derivative works of any of this material for any public or commercial purposes.

Document No.: R11TB0003CE0000

1.Basic Blocks & Functions

2. Sequential Logic

3. Signal Conditioning

4. Safety Features

. Communication Protocols

6. Pulse-based Control

7. Power Management

8. Mot

9. Advanced Analog Features