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

Generate similiar *.ll code as Clang does for #pragma omp target parallel #49

Open
wants to merge 15 commits into
base: aomp-dev
Choose a base branch
from

Conversation

DominikAdamski
Copy link
Contributor

No description provided.

@DominikAdamski DominikAdamski force-pushed the smpd_kernel_new_api_v1 branch from f864548 to 4e98c1c Compare April 21, 2022 10:17
@DominikAdamski DominikAdamski changed the title WIP: New OpenMP API for SPMD kernels Generate similiar *.ll code as Clang does for #pragma omp target parallel Apr 21, 2022
Done:
   Added declaration of kmpc_parallel_51
   Set constant args
   Added logic for setting up size of array which will
     contain target symbols
   Calling kmpc_parallel_51
   Moved deinit function just after kmpc_parallel_51

Not done:
   Passing symbols to target array
   Creating separate function which will reflect kernel code

Signed-off-by: Dominik Adamski <[email protected]>
kmpc_parallel_51 requires that offloaded symbols are passed
as addresses inside pointer array

Signed-off-by: Dominik Adamski <[email protected]>
Flang generates new SPMD kernels which use kmpc_parallel_51
function.

Signed-off-by: Dominik Adamski <[email protected]>
Signed-off-by: Dominik Adamski <[email protected]>
Do not assign new dtype value for device symbols via
get_type function. Use macros PASSBYVALP PASSBYREFP instead.

Remove hack for load/store of the last symbol.

Signed-off-by: Dominik Adamski <[email protected]>
Fixed passing scalars which type is different than int64.

Fixed passing allocatable arrays.

Signed-off-by: Dominik Adamski <[email protected]>
If we generate initialization function for SPMD
kernels we need to store addresses of the arguments before
we call kmpc_parallel_51 function. We use ptrtoint instruction
for scalar variables. Before this patch the LLVM IR code was generated
wrongly for complex variables:

void kernel_func(<float, float> *Arg_c)
//some code
ptrtoint i64* %Arg_c //error Arg_c was declared as pair of floats
//some code
call kmpc_parallel_51()
//some code

This patch causes that LLVM IR contains correct ptrtoint instruction:
void kernel_func(<float, float> *Arg_c)
//some code
ptrtoint <float, float>* %Arg_c //ok, Arg_c was declared as pair of floats
//some code
call kmpc_parallel_51()
//some code

Signed-off-by: Dominik Adamski <[email protected]>
Fortran objects should be passed as i64*

Signed-off-by: Dominik Adamski <[email protected]>
Signed-off-by: Dominik Adamski <[email protected]>
Clang uses kmpc_parallel_51 function for handlig target parallel for
pragma.

Flang should use the same functions as Clang for pragma
target parallel

Signed-off-by: Dominik Adamski <[email protected]>
@DominikAdamski DominikAdamski force-pushed the smpd_kernel_new_api_v1 branch from 4e98c1c to 3fb2323 Compare May 10, 2022 11:01
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant