Editor Version ×
recommended

Pro Edition

free

Brand new interactions and interfaces

Smooth support for design sizes of over 3W

devices or 10W pads

More rigorous design constraints, more

standardized processes

For enterprises, more professional users

Std Edition

Easy to use and quick to get started

The process supports design scales of 300

devices or 1000 pads

Supports simple circuit simulation

For students, teachers, creators

Ongoing

STD ATtiny412 USB PD Inverter

ATtiny412 USB PD Inverter

Project tags

License

CC-BY-SA 3.0

License: CC-BY-SA 3.0

Mode:

Mode

Editors' pick

Editors' pick

  • 1.4k
  • 0
  • 2
Update time: 2022-09-25 09:32:17
Creation time: 2022-08-08 10:32:42
Description

Description

# Overview The ATtiny212/412-based USB Power Delivery Inverter converts direct current from USB PD power supplies into sine wave alternating current with selectable voltage and adjustable frequency. For this purpose, the ATtiny's powerful Timer/Counter D (TCD) controls an H-Bridge with a subsequent low-pass filter. * Firmware (Github): https://github.com/wagiminator/ATtiny412-USB-PD-Inverter ![pic1.jpg](https://raw.githubusercontent.com/wagiminator/ATtiny412-USB-PD-Inverter/main/documentation/USB_PD_Inverter_pic1.jpg) # Hardware ## Schematic ![wiring.png](https://raw.githubusercontent.com/wagiminator/ATtiny412-USB-PD-Inverter/main/documentation/USB_PD_Inverter_wiring.png) ## 78L05 Voltage Regulator The 78L05 is a simple and inexpensive voltage regulator that can convert input voltages up to 30V to an output voltage of 5V with an output current of up to 200mA and a dropout voltage of 1.7V. The 78L05 supplies some elements of the circuit with 5V. ## CH224K USB PD Power Receiving Chip The CH224K is a USB PD power receiving protocol chip, which integrates PD3.0/2.0, BC1.2 and other fast charging protocols, automatically detects VCONN and analog E-Mark chips, supports up to 100W power, and has built-in PD communication module. It also integrates output voltage detection internally to support overheating and overvoltage protection. It features: * 4V to 22V input voltage * PD3.0/2.0, BC1.2 and other fast charging protocols * USB Type-C PD, positive and negative insertion detection and automatic switching * E-Mark simulation, automatically detects VCONN, supports 100W power PD request * requested voltage can be dynamically adjusted through a variety of methods * high integration of single chip, simplified peripheral and low cost * built-in over-voltage and over-temperature protection module In this application, the CH224K is used to communicate with the USB PD Power Adapter to request the output voltage selected via the DIP switches. The CH224K's PG pin is open-drain, pulling the input to ground when the requested voltage has been successfully negotiated with the USB PD power supply. Here it is used to drive an indicator LED. ## DRV8870 H-Bridge Motor Driver The DRV8870 device is a brushed-DC motor driver for printers, appliances, industrial equipment, and other small machines. Two logic inputs control the H-bridge driver, which consists of four N-channel MOSFETs that can control motors bidirectionally with up to 3.6A peak current. The inputs can be pulsewidth modulated (PWM) to control motor speed, using a choice of current-decay modes. Setting both inputs low enters a low-power sleep mode. It features: * H-Bridge Motor Driver * Wide 6.5-V to 45-V Operating Voltage * 565-mΩ Typical RDS(on) (HS LS) * 3.6A Peak Current Drive * PWM Control Interface * Integrated Current Regulation * Low-Power Sleep Mode * Small Package and Footprint * Integrated Protection Features * VM Undervoltage Lockout (UVLO) * Overcurrent Protection (OCP) * Thermal Shutdown (TSD) * Automatic Fault Recovery In this application, the H-bridge is used to switch the polarity of the input voltage with high frequency PWM and a variable duty cycle. A downstream low-pass L-C filter removes the original high-frequency PWM signal, leaving only the lower-frequency sine wave modulated via the duty cycle at the output. The cutoff frequency of the filter should be well between the PWM freqency (19kHz) and the sine wave frequency (50Hz or 60Hz). The cutoff frequency depending on the inductor (L1, L2) and capacitor (C4, C5) can be determined using the following formula: $$f_{cutoff} = \frac{1}{2\times\pi\times\sqrt{L \times C}} = \frac{1}{2\times\pi\times\sqrt{0.00022H \times 0.00022F}} = 723Hz$$ The DRV8870 offers the possibility to set a current limit via a resistor (R2). The resistance value is calculated as follows: $$R2 = \frac\{V\_\{REF\}\}\{10 \times I\_\{limit\}\} = \frac\{5V\}\{10 \times 2\.5A\} = 0\.2Ω$$ ## ATtiny Microcontroller The ATtiny212 or ATtiny412 microcontroller generates the high-frequency PWM signal with the duty cycle modulated sine wave for the H-bridge. ![hardware.png](https://raw.githubusercontent.com/wagiminator/ATtiny412-USB-PD-Inverter/main/documentation/USB_PD_Inverter_hardware.png) # Software ## Creating the PWM Signal Two complementary logic signals with intermediate dead times (break-before-make times) are required to control the H-bridge. The dead times are necessary to prevent short circuits due to H-bridge switching delays. To generate this, the ATtiny's powerful Timer/Counter D (TCD) is used, which is also specialized in controlling H-bridges, among other things. The TCD is operated in Four Ramp Mode with a clock frequency of $f_{TCD} = 5MHz$. In Four Ramp mode, the TCD cycle follows this pattern: 1. A TCD cycle begins with the TCD counter counting up from zero until it reaches the CMPASET value. Then it resets to zero and switches the WOA pin to HIGH. 2. The counter counts up until it reaches the CMPACLR value, then it resets to zero and switches the WOA pin to LOW. 3. The counter counts up until it reaches the CMPBSET value, then it resets to zero and switches the WOB pin to HIGH. 4. The counter counts up until it reaches the CMPBCLR value, and ends the TCD cycle by resetting to zero and switching WOB pin to LOW. ![TCD.png](https://raw.githubusercontent.com/wagiminator/ATtiny412-USB-PD-Inverter/main/documentation/USB_PD_Inverter_TCD.png) The values of the registers CMPASET and CMPBSET determine the length of the respective dead times. At the beginning, these are set in such a way that they are each 200ns and are then not changed any more. ``` c int main(void) { _PROTECTED_WRITE(CLKCTRL.MCLKCTRLB, 0); // set clock frequency to 20 MHz pinOutput(PIN_WOA); pinOutput(PIN_WOB); // enable output on WOA/WOB pin TCD0.CTRLB = TCD_WGMODE_FOURRAMP_gc; // set four ramp mode TCD0.CMPASET = 0x00; // 200ns dead time TCD0.CMPACLR = 0x80; // 25800ns on-time WOA TCD0.CMPBSET = 0x00; // 200ns dead time TCD0.CMPBCLR = 0x7f; // 25600ns on-time WOB CPU_CCP = CCP_IOREG_gc; // protected write is coming TCD0.FAULTCTRL = TCD_CMPAEN_bm // enable WOA output channel | TCD_CMPBEN_bm; // enable WOB output channel TCD0.INTCTRL = TCD_OVF_bm; // enable overflow interrupt while(~TCD0.STATUS & TCD_ENRDY_bm); // wait for synchronization TCD0.CTRLA = TCD_CLKSEL_20MHZ_gc // select 20MHz base clock | TCD_CNTPRES_DIV4_gc // prescaler 4 -> 5MHz timer clock | TCD_ENABLE_bm; // enable timer sei(); // enable interrupts while(1); // everything is done via interrupt } ``` CMPACLR determines the length of the WOA/IN1 signal, CMPBCLR the length of the WOB/IN2 signal for the H-bridge. Both lengths are changed after each TCD cycle according to a [sine table](https://www.daycounter.com/Calculators/Sine-Generator-Calculator.phtml) and are always complementary to each other. This is controlled via the TCD overflow interrupt, which calls the appropriate interrupt service routine at the end of each TCD cycle: ``` c ISR(TCD0_OVF_vect) { TCD0.CMPACLRL = SIN_val; // set next sine value for WOA TCD0.CMPBCLRL = -SIN_val; // inverse value for WOB TCD0.CTRLE = TCD_SYNCEOC_bm; // sync registers at TCD cycle end TCD0.INTFLAGS = TCD_OVF_bm; // clear interrupt flag if( SIN_ptr >= sizeof(SIN)) SIN_ptr = 0; // increase sine pointer SIN_val = SIN[SIN_ptr]; // get next sine value } ``` This results in a PWM signal with always the same length and the same dead times, but a variable duty cycle. The period of the TCD cycle and thus the length of the PWM signal is calculated as follows: $$T\_\{cycle\} = \frac\{\(CMPASET \ 1\) \ \(CMPACLR \ 1\) \ \(CMPBSET \ 1\) \ \(CMPBCLR \ 1\)\}\{f\_\{TCD\}\}$$ Since the amplitude of the sine table was chosen so that the values are between 0 and 255, CMPACLR and CMPBCLR are always complementary (CMPACLR CMPBCLR = 255) and CMPASET = CMPBSET = 0, this results in a TCD period of 259 clock cycles or 51.8µs. The PWM frequency is calculated as follows: $$f\_\{PWM\} = \frac\{1\}\{T\_\{cycle\}\} = \frac\{1\}\{0\.0000518s\} = 19305Hz$$ The number of values in the sine table for a complete period determines the frequency of the sine wave. It is calculated as follows: $$Number of values = \frac\{f\_\{PWM\}\}\{f\_\{sine\}\} = \frac\{19305Hz\}\{50Hz\} = 386$$ So the frequency of the output voltage can be controlled, among other things, by the number of values in the sine table. The AC output voltage itself is determined by the DC input voltage and the amplitude of the sine wave in the table. Since this oscillates fully from 0 to 255 here, the AC output voltage (RMS) is calculated as follows: $$U\_\{AC\} = \frac\{U\_\{DC\}\}\{\sqrt\{2\}\}$$ Here's the final wave at the AC output terminal: ![scope1.jpg](https://raw.githubusercontent.com/wagiminator/ATtiny412-USB-PD-Inverter/main/documentation/USB_PD_Inverter_scope1.jpg) ## Compiling and Uploading the Firmware ### If using the Arduino IDE * Open your Arduino IDE. * Make sure you have installed [megaTinyCore](https://github.com/SpenceKonde/megaTinyCore). * Go to **Tools -> Board -> megaTinyCore** and select **ATtiny412/402/212/202**. * Go to **Tools** and choose the following board options: * **Chip:** ATtiny212 or ATtiny412 * **Clock:** 20 MHz internal * Leave the rest at the default settings. * Connect your [programmer](https://github.com/wagiminator/AVR-Programmer) to your PC and to the UPDI header on the board. * Go to **Tools -> Programmer** and select your UPDI programmer. * Go to **Tools -> Burn Bootloader** to burn the fuses. * Open the sketch and click **Upload**. ### If using the makefile (Linux/Mac) * Connect your [programmer](https://github.com/wagiminator/AVR-Programmer) to your PC and to the UPDI header on the board. * Download [AVR 8-bit Toolchain](https://www.microchip.com/mplab/avr-support/avr-and-arm-toolchains-c-compilers) and extract the sub-folders (avr, bin, include, ...) to /software/tools/avr-gcc. To do this, you have to register for free with Microchip on the download site. * Open a terminal. * Navigate to the folder with the makefile and the sketch. * Run `DEVICE=attiny412 PROGRMR=serialupdi PORT=/dev/ttyUSB0 make install` to compile, burn the fuses and upload the firmware (change DEVICE, PROGRMR and PORT accordingly). # Operating Instructions Use the DIP switches on the device to select the output voltage and AC frequency. Connect the device to a USB PD power adapter. As soon as the LED lights up, the correct output values are present. The switch positions can also be changed during operation. The output voltage is selected via two of the three DIP switches according to the following table: | DC Voltage | AC Voltage | SW2 | SW3 | | ---------: | ---------: | --- | --- | | 9V | 6.4V | 1 | 1 | | 12V | 8.5V | 1 | 0 | | 15V | 10.6V | 0 | 0 | | 20V | 14.1V | 0 | 1 | The AC output frequency is selected via the first DIP switch as follows: | Frequency | SW1 | | --------- | --- | | 50Hz | 0 | | 60Hz | 1 | # References, Links and Notes 1. [78L05 Datasheet](https://datasheet.lcsc.com/lcsc/2203221230_UMW-Youtai-Semiconductor-Co---Ltd--78L05_C347258.pdf) 2. [CH224K Datasheet](https://datasheet.lcsc.com/lcsc/2204251615_WCH-Jiangsu-Qin-Heng-CH224K_C970725.pdf) 3. [DRV8870 Datasheet](https://www.ti.com/lit/ds/symlink/drv8870.pdf?ts=1664013779134) 4. [ATtiny412 Datasheet](https://ww1.microchip.com/downloads/en/DeviceDoc/ATtiny212-214-412-414-416-DataSheet-DS40002287A.pdf) 5. [Sine Table Generator](https://www.daycounter.com/Calculators/Sine-Generator-Calculator.phtml) 6. [CH224K USB PD Adapter](https://github.com/wagiminator/ATtiny814-USB-PD-Adapter) 7. [CH224K USB PD Decoy](https://github.com/wagiminator/Power-Boards/tree/master/USB-PD_Decoy_CH224K) 8. [IP6520 USB PD Source](https://github.com/wagiminator/Power-Boards/tree/master/USB-PD_Source_IP6520) 9. [TI Primer on USB PD](https://www.ti.com/lit/wp/slyy109b/slyy109b.pdf) ![pic2.jpg](https://raw.githubusercontent.com/wagiminator/ATtiny412-USB-PD-Inverter/main/documentation/USB_PD_Inverter_pic2.jpg) ![pic3.jpg](https://raw.githubusercontent.com/wagiminator/ATtiny412-USB-PD-Inverter/main/documentation/USB_PD_Inverter_pic3.jpg) # License ![license.png](https://i.creativecommons.org/l/by-sa/3.0/88x31.png) This work is licensed under Creative Commons Attribution-ShareAlike 3.0 Unported License. (http://creativecommons.org/licenses/by-sa/3.0/)
Design Drawing

Design Drawing

schematic diagram
1 /
PCB
1 /
The preview image was not generated, please save it again in the editor.
ID Name Designator Footprint Quantity BOM_Manufacturer BOM_Manufacturer Part BOM_Supplier Part
1 100n C1,C6,C9 C_0603 3 YAGEO CC0603KRX7R9BB104 C14663
2 10u C2 C_0603 1 SAMSUNG CL10A106KP8NNNC C19702
3 1u C3 C_0603 1 SAMSUNG CL10A105KB8NNNC C15849
4 220u C4,C5 CAP_SMD_10MM 2 ROQANG RT1H221M1010 C280410
5 470u C7 CAP_SMD_10MM 1 ROQANG RT1V471M1010 C280413
6 330n C8 C_0603 1 FH 0603B334K250NT C1615
7 GT-USB-7010ASV CN1 USB-C-7010ASV 1 G-Switch(品赞) GT-USB-7010ASV C2988369
8 KF301-2P CN2,CN3 KF301-2P 2 Cixi Kefa Elec KF301-5.0-2P C474881
9 UPDI CN4 210S-3X1/2.54 1 BOOMELE Header2.54mm 1*3P C49257
10 220uH L1,L2 IND-SMD_L12.3 2 SHOU HAN(首韩) CYH127-220UH C2929507
11 PWR LED1 LED_0603_S 1 EVERLIGHT 19-217/GHC-YR1S2/3T C72043
12 10k R1,R3,R4 0603 3 UniOhm 0603WAF1002T5E C25804
13 R200 R2 2512 1 UniOhm 25121WF200LT4E C83749
14 1k R5,R6 0603 2 UniOhm 0603WAF1001T5E C21190
15 DSHP03TS-S SW1 SW-SMD_DIP3 1 XKB Enterprise DSHP03TS-S C319051
16 ATTINY412-SSN U1 SOP-8_150MIL 1 MICROCHIP(美国微芯) ATTINY412-SSN C1338223
17 CH224K U2 ESSOP-10-EP 1 WCH CH224K CH224K
18 DRV8870DDAR U3 SOP-8_EP_150MIL 1 TI DRV8870DDAR C86590
19 78L05 U4 SOT-89-3_BR 1 Youtai Semiconductor Co., Ltd. UMW78L05 C347258

Unfold

Project Attachments

Project Attachments

Empty
Project Members

Project Members

Target complaint
Related Projects
Change a batch
Loading...

Comment

Add to album ×

Loading...

reminder ×

Do you need to add this project to the album?

服务时间

周一至周五 9:00~18:00
  • 0755 - 2382 4495
  • 153 6159 2675

服务时间

周一至周五 9:00~18:00
  • 立创EDA微信号

    easyeda

  • QQ交流群

    664186054

  • 立创EDA公众号

    lceda-cn