Files
firmware-test/modules/nrfx/mdk/nrf51_erratas.h
Charles Kwon a8ba31871e Initial commit: MT firmware project
- BLE peripheral applications
- dr_piezo and bladder_patch projects

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-25 17:26:39 +09:00

4737 lines
164 KiB
C

#ifndef NRF51_ERRATAS_H
#define NRF51_ERRATAS_H
/*
Copyright (c) 2010 - 2021, Nordic Semiconductor ASA
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, except as embedded into a Nordic
Semiconductor ASA integrated circuit in a product or a software update for
such product, 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 Nordic Semiconductor ASA nor the names of its
contributors may be used to endorse or promote products derived from this
software without specific prior written permission.
4. This software, with or without modification, must only be used with a
Nordic Semiconductor ASA integrated circuit.
5. Any software provided in binary form under this license must not be reverse
engineered, decompiled, modified and/or disassembled.
THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS
OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA 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.
*/
#include <stdint.h>
#include <stdbool.h>
#include "compiler_abstraction.h"
static bool nrf51_errata_1(void) __UNUSED;
static bool nrf51_errata_2(void) __UNUSED;
static bool nrf51_errata_3(void) __UNUSED;
static bool nrf51_errata_4(void) __UNUSED;
static bool nrf51_errata_5(void) __UNUSED;
static bool nrf51_errata_6(void) __UNUSED;
static bool nrf51_errata_7(void) __UNUSED;
static bool nrf51_errata_8(void) __UNUSED;
static bool nrf51_errata_9(void) __UNUSED;
static bool nrf51_errata_10(void) __UNUSED;
static bool nrf51_errata_11(void) __UNUSED;
static bool nrf51_errata_12(void) __UNUSED;
static bool nrf51_errata_13(void) __UNUSED;
static bool nrf51_errata_14(void) __UNUSED;
static bool nrf51_errata_15(void) __UNUSED;
static bool nrf51_errata_16(void) __UNUSED;
static bool nrf51_errata_17(void) __UNUSED;
static bool nrf51_errata_18(void) __UNUSED;
static bool nrf51_errata_19(void) __UNUSED;
static bool nrf51_errata_20(void) __UNUSED;
static bool nrf51_errata_21(void) __UNUSED;
static bool nrf51_errata_22(void) __UNUSED;
static bool nrf51_errata_23(void) __UNUSED;
static bool nrf51_errata_24(void) __UNUSED;
static bool nrf51_errata_25(void) __UNUSED;
static bool nrf51_errata_26(void) __UNUSED;
static bool nrf51_errata_27(void) __UNUSED;
static bool nrf51_errata_28(void) __UNUSED;
static bool nrf51_errata_29(void) __UNUSED;
static bool nrf51_errata_30(void) __UNUSED;
static bool nrf51_errata_31(void) __UNUSED;
static bool nrf51_errata_32(void) __UNUSED;
static bool nrf51_errata_33(void) __UNUSED;
static bool nrf51_errata_34(void) __UNUSED;
static bool nrf51_errata_35(void) __UNUSED;
static bool nrf51_errata_36(void) __UNUSED;
static bool nrf51_errata_37(void) __UNUSED;
static bool nrf51_errata_38(void) __UNUSED;
static bool nrf51_errata_39(void) __UNUSED;
static bool nrf51_errata_40(void) __UNUSED;
static bool nrf51_errata_41(void) __UNUSED;
static bool nrf51_errata_42(void) __UNUSED;
static bool nrf51_errata_43(void) __UNUSED;
static bool nrf51_errata_44(void) __UNUSED;
static bool nrf51_errata_45(void) __UNUSED;
static bool nrf51_errata_46(void) __UNUSED;
static bool nrf51_errata_47(void) __UNUSED;
static bool nrf51_errata_48(void) __UNUSED;
static bool nrf51_errata_49(void) __UNUSED;
static bool nrf51_errata_50(void) __UNUSED;
static bool nrf51_errata_51(void) __UNUSED;
static bool nrf51_errata_52(void) __UNUSED;
static bool nrf51_errata_53(void) __UNUSED;
static bool nrf51_errata_54(void) __UNUSED;
static bool nrf51_errata_55(void) __UNUSED;
static bool nrf51_errata_56(void) __UNUSED;
static bool nrf51_errata_57(void) __UNUSED;
static bool nrf51_errata_58(void) __UNUSED;
static bool nrf51_errata_59(void) __UNUSED;
static bool nrf51_errata_60(void) __UNUSED;
static bool nrf51_errata_61(void) __UNUSED;
static bool nrf51_errata_62(void) __UNUSED;
static bool nrf51_errata_63(void) __UNUSED;
static bool nrf51_errata_64(void) __UNUSED;
static bool nrf51_errata_65(void) __UNUSED;
static bool nrf51_errata_66(void) __UNUSED;
static bool nrf51_errata_67(void) __UNUSED;
static bool nrf51_errata_68(void) __UNUSED;
static bool nrf51_errata_69(void) __UNUSED;
static bool nrf51_errata_70(void) __UNUSED;
static bool nrf51_errata_71(void) __UNUSED;
static bool nrf51_errata_72(void) __UNUSED;
static bool nrf51_errata_73(void) __UNUSED;
static bool nrf51_errata_74(void) __UNUSED;
static bool nrf51_errata_75(void) __UNUSED;
static bool nrf51_errata_76(void) __UNUSED;
static bool nrf51_errata_77(void) __UNUSED;
static bool nrf51_errata_78(void) __UNUSED;
/* ========= Errata 1 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_1_PRESENT 1
#else
#define NRF51_ERRATA_1_PRESENT 0
#endif
#ifndef NRF51_ERRATA_1_ENABLE_WORKAROUND
#define NRF51_ERRATA_1_ENABLE_WORKAROUND NRF51_ERRATA_1_PRESENT
#endif
static bool nrf51_errata_1(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 2 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_2_PRESENT 1
#else
#define NRF51_ERRATA_2_PRESENT 0
#endif
#ifndef NRF51_ERRATA_2_ENABLE_WORKAROUND
#define NRF51_ERRATA_2_ENABLE_WORKAROUND NRF51_ERRATA_2_PRESENT
#endif
static bool nrf51_errata_2(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 3 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_3_PRESENT 1
#else
#define NRF51_ERRATA_3_PRESENT 0
#endif
#ifndef NRF51_ERRATA_3_ENABLE_WORKAROUND
#define NRF51_ERRATA_3_ENABLE_WORKAROUND NRF51_ERRATA_3_PRESENT
#endif
static bool nrf51_errata_3(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 4 ========= */
#define NRF51_ERRATA_4_PRESENT 0
#ifndef NRF51_ERRATA_4_ENABLE_WORKAROUND
#define NRF51_ERRATA_4_ENABLE_WORKAROUND NRF51_ERRATA_4_PRESENT
#endif
static bool nrf51_errata_4(void)
{
#ifndef NRF51_SERIES
return false;
#else
return false;
#endif
}
/* ========= Errata 5 ========= */
#define NRF51_ERRATA_5_PRESENT 0
#ifndef NRF51_ERRATA_5_ENABLE_WORKAROUND
#define NRF51_ERRATA_5_ENABLE_WORKAROUND NRF51_ERRATA_5_PRESENT
#endif
static bool nrf51_errata_5(void)
{
#ifndef NRF51_SERIES
return false;
#else
return false;
#endif
}
/* ========= Errata 6 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_6_PRESENT 1
#else
#define NRF51_ERRATA_6_PRESENT 0
#endif
#ifndef NRF51_ERRATA_6_ENABLE_WORKAROUND
#define NRF51_ERRATA_6_ENABLE_WORKAROUND NRF51_ERRATA_6_PRESENT
#endif
static bool nrf51_errata_6(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 7 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_7_PRESENT 1
#else
#define NRF51_ERRATA_7_PRESENT 0
#endif
#ifndef NRF51_ERRATA_7_ENABLE_WORKAROUND
#define NRF51_ERRATA_7_ENABLE_WORKAROUND NRF51_ERRATA_7_PRESENT
#endif
static bool nrf51_errata_7(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 8 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_8_PRESENT 1
#else
#define NRF51_ERRATA_8_PRESENT 0
#endif
#ifndef NRF51_ERRATA_8_ENABLE_WORKAROUND
#define NRF51_ERRATA_8_ENABLE_WORKAROUND NRF51_ERRATA_8_PRESENT
#endif
static bool nrf51_errata_8(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 9 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_9_PRESENT 1
#else
#define NRF51_ERRATA_9_PRESENT 0
#endif
#ifndef NRF51_ERRATA_9_ENABLE_WORKAROUND
#define NRF51_ERRATA_9_ENABLE_WORKAROUND NRF51_ERRATA_9_PRESENT
#endif
static bool nrf51_errata_9(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 10 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_10_PRESENT 1
#else
#define NRF51_ERRATA_10_PRESENT 0
#endif
#ifndef NRF51_ERRATA_10_ENABLE_WORKAROUND
#define NRF51_ERRATA_10_ENABLE_WORKAROUND NRF51_ERRATA_10_PRESENT
#endif
static bool nrf51_errata_10(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 11 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_11_PRESENT 1
#else
#define NRF51_ERRATA_11_PRESENT 0
#endif
#ifndef NRF51_ERRATA_11_ENABLE_WORKAROUND
#define NRF51_ERRATA_11_ENABLE_WORKAROUND NRF51_ERRATA_11_PRESENT
#endif
static bool nrf51_errata_11(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 12 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_12_PRESENT 1
#else
#define NRF51_ERRATA_12_PRESENT 0
#endif
#ifndef NRF51_ERRATA_12_ENABLE_WORKAROUND
#define NRF51_ERRATA_12_ENABLE_WORKAROUND NRF51_ERRATA_12_PRESENT
#endif
static bool nrf51_errata_12(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 13 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_13_PRESENT 1
#else
#define NRF51_ERRATA_13_PRESENT 0
#endif
#ifndef NRF51_ERRATA_13_ENABLE_WORKAROUND
#define NRF51_ERRATA_13_ENABLE_WORKAROUND NRF51_ERRATA_13_PRESENT
#endif
static bool nrf51_errata_13(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 14 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_14_PRESENT 1
#else
#define NRF51_ERRATA_14_PRESENT 0
#endif
#ifndef NRF51_ERRATA_14_ENABLE_WORKAROUND
#define NRF51_ERRATA_14_ENABLE_WORKAROUND NRF51_ERRATA_14_PRESENT
#endif
static bool nrf51_errata_14(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 15 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_15_PRESENT 1
#else
#define NRF51_ERRATA_15_PRESENT 0
#endif
#ifndef NRF51_ERRATA_15_ENABLE_WORKAROUND
#define NRF51_ERRATA_15_ENABLE_WORKAROUND NRF51_ERRATA_15_PRESENT
#endif
static bool nrf51_errata_15(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 16 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_16_PRESENT 1
#else
#define NRF51_ERRATA_16_PRESENT 0
#endif
#ifndef NRF51_ERRATA_16_ENABLE_WORKAROUND
#define NRF51_ERRATA_16_ENABLE_WORKAROUND NRF51_ERRATA_16_PRESENT
#endif
static bool nrf51_errata_16(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 17 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_17_PRESENT 1
#else
#define NRF51_ERRATA_17_PRESENT 0
#endif
#ifndef NRF51_ERRATA_17_ENABLE_WORKAROUND
#define NRF51_ERRATA_17_ENABLE_WORKAROUND NRF51_ERRATA_17_PRESENT
#endif
static bool nrf51_errata_17(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 18 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_18_PRESENT 1
#else
#define NRF51_ERRATA_18_PRESENT 0
#endif
#ifndef NRF51_ERRATA_18_ENABLE_WORKAROUND
#define NRF51_ERRATA_18_ENABLE_WORKAROUND NRF51_ERRATA_18_PRESENT
#endif
static bool nrf51_errata_18(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 19 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_19_PRESENT 1
#else
#define NRF51_ERRATA_19_PRESENT 0
#endif
#ifndef NRF51_ERRATA_19_ENABLE_WORKAROUND
#define NRF51_ERRATA_19_ENABLE_WORKAROUND NRF51_ERRATA_19_PRESENT
#endif
static bool nrf51_errata_19(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 20 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_20_PRESENT 1
#else
#define NRF51_ERRATA_20_PRESENT 0
#endif
#ifndef NRF51_ERRATA_20_ENABLE_WORKAROUND
#define NRF51_ERRATA_20_ENABLE_WORKAROUND NRF51_ERRATA_20_PRESENT
#endif
static bool nrf51_errata_20(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 21 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_21_PRESENT 1
#else
#define NRF51_ERRATA_21_PRESENT 0
#endif
#ifndef NRF51_ERRATA_21_ENABLE_WORKAROUND
#define NRF51_ERRATA_21_ENABLE_WORKAROUND NRF51_ERRATA_21_PRESENT
#endif
static bool nrf51_errata_21(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 22 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_22_PRESENT 1
#else
#define NRF51_ERRATA_22_PRESENT 0
#endif
#ifndef NRF51_ERRATA_22_ENABLE_WORKAROUND
#define NRF51_ERRATA_22_ENABLE_WORKAROUND NRF51_ERRATA_22_PRESENT
#endif
static bool nrf51_errata_22(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 23 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_23_PRESENT 1
#else
#define NRF51_ERRATA_23_PRESENT 0
#endif
#ifndef NRF51_ERRATA_23_ENABLE_WORKAROUND
#define NRF51_ERRATA_23_ENABLE_WORKAROUND NRF51_ERRATA_23_PRESENT
#endif
static bool nrf51_errata_23(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 24 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_24_PRESENT 1
#else
#define NRF51_ERRATA_24_PRESENT 0
#endif
#ifndef NRF51_ERRATA_24_ENABLE_WORKAROUND
#define NRF51_ERRATA_24_ENABLE_WORKAROUND NRF51_ERRATA_24_PRESENT
#endif
static bool nrf51_errata_24(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 25 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_25_PRESENT 1
#else
#define NRF51_ERRATA_25_PRESENT 0
#endif
#ifndef NRF51_ERRATA_25_ENABLE_WORKAROUND
#define NRF51_ERRATA_25_ENABLE_WORKAROUND NRF51_ERRATA_25_PRESENT
#endif
static bool nrf51_errata_25(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 26 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_26_PRESENT 1
#else
#define NRF51_ERRATA_26_PRESENT 0
#endif
#ifndef NRF51_ERRATA_26_ENABLE_WORKAROUND
#define NRF51_ERRATA_26_ENABLE_WORKAROUND NRF51_ERRATA_26_PRESENT
#endif
static bool nrf51_errata_26(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 27 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_27_PRESENT 1
#else
#define NRF51_ERRATA_27_PRESENT 0
#endif
#ifndef NRF51_ERRATA_27_ENABLE_WORKAROUND
#define NRF51_ERRATA_27_ENABLE_WORKAROUND NRF51_ERRATA_27_PRESENT
#endif
static bool nrf51_errata_27(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 28 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_28_PRESENT 1
#else
#define NRF51_ERRATA_28_PRESENT 0
#endif
#ifndef NRF51_ERRATA_28_ENABLE_WORKAROUND
#define NRF51_ERRATA_28_ENABLE_WORKAROUND NRF51_ERRATA_28_PRESENT
#endif
static bool nrf51_errata_28(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 29 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_29_PRESENT 1
#else
#define NRF51_ERRATA_29_PRESENT 0
#endif
#ifndef NRF51_ERRATA_29_ENABLE_WORKAROUND
#define NRF51_ERRATA_29_ENABLE_WORKAROUND NRF51_ERRATA_29_PRESENT
#endif
static bool nrf51_errata_29(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 30 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_30_PRESENT 1
#else
#define NRF51_ERRATA_30_PRESENT 0
#endif
#ifndef NRF51_ERRATA_30_ENABLE_WORKAROUND
#define NRF51_ERRATA_30_ENABLE_WORKAROUND NRF51_ERRATA_30_PRESENT
#endif
static bool nrf51_errata_30(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 31 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_31_PRESENT 1
#else
#define NRF51_ERRATA_31_PRESENT 0
#endif
#ifndef NRF51_ERRATA_31_ENABLE_WORKAROUND
#define NRF51_ERRATA_31_ENABLE_WORKAROUND NRF51_ERRATA_31_PRESENT
#endif
static bool nrf51_errata_31(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 32 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_32_PRESENT 1
#else
#define NRF51_ERRATA_32_PRESENT 0
#endif
#ifndef NRF51_ERRATA_32_ENABLE_WORKAROUND
#define NRF51_ERRATA_32_ENABLE_WORKAROUND NRF51_ERRATA_32_PRESENT
#endif
static bool nrf51_errata_32(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 33 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_33_PRESENT 1
#else
#define NRF51_ERRATA_33_PRESENT 0
#endif
#ifndef NRF51_ERRATA_33_ENABLE_WORKAROUND
#define NRF51_ERRATA_33_ENABLE_WORKAROUND NRF51_ERRATA_33_PRESENT
#endif
static bool nrf51_errata_33(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 34 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_34_PRESENT 1
#else
#define NRF51_ERRATA_34_PRESENT 0
#endif
#ifndef NRF51_ERRATA_34_ENABLE_WORKAROUND
#define NRF51_ERRATA_34_ENABLE_WORKAROUND NRF51_ERRATA_34_PRESENT
#endif
static bool nrf51_errata_34(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 35 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_35_PRESENT 1
#else
#define NRF51_ERRATA_35_PRESENT 0
#endif
#ifndef NRF51_ERRATA_35_ENABLE_WORKAROUND
#define NRF51_ERRATA_35_ENABLE_WORKAROUND NRF51_ERRATA_35_PRESENT
#endif
static bool nrf51_errata_35(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 36 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_36_PRESENT 1
#else
#define NRF51_ERRATA_36_PRESENT 0
#endif
#ifndef NRF51_ERRATA_36_ENABLE_WORKAROUND
#define NRF51_ERRATA_36_ENABLE_WORKAROUND NRF51_ERRATA_36_PRESENT
#endif
static bool nrf51_errata_36(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 37 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_37_PRESENT 1
#else
#define NRF51_ERRATA_37_PRESENT 0
#endif
#ifndef NRF51_ERRATA_37_ENABLE_WORKAROUND
#define NRF51_ERRATA_37_ENABLE_WORKAROUND NRF51_ERRATA_37_PRESENT
#endif
static bool nrf51_errata_37(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 38 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_38_PRESENT 1
#else
#define NRF51_ERRATA_38_PRESENT 0
#endif
#ifndef NRF51_ERRATA_38_ENABLE_WORKAROUND
#define NRF51_ERRATA_38_ENABLE_WORKAROUND NRF51_ERRATA_38_PRESENT
#endif
static bool nrf51_errata_38(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return true;
case 0x08ul:
return true;
case 0x09ul:
return true;
case 0x0Aul:
return true;
case 0x0Bul:
return true;
case 0x0Cul:
return true;
case 0x0Dul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
/* ========= Errata 39 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_39_PRESENT 1
#else
#define NRF51_ERRATA_39_PRESENT 0
#endif
#ifndef NRF51_ERRATA_39_ENABLE_WORKAROUND
#define NRF51_ERRATA_39_ENABLE_WORKAROUND NRF51_ERRATA_39_PRESENT
#endif
static bool nrf51_errata_39(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 40 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_40_PRESENT 1
#else
#define NRF51_ERRATA_40_PRESENT 0
#endif
#ifndef NRF51_ERRATA_40_ENABLE_WORKAROUND
#define NRF51_ERRATA_40_ENABLE_WORKAROUND NRF51_ERRATA_40_PRESENT
#endif
static bool nrf51_errata_40(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 41 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_41_PRESENT 1
#else
#define NRF51_ERRATA_41_PRESENT 0
#endif
#ifndef NRF51_ERRATA_41_ENABLE_WORKAROUND
#define NRF51_ERRATA_41_ENABLE_WORKAROUND NRF51_ERRATA_41_PRESENT
#endif
static bool nrf51_errata_41(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 42 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_42_PRESENT 1
#else
#define NRF51_ERRATA_42_PRESENT 0
#endif
#ifndef NRF51_ERRATA_42_ENABLE_WORKAROUND
#define NRF51_ERRATA_42_ENABLE_WORKAROUND NRF51_ERRATA_42_PRESENT
#endif
static bool nrf51_errata_42(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 43 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_43_PRESENT 1
#else
#define NRF51_ERRATA_43_PRESENT 0
#endif
#ifndef NRF51_ERRATA_43_ENABLE_WORKAROUND
#define NRF51_ERRATA_43_ENABLE_WORKAROUND NRF51_ERRATA_43_PRESENT
#endif
static bool nrf51_errata_43(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 44 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_44_PRESENT 1
#else
#define NRF51_ERRATA_44_PRESENT 0
#endif
#ifndef NRF51_ERRATA_44_ENABLE_WORKAROUND
#define NRF51_ERRATA_44_ENABLE_WORKAROUND NRF51_ERRATA_44_PRESENT
#endif
static bool nrf51_errata_44(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 45 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_45_PRESENT 1
#else
#define NRF51_ERRATA_45_PRESENT 0
#endif
#ifndef NRF51_ERRATA_45_ENABLE_WORKAROUND
#define NRF51_ERRATA_45_ENABLE_WORKAROUND NRF51_ERRATA_45_PRESENT
#endif
static bool nrf51_errata_45(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 46 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_46_PRESENT 1
#else
#define NRF51_ERRATA_46_PRESENT 0
#endif
#ifndef NRF51_ERRATA_46_ENABLE_WORKAROUND
#define NRF51_ERRATA_46_ENABLE_WORKAROUND NRF51_ERRATA_46_PRESENT
#endif
static bool nrf51_errata_46(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return true;
case 0x08ul:
return true;
case 0x09ul:
return true;
case 0x0Aul:
return false;
case 0x0Bul:
return true;
case 0x0Cul:
return true;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 47 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_47_PRESENT 1
#else
#define NRF51_ERRATA_47_PRESENT 0
#endif
#ifndef NRF51_ERRATA_47_ENABLE_WORKAROUND
#define NRF51_ERRATA_47_ENABLE_WORKAROUND NRF51_ERRATA_47_PRESENT
#endif
static bool nrf51_errata_47(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 48 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_48_PRESENT 1
#else
#define NRF51_ERRATA_48_PRESENT 0
#endif
#ifndef NRF51_ERRATA_48_ENABLE_WORKAROUND
#define NRF51_ERRATA_48_ENABLE_WORKAROUND NRF51_ERRATA_48_PRESENT
#endif
static bool nrf51_errata_48(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 49 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_49_PRESENT 1
#else
#define NRF51_ERRATA_49_PRESENT 0
#endif
#ifndef NRF51_ERRATA_49_ENABLE_WORKAROUND
#define NRF51_ERRATA_49_ENABLE_WORKAROUND NRF51_ERRATA_49_PRESENT
#endif
static bool nrf51_errata_49(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 50 ========= */
#define NRF51_ERRATA_50_PRESENT 0
#ifndef NRF51_ERRATA_50_ENABLE_WORKAROUND
#define NRF51_ERRATA_50_ENABLE_WORKAROUND NRF51_ERRATA_50_PRESENT
#endif
static bool nrf51_errata_50(void)
{
#ifndef NRF51_SERIES
return false;
#else
return false;
#endif
}
/* ========= Errata 51 ========= */
#define NRF51_ERRATA_51_PRESENT 0
#ifndef NRF51_ERRATA_51_ENABLE_WORKAROUND
#define NRF51_ERRATA_51_ENABLE_WORKAROUND NRF51_ERRATA_51_PRESENT
#endif
static bool nrf51_errata_51(void)
{
#ifndef NRF51_SERIES
return false;
#else
return false;
#endif
}
/* ========= Errata 52 ========= */
#define NRF51_ERRATA_52_PRESENT 0
#ifndef NRF51_ERRATA_52_ENABLE_WORKAROUND
#define NRF51_ERRATA_52_ENABLE_WORKAROUND NRF51_ERRATA_52_PRESENT
#endif
static bool nrf51_errata_52(void)
{
#ifndef NRF51_SERIES
return false;
#else
return false;
#endif
}
/* ========= Errata 53 ========= */
#define NRF51_ERRATA_53_PRESENT 0
#ifndef NRF51_ERRATA_53_ENABLE_WORKAROUND
#define NRF51_ERRATA_53_ENABLE_WORKAROUND NRF51_ERRATA_53_PRESENT
#endif
static bool nrf51_errata_53(void)
{
#ifndef NRF51_SERIES
return false;
#else
return false;
#endif
}
/* ========= Errata 54 ========= */
#define NRF51_ERRATA_54_PRESENT 0
#ifndef NRF51_ERRATA_54_ENABLE_WORKAROUND
#define NRF51_ERRATA_54_ENABLE_WORKAROUND NRF51_ERRATA_54_PRESENT
#endif
static bool nrf51_errata_54(void)
{
#ifndef NRF51_SERIES
return false;
#else
return false;
#endif
}
/* ========= Errata 55 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_55_PRESENT 1
#else
#define NRF51_ERRATA_55_PRESENT 0
#endif
#ifndef NRF51_ERRATA_55_ENABLE_WORKAROUND
#define NRF51_ERRATA_55_ENABLE_WORKAROUND NRF51_ERRATA_55_PRESENT
#endif
static bool nrf51_errata_55(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return false;
case 0x03ul:
return true;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 56 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_56_PRESENT 1
#else
#define NRF51_ERRATA_56_PRESENT 0
#endif
#ifndef NRF51_ERRATA_56_ENABLE_WORKAROUND
#define NRF51_ERRATA_56_ENABLE_WORKAROUND NRF51_ERRATA_56_PRESENT
#endif
static bool nrf51_errata_56(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 57 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_57_PRESENT 1
#else
#define NRF51_ERRATA_57_PRESENT 0
#endif
#ifndef NRF51_ERRATA_57_ENABLE_WORKAROUND
#define NRF51_ERRATA_57_ENABLE_WORKAROUND NRF51_ERRATA_57_PRESENT
#endif
static bool nrf51_errata_57(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 58 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_58_PRESENT 1
#else
#define NRF51_ERRATA_58_PRESENT 0
#endif
#ifndef NRF51_ERRATA_58_ENABLE_WORKAROUND
#define NRF51_ERRATA_58_ENABLE_WORKAROUND NRF51_ERRATA_58_PRESENT
#endif
static bool nrf51_errata_58(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 59 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_59_PRESENT 1
#else
#define NRF51_ERRATA_59_PRESENT 0
#endif
#ifndef NRF51_ERRATA_59_ENABLE_WORKAROUND
#define NRF51_ERRATA_59_ENABLE_WORKAROUND NRF51_ERRATA_59_PRESENT
#endif
static bool nrf51_errata_59(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 60 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_60_PRESENT 1
#else
#define NRF51_ERRATA_60_PRESENT 0
#endif
#ifndef NRF51_ERRATA_60_ENABLE_WORKAROUND
#define NRF51_ERRATA_60_ENABLE_WORKAROUND NRF51_ERRATA_60_PRESENT
#endif
static bool nrf51_errata_60(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 61 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_61_PRESENT 1
#else
#define NRF51_ERRATA_61_PRESENT 0
#endif
#ifndef NRF51_ERRATA_61_ENABLE_WORKAROUND
#define NRF51_ERRATA_61_ENABLE_WORKAROUND NRF51_ERRATA_61_PRESENT
#endif
static bool nrf51_errata_61(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return true;
case 0x08ul:
return true;
case 0x09ul:
return true;
case 0x0Aul:
return true;
case 0x0Bul:
return true;
case 0x0Cul:
return true;
case 0x0Dul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
/* ========= Errata 62 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_62_PRESENT 1
#else
#define NRF51_ERRATA_62_PRESENT 0
#endif
#ifndef NRF51_ERRATA_62_ENABLE_WORKAROUND
#define NRF51_ERRATA_62_ENABLE_WORKAROUND NRF51_ERRATA_62_PRESENT
#endif
static bool nrf51_errata_62(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 63 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_63_PRESENT 1
#else
#define NRF51_ERRATA_63_PRESENT 0
#endif
#ifndef NRF51_ERRATA_63_ENABLE_WORKAROUND
#define NRF51_ERRATA_63_ENABLE_WORKAROUND NRF51_ERRATA_63_PRESENT
#endif
static bool nrf51_errata_63(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 64 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_64_PRESENT 1
#else
#define NRF51_ERRATA_64_PRESENT 0
#endif
#ifndef NRF51_ERRATA_64_ENABLE_WORKAROUND
#define NRF51_ERRATA_64_ENABLE_WORKAROUND NRF51_ERRATA_64_PRESENT
#endif
static bool nrf51_errata_64(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 65 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_65_PRESENT 1
#else
#define NRF51_ERRATA_65_PRESENT 0
#endif
#ifndef NRF51_ERRATA_65_ENABLE_WORKAROUND
#define NRF51_ERRATA_65_ENABLE_WORKAROUND NRF51_ERRATA_65_PRESENT
#endif
static bool nrf51_errata_65(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 66 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_66_PRESENT 1
#else
#define NRF51_ERRATA_66_PRESENT 0
#endif
#ifndef NRF51_ERRATA_66_ENABLE_WORKAROUND
#define NRF51_ERRATA_66_ENABLE_WORKAROUND NRF51_ERRATA_66_PRESENT
#endif
static bool nrf51_errata_66(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return true;
case 0x08ul:
return true;
case 0x09ul:
return true;
case 0x0Aul:
return false;
case 0x0Bul:
return true;
case 0x0Cul:
return true;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 67 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_67_PRESENT 1
#else
#define NRF51_ERRATA_67_PRESENT 0
#endif
#ifndef NRF51_ERRATA_67_ENABLE_WORKAROUND
#define NRF51_ERRATA_67_ENABLE_WORKAROUND NRF51_ERRATA_67_PRESENT
#endif
static bool nrf51_errata_67(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return true;
case 0x08ul:
return true;
case 0x09ul:
return true;
case 0x0Aul:
return true;
case 0x0Bul:
return true;
case 0x0Cul:
return true;
case 0x0Dul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
/* ========= Errata 68 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_68_PRESENT 1
#else
#define NRF51_ERRATA_68_PRESENT 0
#endif
#ifndef NRF51_ERRATA_68_ENABLE_WORKAROUND
#define NRF51_ERRATA_68_ENABLE_WORKAROUND NRF51_ERRATA_68_PRESENT
#endif
static bool nrf51_errata_68(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 69 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_69_PRESENT 1
#else
#define NRF51_ERRATA_69_PRESENT 0
#endif
#ifndef NRF51_ERRATA_69_ENABLE_WORKAROUND
#define NRF51_ERRATA_69_ENABLE_WORKAROUND NRF51_ERRATA_69_PRESENT
#endif
static bool nrf51_errata_69(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return false;
case 0x03ul:
return false;
case 0x04ul:
return false;
case 0x07ul:
return true;
case 0x08ul:
return true;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return true;
case 0x0Cul:
return true;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 70 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_70_PRESENT 1
#else
#define NRF51_ERRATA_70_PRESENT 0
#endif
#ifndef NRF51_ERRATA_70_ENABLE_WORKAROUND
#define NRF51_ERRATA_70_ENABLE_WORKAROUND NRF51_ERRATA_70_PRESENT
#endif
static bool nrf51_errata_70(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return true;
case 0x08ul:
return true;
case 0x09ul:
return true;
case 0x0Aul:
return true;
case 0x0Bul:
return true;
case 0x0Cul:
return true;
case 0x0Dul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
/* ========= Errata 71 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_71_PRESENT 1
#else
#define NRF51_ERRATA_71_PRESENT 0
#endif
#ifndef NRF51_ERRATA_71_ENABLE_WORKAROUND
#define NRF51_ERRATA_71_ENABLE_WORKAROUND NRF51_ERRATA_71_PRESENT
#endif
static bool nrf51_errata_71(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return false;
case 0x03ul:
return false;
case 0x04ul:
return false;
case 0x07ul:
return true;
case 0x08ul:
return true;
case 0x09ul:
return false;
case 0x0Aul:
return false;
case 0x0Bul:
return true;
case 0x0Cul:
return true;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 72 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_72_PRESENT 1
#else
#define NRF51_ERRATA_72_PRESENT 0
#endif
#ifndef NRF51_ERRATA_72_ENABLE_WORKAROUND
#define NRF51_ERRATA_72_ENABLE_WORKAROUND NRF51_ERRATA_72_PRESENT
#endif
static bool nrf51_errata_72(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return true;
case 0x01ul:
return true;
case 0x02ul:
return true;
case 0x03ul:
return true;
case 0x04ul:
return true;
case 0x07ul:
return true;
case 0x08ul:
return true;
case 0x09ul:
return true;
case 0x0Aul:
return true;
case 0x0Bul:
return true;
case 0x0Cul:
return true;
case 0x0Dul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
/* ========= Errata 73 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_73_PRESENT 1
#else
#define NRF51_ERRATA_73_PRESENT 0
#endif
#ifndef NRF51_ERRATA_73_ENABLE_WORKAROUND
#define NRF51_ERRATA_73_ENABLE_WORKAROUND NRF51_ERRATA_73_PRESENT
#endif
static bool nrf51_errata_73(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return false;
case 0x03ul:
return false;
case 0x04ul:
return false;
case 0x07ul:
return true;
case 0x08ul:
return true;
case 0x09ul:
return true;
case 0x0Aul:
return false;
case 0x0Bul:
return true;
case 0x0Cul:
return true;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 74 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_74_PRESENT 1
#else
#define NRF51_ERRATA_74_PRESENT 0
#endif
#ifndef NRF51_ERRATA_74_ENABLE_WORKAROUND
#define NRF51_ERRATA_74_ENABLE_WORKAROUND NRF51_ERRATA_74_PRESENT
#endif
static bool nrf51_errata_74(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return true;
case 0x08ul:
return true;
case 0x09ul:
return true;
case 0x0Aul:
return false;
case 0x0Bul:
return true;
case 0x0Cul:
return true;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
/* ========= Errata 75 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_75_PRESENT 1
#else
#define NRF51_ERRATA_75_PRESENT 0
#endif
#ifndef NRF51_ERRATA_75_ENABLE_WORKAROUND
#define NRF51_ERRATA_75_ENABLE_WORKAROUND NRF51_ERRATA_75_PRESENT
#endif
static bool nrf51_errata_75(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return true;
case 0x08ul:
return true;
case 0x09ul:
return true;
case 0x0Aul:
return true;
case 0x0Bul:
return true;
case 0x0Cul:
return true;
case 0x0Dul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
/* ========= Errata 76 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_76_PRESENT 1
#else
#define NRF51_ERRATA_76_PRESENT 0
#endif
#ifndef NRF51_ERRATA_76_ENABLE_WORKAROUND
#define NRF51_ERRATA_76_ENABLE_WORKAROUND NRF51_ERRATA_76_PRESENT
#endif
static bool nrf51_errata_76(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return false;
case 0x03ul:
return false;
case 0x04ul:
return false;
case 0x07ul:
return false;
case 0x08ul:
return false;
case 0x09ul:
return false;
case 0x0Aul:
return true;
case 0x0Bul:
return false;
case 0x0Cul:
return false;
case 0x0Dul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
/* ========= Errata 77 ========= */
#define NRF51_ERRATA_77_PRESENT 0
#ifndef NRF51_ERRATA_77_ENABLE_WORKAROUND
#define NRF51_ERRATA_77_ENABLE_WORKAROUND NRF51_ERRATA_77_PRESENT
#endif
static bool nrf51_errata_77(void)
{
#ifndef NRF51_SERIES
return false;
#else
return false;
#endif
}
/* ========= Errata 78 ========= */
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422) \
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
#define NRF51_ERRATA_78_PRESENT 1
#else
#define NRF51_ERRATA_78_PRESENT 0
#endif
#ifndef NRF51_ERRATA_78_ENABLE_WORKAROUND
#define NRF51_ERRATA_78_ENABLE_WORKAROUND NRF51_ERRATA_78_PRESENT
#endif
static bool nrf51_errata_78(void)
{
#ifndef NRF51_SERIES
return false;
#else
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
uint32_t var1 = ((*(uint32_t *)0xF0000FE0ul) & 0x000000FFul);
uint32_t var2 = ((*(uint32_t *)0xF0000FE8ul) & 0x000000F0ul) >> 4;
#endif
#if defined (NRF51422_XXAA) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAB) || defined (DEVELOP_IN_NRF51422)\
|| defined (NRF51422_XXAC) || defined (DEVELOP_IN_NRF51422)
if (var1 == 0x01)
{
switch(var2)
{
case 0x00ul:
return false;
case 0x01ul:
return false;
case 0x02ul:
return true;
case 0x03ul:
return false;
case 0x04ul:
return true;
case 0x07ul:
return true;
case 0x08ul:
return true;
case 0x09ul:
return true;
case 0x0Aul:
return false;
case 0x0Bul:
return true;
case 0x0Cul:
return true;
case 0x0Dul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
#endif /* NRF51_ERRATAS_H */