new file: include/_hal_uart_dma.c
new file: include/_hal_uart_isr.c new file: include/hal_adc.c new file: include/hal_adc.h new file: include/hal_aes.h new file: include/hal_assert.c new file: include/hal_assert.h new file: include/hal_board.h new file: include/hal_board_cfg.h new file: include/hal_ccm.h new file: include/hal_defs.h new file: include/hal_dma.c new file: include/hal_dma.h new file: include/hal_drivers.c new file: include/hal_drivers.h new file: include/hal_flash.c new file: include/hal_flash.h new file: include/hal_key.c new file: include/hal_key.h new file: include/hal_lcd.c new file: include/hal_lcd.h new file: include/hal_led.c new file: include/hal_led.h new file: include/hal_mac_cfg.h new file: include/hal_mcu.h new file: include/hal_oad.c new file: include/hal_oad.h new file: include/hal_ota.c new file: include/hal_ota.h new file: include/hal_rpc.h new file: include/hal_sleep.c new file: include/hal_sleep.h new file: include/hal_startup.c new file: include/hal_timer.c new file: include/hal_timer.h new file: include/hal_types.h new file: include/hal_uart.c new file: include/hal_uart.h
This commit is contained in:
130
include/hal_oad.h
Normal file
130
include/hal_oad.h
Normal file
@@ -0,0 +1,130 @@
|
||||
/**************************************************************************************************
|
||||
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 <20>AS IS<49> 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
|
||||
Reference in New Issue
Block a user