/* * Copyright (c) 1996, by Steve Passe * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. The name of the developer may NOT be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * $Id: mpapic.h,v 1.1 1997/05/01 06:57:56 smp Exp smp $ */ #ifndef _MACHINE_MPAPIC_H_ #define _MACHINE_MPAPIC_H_ #include #include /* number of busses */ #if !defined(NBUS) # define NBUS 4 #endif /* NBUS */ /* total number of APIC INTs, including SHARED INTs */ #if !defined(NINTR) #define NINTR 24 #endif /* NINTR */ /* size of APIC ID list */ #define NAPICID 16 /* number of IO APICs */ # if !defined(NAPIC) # define NAPIC 1 # endif /* NAPIC */ /* these don't really belong in here... */ enum busTypes { CBUS = 1, CBUSII = 2, EISA = 3, ISA = 6, PCI = 13, XPRESS = 18, MAX_BUSTYPE = 18, UNKNOWN_BUSTYPE = 0xff }; /* * the physical/logical APIC ID management macors */ #define CPU_TO_ID(CPU) (cpu_num_to_apic_id[CPU]) #define ID_TO_CPU(ID) (apic_id_to_logical[ID]) #define IO_TO_ID(IO) (io_num_to_apic_id[IO]) #define ID_TO_IO(ID) (apic_id_to_logical[ID]) /* * inline functions to read/write the IO APIC * NOTES: * unlike the local APIC, the IO APIC is accessed indirectly thru 2 registers. * the select register is loaded with an index to the desired 'window' reg. * the 'window' is accessed as a 32 bit unsigned. */ /* * read 'reg' from 'apic' */ #if defined(MULTIPLE_IOAPICS) #error MULTIPLE_IOAPICSXXX #else static __inline u_int32_t io_apic_read(int apic __attribute__ ((unused)), int reg) { (*io_apic_base) = reg; return (*(io_apic_base + (IOAPIC_WINDOW / sizeof(u_int)))); } #endif /* MULTIPLE_IOAPICS */ /* * write 'value' to 'reg' of 'apic' */ #if defined(MULTIPLE_IOAPICS) #error MULTIPLE_IOAPICSXXX #else static __inline void io_apic_write(int apic __attribute__ ((unused)), int reg, u_int32_t value) { (*io_apic_base) = reg; (*(io_apic_base + (IOAPIC_WINDOW / sizeof(u_int)))) = value; } #endif /* MULTIPLE_IOAPICS */ #if defined(READY) /* * set the IO APIC mask for INT# 'i' */ #if defined(MULTIPLE_IOAPICS) #error MULTIPLE_IOAPICSXXX #else static __inline void set_io_apic_mask(int apic, u_int32_t i) { int select; /* the select register is 8 bits */ u_int32_t low_reg; /* the window register is 32 bits */ imen |= (1<