aboutsummaryrefslogtreecommitdiffstats
path: root/core/vm/sqlvm/runtime/runtime.go
diff options
context:
space:
mode:
authorMeng-Ying Yang <garfield@dexon.org>2019-02-23 10:51:51 +0800
committerJhih-Ming Huang <jm.huang@cobinhood.com>2019-05-06 10:44:04 +0800
commit8115f8c82f95e6581361fcd7e2d838406517ea4f (patch)
tree2efe439e555bf75761b084f7f5fe3634e3bbf260 /core/vm/sqlvm/runtime/runtime.go
parent4c3bc281c9d8409e2ae030be63e82d2c27aa73aa (diff)
downloaddexon-8115f8c82f95e6581361fcd7e2d838406517ea4f.tar
dexon-8115f8c82f95e6581361fcd7e2d838406517ea4f.tar.gz
dexon-8115f8c82f95e6581361fcd7e2d838406517ea4f.tar.bz2
dexon-8115f8c82f95e6581361fcd7e2d838406517ea4f.tar.lz
dexon-8115f8c82f95e6581361fcd7e2d838406517ea4f.tar.xz
dexon-8115f8c82f95e6581361fcd7e2d838406517ea4f.tar.zst
dexon-8115f8c82f95e6581361fcd7e2d838406517ea4f.zip
core: vm: sqlvm: opcodes and basic structs
For runtime implementation, we define opcodes and basic structs for runtime usage and concrete implementation.
Diffstat (limited to 'core/vm/sqlvm/runtime/runtime.go')
-rw-r--r--core/vm/sqlvm/runtime/runtime.go13
1 files changed, 9 insertions, 4 deletions
diff --git a/core/vm/sqlvm/runtime/runtime.go b/core/vm/sqlvm/runtime/runtime.go
index 8c3a105ac..e6a3a0006 100644
--- a/core/vm/sqlvm/runtime/runtime.go
+++ b/core/vm/sqlvm/runtime/runtime.go
@@ -3,20 +3,25 @@ package runtime
import (
"github.com/dexon-foundation/dexon/core/vm"
"github.com/dexon-foundation/dexon/core/vm/sqlvm/common"
- "github.com/dexon-foundation/dexon/core/vm/sqlvm/errors"
+ se "github.com/dexon-foundation/dexon/core/vm/sqlvm/errors"
)
// Run is runtime entrypoint.
func Run(stateDB vm.StateDB, ins []Instruction, registers []*Operand) (ret []byte, err error) {
for _, in := range ins {
+ for i := 0; i < len(in.Input); i++ {
+ if !in.Input[i].IsImmediate {
+ in.Input[i] = registers[in.Input[i].RegisterIndex]
+ }
+ }
opFunc := jumpTable[in.Op]
loadRegister(in.Input, registers)
errCode := opFunc(&common.Context{}, in.Input, registers, in.Output)
if errCode != nil {
- err = errors.Error{
+ err = se.Error{
Position: in.Position,
- Code: errCode.(errors.ErrorCode),
- Category: errors.ErrorCategoryRuntime,
+ Code: errCode.(se.ErrorCode),
+ Category: se.ErrorCategoryRuntime,
}
return nil, err
}