RTEMS 6.1-rc2
Loading...
Searching...
No Matches
reg_efuse.h
Go to the documentation of this file.
1/* SPDX-License-Identifier: BSD-2-Clause */
2
11/* The header file is generated by make_header.py from EFUSE.json */
12/* Current script's version can be found at: */
13/* https://github.com/AoLaD/rtems-tms570-utils/tree/headers/headers/python */
14
15/*
16 * Copyright (c) 2014-2015, Premysl Houdek <kom541000@gmail.com>
17 *
18 * Czech Technical University in Prague
19 * Zikova 1903/4
20 * 166 36 Praha 6
21 * Czech Republic
22 *
23 * All rights reserved.
24 *
25 * Redistribution and use in source and binary forms, with or without
26 * modification, are permitted provided that the following conditions are met:
27 *
28 * 1. Redistributions of source code must retain the above copyright notice, this
29 * list of conditions and the following disclaimer.
30 * 2. Redistributions in binary form must reproduce the above copyright notice,
31 * this list of conditions and the following disclaimer in the documentation
32 * and/or other materials provided with the distribution.
33 *
34 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
35 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
36 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
37 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
38 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
39 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
40 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
41 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
42 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
43 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
44 *
45 * The views and conclusions contained in the software and documentation are those
46 * of the authors and should not be interpreted as representing official policies,
47 * either expressed or implied, of the FreeBSD Project.
48*/
49#ifndef LIBBSP_ARM_TMS570_EFUSE
50#define LIBBSP_ARM_TMS570_EFUSE
51
52#include <bsp/utility.h>
53
54typedef struct{
55 uint32_t EFCBOUND; /*EFC Boundary Control Register*/
56 uint8_t reserved1 [12];
57 uint32_t EFCPINS; /*EFC Pins Register*/
58 uint8_t reserved2 [12];
59 uint32_t EFC_ERR_STAT; /*EFC Error Status Register*/
60 uint8_t reserved3 [8];
61 uint32_t EFC_ST_CY; /*EFC Self Test Cycles Register*/
62 uint32_t EFC_ST_SIG; /*EFC Self Test Signature Register*/
64
65
66/*-------------------TMS570_EFUSE_EFCBOUND-------------------*/
67/* field: EFC_Self_Test_Error - This bit drives the self test error signal when bit 17 (Self Test Error OE) is high. */
68#define TMS570_EFUSE_EFCBOUND_EFC_Self_Test_Error BSP_BIT32(21)
69
70/* field: EFC_Single_Bit_Error - This bit drives the single bit error signal when bit 16 (Single bit Error OE) is high. */
71#define TMS570_EFUSE_EFCBOUND_EFC_Single_Bit_Error BSP_BIT32(20)
72
73/* field: EFC_Instruction_Error - This bit drives the instruction error signal when bit 15 (Instruction Error OE) is high. */
74#define TMS570_EFUSE_EFCBOUND_EFC_Instruction_Error BSP_BIT32(19)
75
76/* field: EFC_Autoload_Error - This bit drives the Autoload Error signal when bit 14 (Autoload Error OE) is high. */
77#define TMS570_EFUSE_EFCBOUND_EFC_Autoload_Error BSP_BIT32(18)
78
79/* field: Self_Test_Error_OE - The Self Test Error Output Enable bit determines if the EFC Self Test signal comes from the */
80#define TMS570_EFUSE_EFCBOUND_Self_Test_Error_OE BSP_BIT32(17)
81
82/* field: Single_Bit_Error_OE - The single bit error output enable signal determines if the EFC Single Bit Error signal comes */
83#define TMS570_EFUSE_EFCBOUND_Single_Bit_Error_OE BSP_BIT32(16)
84
85/* field: Instruction_Error_OE - comes from the eFuse controller or from bit 19 of the boundary register. */
86#define TMS570_EFUSE_EFCBOUND_Instruction_Error_OE BSP_BIT32(15)
87
88/* field: Autoload_Error_OE - The autoload error output enable signal determines if the EFC Autoload Error signal comes */
89#define TMS570_EFUSE_EFCBOUND_Autoload_Error_OE BSP_BIT32(14)
90
91/* field: EFC_ECC_Selftest - The eFuse Controller ECC Selftest Enable bit starts the selftest of the ECC logic if the four */
92#define TMS570_EFUSE_EFCBOUND_EFC_ECC_Selftest BSP_BIT32(13)
93
94/* field: Input_Enable - The eFuse Controller ECC Selftest Enable bit starts the selftest of the ECC logic if the four */
95#define TMS570_EFUSE_EFCBOUND_Input_Enable(val) BSP_FLD32(val,0, 3)
96#define TMS570_EFUSE_EFCBOUND_Input_Enable_GET(reg) BSP_FLD32GET(reg,0, 3)
97#define TMS570_EFUSE_EFCBOUND_Input_Enable_SET(reg,val) BSP_FLD32SET(reg, val,0, 3)
98
99
100/*--------------------TMS570_EFUSE_EFCPINS--------------------*/
101/* field: EFC_Selftest_Done - This bit can be polled to determine when the EFC ECC selftest is complete */
102#define TMS570_EFUSE_EFCPINS_EFC_Selftest_Done BSP_BIT32(15)
103
104/* field: EFC_Selftest_Error - This bit indicates the pass/fail status of the EFC ECC Selftest once the EFC Selftest Done */
105#define TMS570_EFUSE_EFCPINS_EFC_Selftest_Error BSP_BIT32(14)
106
107/* field: EFC_Single_Bit_Error - This bit indicates if a single bit error was corrected by the ECC logic during the autoload */
108#define TMS570_EFUSE_EFCPINS_EFC_Single_Bit_Error BSP_BIT32(12)
109
110/* field: EFC_Instruction_Error - This bit indicates an error occured during a factory test or program operation. */
111#define TMS570_EFUSE_EFCPINS_EFC_Instruction_Error BSP_BIT32(11)
112
113/* field: EFC_Autoload_Error - This bit indicates that some non-correctable error occurred during the autoload sequence */
114#define TMS570_EFUSE_EFCPINS_EFC_Autoload_Error BSP_BIT32(10)
115
116
117/*-----------------TMS570_EFUSE_EFC_ERR_STAT-----------------*/
118/* field: Instruc_Done - Instruction done. */
119#define TMS570_EFUSE_EFC_ERR_STAT_Instruc_Done BSP_BIT32(5)
120
121/* field: Error_Code - The error status of the last instruction executed by the eFuse Controller */
122#define TMS570_EFUSE_EFC_ERR_STAT_Error_Code(val) BSP_FLD32(val,0, 4)
123#define TMS570_EFUSE_EFC_ERR_STAT_Error_Code_GET(reg) BSP_FLD32GET(reg,0, 4)
124#define TMS570_EFUSE_EFC_ERR_STAT_Error_Code_SET(reg,val) BSP_FLD32SET(reg, val,0, 4)
125
126
127/*-------------------TMS570_EFUSE_EFC_ST_CY-------------------*/
128/* field: Cycles - This register is used to determine the number of cycles to run the eFuse controller ECC logic self test. */
129/* Whole 32 bits */
130
131/*------------------TMS570_EFUSE_EFC_ST_SIG------------------*/
132/* field: Signature - This register is used to hold the expected signature for the eFuse ECC logic self test. */
133/* Whole 32 bits */
134
135
136#endif /* LIBBSP_ARM_TMS570_EFUSE */
This header file provides utility macros for BSPs.
Definition: reg_efuse.h:54