X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/b8df87e176f27b25534f27d7e240defa32ca35bc..39f579ce40d3bd04d9f64a7914b07d1ec3334e4b:/src/plugins/dirty_page_tracking.cpp diff --git a/src/plugins/dirty_page_tracking.cpp b/src/plugins/dirty_page_tracking.cpp index 807dc1d090..ebf4968f87 100644 --- a/src/plugins/dirty_page_tracking.cpp +++ b/src/plugins/dirty_page_tracking.cpp @@ -4,6 +4,7 @@ * under the terms of the license (GNU LGPL) which comes with this package. */ #include "simgrid/plugins/live_migration.h" +#include "simgrid/s4u/Exec.hpp" #include "src/kernel/activity/ExecImpl.hpp" #include "src/plugins/vm/VirtualMachineImpl.hpp" @@ -11,7 +12,7 @@ namespace simgrid { namespace vm { class DirtyPageTrackingExt { bool dp_tracking_ = false; - std::map dp_objs_; + std::map dp_objs_; double dp_updated_by_deleted_tasks_ = 0.0; // Percentage of pages that get dirty compared to netspeed [0;1] bytes per 1 flop execution double dp_intensity_ = 0.0; @@ -23,9 +24,9 @@ public: void start_tracking(); void stop_tracking() { dp_tracking_ = false; } bool is_tracking() { return dp_tracking_; } - void track(kernel::activity::ExecImplPtr exec, double amount) { dp_objs_.insert({exec, amount}); } - void untrack(kernel::activity::ExecImplPtr exec) { dp_objs_.erase(exec); } - double get_stored_remains(kernel::activity::ExecImplPtr exec) { return dp_objs_.at(exec); } + void track(kernel::activity::ExecImpl const* exec, double amount) { dp_objs_.insert({exec, amount}); } + void untrack(kernel::activity::ExecImpl const* exec) { dp_objs_.erase(exec); } + double get_stored_remains(kernel::activity::ExecImpl const* exec) { return dp_objs_.at(exec); } void update_dirty_page_count(double delta) { dp_updated_by_deleted_tasks_ += delta; } double computed_flops_lookup(); double get_intensity() { return dp_intensity_; } @@ -67,14 +68,15 @@ double DirtyPageTrackingExt::computed_flops_lookup() } // namespace vm } // namespace simgrid -static void on_virtual_machine_creation(simgrid::vm::VirtualMachineImpl* vm) +static void on_virtual_machine_creation(simgrid::vm::VirtualMachineImpl& vm) { - vm->extension_set(new simgrid::vm::DirtyPageTrackingExt()); + vm.extension_set(new simgrid::vm::DirtyPageTrackingExt()); } -static void on_exec_creation(simgrid::kernel::activity::ExecImplPtr exec) +static void on_exec_creation(simgrid::s4u::Actor const&, simgrid::s4u::Exec const& e) { - simgrid::s4u::VirtualMachine* vm = dynamic_cast(exec->host_); + auto exec = static_cast(e.get_impl()); + simgrid::s4u::VirtualMachine* vm = dynamic_cast(exec->get_host()); if (vm == nullptr) return; @@ -85,9 +87,10 @@ static void on_exec_creation(simgrid::kernel::activity::ExecImplPtr exec) } } -static void on_exec_completion(simgrid::kernel::activity::ExecImplPtr exec) +static void on_exec_completion(simgrid::s4u::Actor const&, simgrid::s4u::Exec const& e) { - simgrid::s4u::VirtualMachine* vm = dynamic_cast(exec->host_); + auto exec = static_cast(e.get_impl()); + simgrid::s4u::VirtualMachine* vm = dynamic_cast(exec->get_host()); if (vm == nullptr) return; @@ -106,8 +109,8 @@ void sg_vm_dirty_page_tracking_init() simgrid::vm::DirtyPageTrackingExt::EXTENSION_ID = simgrid::vm::VirtualMachineImpl::extension_create(); simgrid::vm::VirtualMachineImpl::on_creation.connect(&on_virtual_machine_creation); - simgrid::kernel::activity::ExecImpl::on_creation.connect(&on_exec_creation); - simgrid::kernel::activity::ExecImpl::on_completion.connect(&on_exec_completion); + simgrid::s4u::Exec::on_start.connect(&on_exec_creation); + simgrid::s4u::Exec::on_completion.connect(&on_exec_completion); } }