source: rtems/cpukit/score/cpu/sparc/rtems/asm.h @ b8ed8a9f

4.104.114.84.95
Last change on this file since b8ed8a9f was b8ed8a9f, checked in by Ralf Corsepius <ralf.corsepius@…>, on 11/21/04 at 08:25:23

2004-11-12 Ralf Corsepius <ralf.corsepius@…>

  • asm.h: Add doxygen preamble.
  • Property mode set to 100644
File size: 2.8 KB
Line 
1/**
2 * @file rtems/asm.h
3 *
4 *  This include file attempts to address the problems
5 *  caused by incompatible flavors of assemblers and
6 *  toolsets.  It primarily addresses variations in the
7 *  use of leading underscores on symbols and the requirement
8 *  that register names be preceded by a %.
9 */
10
11/*
12 *  NOTE: The spacing in the use of these macros
13 *        is critical to them working as advertised.
14 *
15 *  COPYRIGHT:
16 *
17 *  This file is based on similar code found in newlib available
18 *  from ftp.cygnus.com.  The file which was used had no copyright
19 *  notice.  This file is freely distributable as long as the source
20 *  of the file is noted.
21 *
22 *  $Id$
23 */
24
25#ifndef __SPARC_ASM_h
26#define __SPARC_ASM_h
27
28/*
29 *  Indicate we are in an assembly file and get the basic CPU definitions.
30 */
31
32#ifndef ASM
33#define ASM
34#endif
35
36#include <rtems/score/cpuopts.h>
37#include <rtems/score/cpu.h>
38
39/*
40 *  Recent versions of GNU cpp define variables which indicate the
41 *  need for underscores and percents.  If not using GNU cpp or
42 *  the version does not support this, then you will obviously
43 *  have to define these as appropriate.
44 */
45
46/* XXX __USER_LABEL_PREFIX__ and __REGISTER_PREFIX__ do not work on gcc 2.7.0 */
47/* XXX The following ifdef magic fixes the problem but results in a warning   */
48/* XXX when compiling assembly code.                                          */
49
50#ifndef __USER_LABEL_PREFIX__
51#define __USER_LABEL_PREFIX__ _
52#endif
53
54#ifndef __REGISTER_PREFIX__
55#define __REGISTER_PREFIX__
56#endif
57
58/* ANSI concatenation macros.  */
59
60#define CONCAT1(a, b) CONCAT2(a, b)
61#define CONCAT2(a, b) a ## b
62
63/* Use the right prefix for global labels.  */
64
65#define SYM(x) CONCAT1 (__USER_LABEL_PREFIX__, x)
66
67/* Use the right prefix for registers.  */
68
69#define REG(x) CONCAT1 (__REGISTER_PREFIX__, x)
70
71/*
72 *  define macros for all of the registers on this CPU
73 *
74 *  EXAMPLE:     #define d0 REG (d0)
75 */
76
77/*
78 *  Define macros to handle section beginning and ends.
79 */
80
81
82#define BEGIN_CODE_DCL .text
83#define END_CODE_DCL
84#define BEGIN_DATA_DCL .data
85#define END_DATA_DCL
86#define BEGIN_CODE .text
87#define END_CODE
88#define BEGIN_DATA
89#define END_DATA
90#define BEGIN_BSS
91#define END_BSS
92#define END
93
94/*
95 *  Following must be tailor for a particular flavor of the C compiler.
96 *  They may need to put underscores in front of the symbols.
97 */
98
99#define PUBLIC(sym) .globl SYM (sym)
100#define EXTERN(sym) .globl SYM (sym)
101
102/*
103 *  Entry for traps which jump to a programmer-specified trap handler.
104 */
105 
106#define TRAP(_vector, _handler)  \
107  mov   %psr, %l0 ; \
108  sethi %hi(_handler), %l4 ; \
109  jmp   %l4+%lo(_handler); \
110  mov   _vector, %l3
111
112/*
113 *  Used for the reset trap to avoid a supervisor instruction
114 */
115 
116#define RTRAP(_vector, _handler)  \
117  mov   %g0, %l0 ; \
118  sethi %hi(_handler), %l4 ; \
119  jmp   %l4+%lo(_handler); \
120  mov   _vector, %l3
121
122#endif
123/* end of include file */
Note: See TracBrowser for help on using the repository browser.