mirror of
https://github.com/corda/corda.git
synced 2025-01-22 12:28:11 +00:00
resolve address operands only when writing the final output
This commit is contained in:
parent
c4fc933383
commit
13fae991fd
@ -1467,7 +1467,7 @@ RegisterOperand::accept(Context* c, Operation op,
|
||||
ImmediateOperand*
|
||||
value(Context* c, AddressOperand* operand)
|
||||
{
|
||||
if (operand->promise->resolved(c)) {
|
||||
if (c->codeLength and operand->promise->resolved(c)) {
|
||||
return immediate(c, operand->promise->value(c));
|
||||
} else {
|
||||
return immediate(c, 0);
|
||||
@ -1544,7 +1544,7 @@ RegisterOperand::accept(Context* c, Operation op,
|
||||
ImmediateOperand*
|
||||
value(Context* c, AbsoluteOperand* operand)
|
||||
{
|
||||
if (operand->promise->resolved(c)) {
|
||||
if (c->codeLength and operand->promise->resolved(c)) {
|
||||
return immediate(c, operand->promise->value(c));
|
||||
} else {
|
||||
return immediate(c, 0);
|
||||
@ -1582,7 +1582,7 @@ void
|
||||
unconditional(Context* c, unsigned jump, AddressOperand* operand)
|
||||
{
|
||||
intptr_t v;
|
||||
if (operand->promise->resolved(c)) {
|
||||
if (c->codeLength and operand->promise->resolved(c)) {
|
||||
uint8_t* instruction = c->code.data + c->code.length();
|
||||
v = reinterpret_cast<uint8_t*>(operand->promise->value(c))
|
||||
- instruction - 5;
|
||||
@ -1600,7 +1600,7 @@ void
|
||||
conditional(Context* c, unsigned condition, AddressOperand* operand)
|
||||
{
|
||||
intptr_t v;
|
||||
if (operand->promise->resolved(c)) {
|
||||
if (c->codeLength and operand->promise->resolved(c)) {
|
||||
uint8_t* instruction = c->code.data + c->code.length();
|
||||
v = reinterpret_cast<uint8_t*>(operand->promise->value(c))
|
||||
- instruction - 6;
|
||||
|
Loading…
Reference in New Issue
Block a user