CMakeLists.txt 5.11 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
        -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
75
        -hicpp-member-init
Paul's avatar
Paul committed
76
77
        -hicpp-no-array-decay
        -hicpp-special-member-functions
Paul's avatar
Paul committed
78
        -hicpp-uppercase-literal-suffix
Paul's avatar
Paul committed
79
        -hicpp-use-override
Paul's avatar
Paul committed
80
        # This check is broken
Paul's avatar
Paul committed
81
82
        -llvm-header-guard
        -llvm-include-order
Paul's avatar
Paul committed
83
        -misc-macro-parentheses
84
        -modernize-concat-nested-namespaces
Paul's avatar
Paul committed
85
86
        -modernize-pass-by-value
        -modernize-use-default-member-init
87
88
        -modernize-use-nodiscard
        -modernize-use-override
Paul's avatar
Paul committed
89
        -modernize-use-trailing-return-type
Paul's avatar
Paul committed
90
        -modernize-use-transparent-functors
Paul's avatar
Paul committed
91
        -performance-type-promotion-in-math-fn
Paul's avatar
Paul committed
92
93
94
        -readability-braces-around-statements
        -readability-else-after-return
        -readability-named-parameter
Paul's avatar
Paul committed
95
96
        -readability-uppercase-literal-suffix,
        -*-avoid-c-arrays
Paul's avatar
Paul committed
97
        -*-explicit-constructor
Paul's avatar
Paul committed
98
99
100
        -*-magic-numbers
        -*-non-private-member-variables-in-classes
        -*-use-auto
Paul's avatar
Paul committed
101
102
        -*-use-emplace
        -*-use-equals-default
Paul's avatar
Paul committed
103
104
105
106
107
108
    ERRORS
        *
        -readability-inconsistent-declaration-parameter-name
    HEADER_FILTER
        ".*hpp"
    EXTRA_ARGS
Paul's avatar
Paul committed
109
        -DMIGRAPHX_USE_CLANG_TIDY
Paul's avatar
Paul committed
110
        "-Dmain\\\\(...\\\\)=main\\\\(__VA_ARGS__\\\\) // NOLINT"
Paul's avatar
Paul committed
111
112
113
114

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

Paul's avatar
Paul committed
150
151
enable_testing()

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

162
163
164
165
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/lib)
set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/lib)
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/bin)

Paul's avatar
Paul committed
166
add_subdirectory(src)
Paul's avatar
Paul committed
167
add_subdirectory(doc)
Paul's avatar
Paul committed
168
add_subdirectory(test)
Paul's avatar
Paul committed
169
add_subdirectory(tools)