diff --git a/mlir/include/mlir/Dialect/SPIRV/Serialization.h b/mlir/include/mlir/Target/SPIRV/Deserialization.h rename from mlir/include/mlir/Dialect/SPIRV/Serialization.h rename to mlir/include/mlir/Target/SPIRV/Deserialization.h --- a/mlir/include/mlir/Dialect/SPIRV/Serialization.h +++ b/mlir/include/mlir/Target/SPIRV/Deserialization.h @@ -6,13 +6,12 @@ // //===----------------------------------------------------------------------===// // -// This file declares the entry points for serialize and deserialize SPIR-V -// binary modules. +// This file declares the entry points for deserializing SPIR-V binary modules. // //===----------------------------------------------------------------------===// -#ifndef MLIR_DIALECT_SPIRV_SERIALIZATION_H_ -#define MLIR_DIALECT_SPIRV_SERIALIZATION_H_ +#ifndef MLIR_DIALECT_SPIRV_DESERIALIZATION_H_ +#define MLIR_DIALECT_SPIRV_DESERIALIZATION_H_ #include "mlir/Support/LLVM.h" @@ -21,15 +20,8 @@ class MLIRContext; namespace spirv { -class ModuleOp; class OwningSPIRVModuleRef; -/// Serializes the given SPIR-V `module` and writes to `binary`. On failure, -/// reports errors to the error handler registered with the MLIR context for -/// `module`. -LogicalResult serialize(ModuleOp module, SmallVectorImpl &binary, - bool emitDebugInfo = false); - /// Deserializes the given SPIR-V `binary` module and creates a MLIR ModuleOp /// in the given `context`. Returns the ModuleOp on success; otherwise, reports /// errors to the error handler registered with `context` and returns a null @@ -40,4 +32,4 @@ } // end namespace spirv } // end namespace mlir -#endif // MLIR_DIALECT_SPIRV_SERIALIZATION_H_ +#endif // MLIR_DIALECT_SPIRV_DESERIALIZATION_H_ diff --git a/mlir/include/mlir/Dialect/SPIRV/Serialization.h b/mlir/include/mlir/Target/SPIRV/Serialization.h rename from mlir/include/mlir/Dialect/SPIRV/Serialization.h rename to mlir/include/mlir/Target/SPIRV/Serialization.h --- a/mlir/include/mlir/Dialect/SPIRV/Serialization.h +++ b/mlir/include/mlir/Target/SPIRV/Serialization.h @@ -6,8 +6,7 @@ // //===----------------------------------------------------------------------===// // -// This file declares the entry points for serialize and deserialize SPIR-V -// binary modules. +// This file declares the entry point for serializing SPIR-V binary modules. // //===----------------------------------------------------------------------===// @@ -22,7 +21,6 @@ namespace spirv { class ModuleOp; -class OwningSPIRVModuleRef; /// Serializes the given SPIR-V `module` and writes to `binary`. On failure, /// reports errors to the error handler registered with the MLIR context for @@ -30,13 +28,6 @@ LogicalResult serialize(ModuleOp module, SmallVectorImpl &binary, bool emitDebugInfo = false); -/// Deserializes the given SPIR-V `binary` module and creates a MLIR ModuleOp -/// in the given `context`. Returns the ModuleOp on success; otherwise, reports -/// errors to the error handler registered with `context` and returns a null -/// module. -OwningSPIRVModuleRef deserialize(ArrayRef binary, - MLIRContext *context); - } // end namespace spirv } // end namespace mlir diff --git a/mlir/lib/Conversion/GPUToVulkan/ConvertGPULaunchFuncToVulkanLaunchFunc.cpp b/mlir/lib/Conversion/GPUToVulkan/ConvertGPULaunchFuncToVulkanLaunchFunc.cpp --- a/mlir/lib/Conversion/GPUToVulkan/ConvertGPULaunchFuncToVulkanLaunchFunc.cpp +++ b/mlir/lib/Conversion/GPUToVulkan/ConvertGPULaunchFuncToVulkanLaunchFunc.cpp @@ -18,13 +18,13 @@ #include "mlir/Dialect/GPU/GPUDialect.h" #include "mlir/Dialect/SPIRV/SPIRVDialect.h" #include "mlir/Dialect/SPIRV/SPIRVOps.h" -#include "mlir/Dialect/SPIRV/Serialization.h" #include "mlir/Dialect/StandardOps/IR/Ops.h" #include "mlir/IR/Attributes.h" #include "mlir/IR/Builders.h" #include "mlir/IR/Function.h" #include "mlir/IR/Module.h" #include "mlir/IR/StandardTypes.h" +#include "mlir/Target/SPIRV/Serialization.h" using namespace mlir; diff --git a/mlir/lib/Dialect/SPIRV/CMakeLists.txt b/mlir/lib/Dialect/SPIRV/CMakeLists.txt --- a/mlir/lib/Dialect/SPIRV/CMakeLists.txt +++ b/mlir/lib/Dialect/SPIRV/CMakeLists.txt @@ -35,5 +35,4 @@ ) add_subdirectory(Linking) -add_subdirectory(Serialization) add_subdirectory(Transforms) diff --git a/mlir/lib/Dialect/SPIRV/Serialization/CMakeLists.txt b/mlir/lib/Dialect/SPIRV/Serialization/CMakeLists.txt deleted file mode 100644 --- a/mlir/lib/Dialect/SPIRV/Serialization/CMakeLists.txt +++ /dev/null @@ -1,18 +0,0 @@ -add_mlir_dialect_library(MLIRSPIRVSerialization - Deserializer.cpp - Serializer.cpp - SPIRVBinaryUtils.cpp - TranslateRegistration.cpp - - ADDITIONAL_HEADER_DIRS - ${MLIR_MAIN_INCLUDE_DIR}/mlir/Dialect/SPIRV - - DEPENDS - MLIRSPIRVSerializationGen - - LINK_LIBS PUBLIC - MLIRIR - MLIRSPIRV - MLIRSupport - MLIRTranslation - ) diff --git a/mlir/lib/Target/CMakeLists.txt b/mlir/lib/Target/CMakeLists.txt --- a/mlir/lib/Target/CMakeLists.txt +++ b/mlir/lib/Target/CMakeLists.txt @@ -94,3 +94,33 @@ MLIRROCDLIR MLIRTargetLLVMIRModuleTranslation ) + +add_mlir_translation_library(MLIRSPIRVSerialization + SPIRV/Serialization.cpp + SPIRV/SPIRVBinaryUtils.cpp + SPIRV/TranslateRegistration.cpp + + DEPENDS + MLIRSPIRVSerializationGen + + LINK_LIBS PUBLIC + MLIRIR + MLIRSPIRV + MLIRSupport + MLIRTranslation + ) + +add_mlir_translation_library(MLIRSPIRVDeserialization + SPIRV/Deserialization.cpp + SPIRV/SPIRVBinaryUtils.cpp + SPIRV/TranslateRegistration.cpp + + DEPENDS + MLIRSPIRVSerializationGen + + LINK_LIBS PUBLIC + MLIRIR + MLIRSPIRV + MLIRSupport + MLIRTranslation + ) diff --git a/mlir/lib/Dialect/SPIRV/Serialization/Deserializer.cpp b/mlir/lib/Target/SPIRV/Deserialization.cpp rename from mlir/lib/Dialect/SPIRV/Serialization/Deserializer.cpp rename to mlir/lib/Target/SPIRV/Deserialization.cpp --- a/mlir/lib/Dialect/SPIRV/Serialization/Deserializer.cpp +++ b/mlir/lib/Target/SPIRV/Deserialization.cpp @@ -10,7 +10,7 @@ // //===----------------------------------------------------------------------===// -#include "mlir/Dialect/SPIRV/Serialization.h" +#include "mlir/Target/SPIRV/Deserialization.h" #include "mlir/Dialect/SPIRV/SPIRVAttributes.h" #include "mlir/Dialect/SPIRV/SPIRVBinaryUtils.h" diff --git a/mlir/lib/Dialect/SPIRV/Serialization/SPIRVBinaryUtils.cpp b/mlir/lib/Target/SPIRV/SPIRVBinaryUtils.cpp rename from mlir/lib/Dialect/SPIRV/Serialization/SPIRVBinaryUtils.cpp rename to mlir/lib/Target/SPIRV/SPIRVBinaryUtils.cpp diff --git a/mlir/lib/Dialect/SPIRV/Serialization/Serializer.cpp b/mlir/lib/Target/SPIRV/Serialization.cpp rename from mlir/lib/Dialect/SPIRV/Serialization/Serializer.cpp rename to mlir/lib/Target/SPIRV/Serialization.cpp --- a/mlir/lib/Dialect/SPIRV/Serialization/Serializer.cpp +++ b/mlir/lib/Target/SPIRV/Serialization.cpp @@ -10,7 +10,7 @@ // //===----------------------------------------------------------------------===// -#include "mlir/Dialect/SPIRV/Serialization.h" +#include "mlir/Target/SPIRV/Serialization.h" #include "mlir/Dialect/SPIRV/SPIRVAttributes.h" #include "mlir/Dialect/SPIRV/SPIRVBinaryUtils.h" @@ -2139,6 +2139,7 @@ return success(); } +namespace mlir { LogicalResult spirv::serialize(spirv::ModuleOp module, SmallVectorImpl &binary, bool emitDebugInfo) { @@ -2156,3 +2157,4 @@ serializer.collect(binary); return success(); } +} // namespace mlir diff --git a/mlir/lib/Dialect/SPIRV/Serialization/TranslateRegistration.cpp b/mlir/lib/Target/SPIRV/TranslateRegistration.cpp rename from mlir/lib/Dialect/SPIRV/Serialization/TranslateRegistration.cpp rename to mlir/lib/Target/SPIRV/TranslateRegistration.cpp --- a/mlir/lib/Dialect/SPIRV/Serialization/TranslateRegistration.cpp +++ b/mlir/lib/Target/SPIRV/TranslateRegistration.cpp @@ -14,13 +14,14 @@ #include "mlir/Dialect/SPIRV/SPIRVDialect.h" #include "mlir/Dialect/SPIRV/SPIRVModule.h" #include "mlir/Dialect/SPIRV/SPIRVOps.h" -#include "mlir/Dialect/SPIRV/Serialization.h" #include "mlir/IR/Builders.h" #include "mlir/IR/Dialect.h" #include "mlir/IR/Function.h" #include "mlir/IR/Module.h" #include "mlir/Parser.h" #include "mlir/Support/FileUtilities.h" +#include "mlir/Target/SPIRV/Deserialization.h" +#include "mlir/Target/SPIRV/Serialization.h" #include "mlir/Translation.h" #include "llvm/ADT/StringRef.h" #include "llvm/Support/MemoryBuffer.h" diff --git a/mlir/unittests/Dialect/SPIRV/CMakeLists.txt b/mlir/unittests/Dialect/SPIRV/CMakeLists.txt --- a/mlir/unittests/Dialect/SPIRV/CMakeLists.txt +++ b/mlir/unittests/Dialect/SPIRV/CMakeLists.txt @@ -1,8 +1,2 @@ -add_mlir_unittest(MLIRSPIRVTests - DeserializationTest.cpp - SerializationTest.cpp -) -target_link_libraries(MLIRSPIRVTests - PRIVATE - MLIRSPIRV - MLIRSPIRVSerialization) +add_subdirectory(Serialization) +add_subdirectory(Deserialization) diff --git a/mlir/unittests/Dialect/SPIRV/Deserialization/CMakeLists.txt b/mlir/unittests/Dialect/SPIRV/Deserialization/CMakeLists.txt new file mode 100644 --- /dev/null +++ b/mlir/unittests/Dialect/SPIRV/Deserialization/CMakeLists.txt @@ -0,0 +1,7 @@ +add_mlir_unittest(MLIRSPIRVDeserializationTests + DeserializationTest.cpp +) +target_link_libraries(MLIRSPIRVDeserializationTests + PRIVATE + MLIRSPIRV + MLIRSPIRVDeserialization) diff --git a/mlir/unittests/Dialect/SPIRV/DeserializationTest.cpp b/mlir/unittests/Dialect/SPIRV/Deserialization/DeserializationTest.cpp rename from mlir/unittests/Dialect/SPIRV/DeserializationTest.cpp rename to mlir/unittests/Dialect/SPIRV/Deserialization/DeserializationTest.cpp --- a/mlir/unittests/Dialect/SPIRV/DeserializationTest.cpp +++ b/mlir/unittests/Dialect/SPIRV/Deserialization/DeserializationTest.cpp @@ -12,11 +12,11 @@ // //===----------------------------------------------------------------------===// +#include "mlir/Target/SPIRV/Deserialization.h" #include "mlir/Dialect/SPIRV/SPIRVBinaryUtils.h" #include "mlir/Dialect/SPIRV/SPIRVDialect.h" #include "mlir/Dialect/SPIRV/SPIRVModule.h" #include "mlir/Dialect/SPIRV/SPIRVOps.h" -#include "mlir/Dialect/SPIRV/Serialization.h" #include "mlir/IR/Diagnostics.h" #include "mlir/IR/MLIRContext.h" #include "gmock/gmock.h" diff --git a/mlir/unittests/Dialect/SPIRV/Serialization/CMakeLists.txt b/mlir/unittests/Dialect/SPIRV/Serialization/CMakeLists.txt new file mode 100644 --- /dev/null +++ b/mlir/unittests/Dialect/SPIRV/Serialization/CMakeLists.txt @@ -0,0 +1,7 @@ +add_mlir_unittest(MLIRSPIRVSerializationTests + SerializationTest.cpp +) +target_link_libraries(MLIRSPIRVSerializationTests + PRIVATE + MLIRSPIRV + MLIRSPIRVSerialization) diff --git a/mlir/unittests/Dialect/SPIRV/SerializationTest.cpp b/mlir/unittests/Dialect/SPIRV/Serialization/SerializationTest.cpp rename from mlir/unittests/Dialect/SPIRV/SerializationTest.cpp rename to mlir/unittests/Dialect/SPIRV/Serialization/SerializationTest.cpp --- a/mlir/unittests/Dialect/SPIRV/SerializationTest.cpp +++ b/mlir/unittests/Dialect/SPIRV/Serialization/SerializationTest.cpp @@ -11,7 +11,7 @@ // //===----------------------------------------------------------------------===// -#include "mlir/Dialect/SPIRV/Serialization.h" +#include "mlir/Target/SPIRV/Serialization.h" #include "mlir/Dialect/SPIRV/SPIRVAttributes.h" #include "mlir/Dialect/SPIRV/SPIRVBinaryUtils.h" #include "mlir/Dialect/SPIRV/SPIRVDialect.h"