1 1.77 thorpej /* $NetBSD: cpu.h,v 1.77 2024/01/20 00:15:30 thorpej Exp $ */ 2 1.1 leo 3 1.1 leo /* 4 1.66 rmind * Copyright (c) 1988 University of Utah. 5 1.1 leo * Copyright (c) 1982, 1990 The Regents of the University of California. 6 1.1 leo * All rights reserved. 7 1.42 agc * 8 1.42 agc * This code is derived from software contributed to Berkeley by 9 1.42 agc * the Systems Programming Group of the University of Utah Computer 10 1.42 agc * Science Department. 11 1.42 agc * 12 1.42 agc * Redistribution and use in source and binary forms, with or without 13 1.42 agc * modification, are permitted provided that the following conditions 14 1.42 agc * are met: 15 1.42 agc * 1. Redistributions of source code must retain the above copyright 16 1.42 agc * notice, this list of conditions and the following disclaimer. 17 1.42 agc * 2. Redistributions in binary form must reproduce the above copyright 18 1.42 agc * notice, this list of conditions and the following disclaimer in the 19 1.42 agc * documentation and/or other materials provided with the distribution. 20 1.42 agc * 3. Neither the name of the University nor the names of its contributors 21 1.42 agc * may be used to endorse or promote products derived from this software 22 1.42 agc * without specific prior written permission. 23 1.42 agc * 24 1.42 agc * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 25 1.42 agc * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 26 1.42 agc * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 27 1.42 agc * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 28 1.42 agc * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 29 1.42 agc * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 30 1.42 agc * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 31 1.42 agc * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 32 1.42 agc * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 33 1.42 agc * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 34 1.42 agc * SUCH DAMAGE. 35 1.42 agc * 36 1.42 agc * from: Utah $Hdr: cpu.h 1.16 91/03/25$ 37 1.42 agc * 38 1.42 agc * @(#)cpu.h 7.7 (Berkeley) 6/27/91 39 1.42 agc */ 40 1.1 leo 41 1.1 leo #ifndef _MACHINE_CPU_H_ 42 1.1 leo #define _MACHINE_CPU_H_ 43 1.1 leo 44 1.37 mrg #if defined(_KERNEL_OPT) 45 1.33 thorpej #include "opt_lockdebug.h" 46 1.33 thorpej #endif 47 1.33 thorpej 48 1.1 leo /* 49 1.14 thorpej * Get common m68k CPU definitions. 50 1.14 thorpej */ 51 1.14 thorpej #include <m68k/cpu.h> 52 1.69 tsutsui 53 1.69 tsutsui #if defined(_KERNEL) 54 1.40 thorpej void cpu_proc_fork(struct proc *, struct proc *); 55 1.40 thorpej 56 1.1 leo /* 57 1.1 leo * The rest of this should probably be moved to ../atari/ataricpu.h, 58 1.1 leo * although some of it could probably be put into generic 68k headers. 59 1.1 leo */ 60 1.1 leo #define BASEPRI(sr) ((sr & PSL_IPL) == 0) 61 1.45 yamt #endif /* _KERNEL */ 62 1.1 leo 63 1.1 leo /* 64 1.1 leo * Values for machineid. 65 1.1 leo */ 66 1.10 leo #define ATARI_68000 1 /* 68000 CPU */ 67 1.10 leo #define ATARI_68010 (1<<1) /* 68010 CPU */ 68 1.10 leo #define ATARI_68020 (1L<<2) /* 68020 CPU */ 69 1.10 leo #define ATARI_68030 (1L<<3) /* 68030 CPU */ 70 1.10 leo #define ATARI_68040 (1L<<4) /* 68040 CPU */ 71 1.22 leo #define ATARI_68060 (1L<<6) /* 68060 CPU */ 72 1.36 leo #define ATARI_TT (1L<<11) /* This is a TT030 */ 73 1.36 leo #define ATARI_FALCON (1L<<12) /* Falcon */ 74 1.36 leo #define ATARI_HADES (1L<<13) /* Hades */ 75 1.36 leo #define ATARI_MILAN (1L<<14) /* Milan */ 76 1.7 leo 77 1.7 leo #define ATARI_CLKBROKEN (1L<<16) 78 1.1 leo 79 1.10 leo #define ATARI_ANYCPU (ATARI_68000|ATARI_68010|ATARI_68020|ATARI_68030 \ 80 1.22 leo |ATARI_68040|ATARI_68060) 81 1.1 leo 82 1.36 leo #define ATARI_ANYMACH (ATARI_TT|ATARI_FALCON|ATARI_HADES|ATARI_MILAN) 83 1.12 leo 84 1.45 yamt #if defined(_KERNEL) 85 1.18 leo extern int machineid; 86 1.1 leo 87 1.11 leo /* 88 1.11 leo * Prototypes from atari_init.c 89 1.11 leo */ 90 1.62 tsutsui int cpu_dump(int (*)(dev_t, daddr_t, void *, size_t), daddr_t *); 91 1.62 tsutsui int cpu_dumpsize(void); 92 1.11 leo 93 1.11 leo /* 94 1.11 leo * Prototypes from autoconf.c 95 1.11 leo */ 96 1.62 tsutsui void config_console(void); 97 1.11 leo 98 1.11 leo /* 99 1.11 leo * Prototypes from fpu.c 100 1.11 leo */ 101 1.62 tsutsui const char *fpu_describe(int); 102 1.11 leo 103 1.11 leo /* 104 1.11 leo * Prototypes from locore.s 105 1.11 leo */ 106 1.62 tsutsui void clearseg(paddr_t); 107 1.62 tsutsui void doboot(void); 108 1.62 tsutsui void physcopyseg(paddr_t, paddr_t); 109 1.62 tsutsui u_int probeva(u_int, u_int); 110 1.11 leo 111 1.11 leo /* 112 1.11 leo * Prototypes from machdep.c: 113 1.11 leo */ 114 1.62 tsutsui int badbaddr(void *, int); 115 1.62 tsutsui void consinit(void); 116 1.11 leo typedef void (*si_farg)(void *, void *); /* XXX */ 117 1.62 tsutsui void init_sicallback(void); /* XXX */ 118 1.62 tsutsui void add_sicallback(si_farg, void *, void *); 119 1.62 tsutsui void rem_sicallback(si_farg); 120 1.62 tsutsui void dumpsys(void); 121 1.62 tsutsui vaddr_t reserve_dumppages(vaddr_t); 122 1.11 leo 123 1.11 leo 124 1.11 leo /* 125 1.11 leo * Prototypes from nvram.c: 126 1.11 leo */ 127 1.11 leo struct uio; 128 1.62 tsutsui int nvram_uio(struct uio *); 129 1.11 leo 130 1.11 leo /* 131 1.24 leo * Prototypes from pci_machdep.c 132 1.24 leo */ 133 1.62 tsutsui void init_pci_bus(void); 134 1.11 leo 135 1.11 leo #endif /* _KERNEL */ 136 1.1 leo #endif /* !_MACHINE_CPU_H_ */ 137