DRV_W25_SectorErase Function

C

bool DRV_W25_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_W25_TransferStatusGet() API to know the current status of the request.

Preconditions

The DRV_W25_Open() routine must have been called for the specified W25 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_W25_Open
uint32_t sectorStart = 0;

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

// Wait for erase to be completed
while(DRV_W25_TRANSFER_BUSY == DRV_W25_TransferStatusGet(handle));

Remarks

This routine will block wait until erase request is submitted successfully.

Client should wait until erase is complete to send next transfer request.