Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
implement s4u::Comm::recv_async()
[simgrid.git] / include / simgrid / s4u / comm.hpp
index f8cfd8f..94b74cb 100644 (file)
@@ -30,9 +30,9 @@ public:
        /** Creates and start an async send to the mailbox #dest */
        static Comm &send_async(s4u::Actor *sender, Mailbox &dest, void *data, int simulatedByteAmount);
     /** Creates (but don't start) an async recv onto the mailbox #from */
-       //static Comm &recv_init(Mailbox &from);
+       static Comm &recv_init(s4u::Actor *receiver, Mailbox &from);
        /** Creates and start an async recv to the mailbox #from */
-       //static Comm &recv_async(Mailbox &from, void *data);
+       static Comm &recv_async(s4u::Actor *receiver, Mailbox &from, void **data);
 
        void start() override;
        void wait() override;
@@ -45,6 +45,8 @@ public:
        void setRate(double rate);
 
 private:
+       void *p_dstBuff = NULL;
+       size_t p_dstBuffSize = 0;
        void *p_srcBuff = NULL;
        size_t p_srcBuffSize = sizeof(void*);
 public:
@@ -55,17 +57,23 @@ public:
        /** Specify the data to send and its size */
        void setSrcData(void * buff, size_t size);
 
+       /** Specify where to receive the data */
+       void setDstData(void ** buff);
+       /** Specify the buffer in which the data should be received */
+       void setDstData(void ** buff, size_t size);
+       /** Retrieve the size of the received data */
+       size_t getDstDataSize();
+
+
 private: /* FIXME: expose these elements in the API */
        int p_detached = 0;
     int (*p_matchFunction)(void *, void *, smx_synchro_t) = NULL;
     void (*p_cleanFunction)(void *) = NULL;
     void (*p_copyDataFunction)(smx_synchro_t, void*, size_t) = NULL;
 
-
-
-
 private:
        Actor *p_sender = NULL;
+       Actor *p_receiver = NULL;
        Mailbox *p_mailbox = NULL;
 };