mirror of
https://github.com/OpenMP/Examples.git
synced 2025-04-04 05:41:33 +01:00
Merge pull request #10 from HenryJin/ticket381+history
Ticket381+history
This commit is contained in:
commit
73f791b0ac
26
Changes.log
26
Changes.log
@ -23,10 +23,32 @@ Example_SIMD.7f.f
|
||||
Example_SIMD.8c.c
|
||||
Example_SIMD.8f.f
|
||||
|
||||
3. Other changes
|
||||
3. Misc modifications to examples (Tickets #180 and #295)
|
||||
|
||||
- Use C++ only header for the following C++ specific examples:
|
||||
threadprivate.4c
|
||||
threadprivate.5c
|
||||
pra_iterator.1c
|
||||
declare_target.2c
|
||||
|
||||
- Text description change in
|
||||
Examples_lock_owner.tex
|
||||
Examples_default_none.tex
|
||||
|
||||
4. Other changes (Ticket #381)
|
||||
|
||||
- openmp.sty
|
||||
use mnemonics for example naming
|
||||
added the \cppexample macro
|
||||
|
||||
- Move task depedence examples from tasking to a separate chapter.
|
||||
tasking.15-19 -> task_dep.1-5
|
||||
tasking.15-19 -> task_dep.1-5
|
||||
|
||||
Rename chapters:
|
||||
"Tasking Constructs" to "The task and taskwait Constructs"
|
||||
"The taskyield Directive" to "The taskyield Consutrcts"
|
||||
|
||||
- Add revision history
|
||||
|
||||
- Fix broken links
|
||||
-Chap-4 (icv), page 11: "According to $"
|
||||
|
@ -38,13 +38,15 @@ scope for the compiler to determine that a target binary should be available.
|
||||
|
||||
\section{\code{declare} \code{target} Construct for Class Type}
|
||||
|
||||
\cppspecificstart
|
||||
The following example shows how the \code{declare} \code{target} and \code{end}
|
||||
\code{declare} \code{target} directives are used to enclose the declaration
|
||||
of a variable \plc{varY} with a class type \code{typeY}. The member function \code{typeY::foo()} cannot
|
||||
be accessed on a target device because its declaration did not appear between \code{declare}
|
||||
\code{target} and \code{end} \code{declare} \code{target} directives.
|
||||
|
||||
\cexample{declare_target}{2c}
|
||||
\cnexample{declare_target}{2c}
|
||||
\cppspecificend
|
||||
|
||||
\section{\code{declare} \code{target} and \code{end} \code{declare} \code{target} for Variables}
|
||||
|
||||
|
@ -5,7 +5,14 @@
|
||||
The following example distinguishes the variables that are affected by the \code{default(none)}
|
||||
clause from those that are not.
|
||||
|
||||
\cexample{default_none}{1c}
|
||||
\ccppspecificstart
|
||||
Beginning with OpenMP 4.0, variables with \code{const}-qualified type and no mutable member
|
||||
are no longer predetermined shared. Thus, these variables (variable \plc{c} in the example)
|
||||
need to be explicitly listed
|
||||
in data-sharing attribute clauses when the \code{default(none)} clause is specified.
|
||||
|
||||
\cnexample{default_none}{1c}
|
||||
\ccppspecificend
|
||||
|
||||
\fexample{default_none}{1f}
|
||||
|
||||
|
@ -4,7 +4,7 @@
|
||||
|
||||
Ownership of locks has changed since OpenMP 2.5. In OpenMP 2.5, locks are owned
|
||||
by threads; so a lock released by the \code{omp\_unset\_lock} routine must be
|
||||
owned by the same thread executing the routine. With OpenMP 3.0, locks are owned
|
||||
owned by the same thread executing the routine. Beginning with OpenMP 3.0, locks are owned
|
||||
by task regions; so a lock released by the \code{omp\_unset\_lock} routine in
|
||||
a task region must be owned by the same task region.
|
||||
|
||||
@ -12,7 +12,7 @@ This change in ownership requires extra care when using locks. The following pro
|
||||
is conforming in OpenMP 2.5 because the thread that releases the lock \code{lck}
|
||||
in the parallel region is the same thread that acquired the lock in the sequential
|
||||
part of the program (master thread of parallel region and the initial thread are
|
||||
the same). However, it is not conforming in OpenMP 3.0 and 3.1, because the task
|
||||
the same). However, it is not conforming beginning with OpenMP 3.0, because the task
|
||||
region that releases the lock \code{lck} is different from the task region that
|
||||
acquires the lock.
|
||||
|
||||
|
@ -1,11 +1,11 @@
|
||||
\pagebreak
|
||||
\chapter{Parallel Random Access Iterator Loop}
|
||||
\ccppspecificstart
|
||||
\cppspecificstart
|
||||
\label{chap:pra_iterator}
|
||||
|
||||
The following example shows a parallel random access iterator loop.
|
||||
|
||||
\cnexample{pra_iterator}{1c}
|
||||
\ccppspecificend
|
||||
\cppspecificend
|
||||
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
\pagebreak
|
||||
\chapter{Tasking Constructs}
|
||||
\chapter{The \code{task} and \code{taskwait} Constructs}
|
||||
\label{chap:tasking}
|
||||
|
||||
The following example shows how to traverse a tree-like structure using explicit
|
||||
|
@ -1,5 +1,5 @@
|
||||
\pagebreak
|
||||
\chapter{The \code{taskyield} Directive}
|
||||
\chapter{The \code{taskyield} Construct}
|
||||
\label{chap:taskyield}
|
||||
|
||||
The following example illustrates the use of the \code{taskyield} directive.
|
||||
|
@ -89,7 +89,7 @@ The following is an example of the use of \code{threadprivate} for module variab
|
||||
\fnexample{threadprivate}{6f}
|
||||
\fortranspecificend
|
||||
|
||||
\ccppspecificstart
|
||||
\cppspecificstart
|
||||
The following example illustrates initialization of \code{threadprivate} variables
|
||||
for class-type \code{T}. \code{t1} is default constructed, \code{t2} is constructed
|
||||
taking a constructor accepting one argument of integer type, \code{t3} is copy
|
||||
@ -102,5 +102,5 @@ class members. The \code{threadprivate} directive for a static class member must
|
||||
be placed inside the class definition.
|
||||
|
||||
\cnexample{threadprivate}{5c}
|
||||
\ccppspecificend
|
||||
\cppspecificend
|
||||
|
||||
|
40
History.tex
Normal file
40
History.tex
Normal file
@ -0,0 +1,40 @@
|
||||
\chapter{Document Revision History}
|
||||
\label{chap:history}
|
||||
|
||||
\section{Changes from 4.0.1 to 4.0.2}
|
||||
|
||||
\begin{itemize}
|
||||
\item Names of examples were changed from numbers to mnemonics
|
||||
\item Added SIMD examples (\specref{chap:SIMD})
|
||||
\item Applied miscellaneous fixes in several source codes
|
||||
\item Added the revision history
|
||||
\end{itemize}
|
||||
|
||||
\section{Changes from 4.0 to 4.0.1}
|
||||
|
||||
Added the following new examples:
|
||||
\begin{itemize}
|
||||
\item the \code{proc\_bind} clause (\specref{chap:affinity})
|
||||
\item the \code{taskgroup} construct (\specref{chap:taskgroup})
|
||||
\end{itemize}
|
||||
|
||||
\section{Changes from 3.1 to 4.0}
|
||||
|
||||
Beginning with OpenMP 4.0, examples were placed in a separate document
|
||||
from the specification document.
|
||||
|
||||
Version 4.0 added the following new examples:
|
||||
\begin{itemize}
|
||||
\item task dependences (\specref{chap:task_dep})
|
||||
\item cancellation constructs (\specref{chap:cancellation})
|
||||
\item \code{target} construct (\specref{chap:target})
|
||||
\item \code{target} \code{data} construct (\specref{chap:target_data})
|
||||
\item \code{target} \code{update} construct (\specref{chap:target_update})
|
||||
\item \code{declare} \code{target} construct (\specref{chap:declare_target})
|
||||
\item \code{teams} constructs (\specref{chap:teams})
|
||||
\item asynchronous execution of a \code{target} region using tasks
|
||||
(\specref{chap:async_target})
|
||||
\item array sections in device constructs (\specref{chap:array_sections})
|
||||
\item device runtime routines (\specref{chap:device})
|
||||
\item Fortran ASSOCIATE construct (\specref{chap:associate})
|
||||
\end{itemize}
|
3
Makefile
3
Makefile
@ -67,7 +67,8 @@ CHAPTERS=Title_Page.tex \
|
||||
Examples_async_target.tex \
|
||||
Examples_array_sections.tex \
|
||||
Examples_device.tex \
|
||||
Examples_associate.tex
|
||||
Examples_associate.tex \
|
||||
History.tex
|
||||
|
||||
INTERMEDIATE_FILES=openmp-examples.pdf \
|
||||
openmp-examples.toc \
|
||||
|
7
README
7
README
@ -53,9 +53,10 @@ For a brief revision history, please see Changes.log.
|
||||
\fnexample{<ename>}{<seq-no>f}
|
||||
|
||||
- Language h-rules
|
||||
\cspecificbegin, \cspecificend
|
||||
\cppspecificbegin, \cppspecificend
|
||||
\fortranspecificbegin, \fortranspecificend
|
||||
\cspecificstart, \cspecificend
|
||||
\cppspecificstart, \cppspecificend
|
||||
\ccppspecificstart, \ccppspecificend
|
||||
\fortranspecificstart, \fortranspecificend
|
||||
|
||||
- See openmp.sty for more information
|
||||
|
||||
|
@ -17,7 +17,7 @@
|
||||
|
||||
\vspace{1.0in}
|
||||
|
||||
\textbf{Version 4.0.2rv1 -- February, 2015}
|
||||
\textbf{Version 4.0.2rv3 -- February, 2015}
|
||||
\end{center}
|
||||
\end{adjustwidth}
|
||||
|
||||
@ -39,6 +39,7 @@ permission of OpenMP Architecture Review Board.\end{adjustwidth}
|
||||
\phantom{a}
|
||||
\emph{This page intentionally left blank}
|
||||
|
||||
This working version enacted the following tickets: 299, 342, and a few other editorial changes.
|
||||
This working version enacted the following tickets: 180, 295, 299, 342, 381,
|
||||
and a few other editorial changes.
|
||||
\vfill
|
||||
|
||||
|
@ -135,5 +135,6 @@
|
||||
\input{Examples_array_sections}
|
||||
\input{Examples_device}
|
||||
\input{Examples_associate}
|
||||
\input{History}
|
||||
\end{document}
|
||||
|
||||
|
@ -470,6 +470,12 @@
|
||||
\ccppspecificend
|
||||
}
|
||||
|
||||
\newcommand\cppexample[2]{%
|
||||
\needspace{5\baselineskip}\cppspecificstart
|
||||
\cnexample{#1}{#2}
|
||||
\cppspecificend
|
||||
}
|
||||
|
||||
\newcommand\fexample[2]{%
|
||||
\needspace{5\baselineskip}\fortranspecificstart
|
||||
\fnexample{#1}{#2}
|
||||
|
@ -13,14 +13,14 @@ void default_none(int a) {
|
||||
const int c = 1;
|
||||
int i = 0;
|
||||
|
||||
#pragma omp parallel default(none) private(a) shared(z)
|
||||
#pragma omp parallel default(none) private(a) shared(z, c)
|
||||
{
|
||||
int j = omp_get_num_threads();
|
||||
/* O.K. - j is declared within parallel region */
|
||||
a = z[j]; /* O.K. - a is listed in private clause */
|
||||
/* - z is listed in shared clause */
|
||||
x = c; /* O.K. - x is threadprivate */
|
||||
/* - c has const-qualified type */
|
||||
/* - c has const-qualified type and is listed in shared */
|
||||
z[i] = y; /* Error - cannot reference i or y here */
|
||||
|
||||
#pragma omp for firstprivate(y)
|
||||
|
Loading…
x
Reference in New Issue
Block a user