source: rtems/c/src/lib/libcpu/powerpc/mpc55xx/include/emios.h @ edb1dd83

4.115
Last change on this file since edb1dd83 was edb1dd83, checked in by Sebastian Huber <sebastian.huber@…>, on 11/08/11 at 10:05:50

2011-11-08 Sebastian Huber <sebastian.huber@…>

  • new-exceptions/bspsupport/ppc_exc_async_normal.S: Bugfix for MPC5674F. Use it for all to be safe.
  • mpc55xx/include/emios.h: Fixed eMIOS module count.
  • mpc55xx/include/irq.h: Fixed CAN vector numbers. BSP_INTERRUPT_HANDLER_TABLE_SIZE is now a BSP option.
  • Property mode set to 100644
File size: 6.9 KB
Line 
1/**
2 * @file
3 *
4 * @ingroup mpc55xx
5 *
6 * @brief Enhanced Modular Input Output Subsystem (eMIOS).
7 */
8
9/*
10 * Copyright (c) 2009
11 * embedded brains GmbH
12 * Obere Lagerstr. 30
13 * D-82178 Puchheim
14 * Germany
15 * <rtems@embedded-brains.de>
16 *
17 * The license and distribution terms for this file may be
18 * found in the file LICENSE in this distribution or at
19 * http://www.rtems.com/license/LICENSE.
20 */
21
22#ifndef LIBCPU_POWERPC_MPC55XX_EMIOS_H
23#define LIBCPU_POWERPC_MPC55XX_EMIOS_H
24
25#include <stdbool.h>
26#include <stdint.h>
27
28#include <rtems.h>
29#include <rtems/chain.h>
30
31#include <bspopts.h>
32
33#ifdef __cplusplus
34extern "C" {
35#endif /* __cplusplus */
36
37/**
38 * @name eMIOS - Modes
39 *
40 * @{
41 */
42
43#define MPC55XX_EMIOS_MODE_GPIO_INPUT 0U
44#define MPC55XX_EMIOS_MODE_GPIO_OUTPUT 1U
45#define MPC55XX_EMIOS_MODE_SAIC 2U
46#define MPC55XX_EMIOS_MODE_SAOC 3U
47#define MPC55XX_EMIOS_MODE_IPWM 4U
48#define MPC55XX_EMIOS_MODE_IPM 5U
49#define MPC55XX_EMIOS_MODE_DAOC_SECOND 6U
50#define MPC55XX_EMIOS_MODE_DAOC_BOTH 7U
51#define MPC55XX_EMIOS_MODE_PEA_ACCU_CONT 8U
52#define MPC55XX_EMIOS_MODE_PEA_ACCU_SINGLE 9U
53#define MPC55XX_EMIOS_MODE_PEA_COUNT_CONT 10U
54#define MPC55XX_EMIOS_MODE_PEA_COUNT_SINGLE 11U
55#define MPC55XX_EMIOS_MODE_QDEC_COUNT_DIR 12U
56#define MPC55XX_EMIOS_MODE_QDEC_PHASE 13U
57#define MPC55XX_EMIOS_MODE_WPTA 14U
58#define MPC55XX_EMIOS_MODE_RESERVED_15 15U
59#define MPC55XX_EMIOS_MODE_MC_UP_INT_CLK 16U
60#define MPC55XX_EMIOS_MODE_MC_UP_EXT_CLK 17U
61#define MPC55XX_EMIOS_MODE_RESERVED_18 18U
62#define MPC55XX_EMIOS_MODE_RESERVED_19 19U
63#define MPC55XX_EMIOS_MODE_MC_UP_DOWN_INT_CLK 20U
64#define MPC55XX_EMIOS_MODE_MC_UP_DOWN_EXT_CLK 21U
65#define MPC55XX_EMIOS_MODE_MC_UP_DOWN_CHANGE_INT_CLK 22U
66#define MPC55XX_EMIOS_MODE_MC_UP_DOWN_CHANGE_EXT_CLK 23U
67#define MPC55XX_EMIOS_MODE_OPWFM_B_IMMEDIATE 24U
68#define MPC55XX_EMIOS_MODE_OPWFM_B_NEXT_PERIOD 25U
69#define MPC55XX_EMIOS_MODE_OPWFM_AB_IMMEDIATE 26U
70#define MPC55XX_EMIOS_MODE_OPWFM_AB_NEXT_PERIOD 27U
71#define MPC55XX_EMIOS_MODE_OPWMC_TRAIL_TRAIL 28U
72#define MPC55XX_EMIOS_MODE_OPWMC_TRAIL_LEAD 29U
73#define MPC55XX_EMIOS_MODE_OPWMC_BOTH_TRAIL 30U
74#define MPC55XX_EMIOS_MODE_OPWMC_BOTH_LEAD 31U
75#define MPC55XX_EMIOS_MODE_OPWM_B_IMMEDIATE 32U
76#define MPC55XX_EMIOS_MODE_OPWM_B_NEXT_PERIOD 33U
77#define MPC55XX_EMIOS_MODE_OPWM_AB_IMMEDIATE 34U
78#define MPC55XX_EMIOS_MODE_OPWM_AB_NEXT_PERIOD 35U
79#define MPC55XX_EMIOS_MODE_RESERVED_36 36U
80#define MPC55XX_EMIOS_MODE_RESERVED_37 37U
81#define MPC55XX_EMIOS_MODE_RESERVED_38 38U
82#define MPC55XX_EMIOS_MODE_RESERVED_39 39U
83#define MPC55XX_EMIOS_MODE_RESERVED_40 40U
84#define MPC55XX_EMIOS_MODE_RESERVED_41 41U
85#define MPC55XX_EMIOS_MODE_RESERVED_42 42U
86#define MPC55XX_EMIOS_MODE_RESERVED_43 43U
87#define MPC55XX_EMIOS_MODE_RESERVED_44 44U
88#define MPC55XX_EMIOS_MODE_RESERVED_45 45U
89#define MPC55XX_EMIOS_MODE_RESERVED_46 46U
90#define MPC55XX_EMIOS_MODE_RESERVED_47 47U
91#define MPC55XX_EMIOS_MODE_RESERVED_48 48U
92#define MPC55XX_EMIOS_MODE_RESERVED_49 49U
93#define MPC55XX_EMIOS_MODE_RESERVED_50 50U
94#define MPC55XX_EMIOS_MODE_RESERVED_51 51U
95#define MPC55XX_EMIOS_MODE_RESERVED_52 52U
96#define MPC55XX_EMIOS_MODE_RESERVED_53 53U
97#define MPC55XX_EMIOS_MODE_RESERVED_54 54U
98#define MPC55XX_EMIOS_MODE_RESERVED_55 55U
99#define MPC55XX_EMIOS_MODE_RESERVED_56 56U
100#define MPC55XX_EMIOS_MODE_RESERVED_57 57U
101#define MPC55XX_EMIOS_MODE_RESERVED_58 58U
102#define MPC55XX_EMIOS_MODE_RESERVED_59 59U
103#define MPC55XX_EMIOS_MODE_RESERVED_60 60U
104#define MPC55XX_EMIOS_MODE_RESERVED_61 61U
105#define MPC55XX_EMIOS_MODE_RESERVED_62 62U
106#define MPC55XX_EMIOS_MODE_RESERVED_63 63U
107#define MPC55XX_EMIOS_MODE_RESERVED_64 64U
108#define MPC55XX_EMIOS_MODE_RESERVED_65 65U
109#define MPC55XX_EMIOS_MODE_RESERVED_66 66U
110#define MPC55XX_EMIOS_MODE_RESERVED_67 67U
111#define MPC55XX_EMIOS_MODE_RESERVED_68 68U
112#define MPC55XX_EMIOS_MODE_RESERVED_69 69U
113#define MPC55XX_EMIOS_MODE_RESERVED_70 70U
114#define MPC55XX_EMIOS_MODE_RESERVED_71 71U
115#define MPC55XX_EMIOS_MODE_RESERVED_72 72U
116#define MPC55XX_EMIOS_MODE_RESERVED_73 73U
117#define MPC55XX_EMIOS_MODE_RESERVED_74 74U
118#define MPC55XX_EMIOS_MODE_RESERVED_75 75U
119#define MPC55XX_EMIOS_MODE_RESERVED_76 76U
120#define MPC55XX_EMIOS_MODE_RESERVED_77 77U
121#define MPC55XX_EMIOS_MODE_RESERVED_78 78U
122#define MPC55XX_EMIOS_MODE_RESERVED_79 79U
123#define MPC55XX_EMIOS_MODE_MCB_UP_INT_CLK 80U
124#define MPC55XX_EMIOS_MODE_MCB_UP_EXT_CLK 81U
125#define MPC55XX_EMIOS_MODE_RESERVED_82 82U
126#define MPC55XX_EMIOS_MODE_RESERVED_83 83U
127#define MPC55XX_EMIOS_MODE_MCB_UP_DOWN_ONE_INT_CLK 84U
128#define MPC55XX_EMIOS_MODE_MCB_UP_DOWN_ONE_EXT_CLK 85U
129#define MPC55XX_EMIOS_MODE_MCB_UP_DOWN_BOTH_INT_CLK 86U
130#define MPC55XX_EMIOS_MODE_MCB_UP_DOWN_BOTH_EXT_CLK 87U
131#define MPC55XX_EMIOS_MODE_OPWFMB_B 88U
132#define MPC55XX_EMIOS_MODE_RESERVED_89 89U
133#define MPC55XX_EMIOS_MODE_OPWFMB_AB 90U
134#define MPC55XX_EMIOS_MODE_RESERVED_91 91U
135#define MPC55XX_EMIOS_MODE_OPWMCB_TRAIL_TRAIL 92U
136#define MPC55XX_EMIOS_MODE_OPWMCB_TRAIL_LEAD 93U
137#define MPC55XX_EMIOS_MODE_OPWMCB_BOTH_TRAIL 94U
138#define MPC55XX_EMIOS_MODE_OPWMCB_BOTH_LEAD 95U
139#define MPC55XX_EMIOS_MODE_OPWMB_SECOND 96U
140#define MPC55XX_EMIOS_MODE_RESERVED_97 97U
141#define MPC55XX_EMIOS_MODE_OPWMB_BOTH 98U
142#define MPC55XX_EMIOS_MODE_RESERVED_99 99U
143#define MPC55XX_EMIOS_MODE_RESERVED_100 100U
144#define MPC55XX_EMIOS_MODE_RESERVED_101 101U
145#define MPC55XX_EMIOS_MODE_RESERVED_102 102U
146#define MPC55XX_EMIOS_MODE_RESERVED_103 103U
147#define MPC55XX_EMIOS_MODE_RESERVED_104 104U
148#define MPC55XX_EMIOS_MODE_RESERVED_105 105U
149#define MPC55XX_EMIOS_MODE_RESERVED_106 106U
150#define MPC55XX_EMIOS_MODE_RESERVED_107 107U
151#define MPC55XX_EMIOS_MODE_RESERVED_108 108U
152#define MPC55XX_EMIOS_MODE_RESERVED_109 109U
153#define MPC55XX_EMIOS_MODE_RESERVED_110 110U
154#define MPC55XX_EMIOS_MODE_RESERVED_111 111U
155#define MPC55XX_EMIOS_MODE_RESERVED_112 112U
156#define MPC55XX_EMIOS_MODE_RESERVED_113 113U
157#define MPC55XX_EMIOS_MODE_RESERVED_114 114U
158#define MPC55XX_EMIOS_MODE_RESERVED_115 115U
159#define MPC55XX_EMIOS_MODE_RESERVED_116 116U
160#define MPC55XX_EMIOS_MODE_RESERVED_117 117U
161#define MPC55XX_EMIOS_MODE_RESERVED_118 118U
162#define MPC55XX_EMIOS_MODE_RESERVED_119 119U
163#define MPC55XX_EMIOS_MODE_RESERVED_120 120U
164#define MPC55XX_EMIOS_MODE_RESERVED_121 121U
165#define MPC55XX_EMIOS_MODE_RESERVED_122 122U
166#define MPC55XX_EMIOS_MODE_RESERVED_123 123U
167#define MPC55XX_EMIOS_MODE_RESERVED_124 124U
168#define MPC55XX_EMIOS_MODE_RESERVED_125 125U
169#define MPC55XX_EMIOS_MODE_RESERVED_126 126U
170#define MPC55XX_EMIOS_MODE_RESERVED_127 127U
171
172/** @} */
173
174#if MPC55XX_CHIP_TYPE / 10 == 567
175  #define MPC55XX_EMIOS_CHANNEL_NUMBER 32U
176#else
177  #define MPC55XX_EMIOS_CHANNEL_NUMBER 24U
178#endif
179
180#define MPC55XX_EMIOS_VALUE_MAX 0x00ffffffU
181
182#define MPC55XX_EMIOS_IS_CHANNEL_VALID( c) \
183  ((unsigned) (c) < MPC55XX_EMIOS_CHANNEL_NUMBER)
184
185#define MPC55XX_EMIOS_IS_CHANNEL_INVALID( c) \
186  (!MPC55XX_EMIOS_IS_CHANNEL_VALID( c))
187
188void mpc55xx_emios_initialize( unsigned prescaler);
189
190unsigned mpc55xx_emios_global_prescaler( void);
191
192void mpc55xx_emios_set_global_prescaler( unsigned prescaler);
193
194#ifdef __cplusplus
195}
196#endif /* __cplusplus */
197
198#endif /* LIBCPU_POWERPC_MPC55XX_EMIOS_H */
Note: See TracBrowser for help on using the repository browser.