1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/cpu/cc26x0/vendor/inc/hw_chip_def.h
2020-11-05 23:25:49 -08:00

238 lines
9.7 KiB
C

/******************************************************************************
* Filename: hw_chip_def.h
* Revised: 2017-06-26 09:33:33 +0200 (Mon, 26 Jun 2017)
* Revision: 49227
*
* Description: Defines for device properties.
*
* Copyright (c) 2015 - 2017, Texas Instruments Incorporated
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1) Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2) Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* 3) Neither the name of the ORGANIZATION nor the names of its contributors may
* be used to endorse or promote products derived from this software without
* specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
******************************************************************************/
//*****************************************************************************
//
//! \addtogroup config_api
//! @{
//
//*****************************************************************************
#ifndef __HW_CHIP_DEF_H__
#define __HW_CHIP_DEF_H__
//*****************************************************************************
//
// If building with a C++ compiler, make all of the definitions in this header
// have a C binding.
//
//*****************************************************************************
#ifdef __cplusplus
extern "C"
{
#endif
//*****************************************************************************
//
// Define CC_CHIP_ID code used in the following macros defined at the bottom:
// CC_GET_CHIP_FAMILY/DEVICE/PACKAGE/HWREV
//
//*****************************************************************************
/* CC2620F128 */
#if defined(CC2620F128RGZ_R20) || defined(CC2620F128RGZ_R21)
#define CC_CHIP_ID 0x26200720
#elif defined(CC2620F128RHB_R20) || defined(CC2620F128RHB_R21)
#define CC_CHIP_ID 0x26200520
#elif defined(CC2620F128RSM_R20) || defined(CC2620F128RSM_R21)
#define CC_CHIP_ID 0x26200420
#elif defined(CC2620F128_R20) || defined(CC2620F128_R21)
#define CC_CHIP_ID 0x26200020
#elif defined(CC2620F128RGZ_R22) || defined(CC2620F128RGZ)
#define CC_CHIP_ID 0x26200722
#elif defined(CC2620F128RHB_R22) || defined(CC2620F128RHB)
#define CC_CHIP_ID 0x26200522
#elif defined(CC2620F128RSM_R22) || defined(CC2620F128RSM)
#define CC_CHIP_ID 0x26200422
#elif defined(CC2620F128_R22) || defined(CC2620F128)
#define CC_CHIP_ID 0x26200022
/* CC2630F128 */
#elif defined(CC2630F128RGZ_R20) || defined(CC2630F128RGZ_R21)
#define CC_CHIP_ID 0x26300720
#elif defined(CC2630F128RHB_R20) || defined(CC2630F128RHB_R21)
#define CC_CHIP_ID 0x26300520
#elif defined(CC2630F128RSM_R20) || defined(CC2630F128RSM_R21)
#define CC_CHIP_ID 0x26300420
#elif defined(CC2630F128_R20) || defined(CC2630F128_R21)
#define CC_CHIP_ID 0x26300020
#elif defined(CC2630F128RGZ_R22) || defined(CC2630F128RGZ)
#define CC_CHIP_ID 0x26300722
#elif defined(CC2630F128RHB_R22) || defined(CC2630F128RHB)
#define CC_CHIP_ID 0x26300522
#elif defined(CC2630F128RSM_R22) || defined(CC2630F128RSM)
#define CC_CHIP_ID 0x26300422
#elif defined(CC2630F128_R22) || defined(CC2630F128)
#define CC_CHIP_ID 0x26300022
/* CC2640F128 */
#elif defined(CC2640F128RGZ_R20) || defined(CC2640F128RGZ_R21)
#define CC_CHIP_ID 0x26400720
#elif defined(CC2640F128RHB_R20) || defined(CC2640F128RHB_R21)
#define CC_CHIP_ID 0x26400520
#elif defined(CC2640F128RSM_R20) || defined(CC2640F128RSM_R21)
#define CC_CHIP_ID 0x26400420
#elif defined(CC2640F128_R20) || defined(CC2640F128_R21)
#define CC_CHIP_ID 0x26400020
#elif defined(CC2640F128RGZ_R22) || defined(CC2640F128RGZ)
#define CC_CHIP_ID 0x26400722
#elif defined(CC2640F128RHB_R22) || defined(CC2640F128RHB)
#define CC_CHIP_ID 0x26400522
#elif defined(CC2640F128RSM_R22) || defined(CC2640F128RSM)
#define CC_CHIP_ID 0x26400422
#elif defined(CC2640F128_R22) || defined(CC2640F128)
#define CC_CHIP_ID 0x26400022
/* CC2650F128 */
#elif defined(CC2650F128RGZ_R20) || defined(CC2650F128RGZ_R21)
#define CC_CHIP_ID 0x26500720
#elif defined(CC2650F128RHB_R20) || defined(CC2650F128RHB_R21)
#define CC_CHIP_ID 0x26500520
#elif defined(CC2650F128RSM_R20) || defined(CC2650F128RSM_R21)
#define CC_CHIP_ID 0x26500420
#elif defined(CC2650F128_R20) || defined(CC2650F128_R21)
#define CC_CHIP_ID 0x26500020
#elif defined(CC2650F128RGZ_R22) || defined(CC2650F128RGZ)
#define CC_CHIP_ID 0x26500722
#elif defined(CC2650F128RHB_R22) || defined(CC2650F128RHB)
#define CC_CHIP_ID 0x26500522
#elif defined(CC2650F128RSM_R22) || defined(CC2650F128RSM)
#define CC_CHIP_ID 0x26500422
#elif defined(CC2650F128_R22) || defined(CC2650F128)
#define CC_CHIP_ID 0x26500022
/* CC2650L128 (OTP) */
#elif defined(CC2650L128)
#define CC_CHIP_ID 0x26501710
/* CC1310F128 */
#elif defined(CC1310F128RGZ_R20) || defined(CC1310F128RGZ)
#define CC_CHIP_ID 0x13100720
#elif defined(CC1310F128RHB_R20) || defined(CC1310F128RHB)
#define CC_CHIP_ID 0x13100520
#elif defined(CC1310F128RSM_R20) || defined(CC1310F128RSM)
#define CC_CHIP_ID 0x13100420
#elif defined(CC1310F128_R20) || defined(CC1310F128)
#define CC_CHIP_ID 0x13100020
/* CC1350F128 */
#elif defined(CC1350F128RGZ_R20) || defined(CC1350F128RGZ)
#define CC_CHIP_ID 0x13500720
#elif defined(CC1350F128RHB_R20) || defined(CC1350F128RHB)
#define CC_CHIP_ID 0x13500520
#elif defined(CC1350F128RSM_R20) || defined(CC1350F128RSM)
#define CC_CHIP_ID 0x13500420
#elif defined(CC1350F128_R20) || defined(CC1350F128)
#define CC_CHIP_ID 0x13500020
/* CC2640R2F */
#elif defined(CC2640R2FRGZ_R25) || defined(CC2640R2FRGZ)
#define CC_CHIP_ID 0x26401710
#elif defined(CC2640R2FRHB_R25) || defined(CC2640R2FRHB)
#define CC_CHIP_ID 0x26401510
#elif defined(CC2640R2FRSM_R25) || defined(CC2640R2FRSM)
#define CC_CHIP_ID 0x26401410
#elif defined(CC2640R2F_R25) || defined(CC2640R2F)
#define CC_CHIP_ID 0x26401010
/* CC2652R1F */
#elif defined(CC2652R1FRGZ_R10) || defined(CC2652R1FRGZ)
#define CC_CHIP_ID 0x26523710
#elif defined(CC2652R1F_R10) || defined(CC2652R1F)
#define CC_CHIP_ID 0x26523010
/* CC2644R1F */
#elif defined(CC2644R1FRGZ_R10) || defined(CC2644R1FRGZ)
#define CC_CHIP_ID 0x26443710
#elif defined(CC2644R1F_R10) || defined(CC2644R1F)
#define CC_CHIP_ID 0x26443010
/* CC2642R1F */
#elif defined(CC2642R1FRGZ_R10) || defined(CC2642R1FRGZ)
#define CC_CHIP_ID 0x26423710
#elif defined(CC2642R1F_R10) || defined(CC2642R1F)
#define CC_CHIP_ID 0x26423010
/* CC1354R1F */
#elif defined(CC1354R1FRGZ_R10) || defined(CC1354R1FRGZ)
#define CC_CHIP_ID 0x13543710
#elif defined(CC1354R1F_R10) || defined(CC1354R1F)
#define CC_CHIP_ID 0x13543010
/* CC1352R1F */
#elif defined(CC1352R1FRGZ_R10) || defined(CC1352R1FRGZ)
#define CC_CHIP_ID 0x13523710
#elif defined(CC1352R1F_R10) || defined(CC1352R1F)
#define CC_CHIP_ID 0x13523010
/* CC1312R1F */
#elif defined(CC1312R1FRGZ_R10) || defined(CC1312R1FRGZ)
#define CC_CHIP_ID 0x13123710
#elif defined(CC1312R1F_R10) || defined(CC1312R1F)
#define CC_CHIP_ID 0x13123010
#endif
#define CC_GET_CHIP_FAMILY 0x26
#define CC_GET_CHIP_OPTION 0x0
#define CC_GET_CHIP_HWREV 0x22
#ifdef CC_CHIP_ID
/* Define chip package only if specified */
#if (CC_CHIP_ID & 0x00000F00) != 0
#define CC_GET_CHIP_PACKAGE (((CC_CHIP_ID) & 0x00000F00) >> 8)
#endif
/* Define chip device */
#define CC_GET_CHIP_DEVICE (((CC_CHIP_ID) & 0xFFFF0000) >> 16)
/* The chip family, option and package shall match the DriverLib release */
#if (CC_GET_CHIP_FAMILY != ((CC_CHIP_ID & 0xFF000000) >> 24))
#error "Specified chip family does not match DriverLib release"
#endif
#if (CC_GET_CHIP_OPTION != ((CC_CHIP_ID & 0x0000F000) >> 12))
#error "Specified chip option does not match DriverLib release"
#endif
#if (CC_GET_CHIP_HWREV != ((CC_CHIP_ID & 0x000000FF) >> 0))
#error "Specified chip hardware revision does not match DriverLib release"
#endif
#endif
//*****************************************************************************
//
// Mark the end of the C bindings section for C++ compilers.
//
//*****************************************************************************
#ifdef __cplusplus
}
#endif
#endif // __HW_CHIP_DEF_H__
//*****************************************************************************
//
//! Close the Doxygen group.
//! @}
//
//*****************************************************************************