/*- * Copyright (c) 1990, 1993 * The Regents of the University of California. All rights reserved. * * This code is derived from software contributed to Berkeley by * William Jolitz. * * %sccs.include.redist.c% * * @(#)cpu.h 8.5 (Berkeley) 05/17/95 */ /* * Definitions unique to i386 cpu support. */ #include #include /* * definitions of cpu-dependent requirements * referenced in generic code */ #undef COPY_SIGCODE /* don't copy sigcode above user stack in exec */ #define cpu_exec(p) /* nothing */ #define cpu_swapin(p) /* nothing */ #define cpu_setstack(p, ap) (p)->p_md.md_regs[SP] = ap #define cpu_set_init_frame(p, fp) (p)->p_md.md_regs = fp #define BACKTRACE(p) /* not implemented */ /* * Arguments to hardclock, softclock and gatherstats * encapsulate the previous machine state in an opaque * clockframe; for now, use generic intrframe. */ struct clockframe { struct intrframe cf_if; }; #define CLKF_USERMODE(framep) (ISPL((framep)->cf_if.if_cs) == SEL_UPL) #define CLKF_BASEPRI(framep) ((framep)->cf_if.if_ppl == 0) #define CLKF_PC(framep) ((framep)->cf_if.if_eip) #define resettodr() /* no todr to set */ /* * Preempt the current process if in interrupt from user mode, * or after the current trap/syscall if in system mode. */ #define need_resched() { want_resched++; aston(); } /* * Give a profiling tick to the current process from the softclock * interrupt. On tahoe, request an ast to send us through trap(), * marking the proc as needing a profiling tick. */ #define profile_tick(p, framep) { (p)->p_flag |= P_OWEUPC; aston(); } /* * Notify the current process (p) that it has a signal pending, * process as soon as possible. */ #define signotify(p) aston() #define aston() (astpending++) int astpending; /* need to trap before returning to user mode */ int want_resched; /* resched() was called */ /* * Kinds of processor */ #define CPU_386SX 0 #define CPU_386 1 #define CPU_486SX 2 #define CPU_486 3 #define CPU_586 4 /* * CTL_MACHDEP definitions. */ #define CPU_CONSDEV 1 /* dev_t: console terminal device */ #define CPU_MAXID 2 /* number of valid machdep ids */ #define CTL_MACHDEP_NAMES { \ { 0, 0 }, \ { "console_device", CTLTYPE_STRUCT }, \ }