aboutsummaryrefslogtreecommitdiff
path: root/CMakeLists.txt
blob: 6bc3e6b75954c99f1451a53b7005fa3a8f35ff7d (plain)
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
# TOSA serialization MLIR passes

cmake_minimum_required(VERSION 3.13.4)
project(MlirTosaPasses)

set(CMAKE_CXX_STANDARD_REQUIRED YES)

set(CMAKE_VERBOSE_MAKEFILE ON)

# TOSA MLIR->Flatbuffers serialization pass

include_directories(${CMAKE_CURRENT_SOURCE_DIR}/include)
include_directories(${PROJECT_SOURCE_DIR}/third_party/serialization_lib/include)
include_directories(${PROJECT_SOURCE_DIR}/third_party/serialization_lib/third_party/half/include)
include_directories(${PROJECT_SOURCE_DIR}/third_party/serialization_lib/third_party/flatbuffers/include)

set(LLVM_TARGET_DEFINITIONS include/SerializationPasses.td)
mlir_tablegen(include/SerializationPasses.h.inc -gen-pass-decls -name TosaSerialization)
add_public_tablegen_target(tosa_serialization_passes_inc_gen)

set(LLVM_TARGET_DEFINITIONS include/DeserializationPasses.td)
mlir_tablegen(include/DeserializationPasses.h.inc -gen-pass-decls -name TosaDeserialization)
add_public_tablegen_target(tosa_deserialization_passes_inc_gen)

# Compile the TOSA serialization_lib
add_subdirectory(third_party/serialization_lib)

add_mlir_library(tosa_serialize
  src/TosaSerialize.cpp
  src/TosaDeserialize.cpp

  DEPENDS
  mlir-headers
  tosa_serialization_passes_inc_gen
  tosa_deserialization_passes_inc_gen

  LINK_LIBS PRIVATE
  tosa_serialization_lib
)