common.h 3.6 KB
Newer Older
1 2
/**
 *
Mathieu Faverge's avatar
Mathieu Faverge committed
3 4
 * @copyright 2009-2014 The University of Tennessee and The University of
 *                      Tennessee Research Foundation. All rights reserved.
5 6
 * @copyright 2012-2015 Bordeaux INP, CNRS (LaBRI UMR 5800), Inria,
 *                      Univ. Bordeaux. All rights reserved.
7
 *
Mathieu Faverge's avatar
Mathieu Faverge committed
8
 ***
9 10 11 12 13 14 15 16
 *
 * @file common.h
 *
 *  MORSE codelets kernel
 *  MORSE is a software package provided by Univ. of Tennessee,
 *  Univ. of California Berkeley and Univ. of Colorado Denver,
 *  and INRIA Bordeaux Sud-Ouest
 *
17
 * @version 0.9.0
18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
 * @author Mathieu Faverge
 * @author Cedric Castagnede
 * @date 2012-09-15
 *
 **/
/*******************************************************************************
 *  MORSE facilities of interest to both MORSE core developer
 *  and also of interest to MORSE community contributor.
 **/
#ifndef _MORSE_COMMON_H_
#define _MORSE_COMMON_H_


#if defined( _WIN32 ) || defined( _WIN64 )
#include <io.h>
#else
#include <unistd.h>
#endif

/** ****************************************************************************
 * Implementation headers
 **/
40
#if defined(CHAMELEON_USE_CUDA) && !defined(CHAMELEON_SIMULATION)
41 42 43
#include <cuda.h>
#include <cuda_runtime.h>
#include <cuda_runtime_api.h>
44
#if defined(CHAMELEON_USE_CUBLAS_V2)
45
#include <cublas.h>
46 47
#include <cublas_v2.h>
#else
48 49
#include <cublas.h>
#endif
50
#endif
51

52
#if defined(CHAMELEON_USE_OPENCL) && !defined(CHAMELEON_SIMULATION)
53 54 55
#include <OpenCL/cl.h>
#endif

56
#if defined(CHAMELEON_USE_MPI)
57 58 59 60
#include <mpi.h>
#endif

/** ****************************************************************************
61 62
 *  Line to avoid conflict with other linear algebra libraries, because, we
 *  don't know why but lapacke provide a wrong interface of lapack in fortran
63 64 65 66
 **/
#ifndef LAPACK_NAME
#define LAPACK_NAME(a, b) lapackef77_##a
#endif
67 68 69 70 71 72

/** ****************************************************************************
 *  Chameleon header files
 **/
#include "morse.h"

73 74
#include "control/global.h"
#include "control/auxiliary.h"
75 76
#include "control/context.h"
#include "control/descriptor.h"
77
#include "control/async.h"
78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93

/*******************************************************************************
 *  Global shortcuts
 **/
#define MORSE_RANK        morse_rank(morse)
#define MORSE_SIZE        morse->world_size
#define MORSE_GRPSIZE     morse->group_size
#define MORSE_NB          morse->nb
#define MORSE_IB          morse->ib
#define MORSE_NBNBSIZE    morse->nbnbsize
#define MORSE_IBNBSIZE    morse->ibnbsize
#define MORSE_SCHEDULING  morse->scheduling
#define MORSE_RHBLK       morse->rhblock
#define MORSE_TRANSLATION morse->translation
#define MORSE_PARALLEL    morse->parallel_enabled
#define MORSE_PROFILING   morse->profiling_enabled
94
#if defined(CHAMELEON_USE_MPI)
95 96 97 98 99 100 101 102 103 104 105 106 107 108 109
#define MORSE_MPI_RANK    morse->my_mpi_rank
#define MORSE_MPI_SIZE    morse->mpi_comm_size
#endif

/*******************************************************************************
 *  IPT internal define
 **/
#define MorseIPT_NoDep   0
#define MorseIPT_Panel   1
#define MorseIPT_All     2

/*******************************************************************************
 *  Global array of LAPACK constants
 **/
extern char *morse_lapack_constants[];
110
#define morse_lapack_const(morse_const) morse_lapack_constants[morse_const][0]
111 112 113 114 115

#ifdef __cplusplus
extern "C" {
#endif

116 117
#include "control/compute_s.h"
#include "control/compute_d.h"
118
#define COMPLEX
119 120
#include "control/compute_c.h"
#include "control/compute_z.h"
121 122 123 124 125 126 127 128 129 130 131 132 133 134
#undef COMPLEX

/*
void morse_pdlag2s(MORSE_context_t *morse);
void morse_pzlag2c(MORSE_context_t *morse);
void morse_pslag2d(MORSE_context_t *morse);
void morse_pclag2z(MORSE_context_t *morse);
*/

#ifdef __cplusplus
}
#endif

#endif