<br><font size=2 face="sans-serif">Rajesh,</font>
<br>
<br><font size=2 face="sans-serif">These are excellent questions! We need
to provide better documentation on how the callback flow works ... baring
that, I'll answer your questions as they come and maybe we can pull together
a document after answering these questions on the mailing list.</font>
<br>
<br>
<br><font size=2 face="sans-serif">There are two types of callbacks - think
of them as &quot;local completion&quot; and &quot;remote notification&quot;
callbacks.</font>
<br>
<br><font size=2 face="sans-serif">The local completion callbacks are specified
not at registration time, but when an individual operation is started (DCMF_Send(),
for example). This callback is invoked by the dcmf runtime, when the local
node calls the DCMF_Messager_advance() function, after the source buffer
has been completely sent. &nbsp;Once the local completion callback is invoked
all buffers associated with the operation may be deallocated, etc.</font>
<br>
<br><font size=2 face="sans-serif">The callbacks that are registered for
DCMF_Send (and DCMF_Control, etc) with the DCMF_Send_register() function
are invoked by the dcmf runtime on the remote node when that node call
the DCMF_Messager_advance() function. Typically all nodes in the system
will periodically poll with DCMF_Messager_advance() to make progress, however
the BGP messager can be configured to enable an interupt to be fired when
a core receives a packet. &nbsp;In this interrupt mode active polling is
not required - although you do take a performance hit because of the overhead
of processing the interrupts.</font>
<br>
<br><font size=2 face="sans-serif">The remote callbacks for DCMF_Send are
invoked before any data has been written to the remote node. &nbsp;There
are two callback types and each has slightly different use by the application
programmer.</font>
<br>
<br><font size=2 face="sans-serif">The DCMF_RecvSendShort (&quot;short&quot;)
callbacks are invoked when the entire message has been received by the
remote node into a temporary location (on BGP this is a single packet of
data that has been received by the DMA into a memory fifo). &nbsp;The application's
responsibility is to copy the data out of the temporary buffer and into
the final destination buffer. This callback type was created specifically
to allow the dcmf implementation to optimize the performance for small
messages.</font>
<br>
<br><font size=2 face="sans-serif">The DCMF_RecvSend (&quot;long&quot;
or &quot;asynhcronous&quot;) callbacks are invoked when the control information
has been received by the remote node into a temporary location (on BGP
the control information will be contained in a single packet). &nbsp;The
application's responsibility is to allocate memory (DCMF_Request_t) for
the dcmf runtime to use to receive the rest of the data, as well as specify
the destination buffer and length and a (&quot;recv_done&quot;) callback.
This &quot;recv_done&quot; callback is invoked by the dcmf runtime when
the data has been completely received and written to the destination buffer.
&nbsp;Typically applications will free/deallocate the DCMF_Request_t memory
that was allocated previously.</font>
<br>
<br>
<br>
<br><font size=2 face="sans-serif">DCMF_Put and memory regions (i.e., registration,
pinning)</font>
<br>
<br><font size=2 face="sans-serif">The DCMF_Put in the library is just
stubbed in as we didn't have a need for it in release 1 of the BG/P software.
&nbsp;However, we are actively working on adding the DCMF_Put() into the
API which will also require a memory region API. The existing DCMF_Get
API will be updated to use these new memory regions objects. &nbsp;Perhaps
we should go into more detail on the memory region API in a separate email.</font>
<br>
<br>
<br><font size=2 face="sans-serif">I hope this helps!</font>
<br>
<br><font size=2 face="sans-serif">Michael Blocksome<br>
Blue Gene Messaging Team Lead<br>
Advanced Systems SW Development<br>
blocksom@us.ibm.com<br>
</font>
<br>
<br>
<br>
<table width=100%>
<tr valign=top>
<td width=40%><font size=1 face="sans-serif"><b>&quot;Rajesh Nishtala&quot;
&lt;rajeshn@eecs.berkeley.edu&gt;</b> </font>
<br><font size=1 face="sans-serif">Sent by: dcmf-bounces@lists.anl-external.org</font>
<p><font size=1 face="sans-serif">02/07/2008 12:01 PM</font>
<td width=59%>
<table width=100%>
<tr valign=top>
<td>
<div align=right><font size=1 face="sans-serif">To</font></div>
<td><font size=1 face="sans-serif">dcmf@lists.anl-external.org</font>
<tr valign=top>
<td>
<div align=right><font size=1 face="sans-serif">cc</font></div>
<td><font size=1 face="sans-serif">upc-devel@lbl.gov</font>
<tr valign=top>
<td>
<div align=right><font size=1 face="sans-serif">Subject</font></div>
<td><font size=1 face="sans-serif">[dcmf] Question about DCMF Library from
a new user</font></table>
<br>
<table>
<tr valign=top>
<td>
<td></table>
<br></table>
<br>
<br>
<br><tt><font size=2>Hi,<br>
 I am porting GASNet, our portable runtime layer for the Berkeley UPC<br>
compiler, to the BlueGene/P and i'm using DCMF as the lower level<br>
messaging layer. I have some high level questions regarding the<br>
library that will influence the design of our BlueGene/P port. The<br>
main difference between our library and MPI is that we focus on<br>
one-sided communication so my main questions are regarding these<br>
issues.<br>
<br>
+ When does the callback that gets registered with DCMF_Send() get<br>
called? Does it get called after the data has been committed to the<br>
memory on the remote node or does it simply imply that the data buffer<br>
is safe to reuse on the local node?<br>
<br>
+ I notice that when I do an nm on the dcmf libraries there is<br>
DCMF_Put() function, however when i waded through the code a little<br>
bit more I noticed that the function simply called an abort which to<br>
me implies that it is not implemented. Is this why it doesn't show up<br>
in the dcmf.h header files?<br>
<br>
+ I have heard that the BlueGene/P supports RDMA operations. Are there<br>
any special considerations for managing the memory registration (i.e.<br>
memory pinning) to enable these operations or is this done<br>
automatically under the covers?<br>
<br>
<br>
Thanks in advance for any help!<br>
<br>
Sincerely,<br>
Rajesh Nishtala<br>
_______________________________________________<br>
dcmf mailing list<br>
dcmf@lists.anl-external.org<br>
http://lists.anl-external.org/cgi-bin/mailman/listinfo/dcmf<br>
http://dcmf.anl-external.org/wiki<br>
</font></tt>
<br>