X-Git-Url: http://v3vee.org/palacios/gitweb/gitweb.cgi?a=blobdiff_plain;f=linux_module%2Fpalacios.h;h=4c8cf62988b5becf0b252160b0f7248d30ad4a4d;hb=3797543c14ea12fbc25021e6da4cd08a9959b8f2;hp=b4c17e6c7d4b5601389d305d0d30c5d4a10cc650;hpb=9feccf93cd8327d1d30a404a92f19716bf5a1e96;p=palacios.git diff --git a/linux_module/palacios.h b/linux_module/palacios.h index b4c17e6..4c8cf62 100644 --- a/linux_module/palacios.h +++ b/linux_module/palacios.h @@ -18,6 +18,9 @@ #define V3_ADD_PCI_HW_DEV 55 #define V3_ADD_PCI_USER_DEV 56 +#define V3_DVFS_CTRL 60 + + /* VM Specific IOCTLs */ #define V3_VM_CONSOLE_CONNECT 20 #define V3_VM_STREAM_CONNECT 21 @@ -44,6 +47,10 @@ #define V3_VM_FB_INPUT 257 #define V3_VM_FB_QUERY 258 +#define V3_VM_MEM_TRACK_SIZE 300 +#define V3_VM_MEM_TRACK_CMD 301 +#define V3_VM_MEM_TRACK_SNAP 302 + #define V3_VM_HOST_DEV_CONNECT 10245 #define V3_VM_KSTREAM_USER_CONNECT 11245 @@ -55,10 +62,9 @@ struct v3_guest_img { char name[128]; } __attribute__((packed)); -typedef enum { PREALLOCATED=0, // user space-allocated (e.g. hot remove) +typedef enum { PREALLOCATED=0, // user space-allocated (e.g. hot remove) REQUESTED, // kernel will attempt allocation (anywhere) REQUESTED32, // kernel will attempt allocation (<4GB) - } v3_mem_region_type_t; struct v3_mem_region { @@ -149,7 +155,7 @@ struct proc_dir_entry *palacios_get_procdir(void); void palacios_print_scoped(void *vm, int vcore, const char *fmt, ...); #define palacios_print(...) palacios_print_scoped(0,-1, __VA_ARGS__) // node_id=-1 => no node constraint -void *palacios_allocate_pages(int num_pages, unsigned int alignment, int node_id, int constraints); +void *palacios_allocate_pages(int num_pages, unsigned int alignment, int node_id, int (*filter_func)(void *paddr, void *filter_state), void *filter_state); void palacios_free_pages(void *page_addr, int num_pages); void *palacios_alloc(unsigned int size); // node_id=-1 => no node constraint @@ -159,8 +165,11 @@ void *palacios_valloc(unsigned int size); // use instead of vmalloc void palacios_vfree(void *); // use instead of vfree void *palacios_vaddr_to_paddr(void *vaddr); void *palacios_paddr_to_vaddr(void *paddr); -void *palacios_start_kernel_thread(int (*fn)(void * arg), void *arg, char *thread_name); -void *palacios_start_thread_on_cpu(int cpu_id, int (*fn)(void * arg), void *arg, char *thread_name); +void palacios_xcall(int cpu_id, void (*fn)(void *arg), void *arg); +void *palacios_create_and_start_kernel_thread(int (*fn)(void * arg), void *arg, char *thread_name); +void *palacios_create_thread_on_cpu(int cpu_id, int (*fn)(void * arg), void *arg, char *thread_name); +void palacios_start_thread(void *thread_ptr); +void *palacios_creeate_and_start_thread_on_cpu(int cpu_id, int (*fn)(void * arg), void *arg, char *thread_name); int palacios_move_thread_to_cpu(int new_cpu_id, void *thread_ptr); void palacios_yield_cpu(void); void palacios_sleep_cpu(unsigned int us);