4.13 CLASSB_SRAM_MarchTestInit

Function

CLASSB_TEST_STATUS CLASSB_SRAM_MarchTestInit(uint32_t * start_addr, uint32_t test_size, CLASSB_SRAM_MARCH_ALGO march_algo, bool running_context, CLASSB_MEM_REGION mem_region);

Summary

This self-test checks the SRAM with the help of RAM March algorithm.

Description

This self-test run the selected RAM March algorithm on the SRAM to detect stuck-at fault, DC fault and addressing fault.

Precondition

None.

Parameters

start_addr - Starting address of the memory block.

test_size - Size of the memory block.

march_algo - The selected RAM March algorithm. It can be March C, March C minus or March B.

running_context - False for startup test. True for run-time test.

mem_region - The memory region in which the test will be performed (ITCM/DTCM/SRAM)

Returns

CLASSB_TEST_STATUS - Status of the test.

Example

CLASSB_TEST_STATUS classb_test_status = CLASSB_TEST_NOT_EXECUTED;
// Perform run-time test of the internal SRAM
classb_test_status = CLASSB_SRAM_MarchTestInit((uint32_t *)CLASSB_SRAM_APP_AREA_START,
    1024, CLASSB_SRAM_MARCH_C, true, CLASSB_MEM_REGION_SRAM);

Remarks

This self-test can be used during startup as well as run-time. Initial 1kB of the SRAM must be reserved for the Class B library.