2010-10-25 09:03:38 +00:00
|
|
|
/** @file hal/micro/cortexm3/memmap-fat.h
|
|
|
|
* @brief STM32W108 series memory map fixed address table definition
|
|
|
|
*
|
|
|
|
* <!--(C) COPYRIGHT 2010 STMicroelectronics. All rights reserved. -->
|
|
|
|
*/
|
2013-11-24 15:57:08 +00:00
|
|
|
#ifndef MEMMAP_FAT_H_
|
|
|
|
#define MEMMAP_FAT_H_
|
2010-10-25 09:03:38 +00:00
|
|
|
|
2013-11-24 15:57:08 +00:00
|
|
|
#ifndef MEMMAP_TABLES_H_
|
2010-10-25 09:03:38 +00:00
|
|
|
// if we weren't included via memmap-tables.h, define a dummy type for the BAT
|
|
|
|
typedef void HalBootloaderAddressTableType;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "hal/micro/cortexm3/bootloader/fib-bootloader.h"
|
|
|
|
|
|
|
|
// ****************************************************************************
|
|
|
|
// If any of these address table definitions ever need to change, it is highly
|
|
|
|
// desirable to only add new entries, and only add them on to the end of an
|
|
|
|
// existing address table... this will provide the best compatibility with
|
|
|
|
// any existing code which may utilize the tables, and which may not be able to
|
|
|
|
// be updated to understand a new format (example: bootloader which reads the
|
|
|
|
// application address table)
|
|
|
|
|
|
|
|
|
|
|
|
// Description of the Fixed Address Table (FAT)
|
|
|
|
typedef struct {
|
|
|
|
HalBaseAddressTableType baseTable;
|
|
|
|
void *CustomerInformationBlock;
|
|
|
|
HalBootloaderAddressTableType *bootloaderAddressTable;
|
|
|
|
void *startOfUnusedRam;
|
|
|
|
// ** pointers to shared functions **
|
2013-03-15 15:14:09 +00:00
|
|
|
FibStatus (* fibFlashWrite)(uint32_t address, uint8_t *data,
|
|
|
|
uint32_t writeLength, uint32_t verifyLength);
|
|
|
|
FibStatus (* fibFlashErase)(FibEraseType eraseType, uint32_t address);
|
2010-10-25 09:03:38 +00:00
|
|
|
} HalFixedAddressTableType;
|
|
|
|
|
|
|
|
extern const HalFixedAddressTableType halFixedAddressTable;
|
|
|
|
|
|
|
|
#define FIXED_ADDRESS_TABLE_TYPE (0x0FA7)
|
|
|
|
|
|
|
|
// The current versions of the address tables.
|
|
|
|
// Note that the major version should be updated only when a non-backwards
|
|
|
|
// compatible change is introduced (like removing or rearranging fields)
|
|
|
|
// adding new fields is usually backwards compatible, and their presence can
|
|
|
|
// be indicated by incrementing only the minor version
|
|
|
|
#define FAT_VERSION (0x0003)
|
|
|
|
#define FAT_MAJOR_VERSION (0x0000)
|
|
|
|
#define FAT_MAJOR_VERSION_MASK (0xFF00)
|
|
|
|
|
|
|
|
|
2013-11-24 15:57:08 +00:00
|
|
|
#endif //MEMMAP_FAT_H_
|