| /* | 
 |  * USB UHCI controller emulation | 
 |  * | 
 |  * Copyright (c) 2005 Fabrice Bellard | 
 |  * | 
 |  * Copyright (c) 2008 Max Krasnyansky | 
 |  *     Magor rewrite of the UHCI data structures parser and frame processor | 
 |  *     Support for fully async operation and multiple outstanding transactions | 
 |  * | 
 |  * Permission is hereby granted, free of charge, to any person obtaining a copy | 
 |  * of this software and associated documentation files (the "Software"), to deal | 
 |  * in the Software without restriction, including without limitation the rights | 
 |  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | 
 |  * copies of the Software, and to permit persons to whom the Software is | 
 |  * furnished to do so, subject to the following conditions: | 
 |  * | 
 |  * The above copyright notice and this permission notice shall be included in | 
 |  * all copies or substantial portions of the Software. | 
 |  * | 
 |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | 
 |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | 
 |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL | 
 |  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | 
 |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | 
 |  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | 
 |  * THE SOFTWARE. | 
 |  */ | 
 | #ifndef HW_USB_HCD_UHCI_H | 
 | #define HW_USB_HCD_UHCI_H | 
 |  | 
 | #include "exec/memory.h" | 
 | #include "qemu/timer.h" | 
 | #include "hw/pci/pci_device.h" | 
 | #include "hw/usb.h" | 
 |  | 
 | typedef struct UHCIQueue UHCIQueue; | 
 |  | 
 | #define UHCI_PORTS 2 | 
 |  | 
 | typedef struct UHCIPort { | 
 |     USBPort port; | 
 |     uint16_t ctrl; | 
 | } UHCIPort; | 
 |  | 
 | typedef struct UHCIState { | 
 |     PCIDevice dev; | 
 |     MemoryRegion io_bar; | 
 |     USBBus bus; /* Note unused when we're a companion controller */ | 
 |     uint16_t cmd; /* cmd register */ | 
 |     uint16_t status; | 
 |     uint16_t intr; /* interrupt enable register */ | 
 |     uint16_t frnum; /* frame number */ | 
 |     uint32_t fl_base_addr; /* frame list base address */ | 
 |     uint8_t sof_timing; | 
 |     uint8_t status2; /* bit 0 and 1 are used to generate UHCI_STS_USBINT */ | 
 |     int64_t expire_time; | 
 |     QEMUTimer *frame_timer; | 
 |     QEMUBH *bh; | 
 |     uint32_t frame_bytes; | 
 |     uint32_t frame_bandwidth; | 
 |     bool completions_only; | 
 |     UHCIPort ports[UHCI_PORTS]; | 
 |     qemu_irq irq; | 
 |     /* Interrupts that should be raised at the end of the current frame.  */ | 
 |     uint32_t pending_int_mask; | 
 |  | 
 |     /* Active packets */ | 
 |     QTAILQ_HEAD(, UHCIQueue) queues; | 
 |     uint8_t num_ports_vmstate; | 
 |  | 
 |     /* Properties */ | 
 |     char *masterbus; | 
 |     uint32_t firstport; | 
 |     uint32_t maxframes; | 
 | } UHCIState; | 
 |  | 
 | #define TYPE_UHCI "pci-uhci-usb" | 
 | OBJECT_DECLARE_TYPE(UHCIState, UHCIPCIDeviceClass, UHCI) | 
 |  | 
 | typedef struct UHCIInfo { | 
 |     const char *name; | 
 |     uint16_t   vendor_id; | 
 |     uint16_t   device_id; | 
 |     uint8_t    revision; | 
 |     uint8_t    irq_pin; | 
 |     void       (*realize)(PCIDevice *dev, Error **errp); | 
 |     bool       unplug; | 
 |     bool       notuser; /* disallow user_creatable */ | 
 | } UHCIInfo; | 
 |  | 
 | void uhci_data_class_init(ObjectClass *klass, void *data); | 
 | void usb_uhci_common_realize(PCIDevice *dev, Error **errp); | 
 |  | 
 | #define TYPE_PIIX3_USB_UHCI "piix3-usb-uhci" | 
 | #define TYPE_PIIX4_USB_UHCI "piix4-usb-uhci" | 
 | #define TYPE_ICH9_USB_UHCI(fn) "ich9-usb-uhci" #fn | 
 |  | 
 | #endif |