nanoFramework.Iot.Device.Bq2579x 1.0.380

Prefix Reserved
dotnet add package nanoFramework.Iot.Device.Bq2579x --version 1.0.380                
NuGet\Install-Package nanoFramework.Iot.Device.Bq2579x -Version 1.0.380                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="nanoFramework.Iot.Device.Bq2579x" Version="1.0.380" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add nanoFramework.Iot.Device.Bq2579x --version 1.0.380                
#r "nuget: nanoFramework.Iot.Device.Bq2579x, 1.0.380"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install nanoFramework.Iot.Device.Bq2579x as a Cake Addin
#addin nuget:?package=nanoFramework.Iot.Device.Bq2579x&version=1.0.380

// Install nanoFramework.Iot.Device.Bq2579x as a Cake Tool
#tool nuget:?package=nanoFramework.Iot.Device.Bq2579x&version=1.0.380                

BQ2579x/BQ25792/BQ25798 - Buck-boost battery charger

This library supports several Bq2579x devices, namely:

  • The BQ25798 is an I²C controlled, 1-4-cell, 5-A buck-boost solar battery charger with dual-input selector and MPPT.
  • The BQ25792 is an I²C controlled, 5-A, 1-4 cell buck-boost charger with dual-input selector and USB PD 3.0 OTG output.

Documentation

Device & EVM

Sensor image
VQFN 29 pins chip package
Simplified schematic
Simplified schematic
Evaluation Module
Evaluation Module

Usage

Warning: If using an ESP32, make sure to properly setup the I2C pins before creating the I2cDevice. Add a reference to nanoFramework.Hardware.ESP32 NuGet package and add the following code lines:

//////////////////////////////////////////////////////////////////////
// when connecting to an ESP32 device, need to configure the I2C GPIOs
// used for the bus
Configuration.SetPinFunction(21, DeviceFunction.I2C1_DATA);
Configuration.SetPinFunction(22, DeviceFunction.I2C1_CLOCK);

For other devices like STM32, please make sure you're using the preset pins for the I2C bus you want to use.

Hardware Required

  • BQ25798 EVM
  • Male/Female Jumper Wires

Circuit

  • SCL - SCL
  • SDA - SDA
  • VCC - 5V
  • GND - GND

Code

The following code creates an I2C configuration and instantiates a Bq25798 object. Then it prints the Minimum System Voltage detected by the device at boot. Last it enters a loop where it prints the current Vbus voltage each second.

I2cConnectionSettings settings = new I2cConnectionSettings(1, Bq25798.DefaultI2cAddress);
I2cDevice device = I2cDevice.Create(settings);

using (Bq25798 charger = new Bq25798(device))
{
    Debug.WriteLine("");
    Debug.WriteLine($"BQ25798 connected to I2C{device.ConnectionSettings.BusId}");
    Debug.WriteLine("");

    Debug.WriteLine($"Minimum System Voltage is config @ {charger.MinimalSystemVoltage.VoltsDc:N3}V");

    while (true)
    {
        Debug.WriteLine($"Current Vbus: {charger.Vbus.VoltsDc:N3}V");

        Debug.WriteLine("");

        Thread.Sleep(1000);
    }
}

Acknowledgments

The development of this library was kindly sponsored by OrgPal.IoT!

orgpallogo.png

Product Compatible and additional computed target framework versions.
.NET Framework net is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.380 69 1/20/2025
1.0.374 63 1/13/2025
1.0.355 80 12/30/2024
1.0.333 91 12/16/2024
1.0.310 98 10/23/2024
1.0.293 86 10/3/2024
1.0.279 110 9/10/2024
1.0.276 103 9/6/2024
1.0.268 93 8/28/2024
1.0.250 111 8/9/2024
1.0.238 77 7/26/2024
1.0.227 102 7/17/2024
1.0.210 110 6/19/2024
1.0.207 105 6/14/2024
1.0.173 124 4/15/2024
1.0.151 127 3/22/2024
1.0.131 120 2/28/2024
1.0.111 133 1/24/2024
1.0.99 174 1/5/2024
1.0.95 145 12/20/2023
1.0.73 159 11/10/2023
1.0.53 119 11/8/2023
1.0.40 145 10/6/2023
1.0.33 137 9/27/2023
1.0.21 160 9/6/2023
1.0.15 182 8/16/2023
1.0.8 176 8/2/2023
1.0.6 180 8/2/2023
1.0.1 178 7/31/2023