2020-04-23 02:23:59 +02:00
|
|
|
/*
|
2023-01-06 15:36:05 -05:00
|
|
|
* 86Box A hypervisor and IBM PC system emulator that specializes in
|
|
|
|
|
* running old operating systems and software designed for IBM
|
|
|
|
|
* PC systems and compatibles from 1981 through fairly recent
|
|
|
|
|
* system designs based on the PCI bus.
|
2020-04-23 02:23:59 +02:00
|
|
|
*
|
2023-01-06 15:36:05 -05:00
|
|
|
* This file is part of the 86Box distribution.
|
2020-04-23 02:23:59 +02:00
|
|
|
*
|
2023-01-06 15:36:05 -05:00
|
|
|
* Definitions for the Distributed DMA emulation.
|
2020-04-23 02:23:59 +02:00
|
|
|
*
|
|
|
|
|
*
|
|
|
|
|
*
|
2023-01-06 15:36:05 -05:00
|
|
|
* Authors: Miran Grca, <mgrca8@gmail.com>
|
2020-04-23 02:23:59 +02:00
|
|
|
*
|
2023-01-06 15:36:05 -05:00
|
|
|
* Copyright 2020 Miran Grca.
|
2020-04-23 02:23:59 +02:00
|
|
|
*/
|
2022-02-18 19:42:21 -05:00
|
|
|
|
2020-04-23 02:23:59 +02:00
|
|
|
#ifndef USB_H
|
2022-09-18 17:15:38 -04:00
|
|
|
#define USB_H
|
2020-04-23 02:23:59 +02:00
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
extern "C" {
|
|
|
|
|
#endif
|
2017-01-22 00:22:14 -06:00
|
|
|
|
2023-04-30 23:01:15 +06:00
|
|
|
typedef struct usb_t usb_t;
|
2023-05-16 00:53:59 +02:00
|
|
|
typedef struct usb_device_t usb_device_t;
|
|
|
|
|
|
|
|
|
|
enum usb_pid
|
|
|
|
|
{
|
|
|
|
|
USB_PID_OUT = 0xE1,
|
|
|
|
|
USB_PID_IN = 0x69,
|
|
|
|
|
USB_PID_SETUP = 0x2D
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
enum usb_errors
|
|
|
|
|
{
|
|
|
|
|
USB_ERROR_NO_ERROR = 0,
|
|
|
|
|
USB_ERROR_NAK = 1,
|
|
|
|
|
USB_ERROR_OVERRUN = 2,
|
|
|
|
|
USB_ERROR_UNDERRUN = 3
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
enum usb_bus_types
|
|
|
|
|
{
|
|
|
|
|
USB_BUS_OHCI = 0,
|
|
|
|
|
USB_BUS_UHCI,
|
|
|
|
|
USB_BUS_MAX
|
|
|
|
|
};
|
2023-04-30 23:01:15 +06:00
|
|
|
|
|
|
|
|
/* USB device creation parameters struct */
|
2017-01-22 00:22:14 -06:00
|
|
|
typedef struct
|
2023-04-30 23:01:15 +06:00
|
|
|
{
|
2023-05-07 02:53:04 +02:00
|
|
|
void (*update_interrupt)(usb_t*, void*);
|
2023-05-05 00:28:08 +06:00
|
|
|
/* Handle (but do not raise) SMI. Returns 1 if SMI can be raised, 0 otherwise. */
|
|
|
|
|
uint8_t (*smi_handle)(usb_t*, void*);
|
2023-04-30 23:01:15 +06:00
|
|
|
void* parent_priv;
|
|
|
|
|
} usb_params_t;
|
|
|
|
|
|
2023-05-07 02:53:04 +02:00
|
|
|
typedef union
|
|
|
|
|
{
|
|
|
|
|
uint32_t l;
|
|
|
|
|
uint16_t w[2];
|
|
|
|
|
uint8_t b[4];
|
|
|
|
|
} ohci_mmio_t;
|
|
|
|
|
|
2023-04-30 23:01:15 +06:00
|
|
|
/* USB Host Controller device struct */
|
|
|
|
|
typedef struct usb_t
|
2017-01-22 00:22:14 -06:00
|
|
|
{
|
2023-05-06 23:19:55 +06:00
|
|
|
uint8_t uhci_io[32];
|
2023-05-07 02:53:04 +02:00
|
|
|
ohci_mmio_t ohci_mmio[1024];
|
2022-09-18 17:15:38 -04:00
|
|
|
uint16_t uhci_io_base;
|
|
|
|
|
int uhci_enable, ohci_enable;
|
2023-05-07 02:53:04 +02:00
|
|
|
uint32_t ohci_mem_base, irq_level;
|
2022-09-18 17:15:38 -04:00
|
|
|
mem_mapping_t ohci_mmio_mapping;
|
2023-05-01 16:55:49 +06:00
|
|
|
pc_timer_t ohci_frame_timer;
|
|
|
|
|
pc_timer_t ohci_port_reset_timer[2];
|
2023-05-16 00:53:59 +02:00
|
|
|
uint8_t ohci_interrupt_counter : 3;
|
|
|
|
|
usb_device_t* ohci_devices[2];
|
|
|
|
|
usb_device_t* uhci_devices[2];
|
|
|
|
|
uint8_t ohci_usb_buf[4096];
|
|
|
|
|
uint8_t ohci_initial_start;
|
2023-04-30 23:01:15 +06:00
|
|
|
|
|
|
|
|
usb_params_t* usb_params;
|
2020-04-23 02:23:59 +02:00
|
|
|
} usb_t;
|
|
|
|
|
|
2023-05-04 16:25:46 +06:00
|
|
|
#pragma pack(push, 1)
|
2023-05-16 00:53:59 +02:00
|
|
|
|
2023-05-04 16:25:46 +06:00
|
|
|
/* Base USB descriptor struct. */
|
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
uint8_t bLength;
|
|
|
|
|
uint8_t bDescriptorType;
|
|
|
|
|
} usb_desc_base_t;
|
2023-05-05 01:20:32 +06:00
|
|
|
|
2023-05-16 00:53:59 +02:00
|
|
|
enum usb_desc_setup_req_types
|
|
|
|
|
{
|
|
|
|
|
USB_SETUP_TYPE_DEVICE = 0x0,
|
|
|
|
|
USB_SETUP_TYPE_INTERFACE = 0x1,
|
|
|
|
|
USB_SETUP_TYPE_ENDPOING = 0x2,
|
|
|
|
|
USB_SETUP_TYPE_OTHER = 0x3,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
#define USB_SETUP_TYPE_MAX 0x1F
|
|
|
|
|
|
|
|
|
|
#define USB_SETUP_DEV_TO_HOST 0x80
|
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
uint8_t bmRequestType;
|
|
|
|
|
uint8_t bRequest;
|
|
|
|
|
uint16_t wValue;
|
|
|
|
|
uint16_t wIndex;
|
|
|
|
|
uint16_t wLength;
|
|
|
|
|
} usb_desc_setup_t;
|
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
usb_desc_base_t base;
|
|
|
|
|
uint8_t bEndpointAddress;
|
|
|
|
|
uint8_t bmAttributes;
|
|
|
|
|
uint16_t wMaxPacketSize;
|
|
|
|
|
uint8_t bInterval;
|
|
|
|
|
} usb_desc_endpoint_t;
|
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
usb_desc_base_t base;
|
|
|
|
|
|
|
|
|
|
uint16_t bcdHID;
|
|
|
|
|
uint8_t bCountryCode;
|
|
|
|
|
uint8_t bNumDescriptors;
|
|
|
|
|
uint8_t bDescriptorType;
|
|
|
|
|
uint16_t wDescriptorLength;
|
|
|
|
|
} usb_desc_hid_t;
|
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
usb_desc_base_t base;
|
|
|
|
|
|
|
|
|
|
uint8_t bInterfaceNumber;
|
|
|
|
|
uint8_t bAlternateSetting;
|
|
|
|
|
uint8_t bNumEndpoints;
|
|
|
|
|
uint8_t bInterfaceClass;
|
|
|
|
|
uint8_t bInterfaceSubClass;
|
|
|
|
|
uint8_t bInterfaceProtocol;
|
|
|
|
|
uint8_t iInterface;
|
|
|
|
|
} usb_desc_interface_t;
|
|
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
usb_desc_base_t base;
|
|
|
|
|
uint16_t bString[];
|
|
|
|
|
} usb_desc_string_t;
|
|
|
|
|
|
2023-05-05 01:20:32 +06:00
|
|
|
typedef struct
|
|
|
|
|
{
|
|
|
|
|
usb_desc_base_t base;
|
|
|
|
|
|
|
|
|
|
uint16_t wTotalLength;
|
|
|
|
|
uint8_t bNumInterfaces;
|
|
|
|
|
uint8_t bConfigurationValue;
|
|
|
|
|
uint8_t iConfiguration;
|
|
|
|
|
uint8_t bmAttributes;
|
|
|
|
|
uint8_t bMaxPower;
|
|
|
|
|
} usb_desc_conf_t;
|
2023-05-04 16:25:46 +06:00
|
|
|
|
2023-05-07 01:11:38 +06:00
|
|
|
typedef struct
|
|
|
|
|
{
|
2023-05-16 00:53:59 +02:00
|
|
|
usb_desc_base_t base;
|
|
|
|
|
|
|
|
|
|
uint16_t bcdUSB;
|
|
|
|
|
uint8_t bDeviceClass;
|
|
|
|
|
uint8_t bDeviceSubClass;
|
|
|
|
|
uint8_t bDeviceProtocol;
|
|
|
|
|
uint8_t bMaxPacketSize;
|
|
|
|
|
uint16_t idVendor;
|
|
|
|
|
uint16_t idProduct;
|
|
|
|
|
uint16_t bcdDevice;
|
|
|
|
|
uint8_t iManufacturer;
|
|
|
|
|
uint8_t iProduct;
|
|
|
|
|
uint8_t iSerialNumber;
|
|
|
|
|
uint8_t bNumConfigurations;
|
|
|
|
|
} usb_desc_device_t;
|
|
|
|
|
|
|
|
|
|
#pragma pack(pop)
|
2023-05-07 01:11:38 +06:00
|
|
|
|
2023-04-30 00:59:11 +06:00
|
|
|
/* USB endpoint device struct. Incomplete and unused. */
|
2023-05-16 00:53:59 +02:00
|
|
|
typedef struct usb_device_t
|
2023-04-30 00:59:11 +06:00
|
|
|
{
|
2023-05-16 00:53:59 +02:00
|
|
|
usb_desc_device_t device_desc;
|
|
|
|
|
struct {
|
|
|
|
|
usb_desc_conf_t conf_desc;
|
|
|
|
|
usb_desc_base_t* other_descs[16];
|
|
|
|
|
} conf_desc_items;
|
|
|
|
|
|
|
|
|
|
/* General-purpose function for I/O. Non-zero value indicates error. */
|
|
|
|
|
uint8_t (*device_process)(void* priv, uint8_t* data, uint32_t *len, uint8_t pid_token, uint8_t endpoint, uint8_t underrun_not_allowed);
|
|
|
|
|
/* Device reset. */
|
2023-05-06 16:08:33 +06:00
|
|
|
void (*device_reset)(void* priv);
|
2023-05-16 00:53:59 +02:00
|
|
|
/* Get address. */
|
|
|
|
|
uint8_t (*device_get_address)(void* priv);
|
|
|
|
|
|
2023-05-04 16:25:46 +06:00
|
|
|
void* priv;
|
2023-04-30 00:59:11 +06:00
|
|
|
} usb_device_t;
|
|
|
|
|
|
2020-04-23 02:23:59 +02:00
|
|
|
/* Global variables. */
|
2022-09-18 17:15:38 -04:00
|
|
|
extern const device_t usb_device;
|
2023-05-16 00:53:59 +02:00
|
|
|
extern usb_t* usb_device_inst;
|
2020-04-23 02:23:59 +02:00
|
|
|
|
|
|
|
|
/* Functions. */
|
2022-09-18 17:15:38 -04:00
|
|
|
extern void uhci_update_io_mapping(usb_t *dev, uint8_t base_l, uint8_t base_h, int enable);
|
|
|
|
|
extern void ohci_update_mem_mapping(usb_t *dev, uint8_t base1, uint8_t base2, uint8_t base3, int enable);
|
2023-05-05 22:46:18 +06:00
|
|
|
/* Attach USB device to a port of a USB bus. Returns the port to which it got attached to. */
|
|
|
|
|
extern uint8_t usb_attach_device(usb_t *dev, usb_device_t* device, uint8_t bus_type);
|
|
|
|
|
/* Detach USB device from a port. */
|
|
|
|
|
extern void usb_detach_device(usb_t *dev, uint8_t port, uint8_t bus_type);
|
2020-04-23 02:23:59 +02:00
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
2022-09-18 17:15:38 -04:00
|
|
|
#endif /*USB_H*/
|