This makes the bytecode reader/writer work on big-endian platforms. The only problem was related to encoding of multi-byte integers, where both reader and writer code make implicit assumptions about endianness of the host platform. This fixes the current test failures on s390x, and in addition allows to remove the UNSUPPORTED markers from all other bytecode-related test cases - they now also all pass on s390x. Also adding a GFAIL_SKIP to the MultiModuleWithResource unit test, as this still fails due to an unrelated endian bug regarding decoding of external resources. Differential Revision: https://reviews.llvm.org/D153567 Reviewed By: mehdi_amini, jpienaar, rriddle
27 lines
1.1 KiB
MLIR
27 lines
1.1 KiB
MLIR
// This file contains a test case representative of a dialect parsing an
|
|
// attribute with versioned custom encoding.
|
|
|
|
//===--------------------------------------------------------------------===//
|
|
// Test attribute upgrade
|
|
//===--------------------------------------------------------------------===//
|
|
|
|
// COM: bytecode contains
|
|
// COM: module {
|
|
// COM: version: 1.12
|
|
// COM: "test.versionedB"() <{attribute = #test.attr_params<24, 42>}> : () -> ()
|
|
// COM: }
|
|
// RUN: mlir-opt %S/versioned-attr-1.12.mlirbc 2>&1 | FileCheck %s --check-prefix=CHECK1
|
|
// CHECK1: "test.versionedB"() <{attribute = #test.attr_params<42, 24>}> : () -> ()
|
|
|
|
//===--------------------------------------------------------------------===//
|
|
// Test attribute upgrade
|
|
//===--------------------------------------------------------------------===//
|
|
|
|
// COM: bytecode contains
|
|
// COM: module {
|
|
// COM: version: 2.0
|
|
// COM: "test.versionedB"() <{attribute = #test.attr_params<42, 24>}> : () -> ()
|
|
// COM: }
|
|
// RUN: mlir-opt %S/versioned-attr-2.0.mlirbc 2>&1 | FileCheck %s --check-prefix=CHECK2
|
|
// CHECK2: "test.versionedB"() <{attribute = #test.attr_params<42, 24>}> : () -> ()
|