82 lines
2.5 KiB
C
82 lines
2.5 KiB
C
|
/* SPARClite defs
|
||
|
*
|
||
|
* Copyright (c) 1995 Cygnus Support
|
||
|
*
|
||
|
* The authors hereby grant permission to use, copy, modify, distribute,
|
||
|
* and license this software and its documentation for any purpose, provided
|
||
|
* that existing copyright notices are retained in all copies and that this
|
||
|
* notice is included verbatim in any distributions. No written agreement,
|
||
|
* license, or royalty fee is required for any of the authorized uses.
|
||
|
* Modifications to this software may be copyrighted by their authors
|
||
|
* and need not follow the licensing terms described here, provided that
|
||
|
* the new terms are clearly indicated on the first page of each file where
|
||
|
* they apply.
|
||
|
*/
|
||
|
|
||
|
/* Macros for reading and writing to arbitrary address spaces. Note that ASI
|
||
|
must be a constant (sorry, but the SPARC can only specify ASIs as part of an
|
||
|
instruction. */
|
||
|
|
||
|
#define read_asi(ASI, LOC) \
|
||
|
({ \
|
||
|
unsigned int val; \
|
||
|
__asm__ volatile ("lda [%r1]%2,%0" : "=r" (val) : "rJ" (LOC), "I" (ASI)); \
|
||
|
val; \
|
||
|
})
|
||
|
|
||
|
#define write_asi(ASI, LOC, VAL) \
|
||
|
__asm__ volatile ("sta %0,[%r1]%2" : : "r" (VAL), "rJ" (LOC), "I" (ASI))
|
||
|
|
||
|
/* Use this when modifying registers that cause memory to be modified. This
|
||
|
will cause GCC to reload all values after this point. */
|
||
|
|
||
|
#define write_asi_volatile(ASI, LOC, VAL) \
|
||
|
__asm__ volatile ("sta %0,[%r1]%2" : : "r" (VAL), "rJ" (LOC), "I" (ASI) \
|
||
|
: "memory")
|
||
|
|
||
|
/* Read the PSR (processor state register). */
|
||
|
|
||
|
#define read_psr() \
|
||
|
({ \
|
||
|
unsigned int psr; \
|
||
|
__asm__ ("mov %%psr, %0" : "=r" (psr)); \
|
||
|
psr; \
|
||
|
})
|
||
|
|
||
|
/* Write the PSR. */
|
||
|
|
||
|
#define write_psr(VAL) \
|
||
|
__asm__ ("mov %0, %%psr \n nop \n nop \n nop" : : "r" (VAL))
|
||
|
|
||
|
/* Read the specified Ancillary State Register. */
|
||
|
|
||
|
#define read_asr(REG) read_asr1(REG)
|
||
|
#define read_asr1(REG) \
|
||
|
({ \
|
||
|
unsigned int val; \
|
||
|
__asm__ ("rd %%asr" #REG ",%0" : "=r" (val)); \
|
||
|
val; \
|
||
|
})
|
||
|
|
||
|
/* Write the specified Ancillary State Register. */
|
||
|
|
||
|
#define write_asr(REG, VAL) write_asr1(REG, VAL)
|
||
|
#define write_asr1(REG, VAL) \
|
||
|
__asm__ ("wr %0, 0, %%asr" #REG : : "r" (VAL))
|
||
|
|
||
|
/* Set window size for window overflow and underflow trap handlers. Better to
|
||
|
do this at at compile time than to calculate them at compile time each time
|
||
|
we get a window overflow/underflow trap. */
|
||
|
|
||
|
#ifdef SL933
|
||
|
asm ("__WINSIZE=6");
|
||
|
#else
|
||
|
asm ("__WINSIZE=8");
|
||
|
#endif
|
||
|
|
||
|
#define PSR_INIT 0x10c0 /* Disable traps, set s and ps */
|
||
|
#define TBR_INIT 0
|
||
|
#define WIM_INIT 2
|
||
|
#define STACK_SIZE 16 * 1024
|
||
|
|