4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-01-19 04:03:32 +08:00
2017-08-30 12:18:28 +08:00

1595 lines
36 KiB
C

/**
* \file
*
* \brief Atmel part identification macros
*
* Copyright (C) 2012-2017 Atmel Corporation. All rights reserved.
*
* \asf_license_start
*
* \page License
*
* 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. The name of Atmel may not be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* 4. This software may only be redistributed and used in connection with an
* Atmel microcontroller product.
*
* THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE
* EXPRESSLY AND SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL 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.
*
* \asf_license_stop
*
*/
/*
* Support and FAQ: visit <a href="http://www.atmel.com/design-support/">Atmel Support</a>
*/
#ifndef ATMEL_PARTS_H
#define ATMEL_PARTS_H
/**
* \defgroup part_macros_group Atmel part identification macros
*
* This collection of macros identify which series and families that the various
* Atmel parts belong to. These can be used to select part-dependent sections of
* code at compile time.
*
* @{
*/
/**
* \name Convenience macros for part checking
* @{
*/
/* ! Check GCC and IAR part definition for 8-bit AVR */
#define AVR8_PART_IS_DEFINED(part) \
(defined(__ ## part ## __) || defined(__AVR_ ## part ## __))
/* ! Check GCC and IAR part definition for 32-bit AVR */
#define AVR32_PART_IS_DEFINED(part) \
(defined(__AT32 ## part ## __) || defined(__AVR32_ ## part ## __))
/* ! Check GCC and IAR part definition for SAM */
#define SAM_PART_IS_DEFINED(part) (defined(__ ## part ## __))
/** @} */
/**
* \defgroup uc3_part_macros_group AVR UC3 parts
* @{
*/
/**
* \name AVR UC3 A series
* @{
*/
#define UC3A0 ( \
AVR32_PART_IS_DEFINED(UC3A0128) || \
AVR32_PART_IS_DEFINED(UC3A0256) || \
AVR32_PART_IS_DEFINED(UC3A0512) \
)
#define UC3A1 ( \
AVR32_PART_IS_DEFINED(UC3A1128) || \
AVR32_PART_IS_DEFINED(UC3A1256) || \
AVR32_PART_IS_DEFINED(UC3A1512) \
)
#define UC3A3 ( \
AVR32_PART_IS_DEFINED(UC3A364) || \
AVR32_PART_IS_DEFINED(UC3A364S) || \
AVR32_PART_IS_DEFINED(UC3A3128) || \
AVR32_PART_IS_DEFINED(UC3A3128S) || \
AVR32_PART_IS_DEFINED(UC3A3256) || \
AVR32_PART_IS_DEFINED(UC3A3256S) \
)
#define UC3A4 ( \
AVR32_PART_IS_DEFINED(UC3A464) || \
AVR32_PART_IS_DEFINED(UC3A464S) || \
AVR32_PART_IS_DEFINED(UC3A4128) || \
AVR32_PART_IS_DEFINED(UC3A4128S) || \
AVR32_PART_IS_DEFINED(UC3A4256) || \
AVR32_PART_IS_DEFINED(UC3A4256S) \
)
/** @} */
/**
* \name AVR UC3 B series
* @{
*/
#define UC3B0 ( \
AVR32_PART_IS_DEFINED(UC3B064) || \
AVR32_PART_IS_DEFINED(UC3B0128) || \
AVR32_PART_IS_DEFINED(UC3B0256) || \
AVR32_PART_IS_DEFINED(UC3B0512) \
)
#define UC3B1 ( \
AVR32_PART_IS_DEFINED(UC3B164) || \
AVR32_PART_IS_DEFINED(UC3B1128) || \
AVR32_PART_IS_DEFINED(UC3B1256) || \
AVR32_PART_IS_DEFINED(UC3B1512) \
)
/** @} */
/**
* \name AVR UC3 C series
* @{
*/
#define UC3C0 ( \
AVR32_PART_IS_DEFINED(UC3C064C) || \
AVR32_PART_IS_DEFINED(UC3C0128C) || \
AVR32_PART_IS_DEFINED(UC3C0256C) || \
AVR32_PART_IS_DEFINED(UC3C0512C) \
)
#define UC3C1 ( \
AVR32_PART_IS_DEFINED(UC3C164C) || \
AVR32_PART_IS_DEFINED(UC3C1128C) || \
AVR32_PART_IS_DEFINED(UC3C1256C) || \
AVR32_PART_IS_DEFINED(UC3C1512C) \
)
#define UC3C2 ( \
AVR32_PART_IS_DEFINED(UC3C264C) || \
AVR32_PART_IS_DEFINED(UC3C2128C) || \
AVR32_PART_IS_DEFINED(UC3C2256C) || \
AVR32_PART_IS_DEFINED(UC3C2512C) \
)
/** @} */
/**
* \name AVR UC3 D series
* @{
*/
#define UC3D3 ( \
AVR32_PART_IS_DEFINED(UC64D3) || \
AVR32_PART_IS_DEFINED(UC128D3) \
)
#define UC3D4 ( \
AVR32_PART_IS_DEFINED(UC64D4) || \
AVR32_PART_IS_DEFINED(UC128D4) \
)
/** @} */
/**
* \name AVR UC3 L series
* @{
*/
#define UC3L0 ( \
AVR32_PART_IS_DEFINED(UC3L016) || \
AVR32_PART_IS_DEFINED(UC3L032) || \
AVR32_PART_IS_DEFINED(UC3L064) \
)
#define UC3L0128 ( \
AVR32_PART_IS_DEFINED(UC3L0128) \
)
#define UC3L0256 ( \
AVR32_PART_IS_DEFINED(UC3L0256) \
)
#define UC3L3 ( \
AVR32_PART_IS_DEFINED(UC64L3U) || \
AVR32_PART_IS_DEFINED(UC128L3U) || \
AVR32_PART_IS_DEFINED(UC256L3U) \
)
#define UC3L4 ( \
AVR32_PART_IS_DEFINED(UC64L4U) || \
AVR32_PART_IS_DEFINED(UC128L4U) || \
AVR32_PART_IS_DEFINED(UC256L4U) \
)
#define UC3L3_L4 (UC3L3 || UC3L4)
/** @} */
/**
* \name AVR UC3 families
* @{
*/
/** AVR UC3 A family */
#define UC3A (UC3A0 || UC3A1 || UC3A3 || UC3A4)
/** AVR UC3 B family */
#define UC3B (UC3B0 || UC3B1)
/** AVR UC3 C family */
#define UC3C (UC3C0 || UC3C1 || UC3C2)
/** AVR UC3 D family */
#define UC3D (UC3D3 || UC3D4)
/** AVR UC3 L family */
#define UC3L (UC3L0 || UC3L0128 || UC3L0256 || UC3L3_L4)
/** @} */
/** AVR UC3 product line */
#define UC3 (UC3A || UC3B || UC3C || UC3D || UC3L)
/** @} */
/**
* \defgroup xmega_part_macros_group AVR XMEGA parts
* @{
*/
/**
* \name AVR XMEGA A series
* @{
*/
#define XMEGA_A1 ( \
AVR8_PART_IS_DEFINED(ATxmega64A1) || \
AVR8_PART_IS_DEFINED(ATxmega128A1) \
)
#define XMEGA_A3 ( \
AVR8_PART_IS_DEFINED(ATxmega64A3) || \
AVR8_PART_IS_DEFINED(ATxmega128A3) || \
AVR8_PART_IS_DEFINED(ATxmega192A3) || \
AVR8_PART_IS_DEFINED(ATxmega256A3) \
)
#define XMEGA_A3B ( \
AVR8_PART_IS_DEFINED(ATxmega256A3B) \
)
#define XMEGA_A4 ( \
AVR8_PART_IS_DEFINED(ATxmega16A4) || \
AVR8_PART_IS_DEFINED(ATxmega32A4) \
)
/** @} */
/**
* \name AVR XMEGA AU series
* @{
*/
#define XMEGA_A1U ( \
AVR8_PART_IS_DEFINED(ATxmega64A1U) || \
AVR8_PART_IS_DEFINED(ATxmega128A1U) \
)
#define XMEGA_A3U ( \
AVR8_PART_IS_DEFINED(ATxmega64A3U) || \
AVR8_PART_IS_DEFINED(ATxmega128A3U) || \
AVR8_PART_IS_DEFINED(ATxmega192A3U) || \
AVR8_PART_IS_DEFINED(ATxmega256A3U) \
)
#define XMEGA_A3BU ( \
AVR8_PART_IS_DEFINED(ATxmega256A3BU) \
)
#define XMEGA_A4U ( \
AVR8_PART_IS_DEFINED(ATxmega16A4U) || \
AVR8_PART_IS_DEFINED(ATxmega32A4U) || \
AVR8_PART_IS_DEFINED(ATxmega64A4U) || \
AVR8_PART_IS_DEFINED(ATxmega128A4U) \
)
/** @} */
/**
* \name AVR XMEGA B series
* @{
*/
#define XMEGA_B1 ( \
AVR8_PART_IS_DEFINED(ATxmega64B1) || \
AVR8_PART_IS_DEFINED(ATxmega128B1) \
)
#define XMEGA_B3 ( \
AVR8_PART_IS_DEFINED(ATxmega64B3) || \
AVR8_PART_IS_DEFINED(ATxmega128B3) \
)
/** @} */
/**
* \name AVR XMEGA C series
* @{
*/
#define XMEGA_C3 ( \
AVR8_PART_IS_DEFINED(ATxmega384C3) || \
AVR8_PART_IS_DEFINED(ATxmega256C3) || \
AVR8_PART_IS_DEFINED(ATxmega192C3) || \
AVR8_PART_IS_DEFINED(ATxmega128C3) || \
AVR8_PART_IS_DEFINED(ATxmega64C3) || \
AVR8_PART_IS_DEFINED(ATxmega32C3) \
)
#define XMEGA_C4 ( \
AVR8_PART_IS_DEFINED(ATxmega32C4) || \
AVR8_PART_IS_DEFINED(ATxmega16C4) \
)
/** @} */
/**
* \name AVR XMEGA D series
* @{
*/
#define XMEGA_D3 ( \
AVR8_PART_IS_DEFINED(ATxmega32D3) || \
AVR8_PART_IS_DEFINED(ATxmega64D3) || \
AVR8_PART_IS_DEFINED(ATxmega128D3) || \
AVR8_PART_IS_DEFINED(ATxmega192D3) || \
AVR8_PART_IS_DEFINED(ATxmega256D3) || \
AVR8_PART_IS_DEFINED(ATxmega384D3) \
)
#define XMEGA_D4 ( \
AVR8_PART_IS_DEFINED(ATxmega16D4) || \
AVR8_PART_IS_DEFINED(ATxmega32D4) || \
AVR8_PART_IS_DEFINED(ATxmega64D4) || \
AVR8_PART_IS_DEFINED(ATxmega128D4) \
)
/** @} */
/**
* \name AVR XMEGA E series
* @{
*/
#define XMEGA_E5 ( \
AVR8_PART_IS_DEFINED(ATxmega8E5) || \
AVR8_PART_IS_DEFINED(ATxmega16E5) || \
AVR8_PART_IS_DEFINED(ATxmega32E5) \
)
/** @} */
/**
* \name AVR XMEGA families
* @{
*/
/** AVR XMEGA A family */
#define XMEGA_A (XMEGA_A1 || XMEGA_A3 || XMEGA_A3B || XMEGA_A4)
/** AVR XMEGA AU family */
#define XMEGA_AU (XMEGA_A1U || XMEGA_A3U || XMEGA_A3BU || XMEGA_A4U)
/** AVR XMEGA B family */
#define XMEGA_B (XMEGA_B1 || XMEGA_B3)
/** AVR XMEGA C family */
#define XMEGA_C (XMEGA_C3 || XMEGA_C4)
/** AVR XMEGA D family */
#define XMEGA_D (XMEGA_D3 || XMEGA_D4)
/** AVR XMEGA E family */
#define XMEGA_E (XMEGA_E5)
/** @} */
/** AVR XMEGA product line */
#define XMEGA (XMEGA_A || XMEGA_AU || XMEGA_B || XMEGA_C || XMEGA_D || XMEGA_E)
/** @} */
/**
* \defgroup mega_part_macros_group megaAVR parts
*
* \note These megaAVR groupings are based on the groups in AVR Libc for the
* part header files. They are not names of official megaAVR device series or
* families.
*
* @{
*/
/**
* \name ATmegaxx0/xx1 subgroups
* @{
*/
#define MEGA_XX0 ( \
AVR8_PART_IS_DEFINED(ATmega640) || \
AVR8_PART_IS_DEFINED(ATmega1280) || \
AVR8_PART_IS_DEFINED(ATmega2560) \
)
#define MEGA_XX1 ( \
AVR8_PART_IS_DEFINED(ATmega1281) || \
AVR8_PART_IS_DEFINED(ATmega2561) \
)
/** @} */
/**
* \name megaAVR groups
* @{
*/
/** ATmegaxx0/xx1 group */
#define MEGA_XX0_1 (MEGA_XX0 || MEGA_XX1)
/** ATmegaxx4 group */
#define MEGA_XX4 ( \
AVR8_PART_IS_DEFINED(ATmega164A) || \
AVR8_PART_IS_DEFINED(ATmega164PA) || \
AVR8_PART_IS_DEFINED(ATmega324A) || \
AVR8_PART_IS_DEFINED(ATmega324PA) || \
AVR8_PART_IS_DEFINED(ATmega324PB) || \
AVR8_PART_IS_DEFINED(ATmega644) || \
AVR8_PART_IS_DEFINED(ATmega644A) || \
AVR8_PART_IS_DEFINED(ATmega644PA) || \
AVR8_PART_IS_DEFINED(ATmega1284P) || \
AVR8_PART_IS_DEFINED(ATmega128RFA1) \
)
/** ATmegaxx4 group */
#define MEGA_XX4_A ( \
AVR8_PART_IS_DEFINED(ATmega164A) || \
AVR8_PART_IS_DEFINED(ATmega164PA) || \
AVR8_PART_IS_DEFINED(ATmega324A) || \
AVR8_PART_IS_DEFINED(ATmega324PA) || \
AVR8_PART_IS_DEFINED(ATmega644A) || \
AVR8_PART_IS_DEFINED(ATmega644PA) || \
AVR8_PART_IS_DEFINED(ATmega1284P) \
)
/** ATmegaxx8 group */
#define MEGA_XX8 ( \
AVR8_PART_IS_DEFINED(ATmega48) || \
AVR8_PART_IS_DEFINED(ATmega48A) || \
AVR8_PART_IS_DEFINED(ATmega48PA) || \
AVR8_PART_IS_DEFINED(ATmega48PB) || \
AVR8_PART_IS_DEFINED(ATmega88) || \
AVR8_PART_IS_DEFINED(ATmega88A) || \
AVR8_PART_IS_DEFINED(ATmega88PA) || \
AVR8_PART_IS_DEFINED(ATmega88PB) || \
AVR8_PART_IS_DEFINED(ATmega168) || \
AVR8_PART_IS_DEFINED(ATmega168A) || \
AVR8_PART_IS_DEFINED(ATmega168PA) || \
AVR8_PART_IS_DEFINED(ATmega168PB) || \
AVR8_PART_IS_DEFINED(ATmega328) || \
AVR8_PART_IS_DEFINED(ATmega328P) || \
AVR8_PART_IS_DEFINED(ATmega328PB) \
)
/** ATmegaxx8A/P/PA group */
#define MEGA_XX8_A ( \
AVR8_PART_IS_DEFINED(ATmega48A) || \
AVR8_PART_IS_DEFINED(ATmega48PA) || \
AVR8_PART_IS_DEFINED(ATmega88A) || \
AVR8_PART_IS_DEFINED(ATmega88PA) || \
AVR8_PART_IS_DEFINED(ATmega168A) || \
AVR8_PART_IS_DEFINED(ATmega168PA) || \
AVR8_PART_IS_DEFINED(ATmega328P) \
)
/** ATmegaxx group */
#define MEGA_XX ( \
AVR8_PART_IS_DEFINED(ATmega16) || \
AVR8_PART_IS_DEFINED(ATmega16A) || \
AVR8_PART_IS_DEFINED(ATmega32) || \
AVR8_PART_IS_DEFINED(ATmega32A) || \
AVR8_PART_IS_DEFINED(ATmega64) || \
AVR8_PART_IS_DEFINED(ATmega64A) || \
AVR8_PART_IS_DEFINED(ATmega128) || \
AVR8_PART_IS_DEFINED(ATmega128A) \
)
/** ATmegaxxA/P/PA group */
#define MEGA_XX_A ( \
AVR8_PART_IS_DEFINED(ATmega16A) || \
AVR8_PART_IS_DEFINED(ATmega32A) || \
AVR8_PART_IS_DEFINED(ATmega64A) || \
AVR8_PART_IS_DEFINED(ATmega128A) \
)
/** ATmegaxxRFA1 group */
#define MEGA_RFA1 ( \
AVR8_PART_IS_DEFINED(ATmega128RFA1) \
)
/** ATmegaxxRFR2 group */
#define MEGA_RFR2 ( \
AVR8_PART_IS_DEFINED(ATmega64RFR2) || \
AVR8_PART_IS_DEFINED(ATmega128RFR2) || \
AVR8_PART_IS_DEFINED(ATmega256RFR2) || \
AVR8_PART_IS_DEFINED(ATmega644RFR2) || \
AVR8_PART_IS_DEFINED(ATmega1284RFR2) || \
AVR8_PART_IS_DEFINED(ATmega2564RFR2) \
)
/** ATmegaxxRFxx group */
#define MEGA_RF (MEGA_RFA1 || MEGA_RFR2)
/**
* \name ATmegaxx_un0/un1/un2 subgroups
* @{
*/
#define MEGA_XX_UN0 ( \
AVR8_PART_IS_DEFINED(ATmega16) || \
AVR8_PART_IS_DEFINED(ATmega16A) || \
AVR8_PART_IS_DEFINED(ATmega32) || \
AVR8_PART_IS_DEFINED(ATmega32A) \
)
/** ATmegaxx group without power reduction and
* And interrupt sense register.
*/
#define MEGA_XX_UN1 ( \
AVR8_PART_IS_DEFINED(ATmega64) || \
AVR8_PART_IS_DEFINED(ATmega64A) || \
AVR8_PART_IS_DEFINED(ATmega128) || \
AVR8_PART_IS_DEFINED(ATmega128A) \
)
/** ATmegaxx group without power reduction and
* And interrupt sense register.
*/
#define MEGA_XX_UN2 ( \
AVR8_PART_IS_DEFINED(ATmega169P) || \
AVR8_PART_IS_DEFINED(ATmega169PA) || \
AVR8_PART_IS_DEFINED(ATmega329P) || \
AVR8_PART_IS_DEFINED(ATmega329PA) \
)
/** Devices added to complete megaAVR offering.
* Please do not use this group symbol as it is not intended
* to be permanent: the devices should be regrouped.
*/
#define MEGA_UNCATEGORIZED ( \
AVR8_PART_IS_DEFINED(AT90CAN128) || \
AVR8_PART_IS_DEFINED(AT90CAN32) || \
AVR8_PART_IS_DEFINED(AT90CAN64) || \
AVR8_PART_IS_DEFINED(AT90PWM1) || \
AVR8_PART_IS_DEFINED(AT90PWM216) || \
AVR8_PART_IS_DEFINED(AT90PWM2B) || \
AVR8_PART_IS_DEFINED(AT90PWM316) || \
AVR8_PART_IS_DEFINED(AT90PWM3B) || \
AVR8_PART_IS_DEFINED(AT90PWM81) || \
AVR8_PART_IS_DEFINED(AT90USB1286) || \
AVR8_PART_IS_DEFINED(AT90USB1287) || \
AVR8_PART_IS_DEFINED(AT90USB162) || \
AVR8_PART_IS_DEFINED(AT90USB646) || \
AVR8_PART_IS_DEFINED(AT90USB647) || \
AVR8_PART_IS_DEFINED(AT90USB82) || \
AVR8_PART_IS_DEFINED(ATmega1284) || \
AVR8_PART_IS_DEFINED(ATmega162) || \
AVR8_PART_IS_DEFINED(ATmega164P) || \
AVR8_PART_IS_DEFINED(ATmega165A) || \
AVR8_PART_IS_DEFINED(ATmega165P) || \
AVR8_PART_IS_DEFINED(ATmega165PA) || \
AVR8_PART_IS_DEFINED(ATmega168P) || \
AVR8_PART_IS_DEFINED(ATmega169A) || \
AVR8_PART_IS_DEFINED(ATmega16M1) || \
AVR8_PART_IS_DEFINED(ATmega16U2) || \
AVR8_PART_IS_DEFINED(ATmega16U4) || \
AVR8_PART_IS_DEFINED(ATmega256RFA2) || \
AVR8_PART_IS_DEFINED(ATmega324P) || \
AVR8_PART_IS_DEFINED(ATmega325) || \
AVR8_PART_IS_DEFINED(ATmega3250) || \
AVR8_PART_IS_DEFINED(ATmega3250A) || \
AVR8_PART_IS_DEFINED(ATmega3250P) || \
AVR8_PART_IS_DEFINED(ATmega3250PA) || \
AVR8_PART_IS_DEFINED(ATmega325A) || \
AVR8_PART_IS_DEFINED(ATmega325P) || \
AVR8_PART_IS_DEFINED(ATmega325PA) || \
AVR8_PART_IS_DEFINED(ATmega329) || \
AVR8_PART_IS_DEFINED(ATmega3290) || \
AVR8_PART_IS_DEFINED(ATmega3290A) || \
AVR8_PART_IS_DEFINED(ATmega3290P) || \
AVR8_PART_IS_DEFINED(ATmega3290PA) || \
AVR8_PART_IS_DEFINED(ATmega329A) || \
AVR8_PART_IS_DEFINED(ATmega32M1) || \
AVR8_PART_IS_DEFINED(ATmega32U2) || \
AVR8_PART_IS_DEFINED(ATmega32U4) || \
AVR8_PART_IS_DEFINED(ATmega48P) || \
AVR8_PART_IS_DEFINED(ATmega644P) || \
AVR8_PART_IS_DEFINED(ATmega645) || \
AVR8_PART_IS_DEFINED(ATmega6450) || \
AVR8_PART_IS_DEFINED(ATmega6450A) || \
AVR8_PART_IS_DEFINED(ATmega6450P) || \
AVR8_PART_IS_DEFINED(ATmega645A) || \
AVR8_PART_IS_DEFINED(ATmega645P) || \
AVR8_PART_IS_DEFINED(ATmega649) || \
AVR8_PART_IS_DEFINED(ATmega6490) || \
AVR8_PART_IS_DEFINED(ATmega6490A) || \
AVR8_PART_IS_DEFINED(ATmega6490P) || \
AVR8_PART_IS_DEFINED(ATmega649A) || \
AVR8_PART_IS_DEFINED(ATmega649P) || \
AVR8_PART_IS_DEFINED(ATmega64M1) || \
AVR8_PART_IS_DEFINED(ATmega64RFA2) || \
AVR8_PART_IS_DEFINED(ATmega8) || \
AVR8_PART_IS_DEFINED(ATmega8515) || \
AVR8_PART_IS_DEFINED(ATmega8535) || \
AVR8_PART_IS_DEFINED(ATmega88P) || \
AVR8_PART_IS_DEFINED(ATmega8A) || \
AVR8_PART_IS_DEFINED(ATmega8U2) \
)
/** Unspecified group */
#define MEGA_UNSPECIFIED (MEGA_XX_UN0 || MEGA_XX_UN1 || MEGA_XX_UN2 || \
MEGA_UNCATEGORIZED)
/** @} */
/** megaAVR product line */
#define MEGA (MEGA_XX0_1 || MEGA_XX4 || MEGA_XX8 || MEGA_XX || MEGA_RF || \
MEGA_UNSPECIFIED)
/** @} */
/**
* \defgroup sam_part_macros_group SAM parts
* @{
*/
/**
* \name SAM3S series
* @{
*/
#define SAM3S1 ( \
SAM_PART_IS_DEFINED(SAM3S1A) || \
SAM_PART_IS_DEFINED(SAM3S1B) || \
SAM_PART_IS_DEFINED(SAM3S1C) \
)
#define SAM3S2 ( \
SAM_PART_IS_DEFINED(SAM3S2A) || \
SAM_PART_IS_DEFINED(SAM3S2B) || \
SAM_PART_IS_DEFINED(SAM3S2C) \
)
#define SAM3S4 ( \
SAM_PART_IS_DEFINED(SAM3S4A) || \
SAM_PART_IS_DEFINED(SAM3S4B) || \
SAM_PART_IS_DEFINED(SAM3S4C) \
)
#define SAM3S8 ( \
SAM_PART_IS_DEFINED(SAM3S8B) || \
SAM_PART_IS_DEFINED(SAM3S8C) \
)
#define SAM3SD8 ( \
SAM_PART_IS_DEFINED(SAM3SD8B) || \
SAM_PART_IS_DEFINED(SAM3SD8C) \
)
/** @} */
/**
* \name SAM3U series
* @{
*/
#define SAM3U1 ( \
SAM_PART_IS_DEFINED(SAM3U1C) || \
SAM_PART_IS_DEFINED(SAM3U1E) \
)
#define SAM3U2 ( \
SAM_PART_IS_DEFINED(SAM3U2C) || \
SAM_PART_IS_DEFINED(SAM3U2E) \
)
#define SAM3U4 ( \
SAM_PART_IS_DEFINED(SAM3U4C) || \
SAM_PART_IS_DEFINED(SAM3U4E) \
)
/** @} */
/**
* \name SAM3N series
* @{
*/
#define SAM3N00 ( \
SAM_PART_IS_DEFINED(SAM3N00A) || \
SAM_PART_IS_DEFINED(SAM3N00B) \
)
#define SAM3N0 ( \
SAM_PART_IS_DEFINED(SAM3N0A) || \
SAM_PART_IS_DEFINED(SAM3N0B) || \
SAM_PART_IS_DEFINED(SAM3N0C) \
)
#define SAM3N1 ( \
SAM_PART_IS_DEFINED(SAM3N1A) || \
SAM_PART_IS_DEFINED(SAM3N1B) || \
SAM_PART_IS_DEFINED(SAM3N1C) \
)
#define SAM3N2 ( \
SAM_PART_IS_DEFINED(SAM3N2A) || \
SAM_PART_IS_DEFINED(SAM3N2B) || \
SAM_PART_IS_DEFINED(SAM3N2C) \
)
#define SAM3N4 ( \
SAM_PART_IS_DEFINED(SAM3N4A) || \
SAM_PART_IS_DEFINED(SAM3N4B) || \
SAM_PART_IS_DEFINED(SAM3N4C) \
)
/** @} */
/**
* \name SAM3X series
* @{
*/
#define SAM3X4 ( \
SAM_PART_IS_DEFINED(SAM3X4C) || \
SAM_PART_IS_DEFINED(SAM3X4E) \
)
#define SAM3X8 ( \
SAM_PART_IS_DEFINED(SAM3X8C) || \
SAM_PART_IS_DEFINED(SAM3X8E) || \
SAM_PART_IS_DEFINED(SAM3X8H) \
)
/** @} */
/**
* \name SAM3A series
* @{
*/
#define SAM3A4 ( \
SAM_PART_IS_DEFINED(SAM3A4C) \
)
#define SAM3A8 ( \
SAM_PART_IS_DEFINED(SAM3A8C) \
)
/** @} */
/**
* \name SAM4S series
* @{
*/
#define SAM4S2 ( \
SAM_PART_IS_DEFINED(SAM4S2A) || \
SAM_PART_IS_DEFINED(SAM4S2B) || \
SAM_PART_IS_DEFINED(SAM4S2C) \
)
#define SAM4S4 ( \
SAM_PART_IS_DEFINED(SAM4S4A) || \
SAM_PART_IS_DEFINED(SAM4S4B) || \
SAM_PART_IS_DEFINED(SAM4S4C) \
)
#define SAM4S8 ( \
SAM_PART_IS_DEFINED(SAM4S8B) || \
SAM_PART_IS_DEFINED(SAM4S8C) \
)
#define SAM4S16 ( \
SAM_PART_IS_DEFINED(SAM4S16B) || \
SAM_PART_IS_DEFINED(SAM4S16C) \
)
#define SAM4SA16 ( \
SAM_PART_IS_DEFINED(SAM4SA16B) || \
SAM_PART_IS_DEFINED(SAM4SA16C) \
)
#define SAM4SD16 ( \
SAM_PART_IS_DEFINED(SAM4SD16B) || \
SAM_PART_IS_DEFINED(SAM4SD16C) \
)
#define SAM4SD32 ( \
SAM_PART_IS_DEFINED(SAM4SD32B) || \
SAM_PART_IS_DEFINED(SAM4SD32C) \
)
/** @} */
/**
* \name SAM4L series
* @{
*/
#define SAM4LS ( \
SAM_PART_IS_DEFINED(SAM4LS2A) || \
SAM_PART_IS_DEFINED(SAM4LS2B) || \
SAM_PART_IS_DEFINED(SAM4LS2C) || \
SAM_PART_IS_DEFINED(SAM4LS4A) || \
SAM_PART_IS_DEFINED(SAM4LS4B) || \
SAM_PART_IS_DEFINED(SAM4LS4C) || \
SAM_PART_IS_DEFINED(SAM4LS8A) || \
SAM_PART_IS_DEFINED(SAM4LS8B) || \
SAM_PART_IS_DEFINED(SAM4LS8C) \
)
#define SAM4LC ( \
SAM_PART_IS_DEFINED(SAM4LC2A) || \
SAM_PART_IS_DEFINED(SAM4LC2B) || \
SAM_PART_IS_DEFINED(SAM4LC2C) || \
SAM_PART_IS_DEFINED(SAM4LC4A) || \
SAM_PART_IS_DEFINED(SAM4LC4B) || \
SAM_PART_IS_DEFINED(SAM4LC4C) || \
SAM_PART_IS_DEFINED(SAM4LC8A) || \
SAM_PART_IS_DEFINED(SAM4LC8B) || \
SAM_PART_IS_DEFINED(SAM4LC8C) \
)
/** @} */
/**
* \name SAMD20 series
* @{
*/
#define SAMD20J ( \
SAM_PART_IS_DEFINED(SAMD20J14) || \
SAM_PART_IS_DEFINED(SAMD20J15) || \
SAM_PART_IS_DEFINED(SAMD20J16) || \
SAM_PART_IS_DEFINED(SAMD20J17) || \
SAM_PART_IS_DEFINED(SAMD20J18) \
)
#define SAMD20G ( \
SAM_PART_IS_DEFINED(SAMD20G14) || \
SAM_PART_IS_DEFINED(SAMD20G15) || \
SAM_PART_IS_DEFINED(SAMD20G16) || \
SAM_PART_IS_DEFINED(SAMD20G17) || \
SAM_PART_IS_DEFINED(SAMD20G17U) || \
SAM_PART_IS_DEFINED(SAMD20G18) || \
SAM_PART_IS_DEFINED(SAMD20G18U) \
)
#define SAMD20E ( \
SAM_PART_IS_DEFINED(SAMD20E14) || \
SAM_PART_IS_DEFINED(SAMD20E15) || \
SAM_PART_IS_DEFINED(SAMD20E16) || \
SAM_PART_IS_DEFINED(SAMD20E17) || \
SAM_PART_IS_DEFINED(SAMD20E18) \
)
/** @} */
/**
* \name SAMD21 series
* @{
*/
#define SAMD21J ( \
SAM_PART_IS_DEFINED(SAMD21J15A) || \
SAM_PART_IS_DEFINED(SAMD21J16A) || \
SAM_PART_IS_DEFINED(SAMD21J17A) || \
SAM_PART_IS_DEFINED(SAMD21J18A) || \
SAM_PART_IS_DEFINED(SAMD21J15B) || \
SAM_PART_IS_DEFINED(SAMD21J16B) \
)
#define SAMD21G ( \
SAM_PART_IS_DEFINED(SAMD21G15A) || \
SAM_PART_IS_DEFINED(SAMD21G16A) || \
SAM_PART_IS_DEFINED(SAMD21G17A) || \
SAM_PART_IS_DEFINED(SAMD21G17AU) || \
SAM_PART_IS_DEFINED(SAMD21G18A) || \
SAM_PART_IS_DEFINED(SAMD21G18AU) || \
SAM_PART_IS_DEFINED(SAMD21G15B) || \
SAM_PART_IS_DEFINED(SAMD21G16B) || \
SAM_PART_IS_DEFINED(SAMD21G15L) || \
SAM_PART_IS_DEFINED(SAMD21G16L) \
)
#define SAMD21GXXL ( \
SAM_PART_IS_DEFINED(SAMD21G15L) || \
SAM_PART_IS_DEFINED(SAMD21G16L) \
)
#define SAMD21E ( \
SAM_PART_IS_DEFINED(SAMD21E15A) || \
SAM_PART_IS_DEFINED(SAMD21E16A) || \
SAM_PART_IS_DEFINED(SAMD21E17A) || \
SAM_PART_IS_DEFINED(SAMD21E18A) || \
SAM_PART_IS_DEFINED(SAMD21E15B) || \
SAM_PART_IS_DEFINED(SAMD21E15BU) || \
SAM_PART_IS_DEFINED(SAMD21E16B) || \
SAM_PART_IS_DEFINED(SAMD21E16BU) || \
SAM_PART_IS_DEFINED(SAMD21E15L) || \
SAM_PART_IS_DEFINED(SAMD21E16L) \
)
#define SAMD21EXXL ( \
SAM_PART_IS_DEFINED(SAMD21E15L) || \
SAM_PART_IS_DEFINED(SAMD21E16L) \
)
/** @} */
/**
* \name SAMR21 series
* @{
*/
#define SAMR21G ( \
SAM_PART_IS_DEFINED(SAMR21G16A) || \
SAM_PART_IS_DEFINED(SAMR21G17A) || \
SAM_PART_IS_DEFINED(SAMR21G18A) \
)
#define SAMR21E ( \
SAM_PART_IS_DEFINED(SAMR21E16A) || \
SAM_PART_IS_DEFINED(SAMR21E17A) || \
SAM_PART_IS_DEFINED(SAMR21E18A) || \
SAM_PART_IS_DEFINED(SAMR21E19A) \
)
/** @} */
/**
* \name SAMR30 series
* @{
*/
#define SAMR30G ( \
SAM_PART_IS_DEFINED(SAMR30G18A) \
)
#define SAMR30E ( \
SAM_PART_IS_DEFINED(SAMR30E18A) \
)
/** @} */
/**
* \name SAMB11 series
* @{
*/
#define SAMB11G ( \
SAM_PART_IS_DEFINED(SAMB11G18A) || \
SAM_PART_IS_DEFINED(SAMB11ZR) \
)
#define BTLC1000 ( \
SAM_PART_IS_DEFINED(BTLC1000WLCSP) \
)
/** @} */
/**
* \name SAMD09 series
* @{
*/
#define SAMD09C ( \
SAM_PART_IS_DEFINED(SAMD09C13A) \
)
#define SAMD09D ( \
SAM_PART_IS_DEFINED(SAMD09D14A) \
)
/** @} */
/**
* \name SAMD10 series
* @{
*/
#define SAMD10C ( \
SAM_PART_IS_DEFINED(SAMD10C12A) || \
SAM_PART_IS_DEFINED(SAMD10C13A) || \
SAM_PART_IS_DEFINED(SAMD10C14A) \
)
#define SAMD10DS ( \
SAM_PART_IS_DEFINED(SAMD10D12AS) || \
SAM_PART_IS_DEFINED(SAMD10D13AS) || \
SAM_PART_IS_DEFINED(SAMD10D14AS) \
)
#define SAMD10DM ( \
SAM_PART_IS_DEFINED(SAMD10D12AM) || \
SAM_PART_IS_DEFINED(SAMD10D13AM) || \
SAM_PART_IS_DEFINED(SAMD10D14AM) \
)
#define SAMD10DU ( \
SAM_PART_IS_DEFINED(SAMD10D14AU) \
)
/** @} */
/**
* \name SAMD11 series
* @{
*/
#define SAMD11C ( \
SAM_PART_IS_DEFINED(SAMD11C14A) \
)
#define SAMD11DS ( \
SAM_PART_IS_DEFINED(SAMD11D14AS) \
)
#define SAMD11DM ( \
SAM_PART_IS_DEFINED(SAMD11D14AM) \
)
#define SAMD11DU ( \
SAM_PART_IS_DEFINED(SAMD11D14AU) \
)
/** @} */
/**
* \name SAML21 series
* @{
*/
#define SAML21E ( \
SAM_PART_IS_DEFINED(SAML21E18A) || \
SAM_PART_IS_DEFINED(SAML21E15B) || \
SAM_PART_IS_DEFINED(SAML21E16B) || \
SAM_PART_IS_DEFINED(SAML21E17B) || \
SAM_PART_IS_DEFINED(SAML21E18B) \
)
#define SAML21G ( \
SAM_PART_IS_DEFINED(SAML21G18A) || \
SAM_PART_IS_DEFINED(SAML21G16B) || \
SAM_PART_IS_DEFINED(SAML21G17B) || \
SAM_PART_IS_DEFINED(SAML21G18B) \
)
#define SAML21J ( \
SAM_PART_IS_DEFINED(SAML21J18A) || \
SAM_PART_IS_DEFINED(SAML21J16B) || \
SAM_PART_IS_DEFINED(SAML21J17B) || \
SAM_PART_IS_DEFINED(SAML21J18B) \
)
/* Group for SAML21 A variant: SAML21[E/G/J][18]A */
#define SAML21XXXA ( \
SAM_PART_IS_DEFINED(SAML21E18A) || \
SAM_PART_IS_DEFINED(SAML21G18A) || \
SAM_PART_IS_DEFINED(SAML21J18A) \
)
/* Group for SAML21 B variant: SAML21[E/G/J][15/16/1718]B */
#define SAML21XXXB ( \
SAM_PART_IS_DEFINED(SAML21E15B) || \
SAM_PART_IS_DEFINED(SAML21E16B) || \
SAM_PART_IS_DEFINED(SAML21E17B) || \
SAM_PART_IS_DEFINED(SAML21E18B) || \
SAM_PART_IS_DEFINED(SAML21G16B) || \
SAM_PART_IS_DEFINED(SAML21G17B) || \
SAM_PART_IS_DEFINED(SAML21G18B) || \
SAM_PART_IS_DEFINED(SAML21J16B) || \
SAM_PART_IS_DEFINED(SAML21J17B) || \
SAM_PART_IS_DEFINED(SAML21J18B) \
)
/** @} */
/**
* \name SAML22 series
* @{
*/
#define SAML22N ( \
SAM_PART_IS_DEFINED(SAML22N16A) || \
SAM_PART_IS_DEFINED(SAML22N17A) || \
SAM_PART_IS_DEFINED(SAML22N18A) \
)
#define SAML22G ( \
SAM_PART_IS_DEFINED(SAML22G16A) || \
SAM_PART_IS_DEFINED(SAML22G17A) || \
SAM_PART_IS_DEFINED(SAML22G18A) \
)
#define SAML22J ( \
SAM_PART_IS_DEFINED(SAML22J16A) || \
SAM_PART_IS_DEFINED(SAML22J17A) || \
SAM_PART_IS_DEFINED(SAML22J18A) \
)
/** @} */
/**
* \name SAMDA1 series
* @{
*/
#define SAMDA1J ( \
SAM_PART_IS_DEFINED(SAMDA1J14A) || \
SAM_PART_IS_DEFINED(SAMDA1J15B) || \
SAM_PART_IS_DEFINED(SAMDA1J15A) || \
SAM_PART_IS_DEFINED(SAMDA1J15B) || \
SAM_PART_IS_DEFINED(SAMDA1J16A) || \
SAM_PART_IS_DEFINED(SAMDA1J16B) \
)
#define SAMDA1G ( \
SAM_PART_IS_DEFINED(SAMDA1G14A) || \
SAM_PART_IS_DEFINED(SAMDA1G14B) || \
SAM_PART_IS_DEFINED(SAMDA1G15A) || \
SAM_PART_IS_DEFINED(SAMDA1G15B) || \
SAM_PART_IS_DEFINED(SAMDA1G16A) || \
SAM_PART_IS_DEFINED(SAMDA1G16B) \
)
#define SAMDA1E ( \
SAM_PART_IS_DEFINED(SAMDA1E14A) || \
SAM_PART_IS_DEFINED(SAMDA1E14B) || \
SAM_PART_IS_DEFINED(SAMDA1E15A) || \
SAM_PART_IS_DEFINED(SAMDA1E15B) || \
SAM_PART_IS_DEFINED(SAMDA1E16A) || \
SAM_PART_IS_DEFINED(SAMDA1E16B) \
)
/** @} */
/**
* \name SAMHA1 series
* @{
*/
#define SAMHA1G ( \
SAM_PART_IS_DEFINED(SAMHA1G14A) || \
SAM_PART_IS_DEFINED(SAMHA1G15A) || \
SAM_PART_IS_DEFINED(SAMHA1G16A) \
)
/** @} */
/**
* \name SAMC20 series
* @{
*/
#define SAMC20E ( \
SAM_PART_IS_DEFINED(SAMC20E15A) || \
SAM_PART_IS_DEFINED(SAMC20E16A) || \
SAM_PART_IS_DEFINED(SAMC20E17A) || \
SAM_PART_IS_DEFINED(SAMC20E18A) \
)
#define SAMC20G ( \
SAM_PART_IS_DEFINED(SAMC20G15A) || \
SAM_PART_IS_DEFINED(SAMC20G16A) || \
SAM_PART_IS_DEFINED(SAMC20G17A) || \
SAM_PART_IS_DEFINED(SAMC20G18A) \
)
#define SAMC20J ( \
SAM_PART_IS_DEFINED(SAMC20J15A) || \
SAM_PART_IS_DEFINED(SAMC20J16A) || \
SAM_PART_IS_DEFINED(SAMC20J17A) || \
SAM_PART_IS_DEFINED(SAMC20J18A) \
)
/** @} */
/**
* \name SAMC21 series
* @{
*/
#define SAMC21E ( \
SAM_PART_IS_DEFINED(SAMC21E15A) || \
SAM_PART_IS_DEFINED(SAMC21E16A) || \
SAM_PART_IS_DEFINED(SAMC21E17A) || \
SAM_PART_IS_DEFINED(SAMC21E18A) \
)
#define SAMC21G ( \
SAM_PART_IS_DEFINED(SAMC21G15A) || \
SAM_PART_IS_DEFINED(SAMC21G16A) || \
SAM_PART_IS_DEFINED(SAMC21G17A) || \
SAM_PART_IS_DEFINED(SAMC21G18A) \
)
#define SAMC21J ( \
SAM_PART_IS_DEFINED(SAMC21J15A) || \
SAM_PART_IS_DEFINED(SAMC21J16A) || \
SAM_PART_IS_DEFINED(SAMC21J17A) || \
SAM_PART_IS_DEFINED(SAMC21J18A) \
)
/** @} */
/**
* \name SAM4E series
* @{
*/
#define SAM4E8 ( \
SAM_PART_IS_DEFINED(SAM4E8C) || \
SAM_PART_IS_DEFINED(SAM4E8CB) || \
SAM_PART_IS_DEFINED(SAM4E8E) \
)
#define SAM4E16 ( \
SAM_PART_IS_DEFINED(SAM4E16C) || \
SAM_PART_IS_DEFINED(SAM4E16CB) || \
SAM_PART_IS_DEFINED(SAM4E16E) \
)
/** @} */
/**
* \name SAM4N series
* @{
*/
#define SAM4N8 ( \
SAM_PART_IS_DEFINED(SAM4N8A) || \
SAM_PART_IS_DEFINED(SAM4N8B) || \
SAM_PART_IS_DEFINED(SAM4N8C) \
)
#define SAM4N16 ( \
SAM_PART_IS_DEFINED(SAM4N16B) || \
SAM_PART_IS_DEFINED(SAM4N16C) \
)
/** @} */
/**
* \name SAM4C series
* @{
*/
#define SAM4C4_0 ( \
SAM_PART_IS_DEFINED(SAM4C4C_0) \
)
#define SAM4C4_1 ( \
SAM_PART_IS_DEFINED(SAM4C4C_1) \
)
#define SAM4C4 (SAM4C4_0 || SAM4C4_1)
#define SAM4C8_0 ( \
SAM_PART_IS_DEFINED(SAM4C8C_0) \
)
#define SAM4C8_1 ( \
SAM_PART_IS_DEFINED(SAM4C8C_1) \
)
#define SAM4C8 (SAM4C8_0 || SAM4C8_1)
#define SAM4C16_0 ( \
SAM_PART_IS_DEFINED(SAM4C16C_0) \
)
#define SAM4C16_1 ( \
SAM_PART_IS_DEFINED(SAM4C16C_1) \
)
#define SAM4C16 (SAM4C16_0 || SAM4C16_1)
#define SAM4C32_0 ( \
SAM_PART_IS_DEFINED(SAM4C32C_0) ||\
SAM_PART_IS_DEFINED(SAM4C32E_0) \
)
#define SAM4C32_1 ( \
SAM_PART_IS_DEFINED(SAM4C32C_1) ||\
SAM_PART_IS_DEFINED(SAM4C32E_1) \
)
#define SAM4C32 (SAM4C32_0 || SAM4C32_1)
/** @} */
/**
* \name SAM4CM series
* @{
*/
#define SAM4CMP8_0 ( \
SAM_PART_IS_DEFINED(SAM4CMP8C_0) \
)
#define SAM4CMP8_1 ( \
SAM_PART_IS_DEFINED(SAM4CMP8C_1) \
)
#define SAM4CMP8 (SAM4CMP8_0 || SAM4CMP8_1)
#define SAM4CMP16_0 ( \
SAM_PART_IS_DEFINED(SAM4CMP16C_0) \
)
#define SAM4CMP16_1 ( \
SAM_PART_IS_DEFINED(SAM4CMP16C_1) \
)
#define SAM4CMP16 (SAM4CMP16_0 || SAM4CMP16_1)
#define SAM4CMP32_0 ( \
SAM_PART_IS_DEFINED(SAM4CMP32C_0) \
)
#define SAM4CMP32_1 ( \
SAM_PART_IS_DEFINED(SAM4CMP32C_1) \
)
#define SAM4CMP32 (SAM4CMP32_0 || SAM4CMP32_1)
#define SAM4CMS4_0 ( \
SAM_PART_IS_DEFINED(SAM4CMS4C_0) \
)
#define SAM4CMS4_1 ( \
SAM_PART_IS_DEFINED(SAM4CMS4C_1) \
)
#define SAM4CMS4 (SAM4CMS4_0 || SAM4CMS4_1)
#define SAM4CMS8_0 ( \
SAM_PART_IS_DEFINED(SAM4CMS8C_0) \
)
#define SAM4CMS8_1 ( \
SAM_PART_IS_DEFINED(SAM4CMS8C_1) \
)
#define SAM4CMS8 (SAM4CMS8_0 || SAM4CMS8_1)
#define SAM4CMS16_0 ( \
SAM_PART_IS_DEFINED(SAM4CMS16C_0) \
)
#define SAM4CMS16_1 ( \
SAM_PART_IS_DEFINED(SAM4CMS16C_1) \
)
#define SAM4CMS16 (SAM4CMS16_0 || SAM4CMS16_1)
#define SAM4CMS32_0 ( \
SAM_PART_IS_DEFINED(SAM4CMS32C_0) \
)
#define SAM4CMS32_1 ( \
SAM_PART_IS_DEFINED(SAM4CMS32C_1) \
)
#define SAM4CMS32 (SAM4CMS32_0 || SAM4CMS32_1)
/** @} */
/**
* \name SAM4CP series
* @{
*/
#define SAM4CP16_0 ( \
SAM_PART_IS_DEFINED(SAM4CP16B_0) \
)
#define SAM4CP16_1 ( \
SAM_PART_IS_DEFINED(SAM4CP16B_1) \
)
#define SAM4CP16 (SAM4CP16_0 || SAM4CP16_1)
/** @} */
/**
* \name SAMG series
* @{
*/
#define SAMG51 ( \
SAM_PART_IS_DEFINED(SAMG51G18) \
)
#define SAMG53 ( \
SAM_PART_IS_DEFINED(SAMG53G19) ||\
SAM_PART_IS_DEFINED(SAMG53N19) \
)
#define SAMG54 ( \
SAM_PART_IS_DEFINED(SAMG54G19) ||\
SAM_PART_IS_DEFINED(SAMG54J19) ||\
SAM_PART_IS_DEFINED(SAMG54N19) \
)
#define SAMG55 ( \
SAM_PART_IS_DEFINED(SAMG55G18) ||\
SAM_PART_IS_DEFINED(SAMG55G19) ||\
SAM_PART_IS_DEFINED(SAMG55J18) ||\
SAM_PART_IS_DEFINED(SAMG55J19) ||\
SAM_PART_IS_DEFINED(SAMG55N19) \
)
/** @} */
/**
* \name SAMV71 series
* @{
*/
#define SAMV71J ( \
SAM_PART_IS_DEFINED(SAMV71J19) || \
SAM_PART_IS_DEFINED(SAMV71J20) || \
SAM_PART_IS_DEFINED(SAMV71J21) \
)
#define SAMV71N ( \
SAM_PART_IS_DEFINED(SAMV71N19) || \
SAM_PART_IS_DEFINED(SAMV71N20) || \
SAM_PART_IS_DEFINED(SAMV71N21) \
)
#define SAMV71Q ( \
SAM_PART_IS_DEFINED(SAMV71Q19) || \
SAM_PART_IS_DEFINED(SAMV71Q20) || \
SAM_PART_IS_DEFINED(SAMV71Q21) \
)
/** @} */
/**
* \name SAMV70 series
* @{
*/
#define SAMV70J ( \
SAM_PART_IS_DEFINED(SAMV70J19) || \
SAM_PART_IS_DEFINED(SAMV70J20) \
)
#define SAMV70N ( \
SAM_PART_IS_DEFINED(SAMV70N19) || \
SAM_PART_IS_DEFINED(SAMV70N20) \
)
#define SAMV70Q ( \
SAM_PART_IS_DEFINED(SAMV70Q19) || \
SAM_PART_IS_DEFINED(SAMV70Q20) \
)
/** @} */
/**
* \name SAMS70 series
* @{
*/
#define SAMS70J ( \
SAM_PART_IS_DEFINED(SAMS70J19) || \
SAM_PART_IS_DEFINED(SAMS70J20) || \
SAM_PART_IS_DEFINED(SAMS70J21) \
)
#define SAMS70N ( \
SAM_PART_IS_DEFINED(SAMS70N19) || \
SAM_PART_IS_DEFINED(SAMS70N20) || \
SAM_PART_IS_DEFINED(SAMS70N21) \
)
#define SAMS70Q ( \
SAM_PART_IS_DEFINED(SAMS70Q19) || \
SAM_PART_IS_DEFINED(SAMS70Q20) || \
SAM_PART_IS_DEFINED(SAMS70Q21) \
)
/** @} */
/**
* \name SAME70 series
* @{
*/
#define SAME70J ( \
SAM_PART_IS_DEFINED(SAME70J19) || \
SAM_PART_IS_DEFINED(SAME70J20) || \
SAM_PART_IS_DEFINED(SAME70J21) \
)
#define SAME70N ( \
SAM_PART_IS_DEFINED(SAME70N19) || \
SAM_PART_IS_DEFINED(SAME70N20) || \
SAM_PART_IS_DEFINED(SAME70N21) \
)
#define SAME70Q ( \
SAM_PART_IS_DEFINED(SAME70Q19) || \
SAM_PART_IS_DEFINED(SAME70Q20) || \
SAM_PART_IS_DEFINED(SAME70Q21) \
)
/** @} */
/**
* \name SAM families
* @{
*/
/** SAM3S Family */
#define SAM3S (SAM3S1 || SAM3S2 || SAM3S4 || SAM3S8 || SAM3SD8)
/** SAM3U Family */
#define SAM3U (SAM3U1 || SAM3U2 || SAM3U4)
/** SAM3N Family */
#define SAM3N (SAM3N00 || SAM3N0 || SAM3N1 || SAM3N2 || SAM3N4)
/** SAM3XA Family */
#define SAM3XA (SAM3X4 || SAM3X8 || SAM3A4 || SAM3A8)
/** SAM4S Family */
#define SAM4S (SAM4S2 || SAM4S4 || SAM4S8 || SAM4S16 || SAM4SA16 || SAM4SD16 || SAM4SD32)
/** SAM4L Family */
#define SAM4L (SAM4LS || SAM4LC)
/** SAMD20 Family */
#define SAMD20 (SAMD20J || SAMD20G || SAMD20E)
/** SAMD21 Family */
#define SAMD21 (SAMD21J || SAMD21G || SAMD21E)
/** SAMD09 Family */
#define SAMD09 (SAMD09C || SAMD09D)
/** SAMD10 Family */
#define SAMD10 (SAMD10C || SAMD10DS || SAMD10DM || SAMD10DU)
/** SAMD11 Family */
#define SAMD11 (SAMD11C || SAMD11DS || SAMD11DM || SAMD11DU)
/** SAMDA1 Family */
#define SAMDA1 (SAMDA1J || SAMDA1G || SAMDA1E)
/** SAMHA1 Family */
#define SAMHA1 (SAMHA1G)
/** SAMD Family */
#define SAMD (SAMD20 || SAMD21 || SAMD09 || SAMD10 || SAMD11 || SAMDA1)
/** SAMR21 Family */
#define SAMR21 (SAMR21G || SAMR21E)
/** SAMR30 Family */
#define SAMR30 (SAMR30G || SAMR30E)
/** SAMB11 Family */
#define SAMB11 (SAMB11G || BTLC1000)
/** SAML21 Family */
#define SAML21 (SAML21J || SAML21G || SAML21E)
/** SAML22 Family */
#define SAML22 (SAML22J || SAML22G || SAML22N)
/** SAMC20 Family */
#define SAMC20 (SAMC20J || SAMC20G || SAMC20E)
/** SAMC21 Family */
#define SAMC21 (SAMC21J || SAMC21G || SAMC21E)
/** SAM4E Family */
#define SAM4E (SAM4E8 || SAM4E16)
/** SAM4N Family */
#define SAM4N (SAM4N8 || SAM4N16)
/** SAM4C Family */
#define SAM4C_0 (SAM4C4_0 || SAM4C8_0 || SAM4C16_0 || SAM4C32_0)
#define SAM4C_1 (SAM4C4_1 || SAM4C8_1 || SAM4C16_1 || SAM4C32_1)
#define SAM4C (SAM4C4 || SAM4C8 || SAM4C16 || SAM4C32)
/** SAM4CM Family */
#define SAM4CM_0 (SAM4CMP8_0 || SAM4CMP16_0 || SAM4CMP32_0 || \
SAM4CMS4_0 || SAM4CMS8_0 || SAM4CMS16_0 || SAM4CMS32_0)
#define SAM4CM_1 (SAM4CMP8_1 || SAM4CMP16_1 || SAM4CMP32_1 || \
SAM4CMS4_1 || SAM4CMS8_1 || SAM4CMS16_1 || SAM4CMS32_1)
#define SAM4CM (SAM4CMP8 || SAM4CMP16 || SAM4CMP32 || \
SAM4CMS4 || SAM4CMS8 || SAM4CMS16 || SAM4CMS32)
/** SAM4CP Family */
#define SAM4CP_0 (SAM4CP16_0)
#define SAM4CP_1 (SAM4CP16_1)
#define SAM4CP (SAM4CP16)
/** SAMG Family */
#define SAMG (SAMG51 || SAMG53 || SAMG54 || SAMG55)
/** SAMB Family */
#define SAMB (SAMB11)
/** SAMV71 Family */
#define SAMV71 (SAMV71J || SAMV71N || SAMV71Q)
/** SAMV70 Family */
#define SAMV70 (SAMV70J || SAMV70N || SAMV70Q)
/** SAME70 Family */
#define SAME70 (SAME70J || SAME70N || SAME70Q)
/** SAMS70 Family */
#define SAMS70 (SAMS70J || SAMS70N || SAMS70Q)
/** SAM0 product line (cortex-m0+) */
#define SAM0 (SAMD20 || SAMD21 || SAMR21 || SAMD10 || SAMD11 || SAML21 ||\
SAMDA1 || SAMC20 || SAMC21 || SAML22 || SAMD09 || SAMR30 || SAMHA1)
/** @} */
/** SAM product line */
#define SAM (SAM3S || SAM3U || SAM3N || SAM3XA || SAM4S || SAM4L || SAM4E || \
SAM0 || SAM4N || SAM4C || SAM4CM || SAM4CP || SAMG || SAMV71 || SAMV70 || SAME70 || SAMS70)
/** @} */
/** @} */
/** @} */
#endif /* ATMEL_PARTS_H */