Path: blob/main/usr.sbin/bhyve/amd64/pci_irq_machdep.h
111661 views
/*-1* SPDX-License-Identifier: BSD-2-Clause2*3* Copyright (c) 2014 Hudson River Trading LLC4* Written by: John H. Baldwin <[email protected]>5* All rights reserved.6*7* Redistribution and use in source and binary forms, with or without8* modification, are permitted provided that the following conditions9* are met:10* 1. Redistributions of source code must retain the above copyright11* notice, this list of conditions and the following disclaimer.12* 2. Redistributions in binary form must reproduce the above copyright13* notice, this list of conditions and the following disclaimer in the14* documentation and/or other materials provided with the distribution.15*16* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND17* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE18* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE19* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE20* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL21* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS22* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)23* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT24* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY25* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF26* SUCH DAMAGE.27*/2829#ifndef __PCI_IRQ_MD_H__30#define __PCI_IRQ_MD_H__3132struct vmctx;3334struct pci_irq {35int pirq_pin;36int ioapic_irq;37};3839void pci_irq_init(struct vmctx *ctx);40void pci_irq_reserve(int irq);41void pci_irq_use(int irq);42int pirq_irq(int pin);43uint8_t pirq_read(int pin);44void pirq_write(struct vmctx *ctx, int pin, uint8_t val);4546static inline void47pci_irq_init_irq(struct pci_irq *irq)48{49irq->pirq_pin = 0;50irq->ioapic_irq = 0;51}5253static inline uint8_t54pci_irq_intline(struct pci_irq *irq)55{56return (pirq_irq(irq->pirq_pin));57}5859#endif606162