CTRDG_WriteAgbFlashSector

Syntax

#include <nitro/ctrdg.h>
u16 CTRDG_WriteAgbFlashSector(u16 sec_num, u8* src);
  
Corresponding AGB function: u16 (*ProgramFlashSector)(u16 secNo,u8 *src)

Arguments

sec_num Destination flash sector number.
src Source address.

Return Values

Returns zero if the write succeeds. Returns a nonzero value if it fails.

Description

Writes one sector (4 KB) of data beginning from the address given by src into the target sector number. The CTRDG_EraseAgbFlashSector function is called inside this function, and data is written after the sector is erased. This function returns an error if the target sector number is out of range. To find out how many bytes remain available while this function is executing, access the global variable flash_remainder.

The access cycle setting does not need to be set in advance because it is created inside the function. In addition, the OS_InitTick function must be called in advance because clock ticks are used by this function to measure timeouts.

Note: All interrupts are disabled inside this function, and the cartridge bus is locked for a set period. In particular, when this function is called, do not use DMA that starts automatically during direct sound and V/H blank synchronization, display synchronization, cartridge request, and so on.

Note that the AGB backup device cannot be accessed normally with IS-NITRO-DEBUGGER version 1.66 or earlier.

See Also

CTRDG_WriteAndVerifyAgbFlash
CTRDG_WriteAgbFlashSectorAsync
CTRDG_WriteAndVerifyAgbFlashAsync

Revision History

2006/05/25 Added a description that the AGB backup device cannot be accessed normally with IS-NITRO-DEBUGGER version 1.66 or earlier.
2006/04/07 Initial version.


CONFIDENTIAL