merge
authorMario de Sousa <msousa@fe.up.pt>
Thu, 03 Jan 2013 18:27:06 +0000
changeset 795 9c1bca18d3fa
parent 793 268bf4ca5fa1 (current diff)
parent 794 d534db26cbd5 (diff)
child 796 73e14a2ce5d1
merge
--- a/stage3/constant_folding.cc	Thu Jan 03 18:23:07 2013 +0000
+++ b/stage3/constant_folding.cc	Thu Jan 03 18:27:06 2013 +0000
@@ -448,6 +448,8 @@
 	if (!VALID_CVALUE(uint64, res))
 		return;
 	/* Test by pre-condition: If (UINT64_MAX / a) < b => overflow! */
+	if (0 == GET_CVALUE(uint64, a))
+		return; // multiplying by 0 will always result in 0, a valid result!	  
 	if ((UINT64_MAX / GET_CVALUE(uint64, a)) < GET_CVALUE(uint64, b))
 		SET_OVFLOW(uint64, res);
 }