From 59b883333ba3f76d5ea776240813478b00ac8f90 Mon Sep 17 00:00:00 2001 From: Roland Westrelin Date: Fri, 23 Dec 2011 09:36:23 +0100 Subject: [PATCH] 7123253: C1: in store check code, usage of registers may be incorrect Fix usage of input register in assembly code for store check. Reviewed-by: never --- hotspot/src/share/vm/c1/c1_LIR.cpp | 3 +++ 1 file changed, 3 insertions(+) diff --git a/hotspot/src/share/vm/c1/c1_LIR.cpp b/hotspot/src/share/vm/c1/c1_LIR.cpp index 267b966641c..629d849bc60 100644 --- a/hotspot/src/share/vm/c1/c1_LIR.cpp +++ b/hotspot/src/share/vm/c1/c1_LIR.cpp @@ -854,6 +854,9 @@ void LIR_OpVisitState::visit(LIR_Op* op) { if (opTypeCheck->_info_for_exception) do_info(opTypeCheck->_info_for_exception); if (opTypeCheck->_info_for_patch) do_info(opTypeCheck->_info_for_patch); if (opTypeCheck->_object->is_valid()) do_input(opTypeCheck->_object); + if (op->code() == lir_store_check && opTypeCheck->_object->is_valid()) { + do_temp(opTypeCheck->_object); + } if (opTypeCheck->_array->is_valid()) do_input(opTypeCheck->_array); if (opTypeCheck->_tmp1->is_valid()) do_temp(opTypeCheck->_tmp1); if (opTypeCheck->_tmp2->is_valid()) do_temp(opTypeCheck->_tmp2);