diff options
author | Mehdi Amini <aminim@google.com> | 2019-12-24 02:47:41 +0000 |
---|---|---|
committer | Mehdi Amini <aminim@google.com> | 2019-12-24 02:47:41 +0000 |
commit | 0f0d0ed1c78f1a80139a1f2133fad5284691a121 (patch) | |
tree | 31979a3137c364e3eb58e0169a7c4029c7ee7db3 /mlir/test/mlir-cpu-runner/mlir_runner_utils.cpp | |
parent | 6f635f90929da9545dd696071a829a1a42f84b30 (diff) | |
parent | 5b4a01d4a63cb66ab981e52548f940813393bf42 (diff) | |
download | bcm5719-llvm-0f0d0ed1c78f1a80139a1f2133fad5284691a121.tar.gz bcm5719-llvm-0f0d0ed1c78f1a80139a1f2133fad5284691a121.zip |
Import MLIR into the LLVM tree
Diffstat (limited to 'mlir/test/mlir-cpu-runner/mlir_runner_utils.cpp')
-rw-r--r-- | mlir/test/mlir-cpu-runner/mlir_runner_utils.cpp | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/mlir/test/mlir-cpu-runner/mlir_runner_utils.cpp b/mlir/test/mlir-cpu-runner/mlir_runner_utils.cpp new file mode 100644 index 00000000000..fc3a782c080 --- /dev/null +++ b/mlir/test/mlir-cpu-runner/mlir_runner_utils.cpp @@ -0,0 +1,85 @@ +//===- mlir_runner_utils.cpp - Utils for MLIR CPU execution ---------------===// +// +// Part of the MLIR 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 +// +//===----------------------------------------------------------------------===// +// +// Utilities for interfacing MLIR types with C code as well as printing, +// debugging etc. +// +//===----------------------------------------------------------------------===// + +#include "include/mlir_runner_utils.h" + +#include <cstdio> + +extern "C" void +print_memref_vector_4x4xf32(StridedMemRefType<Vector2D<4, 4, float>, 2> *M) { + impl::printMemRef(*M); +} + +#define MEMREF_CASE(TYPE, RANK) \ + case RANK: \ + impl::printMemRef(*(static_cast<StridedMemRefType<TYPE, RANK> *>(ptr))); \ + break + +extern "C" void print_memref_i8(UnrankedMemRefType<int8_t> *M) { + printUnrankedMemRefMetaData(std::cout, *M); + int rank = M->rank; + void *ptr = M->descriptor; + + switch (rank) { + MEMREF_CASE(int8_t, 0); + MEMREF_CASE(int8_t, 1); + MEMREF_CASE(int8_t, 2); + MEMREF_CASE(int8_t, 3); + MEMREF_CASE(int8_t, 4); + default: + assert(0 && "Unsupported rank to print"); + } +} + +extern "C" void print_memref_f32(UnrankedMemRefType<float> *M) { + printUnrankedMemRefMetaData(std::cout, *M); + int rank = M->rank; + void *ptr = M->descriptor; + + switch (rank) { + MEMREF_CASE(float, 0); + MEMREF_CASE(float, 1); + MEMREF_CASE(float, 2); + MEMREF_CASE(float, 3); + MEMREF_CASE(float, 4); + default: + assert(0 && "Unsupported rank to print"); + } +} + +extern "C" void print_memref_0d_f32(StridedMemRefType<float, 0> *M) { + impl::printMemRef(*M); +} +extern "C" void print_memref_1d_f32(StridedMemRefType<float, 1> *M) { + impl::printMemRef(*M); +} +extern "C" void print_memref_2d_f32(StridedMemRefType<float, 2> *M) { + impl::printMemRef(*M); +} +extern "C" void print_memref_3d_f32(StridedMemRefType<float, 3> *M) { + impl::printMemRef(*M); +} +extern "C" void print_memref_4d_f32(StridedMemRefType<float, 4> *M) { + impl::printMemRef(*M); +} + +// Small runtime support "lib" for vector.print lowering. +// By providing elementary printing methods only, this +// library can remain fully unaware of low-level implementation +// details of our vectors. +extern "C" void print_f32(float f) { fprintf(stdout, "%g", f); } +extern "C" void print_f64(double d) { fprintf(stdout, "%lg", d); } +extern "C" void print_open() { fputs("( ", stdout); } +extern "C" void print_close() { fputs(" )", stdout); } +extern "C" void print_comma() { fputs(", ", stdout); } +extern "C" void print_newline() { fputc('\n', stdout); } |