X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=palacios%2Finclude%2Fpalacios%2Fvm_dev.h;h=6c7d77f97e09e56615271776eba007c541dd00c7;hb=9b4bfeefac09294a6f0ae12dbadf102eb547f5ec;hp=795a3d121d3e25bb20458ab7c34188dc91ca0807;hpb=f4b074d9bf5c28dfd6e5fd616805ade2e9473b01;p=palacios.git diff --git a/palacios/include/palacios/vm_dev.h b/palacios/include/palacios/vm_dev.h index 795a3d1..6c7d77f 100644 --- a/palacios/include/palacios/vm_dev.h +++ b/palacios/include/palacios/vm_dev.h @@ -1,5 +1,21 @@ -/* (c) 2008, Jack Lange */ -/* (c) 2008, The V3VEE Project */ +/* + * 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) 2008, Jack Lange + * Copyright (c) 2008, The V3VEE Project + * All rights reserved. + * + * Author: Jack Lange + * + * This is free software. You are permitted to use, + * redistribute, and modify it as specified in the file "V3VEE_LICENSE". + */ #ifndef __VM_DEV_H #define __VM_DEV_H @@ -17,72 +33,72 @@ struct vm_device; struct vm_device_ops { - int (*init)(struct vm_device *dev); - int (*deinit)(struct vm_device *dev); + int (*init)(struct vm_device *dev); + int (*deinit)(struct vm_device *dev); - int (*reset)(struct vm_device *dev); + int (*reset)(struct vm_device *dev); - int (*start)(struct vm_device *dev); - int (*stop)(struct vm_device *dev); + int (*start)(struct vm_device *dev); + int (*stop)(struct vm_device *dev); - //int (*save)(struct vm_device *dev, struct *iostream); - //int (*restore)(struct vm_device *dev, struct *iostream); + //int (*save)(struct vm_device *dev, struct *iostream); + //int (*restore)(struct vm_device *dev, struct *iostream); }; struct vm_device { - char name[32]; + char name[32]; - void *private_data; + void *private_data; - struct vm_device_ops * ops; + struct vm_device_ops * ops; - struct guest_info * vm; + struct guest_info * vm; - struct list_head dev_link; + struct list_head dev_link; - uint_t num_io_hooks; - struct list_head io_hooks; - uint_t num_mem_hooks; - struct list_head mem_hooks; - uint_t num_irq_hooks; - struct list_head irq_hooks; + uint_t num_io_hooks; + struct list_head io_hooks; + uint_t num_mem_hooks; + struct list_head mem_hooks; + uint_t num_irq_hooks; + struct list_head irq_hooks; }; -struct vm_device * allocate_device(); -struct vm_device * create_device(char * name, struct vm_device_ops * ops, void * private_data); -void free_device(struct vm_device * dev); +struct vm_device * v3_create_device(char * name, struct vm_device_ops * ops, void * private_data); +void v3_free_device(struct vm_device * dev); -int dev_hook_io(struct vm_device *dev, - ushort_t port, - int (*read)(ushort_t port, void * dst, uint_t length, struct vm_device * dev), - int (*write)(ushort_t port, void * src, uint_t length, struct vm_device * dev)); -int dev_unhook_io(struct vm_device *dev, - ushort_t port); +int v3_dev_hook_io(struct vm_device *dev, + ushort_t port, + int (*read)(ushort_t port, void * dst, uint_t length, struct vm_device * dev), + int (*write)(ushort_t port, void * src, uint_t length, struct vm_device * dev)); -int dev_hook_mem(struct vm_device *dev, - void *start, - void *end); +int v3_dev_unhook_io(struct vm_device *dev, + ushort_t port); -int dev_unhook_mem(struct vm_device * dev, - void * start, - void * end); +int v3_dev_hook_mem(struct vm_device *dev, + void *start, + void *end); +int v3_dev_unhook_mem(struct vm_device * dev, + void * start, + void * end); -int dev_hook_irq(struct vm_device * dev, - uint_t irq, - int (*handler)(uint_t irq, struct vm_device * dev)); -int dev_unhook_irq(struct vm_device * dev, uint_t irq); + +int v3_dev_hook_irq(struct vm_device * dev, + uint_t irq, + int (*handler)(uint_t irq, struct vm_device * dev)); +int v3_dev_unhook_irq(struct vm_device * dev, uint_t irq);