DRV_AT25DF_SectorErase Function

C

bool DRV_AT25DF_SectorErase(const DRV_HANDLE handle, uint32_t address);

Summary

Erase the sector from the specified block start address.

Description

This function schedules a non-blocking sector erase operation of flash memory. Each Sector is of 4 KByte.

The requesting client should call DRV_AT25DF_TransferStatusGet() API to know the current status of the request.

Preconditions

The DRV_AT25DF_Open() routine must have been called for the specified AT25DF driver instance.

Parameters

ParamDescription
handleA valid open-instance handle, returned from the driver's open routine
addressblock start address from where a sector needs to be erased.

Returns

true

  • if the erase request is successfully sent to the flash

false

  • if Write enable fails before sending sector erase command to flash

  • if sector erase command itself fails

Example

DRV_HANDLE handle; // Returned from DRV_AT25DF_Open
uint32_t sectorStart = 0;

if(DRV_AT25DF_SectorErase(handle, sectorStart) == false)
{
    // Error handling here
}

// Wait for erase to be completed
while(DRV_AT25DF_TransferStatusGet(handle) == DRV_AT25DF_TRANSFER_STATUS_BUSY);

Remarks

This routine will block wait until erase request is submitted successfully. Client should wait until erase is complete to send next transfer request.