OpenCores
URL https://opencores.org/ocsvn/or1k_old/or1k_old/trunk

Subversion Repositories or1k_old

[/] [or1k_old/] [trunk/] [uclinux/] [uClinux-2.0.x/] [include/] [asm-sparc/] [psr.h] - Blame information for rev 1782

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 199 simons
/* $Id: psr.h,v 1.1.1.1 2001-09-10 07:44:43 simons Exp $
2
 * psr.h: This file holds the macros for masking off various parts of
3
 *        the processor status register on the Sparc. This is valid
4
 *        for Version 8. On the V9 this is renamed to the PSTATE
5
 *        register and its members are accessed as fields like
6
 *        PSTATE.PRIV for the current CPU privilege level.
7
 *
8
 * Copyright (C) 1994 David S. Miller (davem@caip.rutgers.edu)
9
 */
10
 
11
#ifndef __LINUX_SPARC_PSR_H
12
#define __LINUX_SPARC_PSR_H
13
 
14
/* The Sparc PSR fields are laid out as the following:
15
 *
16
 *  ------------------------------------------------------------------------
17
 *  | impl  | vers  | icc   | resv  | EC | EF | PIL  | S | PS | ET |  CWP  |
18
 *  | 31-28 | 27-24 | 23-20 | 19-14 | 13 | 12 | 11-8 | 7 | 6  | 5  |  4-0  |
19
 *  ------------------------------------------------------------------------
20
 */
21
#define PSR_CWP     0x0000001f         /* current window pointer     */
22
#define PSR_ET      0x00000020         /* enable traps field         */
23
#define PSR_PS      0x00000040         /* previous privilege level   */
24
#define PSR_S       0x00000080         /* current privilege level    */
25
#define PSR_PIL     0x00000f00         /* processor interrupt level  */
26
#define PSR_EF      0x00001000         /* enable floating point      */
27
#define PSR_EC      0x00002000         /* enable co-processor        */
28
#define PSR_LE      0x00008000         /* SuperSparcII little-endian */
29
#define PSR_ICC     0x00f00000         /* integer condition codes    */
30
#define PSR_C       0x00100000         /* carry bit                  */
31
#define PSR_V       0x00200000         /* overflow bit               */
32
#define PSR_Z       0x00400000         /* zero bit                   */
33
#define PSR_N       0x00800000         /* negative bit               */
34
#define PSR_VERS    0x0f000000         /* cpu-version field          */
35
#define PSR_IMPL    0xf0000000         /* cpu-implementation field   */
36
 
37
#ifdef __KERNEL__
38
 
39
#ifndef __ASSEMBLY__
40
/* Get the %psr register. */
41
extern inline unsigned int get_psr(void)
42
{
43
        unsigned int psr;
44
        __asm__ __volatile__("rd %%psr, %0\n\t" :
45
                             "=r" (psr));
46
        return psr;
47
}
48
 
49
extern inline void put_psr(unsigned int new_psr)
50
{
51
        __asm__ __volatile__("wr %0, 0x0, %%psr\n\t"
52
                             "nop; nop; nop;\n\t" : :
53
                             "r" (new_psr));
54
}
55
 
56
/* Get the %fsr register.  Be careful, make sure the floating point
57
 * enable bit is set in the %psr when you execute this or you will
58
 * incur a trap.
59
 */
60
 
61
extern unsigned int fsr_storage;
62
 
63
extern inline unsigned int get_fsr(void)
64
{
65
        unsigned int fsr = 0;
66
 
67
        __asm__ __volatile__("st %%fsr, %1\n\t"
68
                             "ld %1, %0\n\t" :
69
                             "=r" (fsr) :
70
                             "m" (fsr_storage));
71
        return fsr;
72
}
73
 
74
#endif /* !(__ASSEMBLY__) */
75
 
76
#endif /* (__KERNEL__) */
77
 
78
#endif /* !(__LINUX_SPARC_PSR_H) */

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.