load("@llvm-project//mlir:tblgen.bzl", "gentbl") package( default_visibility = ["//visibility:public"], licenses = ["notice"], # Apache 2.0 ) exports_files(["include/mlir-hlo/Dialect/mhlo/IR/hlo_ops.td"]) exports_files(["include/mlir-hlo/Dialect/mhlo/IR/lhlo_ops.td"]) filegroup( name = "hlo_ops_td_files", srcs = [ "include/mlir-hlo/Dialect/mhlo/IR/chlo_ops.td", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops.td", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base.td", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base_enums.td", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base_structs.td", "include/mlir-hlo/Dialect/mhlo/IR/hlo_utils.td", "include/mlir-hlo/Dialect/mhlo/IR/infer_fusibility_op_interface.td", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_ops.td", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_ops_base.td", "@llvm-project//mlir:OpBaseTdFiles", "@llvm-project//mlir:SideEffectTdFiles", "@llvm-project//mlir:include/mlir/Interfaces/CopyOpInterface.td", "@llvm-project//mlir:include/mlir/Interfaces/InferTypeOpInterface.td", "@llvm-project//mlir:include/mlir/Interfaces/LoopLikeInterface.td", "@llvm-project//mlir:include/mlir/Interfaces/ViewLikeInterface.td", ], ) filegroup( name = "hlo_ops_base_td", srcs = [ "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base.td", ], ) gentbl( name = "MhloPassIncGen", strip_include_prefix = "include", tbl_outs = [ ( "-gen-pass-decls -name MHLO", "include/mlir-hlo/Dialect/mhlo/transforms/mhlo_passes.h.inc", ), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "include/mlir-hlo/Dialect/mhlo/transforms/mhlo_passes.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_srcs = [ "@llvm-project//mlir:PassBaseTdFiles", ], ) gentbl( name = "LmhloPassIncGen", strip_include_prefix = "include", tbl_outs = [ ( "-gen-pass-decls -name LMHLO", "include/mlir-hlo/Dialect/mhlo/transforms/lmhlo_passes.h.inc", ), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "include/mlir-hlo/Dialect/mhlo/transforms/lmhlo_passes.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_srcs = [ "@llvm-project//mlir:PassBaseTdFiles", ], ) gentbl( name = "chlo_ops_inc_gen", strip_include_prefix = "include", tbl_outs = [ ("-gen-op-decls", "include/mlir-hlo/Dialect/mhlo/IR/chlo_ops.h.inc"), ("-gen-op-defs", "include/mlir-hlo/Dialect/mhlo/IR/chlo_ops.cc.inc"), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "include/mlir-hlo/Dialect/mhlo/IR/chlo_ops.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [":hlo_ops_td_files"], ) gentbl( name = "hlo_ops_inc_gen", strip_include_prefix = "include", tbl_outs = [ ("-gen-op-decls", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops.h.inc"), ("-gen-op-defs", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops.cc.inc"), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops.td", td_includes = [ "external/mlir_hlo/include", "include", "include/mlir-hlo/Dialect/mhlo/IR/hlo_utils.td", ], td_relative_includes = [ "include", ], td_srcs = [ ":hlo_ops_base_td", ":hlo_ops_td_files", "@llvm-project//mlir:include/mlir/Interfaces/InferTypeOpInterface.td", ], ) gentbl( name = "hlo_ops_base_inc_gen", strip_include_prefix = "include", tbl_outs = [ ("-gen-op-decls", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base.h.inc"), ("-gen-op-defs", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base.cc.inc"), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [":hlo_ops_td_files"], ) gentbl( name = "hlo_ops_base_structs_inc_gen", tbl_outs = [ ("-gen-struct-attr-decls", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base_structs.h.inc"), ("-gen-struct-attr-defs", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base_structs.cc.inc"), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [":hlo_ops_td_files"], ) gentbl( name = "hlo_ops_base_enums_inc_gen", tbl_outs = [ ("-gen-enum-decls", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base_enums.h.inc"), ("-gen-enum-defs", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base_enums.cc.inc"), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [":hlo_ops_td_files"], ) gentbl( name = "hlo_ops_pattern_gen", strip_include_prefix = "lib/Dialect/mhlo/IR/", tbl_outs = [ ( "-gen-rewriters", "lib/Dialect/mhlo/IR/hlo_patterns.cc.inc", ), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "lib/Dialect/mhlo/IR/hlo_patterns.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [ ":hlo_ops_td_files", "@llvm-project//mlir:StdOpsTdFiles", "@llvm-project//mlir:include/mlir/Dialect/Shape/IR/ShapeBase.td", "@llvm-project//mlir:include/mlir/Dialect/Shape/IR/ShapeOps.td", ], ) gentbl( name = "lhlo_ops_inc_gen", strip_include_prefix = "include", tbl_outs = [ ("-gen-op-decls", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_ops.h.inc"), ("-gen-op-defs", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_ops.cc.inc"), ("-gen-struct-attr-decls", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_ops_structs.h.inc"), ("-gen-struct-attr-defs", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_ops_structs.cc.inc"), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "include/mlir-hlo/Dialect/mhlo/IR/lhlo_ops.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [":hlo_ops_td_files"], ) gentbl( name = "lhlo_gpu_ops_structs_inc_gen", strip_include_prefix = "include", tbl_outs = [ ("-gen-struct-attr-decls", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_structs.h.inc"), ("-gen-struct-attr-defs", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_structs.cc.inc"), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_structs.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [ ":hlo_ops_td_files", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_base.td", ], ) gentbl( name = "lhlo_gpu_ops_enums_inc_gen", strip_include_prefix = "include", tbl_outs = [ ("-gen-enum-decls", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_enums.h.inc"), ("-gen-enum-defs", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_enums.cc.inc"), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_enums.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [":hlo_ops_td_files"], ) cc_library( name = "lhlo_gpu_ops_structs", srcs = [ "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_structs.cc.inc", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_structs.h.inc", "lib/Dialect/mhlo/IR/lhlo_gpu_ops_structs.cc", ], hdrs = [ "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_structs.h", ], includes = ["include"], deps = [ ":lhlo_gpu_ops_structs_inc_gen", "@llvm-project//mlir:IR", "@llvm-project//mlir:Support", ], ) cc_library( name = "lhlo_gpu_ops_enums", srcs = [ "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_enums.cc.inc", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_enums.h.inc", "lib/Dialect/mhlo/IR/lhlo_gpu_ops_enums.cc", ], hdrs = [ "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_enums.h", ], includes = ["include"], deps = [ ":lhlo_gpu_ops_enums_inc_gen", "@llvm-project//llvm:Support", ], ) gentbl( name = "lhlo_gpu_ops_inc_gen", strip_include_prefix = "include", tbl_outs = [ ("-gen-op-decls", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops.h.inc"), ("-gen-op-defs", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops.cc.inc"), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [ ":hlo_ops_td_files", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_base.td", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_structs.td", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops_enums.td", ], ) #TODO(aminim): revisit the naming and grouping of these rules post-move. gentbl( name = "canonicalize_inc_gen", strip_include_prefix = "lib/Dialect/mhlo/IR/", tbl_outs = [ ("-gen-rewriters", "lib/Dialect/mhlo/IR/mhlo_canonicalize.inc"), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "lib/Dialect/mhlo/IR/mhlo_canonicalize.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [":hlo_ops_td_files"], ) gentbl( name = "infer_fusibility_op_interface_gen", tbl_outs = [ ( "-gen-op-interface-decls", "include/mlir-hlo/Dialect/mhlo/IR/infer_fusibility_op_interface.h.inc", ), ( "-gen-op-interface-defs", "include/mlir-hlo/Dialect/mhlo/IR/infer_fusibility_op_interface.cpp.inc", ), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "include/mlir-hlo/Dialect/mhlo/IR/infer_fusibility_op_interface.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [ ":hlo_ops_td_files", ], ) cc_library( name = "infer_fusibility_op_interface", srcs = [ "lib/Dialect/mhlo/IR/infer_fusibility_op_interface.cc", ], hdrs = [ "include/mlir-hlo/Dialect/mhlo/IR/infer_fusibility_op_interface.h", "include/mlir-hlo/Dialect/mhlo/IR/infer_fusibility_op_interface.h.inc", ], includes = ["include"], deps = [ ":infer_fusibility_op_interface_gen", "@llvm-project//mlir:IR", "@llvm-project//mlir:Support", ], alwayslink = 1, ) cc_library( name = "hlo_ops_base_structs", srcs = [ "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base_structs.h.inc", "lib/Dialect/mhlo/IR/hlo_ops_base_structs.cc", ], hdrs = [ "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base_structs.h", ], includes = ["include"], deps = [ ":hlo_ops_base_structs_inc_gen", "@llvm-project//mlir:IR", "@llvm-project//mlir:Support", ], ) cc_library( name = "hlo_ops_base_enums", srcs = [ "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base_enums.h.inc", "lib/Dialect/mhlo/IR/hlo_ops_base_enums.cc", ], hdrs = [ "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops_base_enums.h", ], includes = ["include"], deps = [ ":hlo_ops_base_enums_inc_gen", "@llvm-project//llvm:Support", ], ) cc_library( name = "convert_op_folder", srcs = ["lib/utils/convert_op_folder.cc"], hdrs = ["include/mlir-hlo/utils/convert_op_folder.h"], includes = ["include"], deps = [ "@llvm-project//mlir:IR", ], ) cc_library( name = "hlo", srcs = [ "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops.cc.inc", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops.h.inc", "lib/Dialect/mhlo/IR/chlo_ops.cc", "lib/Dialect/mhlo/IR/hlo_ops.cc", "lib/utils/broadcast_utils.cc", "lib/utils/hlo_utils.cc", ], hdrs = [ "include/mlir-hlo/Dialect/mhlo/IR/chlo_ops.h", "include/mlir-hlo/Dialect/mhlo/IR/hlo_ops.h", "include/mlir-hlo/utils/broadcast_utils.h", "include/mlir-hlo/utils/hlo_utils.h", ], includes = ["include"], deps = [ "hlo_ops_pattern_gen", ":canonicalize_inc_gen", ":chlo_ops_inc_gen", ":convert_op_folder", ":hlo_ops_base_enums", ":hlo_ops_base_inc_gen", ":hlo_ops_base_structs", ":hlo_ops_inc_gen", ":infer_fusibility_op_interface", "@llvm-project//llvm:Support", "@llvm-project//mlir:Analysis", "@llvm-project//mlir:IR", "@llvm-project//mlir:InferTypeOpInterface", "@llvm-project//mlir:Pass", "@llvm-project//mlir:Shape", "@llvm-project//mlir:SideEffects", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Support", "@llvm-project//mlir:TransformUtils", "@llvm-project//mlir:Transforms", ], alwayslink = 1, ) cc_library( name = "lhlo", srcs = [ "include/mlir-hlo/Dialect/mhlo/IR/lhlo_ops.cc.inc", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_ops.h.inc", "lib/Dialect/mhlo/IR/lhlo_ops.cc", ], hdrs = [ "include/mlir-hlo/Dialect/mhlo/IR/lhlo_ops.h", ], includes = ["include"], deps = [ ":hlo_ops_base_enums", ":hlo_ops_base_inc_gen", ":hlo_ops_base_structs", ":lhlo_ops_inc_gen", "@llvm-project//llvm:Support", "@llvm-project//mlir:Analysis", "@llvm-project//mlir:CopyOpInterface", "@llvm-project//mlir:IR", "@llvm-project//mlir:Pass", "@llvm-project//mlir:SideEffects", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Support", "@llvm-project//mlir:TransformUtils", "@llvm-project//mlir:Transforms", "@llvm-project//mlir:ViewLikeInterface", ], alwayslink = 1, ) cc_library( name = "lhlo_gpu", srcs = [ "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops.cc.inc", "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops.h.inc", "lib/Dialect/mhlo/IR/lhlo_gpu_ops.cc", ], hdrs = [ "include/mlir-hlo/Dialect/mhlo/IR/lhlo_gpu_ops.h", ], includes = ["include"], deps = [ ":hlo", ":hlo_ops_base_enums", ":hlo_ops_base_structs", ":infer_fusibility_op_interface", ":lhlo_gpu_ops_enums", ":lhlo_gpu_ops_inc_gen", ":lhlo_gpu_ops_structs", "@llvm-project//llvm:Support", "@llvm-project//mlir:Analysis", "@llvm-project//mlir:CopyOpInterface", "@llvm-project//mlir:IR", "@llvm-project//mlir:InferTypeOpInterface", "@llvm-project//mlir:Pass", "@llvm-project//mlir:SideEffects", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Support", "@llvm-project//mlir:TransformUtils", "@llvm-project//mlir:Transforms", "@llvm-project//mlir:ViewLikeInterface", ], alwayslink = 1, ) cc_library( name = "hlo_dialect_registration", srcs = ["lib/Dialect/mhlo/IR/init.cc"], hdrs = ["include/mlir-hlo/Dialect/mhlo/IR/register.h"], deps = [ ":hlo", ":lhlo", ":lhlo_gpu", "@llvm-project//mlir:IR", ], ) cc_library( name = "sink_constants_to_control_flow", srcs = [ "lib/Dialect/mhlo/transforms/sink_constants_to_control_flow.cc", ], hdrs = ["include/mlir-hlo/Dialect/mhlo/transforms/passes.h"], deps = [ ":hlo", ":pass_details", "@llvm-project//llvm:Support", "@llvm-project//mlir:IR", "@llvm-project//mlir:Pass", "@llvm-project//mlir:SCFDialect", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Support", "@llvm-project//mlir:Transforms", ], alwayslink = 1, ) cc_library( name = "mhlo_control_flow_to_scf", srcs = ["lib/Dialect/mhlo/transforms/mhlo_control_flow_to_scf.cc"], hdrs = ["include/mlir-hlo/Dialect/mhlo/transforms/passes.h"], deps = [ ":hlo", "@llvm-project//llvm:Support", "@llvm-project//mlir:IR", "@llvm-project//mlir:Pass", "@llvm-project//mlir:SCFDialect", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Support", "@llvm-project//mlir:TensorDialect", ], ) cc_library( name = "map_lmhlo_to_scalar_op", hdrs = ["include/mlir-hlo/Dialect/mhlo/transforms/map_lmhlo_to_scalar_op.h"], deps = [ ":hlo", ":lhlo", ":map_hlo_to_lhlo_op", "@llvm-project//llvm:Support", "@llvm-project//mlir:IR", "@llvm-project//mlir:StandardOps", ], ) cc_library( name = "map_chlo_to_hlo_op", hdrs = ["include/mlir-hlo/Dialect/mhlo/transforms/map_chlo_to_hlo_op.h"], deps = [ ":hlo", "@llvm-project//mlir:IR", ], ) cc_library( name = "map_hlo_to_lhlo_op", hdrs = ["include/mlir-hlo/Dialect/mhlo/transforms/map_hlo_to_lhlo_op.h"], deps = [ ":hlo", ":lhlo", ], ) cc_library( name = "lhlo_legalize_to_affine", srcs = ["lib/Dialect/mhlo/transforms/lhlo_legalize_to_affine.cc"], deps = [ ":hlo", ":lhlo", ":map_lmhlo_to_scalar_op", "@llvm-project//llvm:Support", "@llvm-project//mlir:Affine", "@llvm-project//mlir:IR", "@llvm-project//mlir:Pass", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:TransformUtils", ], alwayslink = 1, ) cc_library( name = "lhlo_legalize_to_parallel_loops", srcs = ["lib/Dialect/mhlo/transforms/lhlo_legalize_to_parallel_loops.cc"], deps = [ ":lhlo", "@llvm-project//llvm:Support", "@llvm-project//mlir:IR", "@llvm-project//mlir:LinalgOps", "@llvm-project//mlir:Pass", "@llvm-project//mlir:SCFDialect", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Transforms", ], alwayslink = 1, ) cc_library( name = "legalize_to_linalg", srcs = ["lib/Dialect/mhlo/transforms/legalize_to_linalg.cc"], hdrs = [ "include/mlir-hlo/Dialect/mhlo/transforms/passes.h", "include/mlir-hlo/Dialect/mhlo/transforms/rewriters.h", ], deps = [ ":hlo", ":lhlo", ":map_lmhlo_to_scalar_op", "@llvm-project//llvm:Support", "@llvm-project//mlir:Affine", "@llvm-project//mlir:IR", "@llvm-project//mlir:LinalgOps", "@llvm-project//mlir:Pass", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Transforms", ], alwayslink = 1, ) cc_library( name = "transform_unranked_hlo", srcs = ["lib/Dialect/mhlo/transforms/transform_unranked_hlo.cc"], hdrs = [ "include/mlir-hlo/Dialect/mhlo/transforms/passes.h", "include/mlir-hlo/Dialect/mhlo/transforms/rewriters.h", ], deps = [ ":hlo", ":map_chlo_to_hlo_op", "@llvm-project//llvm:Support", "@llvm-project//mlir:IR", "@llvm-project//mlir:Pass", "@llvm-project//mlir:SCFDialect", "@llvm-project//mlir:Shape", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Transforms", ], alwayslink = 1, ) cc_library( name = "lhlo_legalize_to_gpu", srcs = ["lib/Dialect/mhlo/transforms/lhlo_legalize_to_gpu.cc"], deps = [ ":hlo", ":lhlo", ":map_lmhlo_to_scalar_op", "@llvm-project//llvm:Support", "@llvm-project//mlir:Affine", "@llvm-project//mlir:GPUDialect", "@llvm-project//mlir:IR", "@llvm-project//mlir:LinalgOps", "@llvm-project//mlir:Pass", "@llvm-project//mlir:SCFDialect", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Transforms", ], alwayslink = 1, ) cc_library( name = "lhlo_fuse_linalg", srcs = ["lib/Dialect/mhlo/transforms/lhlo_fuse_linalg.cc"], hdrs = ["include/mlir-hlo/Dialect/mhlo/transforms/passes.h"], deps = [ ":lhlo", "@llvm-project//llvm:Support", "@llvm-project//mlir:Affine", "@llvm-project//mlir:IR", "@llvm-project//mlir:LinalgTransforms", "@llvm-project//mlir:Pass", "@llvm-project//mlir:SCFDialect", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Support", "@llvm-project//mlir:TransformUtils", "@llvm-project//mlir:ViewLikeInterface", ], alwayslink = 1, ) cc_library( name = "hlo_legalize_to_lhlo", srcs = ["lib/Dialect/mhlo/transforms/hlo_legalize_to_lhlo.cc"], hdrs = [ "include/mlir-hlo/Dialect/mhlo/transforms/passes.h", "include/mlir-hlo/Dialect/mhlo/transforms/rewriters.h", ], deps = [ ":hlo", ":lhlo", ":map_hlo_to_lhlo_op", "@llvm-project//llvm:Support", "@llvm-project//mlir:IR", "@llvm-project//mlir:Pass", "@llvm-project//mlir:Shape", "@llvm-project//mlir:ShapeTransforms", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:StandardOpsTransforms", "@llvm-project//mlir:Support", "@llvm-project//mlir:TensorDialect", "@llvm-project//mlir:Transforms", ], alwayslink = 1, ) cc_library( name = "cycle_detector", srcs = ["lib/utils/cycle_detector.cc"], hdrs = ["include/mlir-hlo/utils/cycle_detector.h"], includes = ["include"], deps = [ "@llvm-project//llvm:Support", ], alwayslink = 1, ) cc_library( name = "mhlo_fusion", srcs = ["lib/Dialect/mhlo/transforms/mhlo_fusion.cc"], deps = [ ":cycle_detector", ":hlo", "@llvm-project//llvm:Core", "@llvm-project//llvm:Support", "@llvm-project//mlir:IR", "@llvm-project//mlir:Pass", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Support", "@llvm-project//mlir:TransformUtils", ], alwayslink = 1, ) gentbl( name = "legalize_to_standard_inc_gen", strip_include_prefix = "lib/Dialect/mhlo/transforms/", tbl_outs = [ ("-gen-rewriters", "lib/Dialect/mhlo/transforms/generated_legalize_to_standard.inc"), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "lib/Dialect/mhlo/transforms/legalize_to_standard_patterns.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [ ":hlo_ops_td_files", "@llvm-project//mlir:StdOpsTdFiles", ], ) cc_library( name = "legalize_control_flow", srcs = ["lib/Dialect/mhlo/transforms/legalize_control_flow.cc"], hdrs = ["include/mlir-hlo/Dialect/mhlo/transforms/passes.h"], deps = [ ":hlo", "@llvm-project//llvm:Support", "@llvm-project//mlir:IR", "@llvm-project//mlir:Pass", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Support", "@llvm-project//mlir:TensorDialect", ], alwayslink = 1, ) cc_library( name = "legalize_to_standard", srcs = ["lib/Dialect/mhlo/transforms/legalize_to_standard.cc"], hdrs = ["include/mlir-hlo/Dialect/mhlo/transforms/passes.h"], deps = [ ":hlo", ":legalize_to_standard_inc_gen", ":legalize_trigonometric_to_approximation", "@llvm-project//llvm:Support", "@llvm-project//mlir:IR", "@llvm-project//mlir:Pass", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Support", "@llvm-project//mlir:TransformUtils", ], alwayslink = 1, ) cc_library( name = "legalize_gather_to_torch_index_select", srcs = ["lib/Dialect/mhlo/transforms/legalize_gather_to_torch_index_select.cc"], hdrs = [ "include/mlir-hlo/Dialect/mhlo/transforms/passes.h", "include/mlir-hlo/Dialect/mhlo/transforms/rewriters.h", ], deps = [ ":hlo", "@llvm-project//llvm:Support", "@llvm-project//mlir:IR", "@llvm-project//mlir:Pass", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Support", "@llvm-project//mlir:Transforms", ], alwayslink = 1, ) cc_library( name = "legalize_trigonometric_to_approximation", srcs = ["lib/Dialect/mhlo/transforms/legalize_trigonometric_to_approximation.cc"], hdrs = [ "include/mlir-hlo/Dialect/mhlo/transforms/passes.h", "include/mlir-hlo/Dialect/mhlo/transforms/rewriters.h", ], includes = ["include"], deps = [ "@llvm-project//llvm:Support", "@llvm-project//mlir:IR", "@llvm-project//mlir:Pass", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Support", "@llvm-project//mlir:Transforms", ], alwayslink = 1, ) gentbl( name = "lower_complex_inc_gen", strip_include_prefix = "lib/Dialect/mhlo/transforms/", tbl_outs = [ ("-gen-rewriters", "lib/Dialect/mhlo/transforms/generated_lower_complex.inc"), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "lib/Dialect/mhlo/transforms/lower_complex_patterns.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [ ":hlo_ops_td_files", "@llvm-project//llvm:Support", "@llvm-project//mlir:StdOpsTdFiles", ], ) cc_library( #TODO(aminim): find a better name here? name = "mhlo_to_mhlo_lowering_patterns", srcs = [ "lib/Dialect/mhlo/transforms/lower_complex.cc", "lib/Dialect/mhlo/transforms/lower_general_dot.cc", "lib/Dialect/mhlo/transforms/optimize_mhlo.cc", ], hdrs = [ "include/mlir-hlo/Dialect/mhlo/transforms/passes.h", "include/mlir-hlo/Dialect/mhlo/transforms/rewriters.h", ], deps = [ ":hlo", ":lower_complex_inc_gen", "@llvm-project//llvm:Support", "@llvm-project//mlir:Analysis", "@llvm-project//mlir:IR", "@llvm-project//mlir:Pass", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Support", "@llvm-project//mlir:Transforms", ], alwayslink = 1, ) cc_library( name = "materialize_broadcasts", srcs = [ "lib/Dialect/mhlo/transforms/materialize_broadcasts.cc", ], hdrs = [ "include/mlir-hlo/Dialect/mhlo/transforms/passes.h", "include/mlir-hlo/Dialect/mhlo/transforms/rewriters.h", ], deps = [ ":hlo", "@llvm-project//llvm:Support", "@llvm-project//mlir:IR", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Transforms", ], ) cc_library( name = "unfuse_batch_norm", srcs = ["lib/Dialect/mhlo/transforms/unfuse_batch_norm.cc"], hdrs = [ "include/mlir-hlo/Dialect/mhlo/transforms/passes.h", ], deps = [ ":hlo", "@llvm-project//llvm:Support", "@llvm-project//mlir:IR", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Transforms", ], ) cc_library( name = "chlo_legalize_to_hlo", srcs = ["lib/Dialect/mhlo/transforms/chlo_legalize_to_hlo.cc"], hdrs = ["include/mlir-hlo/Dialect/mhlo/transforms/rewriters.h"], deps = [ ":chlo_legalize_to_hlo_inc_gen", ":hlo", ":map_chlo_to_hlo_op", "@llvm-project//mlir:IR", "@llvm-project//mlir:SCFDialect", "@llvm-project//mlir:Shape", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Transforms", ], ) gentbl( name = "chlo_legalize_to_hlo_inc_gen", strip_include_prefix = "lib/Dialect/mhlo/transforms/", tbl_outs = [ ( "-gen-rewriters", "lib/Dialect/mhlo/transforms/generated_chlo_legalize_to_hlo.inc", ), ], tblgen = "@llvm-project//mlir:mlir-tblgen", td_file = "lib/Dialect/mhlo/transforms/chlo_legalize_to_hlo_patterns.td", td_includes = [ "external/mlir_hlo/include", "include", ], td_relative_includes = [ "include", ], td_srcs = [ ":hlo_ops_td_files", ], ) cc_library( name = "pass_details", hdrs = [ "include/mlir-hlo/Dialect/mhlo/transforms/PassDetail.h", ], visibility = [ "//visibility:private", # This target is a private detail of pass implementations ], deps = [ ":MhloPassIncGen", "@llvm-project//mlir:Pass", ], ) cc_library( name = "test_passes", srcs = [ "include/mlir-hlo/Dialect/mhlo/transforms/rewriters.h", "lib/Dialect/mhlo/transforms/chlo_legalize_to_hlo_pass.cc", "lib/Dialect/mhlo/transforms/materialize_broadcasts_pass.cc", "lib/Dialect/mhlo/transforms/optimize_mhlo_pass.cc", "lib/Dialect/mhlo/transforms/test_infer_shaped_type_pass.cc", "lib/Dialect/mhlo/transforms/unfuse_batch_norm_pass.cc", ], deps = [ ":chlo_legalize_to_hlo", # build-cleaner: keep ":hlo", ":lhlo", ":materialize_broadcasts", # build-cleaner: keep ":pass_details", ":unfuse_batch_norm", # build-cleaner: keep "@llvm-project//mlir:IR", "@llvm-project//mlir:InferTypeOpInterface", "@llvm-project//mlir:LLVMDialect", "@llvm-project//mlir:LLVMTransforms", "@llvm-project//mlir:Pass", "@llvm-project//mlir:SCFDialect", "@llvm-project//mlir:Shape", "@llvm-project//mlir:StandardOps", "@llvm-project//mlir:Transforms", ], alwayslink = 1, ) cc_library( name = "all_passes", hdrs = [ "include/mlir-hlo/Dialect/mhlo/transforms/register_passes.h", ], deps = [ ":LmhloPassIncGen", ":MhloPassIncGen", ":chlo_legalize_to_hlo", ":hlo_legalize_to_lhlo", ":legalize_control_flow", ":legalize_gather_to_torch_index_select", ":legalize_to_linalg", ":legalize_to_standard", ":legalize_trigonometric_to_approximation", ":lhlo", ":lhlo_fuse_linalg", ":lhlo_legalize_to_affine", ":lhlo_legalize_to_gpu", ":lhlo_legalize_to_parallel_loops", ":mhlo_control_flow_to_scf", ":mhlo_fusion", ":mhlo_to_mhlo_lowering_patterns", ":sink_constants_to_control_flow", ":test_passes", ":transform_unranked_hlo", "@llvm-project//mlir:Pass", ], ) cc_binary( name = "mlir-hlo-opt", srcs = [ "tools/mlir-hlo-opt/mlir-hlo-opt.cpp", ], deps = [ ":all_passes", ":hlo", ":lhlo", ":lhlo_gpu", "@llvm-project//llvm:Support", "@llvm-project//mlir:AllPassesAndDialectsNoRegistration", "@llvm-project//mlir:IR", "@llvm-project//mlir:MlirOptLib", "@llvm-project//mlir:Pass", "@llvm-project//mlir:Support", ], )