mirror of
https://github.com/TREX-CoE/irpjast.git
synced 2025-01-06 19:33:15 +01:00
Chameleon
This commit is contained in:
parent
aabd6cf003
commit
9b3ecb935a
4
Makefile
4
Makefile
@ -2,7 +2,7 @@ STARPU=~/StarPU/starpu-1.3.7/starpu-1.3.pc
|
|||||||
IRPF90 = irpf90/bin/irpf90 --codelet=factor_een:2 --align=64 # -s nelec_8:504 -s nnuc:100 -s ncord:5 #-a -d
|
IRPF90 = irpf90/bin/irpf90 --codelet=factor_een:2 --align=64 # -s nelec_8:504 -s nnuc:100 -s ncord:5 #-a -d
|
||||||
#FC = ifort -mkl=sequential -xCORE-AVX512 -g -qopt-zmm-usage=high
|
#FC = ifort -mkl=sequential -xCORE-AVX512 -g -qopt-zmm-usage=high
|
||||||
FC = ifort -mkl=sequential -march=core-avx2 -align array64byte -fma -ftz -fomit-frame-pointer
|
FC = ifort -mkl=sequential -march=core-avx2 -align array64byte -fma -ftz -fomit-frame-pointer
|
||||||
CC = gcc $(shell pkg-config --cflags $(STARPU) )
|
CC = gcc $(shell pkg-config --cflags $(STARPU) chameleon)
|
||||||
FCFLAGS= -O3 -I .
|
FCFLAGS= -O3 -I .
|
||||||
NINJA = ninja
|
NINJA = ninja
|
||||||
ARCHIVE = ar crs
|
ARCHIVE = ar crs
|
||||||
@ -10,7 +10,7 @@ RANLIB = ranlib
|
|||||||
|
|
||||||
SRC= qmckl_blas_f.f90 qmckl_dgemm.c
|
SRC= qmckl_blas_f.f90 qmckl_dgemm.c
|
||||||
OBJ= IRPF90_temp/qmckl_blas_f.o IRPF90_temp/qmckl_dgemm.o
|
OBJ= IRPF90_temp/qmckl_blas_f.o IRPF90_temp/qmckl_dgemm.o
|
||||||
LIB= -mkl=sequential $(shell pkg-config --libs $(STARPU) magma)
|
LIB= -mkl=sequential $(shell pkg-config --libs $(STARPU) chameleon magma)
|
||||||
|
|
||||||
-include irpf90.make
|
-include irpf90.make
|
||||||
export
|
export
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
/* Generated from qmckl_dgemm.org */
|
/* Generated from qmckl_dgemm.org */
|
||||||
|
|
||||||
#include <starpu.h>
|
#include <starpu.h>
|
||||||
|
#include <chameleon.h>
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
@ -223,64 +224,28 @@ void qmckl_dgemm(char transa, char transb,
|
|||||||
|
|
||||||
void qmckl_tasks_run(struct dgemm_args** gemms, int ngemms)
|
void qmckl_tasks_run(struct dgemm_args** gemms, int ngemms)
|
||||||
{
|
{
|
||||||
int rc = starpu_init(NULL);
|
int NCPU, NGPU;
|
||||||
starpu_cublas_init();
|
sscanf( getenv( "STARPU_NCPU" ), "%d", &NCPU );
|
||||||
|
sscanf( getenv( "STARPU_NCUDA" ), "%d", &NGPU );
|
||||||
|
|
||||||
assert (rc == 0);
|
int rc = CHAMELEON_Init(NCPU, NGPU);
|
||||||
|
|
||||||
starpu_data_handle_t matrix_handle[ngemms][3];
|
|
||||||
|
|
||||||
for (int i=0 ; i<ngemms ; ++i)
|
for (int i=0 ; i<ngemms ; ++i)
|
||||||
{
|
{
|
||||||
starpu_matrix_data_register(&(matrix_handle[i][0]),
|
CHAMELEON_dgemm(ChamNoTrans, ChamNoTrans,
|
||||||
STARPU_MAIN_RAM,
|
gemms[i]->m,
|
||||||
(uintptr_t) gemms[i]->A,
|
gemms[i]->n,
|
||||||
|
gemms[i]->k,
|
||||||
|
gemms[i]->alpha,
|
||||||
|
gemms[i]->A,
|
||||||
gemms[i]->lda,
|
gemms[i]->lda,
|
||||||
gemms[i]->m,
|
gemms[i]->B,
|
||||||
gemms[i]->k,
|
|
||||||
sizeof(double));
|
|
||||||
|
|
||||||
starpu_matrix_data_register(&(matrix_handle[i][1]),
|
|
||||||
STARPU_MAIN_RAM,
|
|
||||||
(uintptr_t) gemms[i]->B,
|
|
||||||
gemms[i]->ldb,
|
gemms[i]->ldb,
|
||||||
gemms[i]->k,
|
gemms[i]->beta,
|
||||||
gemms[i]->n,
|
gemms[i]->C,
|
||||||
sizeof(double));
|
gemms[i]->ldc);
|
||||||
|
|
||||||
starpu_matrix_data_register(&(matrix_handle[i][2]),
|
|
||||||
STARPU_MAIN_RAM,
|
|
||||||
(uintptr_t) gemms[i]->C,
|
|
||||||
gemms[i]->ldc,
|
|
||||||
gemms[i]->m,
|
|
||||||
gemms[i]->n,
|
|
||||||
sizeof(double));
|
|
||||||
|
|
||||||
struct starpu_task *task = starpu_task_create();
|
|
||||||
|
|
||||||
task->cl = &dgemm_cl;
|
|
||||||
task->cl_arg = gemms[i];
|
|
||||||
task->cl_arg_size = sizeof(*gemms[0]);
|
|
||||||
task->handles[0] = matrix_handle[i][0];
|
|
||||||
task->handles[1] = matrix_handle[i][1];
|
|
||||||
task->handles[2] = matrix_handle[i][2];
|
|
||||||
rc = starpu_task_submit(task);
|
|
||||||
assert (rc == 0);
|
|
||||||
}
|
}
|
||||||
starpu_task_wait_for_all();
|
CHAMELEON_Finalize();
|
||||||
|
|
||||||
for (int i=0 ; i<ngemms ; ++i)
|
|
||||||
{
|
|
||||||
starpu_data_unregister(matrix_handle[i][0]);
|
|
||||||
starpu_data_unregister(matrix_handle[i][1]);
|
|
||||||
starpu_data_unregister(matrix_handle[i][2]);
|
|
||||||
}
|
|
||||||
|
|
||||||
starpu_shutdown();
|
|
||||||
}
|
|
||||||
|
|
||||||
void alloc(void** ptr, int64_t size) {
|
|
||||||
printf("size: %ld\n", size);
|
|
||||||
starpu_malloc(ptr, (size_t) size * sizeof(double));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user