blob: d18f1c9710a2c4e420cf456e929b5c5ba429092d [file] [log] [blame]
Omkar Anand Kulkarni1f425992023-06-22 15:18:07 +05301/*
Rohit Mathewa0dd3072024-02-03 17:22:54 +00002 * Copyright (c) 2023-2024, Arm Limited and Contributors. All rights reserved.
Omkar Anand Kulkarni1f425992023-06-22 15:18:07 +05303 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6
7#include <platform_def.h>
Rohit Mathewa0dd3072024-02-03 17:22:54 +00008
9#include <nrd_ras.h>
10#include <nrd_sdei.h>
Omkar Anand Kulkarni1f425992023-06-22 15:18:07 +053011
Rohit Mathew0ec6ed92024-02-03 18:39:10 +000012struct nrd_ras_ev_map plat_ras_map[] = {
Omkar Anand Kulkarni1f425992023-06-22 15:18:07 +053013 /* Non Secure base RAM ECC CE interrupt */
14 {SGI_SDEI_DS_EVENT_0, NS_RAM_ECC_CE_INT, SGI_RAS_INTR_TYPE_SPI},
15
16 /* Non Secure base RAM ECC UE interrupt */
17 {SGI_SDEI_DS_EVENT_0, NS_RAM_ECC_UE_INT, SGI_RAS_INTR_TYPE_SPI},
Omkar Anand Kulkarni67f5ccb2023-06-21 13:11:04 +053018
19 /* CPU 1-bit ECC CE error interrupt */
20 {SGI_SDEI_DS_EVENT_1, PLAT_CORE_FAULT_IRQ, SGI_RAS_INTR_TYPE_PPI}
Omkar Anand Kulkarni1f425992023-06-22 15:18:07 +053021};
22
23/* RAS error record list definition, used by the common RAS framework. */
24struct err_record_info plat_err_records[] = {
25 /* Base element RAM Non-secure error record. */
26 ERR_RECORD_MEMMAP_V1(SOC_NS_RAM_ERR_REC_BASE, 4, NULL,
Rohit Mathew0ec6ed92024-02-03 18:39:10 +000027 &nrd_ras_sram_intr_handler, 0),
28 ERR_RECORD_SYSREG_V1(0, 1, NULL, &nrd_ras_cpu_intr_handler, 0),
Omkar Anand Kulkarni1f425992023-06-22 15:18:07 +053029};
30
31/* RAS error interrupt list definition, used by the common RAS framework. */
32struct ras_interrupt plat_ras_interrupts[] = {
33 {
Omkar Anand Kulkarni67f5ccb2023-06-21 13:11:04 +053034 .intr_number = PLAT_CORE_FAULT_IRQ,
35 .err_record = &plat_err_records[1],
36 }, {
Omkar Anand Kulkarni1f425992023-06-22 15:18:07 +053037 .intr_number = NS_RAM_ECC_CE_INT,
38 .err_record = &plat_err_records[0],
39 }, {
40 .intr_number = NS_RAM_ECC_UE_INT,
41 .err_record = &plat_err_records[0],
42 },
43};
44
45/* Registers the RAS error record list with common RAS framework. */
46REGISTER_ERR_RECORD_INFO(plat_err_records);
47/* Registers the RAS error interrupt info list with common RAS framework. */
48REGISTER_RAS_INTERRUPTS(plat_ras_interrupts);
49
50/* Platform RAS handling config data definition */
Rohit Mathew0ec6ed92024-02-03 18:39:10 +000051struct plat_nrd_ras_config ras_config = {
Omkar Anand Kulkarni1f425992023-06-22 15:18:07 +053052 plat_ras_map,
53 ARRAY_SIZE(plat_ras_map)
54};