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 8 9 10 11 12 13 14 15 16 17 18
 *
 **/

/**
 *
 * @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
 *
19
 * @version 0.9.0
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
 * @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
 **/
43
#if defined(CHAMELEON_USE_CUDA) && !defined(CHAMELEON_SIMULATION)
44 45 46
#include <cuda.h>
#include <cuda_runtime.h>
#include <cuda_runtime_api.h>
47
#if defined(CHAMELEON_USE_CUBLAS_V2)
48
#include <cublas.h>
49 50
#include <cublas_v2.h>
#else
51 52
#include <cublas.h>
#endif
53
#endif
54

55
#if defined(CHAMELEON_USE_OPENCL) && !defined(CHAMELEON_SIMULATION)
56 57 58
#include <OpenCL/cl.h>
#endif

59
#if defined(CHAMELEON_USE_MPI)
60 61 62 63
#include <mpi.h>
#endif

/** ****************************************************************************
64 65
 *  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
66 67 68 69
 **/
#ifndef LAPACK_NAME
#define LAPACK_NAME(a, b) lapackef77_##a
#endif
70 71 72 73 74 75

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

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

/*******************************************************************************
 *  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
97
#if defined(CHAMELEON_USE_MPI)
98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
#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[];
113
#define morse_lapack_const(morse_const) morse_lapack_constants[morse_const][0]
114 115 116 117 118

#ifdef __cplusplus
extern "C" {
#endif

119 120
#include "control/compute_s.h"
#include "control/compute_d.h"
121
#define COMPLEX
122 123
#include "control/compute_c.h"
#include "control/compute_z.h"
124 125 126 127 128 129 130 131 132 133 134 135 136 137
#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