source: rtems/c/src/lib/libbsp/shared/include/fatal.h @ d1c771c

5
Last change on this file since d1c771c was d1c771c, checked in by Sebastian Huber <sebastian.huber@…>, on 12/15/16 at 08:56:12

bsp/atsam: Move XDMA IRQ handler to XDMA module

The XDMA is shared by all DMA capable modules. Placing the XDMA
interrupt handler into the SPI module is wrong.

  • Property mode set to 100644
File size: 4.4 KB
Line 
1/*
2 * Copyright (c) 2012, 2016 embedded brains GmbH.  All rights reserved.
3 *
4 *  embedded brains GmbH
5 *  Dornierstr. 4
6 *  82178 Puchheim
7 *  Germany
8 *  <rtems@embedded-brains.de>
9 *
10 * The license and distribution terms for this file may be
11 * found in the file LICENSE in this distribution or at
12 * http://www.rtems.org/license/LICENSE.
13 */
14
15#ifndef LIBBSP_SHARED_BSP_FATAL_H
16#define LIBBSP_SHARED_BSP_FATAL_H
17
18#include <rtems.h>
19
20#ifdef __cplusplus
21extern "C" {
22#endif /* __cplusplus */
23
24#define BSP_FATAL_CODE_BLOCK(idx) ((unsigned long) (idx) * 256UL)
25
26/**
27 * @brief BSP fatal error codes.
28 */
29typedef enum {
30  /* Generic BSP fatal codes */
31  BSP_FATAL_INTERRUPT_INITIALIZATION = BSP_FATAL_CODE_BLOCK(0),
32  BSP_FATAL_SPURIOUS_INTERRUPT,
33  BSP_FATAL_CONSOLE_MULTI_INIT,
34  BSP_FATAL_CONSOLE_NO_MEMORY_0,
35  BSP_FATAL_CONSOLE_NO_MEMORY_1,
36  BSP_FATAL_CONSOLE_NO_MEMORY_2,
37  BSP_FATAL_CONSOLE_NO_MEMORY_3,
38  BSP_FATAL_CONSOLE_REGISTER_DEV_0,
39  BSP_FATAL_CONSOLE_REGISTER_DEV_1,
40  BSP_FATAL_CONSOLE_NO_DEV,
41  BSP_FATAL_CONSOLE_INSTALL_0,
42  BSP_FATAL_CONSOLE_INSTALL_1,
43  BSP_FATAL_CONSOLE_REGISTER_DEV_2,
44
45  /* ARM fatal codes */
46  BSP_ARM_A9MPCORE_FATAL_CLOCK_IRQ_INSTALL = BSP_FATAL_CODE_BLOCK(1),
47  BSP_ARM_A9MPCORE_FATAL_CLOCK_IRQ_REMOVE,
48  BSP_ARM_PL111_FATAL_REGISTER_DEV,
49  BSP_ARM_PL111_FATAL_SEM_CREATE,
50  BSP_ARM_PL111_FATAL_SEM_RELEASE,
51  BSP_ARM_A9MPCORE_FATAL_CLOCK_SMP_INIT,
52  BSP_ARM_ARMV7M_CPU_COUNTER_INIT,
53
54  /* LEON3 fatal codes */
55  LEON3_FATAL_NO_IRQMP_CONTROLLER = BSP_FATAL_CODE_BLOCK(2),
56  LEON3_FATAL_CONSOLE_REGISTER_DEV,
57  LEON3_FATAL_CLOCK_INITIALIZATION,
58  LEON3_FATAL_INVALID_CACHE_CONFIG_MAIN_PROCESSOR,
59  LEON3_FATAL_INVALID_CACHE_CONFIG_SECONDARY_PROCESSOR,
60  LEON3_FATAL_CLOCK_NO_IRQMP_TIMESTAMP_SUPPORT,
61
62  /* LPC24XX fatal codes */
63  LPC24XX_FATAL_PL111_SET_UP = BSP_FATAL_CODE_BLOCK(3),
64  LPC24XX_FATAL_PL111_PINS_SET_UP,
65  LPC24XX_FATAL_PL111_PINS_TEAR_DOWN,
66  LPC24XX_FATAL_PL111_TEAR_DOWN,
67
68  /* MPC5200 fatal codes */
69  MPC5200_FATAL_PCF8563_INVALID_YEAR = BSP_FATAL_CODE_BLOCK(4),
70  MPC5200_FATAL_SLICETIMER_0_IRQ_INSTALL,
71  MPC5200_FATAL_SLICETIMER_1_IRQ_INSTALL,
72  MPC5200_FATAL_TM27_IRQ_INSTALL,
73  MPC5200_FATAL_MSCAN_A_INIT,
74  MPC5200_FATAL_MSCAN_B_INIT,
75  MPC5200_FATAL_MSCAN_A_SET_MODE,
76  MPC5200_FATAL_MSCAN_B_SET_MODE,
77  MPC5200_FATAL_ATA_DISK_IO_INIT,
78  MPC5200_FATAL_ATA_DISK_CREATE,
79  MPC5200_FATAL_ATA_DMA_SINGLE_IRQ_INSTALL,
80  MPC5200_FATAL_ATA_LOCK_CREATE,
81  MPC5200_FATAL_ATA_LOCK_DESTROY,
82
83  /* MPC55XX fatal codes */
84  MPC55XX_FATAL_FMPLL_LOCK = BSP_FATAL_CODE_BLOCK(5),
85  MPC55XX_FATAL_CLOCK_EMIOS_IRQ_INSTALL,
86  MPC55XX_FATAL_CLOCK_EMIOS_PRESCALER,
87  MPC55XX_FATAL_CLOCK_EMIOS_INTERVAL,
88  MPC55XX_FATAL_CLOCK_PIT_IRQ_INSTALL,
89  MPC55XX_FATAL_CONSOLE_GENERIC_COUNT,
90  MPC55XX_FATAL_CONSOLE_GENERIC_REGISTER,
91  MPC55XX_FATAL_CONSOLE_GENERIC_REGISTER_CONSOLE,
92  MPC55XX_FATAL_CONSOLE_ESCI_BAUD,
93  MPC55XX_FATAL_CONSOLE_ESCI_ATTRIBUTES,
94  MPC55XX_FATAL_CONSOLE_ESCI_IRQ_INSTALL,
95  MPC55XX_FATAL_CONSOLE_LINFLEX_BAUD,
96  MPC55XX_FATAL_CONSOLE_LINFLEX_ATTRIBUTES,
97  MPC55XX_FATAL_CONSOLE_LINFLEX_RX_IRQ_INSTALL,
98  MPC55XX_FATAL_CONSOLE_LINFLEX_TX_IRQ_INSTALL,
99  MPC55XX_FATAL_CONSOLE_LINFLEX_ERR_IRQ_INSTALL,
100  MPC55XX_FATAL_CONSOLE_LINFLEX_RX_IRQ_REMOVE,
101  MPC55XX_FATAL_CONSOLE_LINFLEX_TX_IRQ_REMOVE,
102  MPC55XX_FATAL_CONSOLE_LINFLEX_ERR_IRQ_REMOVE,
103  MPC55XX_FATAL_EDMA_IRQ_INSTALL,
104  MPC55XX_FATAL_EDMA_IRQ_REMOVE,
105
106  /* MRM332 fatal codes */
107  MRM332_FATAL_SPURIOUS_INTERRUPT = BSP_FATAL_CODE_BLOCK(6),
108
109  /* PowerPC fatal codes */
110  PPC_FATAL_EXCEPTION_INITIALIZATION = BSP_FATAL_CODE_BLOCK(7),
111
112  /* Libchip fatal codes */
113  DWMAC_FATAL_TOO_MANY_RBUFS_CONFIGURED = BSP_FATAL_CODE_BLOCK(8),
114
115  /* ARM fatal codes */
116  ARM_FATAL_L2C_310_UNEXPECTED_ID = BSP_FATAL_CODE_BLOCK(9),
117  ARM_FATAL_L2C_310_UNEXPECTED_NUM_WAYS,
118  ARM_FATAL_L2C_310_EXCLUSIVE_CONFIG,
119
120  /* QorIQ fatal codes */
121  QORIQ_FATAL_SMP_IPI_HANDLER_INSTALL = BSP_FATAL_CODE_BLOCK(10),
122  QORIQ_FATAL_FDT_NO_BUS_FREQUENCY,
123  QORIQ_FATAL_FDT_NO_CLOCK_FREQUENCY,
124  QORIQ_FATAL_FDT_NO_TIMEBASE_FREQUENCY,
125  QORIQ_FATAL_RESTART_FAILED,
126  QORIQ_FATAL_RESTART_INSTALL_INTERRUPT,
127  QORIQ_FATAL_RESTART_INTERRUPT_FAILED,
128
129  /* ATSAM fatal codes */
130  ATSAM_FATAL_XDMA_IRQ_INSTALL = BSP_FATAL_CODE_BLOCK(11)
131} bsp_fatal_code;
132
133RTEMS_NO_RETURN static inline void
134bsp_fatal( bsp_fatal_code code )
135{
136  rtems_fatal( RTEMS_FATAL_SOURCE_BSP, (rtems_fatal_code) code );
137}
138
139#ifdef __cplusplus
140}
141#endif /* __cplusplus */
142
143#endif /* LIBBSP_SHARED_BSP_FATAL_H */
Note: See TracBrowser for help on using the repository browser.