131 lines
5.1 KiB
C
131 lines
5.1 KiB
C
|
/**************************************************************************************************
|
|||
|
Filename: hal_oad.h
|
|||
|
Revised: $Date:$
|
|||
|
Revision: $Revision:$
|
|||
|
|
|||
|
Description: This module defines optionally-compiled Boot Code parameters for the CC2x3x.
|
|||
|
|
|||
|
Copyright 2008-2010 Texas Instruments Incorporated. All rights reserved.
|
|||
|
|
|||
|
IMPORTANT: Your use of this Software is limited to those specific rights
|
|||
|
granted under the terms of a software license agreement between the user
|
|||
|
who downloaded the software, his/her employer (which must be your employer)
|
|||
|
and Texas Instruments Incorporated (the "License"). You may not use this
|
|||
|
Software unless you agree to abide by the terms of the License. The License
|
|||
|
limits your use, and you acknowledge, that the Software may not be modified,
|
|||
|
copied or distributed unless embedded on a Texas Instruments microcontroller
|
|||
|
or used solely and exclusively in conjunction with a Texas Instruments radio
|
|||
|
frequency transceiver, which is integrated into your product. Other than for
|
|||
|
the foregoing purpose, you may not use, reproduce, copy, prepare derivative
|
|||
|
works of, modify, distribute, perform, display or sell this Software and/or
|
|||
|
its documentation for any purpose.
|
|||
|
|
|||
|
YOU FURTHER ACKNOWLEDGE AND AGREE THAT THE SOFTWARE AND DOCUMENTATION ARE
|
|||
|
PROVIDED <EFBFBD>AS IS<EFBFBD> WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED,
|
|||
|
INCLUDING WITHOUT LIMITATION, ANY WARRANTY OF MERCHANTABILITY, TITLE,
|
|||
|
NON-INFRINGEMENT AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL
|
|||
|
TEXAS INSTRUMENTS OR ITS LICENSORS BE LIABLE OR OBLIGATED UNDER CONTRACT,
|
|||
|
NEGLIGENCE, STRICT LIABILITY, CONTRIBUTION, BREACH OF WARRANTY, OR OTHER
|
|||
|
LEGAL EQUITABLE THEORY ANY DIRECT OR INDIRECT DAMAGES OR EXPENSES
|
|||
|
INCLUDING BUT NOT LIMITED TO ANY INCIDENTAL, SPECIAL, INDIRECT, PUNITIVE
|
|||
|
OR CONSEQUENTIAL DAMAGES, LOST PROFITS OR LOST DATA, COST OF PROCUREMENT
|
|||
|
OF SUBSTITUTE GOODS, TECHNOLOGY, SERVICES, OR ANY CLAIMS BY THIRD PARTIES
|
|||
|
(INCLUDING BUT NOT LIMITED TO ANY DEFENSE THEREOF), OR OTHER SIMILAR COSTS.
|
|||
|
|
|||
|
Should you have any questions regarding your right to use this Software,
|
|||
|
contact Texas Instruments Incorporated at www.TI.com.
|
|||
|
**************************************************************************************************/
|
|||
|
|
|||
|
#ifndef HAL_OAD_H
|
|||
|
#define HAL_OAD_H
|
|||
|
|
|||
|
/*********************************************************************
|
|||
|
* INCLUDES
|
|||
|
*/
|
|||
|
|
|||
|
#include "hal_board_cfg.h"
|
|||
|
#include "hal_types.h"
|
|||
|
|
|||
|
/*********************************************************************
|
|||
|
* MACROS
|
|||
|
*/
|
|||
|
|
|||
|
#if !defined HAL_OAD_BOOT_CODE
|
|||
|
#define HAL_OAD_BOOT_CODE FALSE
|
|||
|
#endif
|
|||
|
|
|||
|
// MSP430 needs to explicitly pack OAD data structures - 8051 is automatic with byte alignment.
|
|||
|
#define PACK_1
|
|||
|
|
|||
|
/*********************************************************************
|
|||
|
* CONSTANTS
|
|||
|
*/
|
|||
|
|
|||
|
// Placement controlled by oad.xcl.
|
|||
|
#define HAL_OAD_RC_START 0x0800
|
|||
|
#define HAL_OAD_CRC_ADDR 0x0888
|
|||
|
#define HAL_OAD_CRC_OSET (HAL_OAD_CRC_ADDR - HAL_OAD_RC_START)
|
|||
|
|
|||
|
/* Note that corresponding changes must be made to oad.xcl when changing the source of Xtra-NV.
|
|||
|
* When using internal flash for XNV, (HAL_OAD_BOOT_PG_CNT + HAL_NV_PAGE_CNT) must be even.
|
|||
|
*/
|
|||
|
#define HAL_OAD_XNV_IS_INT FALSE
|
|||
|
#define HAL_OAD_XNV_IS_SPI !HAL_OAD_XNV_IS_INT
|
|||
|
|
|||
|
/* The oad/oad-boot.xcl files only need 1 page of boot code (located on the first flash page),
|
|||
|
* but the Lock Bits Page is lost with OAD since it is not programmable.
|
|||
|
* So discard it here by faking that boot needs 2 pages.
|
|||
|
*/
|
|||
|
#define HAL_OAD_BOOT_PG_CNT 2
|
|||
|
|
|||
|
/* To reduce the binary image size due to padding un-used code space, reduce HAL_OAD_DL_SIZE
|
|||
|
* to the minimum required for your Application and make the corresponding changes to oad_app.xcl.
|
|||
|
* This size must be an even multiple of HAL_FLASH_PAGE_SIZE.
|
|||
|
*/
|
|||
|
#if HAL_OAD_XNV_IS_SPI && !defined HAL_BOARD_CC2530EB_REV13
|
|||
|
#define HAL_OAD_DL_MAX 0x40000
|
|||
|
#define HAL_OAD_DL_SIZE (0x40000 - ((HAL_NV_PAGE_CNT+HAL_OAD_BOOT_PG_CNT)*HAL_FLASH_PAGE_SIZE))
|
|||
|
#define HAL_OAD_DL_OSET 0x0 // Configurable offset into an external NV.
|
|||
|
#else
|
|||
|
#define HAL_OAD_DL_MAX (0x40000 - ((HAL_NV_PAGE_CNT+HAL_OAD_BOOT_PG_CNT)*HAL_FLASH_PAGE_SIZE))
|
|||
|
#define HAL_OAD_DL_SIZE (HAL_OAD_DL_MAX / 2)
|
|||
|
#define HAL_OAD_DL_OSET (HAL_OAD_DL_MAX / 2)
|
|||
|
#endif
|
|||
|
|
|||
|
// To run OAD with the legacy ZOAD.exe PC tool, place the preamble in this legacy location.
|
|||
|
#define PREAMBLE_OFFSET 0x8C
|
|||
|
|
|||
|
#if HAL_OAD_XNV_IS_INT
|
|||
|
#define VDD_MIN_OAD VDD_MIN_NV
|
|||
|
#else
|
|||
|
#define VDD_MIN_OAD VDD_MIN_XNV
|
|||
|
#endif
|
|||
|
|
|||
|
/*********************************************************************
|
|||
|
* TYPEDEFS
|
|||
|
*/
|
|||
|
|
|||
|
typedef enum {
|
|||
|
HAL_OAD_RC, /* Run code / active image. */
|
|||
|
HAL_OAD_DL /* Downloaded code to be activated later. */
|
|||
|
} image_t;
|
|||
|
|
|||
|
typedef struct {
|
|||
|
uint8 magic[2];
|
|||
|
uint32 len;
|
|||
|
uint16 vers;
|
|||
|
uint16 manu;
|
|||
|
uint16 prod;
|
|||
|
} preamble_t;
|
|||
|
|
|||
|
/*********************************************************************
|
|||
|
* FUNCTIONS
|
|||
|
*/
|
|||
|
|
|||
|
uint8 HalOADChkDL(uint8 dlImagePreambleOffset);
|
|||
|
void HalOADInvRC(void);
|
|||
|
uint32 HalOADAvail(void);
|
|||
|
void HalOADRead(uint32 oset, uint8 *pBuf, uint16 len, image_t type);
|
|||
|
void HalOADWrite(uint32 oset, uint8 *pBuf, uint16 len, image_t type);
|
|||
|
#endif
|