CMakeLists.txt 4.81 KB
Newer Older
Paul's avatar
Paul committed
1
2
cmake_minimum_required(VERSION 3.5)

3
4
5
6
if("${CMAKE_SOURCE_DIR}" STREQUAL "${CMAKE_BINARY_DIR}")
    message(FATAL_ERROR "The binary and source directroy cannot be the same")
endif()

Paul's avatar
Paul committed
7
8
9
10
11
12
# This has to be initialized before the project() command appears
# Set the default of CMAKE_BUILD_TYPE to be release, unless user specifies with -D.  MSVC_IDE does not use CMAKE_BUILD_TYPE
if( NOT MSVC_IDE AND NOT CMAKE_BUILD_TYPE )
    set( CMAKE_BUILD_TYPE Release CACHE STRING "Choose the type of build, options are: None Debug Release RelWithDebInfo MinSizeRel." )
endif()

Paul's avatar
Paul committed
13
14
15
16
17
18
19
# Default installation path
if(WIN32)
    set(CMAKE_INSTALL_PREFIX "/opt/rocm/x86_64-w64-mingw32" CACHE PATH "")
else()
    set(CMAKE_INSTALL_PREFIX "/opt/rocm" CACHE PATH "")
endif()

Paul's avatar
Paul committed
20
project(migraphx)
Paul's avatar
Paul committed
21
find_package(ROCM REQUIRED)
Paul's avatar
Paul committed
22

Paul's avatar
Paul committed
23
24
include(ROCMSetupVersion)

Paul's avatar
Paul committed
25
rocm_setup_version(VERSION 0.4)
Paul's avatar
Paul committed
26

Paul's avatar
Paul committed
27
28
option( BUILD_SHARED_LIBS "Build as a shared library" ON )

Paul's avatar
Paul committed
29
if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
Paul's avatar
Paul committed
30
    if(CMAKE_CXX_COMPILER_VERSION VERSION_LESS "5.4")
Paul's avatar
Paul committed
31
        message(FATAL_ERROR "MIGraph requires at least gcc 5.4")
Paul's avatar
Paul committed
32
33
34
    endif()
endif()

35
36
37
include(CheckCXXCompilerFlag)
check_cxx_compiler_flag("--cuda-host-only -x hip" HAS_HIP)
if(HAS_HIP)
Paul's avatar
Paul committed
38
    message(STATUS "Enable miopen backend")
Paul's avatar
Paul committed
39
    set(MIGRAPHX_ENABLE_GPU On CACHE BOOL "")
Paul's avatar
Paul committed
40
else()
Paul's avatar
Paul committed
41
    set(MIGRAPHX_ENABLE_GPU Off CACHE BOOL "")
Paul's avatar
Paul committed
42
43
endif()

Paul's avatar
Paul committed
44
45
add_compile_options(-std=c++14)

Paul's avatar
Paul committed
46
47
list(APPEND CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake)
include(EnableCompilerWarnings)
Paul's avatar
Paul committed
48
49
50
51
52
53
54
55
56
include(ROCMClangTidy)
rocm_enable_clang_tidy(
    CHECKS
        *
        -android-cloexec-fopen
        -clang-analyzer-alpha.core.CastToStruct
        -clang-analyzer-optin.performance.Padding
        -clang-diagnostic-deprecated-declarations
        -clang-diagnostic-extern-c-compat
Paul's avatar
Paul committed
57
        -clang-diagnostic-disabled-macro-expansion
Paul's avatar
Paul committed
58
        -clang-diagnostic-unused-command-line-argument
Paul's avatar
Paul committed
59
        -cppcoreguidelines-explicit-virtual-functions
Paul's avatar
Paul committed
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
        -cppcoreguidelines-pro-bounds-array-to-pointer-decay
        -cppcoreguidelines-pro-bounds-constant-array-index
        -cppcoreguidelines-pro-bounds-pointer-arithmetic
        -cppcoreguidelines-pro-type-member-init
        -cppcoreguidelines-pro-type-reinterpret-cast
        -cppcoreguidelines-pro-type-union-access
        -cppcoreguidelines-pro-type-vararg
        -cppcoreguidelines-special-member-functions
        -fuchsia-*
        -google-readability-braces-around-statements
        -google-readability-todo
        -google-runtime-int
        -google-runtime-references
        -hicpp-braces-around-statements
        -hicpp-explicit-conversions
        -hicpp-no-array-decay
        -hicpp-special-member-functions
Paul's avatar
Paul committed
77
        -hicpp-uppercase-literal-suffix
Paul's avatar
Paul committed
78
        -hicpp-use-override
Paul's avatar
Paul committed
79
        # This check is broken
Paul's avatar
Paul committed
80
81
        -llvm-header-guard
        -llvm-include-order
Paul's avatar
Paul committed
82
        -misc-macro-parentheses
Paul's avatar
Paul committed
83
        -modernize-use-override
Paul's avatar
Paul committed
84
85
        -modernize-pass-by-value
        -modernize-use-default-member-init
Paul's avatar
Paul committed
86
        -modernize-use-trailing-return-type
Paul's avatar
Paul committed
87
        -modernize-use-transparent-functors
Paul's avatar
Paul committed
88
        -performance-type-promotion-in-math-fn
Paul's avatar
Paul committed
89
90
91
        -readability-braces-around-statements
        -readability-else-after-return
        -readability-named-parameter
Paul's avatar
Paul committed
92
93
        -readability-uppercase-literal-suffix,
        -*-avoid-c-arrays
Paul's avatar
Paul committed
94
        -*-explicit-constructor
Paul's avatar
Paul committed
95
96
97
        -*-magic-numbers
        -*-non-private-member-variables-in-classes
        -*-use-auto
Paul's avatar
Paul committed
98
99
        -*-use-emplace
        -*-use-equals-default
Paul's avatar
Paul committed
100
101
102
103
104
105
    ERRORS
        *
        -readability-inconsistent-declaration-parameter-name
    HEADER_FILTER
        ".*hpp"
    EXTRA_ARGS
Paul's avatar
Paul committed
106
        -DMIGRAPHX_USE_CLANG_TIDY
Paul's avatar
Paul committed
107
        "-Dmain\\\\(...\\\\)=main\\\\(__VA_ARGS__\\\\) // NOLINT"
Paul's avatar
Paul committed
108
109
110
111

)
include(ROCMCppCheck)
rocm_enable_cppcheck(
Paul's avatar
Paul committed
112
    CHECKS
Paul's avatar
Paul committed
113
114
115
116
        warning
        style
        performance
        portability
Paul's avatar
Paul committed
117
118
119
120
121
122
123
    SUPPRESS 
        ConfigurationNotChecked
        unmatchedSuppression
        unusedFunction
        noExplicitConstructor
        passedByValue
        unusedStructMember
Paul's avatar
Paul committed
124
        functionStatic
Paul's avatar
Paul committed
125
        functionConst:*program.*
Paul's avatar
Paul committed
126
127
        shadowFunction
        shadowVar
Paul's avatar
Paul committed
128
129
        shadowVariable
        unsafeClassDivZero
Paul's avatar
Paul committed
130
        definePrefix:*test/include/test.hpp
Paul's avatar
Paul committed
131
    FORCE
Paul's avatar
Paul committed
132
    INCONCLUSIVE
Paul's avatar
Paul committed
133
134
    RULE_FILE
        ${CMAKE_CURRENT_SOURCE_DIR}/cppcheck.rules
Paul's avatar
Paul committed
135
136
137
138
    SOURCES
        src/
        test/
    INCLUDE
Paul's avatar
Paul committed
139
140
141
        ${CMAKE_CURRENT_SOURCE_DIR}/src/include
        ${CMAKE_CURRENT_SOURCE_DIR}/src/targets/cpu/include
        ${CMAKE_CURRENT_SOURCE_DIR}/src/targets/miopen/include
Paul's avatar
Paul committed
142
        ${CMAKE_CURRENT_SOURCE_DIR}/test/include
Paul's avatar
Paul committed
143
144
    DEFINE
        CPPCHECK=1
Paul's avatar
Paul committed
145
)
Paul's avatar
Paul committed
146

Paul's avatar
Paul committed
147
148
enable_testing()

Paul's avatar
Paul committed
149
150
include(ROCMCreatePackage)
rocm_create_package(
Paul's avatar
Paul committed
151
    NAME MIGraphX
Paul's avatar
Paul committed
152
153
154
    DESCRIPTION "AMD's graph optimizer"
    MAINTAINER "Paul Fultz II <paul.fultz@amd.com>"
    LDCONFIG
Paul's avatar
Paul committed
155
    PTH
Paul's avatar
Paul committed
156
    DEPENDS miopen-hip rocblas hip_hcc half
Paul's avatar
Paul committed
157
158
)

Paul's avatar
Paul committed
159
add_subdirectory(src)
Paul's avatar
Paul committed
160
add_subdirectory(doc)
Paul's avatar
Paul committed
161
add_subdirectory(test)
Paul's avatar
Paul committed
162
add_subdirectory(tools)