NAME

    Device::Chip::SDCard - chip driver for SD and MMC cards

SYNOPSIS

       use Device::Chip::SDCard;
       use Future::AsyncAwait;
    
       my $card = Device::Chip::SDCard->new;
    
       await $card->mount( Device::Chip::Adapter::...->new );
    
       await $card->initialise;
    
       my $bytes = await $card->read_block( 0 );
    
       print "Read block zero:\n";
       printf "%v02X\n", $bytes;

DESCRIPTION

    This Device::Chip subclass provides specific communication to an SD or
    MMC storage card attached via an SPI adapter.

    At present it only supports MMC and SDSC ("standard capacity") cards,
    not SDHC or SDXC.

METHODS

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

 initialise

       await $card->initialise;

    Checks that an SD card is present, switches it into SPI mode and waits
    for its initialisation process to complete.

 size

       $n_bytes = await $card->size;

    Returns the size of the media card in bytes.

 read_csd

       $data = await $card->read_csd;

    Returns a HASH reference containing decoded fields from the SD card's
    CSD ("card-specific data") register.

    This hash will contain the following fields:

       TAAC
       NSAC
       TRAN_SPEED
       CCC
       READ_BL_LEN
       READ_BL_LEN_PARTIAL
       WRITE_BLK_MISALIGN
       READ_BLK_MISALIGN
       DSR_IMP
       C_SIZE
       VDD_R_CURR_MIN
       VDD_R_CURR_MAX
       VDD_W_CURR_MIN
       VDD_W_CURR_MAX
       C_SIZE_MULT
       ERASE_BLK_EN
       SECTOR_SIZE
       WP_GRP_SIZE
       WP_GRP_ENABLE
       R2W_FACTOR
       WRITE_BL_LEN
       WRITE_BL_PARTIAL
       FILE_FORMAT_GRP
       COPY
       PERM_WRITE_PROTECT
       TEMP_WRITE_PROTECT
       FILE_FORMAT

    The hash will also contain the following calculated fields, derived
    from the decoded fields above for convenience of calling code.

       blocks          # number of blocks implied by C_SIZE / C_SIZE_MULT
       bytes           # number of bytes of storage, implied by blocks and READ_BL_LEN

 read_ocr

       $fields = await $card->read_ocr;

    Returns a HASH reference containing decoded fields from the card's OCR
    ("operating conditions register").

    This hash will contain the following fields:

       BUSY
       CCS
       UHS_II
       1V8_ACCEPTED
       3V5, 3V4, 3V3, ..., 2V7

 read_block

       $bytes = await $card->read_block( $lba );

    Returns a 512-byte bytestring containing data read from the given
    sector of the card.

TODO

      * Support block writing.

      * Support the different initialisation sequence (and block size
      requirements) of SDHC cards.

AUTHOR

    Paul Evans <leonerd@leonerd.org.uk>