123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349 |
- #ifndef HAL_BOARD_CFG_H
- #define HAL_BOARD_CFG_H
- #include "hal_mcu.h"
- #include "hal_defs.h"
- #include "hal_types.h"
- #include "usb_board_cfg.h"
- #define xHAL_PA_LNA
- #define xHAL_PA_LNA_CC2590
- #if !defined (HAL_BOARD_CC2530EB_REV17) && !defined (HAL_BOARD_CC2530EB_REV13)
- #define HAL_BOARD_CC2530EB_REV17
- #endif
- #define HAL_BOARD_CC2530USB
- #define HAL_CPU_CLOCK_MHZ 32
- #define HAL_CLOCK_CRYSTAL
- #define OSC32K_CRYSTAL_INSTALLED FALSE
- #if !defined (OSC32K_CRYSTAL_INSTALLED) || (defined (OSC32K_CRYSTAL_INSTALLED) && (OSC32K_CRYSTAL_INSTALLED == TRUE))
- #define OSC_32KHZ 0x00
- #else
- #define OSC_32KHZ 0x80
- #endif
- #define HAL_CLOCK_STABLE() st( while (CLKCONSTA != (CLKCONCMD_32MHZ | OSC_32KHZ)); )
- #define HAL_NUM_LEDS 2
- #define HAL_LED_BLINK_DELAY() st( { volatile uint32 i; for (i=0; i<0x5800; i++) { }; } )
- #define LED1_BV BV(0)
- #define LED1_SBIT P0_0
- #define LED1_DDR P0DIR
- #define LED1_POLARITY ACTIVE_LOW
- #define LED2_BV BV(1)
- #define LED2_SBIT P1_1
- #define LED2_DDR P1DIR
- #define LED2_POLARITY ACTIVE_HIGH
- #define ACTIVE_LOW !
- #define ACTIVE_HIGH !!
- #define PUSH1_BV BV(2)
- #define PUSH1_SBIT P1_2
- #define PUSH1_POLARITY ACTIVE_LOW
- #define PUSH2_BV BV(3)
- #define PUSH2_SBIT P1_3
- #define PUSH2_POLARITY ACTIVE_LOW
- #define HAL_FLASH_PAGE_PER_BANK 16
- #define HAL_FLASH_PAGE_SIZE 2048
- #define HAL_FLASH_WORD_SIZE 4
- #define HAL_FLASH_PAGE_MAP 0x8000
- #if defined NON_BANKED
- #define HAL_FLASH_LOCK_BITS 16
- #define HAL_NV_PAGE_END 30
- #define HAL_NV_PAGE_CNT 2
- #else
- #define HAL_FLASH_LOCK_BITS 16
- #define HAL_NV_PAGE_END 126
- #define HAL_NV_PAGE_CNT 6
- #endif
- #define HAL_FLASH_IEEE_SIZE 8
- #define HAL_FLASH_IEEE_PAGE (HAL_NV_PAGE_END+1)
- #define HAL_FLASH_IEEE_OSET (HAL_FLASH_PAGE_SIZE - HAL_FLASH_LOCK_BITS - HAL_FLASH_IEEE_SIZE)
- #define HAL_INFOP_IEEE_OSET 0xC
- #define HAL_FLASH_DEV_PRIVATE_KEY_OSET 0x7D2
- #define HAL_FLASH_CA_PUBLIC_KEY_OSET 0x7BC
- #define HAL_FLASH_IMPLICIT_CERT_OSET 0x78C
- #define HAL_NV_PAGE_BEG (HAL_NV_PAGE_END-HAL_NV_PAGE_CNT+1)
- #define HAL_NV_DMA_CH 0
- #define HAL_DMA_CH_RX 3
- #define HAL_DMA_CH_TX 4
- #define HAL_NV_DMA_GET_DESC() HAL_DMA_GET_DESC0()
- #define HAL_NV_DMA_SET_ADDR(a) HAL_DMA_SET_ADDR_DESC0((a))
- #define HAL_SB_IMG_ADDR 0x2000
- #define HAL_SB_CRC_ADDR 0x2090
- #define HAL_SB_IMG_SIZE (0x40000 - 0x2000 - 0x3000 - 0x0800)
- #define PREFETCH_ENABLE() st( FCTL = 0x08; )
- #define PREFETCH_DISABLE() st( FCTL = 0x04; )
- #define HAL_BOARD_INIT() \
- { \
- uint16 i; \
- \
- SLEEPCMD &= ~OSC_PD; \
- while (!(SLEEPSTA & XOSC_STB)); \
- asm("NOP"); \
- for (i=0; i<504; i++) asm("NOP"); \
- CLKCONCMD = (CLKCONCMD_32MHZ | OSC_32KHZ); \
- while (CLKCONSTA != (CLKCONCMD_32MHZ | OSC_32KHZ)); \
- SLEEPCMD |= OSC_PD; \
- \
- \
- PREFETCH_ENABLE(); \
- \
- HAL_TURN_OFF_LED1(); \
- LED1_DDR |= LED1_BV; \
- HAL_TURN_OFF_LED2(); \
- LED2_DDR |= LED2_BV; \
- }
- #define HAL_DEBOUNCE(expr) { int i; for (i=0; i<500; i++) { if (!(expr)) i = 0; } }
- #define HAL_PUSH_BUTTON1() (PUSH1_POLARITY (PUSH1_SBIT))
- #define HAL_PUSH_BUTTON2() (PUSH2_POLARITY (PUSH2_SBIT))
- #define HAL_PUSH_BUTTON3() (0)
- #define HAL_PUSH_BUTTON4() (0)
- #define HAL_PUSH_BUTTON5() (0)
- #define HAL_PUSH_BUTTON6() (0)
- #define HAL_TURN_OFF_LED1() st( LED1_SBIT = LED1_POLARITY (0); )
- #define HAL_TURN_OFF_LED2() st( LED2_SBIT = LED2_POLARITY (0); )
- #define HAL_TURN_OFF_LED3() HAL_TURN_OFF_LED1()
- #define HAL_TURN_OFF_LED4() HAL_TURN_OFF_LED2()
- #define HAL_TURN_ON_LED1() st( LED1_SBIT = LED1_POLARITY (1); )
- #define HAL_TURN_ON_LED2() st( LED2_SBIT = LED2_POLARITY (1); )
- #define HAL_TURN_ON_LED3() HAL_TURN_ON_LED1()
- #define HAL_TURN_ON_LED4() HAL_TURN_ON_LED2()
- #define HAL_TOGGLE_LED1() st( if (LED1_SBIT) { LED1_SBIT = 0; } else { LED1_SBIT = 1;} )
- #define HAL_TOGGLE_LED2() st( if (LED2_SBIT) { LED2_SBIT = 0; } else { LED2_SBIT = 1;} )
- #define HAL_TOGGLE_LED3() HAL_TOGGLE_LED1()
- #define HAL_TOGGLE_LED4() HAL_TOGGLE_LED2()
- #define HAL_STATE_LED1() (LED1_POLARITY (LED1_SBIT))
- #define HAL_STATE_LED2() (LED2_POLARITY (LED2_SBIT))
- #define HAL_STATE_LED3() HAL_STATE_LED1()
- #define HAL_STATE_LED4() HAL_STATE_LED2()
- #define VDD_2_0 74
- #define VDD_MIN_RUN VDD_2_0
- #define VDD_MIN_NV (VDD_2_0+4)
- #ifndef HAL_TIMER
- #define HAL_TIMER FALSE
- #endif
- #ifndef HAL_ADC
- #define HAL_ADC TRUE
- #endif
- #ifndef HAL_DMA
- #define HAL_DMA TRUE
- #endif
- #ifndef HAL_FLASH
- #define HAL_FLASH TRUE
- #endif
- #ifndef HAL_AES
- #define HAL_AES TRUE
- #endif
- #ifndef HAL_AES_DMA
- #define HAL_AES_DMA TRUE
- #endif
- #ifndef HAL_LCD
- #define HAL_LCD FALSE
- #endif
- #ifndef HAL_LED
- #define HAL_LED TRUE
- #endif
- #if (!defined BLINK_LEDS) && (HAL_LED == TRUE)
- #define BLINK_LEDS
- #endif
- #ifndef HAL_KEY
- #define HAL_KEY TRUE
- #endif
- #ifndef HAL_UART
- #define HAL_UART TRUE
- #define HAL_UART_DMA 0
- #define HAL_UART_ISR 0
- #define HAL_UART_USB 1
- #endif
- #ifndef HAL_UART_DMA
- #define HAL_UART_DMA 0
- #endif
- #ifndef HAL_UART_ISR
- #define HAL_UART_ISR 0
- #endif
- #ifndef HAL_UART_USB
- # if HAL_UART
- # define HAL_UART_USB 1
- # else
- # define HAL_UART_USB 0
- # endif
- #endif
- #ifndef HAL_HID
- #define HAL_HID FALSE
- #endif
- #endif
|