source: rtems/c/src/lib/libbsp/arm/gdbarmsim/include/swi.h @ 0e8cfdef

4.115
Last change on this file since 0e8cfdef was 0e8cfdef, checked in by Chirayu Desai <cdesai@…>, on 12/07/13 at 14:04:07

arm: gdbarmsim: Add doxygen

  • Property mode set to 100644
File size: 3.1 KB
Line 
1/**
2 * @file
3 *
4 * @ingroup arm_gdbarmsim
5 *
6 * @brief Software interrupt definitions.
7 */
8
9/*
10 *  Copied from libgloss 1 Oct 2009.
11 *  Minor modifications to work with RTEMS.
12 */
13
14/* SWI numbers for RDP (Demon) monitor.  */
15#define SWI_WriteC                 0x0
16#define SWI_Write0                 0x2
17#define SWI_ReadC                  0x4
18#define SWI_CLI                    0x5
19#define SWI_GetEnv                 0x10
20#define SWI_Exit                   0x11
21#define SWI_EnterOS                0x16
22
23#define SWI_GetErrno               0x60
24#define SWI_Clock                  0x61
25#define SWI_Time                   0x63
26#define SWI_Remove                 0x64
27#define SWI_Rename                 0x65
28#define SWI_Open                   0x66
29
30#define SWI_Close                  0x68
31#define SWI_Write                  0x69
32#define SWI_Read                   0x6a
33#define SWI_Seek                   0x6b
34#define SWI_Flen                   0x6c
35
36#define SWI_IsTTY                  0x6e
37#define SWI_TmpNam                 0x6f
38#define SWI_InstallHandler         0x70
39#define SWI_GenerateError          0x71
40
41
42/* Now the SWI numbers and reason codes for RDI (Angel) monitors.  */
43#define AngelSWI_ARM                    0x123456
44#ifdef __thumb__
45#define AngelSWI                        0xAB
46#else
47#define AngelSWI                        AngelSWI_ARM
48#endif
49/* For Thumb-2 code use the BKPT instruction instead of SWI.  */
50#ifdef __thumb2__
51#define AngelSWIInsn                    "bkpt"
52#define AngelSWIAsm                     bkpt
53#else
54#define AngelSWIInsn                    "swi"
55#define AngelSWIAsm                     swi
56#endif
57
58/* The reason codes:  */
59#define AngelSWI_Reason_Open            0x01
60#define AngelSWI_Reason_Close           0x02
61#define AngelSWI_Reason_WriteC          0x03
62#define AngelSWI_Reason_Write0          0x04
63#define AngelSWI_Reason_Write           0x05
64#define AngelSWI_Reason_Read            0x06
65#define AngelSWI_Reason_ReadC           0x07
66#define AngelSWI_Reason_IsTTY           0x09
67#define AngelSWI_Reason_Seek            0x0A
68#define AngelSWI_Reason_FLen            0x0C
69#define AngelSWI_Reason_TmpNam          0x0D
70#define AngelSWI_Reason_Remove          0x0E
71#define AngelSWI_Reason_Rename          0x0F
72#define AngelSWI_Reason_Clock           0x10
73#define AngelSWI_Reason_Time            0x11
74#define AngelSWI_Reason_System          0x12
75#define AngelSWI_Reason_Errno           0x13
76#define AngelSWI_Reason_GetCmdLine      0x15
77#define AngelSWI_Reason_HeapInfo        0x16
78#define AngelSWI_Reason_EnterSVC        0x17
79#define AngelSWI_Reason_ReportException 0x18
80#define ADP_Stopped_ApplicationExit     ((2 << 16) + 38)
81#define ADP_Stopped_RunTimeError        ((2 << 16) + 35)
82
83#if defined(ARM_RDI_MONITOR) && !defined(__ASSEMBLER__)
84
85static inline int
86do_AngelSWI (int reason, void * arg)
87{
88  int value;
89  __asm__ volatile ("mov r0, %1; mov r1, %2; " AngelSWIInsn " %a3; mov %0, r0"
90       : "=r" (value) /* Outputs */
91       : "r" (reason), "r" (arg), "i" (AngelSWI) /* Inputs */
92       : "r0", "r1", "r2", "r3", "ip", "lr", "memory", "cc"
93                /* Clobbers r0 and r1, and lr if in supervisor mode */);
94                /* Accordingly to page 13-77 of ARM DUI 0040D other registers
95                   can also be clobbered.  Some memory positions may also be
96                   changed by a system call, so they should not be kept in
97                   registers. Note: we are assuming the manual is right and
98                   Angel is respecting the APCS.  */
99  return value;
100}
101
102#endif
Note: See TracBrowser for help on using the repository browser.