A
lgorithmique
N
umérique
D
istribuée
Public GIT Repository
projects
/
simgrid.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
more lambdas
[simgrid.git]
/
src
/
s4u
/
s4u_Mailbox.cpp
diff --git
a/src/s4u/s4u_Mailbox.cpp
b/src/s4u/s4u_Mailbox.cpp
index e7fb05d6b7e74053a85a7db43a8e92f4bc9f0ff1..abbf92e21add9e8cd079cbe6d8543a4ac387250a 100644
(file)
--- a/
src/s4u/s4u_Mailbox.cpp
+++ b/
src/s4u/s4u_Mailbox.cpp
@@
-44,6
+44,15
@@
bool Mailbox::listen()
return not this->empty() || (pimpl_->permanent_receiver_ && not pimpl_->done_comm_queue_.empty());
}
return not this->empty() || (pimpl_->permanent_receiver_ && not pimpl_->done_comm_queue_.empty());
}
+aid_t Mailbox::listen_from()
+{
+ kernel::activity::CommImplPtr comm = front();
+ if (comm && comm->src_actor_)
+ return comm->src_actor_->get_pid();
+ else
+ return -1;
+}
+
bool Mailbox::ready()
{
bool comm_ready = false;
bool Mailbox::ready()
{
bool comm_ready = false;
@@
-167,7
+176,7
@@
sg_mailbox_t sg_mailbox_by_name(const char* alias)
return simgrid::s4u::Mailbox::by_name(alias);
}
return simgrid::s4u::Mailbox::by_name(alias);
}
-const char* sg_mailbox_get_name(sg_mailbox_t mailbox)
+const char* sg_mailbox_get_name(
const_
sg_mailbox_t mailbox)
{
return mailbox->get_cname();
}
{
return mailbox->get_cname();
}
@@
-201,9
+210,16
@@
void* sg_mailbox_get(sg_mailbox_t mailbox)
return mailbox->get();
}
return mailbox->get();
}
+sg_comm_t sg_mailbox_get_async(sg_mailbox_t mailbox, void** data)
+{
+ auto comm = mailbox->get_async(data);
+ comm->add_ref();
+ return comm.get();
+}
+
void sg_mailbox_put(sg_mailbox_t mailbox, void* payload, long simulated_size_in_bytes)
{
void sg_mailbox_put(sg_mailbox_t mailbox, void* payload, long simulated_size_in_bytes)
{
-
return
mailbox->put(payload, simulated_size_in_bytes);
+ mailbox->put(payload, simulated_size_in_bytes);
}
sg_comm_t sg_mailbox_put_async(sg_mailbox_t mailbox, void* payload, long simulated_size_in_bytes)
}
sg_comm_t sg_mailbox_put_async(sg_mailbox_t mailbox, void* payload, long simulated_size_in_bytes)
@@
-212,3
+228,10
@@
sg_comm_t sg_mailbox_put_async(sg_mailbox_t mailbox, void* payload, long simulat
comm->add_ref();
return comm.get();
}
comm->add_ref();
return comm.get();
}
+
+sg_comm_t sg_mailbox_put_init(sg_mailbox_t mailbox, void* payload, long simulated_size_in_bytes)
+{
+ auto comm = mailbox->put_init(payload, simulated_size_in_bytes);
+ comm->add_ref();
+ return comm.get();
+}