2023-05-24 21:52:05 -07:00
|
|
|
//===- AdaptorTest.cpp - Adaptor unit tests -------------------------------===//
|
|
|
|
|
//
|
|
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
|
|
|
//
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
|
|
#include "mlir/Bytecode/BytecodeReader.h"
|
|
|
|
|
#include "mlir/Bytecode/BytecodeWriter.h"
|
|
|
|
|
#include "mlir/IR/AsmState.h"
|
|
|
|
|
#include "mlir/IR/BuiltinAttributes.h"
|
|
|
|
|
#include "mlir/IR/OpImplementation.h"
|
|
|
|
|
#include "mlir/IR/OwningOpRef.h"
|
|
|
|
|
#include "mlir/Parser/Parser.h"
|
|
|
|
|
|
|
|
|
|
#include "llvm/ADT/StringRef.h"
|
2023-06-23 09:17:53 +02:00
|
|
|
#include "llvm/Support/Endian.h"
|
2023-05-24 21:52:05 -07:00
|
|
|
#include "gmock/gmock.h"
|
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
|
|
using namespace llvm;
|
|
|
|
|
using namespace mlir;
|
|
|
|
|
|
|
|
|
|
using testing::ElementsAre;
|
|
|
|
|
|
|
|
|
|
StringLiteral IRWithResources = R"(
|
|
|
|
|
module @TestDialectResources attributes {
|
|
|
|
|
bytecode.test = dense_resource<resource> : tensor<4xi32>
|
|
|
|
|
} {}
|
|
|
|
|
{-#
|
|
|
|
|
dialect_resources: {
|
|
|
|
|
builtin: {
|
|
|
|
|
resource: "0x1000000001000000020000000300000004000000"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
#-}
|
|
|
|
|
)";
|
|
|
|
|
|
|
|
|
|
TEST(Bytecode, MultiModuleWithResource) {
|
|
|
|
|
MLIRContext context;
|
|
|
|
|
Builder builder(&context);
|
|
|
|
|
ParserConfig parseConfig(&context);
|
|
|
|
|
OwningOpRef<Operation *> module =
|
|
|
|
|
parseSourceString<Operation *>(IRWithResources, parseConfig);
|
|
|
|
|
ASSERT_TRUE(module);
|
|
|
|
|
|
|
|
|
|
// Write the module to bytecode
|
|
|
|
|
std::string buffer;
|
|
|
|
|
llvm::raw_string_ostream ostream(buffer);
|
|
|
|
|
ASSERT_TRUE(succeeded(writeBytecodeToFile(module.get(), ostream)));
|
|
|
|
|
|
|
|
|
|
// Parse it back
|
|
|
|
|
OwningOpRef<Operation *> roundTripModule =
|
|
|
|
|
parseSourceString<Operation *>(ostream.str(), parseConfig);
|
|
|
|
|
ASSERT_TRUE(roundTripModule);
|
|
|
|
|
|
2023-06-23 09:17:53 +02:00
|
|
|
// FIXME: Parsing external resources does not work on big-endian
|
|
|
|
|
// platforms currently.
|
|
|
|
|
if (llvm::support::endian::system_endianness() ==
|
|
|
|
|
llvm::support::endianness::big)
|
|
|
|
|
GTEST_SKIP();
|
|
|
|
|
|
2023-05-24 21:52:05 -07:00
|
|
|
// Try to see if we have a valid resource in the parsed module.
|
|
|
|
|
auto checkResourceAttribute = [&](Operation *op) {
|
|
|
|
|
Attribute attr = roundTripModule->getAttr("bytecode.test");
|
|
|
|
|
ASSERT_TRUE(attr);
|
|
|
|
|
auto denseResourceAttr = dyn_cast<DenseI32ResourceElementsAttr>(attr);
|
|
|
|
|
ASSERT_TRUE(denseResourceAttr);
|
|
|
|
|
std::optional<ArrayRef<int32_t>> attrData =
|
|
|
|
|
denseResourceAttr.tryGetAsArrayRef();
|
|
|
|
|
ASSERT_TRUE(attrData.has_value());
|
|
|
|
|
ASSERT_EQ(attrData->size(), static_cast<size_t>(4));
|
|
|
|
|
EXPECT_EQ((*attrData)[0], 1);
|
|
|
|
|
EXPECT_EQ((*attrData)[1], 2);
|
|
|
|
|
EXPECT_EQ((*attrData)[2], 3);
|
|
|
|
|
EXPECT_EQ((*attrData)[3], 4);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
checkResourceAttribute(*module);
|
|
|
|
|
checkResourceAttribute(*roundTripModule);
|
|
|
|
|
}
|