The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/i386/mp_desc.h

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    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


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.