X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/8bc85164acb335cf909052b966b2ee4932e06cd7..9bcd28fb0c558fbaa23ee46416f96baef5279045:/src/surf/ns3/ns3_simulator.hpp diff --git a/src/surf/ns3/ns3_simulator.hpp b/src/surf/ns3/ns3_simulator.hpp index a09388c1e7..f4cd203afa 100644 --- a/src/surf/ns3/ns3_simulator.hpp +++ b/src/surf/ns3/ns3_simulator.hpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2007-2020. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2007-2022. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ @@ -19,18 +19,14 @@ class XBT_PRIVATE NetPointNs3 { public: static simgrid::xbt::Extension EXTENSION_ID; - void set_name(std::string name) { name_ = name; } - explicit NetPointNs3(); - std::string name_; - ns3::Ptr ns3_node_; + ns3::Ptr ns3_node_ = ns3::CreateObject(0); std::string ipv4_address_; }; -XBT_PRIVATE void ns3_initialize(std::string TcpProtocol); XBT_PRIVATE void ns3_simulator(double max_seconds); -XBT_PRIVATE void ns3_add_direct_route(simgrid::kernel::routing::NetPoint* src, simgrid::kernel::routing::NetPoint* dst, - double bw, double lat, const std::string& link_name, +XBT_PRIVATE void ns3_add_direct_route(const simgrid::kernel::routing::NetPoint* src, + const simgrid::kernel::routing::NetPoint* dst, double bw, double lat, simgrid::s4u::Link::SharingPolicy policy); class XBT_PRIVATE SgFlow { @@ -40,8 +36,8 @@ public: // private: std::uint32_t buffered_bytes_ = 0; std::uint32_t sent_bytes_ = 0; - std::uint32_t remaining_; std::uint32_t total_bytes_; + std::uint32_t remaining_; bool finished_ = false; simgrid::kernel::resource::NetworkNS3Action* action_; }; @@ -55,39 +51,4 @@ static inline std::string transform_socket_ptr(ns3::Ptr local_socke return sstream.str(); } -class XBT_PRIVATE WifiZone { -public: - WifiZone(std::string name_, simgrid::s4u::Host* host_, ns3::Ptr ap_node_, - ns3::Ptr channel_, int mcs_, int nss_, int network_, int link_); - - const char* get_cname() { return name.c_str(); } - simgrid::s4u::Host* get_host() { return host; } - ns3::Ptr get_ap_node() { return ap_node; } - ns3::Ptr get_channel() { return channel; } - int get_mcs() { return mcs; } - int get_nss() { return nss; } - int get_network() { return network; } - int get_link() { return link; } - int get_n_sta_nodes() { return n_sta_nodes; } - - void set_network(int network_) { network = network_; } - void set_link(int link_) { link = link_; } - void add_sta_node() { n_sta_nodes++; } - - static bool is_ap(ns3::Ptr node); - static WifiZone* by_name(std::string name); - -private: - std::string name; - simgrid::s4u::Host* host; - ns3::Ptr ap_node; - ns3::Ptr channel; - int mcs; - int nss; - int network; - int link; - int n_sta_nodes = 0; - static std::unordered_map wifi_zones; -}; - #endif