NAME

    Device::Chip::INA219 - chip driver for an INA219

SYNOPSIS

       use Device::Chip::INA219;
       use Future::AsyncAwait;
    
       my $chip = Device::Chip::INA219->new;
       await $chip->mount( Device::Chip::Adapter::...->new );
    
       printf "Current bus voltage is %d mV, shunt voltage is %d uV\n",
          await $chip->read_bus_voltage, await $chip->read_shunt_voltage;

DESCRIPTION

    This Device::Chip subclass provides specific communication to a Texas
    Instruments INA219 attached to a computer via an I²C adapter.

    The reader is presumed to be familiar with the general operation of
    this chip; the documentation here will not attempt to explain or define
    chip-specific concepts or features, only the use of this module to
    access them.

MOUNT PARAMETERS

 addr

    The I²C address of the device. Can be specified in decimal, octal or
    hex with leading 0 or 0x prefixes.

METHODS

    The following methods documented in an await expression return Future
    instances.

 read_config

       $config = await $chip->read_config;

    Reads and returns the current chip configuration as a HASH reference.

       RST        => BOOL
       BRNG       => "16V" | "32V"
       PG         => "40mV" | "80mV" | "160mV" | "320mV"
       BADC       => "9b" | "10b" | "11b" | "12b" | 1 | 2 | 4 | 8 | 16 | 32 | 64 | 128
       SADC       => as above
       MODE_CONT  => BOOL
       MODE_BUS   => BOOL
       MODE_SHUNT => BOOL

 change_config

       await $chip->change_config( %config );

    Changes the configuration. Any field names not mentioned will be
    preserved.

 read_shunt_voltage

       $uv = await $chip->read_shunt_voltage;

    Returns the current shunt voltage reading scaled integer in microvolts.

 read_bus_voltage

       $mv = await $chip->read_bus_voltage;
    
       ( $mv, $ovf, $cnvr ) = await $chip->read_bus_voltage;

    Returns the current bus voltage reading, as a scaled integer in
    milivolts.

    The returned Future also yields the OVF and CNVR flags.

AUTHOR

    Paul Evans <leonerd@leonerd.org.uk>