mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
fix compiler problems discovered in openjdk-src arm bootimage build
This particular problem was introduced in the recent "compiler types" refactor. It's unclear why it wasn't encountered before now. Note that the full, unproguarded bootimage build is still blocked by #305
This commit is contained in:
parent
8471befb4d
commit
f3968d2401
@ -1648,6 +1648,7 @@ class Frame {
|
|||||||
|
|
||||||
void storeLarge(ir::Type type, unsigned index)
|
void storeLarge(ir::Type type, unsigned index)
|
||||||
{
|
{
|
||||||
|
assertT(t, type.rawSize() == 8);
|
||||||
storeLocal(context, 2, type, popLarge(type), index);
|
storeLocal(context, 2, type, popLarge(type), index);
|
||||||
unsigned ti = translateLocalIndex(context, 2, index);
|
unsigned ti = translateLocalIndex(context, 2, index);
|
||||||
assertT(t, ti + 1 < localSize());
|
assertT(t, ti + 1 < localSize());
|
||||||
@ -1691,7 +1692,7 @@ class Frame {
|
|||||||
{
|
{
|
||||||
ir::Value* s0 = c->pop(ir::Type::i4());
|
ir::Value* s0 = c->pop(ir::Type::i4());
|
||||||
|
|
||||||
if (get(sp - 2) == ir::Type::i8()) {
|
if (get(sp - 2).rawSize() == 8) {
|
||||||
ir::Value* s1 = c->pop(ir::Type::i8());
|
ir::Value* s1 = c->pop(ir::Type::i8());
|
||||||
|
|
||||||
c->push(ir::Type::i4(), s0);
|
c->push(ir::Type::i4(), s0);
|
||||||
@ -1724,7 +1725,7 @@ class Frame {
|
|||||||
|
|
||||||
void dup2()
|
void dup2()
|
||||||
{
|
{
|
||||||
if (get(sp - 1) == ir::Type::i8()) {
|
if (get(sp - 1).rawSize() == 8) {
|
||||||
c->push(ir::Type::i8(), c->peek(2, 0));
|
c->push(ir::Type::i8(), c->peek(2, 0));
|
||||||
} else {
|
} else {
|
||||||
ir::Value* s0 = c->pop(ir::Type::i4());
|
ir::Value* s0 = c->pop(ir::Type::i4());
|
||||||
@ -1750,7 +1751,7 @@ class Frame {
|
|||||||
|
|
||||||
void dup2X1()
|
void dup2X1()
|
||||||
{
|
{
|
||||||
if (get(sp - 1) == ir::Type::i8()) {
|
if (get(sp - 1).rawSize() == 8) {
|
||||||
ir::Value* s0 = c->pop(ir::Type::i8());
|
ir::Value* s0 = c->pop(ir::Type::i8());
|
||||||
ir::Value* s1 = c->pop(ir::Type::i4());
|
ir::Value* s1 = c->pop(ir::Type::i4());
|
||||||
|
|
||||||
@ -1787,10 +1788,10 @@ class Frame {
|
|||||||
|
|
||||||
void dup2X2()
|
void dup2X2()
|
||||||
{
|
{
|
||||||
if (get(sp - 1) == ir::Type::i8()) {
|
if (get(sp - 1).rawSize() == 8) {
|
||||||
ir::Value* s0 = c->pop(ir::Type::i8());
|
ir::Value* s0 = c->pop(ir::Type::i8());
|
||||||
|
|
||||||
if (get(sp - 3) == ir::Type::i8()) {
|
if (get(sp - 3).rawSize() == 8) {
|
||||||
ir::Value* s1 = c->pop(ir::Type::i8());
|
ir::Value* s1 = c->pop(ir::Type::i8());
|
||||||
|
|
||||||
c->push(ir::Type::i8(), s0);
|
c->push(ir::Type::i8(), s0);
|
||||||
|
Loading…
Reference in New Issue
Block a user