Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for put with signal operation #218

Closed
wants to merge 30 commits into from
Closed
Show file tree
Hide file tree
Changes from 28 commits
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
fd54dd3
Add initial support for put with signal
naveen-rn May 24, 2018
2c4075c
Update put+signal after RMA WG meeting
naveen-rn May 24, 2018
83fd993
RM memory segment reference from put_signal notes
naveen-rn May 26, 2018
5680e75
rm ping-pong and add ring-bcast for put_sig example
naveen-rn May 26, 2018
7c8e3bb
add changelog for blocking put_signal
naveen-rn May 26, 2018
86981ad
Implement initial reviews for put-with-sig
naveen-rn Jun 29, 2018
643f4d0
Implement reviews for put-with-sig - draft 2
naveen-rn Jun 29, 2018
fce2079
Fix example code after put-with-signal reading
naveen-rn Jul 23, 2018
a67a5f3
Reword signal argument defn as per review
naveen-rn Aug 7, 2018
8f55c03
Update sig_addr dst data object kind explanation
naveen-rn Aug 8, 2018
dc36e68
Add put-with-signal in p2p-sync intro
naveen-rn Sep 10, 2018
34a33e5
Add restrict qualifier to sig_addr
naveen-rn Sep 10, 2018
ecfdb21
RM reference to put-with-signal from p2p sync intro
naveen-rn Oct 8, 2018
5c67d33
RM restrict qualifier from the put-with-signal usage
naveen-rn Oct 8, 2018
8cd7a55
Add new context arg explanation in PWS
naveen-rn Oct 8, 2018
47bc318
Fix review comments for PWS example
naveen-rn Oct 8, 2018
2466053
Duplicate PSW explanation from API summary to description
naveen-rn Oct 8, 2018
2662d76
Update the put-with-signal example
naveen-rn Oct 11, 2018
266564e
Adding overlapping semantics in put-with-signal
naveen-rn Oct 18, 2018
9e879c4
Reorder RMA operations in put-with-signal example
naveen-rn Oct 22, 2018
6c20a84
Explicitly state the signal update is AMO
naveen-rn Jan 8, 2019
441d681
Move NBI put-with-signal apiimpnotes to apinotes
naveen-rn Jan 9, 2019
c8ab483
Change put-with-signal in backmatter
naveen-rn Jan 12, 2019
45fef4a
RM unnecessary \signal and use \VAR{signal} instead
naveen-rn Jan 12, 2019
5ad32c7
Fix \VAR usage correctly for dest and source
naveen-rn Jan 12, 2019
ada81c9
RM unnecessary restrict qualifier from macros
naveen-rn Jan 12, 2019
0908eda
Reframe signal-put compatibility with p2p syncs
naveen-rn Jan 15, 2019
da476d8
Add support for different sig update operations
naveen-rn Apr 11, 2019
3d300e9
Update put-with-signal operation
naveen-rn May 3, 2019
cee7f53
Reframe the atomicity guarantees for p-w-s
naveen-rn May 3, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions content/backmatter.tex
Original file line number Diff line number Diff line change
Expand Up @@ -510,6 +510,9 @@ \section{Version 1.5}
The following list describes the specific changes in \openshmem[1.5]:
\begin{itemize}
%
\item Added support for blocking put-with-signal functions.
\\ See Section \ref{subsec:shmem_put_signal}.
%
\item Specified the validity of communication contexts, added the constant
\CONST{SHMEM\_CTX\_INVALID}, and clarified the behavior of
\FUNC{shmem\_ctx\_*} routines on invalid contexts.
Expand Down
14 changes: 14 additions & 0 deletions content/library_constants.tex
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,20 @@
See Section~\ref{subsec:shmem_ctx_create} for more detail about its use.
\tabularnewline \hline
%%
\color{ForestGreen}
\LibConstDecl{SHMEM\_SIGNAL\_SET} &
\color{ForestGreen}
An integer constant expression corresponding to the signal update set operation.
See Section~\ref{subsec:shmem_put_signal} for more detail about its use.
\tabularnewline \hline
%%
\color{ForestGreen}
\LibConstDecl{SHMEM\_SIGNAL\_ADD} &
\color{ForestGreen}
An integer constant expression corresponding to the signal update add operation.
See Section~\ref{subsec:shmem_put_signal} for more detail about its use.
\tabularnewline \hline
%%
\LibConstDecl{SHMEM\_SYNC\_VALUE}
\begin{DeprecateBlock}
\LibConstDecl{\_SHMEM\_SYNC\_VALUE}
Expand Down
4 changes: 2 additions & 2 deletions content/p2p_sync_intro.tex
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@
object.
The point-to-point synchronization routines can be used to portably ensure
that memory access operations observe remote updates in the order enforced by
the initiator \ac{PE} using the \FUNC{shmem\_fence} and \FUNC{shmem\_quiet}
routines.
the initiator \ac{PE} using the put-with-signal, \FUNC{shmem\_fence} and
\FUNC{shmem\_quiet} routines.

Where appropriate compiler support is available, \openshmem provides
type-generic point-to-point synchronization interfaces via \Cstd[11] generic
Expand Down
107 changes: 107 additions & 0 deletions content/shmem_put_signal.tex
Original file line number Diff line number Diff line change
@@ -0,0 +1,107 @@
\color{ForestGreen}
\apisummary{
The put-with-signal routines provide a method for copying data from a
contiguous local data object to a data object on a specified \ac{PE}
and subsequently update a remote flag to signal completion.
}

\begin{apidefinition}

\begin{C11synopsis}
void @\FuncDecl{shmem\_put\_signal}@(TYPE *dest, const TYPE *source, size_t nelems, uint64_t *sig_addr, uint64_t signal, int sig_op, int pe);
void @\FuncDecl{shmem\_put\_signal}@(shmem_ctx_t ctx, TYPE *dest, const TYPE *source, size_t nelems, uint64_t *sig_addr, uint64_t signal, int sig_op, int pe);
\end{C11synopsis}
where \TYPE{} is one of the standard \ac{RMA} types specified by Table \ref{stdrmatypes}.

\begin{Csynopsis}
void @\FuncDecl{shmem\_\FuncParam{TYPENAME}\_put\_signal}@(TYPE *dest, const TYPE *source, size_t nelems, uint64_t *sig_addr, uint64_t signal, int sig_op, int pe);
void @\FuncDecl{shmem\_ctx\_\FuncParam{TYPENAME}\_put\_signal}@(shmem_ctx_t ctx, TYPE *dest, const TYPE *source, size_t nelems, uint64_t *sig_addr, uint64_t signal, int sig_op, int pe);
\end{Csynopsis}
where \TYPE{} is one of the standard \ac{RMA} types and has a corresponding \TYPENAME{} specified by Table \ref{stdrmatypes}.

\begin{CsynopsisCol}
void @\FuncDecl{shmem\_put\FuncParam{SIZE}\_signal}@(void *dest, const void *source, size_t nelems, uint64_t *sig_addr, uint64_t signal, int sig_op, int pe);
void @\FuncDecl{shmem\_ctx\_put\FuncParam{SIZE}\_signal}@(shmem_ctx_t ctx, void *dest, const void *source, size_t nelems, uint64_t *sig_addr, uint64_t signal, int sig_op, int pe);
\end{CsynopsisCol}
where \SIZE{} is one of \CONST{8, 16, 32, 64, 128}.
jdinan marked this conversation as resolved.
Show resolved Hide resolved

\begin{CsynopsisCol}
void @\FuncDecl{shmem\_putmem\_signal}@(void *dest, const void *source, size_t nelems, uint64_t *sig_addr, uint64_t signal, int sig_op, int pe);
void @\FuncDecl{shmem\_ctx\_putmem\_signal}@(shmem_ctx_t ctx, void *dest, const void *source, size_t nelems, uint64_t *sig_addr, uint64_t signal, int sig_op, int pe);
\end{CsynopsisCol}

\begin{apiarguments}
\apiargument{IN}{ctx}{A context handle specifying the context on which to
perform the operation. When this argument is not provided, the operation is
performed on the default context.}
\apiargument{OUT}{dest}{Data object to be updated on the remote \ac{PE}. This
data object must be remotely accessible.}
\apiargument{IN}{source}{Data object containing the data to be copied.}
\apiargument{IN}{nelems}{Number of elements in the \dest{} and \source{}
arrays. \VAR{nelems} must be of type \VAR{size\_t} for \Cstd.}
\apiargument{OUT}{sig\_addr}{Data object to be updated on the remote
\ac{PE} as the signal. This signal data object must be
remotely accessible.}
\apiargument{IN}{signal}{Unsigned 64-bit value that is assigned to the
remote \VAR{sig\_addr} signal data object.}
\apiargument{IN}{sig\_op}{Signal operator that represents the type of update
to be performed to the remote \VAR{sig\_addr} signal data object.}
\apiargument{IN}{pe}{\ac{PE} number of the remote \ac{PE}.}
\end{apiarguments}

\apidescription{
The put-with-signal routines provide a method for copying data from a
contiguous local data object to a data object on a specified \ac{PE}
and subsequently update a remote flag to signal completion. The routines
return after the data has been copied out of the \source{} array on the
local \ac{PE}.

The \VAR{sig\_op} signal operator determines the type of update to be
performed on the remote \VAR{sig\_addr} signal data object. The completion
of signal update based on the \VAR{sig\_op} signal operator using the
\VAR{signal} flag on the remote \ac{PE} indicates the delivery of its
corresponding \dest{} data words into the data object on the remote \ac{PE}.
}
jdinan marked this conversation as resolved.
Show resolved Hide resolved

\apireturnvalues{
None.
}

\apinotes{
The \dest{} and \VAR{sig\_addr} data objects must both be remotely
accessible. The \VAR{sig\_addr} and \dest{} could be of different kinds,
for example, one could be a global/static \Cstd variable and the other could
be allocated on the symmetric heap.

The \VAR{sig\_addr} and \dest{} may not be overlapping in memory.

The completion of signal update using the \VAR{signal} flag on the remote
\ac{PE} indicates only the delivery of its corresponding \dest{} data words
into the data object on the remote \ac{PE}. Without a memory-ordering
operation, there is no implied ordering between the signal update of a
put-with-signal routine and another data transfer. For example, the
completion of the signal update in a sequence consisting of a put routine
followed by a put-with-signal routine does not imply delivery of the put
routine's data.

The signal update by the put-with-signal routines is compatible with all
point-to-point synchronization interfaces. The delivery of \VAR{signal} flag
based on the \VAR{sig\_op} signal operator on the remote \ac{PE} must not
cause partial updates. Only concurrent accesses on \VAR{sig\_addr} by
different signal update operations using the same signal update operator is
guaranteed to be exclusive.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would suggest to clarify what "exclusive" means in this context.

}

\begin{apiexamples}

\apicexample
{The following example demonstrates the usage of \FUNC{shmem\_put\_signal}.
It shows the implementation of a broadcast operation from \ac{PE} 0 to
itself and all other \acp{PE} in the job as a simple ring-based algorithm
using \FUNC{shmem\_put\_signal}:}
{./example_code/shmem_put_signal_example.c}
{}
\end{apiexamples}

\end{apidefinition}
\color{black}
37 changes: 37 additions & 0 deletions example_code/shmem_put_signal_example.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
#include <shmem.h>
#include <stdio.h>
naveen-rn marked this conversation as resolved.
Show resolved Hide resolved
#include <stdlib.h>
#include <string.h>

int main(void)
{
int i, err_count = 0;

shmem_init();

size_t size = 2048;
int me = shmem_my_pe();
int n = shmem_n_pes();
int pe = (me + 1) % n;
uint64_t * message = malloc(size * sizeof(uint64_t));
static uint64_t sig_addr = 0;

for (i = 0; i < size; i++) {
message[i] = me;
}

uint64_t *data = shmem_calloc(size, sizeof(uint64_t));

if (me == 0) {
shmem_put_signal(data, message, size, &sig_addr, 1, SHMEM_SIGNAL_SET, pe);
} else {
shmem_wait_until(&sig_addr, SHMEM_CMP_EQ, 1);
shmem_put_signal(data, data, size, &sig_addr, 1, SHMEM_SIGNAL_SET, pe);
}
jdinan marked this conversation as resolved.
Show resolved Hide resolved

free(message);
shmem_free(data);

shmem_finalize();
return 0;
}
3 changes: 3 additions & 0 deletions main_spec.tex
Original file line number Diff line number Diff line change
Expand Up @@ -170,6 +170,9 @@ \subsubsection{\textbf{SHMEM\_P}}\label{subsec:shmem_p}
\subsubsection{\textbf{SHMEM\_IPUT}}\label{subsec:shmem_iput}
\input{content/shmem_iput.tex}

\subsubsection{\textbf{SHMEM\_PUT\_SIGNAL}}\label{subsec:shmem_put_signal}
\input{content/shmem_put_signal.tex}

\subsubsection{\textbf{SHMEM\_GET}}\label{subsec:shmem_get}
\input{content/shmem_get.tex}

Expand Down
11 changes: 7 additions & 4 deletions utils/defs.tex
Original file line number Diff line number Diff line change
Expand Up @@ -408,14 +408,16 @@
\textbf{C11:}
\lstset{language={C}, backgroundcolor=\color{gray}, lineskip=2pt,
escapechar=@,
morekeywords={size_t, ptrdiff_t, TYPE, _Noreturn, shmem_ctx_t},
morekeywords={size_t, ptrdiff_t, TYPE, _Noreturn, shmem_ctx_t,
uint64_t},
aboveskip=0pt, belowskip=0pt}}{}

\lstnewenvironment{CsynopsisCol}
{
\lstset{language={C}, backgroundcolor=\color{gray}, lineskip=2pt,
escapechar=@,
morekeywords={size_t, ptrdiff_t, TYPE, TYPENAME, SIZE, shmem_ctx_t},
morekeywords={size_t, ptrdiff_t, TYPE, TYPENAME, SIZE, shmem_ctx_t,
uint64_t},
aboveskip=0pt, belowskip=0pt}}{}


Expand All @@ -424,7 +426,8 @@
\textbf{C/C++:}
\lstset{language={C}, backgroundcolor=\color{gray}, lineskip=2pt,
escapechar=@,
morekeywords={size_t, ptrdiff_t, TYPE, TYPENAME, SIZE, shmem_ctx_t},
morekeywords={size_t, ptrdiff_t, TYPE, TYPENAME, SIZE, shmem_ctx_t,
uint64_t},
aboveskip=0pt, belowskip=0pt}}{}

\lstnewenvironment{CsynopsisST}
Expand Down Expand Up @@ -516,7 +519,7 @@
##1
\lstinputlisting[language={C}, tabsize=2,
basicstyle=\ttfamily\footnotesize,
morekeywords={size_t, ptrdiff_t, shmem_ctx_t, _Thread_local}]{##2}
morekeywords={size_t, ptrdiff_t, shmem_ctx_t, _Thread_local, uint64_t}]{##2}
##3 }
\newcommand{\apifexample}[3]{
##1
Expand Down