NAME

    Device::Chip::PCF8563 - chip driver for a PCF8563

SYNOPSIS

       use Device::Chip::PCF8563;
       use Future::AsyncAwait;
    
       use POSIX qw( mktime strftime );
    
       my $chip = Device::Chip::PCF8563->new;
       await $chip->mount( Device::Chip::Adapter::...->new );
    
       printf "The current time on this chip is ",
          await strftime( "%Y-%m-%d %H:%M:%S", localtime mktime $chip->read_time );

DESCRIPTION

    This Device::Chip subclass provides specific communication to a NXP
    PCF8563 chip attached to a computer via an I²C adapter.

METHODS

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

 read_time

       @tm = await $chip->read_time;

    Returns a 7-element struct tm-compatible list of values by reading the
    timekeeping registers, suitable for passing to POSIX::mktime, etc...
    Note that the returned list does not contain the yday or is_dst fields.

    Because the PCF8563 only stores a 2-digit year number plus a single
    century bit, the year is presumed to be in the range 2000-2199.

    This method presumes POSIX-compatible semantics for the wday field
    stored on the chip; i.e. that 0 is Sunday.

    This method performs an atomic reading of all the timekeeping registers
    as a single I²C transaction, so is preferrable to invoking multiple
    calls to individual read methods.

 write_time

       await $chip->write_time( @tm );

    Writes the timekeeping registers from a 7-element struct tm-compatible
    list of values. This method ignores the yday and is_dst fields, if
    present.

    Because the PCF8563 only stores a 2-digit year number and a century
    bit, the year must be in the range 2000-2199 (i.e. numerical values of
    100 to 299).

    This method performs an atomic writing of all the timekeeping registers
    as a single I²C transaction, so is preferrable to invoking multiple
    calls to individual write methods.

AUTHOR

    Paul Evans <leonerd@leonerd.org.uk>