From f2a32d996ae09620474771c46a649f6c4e1148ad Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Johan=20Sj=C3=B6len?= Date: Mon, 3 Oct 2022 12:18:04 +0000 Subject: [PATCH] 8293691: converting a defined BasicType value to a string should not crash the VM Reviewed-by: shade, coleenp, dlong --- src/hotspot/share/utilities/globalDefinitions.cpp | 11 +++++++++++ src/hotspot/share/utilities/globalDefinitions.hpp | 5 +---- 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/src/hotspot/share/utilities/globalDefinitions.cpp b/src/hotspot/share/utilities/globalDefinitions.cpp index 39c8000df36..c6c1b841650 100644 --- a/src/hotspot/share/utilities/globalDefinitions.cpp +++ b/src/hotspot/share/utilities/globalDefinitions.cpp @@ -236,6 +236,17 @@ const char* type2name_tab[T_CONFLICT+1] = { "*narrowklass*", "*conflict*" }; +const char* type2name(BasicType t) { + if (t < ARRAY_SIZE(type2name_tab)) { + return type2name_tab[t]; + } else if (t == T_ILLEGAL) { + return "*illegal*"; + } else { + fatal("invalid type %d", t); + return "invalid type"; + } +} + BasicType name2type(const char* name) { diff --git a/src/hotspot/share/utilities/globalDefinitions.hpp b/src/hotspot/share/utilities/globalDefinitions.hpp index 003be2bdf4c..84e292047ff 100644 --- a/src/hotspot/share/utilities/globalDefinitions.hpp +++ b/src/hotspot/share/utilities/globalDefinitions.hpp @@ -786,10 +786,7 @@ extern int type2size[T_CONFLICT+1]; // Map BasicType to result stack ele extern const char* type2name_tab[T_CONFLICT+1]; // Map a BasicType to a char* extern BasicType name2type(const char* name); -inline const char* type2name(BasicType t) { - assert((uint)t < T_CONFLICT + 1, "invalid type"); - return type2name_tab[t]; -} +const char* type2name(BasicType t); inline jlong max_signed_integer(BasicType bt) { if (bt == T_INT) {