source: mainline/kernel/arch/mips32/include/arch/cp0.h@ 6ecf5b8

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 6ecf5b8 was 6ecf5b8, checked in by Vojtech Horky <vojtechhorky@…>, 13 years ago

Prevent compile-time symlinks in kernel

So far, architecture specific headers for kernel were in
kernel/arch/$ARCH/include directory.
From kernel sources, they were referenced as arch/header.h.

For example, file kernel/arch/$ARCH/include/whatever.h
was included with <arch/whatever.h>.

To allow that, a symbolic link with name `arch' pointing
to the correct `include/' was created during compilation.

This change adds one arch/ directory and instead of
creating a symbolic link for each compilation, -I flag
was added to the compiler (the header mentioned above would
now reside in kernel/arch/$ARCH/include/arch/whatever.h).

The same goes for genarch/ includes.

This change would be followed by similar changes in userspace
and ABI. To overall goal is to simplify job of documenation
generators or IDEs that might have problems with the dynamically
created symbolic links.

  • Property mode set to 100644
File size: 3.5 KB
Line 
1/*
2 * Copyright (c) 2003-2004 Jakub Jermar
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup mips32
30 * @{
31 */
32/** @file
33 */
34
35#ifndef KERN_mips32_CP0_H_
36#define KERN_mips32_CP0_H_
37
38#define cp0_status_ie_enabled_bit (1 << 0)
39#define cp0_status_exl_exception_bit (1 << 1)
40#define cp0_status_erl_error_bit (1 << 2)
41#define cp0_status_um_bit (1 << 4)
42#define cp0_status_bev_bootstrap_bit (1 << 22)
43#define cp0_status_fpu_bit (1 << 29)
44
45#define cp0_status_im_shift 8
46#define cp0_status_im_mask 0xff00
47
48#define cp0_cause_excno(cause) ((cause >> 2) & 0x1f)
49#define cp0_cause_coperr(cause) ((cause >> 28) & 0x3)
50
51#define fpu_cop_id 1
52
53/*
54 * Magic value for use in msim.
55 */
56#define cp0_compare_value 100000
57
58#define cp0_mask_all_int() \
59 cp0_status_write(cp0_status_read() & ~(cp0_status_im_mask))
60
61#define cp0_unmask_all_int() \
62 cp0_status_write(cp0_status_read() | cp0_status_im_mask)
63
64#define cp0_mask_int(it) \
65 cp0_status_write(cp0_status_read() & ~(1 << (cp0_status_im_shift + (it))))
66
67#define cp0_unmask_int(it) \
68 cp0_status_write(cp0_status_read() | (1 << (cp0_status_im_shift + (it))))
69
70#define GEN_READ_CP0(nm, reg) \
71 static inline uint32_t cp0_ ##nm##_read(void) \
72 { \
73 uint32_t retval; \
74 \
75 asm volatile ( \
76 "mfc0 %0, $" #reg \
77 : "=r"(retval) \
78 ); \
79 \
80 return retval; \
81 }
82
83#define GEN_WRITE_CP0(nm, reg) \
84 static inline void cp0_ ##nm##_write(uint32_t val) \
85 { \
86 asm volatile ( \
87 "mtc0 %0, $" #reg \
88 :: "r"(val) \
89 ); \
90 }
91
92GEN_READ_CP0(index, 0);
93GEN_WRITE_CP0(index, 0);
94
95GEN_READ_CP0(random, 1);
96
97GEN_READ_CP0(entry_lo0, 2);
98GEN_WRITE_CP0(entry_lo0, 2);
99
100GEN_READ_CP0(entry_lo1, 3);
101GEN_WRITE_CP0(entry_lo1, 3);
102
103GEN_READ_CP0(context, 4);
104GEN_WRITE_CP0(context, 4);
105
106GEN_READ_CP0(pagemask, 5);
107GEN_WRITE_CP0(pagemask, 5);
108
109GEN_READ_CP0(wired, 6);
110GEN_WRITE_CP0(wired, 6);
111
112GEN_READ_CP0(badvaddr, 8);
113
114GEN_READ_CP0(count, 9);
115GEN_WRITE_CP0(count, 9);
116
117GEN_READ_CP0(entry_hi, 10);
118GEN_WRITE_CP0(entry_hi, 10);
119
120GEN_READ_CP0(compare, 11);
121GEN_WRITE_CP0(compare, 11);
122
123GEN_READ_CP0(status, 12);
124GEN_WRITE_CP0(status, 12);
125
126GEN_READ_CP0(cause, 13);
127GEN_WRITE_CP0(cause, 13);
128
129GEN_READ_CP0(epc, 14);
130GEN_WRITE_CP0(epc, 14);
131
132GEN_READ_CP0(prid, 15);
133
134#endif
135
136/** @}
137 */
Note: See TracBrowser for help on using the repository browser.