Back to home page

LXR

 
 

    


File indexing completed on 2025-05-11 08:23:38

0001 /* SPDX-License-Identifier: BSD-2-Clause */
0002 
0003 /**
0004  * @file
0005  *
0006  * @ingroup RTEMSBSPsARMTMS570
0007  *
0008  * @brief This header file provides EFUSE interfaces.
0009  */
0010 
0011 /* The header file is generated by make_header.py from EFUSE.json */
0012 /* Current script's version can be found at: */
0013 /* https://github.com/AoLaD/rtems-tms570-utils/tree/headers/headers/python */
0014 
0015 /*
0016  * Copyright (c) 2014-2015, Premysl Houdek <kom541000@gmail.com>
0017  *
0018  * Czech Technical University in Prague
0019  * Zikova 1903/4
0020  * 166 36 Praha 6
0021  * Czech Republic
0022  *
0023  * All rights reserved.
0024  *
0025  * Redistribution and use in source and binary forms, with or without
0026  * modification, are permitted provided that the following conditions are met:
0027  *
0028  * 1. Redistributions of source code must retain the above copyright notice, this
0029  *    list of conditions and the following disclaimer.
0030  * 2. Redistributions in binary form must reproduce the above copyright notice,
0031  *    this list of conditions and the following disclaimer in the documentation
0032  *    and/or other materials provided with the distribution.
0033  *
0034  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
0035  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
0036  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
0037  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
0038  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
0039  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
0040  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
0041  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
0042  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
0043  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
0044  *
0045  * The views and conclusions contained in the software and documentation are those
0046  * of the authors and should not be interpreted as representing official policies,
0047  * either expressed or implied, of the FreeBSD Project.
0048 */
0049 #ifndef LIBBSP_ARM_TMS570_EFUSE
0050 #define LIBBSP_ARM_TMS570_EFUSE
0051 
0052 #include <bsp/utility.h>
0053 
0054 typedef struct{
0055   uint32_t EFCBOUND;          /*EFC Boundary Control Register*/
0056   uint8_t reserved1 [12];
0057   uint32_t EFCPINS;           /*EFC Pins Register*/
0058   uint8_t reserved2 [12];
0059   uint32_t EFC_ERR_STAT;      /*EFC Error Status Register*/
0060   uint8_t reserved3 [8];
0061   uint32_t EFC_ST_CY;         /*EFC Self Test Cycles Register*/
0062   uint32_t EFC_ST_SIG;        /*EFC Self Test Signature Register*/
0063 } tms570_efuse_t;
0064 
0065 
0066 /*-------------------TMS570_EFUSE_EFCBOUND-------------------*/
0067 /* field: EFC_Self_Test_Error - This bit drives the self test error signal when bit 17 (Self Test Error OE) is high. */
0068 #define TMS570_EFUSE_EFCBOUND_EFC_Self_Test_Error BSP_BIT32(21)
0069 
0070 /* field: EFC_Single_Bit_Error - This bit drives the single bit error signal when bit 16 (Single bit Error OE) is high. */
0071 #define TMS570_EFUSE_EFCBOUND_EFC_Single_Bit_Error BSP_BIT32(20)
0072 
0073 /* field: EFC_Instruction_Error - This bit drives the instruction error signal when bit 15 (Instruction Error OE) is high. */
0074 #define TMS570_EFUSE_EFCBOUND_EFC_Instruction_Error BSP_BIT32(19)
0075 
0076 /* field: EFC_Autoload_Error - This bit drives the Autoload Error signal when bit 14 (Autoload Error OE) is high. */
0077 #define TMS570_EFUSE_EFCBOUND_EFC_Autoload_Error BSP_BIT32(18)
0078 
0079 /* field: Self_Test_Error_OE - The Self Test Error Output Enable bit determines if the EFC Self Test signal comes from the */
0080 #define TMS570_EFUSE_EFCBOUND_Self_Test_Error_OE BSP_BIT32(17)
0081 
0082 /* field: Single_Bit_Error_OE - The single bit error output enable signal determines if the EFC Single Bit Error signal comes */
0083 #define TMS570_EFUSE_EFCBOUND_Single_Bit_Error_OE BSP_BIT32(16)
0084 
0085 /* field: Instruction_Error_OE - comes from the eFuse controller or from bit 19 of the boundary register. */
0086 #define TMS570_EFUSE_EFCBOUND_Instruction_Error_OE BSP_BIT32(15)
0087 
0088 /* field: Autoload_Error_OE - The autoload error output enable signal determines if the EFC Autoload Error signal comes */
0089 #define TMS570_EFUSE_EFCBOUND_Autoload_Error_OE BSP_BIT32(14)
0090 
0091 /* field: EFC_ECC_Selftest - The eFuse Controller ECC Selftest Enable bit starts the selftest of the ECC logic if the four */
0092 #define TMS570_EFUSE_EFCBOUND_EFC_ECC_Selftest BSP_BIT32(13)
0093 
0094 /* field: Input_Enable - The eFuse Controller ECC Selftest Enable bit starts the selftest of the ECC logic if the four */
0095 #define TMS570_EFUSE_EFCBOUND_Input_Enable(val) BSP_FLD32(val,0, 3)
0096 #define TMS570_EFUSE_EFCBOUND_Input_Enable_GET(reg) BSP_FLD32GET(reg,0, 3)
0097 #define TMS570_EFUSE_EFCBOUND_Input_Enable_SET(reg,val) BSP_FLD32SET(reg, val,0, 3)
0098 
0099 
0100 /*--------------------TMS570_EFUSE_EFCPINS--------------------*/
0101 /* field: EFC_Selftest_Done - This bit can be polled to determine when the EFC ECC selftest is complete */
0102 #define TMS570_EFUSE_EFCPINS_EFC_Selftest_Done BSP_BIT32(15)
0103 
0104 /* field: EFC_Selftest_Error - This bit indicates the pass/fail status of the EFC ECC Selftest once the EFC Selftest Done */
0105 #define TMS570_EFUSE_EFCPINS_EFC_Selftest_Error BSP_BIT32(14)
0106 
0107 /* field: EFC_Single_Bit_Error - This bit indicates if a single bit error was corrected by the ECC logic during the autoload */
0108 #define TMS570_EFUSE_EFCPINS_EFC_Single_Bit_Error BSP_BIT32(12)
0109 
0110 /* field: EFC_Instruction_Error - This bit indicates an error occured during a factory test or program operation. */
0111 #define TMS570_EFUSE_EFCPINS_EFC_Instruction_Error BSP_BIT32(11)
0112 
0113 /* field: EFC_Autoload_Error - This bit indicates that some non-correctable error occurred during the autoload sequence */
0114 #define TMS570_EFUSE_EFCPINS_EFC_Autoload_Error BSP_BIT32(10)
0115 
0116 
0117 /*-----------------TMS570_EFUSE_EFC_ERR_STAT-----------------*/
0118 /* field: Instruc_Done - Instruction done. */
0119 #define TMS570_EFUSE_EFC_ERR_STAT_Instruc_Done BSP_BIT32(5)
0120 
0121 /* field: Error_Code - The error status of the last instruction executed by the eFuse Controller */
0122 #define TMS570_EFUSE_EFC_ERR_STAT_Error_Code(val) BSP_FLD32(val,0, 4)
0123 #define TMS570_EFUSE_EFC_ERR_STAT_Error_Code_GET(reg) BSP_FLD32GET(reg,0, 4)
0124 #define TMS570_EFUSE_EFC_ERR_STAT_Error_Code_SET(reg,val) BSP_FLD32SET(reg, val,0, 4)
0125 
0126 
0127 /*-------------------TMS570_EFUSE_EFC_ST_CY-------------------*/
0128 /* field: Cycles - This register is used to determine the number of cycles to run the eFuse controller ECC logic self test. */
0129 /* Whole 32 bits */
0130 
0131 /*------------------TMS570_EFUSE_EFC_ST_SIG------------------*/
0132 /* field: Signature - This register is used to hold the expected signature for the eFuse ECC logic self test. */
0133 /* Whole 32 bits */
0134 
0135 
0136 #endif /* LIBBSP_ARM_TMS570_EFUSE */