katam/include/agb_sram.h
2020-02-13 07:51:28 +08:00

101 lines
4.0 KiB
C

#ifndef GUARD_AGB_SRAM_H
#define GUARD_AGB_SRAM_H
#include "global.h"
#define SRAM 0x0E000000
#ifndef __SRAM_DEBUG
#define SRAM_ADR 0x0e000000 // SRAM Start Address
#define SRAM_SIZE_256K 0x00008000 // 256KSRAM
#define SRAM_SIZE_512K 0x00010000 // 512KSRAM
#else
#define SRAM_ADR 0x02018000
#define SRAM_SIZE_256K 0x00000400
#define SRAM_SIZE_512K 0x00000800
#endif
#define SRAM_RETRY_MAX 3 // Maximum retry number for the
// WriteSramEx function
/*------------------------------------------------------------------
The function group in this header file was also used in the old version.
The static variable area of the main unit WRAM is not used, but please
note that compared to the function group AgbSramFast.h, access to
SRAM is slower.
--------------------------------------------------------------------*/
/*------------------------------------------------------------------*/
/* Read Data */
/*------------------------------------------------------------------*/
extern void ReadSram(const u8 *src,u8 *dst,u32 size) ;
/* From the SRAM address specified by the argument, read "size"
byte of data to area starting from "dst" address in Work.
<Arguments>
const u8 *src : Read source SRAM address (Address on AGB memory map)
u8 *dst : Address of work area where read data is stored
(Address on AGB memory map)
u32 size : Read size in bytes
<Return Values>
None
*/
/*------------------------------------------------------------------*/
/* Write Data */
/*------------------------------------------------------------------*/
extern void WriteSram(const u8 *src,u8 *dst,u32 size) ;
/* From the work area address specified by the argument, write "size"
byte data to area starting from 'dst' address in SRAM.
<Arguments>
const u8 *src : Write source work area address
u8 *dst : Write destination SRAM address
(Address on AGB memory map)
u32 size : Write size in bytes
<Return Values>
None
*/
/*------------------------------------------------------------------*/
/* Verify Data */
/*------------------------------------------------------------------*/
extern u32 VerifySram(const u8 *src,u8 *tgt,u32 size) ;
/* Verify "size" byte of data from "src" address in the work area
and "tgt" address in SRAM.
If verify ends normally this function returns 0, if a verify error
occurs and the address where the error occurred is returned.
<Arguments>
const u8 *src : Pointer to verify source work area address (original data)
u8 *tgt : Pointer to verify target SRAM address
(write destination data, address on AGB memory map)
u32 size : Verify size in bytes
<Return Values>
u32 errorAdr : Normal end => 0
Verify error => Error address on device side
*/
/*------------------------------------------------------------------*/
/* Write data & Verify */
/*------------------------------------------------------------------*/
extern u32 WriteSramEx(const u8 *src, u8 *dst, u32 size) ;
/* This function writes internally using WriteSram and then verifies using VerifySram.
In case of an error, it retries a maximum of SRAM_RETRY_MAX times (defined by AgbSram.h).
<Argument>
const u8 *src : Work area address of write source
u8 *dst : SRAM address of write destination (address on AGB memory map)
u32 size : Write size in number of bytes
<Return value>
u32 errorAdr : Normal end => 0
Verify error => Error address on device side
*/
#endif // GUARD_AGB_SRAM_H