X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=linux_usr%2Fv3_ctrl.h;h=e81968c388681e8a1f4a16b4f0b2859aa0726007;hb=13843de52d67d647f8ef05f736dc8f7d8be6adb3;hp=082682570b25277adb3b7fbdf8107e5c7359738f;hpb=793f9cd53a472668dbeb16341085e5512484485c;p=palacios.releases.git diff --git a/linux_usr/v3_ctrl.h b/linux_usr/v3_ctrl.h index 0826825..e81968c 100644 --- a/linux_usr/v3_ctrl.h +++ b/linux_usr/v3_ctrl.h @@ -6,12 +6,24 @@ #ifndef _v3_ctrl_h #define _v3_ctrl_h -#define V3_START_GUEST 10 -#define V3_STOP_GUEST 11 +#include +#include +#include "ezxml.h" + +/* Global Control IOCTLs */ #define V3_CREATE_GUEST 12 #define V3_FREE_GUEST 13 +#define V3_ADD_MEMORY 50 +#define V3_RESET_MEMORY 51 +#define V3_ADD_PCI_HW_DEV 55 +#define V3_ADD_PCI_USER_DEV 56 + +/* VM Specific IOCTLs */ +/* VM Specific ioctls */ +#define V3_VM_CONSOLE_CONNECT 20 +#define V3_VM_SERIAL_CONNECT 21 #define V3_VM_PAUSE 23 #define V3_VM_CONTINUE 24 @@ -19,14 +31,23 @@ #define V3_VM_STOP 26 #define V3_VM_LOAD 27 #define V3_VM_SAVE 28 +#define V3_VM_SIMULATE 29 +#define V3_VM_INSPECT 30 +#define V3_VM_DEBUG 31 -#define V3_ADD_MEMORY 50 - -#define V3_VM_CONSOLE_CONNECT 20 -#define V3_VM_SERIAL_CONNECT 21 #define V3_VM_MOVE_CORE 33 +#define V3_VM_SEND 34 +#define V3_VM_RECEIVE 35 + +#define V3_VM_FB_INPUT 257 +#define V3_VM_FB_QUERY 258 + +#define V3_VM_HOST_DEV_CONNECT 10245 +#define V3_VM_KSTREAM_USER_CONNECT 11245 + + static const char * v3_dev = "/dev/v3vee"; struct v3_guest_img { @@ -48,9 +69,74 @@ struct v3_core_move_cmd{ } __attribute__((packed)); +struct v3_debug_cmd { + unsigned int core; + unsigned int cmd; +} __attribute__((packed)); + struct v3_chkpt_info { char store[128]; char url[256]; /* This might need to be bigger... */ } __attribute__((packed)); + + +struct v3_hw_pci_dev { + char url[128]; + unsigned int bus; + unsigned int dev; + unsigned int func; +} __attribute__((packed)); + +#define V3VEE_STR "\n\n" \ + "The V3Vee Project (c) 2012\n" \ + "\thttp://v3vee.org\n" \ + "\n\n" + +#define v3_usage(fmt, args...) \ +{ \ + printf(("\nUsage: %s " fmt V3VEE_STR), argv[0], ##args); \ + exit(0); \ +} + + +int v3_dev_ioctl (int req, void * arg); +int v3_vm_ioctl (const char * filename, + int req, + void * arg); +void * v3_mmap_file (const char * filename, int prot, int flags); +int v3_read_file (int fd, int size, unsigned char * buf); + +int launch_vm (const char * filename); +int stop_vm (const char * filename); + +unsigned long v3_hash_buffer (unsigned char * msg, unsigned int len); + +/* XML-related structs */ +struct cfg_value { + char * tag; + char * value; +}; + +struct xml_option { + char * tag; + ezxml_t location; + struct xml_option * next; +}; + + +struct file_info { + int size; + char filename[2048]; + char id[256]; +}; + +struct mem_file_hdr { + unsigned int file_idx; + unsigned int file_size; + unsigned long long file_offset; + unsigned long file_hash; +}; + + #endif