Implemented virtio-block
[akaros.git] / user / vmm / include / vmm / vmm.h
1 /* Copyright (c) 2015 Google Inc.
2  * Ron Minnich <rminnich@google.com>
3  * See LICENSE for details.
4  *
5  * VMM.h */
6
7 #pragma once
8
9 #include <ros/vmm.h>
10 #include <vmm/sched.h>
11
12 /* The listing of VIRTIO MMIO devices. We currently only expect to have 2,
13  * console and network. Only the console is fully implemented right now.*/
14 enum {
15         VIRTIO_MMIO_CONSOLE_DEV,
16         VIRTIO_MMIO_NETWORK_DEV,
17         VIRTIO_MMIO_BLOCK_DEV,
18
19         /* This should always be the last entry. */
20         VIRTIO_MMIO_MAX_NUM_DEV,
21 };
22
23 /* Structure to encapsulate all of the bookkeeping for a VM. */
24 struct virtual_machine {
25         struct guest_thread                     **gths;
26         unsigned int                            nr_gpcs;
27         struct vmm_gpcore_init          *gpcis;
28
29         /* TODO: put these in appropriate structures.  e.g., virtio things in
30          * something related to virtio.  low4k in something related to the guest's
31          * memory. */
32         uint8_t                                         *low4k;
33         struct virtio_mmio_dev          *virtio_mmio_devices[VIRTIO_MMIO_MAX_NUM_DEV];
34 };
35
36 char *regname(uint8_t reg);
37 int decode(struct guest_thread *vm_thread, uint64_t *gpa, uint8_t *destreg,
38            uint64_t **regp, int *store, int *size, int *advance);
39 bool io(struct guest_thread *vm_thread);
40 void showstatus(FILE *f, struct guest_thread *vm_thread);
41 uint64_t gvatogpa(struct guest_thread *vm_thread, uint64_t va);
42 uint64_t rippa(struct guest_thread *vm_thread);
43 int msrio(struct guest_thread *vm_thread, struct vmm_gpcore_init *gpci,
44           uint32_t opcode);
45 int do_ioapic(struct guest_thread *vm_thread, uint64_t gpa,
46               int destreg, uint64_t *regp, int store);
47 bool handle_vmexit(struct guest_thread *gth);
48 int __apic_access(struct guest_thread *vm_thread, uint64_t gpa, int destreg,
49                   uint64_t *regp, int store);
50 int vmm_interrupt_guest(struct virtual_machine *vm, unsigned int gpcoreid,
51                         unsigned int vector);
52
53 /* Lookup helpers */
54
55 static struct virtual_machine *gth_to_vm(struct guest_thread *gth)
56 {
57         return ((struct vmm_thread*)gth)->vm;
58 }
59
60 static struct vm_trapframe *gth_to_vmtf(struct guest_thread *gth)
61 {
62         return &gth->uthread.u_ctx.tf.vm_tf;
63 }
64
65 static struct vmm_gpcore_init *gth_to_gpci(struct guest_thread *gth)
66 {
67         struct virtual_machine *vm = gth_to_vm(gth);
68
69         return &vm->gpcis[gth->gpc_id];
70 }
71
72 static struct virtual_machine *get_my_vm(void)
73 {
74         return ((struct vmm_thread*)current_uthread)->vm;
75 }