CMakeLists.txt 1.99 KB
Newer Older
Paul's avatar
Paul committed
1
2
3
4

list(APPEND CMAKE_PREFIX_PATH /opt/rocm /opt/rocm/hip /opt/rocm/hcc)
find_package(miopen)

5
6
7
8
# rocblas
find_package(rocblas REQUIRED PATHS /opt/rocm)
message(STATUS "Build with rocblas")

Paul's avatar
Paul committed
9
10
11
12
if(NOT TARGET MIOpen)
    message(SEND_ERROR "Cant find miopen")
endif()

Paul's avatar
Paul committed
13
add_library(migraphx_device
Paul's avatar
Paul committed
14
    device/add.cpp
Khalique's avatar
Khalique committed
15
16
    device/max.cpp
    device/min.cpp
Shucai Xiao's avatar
Shucai Xiao committed
17
18
    device/exp.cpp
    device/log.cpp
19
    device/sin.cpp
Shucai Xiao's avatar
Shucai Xiao committed
20
21
    device/cos.cpp
    device/tan.cpp
22
23
    device/sinh.cpp
    device/cosh.cpp
24
25
26
    device/asin.cpp
    device/acos.cpp
    device/atan.cpp
Paul's avatar
Paul committed
27
    device/add_relu.cpp
28
    device/contiguous.cpp
29
    device/logsoftmax.cpp
Khalique's avatar
Khalique committed
30
    device/mul.cpp
31
    device/concat.cpp
32
    device/pad.cpp
33
    device/gather.cpp
34
    device/sub.cpp
35
)
Paul's avatar
Paul committed
36
37
set_target_properties(migraphx_device PROPERTIES EXPORT_NAME device)
rocm_clang_tidy_check(migraphx_device)
Paul's avatar
Paul committed
38
target_link_libraries(migraphx_device migraphx hip::device -Wno-invalid-command-line-argument -amdgpu-target=gfx803 -amdgpu-target=gfx900 -amdgpu-target=gfx906)
Paul's avatar
Paul committed
39
40
target_include_directories(migraphx_device PUBLIC $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>)
target_include_directories(migraphx_device PRIVATE $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/device/include>)
41

Paul's avatar
Paul committed
42
add_library(migraphx_gpu
43
    eliminate_workspace.cpp
Paul's avatar
Paul committed
44
    fuse_ops.cpp
Paul's avatar
Paul committed
45
    hip.cpp
Paul's avatar
Paul committed
46
    target.cpp
Paul's avatar
Paul committed
47
    lowering.cpp
wsttiger's avatar
wsttiger committed
48
    gemm.cpp
49
    quant_gemm.cpp
wsttiger's avatar
wsttiger committed
50
51
    pooling.cpp
    convolution.cpp
52
    softmax.cpp
53
    logsoftmax.cpp
54
    contiguous.cpp
55
    concat.cpp
56
    relu.cpp
Khalique's avatar
Khalique committed
57
    leaky_relu.cpp
58
    tanh.cpp
59
    batchnorm.cpp
Paul's avatar
Paul committed
60
    write_literals.cpp
61
    rocblas.cpp
Khalique's avatar
Khalique committed
62
63
    sigmoid.cpp
    abs.cpp
Khalique's avatar
Khalique committed
64
    elu.cpp
65
    pad.cpp
66
    gather.cpp
Khalique's avatar
Khalique committed
67
    lrn.cpp
Paul's avatar
Paul committed
68
    schedule_model.cpp
69
    adjust_allocation.cpp
Paul's avatar
Paul committed
70
)
Paul's avatar
Paul committed
71
72
73
74
set_target_properties(migraphx_gpu PROPERTIES EXPORT_NAME gpu)
rocm_clang_tidy_check(migraphx_gpu)
target_link_libraries(migraphx_gpu PUBLIC migraphx MIOpen roc::rocblas)
target_link_libraries(migraphx_gpu PRIVATE migraphx_device)
mei-ye's avatar
mei-ye committed
75

Paul's avatar
Paul committed
76
rocm_install_targets(
Paul's avatar
Paul committed
77
  TARGETS migraphx_gpu migraphx_device
Paul's avatar
Paul committed
78
79
80
  INCLUDE
    ${CMAKE_CURRENT_SOURCE_DIR}/include
)
mei-ye's avatar
mei-ye committed
81