提交 ec1401b7 编写于 作者: B bdelsart

7057978: improve robustness of c1 ARM back-end wrt non encodable constants

Summary: ARM only, avoid assertion failures for huge constants generated by C1 shared code
Reviewed-by: never, vladidan
上级 d4db62b3
...@@ -142,7 +142,8 @@ void LIR_Address::verify() const { ...@@ -142,7 +142,8 @@ void LIR_Address::verify() const {
#endif #endif
#ifdef ARM #ifdef ARM
assert(disp() == 0 || index()->is_illegal(), "can't have both"); assert(disp() == 0 || index()->is_illegal(), "can't have both");
assert(-4096 < disp() && disp() < 4096, "architecture constraint"); // Note: offsets higher than 4096 must not be rejected here. They can
// be handled by the back-end or will be rejected if not.
#endif #endif
#ifdef _LP64 #ifdef _LP64
assert(base()->is_cpu_register(), "wrong base operand"); assert(base()->is_cpu_register(), "wrong base operand");
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册