wagiminator / ATtiny85-USB-C-Tester

Simple USB-C Power Delivery Tester
https://oshwlab.com/wagiminator/attiny85-usb-c-tester
Other
35 stars 8 forks source link
arduino attiny attiny85 avr diy ina219 oled pcb power-delivery project tester usb-c usb-pd usb-tester

USB Type-C Power Delivery Tester

Simple USB Type-C Power Delivery Tester based on ATtiny25/45/85 and INA219. The device measures voltage, current, power, energy, capacity and displays the values on an OLED screen. You can switch between different screens by pressing the SET button.

pic1.jpg

Hardware

USB Connectors

The device is equipped with a USB Type-C receptacle (PCB version a) or plug (PCB version b) for the input and a USB Type-C receptacle for the output, so that it can be plugged between the power supply and the consumer. CC1 and CC2 communication channels are passed through so that supply and consumer can negotiate the bus power.

pic2.jpg pic4.jpg

Voltage and Current Measurement

An INA219 is used to measure voltage and current. The INA219 is a current shunt and power monitor with an I²C-compatible interface. The device monitors both shunt voltage drop and bus supply voltage, with programmable conversion times and filtering. A programmable calibration value, combined with an internal multiplier, enables direct readouts of current in amperes. The selected shunt resistance of 8mΩ enables both a very small influence on the circuit and a measurement with a resolution of 1mA. For an accurate measurement, a shunt resistor with a low tolerance (1% or better) should be selected.

User Interface

The user interface utilizes two buttons and an SSD1306 128x32 pixels OLED display. An ATtiny24/45/85 microcontroller handles the user interface as well as the calculation and display of the values.

pic3.jpg

Software

Basic Principle

The INA219 continuously measures current and voltage and transmits the values to the ATtiny via I²C. From this, the ATtiny calculates the other values and displays them on the OLED screen.

I²C OLED Implementation

The I²C protocol implementation is based on a crude bitbanging method. It was specifically designed for the limited resources of ATtiny10 and ATtiny13, but it works with some other AVRs (including the ATtiny25/45/85) as well. The functions for the OLED are adapted to the SSD1306 OLED module, but they can easily be modified to be used for other modules. In order to save resources, only the basic functionalities which are needed for this application are implemented. For a detailed information on the working principle of the I²C OLED implementation visit TinyOLEDdemo.

Accuracy of Time and Capacity Determination

The internal oscillator of the ATtiny is used to determine energy and capacity. The accuracy of the internal oscillator is +/-10% with the factory calibration. This can be improved to +/-2% or better by manual calibration. The calibration value determined in this way can be set in the source code.

Compiling and Uploading

Since there is no ICSP header on the board, you have to program the ATtiny either before soldering using an SOP adapter, or after soldering using an EEPROM clip. The AVR Programmer Adapter can help with this.

If using the Arduino IDE

If using the precompiled hex-file

If using the makefile (Linux/Mac)

Operating Instructions

  1. Connect the device between a power supply and a consumer. Due to the internal structure of the USB-C cables, it may be necessary to change the orientation of one of the cable plugs if you are using the 2-receptacle version of the device.
  2. Use the SET button to switch between the different screens.
  3. Use the RESET button to reset all values.

pic7.jpg pic8.jpg

Characteristics

Parameter Value
Voltage 5V - 20V
Current max 5A
Voltage Measurement Resolution 4mV
Current Measurement Resolution 1mA

References, Links and Notes

  1. UBS-A Version
  2. ATtiny25/45/85 Datasheet
  3. INA219 Datasheet
  4. SSD1306 Datasheet
  5. 128x32 OLED on Aliexpress

pic5.jpg pic6.jpg

License

license.png

This work is licensed under Creative Commons Attribution-ShareAlike 3.0 Unported License. (http://creativecommons.org/licenses/by-sa/3.0/)