[OpenMP][libomptarget] Enable usage of shared memory slots

Summary:
Allow the runtime to use the existing shared memory statically allocated slots.

When a variable is globalized, the underlying memory can be either shared or global memory (both have block-wide visibility). In this case, we allow that the storage to use a limited amount of shared memory that has been statically allocated already. Only if shared memory doesn't prove to be enough do we then invoke malloc() to create a new global memory slot.

Reviewers: ABataev, carlo.bertolli, grokos, caomhin

Reviewed By: grokos

Subscribers: guansong, openmp-commits

Differential Revision: https://reviews.llvm.org/D44486

llvm-svn: 327639
This commit is contained in:
Gheorghe-Teodor Bercea 2018-03-15 16:05:34 +00:00
parent c1c4ad6e64
commit 876c1ed2e5
1 changed files with 1 additions and 15 deletions

View File

@ -342,16 +342,7 @@ EXTERN void __kmpc_data_sharing_init_stack() {
DataSharingState.SlotPtr[WID] = RootS;
DataSharingState.TailPtr[WID] = RootS;
// Initialize the stack pointer to be equal to the end of
// the shared memory slot. This way we ensure that the global
// version of the stack will be used.
// TODO: remove this:
DataSharingState.StackPtr[WID] = RootS->DataEnd;
// TODO: When the use of shared memory is enabled we will have to
// initialize this with the start of the Data region like so:
// DataSharingState.StackPtr[WID] = (void *)&RootS->Data[0];
DataSharingState.StackPtr[WID] = (void *)&RootS->Data[0];
// We initialize the list of references to arguments here.
omptarget_nvptx_globalArgs.Init();
@ -368,11 +359,6 @@ EXTERN void __kmpc_data_sharing_init_stack() {
// Called by: master, TODO: call by workers
EXTERN void* __kmpc_data_sharing_push_stack(size_t DataSize,
int16_t UseSharedMemory) {
// TODO: Add shared memory support. For now, use global memory only for
// storing the data sharing slots so ignore the pre-allocated
// shared memory slot.
// Use global memory for storing the stack.
if (IsMasterThread()) {
unsigned WID = getWarpId();