2020-02-28 02:45:43 +08:00
|
|
|
//===- RunnerUtils.cpp - Utils for MLIR exec on targets with a C++ runtime ===//
|
2019-10-08 00:06:08 +08:00
|
|
|
//
|
2020-01-26 11:58:30 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
2019-12-24 01:35:36 +08:00
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2019-10-08 00:06:08 +08:00
|
|
|
//
|
2019-12-24 01:35:36 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2019-10-08 00:06:08 +08:00
|
|
|
//
|
[mlir] NFC: fix trivial typo in source files
Summary: fix trivial typos in the source files
Reviewers: mravishankar, antiagainst, nicolasvasilache, herhut, rriddle, aartbik
Reviewed By: antiagainst, rriddle
Subscribers: mehdi_amini, rriddle, jpienaar, burmako, shauheen, antiagainst, nicolasvasilache, csigg, arpith-jacob, mgester, lucyrfox, aartbik, liufengdb, Joonsoo, bader, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D76876
2020-03-27 02:51:37 +08:00
|
|
|
// This file implements basic functions to debug structured MLIR types at
|
2020-02-28 02:45:43 +08:00
|
|
|
// runtime. Entities in this file may not be compatible with targets without a
|
|
|
|
// C++ runtime. These may be progressively migrated to CRunnerUtils.cpp over
|
|
|
|
// time.
|
2019-10-08 00:06:08 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2020-02-27 22:51:15 +08:00
|
|
|
#include "mlir/ExecutionEngine/RunnerUtils.h"
|
2019-10-08 00:06:08 +08:00
|
|
|
|
2021-03-04 20:35:01 +08:00
|
|
|
extern "C" void
|
|
|
|
_mlir_ciface_print_memref_shape_i8(UnrankedMemRefType<int8_t> *M) {
|
|
|
|
std::cout << "Unranked Memref ";
|
|
|
|
printMemRefMetaData(std::cout, DynamicMemRefType<int8_t>(*M));
|
|
|
|
std::cout << "\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
extern "C" void
|
|
|
|
_mlir_ciface_print_memref_shape_i32(UnrankedMemRefType<int32_t> *M) {
|
|
|
|
std::cout << "Unranked Memref ";
|
|
|
|
printMemRefMetaData(std::cout, DynamicMemRefType<int32_t>(*M));
|
|
|
|
std::cout << "\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
extern "C" void
|
|
|
|
_mlir_ciface_print_memref_shape_i64(UnrankedMemRefType<int64_t> *M) {
|
|
|
|
std::cout << "Unranked Memref ";
|
|
|
|
printMemRefMetaData(std::cout, DynamicMemRefType<int64_t>(*M));
|
|
|
|
std::cout << "\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
extern "C" void
|
|
|
|
_mlir_ciface_print_memref_shape_f32(UnrankedMemRefType<float> *M) {
|
|
|
|
std::cout << "Unranked Memref ";
|
|
|
|
printMemRefMetaData(std::cout, DynamicMemRefType<float>(*M));
|
|
|
|
std::cout << "\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
extern "C" void
|
|
|
|
_mlir_ciface_print_memref_shape_f64(UnrankedMemRefType<double> *M) {
|
|
|
|
std::cout << "Unranked Memref ";
|
|
|
|
printMemRefMetaData(std::cout, DynamicMemRefType<double>(*M));
|
|
|
|
std::cout << "\n";
|
|
|
|
}
|
|
|
|
|
2020-02-10 21:12:47 +08:00
|
|
|
extern "C" void _mlir_ciface_print_memref_vector_4x4xf32(
|
|
|
|
StridedMemRefType<Vector2D<4, 4, float>, 2> *M) {
|
2019-12-12 23:32:36 +08:00
|
|
|
impl::printMemRef(*M);
|
2019-12-06 05:12:50 +08:00
|
|
|
}
|
|
|
|
|
2020-02-10 21:12:47 +08:00
|
|
|
extern "C" void _mlir_ciface_print_memref_i8(UnrankedMemRefType<int8_t> *M) {
|
[MLIR] Helper class referencing MemRefType to unify runner implementations.
Summary:
Add DynamicMemRefType which can reference one of the statically ranked StridedMemRefType or a UnrankedMemRefType so that runner utils only need to be implemented once.
There is definitely room for more clean up and unification, but I will keep that for follow-ups.
Reviewers: nicolasvasilache
Reviewed By: nicolasvasilache
Subscribers: mehdi_amini, rriddle, jpienaar, shauheen, antiagainst, nicolasvasilache, arpith-jacob, mgester, lucyrfox, liufengdb, stephenneuendorffer, Joonsoo, grosul1, frgossen, Kayjukh, jurahul, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D80513
2020-05-25 18:05:57 +08:00
|
|
|
impl::printMemRef(*M);
|
2019-12-19 09:32:00 +08:00
|
|
|
}
|
|
|
|
|
2020-03-11 20:56:31 +08:00
|
|
|
extern "C" void _mlir_ciface_print_memref_i32(UnrankedMemRefType<int32_t> *M) {
|
[MLIR] Helper class referencing MemRefType to unify runner implementations.
Summary:
Add DynamicMemRefType which can reference one of the statically ranked StridedMemRefType or a UnrankedMemRefType so that runner utils only need to be implemented once.
There is definitely room for more clean up and unification, but I will keep that for follow-ups.
Reviewers: nicolasvasilache
Reviewed By: nicolasvasilache
Subscribers: mehdi_amini, rriddle, jpienaar, shauheen, antiagainst, nicolasvasilache, arpith-jacob, mgester, lucyrfox, liufengdb, stephenneuendorffer, Joonsoo, grosul1, frgossen, Kayjukh, jurahul, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D80513
2020-05-25 18:05:57 +08:00
|
|
|
impl::printMemRef(*M);
|
2020-03-11 20:56:31 +08:00
|
|
|
}
|
|
|
|
|
2020-11-23 22:55:42 +08:00
|
|
|
extern "C" void _mlir_ciface_print_memref_i64(UnrankedMemRefType<int64_t> *M) {
|
|
|
|
impl::printMemRef(*M);
|
|
|
|
}
|
|
|
|
|
2020-02-10 21:12:47 +08:00
|
|
|
extern "C" void _mlir_ciface_print_memref_f32(UnrankedMemRefType<float> *M) {
|
[MLIR] Helper class referencing MemRefType to unify runner implementations.
Summary:
Add DynamicMemRefType which can reference one of the statically ranked StridedMemRefType or a UnrankedMemRefType so that runner utils only need to be implemented once.
There is definitely room for more clean up and unification, but I will keep that for follow-ups.
Reviewers: nicolasvasilache
Reviewed By: nicolasvasilache
Subscribers: mehdi_amini, rriddle, jpienaar, shauheen, antiagainst, nicolasvasilache, arpith-jacob, mgester, lucyrfox, liufengdb, stephenneuendorffer, Joonsoo, grosul1, frgossen, Kayjukh, jurahul, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D80513
2020-05-25 18:05:57 +08:00
|
|
|
impl::printMemRef(*M);
|
2019-12-06 05:12:50 +08:00
|
|
|
}
|
|
|
|
|
2020-09-23 19:52:10 +08:00
|
|
|
extern "C" void _mlir_ciface_print_memref_f64(UnrankedMemRefType<double> *M) {
|
|
|
|
impl::printMemRef(*M);
|
|
|
|
}
|
|
|
|
|
2020-03-11 20:56:31 +08:00
|
|
|
extern "C" void print_memref_i32(int64_t rank, void *ptr) {
|
|
|
|
UnrankedMemRefType<int32_t> descriptor = {rank, ptr};
|
|
|
|
_mlir_ciface_print_memref_i32(&descriptor);
|
|
|
|
}
|
|
|
|
|
2020-11-23 22:55:42 +08:00
|
|
|
extern "C" void print_memref_i64(int64_t rank, void *ptr) {
|
|
|
|
UnrankedMemRefType<int64_t> descriptor = {rank, ptr};
|
|
|
|
_mlir_ciface_print_memref_i64(&descriptor);
|
|
|
|
}
|
|
|
|
|
2020-02-10 21:12:47 +08:00
|
|
|
extern "C" void print_memref_f32(int64_t rank, void *ptr) {
|
2020-03-11 20:56:31 +08:00
|
|
|
UnrankedMemRefType<float> descriptor = {rank, ptr};
|
2020-02-10 21:12:47 +08:00
|
|
|
_mlir_ciface_print_memref_f32(&descriptor);
|
|
|
|
}
|
|
|
|
|
2020-09-23 19:52:10 +08:00
|
|
|
extern "C" void print_memref_f64(int64_t rank, void *ptr) {
|
|
|
|
UnrankedMemRefType<double> descriptor = {rank, ptr};
|
|
|
|
_mlir_ciface_print_memref_f64(&descriptor);
|
|
|
|
}
|
|
|
|
|
2020-02-10 21:12:47 +08:00
|
|
|
extern "C" void
|
|
|
|
_mlir_ciface_print_memref_0d_f32(StridedMemRefType<float, 0> *M) {
|
2019-12-12 23:32:36 +08:00
|
|
|
impl::printMemRef(*M);
|
2019-10-08 00:06:08 +08:00
|
|
|
}
|
2020-02-10 21:12:47 +08:00
|
|
|
extern "C" void
|
|
|
|
_mlir_ciface_print_memref_1d_f32(StridedMemRefType<float, 1> *M) {
|
2019-12-12 23:32:36 +08:00
|
|
|
impl::printMemRef(*M);
|
2019-10-08 00:06:08 +08:00
|
|
|
}
|
2020-02-10 21:12:47 +08:00
|
|
|
extern "C" void
|
|
|
|
_mlir_ciface_print_memref_2d_f32(StridedMemRefType<float, 2> *M) {
|
2019-12-12 23:32:36 +08:00
|
|
|
impl::printMemRef(*M);
|
2019-10-08 00:06:08 +08:00
|
|
|
}
|
2020-02-10 21:12:47 +08:00
|
|
|
extern "C" void
|
|
|
|
_mlir_ciface_print_memref_3d_f32(StridedMemRefType<float, 3> *M) {
|
2019-12-12 23:32:36 +08:00
|
|
|
impl::printMemRef(*M);
|
2019-10-08 00:06:08 +08:00
|
|
|
}
|
2020-02-10 21:12:47 +08:00
|
|
|
extern "C" void
|
|
|
|
_mlir_ciface_print_memref_4d_f32(StridedMemRefType<float, 4> *M) {
|
2019-12-12 23:32:36 +08:00
|
|
|
impl::printMemRef(*M);
|
2019-10-08 00:06:08 +08:00
|
|
|
}
|
2021-02-15 03:21:47 +08:00
|
|
|
|
|
|
|
extern "C" int64_t
|
|
|
|
_mlir_ciface_verifyMemRefI32(UnrankedMemRefType<int32_t> *actual,
|
|
|
|
UnrankedMemRefType<int32_t> *expected) {
|
|
|
|
return impl::verifyMemRef(*actual, *expected);
|
|
|
|
}
|
|
|
|
|
|
|
|
extern "C" int64_t
|
|
|
|
_mlir_ciface_verifyMemRefF32(UnrankedMemRefType<float> *actual,
|
|
|
|
UnrankedMemRefType<float> *expected) {
|
|
|
|
return impl::verifyMemRef(*actual, *expected);
|
|
|
|
}
|
|
|
|
|
|
|
|
extern "C" int64_t
|
|
|
|
_mlir_ciface_verifyMemRefF64(UnrankedMemRefType<double> *actual,
|
|
|
|
UnrankedMemRefType<double> *expected) {
|
|
|
|
return impl::verifyMemRef(*actual, *expected);
|
|
|
|
}
|
|
|
|
|
|
|
|
extern "C" int64_t verifyMemRefI32(int64_t rank, void *actualPtr,
|
|
|
|
void *expectedPtr) {
|
|
|
|
UnrankedMemRefType<int32_t> actualDesc = {rank, actualPtr};
|
|
|
|
UnrankedMemRefType<int32_t> expectedDesc = {rank, expectedPtr};
|
|
|
|
return _mlir_ciface_verifyMemRefI32(&actualDesc, &expectedDesc);
|
|
|
|
}
|
|
|
|
|
|
|
|
extern "C" int64_t verifyMemRefF32(int64_t rank, void *actualPtr,
|
|
|
|
void *expectedPtr) {
|
|
|
|
UnrankedMemRefType<float> actualDesc = {rank, actualPtr};
|
|
|
|
UnrankedMemRefType<float> expectedDesc = {rank, expectedPtr};
|
|
|
|
return _mlir_ciface_verifyMemRefF32(&actualDesc, &expectedDesc);
|
|
|
|
}
|
|
|
|
|
|
|
|
extern "C" int64_t verifyMemRefF64(int64_t rank, void *actualPtr,
|
|
|
|
void *expectedPtr) {
|
|
|
|
UnrankedMemRefType<double> actualDesc = {rank, actualPtr};
|
|
|
|
UnrankedMemRefType<double> expectedDesc = {rank, expectedPtr};
|
|
|
|
return _mlir_ciface_verifyMemRefF64(&actualDesc, &expectedDesc);
|
|
|
|
}
|