FreeBSD/Linux Kernel Cross Reference
sys/i386/mp_desc.h
1 /*
2 * Mach Operating System
3 * Copyright (c) 1991,1990 Carnegie Mellon University
4 * All Rights Reserved.
5 *
6 * Permission to use, copy, modify and distribute this software and its
7 * documentation is hereby granted, provided that both the copyright
8 * notice and this permission notice appear in all copies of the
9 * software, derivative works or modified versions, and any portions
10 * thereof, and that both notices appear in supporting documentation.
11 *
12 * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
13 * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
14 * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
15 *
16 * Carnegie Mellon requests users of this software to return to
17 *
18 * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
19 * School of Computer Science
20 * Carnegie Mellon University
21 * Pittsburgh PA 15213-3890
22 *
23 * any improvements or extensions that they make and grant Carnegie Mellon
24 * the rights to redistribute these changes.
25 */
26
27 /*
28 * HISTORY
29 * $Log: mp_desc.h,v $
30 * Revision 2.3 91/05/14 16:12:24 mrt
31 * Correcting copyright
32 *
33 * Revision 2.2 91/05/08 12:39:51 dbg
34 * Created.
35 * [91/03/21 dbg]
36 *
37 */
38
39 #ifndef _I386_MP_DESC_H_
40 #define _I386_MP_DESC_H_
41
42 #include <cpus.h>
43
44 /*
45 * Multiprocessor i386/i486 systems use a separate copy of the
46 * GDT, IDT, LDT, and kernel TSS per processor. The first three
47 * are separate to avoid lock contention: the i386 uses locked
48 * memory cycles to access the descriptor tables. The TSS is
49 * separate since each processor needs its own kernel stack,
50 * and since using a TSS marks it busy.
51 */
52
53 #include <i386/seg.h>
54 #include <i386/tss.h>
55
56 /*
57 * The descriptor tables are together in a structure
58 * allocated one per processor (except for the boot processor).
59 */
60 struct mp_desc_table {
61 struct fake_descriptor idt[IDTSZ]; /* IDT */
62 struct fake_descriptor gdt[GDTSZ]; /* GDT */
63 struct fake_descriptor ldt[LDTSZ]; /* LDT */
64 struct i386_tss ktss;
65 };
66
67 /*
68 * They are pointed to by a per-processor array.
69 */
70 extern struct mp_desc_table *mp_desc_table[NCPUS];
71
72 /*
73 * The kernel TSS gets its own pointer.
74 */
75 extern struct i386_tss *mp_ktss[NCPUS];
76
77 /*
78 * So does the GDT.
79 */
80 extern struct fake_descriptor *mp_gdt[NCPUS];
81
82
83 /*
84 * Each CPU calls this routine to set up its descriptor tables.
85 */
86 extern struct mp_desc_table * mp_desc_init(/* int */);
87
88 #endif /* _I386_MP_DESC_H_ */
Cache object: f13f39f80c20b962f22505efd5e0263b
|