blob: 497431dcda305a29795e98b6f9f048cb043de54f [file] [log] [blame]
load("@llvm-project//mlir:tblgen.bzl", "gentbl_cc_library", "gentbl_filegroup", "td_library")
package(
default_visibility = ["//visibility:public"],
features = ["layering_check"],
licenses = ["notice"],
)
exports_files(glob(["include/iree-dialects/Dialect/Input/*.td"]))
exports_files(glob(["python/*.cpp"]))
################################################################################
# Package-by-package filegroup exports.
# Some tools can make use of such non-nested groups.
################################################################################
filegroup(
name = "python_dialects",
srcs = glob(["python/iree/compiler/dialects/**/*.py"]) + [
":python/iree/compiler/dialects/_iree_ops_gen.py",
],
)
################################################################################
# Tablegen exports
################################################################################
filegroup(
name = "TdFilegroup",
srcs = glob([
"include/iree-dialects/Dialect/Input/*.td",
]),
)
td_library(
name = "TdFiles",
srcs = glob([
"include/iree-dialects/Dialect/Input/*.td",
"python/iree/compiler/dialects/*.td",
]) + [
"@llvm-project//mlir:include/mlir/Bindings/Python/Attributes.td",
],
includes = ["include"],
deps = [
"@llvm-project//mlir:BuiltinDialectTdFiles",
"@llvm-project//mlir:InferTypeOpInterfaceTdFiles",
"@llvm-project//mlir:OpBaseTdFiles",
"@llvm-project//mlir:PDLDialectTdFiles",
"@llvm-project//mlir:SideEffectInterfacesTdFiles",
"@llvm-project//mlir:TransformDialectTdFiles",
],
)
################################################################################
# IREEInput dialect
################################################################################
gentbl_cc_library(
name = "IREEInputIncGen",
strip_include_prefix = "include",
tbl_outs = [
(
["--gen-dialect-decls"],
"include/iree-dialects/Dialect/Input/InputDialect.h.inc",
),
(
["--gen-dialect-defs"],
"include/iree-dialects/Dialect/Input/InputDialect.cpp.inc",
),
(
["--gen-op-decls"],
"include/iree-dialects/Dialect/Input/InputOps.h.inc",
),
(
["--gen-op-defs"],
"include/iree-dialects/Dialect/Input/InputOps.cpp.inc",
),
(
["--gen-typedef-decls"],
"include/iree-dialects/Dialect/Input/InputTypes.h.inc",
),
(
["--gen-typedef-defs"],
"include/iree-dialects/Dialect/Input/InputTypes.cpp.inc",
),
],
tblgen = "@llvm-project//mlir:mlir-tblgen",
td_file = "include/iree-dialects/Dialect/Input/InputOps.td",
deps = [":TdFiles"],
)
cc_library(
name = "IREEInputDialect",
srcs = glob([
"lib/Dialect/Input/*.cpp",
]),
hdrs = glob(["include/iree-dialects/Dialect/Input/*.h"]),
includes = ["include"],
deps = [
":IREEInputIncGen",
"@llvm-project//llvm:Support",
"@llvm-project//mlir:ArithDialect",
"@llvm-project//mlir:IR",
"@llvm-project//mlir:InferTypeOpInterface",
"@llvm-project//mlir:Support",
],
)
gentbl_filegroup(
name = "IREEInputDialectPyGen",
tbl_outs = [
(
[
"--gen-python-op-bindings",
"--bind-dialect=iree",
],
"python/iree/compiler/dialects/_iree_ops_gen.py",
),
],
tblgen = "@llvm-project//mlir:mlir-tblgen",
td_file = "python/iree/compiler/dialects/IreeInputBinding.td",
deps = [
":TdFiles",
],
)
################################################################################
# CAPI
################################################################################
cc_library(
name = "CAPI",
srcs = glob(["lib/CAPI/*.cpp"]),
hdrs = glob(["include/iree-dialects-c/*.h"]),
includes = ["include"],
deps = [
":IREEInputDialect",
"@llvm-project//mlir:CAPIIR",
"@llvm-project//mlir:IR",
"@llvm-project//mlir:LinalgTransformOps",
"@llvm-project//mlir:Support",
"@llvm-project//mlir:TransformDialect",
],
)
################################################################################
# Test lib
################################################################################
cc_library(
name = "IREEDialectsTest",
srcs = glob([
"test/lib/**/*.cpp",
]),
deps = [
"@llvm-project//mlir:IR",
"@llvm-project//mlir:Pass",
"@llvm-project//mlir:Rewrite",
"@llvm-project//mlir:Transforms",
],
)
################################################################################
# Tools
################################################################################
cc_binary(
name = "iree-dialects-opt",
srcs = [
"tools/iree-dialects-opt/iree-dialects-opt.cpp",
],
tags = ["hostonly"],
deps = [
":IREEDialectsTest",
":IREEInputDialect",
"@llvm-project//llvm:Support",
"@llvm-project//mlir:AffineDialect",
"@llvm-project//mlir:ArithDialect",
"@llvm-project//mlir:AsyncDialect",
"@llvm-project//mlir:ControlFlowDialect",
"@llvm-project//mlir:FuncDialect",
"@llvm-project//mlir:IR",
"@llvm-project//mlir:LinalgDialect",
"@llvm-project//mlir:LinalgTransformOps",
"@llvm-project//mlir:LinalgTransforms",
"@llvm-project//mlir:MemRefDialect",
"@llvm-project//mlir:MemRefTransforms",
"@llvm-project//mlir:MlirOptLib",
"@llvm-project//mlir:PDLDialect",
"@llvm-project//mlir:PDLInterpDialect",
"@llvm-project//mlir:SCFDialect",
"@llvm-project//mlir:SCFTransformOps",
"@llvm-project//mlir:SCFTransforms",
"@llvm-project//mlir:Support",
"@llvm-project//mlir:TensorDialect",
"@llvm-project//mlir:TransformDialect",
"@llvm-project//mlir:Transforms",
],
)