From: Peter Dinda Date: Tue, 12 Apr 2011 15:08:24 +0000 (-0500) Subject: Added host device interface X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=commitdiff_plain;h=803414b62464602bee3934b94e30dca98917ce6e;p=palacios.git Added host device interface --- diff --git a/palacios/include/interfaces/vmm_host_dev.h b/palacios/include/interfaces/vmm_host_dev.h new file mode 100644 index 0000000..9f7ea91 --- /dev/null +++ b/palacios/include/interfaces/vmm_host_dev.h @@ -0,0 +1,216 @@ +/* + * This file is part of the Palacios Virtual Machine Monitor developed + * by the V3VEE Project with funding from the United States National + * Science Foundation and the Department of Energy. + * + * The V3VEE Project is a joint project between Northwestern University + * and the University of New Mexico. You can find out more at + * http://www.v3vee.org + * + * Copyright (c) 2011, Peter Dinda + * Copyright (c) 2011, The V3VEE Project + * All rights reserved. + * + * Author: Peter Dinda + * + * This is free software. You are permitted to use, + * redistribute, and modify it as specified in the file "V3VEE_LICENSE". + */ + + +#ifndef __VMM_HOST_DEV_H__ +#define __VMM_HOST_DEV_H__ + +#include + + +/* + + The purpose of this interface is to make it possible to implement + virtual devices in the host OS. It is intended to be used by + passthrough device implementations, such as the generic device + and the PCI passthrough device. + + One use of this interface, and the generic and PCI passthrough devices + might be to build an interface with simulated devices in SST + under a Linux host. That scenario would look like this: + +Guest config: + + generic device: + + ports, memory regions, interrupts set with PASSTHROUGH option + + + PCI passthrough devive: + + vendor and device ids, etc + + +impl="physical" or lack of an impl key would indicate that direct hardware +access is expected, which is how these devices currently operate. + + +Host (Linux) side: + + There would be an implementation and registration of the hooks + defined and explained in this file + + The implementation might, for example, create an interface to + a user space process, for example like the console + (palacios-console.[ch] + v3_cons.c) or graphics console + (palacios-graphics-console.[ch] + v3_vncserver.c) do + and route the hook functions defined here through it. + Through this interface, the calls could be routed to an SST + device module. + +*/ + + +/* A host device is opaque to the palacios */ +typedef void * v3_host_dev_t; +/* A guest device is opaque to the host */ +typedef void * v3_guest_dev_t; + + +/* There is a notion of a bus class to which the device is attached */ +typedef enum { DIRECT, PCI } v3_bus_class_t; + +#ifdef __V3VEE__ + +v3_host_dev_t v3_host_dev_open(char *impl, + v3_bus_class_t bus, + v3_guest_dev_t gdev); + +uin64_t v3_host_dev_read_io(v3_host_dev_t hostdev, + uint16_t port, + void *dest + uint64_t len); + +uint64_t v3_host_dev_write_io(v3_host_dev_t hostdev, + uint16_t port, + void *src, + uint64_t len); + +uint64_t v3_host_dev_read_mem(v3_host_dev_t hostdev, + addr_t gpa, + void *dest, + uint64_t len); + +uint64_t v3_host_dev_write_mem(v3_host_dev_t hostdev, + addr_t gpa, + void *src, + uint64_t len); + +int v3_host_dev_ack_irq(v3_host_dev_t hostdev, uint32_t irq); + +uint64_t v3_host_dev_config_read(v3_host_dev_t hostdev, + void *dest, + uint64_t len); + +uint64_t v3_host_dev_config_write(v3_host_dev_t hostdev, + void *src, + uint64_t len); + +#endif + +struct v3_host_dev_hooks { + + // The host is given the implementation name, the type of bus + // this device is attached to and an opaque pointer back to the + // guest device. It returns an opaque representation of + // the host device it has attached to, with zero indicating + // failure + v3_host_dev_t (*open)(char *impl, + v3_bus_class_t bus, + v3_guest_dev_t gdev); + + // Read/Write from/to an IO port. The read must either + // completely succeed, returning len or completely + // fail, returning != len + // Callee gets the host dev id and the port in the guest + uint64_t (*read_io)(v3_host_dev_t hostdev, + uint16_t port, + void *dest + uint64_t len); + + uint64_t (*write_io)(v3_host_dev_t hostdev, + uint16_t port, + void *src, + uint64_t len); + + // Read/Write from/to memory. The reads/writes must + // completely succeed, returning len or completely + // fail, returning != len + // Callee gets the host dev id, and the guest physical address + uint64_t (*read_mem)(v3_host_dev_t hostdev, + addr_t gpa, + void *dest, + uint64_t len); + + uint64_t (*write_mem)(v3_host_dev_t hostdev, + addr_t gpa, + void *src, + uint64_t len); + + // Palacis will call this when it has taken posession of the + // IRQ ad wants the host device to lower it + // This interface is unclear + // + // One potential use would be to allow for a palacios + // side device to raise the irq asynchronously from + // the host device. If this is permitted, then we + // need a way of informing the host device that the + // irq has actually been signalled. + int (*ack_irq)(v3_host_dev_t hostdev, uint8_t irq); + + // Configuration space reads/writes for devices that + // have them, such as PCI devices + // As with other reads/writes, these must be fully successful + // or fail + // + // Palacios maintains its own configuration for some + // devices (e.g., pci_passthrough) and will take care of + // relevant hooking/unhooking, and maintain its own + // config space info. However, a read will return + // the host device's config, while a write will affect + // both the palacios-internal config and the hsot device's config + uint64_t (*config_read)(v3_host_dev_t hostdev, + void *dest, + uint64_t len); + + uint64_t (*config_write)(v3_host_dev_t hostdev, + void *src, + uint64_t len); + +}; + +/* This function is how the host will raise an irq to palacios + for the device. The IRQ argument will be ignored for devices + whose irqs are managed by palacios */ +int v3_host_dev_raise_irq(v3_host_dev_t hostdev, + v3_guest_dev_t guest_dev, + uint8_t irq); + +/* These functions allow the host to read and write the guest + memory by physical address, for example to implement DMA + + These functions are incremental - that is, they can return + a smaller amount than requested +*/ +uint64_t v3_host_dev_read_guest_mem(v3_host_dev_t hostdev, + v3_guest_dev_t guest_dev, + addr_t gpa, + void *dest, + uint64_t len); + +uint64_t v3_host_dev_write_guest_mem(v3_host_dev_t hostdev, + v3_guest_dev_t guest_dev, + addr_t gpa, + void *src, + uint64_t len); + + +extern void V3_Init_Host_Device_Support(struct v3_host_dev_hooks *hooks); + +#endif