CMakeLists.txt 5.58 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
include(ROCMClangTidy)
Paul's avatar
Paul committed
49
50
51
52
53
54
if(CMAKE_CXX_COMPILER MATCHES ".*hcc")
    set(MIGRAPHX_TIDY_ERRORS ERRORS * -readability-inconsistent-declaration-parameter-name)
# Enable tidy on hip
elseif(MIGRAPHX_ENABLE_GPU)
    set(MIGRAPHX_TIDY_ERRORS ALL)
endif()
Paul's avatar
Paul committed
55
56
57
58
59
60
61
62
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
63
        -clang-diagnostic-disabled-macro-expansion
Paul's avatar
Paul committed
64
        -clang-diagnostic-unused-command-line-argument
Paul's avatar
Paul committed
65
        -cppcoreguidelines-explicit-virtual-functions
Paul's avatar
Paul committed
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
        -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
81
        -hicpp-member-init
Paul's avatar
Paul committed
82
83
        -hicpp-no-array-decay
        -hicpp-special-member-functions
Paul's avatar
Paul committed
84
        -hicpp-uppercase-literal-suffix
Paul's avatar
Paul committed
85
        -hicpp-use-override
Paul's avatar
Paul committed
86
        # This check is broken
Paul's avatar
Paul committed
87
88
        -llvm-header-guard
        -llvm-include-order
Paul's avatar
Paul committed
89
        -misc-macro-parentheses
90
        -modernize-concat-nested-namespaces
Paul's avatar
Paul committed
91
92
        -modernize-pass-by-value
        -modernize-use-default-member-init
93
94
        -modernize-use-nodiscard
        -modernize-use-override
Paul's avatar
Paul committed
95
        -modernize-use-trailing-return-type
Paul's avatar
Paul committed
96
        -modernize-use-transparent-functors
Paul's avatar
Paul committed
97
        -performance-type-promotion-in-math-fn
Paul's avatar
Paul committed
98
99
100
        -readability-braces-around-statements
        -readability-else-after-return
        -readability-named-parameter
Paul's avatar
Paul committed
101
102
        -readability-uppercase-literal-suffix,
        -*-avoid-c-arrays
Paul's avatar
Paul committed
103
        -*-explicit-constructor
Paul's avatar
Paul committed
104
105
106
        -*-magic-numbers
        -*-non-private-member-variables-in-classes
        -*-use-auto
Paul's avatar
Paul committed
107
108
        -*-use-emplace
        -*-use-equals-default
Paul's avatar
Paul committed
109
    ${MIGRAPHX_TIDY_ERRORS}
Paul's avatar
Paul committed
110
111
112
    HEADER_FILTER
        ".*hpp"
    EXTRA_ARGS
Paul's avatar
Paul committed
113
        -DMIGRAPHX_USE_CLANG_TIDY
Paul's avatar
Paul committed
114
        "-Dmain\\\\(...\\\\)=main\\\\(__VA_ARGS__\\\\) // NOLINT"
Paul's avatar
Paul committed
115
116
117
118
119
120
    # CLANG_ARGS
    #     -analyzer-config optin.cplusplus.UninitializedObject:Pedantic=true
    #     -analyzer-config widen-loops=true
    #     -analyzer-config unroll-loops=true
    #     -analyzer-config cfg-lifetime=true
    #     -analyzer-config cfg-scopes=true
Paul's avatar
Paul committed
121
122
123
)
include(ROCMCppCheck)
rocm_enable_cppcheck(
Paul's avatar
Paul committed
124
    CHECKS
Paul's avatar
Paul committed
125
126
127
128
        warning
        style
        performance
        portability
Paul's avatar
Paul committed
129
130
131
132
133
134
135
    SUPPRESS 
        ConfigurationNotChecked
        unmatchedSuppression
        unusedFunction
        noExplicitConstructor
        passedByValue
        unusedStructMember
Paul's avatar
Paul committed
136
        functionStatic
Paul's avatar
Paul committed
137
        functionConst:*program.*
Paul's avatar
Paul committed
138
139
        shadowFunction
        shadowVar
Paul's avatar
Paul committed
140
141
        shadowVariable
        unsafeClassDivZero
Paul's avatar
Paul committed
142
        definePrefix:*test/include/test.hpp
Paul's avatar
Paul committed
143
    FORCE
Paul's avatar
Paul committed
144
    INCONCLUSIVE
Paul's avatar
Paul committed
145
146
    RULE_FILE
        ${CMAKE_CURRENT_SOURCE_DIR}/cppcheck.rules
Paul's avatar
Paul committed
147
148
149
150
    SOURCES
        src/
        test/
    INCLUDE
Paul's avatar
Paul committed
151
152
153
        ${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
154
        ${CMAKE_CURRENT_SOURCE_DIR}/test/include
Paul's avatar
Paul committed
155
156
    DEFINE
        CPPCHECK=1
Paul's avatar
Paul committed
157
158
        __device__=
        __host__=
Paul's avatar
Paul committed
159
)
Paul's avatar
Paul committed
160

Paul's avatar
Paul committed
161
162
enable_testing()

Paul's avatar
Paul committed
163
164
include(ROCMCreatePackage)
rocm_create_package(
Paul's avatar
Paul committed
165
    NAME MIGraphX
Paul's avatar
Paul committed
166
167
168
    DESCRIPTION "AMD's graph optimizer"
    MAINTAINER "Paul Fultz II <paul.fultz@amd.com>"
    LDCONFIG
Paul's avatar
Paul committed
169
    PTH
Paul's avatar
Paul committed
170
    DEPENDS miopen-hip rocblas hip_hcc half
Paul's avatar
Paul committed
171
172
)

173
174
175
176
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
177
add_subdirectory(src)
Paul's avatar
Paul committed
178
add_subdirectory(doc)
Paul's avatar
Paul committed
179
add_subdirectory(test)
Paul's avatar
Paul committed
180
add_subdirectory(tools)