SDL API Guide for J721E
pbist/V0/sdl_ip_pbist.h
Go to the documentation of this file.
1 /********************************************************************
2  * Copyright (C) 2019-2021 Texas Instruments Incorporated.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  *
8  * Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  *
11  * Redistributions in binary form must reproduce the above copyright
12  * notice, this list of conditions and the following disclaimer in the
13  * documentation and/or other materials provided with the
14  * distribution.
15  *
16  * Neither the name of Texas Instruments Incorporated nor the names of
17  * its contributors may be used to endorse or promote products derived
18  * from this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  *
32  */
33 
49 #ifndef SDL_IP_PBIST_H_
50 #define SDL_IP_PBIST_H_
51 
52 #ifdef __cplusplus
53 extern "C" {
54 #endif
55 
56 #include <stdint.h>
57 #include <stdbool.h>
58 #include <src/ip/sdlr_pbist.h>
59 
88 typedef struct
89 {
92  uint32_t override;
93 
99  uint32_t algorithmsBitMap;
100 
104 
107  uint64_t scrambleValue;
109 
119 typedef struct
120 {
123  uint32_t CA0;
124 
127  uint32_t CA1;
128 
131  uint32_t CA2;
132 
135  uint32_t CA3;
136 
139  uint32_t CL0;
140 
143  uint32_t CL1;
144 
147  uint32_t CL2;
148 
151  uint32_t CL3;
152 
155  uint32_t CMS;
156 
159  uint32_t CSR;
160 
163  uint32_t I0;
164 
167  uint32_t I1;
168 
171  uint32_t I2;
172 
175  uint32_t I3;
176 
179  uint32_t RAMT;
181 
190 typedef struct
191 {
194  uint32_t D;
195 
198  uint32_t E;
199 
202  uint32_t CA2;
203 
206  uint32_t CL0;
207 
210  uint32_t CA3;
211 
214  uint32_t I0;
215 
218  uint32_t CL1;
219 
222  uint32_t I3;
223 
226  uint32_t I2;
227 
230  uint32_t CL2;
231 
234  uint32_t CA1;
235 
238  uint32_t CA0;
239 
242  uint32_t CL3;
243 
246  uint32_t I1;
247 
250  uint32_t RAMT;
251 
254  uint32_t CSR;
255 
258  uint32_t CMS;
259 
261 
262 
284 int32_t SDL_PBIST_softReset(SDL_pbistRegs *pPBISTRegs);
285 
299 int32_t SDL_PBIST_start(SDL_pbistRegs *pPBISTRegs,
300  const SDL_PBIST_config * pConfig);
301 
315 int32_t SDL_PBIST_startNeg(SDL_pbistRegs *pPBISTRegs,
316  const SDL_PBIST_configNeg *pConfig);
317 
330 int32_t SDL_PBIST_startROMTest(SDL_pbistRegs *pPBISTRegs,
331  const SDL_PBIST_romTest * const pConfig);
332 
346 int32_t SDL_PBIST_checkResult (const SDL_pbistRegs *pPBISTRegs, bool *pResult);
347 
361 int32_t SDL_PBIST_releaseTestMode(SDL_pbistRegs *pPBISTRegs);
362 
365 #ifdef __cplusplus
366 }
367 #endif
368 
369 #endif /* SDL_IP_PBIST_H_ */
uint32_t CL1
Definition: pbist/V0/sdl_ip_pbist.h:143
uint32_t CA3
Definition: pbist/V0/sdl_ip_pbist.h:135
uint64_t memoryGroupsBitMap
Definition: pbist/V0/sdl_ip_pbist.h:103
uint32_t CL0
Definition: pbist/V0/sdl_ip_pbist.h:139
uint32_t CA0
Definition: pbist/V0/sdl_ip_pbist.h:123
uint32_t CA1
Definition: pbist/V0/sdl_ip_pbist.h:234
uint32_t CA3
Definition: pbist/V0/sdl_ip_pbist.h:210
This structure contains the different configuration used for PBIST for the failure insertion test to ...
Definition: pbist/V0/sdl_ip_pbist.h:119
uint32_t I0
Definition: pbist/V0/sdl_ip_pbist.h:214
int32_t SDL_PBIST_releaseTestMode(SDL_pbistRegs *pPBISTRegs)
PBIST Release Test mode.
uint32_t I1
Definition: pbist/V0/sdl_ip_pbist.h:246
uint32_t CL2
Definition: pbist/V0/sdl_ip_pbist.h:230
This structure contains the different configuration used for PBIST.
Definition: pbist/V0/sdl_ip_pbist.h:88
uint32_t CA0
Definition: pbist/V0/sdl_ip_pbist.h:238
uint32_t RAMT
Definition: pbist/V0/sdl_ip_pbist.h:179
uint32_t CL3
Definition: pbist/V0/sdl_ip_pbist.h:151
uint32_t CL3
Definition: pbist/V0/sdl_ip_pbist.h:242
int32_t SDL_PBIST_softReset(SDL_pbistRegs *pPBISTRegs)
PBIST Soft reset.
uint32_t CA1
Definition: pbist/V0/sdl_ip_pbist.h:127
uint32_t I3
Definition: pbist/V0/sdl_ip_pbist.h:175
uint32_t I2
Definition: pbist/V0/sdl_ip_pbist.h:171
uint32_t CMS
Definition: pbist/V0/sdl_ip_pbist.h:155
uint64_t scrambleValue
Definition: pbist/V0/sdl_ip_pbist.h:107
int32_t SDL_PBIST_startROMTest(SDL_pbistRegs *pPBISTRegs, const SDL_PBIST_romTest *const pConfig)
PBIST Test of ROM Start.
This structure contains the different configuration used for PBIST test of ROM.
Definition: pbist/V0/sdl_ip_pbist.h:190
uint32_t CL0
Definition: pbist/V0/sdl_ip_pbist.h:206
uint32_t CSR
Definition: pbist/V0/sdl_ip_pbist.h:159
uint32_t I0
Definition: pbist/V0/sdl_ip_pbist.h:163
uint32_t I2
Definition: pbist/V0/sdl_ip_pbist.h:226
uint32_t CA2
Definition: pbist/V0/sdl_ip_pbist.h:131
uint32_t RAMT
Definition: pbist/V0/sdl_ip_pbist.h:250
uint32_t D
Definition: pbist/V0/sdl_ip_pbist.h:194
int32_t SDL_PBIST_checkResult(const SDL_pbistRegs *pPBISTRegs, bool *pResult)
PBIST check result.
int32_t SDL_PBIST_startNeg(SDL_pbistRegs *pPBISTRegs, const SDL_PBIST_configNeg *pConfig)
PBIST Failure Insertion Test Start.
uint32_t CL2
Definition: pbist/V0/sdl_ip_pbist.h:147
int32_t SDL_PBIST_start(SDL_pbistRegs *pPBISTRegs, const SDL_PBIST_config *pConfig)
PBIST Start.
uint32_t I1
Definition: pbist/V0/sdl_ip_pbist.h:167
uint32_t E
Definition: pbist/V0/sdl_ip_pbist.h:198
uint32_t CA2
Definition: pbist/V0/sdl_ip_pbist.h:202
uint32_t CSR
Definition: pbist/V0/sdl_ip_pbist.h:254
uint32_t algorithmsBitMap
Definition: pbist/V0/sdl_ip_pbist.h:99
uint32_t CMS
Definition: pbist/V0/sdl_ip_pbist.h:258
uint32_t CL1
Definition: pbist/V0/sdl_ip_pbist.h:218
uint32_t I3
Definition: pbist/V0/sdl_ip_pbist.h:222