source: rtems/cpukit/score/cpu/powerpc/include/rtems/asm.h @ bc16c65

5
Last change on this file since bc16c65 was 2afb22b, checked in by Chris Johns <chrisj@…>, on 12/23/17 at 07:18:56

Remove make preinstall

A speciality of the RTEMS build system was the make preinstall step. It
copied header files from arbitrary locations into the build tree. The
header files were included via the -Bsome/build/tree/path GCC command
line option.

This has at least seven problems:

  • The make preinstall step itself needs time and disk space.
  • Errors in header files show up in the build tree copy. This makes it hard for editors to open the right file to fix the error.
  • There is no clear relationship between source and build tree header files. This makes an audit of the build process difficult.
  • The visibility of all header files in the build tree makes it difficult to enforce API barriers. For example it is discouraged to use BSP-specifics in the cpukit.
  • An introduction of a new build system is difficult.
  • Include paths specified by the -B option are system headers. This may suppress warnings.
  • The parallel build had sporadic failures on some hosts.

This patch removes the make preinstall step. All installed header
files are moved to dedicated include directories in the source tree.
Let @RTEMS_CPU@ be the target architecture, e.g. arm, powerpc, sparc,
etc. Let @RTEMS_BSP_FAMILIY@ be a BSP family base directory, e.g.
erc32, imx, qoriq, etc.

The new cpukit include directories are:

  • cpukit/include
  • cpukit/score/cpu/@RTEMS_CPU@/include
  • cpukit/libnetworking

The new BSP include directories are:

  • bsps/include
  • bsps/@RTEMS_CPU@/include
  • bsps/@RTEMS_CPU@/@RTEMS_BSP_FAMILIY@/include

There are build tree include directories for generated files.

The include directory order favours the most general header file, e.g.
it is not possible to override general header files via the include path
order.

The "bootstrap -p" option was removed. The new "bootstrap -H" option
should be used to regenerate the "headers.am" files.

Update #3254.

  • Property mode set to 100644
File size: 7.5 KB
Line 
1/**
2 * @file
3 *
4 * @brief Address the Problems Caused by Incompatible Flavor of
5 * Assemblers and Toolsets
6 *
7 * This include file attempts to address the problems
8 * caused by incompatible flavors of assemblers and
9 * toolsets.  It primarily addresses variations in the
10 * use of leading underscores on symbols and the requirement
11 * that register names be preceded by a %.
12 *
13 * NOTE: The spacing in the use of these macros
14 *       is critical to them working as advertised.
15 */
16
17/*
18 *  COPYRIGHT:
19 *
20 *  This file is based on similar code found in newlib available
21 *  from ftp.cygnus.com.  The file which was used had no copyright
22 *  notice.  This file is freely distributable as long as the source
23 *  of the file is noted.  This file is:
24 *
25 *  COPYRIGHT (c) 1995.
26 *  i-cubed ltd.
27 *
28 *  COPYRIGHT (c) 1994.
29 *  On-Line Applications Research Corporation (OAR).
30 */
31
32#ifndef _RTEMS_ASM_H
33#define _RTEMS_ASM_H
34
35/*
36 *  Indicate we are in an assembly file and get the basic CPU definitions.
37 */
38
39#ifndef ASM
40#define ASM
41#endif
42#include <rtems/score/cpuopts.h>
43#include <rtems/score/powerpc.h>
44
45/*
46 *  Recent versions of GNU cpp define variables which indicate the
47 *  need for underscores and percents.  If not using GNU cpp or
48 *  the version does not support this, then you will obviously
49 *  have to define these as appropriate.
50 */
51
52#ifndef __USER_LABEL_PREFIX__
53#define __USER_LABEL_PREFIX__
54#endif
55
56#ifndef __REGISTER_PREFIX__
57#define __REGISTER_PREFIX__
58#endif
59
60#ifndef __FLOAT_REGISTER_PREFIX__
61#define __FLOAT_REGISTER_PREFIX__  __REGISTER_PREFIX__
62#endif
63
64#ifndef __PROC_LABEL_PREFIX__
65#define __PROC_LABEL_PREFIX__  __USER_LABEL_PREFIX__
66#endif
67
68#include <rtems/concat.h>
69
70/* Use the right prefix for global labels.  */
71
72#define SYM(x) CONCAT1 (__USER_LABEL_PREFIX__, x)
73
74/* Use the right prefix for procedure labels.  */
75
76#define PROC(x) CONCAT1 (__PROC_LABEL_PREFIX__, x)
77
78/* Use the right prefix for registers.  */
79
80#define REG(x) CONCAT1 (__REGISTER_PREFIX__, x)
81
82/* Use the right prefix for floating point registers.  */
83
84#define FREG(x) CONCAT1 (__FLOAT_REGISTER_PREFIX__, x)
85
86/*
87 *  define macros for all of the registers on this CPU
88 *
89 *  EXAMPLE:     #define d0 REG (d0)
90 */
91#define r0 REG(0)
92#define r1 REG(1)
93#define r2 REG(2)
94#define r3 REG(3)
95#define r4 REG(4)
96#define r5 REG(5)
97#define r6 REG(6)
98#define r7 REG(7)
99#define r8 REG(8)
100#define r9 REG(9)
101#define r10 REG(10)
102#define r11 REG(11)
103#define r12 REG(12)
104#define r13 REG(13)
105#define r14 REG(14)
106#define r15 REG(15)
107#define r16 REG(16)
108#define r17 REG(17)
109#define r18 REG(18)
110#define r19 REG(19)
111#define r20 REG(20)
112#define r21 REG(21)
113#define r22 REG(22)
114#define r23 REG(23)
115#define r24 REG(24)
116#define r25 REG(25)
117#define r26 REG(26)
118#define r27 REG(27)
119#define r28 REG(28)
120#define r29 REG(29)
121#define r30 REG(30)
122#define r31 REG(31)
123#define f0 FREG(0)
124#define f1 FREG(1)
125#define f2 FREG(2)
126#define f3 FREG(3)
127#define f4 FREG(4)
128#define f5 FREG(5)
129#define f6 FREG(6)
130#define f7 FREG(7)
131#define f8 FREG(8)
132#define f9 FREG(9)
133#define f10 FREG(10)
134#define f11 FREG(11)
135#define f12 FREG(12)
136#define f13 FREG(13)
137#define f14 FREG(14)
138#define f15 FREG(15)
139#define f16 FREG(16)
140#define f17 FREG(17)
141#define f18 FREG(18)
142#define f19 FREG(19)
143#define f20 FREG(20)
144#define f21 FREG(21)
145#define f22 FREG(22)
146#define f23 FREG(23)
147#define f24 FREG(24)
148#define f25 FREG(25)
149#define f26 FREG(26)
150#define f27 FREG(27)
151#define f28 FREG(28)
152#define f29 FREG(29)
153#define f30 FREG(30)
154#define f31 FREG(31)
155#define v0 0
156#define v1 1
157#define v2 2
158#define v3 3
159#define v4 4
160#define v5 5
161#define v6 6
162#define v7 7
163#define v8 8
164#define v9 9
165#define v10 10
166#define v11 11
167#define v12 12
168#define v13 13
169#define v14 14
170#define v15 15
171#define v16 16
172#define v17 17
173#define v18 18
174#define v19 19
175#define v20 20
176#define v21 21
177#define v22 22
178#define v23 23
179#define v24 24
180#define v25 25
181#define v26 26
182#define v27 27
183#define v28 28
184#define v29 29
185#define v30 30
186#define v31 31
187
188/*
189 * Some special purpose registers (SPRs).
190 */
191#define srr0    0x01a
192#define srr1    0x01b
193#define srr2    0x3de /* IBM 400 series only */
194#define srr3    0x3df /* IBM 400 series only */
195#define csrr0   58 /* Book E */
196#define csrr1   59 /* Book E */
197#define mcsrr0  570 /* e500 */
198#define mcsrr1  571 /* e500 */
199#define dsrr0   574 /* e200 */
200#define dsrr1   575 /* e200 */
201
202#define sprg0   0x110
203#define sprg1   0x111
204#define sprg2   0x112
205#define sprg3   0x113
206#define sprg4   276
207#define sprg5   277
208#define sprg6   278
209#define sprg7   279
210
211#define usprg0  256
212
213#define dar     0x013   /* Data Address Register */
214#define dec     0x016   /* Decrementer Register */
215
216#if defined(ppc403) || defined(ppc405)
217/* the following SPR/DCR registers exist only in IBM 400 series */
218#define dear    0x3d5
219#define evpr    0x3d6   /* SPR: exception vector prefix register   */
220#define iccr    0x3fb   /* SPR: instruction cache control reg.     */
221#define dccr    0x3fa   /* SPR: data cache control reg.            */
222
223#if defined (ppc403)
224#define exisr   0x040   /* DCR: external interrupt status register */
225#define exier   0x042   /* DCR: external interrupt enable register */
226#endif /* ppc403 */
227#if defined(ppc405)
228#define exisr   0x0C0   /* DCR: external interrupt status register */
229#define exier   0x0C2   /* DCR: external interrupt enable register */
230#endif /* ppc405 */
231
232#define br0     0x080   /* DCR: memory bank register 0             */
233#define br1     0x081   /* DCR: memory bank register 1             */
234#define br2     0x082   /* DCR: memory bank register 2             */
235#define br3     0x083   /* DCR: memory bank register 3             */
236#define br4     0x084   /* DCR: memory bank register 4             */
237#define br5     0x085   /* DCR: memory bank register 5             */
238#define br6     0x086   /* DCR: memory bank register 6             */
239#define br7     0x087   /* DCR: memory bank register 7             */
240
241/* end of IBM400 series register definitions */
242
243#elif defined(mpc555)
244/* The following registers are for the MPC5xx */
245#define eie     0x050   /* External Interrupt Enable Register */
246#define eid     0x051   /* External Interrupt Disable Register */
247#define nri     0x052   /* Non-Recoverable Interrupt Register */
248
249#elif defined(mpc860) || defined(mpc821)
250/* The following registers are for the MPC8x0 */
251#define der     0x095   /* Debug Enable Register */
252#define ictrl   0x09E   /* Instruction Support Control Register */
253#define immr    0x27E   /* Internal Memory Map Register */
254/* end of MPC8x0 registers */
255#endif
256
257/*
258 *  Following must be tailor for a particular flavor of the C compiler.
259 *  They may need to put underscores in front of the symbols.
260 */
261
262#define PUBLIC_VAR(sym) .globl SYM (sym)
263#define EXTERN_VAR(sym) .extern SYM (sym)
264#define PUBLIC_PROC(sym) .globl PROC (sym)
265#define EXTERN_PROC(sym) .extern PROC (sym)
266
267/* Other potentially assembler specific operations */
268#if PPC_ASM == PPC_ASM_ELF
269#define ALIGN(n,p)      .align  p
270#define DESCRIPTOR(x)   \
271        .section .descriptors,"aw";     \
272        PUBLIC_VAR (x);                 \
273SYM (x):;                               \
274        .long   PROC (x);               \
275        .long   s.got;                  \
276        .long   0
277
278#define EXT_SYM_REF(x)  .long x
279#define EXT_PROC_REF(x) .long x
280
281/*
282 *  Define macros to handle section beginning and ends.
283 */
284
285#define BEGIN_CODE_DCL .text
286#define END_CODE_DCL
287#define BEGIN_DATA_DCL .data
288#define END_DATA_DCL
289#define BEGIN_CODE .text
290#define END_CODE
291#define BEGIN_DATA .data
292#define END_DATA
293#define BEGIN_BSS  .bss
294#define END_BSS
295#define END
296
297#else
298#error "PPC_ASM_TYPE is not properly defined"
299#endif
300#ifndef PPC_ASM
301#error "PPC_ASM_TYPE is not properly defined"
302#endif
303
304#if defined(__powerpc64__)
305#define PPC64_NOP_FOR_LINKER_TOC_POINTER_RESTORE nop
306#else
307#define PPC64_NOP_FOR_LINKER_TOC_POINTER_RESTORE
308#endif
309
310#endif
Note: See TracBrowser for help on using the repository browser.