HL-PDJ-1/modules/nrfx/mdk/nrf91_erratas.h

751 lines
21 KiB
C
Raw Normal View History

2025-08-19 09:49:41 +08:00
#ifndef NRF91_ERRATAS_H
#define NRF91_ERRATAS_H
/*
Copyright (c) 2010 - 2020, 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 nrf91_errata_1(void) __UNUSED;
static bool nrf91_errata_2(void) __UNUSED;
static bool nrf91_errata_4(void) __UNUSED;
static bool nrf91_errata_6(void) __UNUSED;
static bool nrf91_errata_7(void) __UNUSED;
static bool nrf91_errata_8(void) __UNUSED;
static bool nrf91_errata_9(void) __UNUSED;
static bool nrf91_errata_10(void) __UNUSED;
static bool nrf91_errata_12(void) __UNUSED;
static bool nrf91_errata_14(void) __UNUSED;
static bool nrf91_errata_15(void) __UNUSED;
static bool nrf91_errata_16(void) __UNUSED;
static bool nrf91_errata_17(void) __UNUSED;
static bool nrf91_errata_20(void) __UNUSED;
static bool nrf91_errata_21(void) __UNUSED;
static bool nrf91_errata_23(void) __UNUSED;
static bool nrf91_errata_24(void) __UNUSED;
static bool nrf91_errata_26(void) __UNUSED;
static bool nrf91_errata_27(void) __UNUSED;
static bool nrf91_errata_28(void) __UNUSED;
static bool nrf91_errata_29(void) __UNUSED;
static bool nrf91_errata_30(void) __UNUSED;
static bool nrf91_errata_31(void) __UNUSED;
static bool nrf91_errata_32(void) __UNUSED;
static bool nrf91_errata_33(void) __UNUSED;
static bool nrf91_errata_1(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_2(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_4(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_6(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_7(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_8(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_9(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return false;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_10(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_12(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_14(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_15(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return false;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_16(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_17(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_20(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return false;
default:
return false;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_21(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_23(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_24(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_26(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_27(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return false;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_28(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_29(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_30(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_31(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_32(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
static bool nrf91_errata_33(void)
{
#ifndef NRF91_SERIES
return false;
#else
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
uint32_t var1 = *(uint32_t *)0x00FF0130ul;
uint32_t var2 = *(uint32_t *)0x00FF0134ul;
#endif
#if defined (NRF9160_XXAA) || defined (DEVELOP_IN_NRF9160)
if (var1 == 0x09)
{
switch(var2)
{
case 0x01ul:
return true;
case 0x02ul:
return true;
default:
return true;
}
}
#endif
return false;
#endif
}
#endif /* NRF91_ERRATAS_H */