+static void instr_actor_on_creation(simgrid::s4u::ActorPtr actor)
+{
+ container_t root = simgrid::instr::Container::get_root();
+ container_t container = simgrid::instr::Container::by_name(actor->get_host()->get_name());
+
+ container->create_child(instr_pid(actor.get()), "ACTOR");
+ simgrid::instr::ContainerType* actor_type =
+ container->type_->by_name_or_create<simgrid::instr::ContainerType>("ACTOR");
+ simgrid::instr::StateType* state = actor_type->by_name_or_create<simgrid::instr::StateType>("ACTOR_STATE");
+ state->add_entity_value("suspend", "1 0 1");
+ state->add_entity_value("sleep", "1 1 0");
+ state->add_entity_value("receive", "1 0 0");
+ state->add_entity_value("send", "0 0 1");
+ state->add_entity_value("task_execute", "0 1 1");
+ root->type_->by_name_or_create("ACTOR_LINK", actor_type, actor_type);
+ root->type_->by_name_or_create("ACTOR_TASK_LINK", actor_type, actor_type);
+
+ actor->on_exit(
+ [](int status, void* actor) {
+ if (status == SMX_EXIT_FAILURE)
+ // kill means that this actor no longer exists, let's destroy it
+ simgrid::instr::Container::by_name(instr_pid(static_cast<simgrid::s4u::Actor*>(actor)))->remove_from_parent();
+ },
+ actor->get_impl());
+}
+
+static long long int counter = 0;
+
+static void instr_actor_on_migration_start(simgrid::s4u::ActorPtr actor)
+{
+ // start link
+ container_t container = simgrid::instr::Container::by_name(instr_pid(actor.get()));
+ simgrid::instr::Container::get_root()->get_link("ACTOR_LINK")->start_event(container, "M", std::to_string(counter));
+
+ // destroy existing container of this process
+ container->remove_from_parent();
+}
+
+static void instr_actor_on_migration_end(simgrid::s4u::ActorPtr actor)
+{
+ // create new container on the new_host location
+ simgrid::instr::Container::by_name(actor->get_host()->get_name())->create_child(instr_pid(actor.get()), "ACTOR");
+ // end link
+ simgrid::instr::Container::get_root()
+ ->get_link("ACTOR_LINK")
+ ->end_event(simgrid::instr::Container::by_name(instr_pid(actor.get())), "M", std::to_string(counter));
+ counter++;
+}
+
+static void instr_vm_on_creation(simgrid::s4u::Host& host)
+{
+ container_t container = new simgrid::instr::HostContainer(host, currentContainer.back());
+ container_t root = simgrid::instr::Container::get_root();
+ simgrid::instr::ContainerType* vm = container->type_->by_name_or_create<simgrid::instr::ContainerType>("VM");
+ simgrid::instr::StateType* state = vm->by_name_or_create<simgrid::instr::StateType>("VM_STATE");
+ state->add_entity_value("suspend", "1 0 1");
+ state->add_entity_value("sleep", "1 1 0");
+ state->add_entity_value("receive", "1 0 0");
+ state->add_entity_value("send", "0 0 1");
+ state->add_entity_value("task_execute", "0 1 1");
+ root->type_->by_name_or_create("VM_LINK", vm, vm);
+ root->type_->by_name_or_create("VM_ACTOR_LINK", vm, vm);
+}
+