1 /* This file only contains deprecated code, and will die with v3.25 */
3 /* Copyright (c) 2010-2023. The SimGrid Team. All rights reserved. */
5 /* This program is free software; you can redistribute it and/or modify it
6 * under the terms of the license (GNU LGPL) which comes with this package. */
8 #include "simgrid/config.h"
9 #include "simgrid/modelchecker.h"
10 #include "src/kernel/EngineImpl.hpp"
11 #include "src/kernel/activity/CommImpl.hpp"
12 #include "src/kernel/actor/SimcallObserver.hpp"
13 #include "src/mc/mc_replay.hpp"
14 #include <simgrid/s4u/Activity.hpp>
16 #define SIMIX_H_NO_DEPRECATED_WARNING // avoid deprecation warning on include (remove with XBT_ATTRIB_DEPRECATED_v335)
17 #include <simgrid/simix.h>
21 void simcall_comm_send(simgrid::kernel::actor::ActorImpl* sender, simgrid::kernel::activity::MailboxImpl* mbox,
22 double task_size, double rate, void* src_buff, size_t src_buff_size,
23 bool (*match_fun)(void*, void*, simgrid::kernel::activity::CommImpl*),
24 void (*copy_data_fun)(simgrid::kernel::activity::CommImpl*, void*, size_t), void* data,
25 double timeout) // XBT_ATTRIB_DEPRECATED_v335
27 xbt_assert(mbox, "No rendez-vous point defined for send");
28 simgrid::s4u::Comm::send(sender, mbox->get_iface(), task_size, rate, src_buff, src_buff_size, match_fun,
29 copy_data_fun, data, timeout);
32 simgrid::kernel::activity::ActivityImplPtr
33 simcall_comm_isend(simgrid::kernel::actor::ActorImpl* sender, simgrid::kernel::activity::MailboxImpl* mbox,
34 double task_size, double rate, void* src_buff, size_t src_buff_size,
35 bool (*match_fun)(void*, void*, simgrid::kernel::activity::CommImpl*), void (*clean_fun)(void*),
36 void (*copy_data_fun)(simgrid::kernel::activity::CommImpl*, void*, size_t), void* data,
37 bool detached) // XBT_ATTRIB_DEPRECATED_v335
39 /* checking for infinite values */
40 xbt_assert(std::isfinite(task_size), "task_size is not finite!");
41 xbt_assert(std::isfinite(rate), "rate is not finite!");
43 xbt_assert(mbox, "No rendez-vous point defined for isend");
45 simgrid::kernel::actor::CommIsendSimcall observer(sender, mbox, task_size, rate,
46 static_cast<unsigned char*>(src_buff), src_buff_size, match_fun,
47 clean_fun, copy_data_fun, data, detached);
48 return simgrid::kernel::actor::simcall_answered(
49 [&observer] { return simgrid::kernel::activity::CommImpl::isend(&observer); });
52 void simcall_comm_recv(simgrid::kernel::actor::ActorImpl* receiver, simgrid::kernel::activity::MailboxImpl* mbox,
53 void* dst_buff, size_t* dst_buff_size,
54 bool (*match_fun)(void*, void*, simgrid::kernel::activity::CommImpl*),
55 void (*copy_data_fun)(simgrid::kernel::activity::CommImpl*, void*, size_t), void* data,
56 double timeout, double rate) // XBT_ATTRIB_DEPRECATED_v335
58 xbt_assert(mbox, "No rendez-vous point defined for recv");
59 simgrid::s4u::Comm::recv(receiver, mbox->get_iface(), dst_buff, dst_buff_size, match_fun, copy_data_fun, data,
63 simgrid::kernel::activity::ActivityImplPtr
64 simcall_comm_irecv(simgrid::kernel::actor::ActorImpl* receiver, simgrid::kernel::activity::MailboxImpl* mbox,
65 void* dst_buff, size_t* dst_buff_size,
66 bool (*match_fun)(void*, void*, simgrid::kernel::activity::CommImpl*),
67 void (*copy_data_fun)(simgrid::kernel::activity::CommImpl*, void*, size_t), void* data,
68 double rate) // XBT_ATTRIB_DEPRECATED_v335
70 xbt_assert(mbox, "No rendez-vous point defined for irecv");
72 simgrid::kernel::actor::CommIrecvSimcall observer(receiver, mbox, static_cast<unsigned char*>(dst_buff),
73 dst_buff_size, match_fun, copy_data_fun, data, rate);
74 return simgrid::kernel::actor::simcall_answered(
75 [&observer] { return simgrid::kernel::activity::CommImpl::irecv(&observer); });
78 ssize_t simcall_comm_waitany(simgrid::kernel::activity::CommImpl* comms[], size_t count,
79 double timeout) // XBT_ATTRIB_DEPRECATED_v335
81 std::vector<simgrid::kernel::activity::ActivityImpl*> activities;
82 for (size_t i = 0; i < count; i++)
83 activities.push_back(static_cast<simgrid::kernel::activity::ActivityImpl*>(comms[i]));
84 simgrid::kernel::actor::ActorImpl* issuer = simgrid::kernel::actor::ActorImpl::self();
85 simgrid::kernel::actor::ActivityWaitanySimcall observer{issuer, activities, timeout};
86 ssize_t changed_pos = simgrid::kernel::actor::simcall_blocking(
88 simgrid::kernel::activity::ActivityImpl::wait_any_for(observer.get_issuer(), observer.get_activities(),
89 observer.get_timeout());
92 if (changed_pos != -1)
93 activities.at(changed_pos)->get_iface()->complete(simgrid::s4u::Activity::State::FINISHED);
97 ssize_t simcall_comm_testany(simgrid::kernel::activity::CommImpl* comms[], size_t count) // XBT_ATTRIB_DEPRECATED_v335
101 std::vector<simgrid::kernel::activity::ActivityImpl*> activities;
102 for (size_t i = 0; i < count; i++)
103 activities.push_back(static_cast<simgrid::kernel::activity::ActivityImpl*>(comms[i]));
105 simgrid::kernel::actor::ActorImpl* issuer = simgrid::kernel::actor::ActorImpl::self();
106 simgrid::kernel::actor::ActivityTestanySimcall observer{issuer, activities};
107 ssize_t changed_pos = simgrid::kernel::actor::simcall_blocking(
109 simgrid::kernel::activity::ActivityImpl::test_any(observer.get_issuer(), observer.get_activities());
112 if (changed_pos != -1)
113 comms[changed_pos]->get_iface()->complete(simgrid::s4u::Activity::State::FINISHED);
117 void simcall_comm_wait(simgrid::kernel::activity::ActivityImpl* comm, double timeout) // XBT_ATTRIB_DEPRECATED_v335
119 xbt_assert(std::isfinite(timeout), "timeout is not finite!");
120 simgrid::kernel::actor::ActorImpl* issuer = simgrid::kernel::actor::ActorImpl::self();
121 simgrid::kernel::actor::simcall_blocking([issuer, comm, timeout] { comm->wait_for(issuer, timeout); });
124 bool simcall_comm_test(simgrid::kernel::activity::ActivityImpl* comm) // XBT_ATTRIB_DEPRECATED_v335
126 simgrid::kernel::actor::ActorImpl* issuer = simgrid::kernel::actor::ActorImpl::self();
127 simgrid::kernel::actor::ActivityTestSimcall observer{issuer, comm};
128 if (simgrid::kernel::actor::simcall_blocking([&observer] { observer.get_activity()->test(observer.get_issuer()); },
130 comm->get_iface()->complete(simgrid::s4u::Activity::State::FINISHED);