* under the terms of the license (GNU LGPL) which comes with this package. */
#include "cpu_cas01.hpp"
-#include "vm_interface.hpp"
+#include "virtual_machine.hpp"
XBT_LOG_NEW_DEFAULT_SUBCATEGORY(surf_vm, surf,
"Logging specific to the SURF VM module");
* Callbacks *
*************/
-surf_callback(void, VM*) VMCreatedCallbacks;
-surf_callback(void, VM*) VMDestructedCallbacks;
-surf_callback(void, VM*) VMStateChangedCallbacks;
+surf_callback(void, VirtualMachine*) VMCreatedCallbacks;
+surf_callback(void, VirtualMachine*) VMDestructedCallbacks;
+surf_callback(void, VirtualMachine*) VMStateChangedCallbacks;
/*********
* Model *
* Resource *
************/
-VM::VM(Model *model, const char *name, xbt_dict_t props,
+VirtualMachine::VirtualMachine(Model *model, const char *name, xbt_dict_t props,
RoutingEdge *netElm, Cpu *cpu)
: Host(model, name, props, NULL, netElm, cpu)
{
VMModel::ws_vms.push_back(*this);
+
+ xbt_lib_set(host_lib, name, SURF_HOST_LEVEL, this);
+
surf_callback_emit(VMCreatedCallbacks, this);
}
* A physical host does not disappear in the current SimGrid code, but a VM may
* disappear during a simulation.
*/
-VM::~VM()
+VirtualMachine::~VirtualMachine()
{
surf_callback_emit(VMDestructedCallbacks, this);
VMModel::ws_vms.erase(VMModel::vm_list_t::s_iterator_to(*this));
}
-void VM::setState(e_surf_resource_state_t state){
+void VirtualMachine::setState(e_surf_resource_state_t state){
Resource::setState(state);
surf_callback_emit(VMStateChangedCallbacks, this);
}
* A surf level object will be useless in the upper layer. Returning the
* dict_elm of the host.
**/
-surf_resource_t VM::getPm()
+surf_resource_t VirtualMachine::getPm()
{
return xbt_lib_get_elm_or_null(host_lib, p_subWs->getName());
}