2022-11-11 11:20:30 +01:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdio.h>
|
2023-01-29 09:40:55 +01:00
|
|
|
#ifdef USE_CUDA
|
|
|
|
#ifndef __CUDACC__
|
|
|
|
#include "cuda_runtime.h"
|
|
|
|
#endif
|
|
|
|
#endif
|
2022-11-11 11:20:30 +01:00
|
|
|
|
|
|
|
#include "include/utils.h"
|
|
|
|
#include "include/colors.h"
|
|
|
|
|
|
|
|
|
|
|
|
int i_div_up(int a, int b) { // Partie entière supérieure de a/b
|
|
|
|
return ((a % b) != 0) ? (a / b + 1) : (a / b);
|
|
|
|
}
|
|
|
|
|
2023-01-29 09:40:55 +01:00
|
|
|
#ifdef __CUDACC__
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
2022-11-11 11:20:30 +01:00
|
|
|
bool check_cuda_compatibility() {
|
|
|
|
#ifdef __CUDACC__
|
|
|
|
int nDevices;
|
|
|
|
cudaDeviceProp prop;
|
|
|
|
|
|
|
|
cudaGetDeviceCount(&nDevices);
|
|
|
|
if (nDevices == 0) {
|
|
|
|
printf("Pas d'utilisation du GPU\n\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
printf("GPUs disponibles:\n");
|
|
|
|
|
|
|
|
for (int i=0; i < nDevices; i++) {
|
|
|
|
cudaGetDeviceProperties(&prop, i);
|
|
|
|
printf(" - %s\n", prop.name);
|
|
|
|
}
|
|
|
|
|
|
|
|
cudaGetDeviceProperties(&prop, 0);
|
|
|
|
printf("Utilisation du GPU: " BLUE "%s" RESET " (Compute capability: %d.%d)\n\n", prop.name, prop.major, prop.minor);
|
|
|
|
return true;
|
|
|
|
#else
|
|
|
|
printf("Pas d'utilisation du GPU\n\n");
|
|
|
|
return false;
|
|
|
|
#endif
|
2023-01-28 22:04:38 +01:00
|
|
|
}
|
2023-01-29 09:40:55 +01:00
|
|
|
#ifdef __CUDACC__
|
2023-01-28 22:04:38 +01:00
|
|
|
}
|
2023-01-29 09:40:55 +01:00
|
|
|
#endif
|
2023-01-28 22:04:38 +01:00
|
|
|
|
|
|
|
|
2023-01-29 09:40:55 +01:00
|
|
|
#ifndef USE_CUDA
|
|
|
|
#ifdef __CUDACC__
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
void* nalloc(size_t sz) {
|
|
|
|
void* ptr = malloc(sz);
|
|
|
|
return ptr;
|
|
|
|
}
|
|
|
|
#ifdef __CUDACC__
|
|
|
|
}
|
|
|
|
#endif
|
2023-01-28 22:04:38 +01:00
|
|
|
|
2023-01-29 09:40:55 +01:00
|
|
|
#ifdef __CUDACC__
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
void gree(void* ptr) {
|
|
|
|
free(ptr);
|
|
|
|
}
|
|
|
|
#ifdef __CUDACC__
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#else
|
|
|
|
#ifdef __CUDACC__
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
void* nalloc(size_t sz) {
|
|
|
|
void* ptr;
|
|
|
|
cudaMallocManaged(&ptr, sz, cudaMemAttachHost);
|
|
|
|
return ptr;
|
|
|
|
}
|
|
|
|
#ifdef __CUDACC__
|
|
|
|
}
|
|
|
|
#endif
|
2023-01-28 22:04:38 +01:00
|
|
|
|
2023-01-29 09:40:55 +01:00
|
|
|
#ifdef __CUDACC__
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
void gree(void* ptr) {
|
|
|
|
cudaFree(ptr);
|
|
|
|
}
|
|
|
|
#ifdef __CUDACC__
|
|
|
|
}
|
|
|
|
#endif
|
2023-01-28 22:04:38 +01:00
|
|
|
#endif
|