[TVMScript] Prevent bool to int conversion in T.Assert condition (#14941)

* [Bugfix] Avoid symbol conflicts in MakePackedAPI/MakeUnpackedAPI

PRs https://github.com/apache/tvm/pull/14913 and
https://github.com/apache/tvm/pull/14914 made analogous changes to
`MakePackedAPI` and `MakeUnpackedAPI` to handle subroutine calls.
Both PRs introduced the same symbol,
`tvm::tir::SubroutineCallRewriter`, a local utility to update internal
calls to a modified function.  While each PR passed CI individually,
and was therefore able to merge, having both changes caused a
duplicate symbol.

This commit updates `MakePackedAPI` and `MakeUnpackedAPI` to place
their local utilities into anonymous namespaces, avoiding the
conflict.

* [TVMScript] Prevent bool to int conversion in T.Assert condition

Previously, while literal `True` and `False` values were converted to
`tvm::Bool` instances, constant-foldable expressions (e.g. `0 == 1`)
would be evaluated to `True`, but were then passed directly to the
FFI.  Because the FFI uses the same representation for integer and
boolean values, the conversion to `PrimExpr` resulted in a
`tvm::Integer` instead of `tvm::Bool`.

This commit converts the argument of `T.Assert` to a `tvm::Bool`
before calling the FFI, avoiding the ambiguity.  In addition, the
`AssertStmt` constructor now validates the datatype of the condition,
to prevent it from re-occurring.

This was first caught in the unit test
`test_debug_info.py::test_llvm_ir_debug_info`, which failed on some
versions of LLVM due to the use of `i32` as the condition of an
assert.

* Updated TVMScript printer unit test with boolean condition
4 files changed
tree: 992dd1f39cdf2b8b77e7ae8360123605715b5e6e
  1. .github/
  2. 3rdparty/
  3. apps/
  4. ci/
  5. cmake/
  6. conda/
  7. configs/
  8. docker/
  9. docs/
  10. gallery/
  11. golang/
  12. include/
  13. jvm/
  14. licenses/
  15. python/
  16. rust/
  17. src/
  18. tests/
  19. vta/
  20. web/
  21. .asf.yaml
  22. .clang-format
  23. .gitattributes
  24. .gitignore
  25. .gitmodules
  26. .pre-commit-config.yaml
  27. CMakeLists.txt
  28. conftest.py
  29. CONTRIBUTORS.md
  30. KEYS
  31. LICENSE
  32. Makefile
  33. mypy.ini
  34. NEWS.md
  35. NOTICE
  36. pyproject.toml
  37. README.md
  38. version.py
README.md

Open Deep Learning Compiler Stack

Documentation | Contributors | Community | Release Notes

Build Status WinMacBuild

Apache TVM is a compiler stack for deep learning systems. It is designed to close the gap between the productivity-focused deep learning frameworks, and the performance- and efficiency-focused hardware backends. TVM works with deep learning frameworks to provide end to end compilation to different backends.

License

TVM is licensed under the Apache-2.0 license.

Getting Started

Check out the TVM Documentation site for installation instructions, tutorials, examples, and more. The Getting Started with TVM tutorial is a great place to start.

Contribute to TVM

TVM adopts apache committer model, we aim to create an open source project that is maintained and owned by the community. Check out the Contributor Guide.

Acknowledgement

We learned a lot from the following projects when building TVM.

  • Halide: Part of TVM's TIR and arithmetic simplification module originates from Halide. We also learned and adapted some part of lowering pipeline from Halide.
  • Loopy: use of integer set analysis and its loop transformation primitives.
  • Theano: the design inspiration of symbolic scan operator for recurrence.