-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathCMakeLists.txt
More file actions
163 lines (137 loc) · 4.72 KB
/
CMakeLists.txt
File metadata and controls
163 lines (137 loc) · 4.72 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
###############################################################################
# Copyright (C) 2022-2026 Advanced Micro Devices, Inc. All rights reserved.
# SPDX-License-Identifier: MIT
###############################################################################
cmake_minimum_required(VERSION 3.16.3)
project(aie_codegen LANGUAGES C VERSION 3.5)
set(CMAKE_C_STANDARD 11)
set(CMAKE_POSITION_INDEPENDENT_CODE ON)
set(CMAKE_WINDOWS_EXPORT_ALL_SYMBOLS TRUE)
# Define a custom option to control whether the library is built as a shared or static library
option(AIE_CODEGEN_BUILD_SHARED "Build aie_codegen as a shared library" ON)
file(
GLOB_RECURSE
SRCS
"${CMAKE_CURRENT_SOURCE_DIR}/*/*.c"
"${CMAKE_CURRENT_SOURCE_DIR}/*/*/*.c"
)
file(
GLOB_RECURSE
HDRS
"${CMAKE_CURRENT_SOURCE_DIR}/*/*.h"
"${CMAKE_CURRENT_SOURCE_DIR}/*/*/*.h"
"${CMAKE_CURRENT_SOURCE_DIR}/../aie-regdb/globalparams/*.h"
)
file(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/include)
file(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/include/aie_codegen_inc)
add_custom_target(copy_headers ALL
COMMAND ${CMAKE_COMMAND} -E copy_if_different
${CMAKE_CURRENT_SOURCE_DIR}/aie_codegen.h
${CMAKE_CURRENT_BINARY_DIR}/include/
COMMAND ${CMAKE_COMMAND} -E copy_if_different
${HDRS}
${CMAKE_CURRENT_BINARY_DIR}/include/aie_codegen_inc/
COMMENT "Syncing headers to build include directory"
)
if(AIE_CODEGEN_BUILD_SHARED)
# Build the library as a shared library
add_library(
${PROJECT_NAME}
SHARED
${SRCS}
)
else()
# Build the library as a static library
add_library(
${PROJECT_NAME}
STATIC
${SRCS}
)
endif()
add_dependencies(${PROJECT_NAME} copy_headers)
target_include_directories(
${PROJECT_NAME}
PUBLIC
$<BUILD_INTERFACE:${CMAKE_CURRENT_BINARY_DIR}/include>
$<BUILD_INTERFACE:${CMAKE_CURRENT_BINARY_DIR}/include/aie_codegen_inc>
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/../aie-regdb/globalparams>
$<INSTALL_INTERFACE:include>
$<INSTALL_INTERFACE:include/aie_codegen_inc>
)
set_target_properties(
${PROJECT_NAME}
PROPERTIES
VERSION
${PROJECT_VERSION}
SOVERSION
${PROJECT_VERSION_MAJOR}
)
if (SOCKET_BACKEND)
list(APPEND IO_BACKEND -D__AIESOCKET__)
endif (SOCKET_BACKEND)
if (DEBUG_BACKEND)
list(APPEND IO_BACKEND -D__AIEDEBUG__)
endif (DEBUG_BACKEND)
#By default, CERT control code backend will be
#enabled while compiling aie-rt using this cmake
list(APPEND IO_BACKEND -D__AIECONTROLCODE__)
if(MSVC)
target_compile_options(${PROJECT_NAME} PRIVATE
/wd4018 /wd4024 /wd4047 /wd4061 /wd4100 /wd4200 /wd4206 /wd4242 /wd4244 /wd4267 /wd4388 /wd4389 /wd4431 /wd4668 /wd4701 /wd4710 /wd4711 /wd4716
/wd4820 /wd4996 /wd5045 /wd5105
)
target_compile_options(${PROJECT_NAME} PRIVATE /Wall -DXAIE_FEATURE_MSVC ${IO_BACKEND})
else()
target_compile_options(${PROJECT_NAME} PRIVATE -Wall -Wextra ${IO_BACKEND})
endif()
include(GNUInstallDirs)
install(
FILES
${HDRS}
DESTINATION
${CMAKE_INSTALL_INCLUDEDIR}/aie_codegen_inc
)
install(
FILES
${CMAKE_CURRENT_SOURCE_DIR}/aie_codegen.h
DESTINATION
${CMAKE_INSTALL_INCLUDEDIR}
)
# FAL (xaiefal) header-only C++ wrappers
file(GLOB _XAIEFAL_COMMON "${CMAKE_CURRENT_SOURCE_DIR}/../fal/src/common/*")
file(GLOB _XAIEFAL_PROFILE "${CMAKE_CURRENT_SOURCE_DIR}/../fal/src/profile/*")
file(GLOB _XAIEFAL_RSC "${CMAKE_CURRENT_SOURCE_DIR}/../fal/src/rsc/*")
file(GLOB _XAIEFAL_TOP "${CMAKE_CURRENT_SOURCE_DIR}/../fal/src/*.hpp")
install(FILES ${_XAIEFAL_COMMON} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/xaiefal/common)
install(FILES ${_XAIEFAL_PROFILE} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/xaiefal/profile)
install(FILES ${_XAIEFAL_RSC} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/xaiefal/rsc)
install(FILES ${_XAIEFAL_TOP} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
install(
TARGETS
${PROJECT_NAME}
EXPORT ${PROJECT_NAME}-targets
INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
)
install(
EXPORT ${PROJECT_NAME}-targets
NAMESPACE ${PROJECT_NAME}::
COMPONENT runtime
DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/${PROJECT_NAME}
)
# Support Find Package
include(CMakePackageConfigHelpers)
configure_file(
${CMAKE_CURRENT_SOURCE_DIR}/config.in
${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}-config.cmake @ONLY
)
write_basic_package_version_file(
${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}-config-version.cmake
VERSION ${PROJECT_VERSION} COMPATIBILITY AnyNewerVersion
)
install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}-config.cmake
${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}-config-version.cmake
COMPONENT runtime DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/${PROJECT_NAME}
)