Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[x/programs] Improve State-keys & Argument Passing #623

Merged
merged 78 commits into from
Dec 12, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
78 commits
Select commit Hold shift + click to select a range
c49fbc6
adding Key struct
samliok Nov 20, 2023
2eaa9aa
use Key struct in state methods
samliok Nov 20, 2023
2526ced
comments
samliok Nov 20, 2023
f457e23
key as ref and lint
samliok Nov 20, 2023
a5c652c
update sdk macro naming
samliok Nov 20, 2023
baa312a
forgot one is_context() method
samliok Nov 20, 2023
2158524
update public macro to convert from raw_ptr
samliok Nov 20, 2023
3e5b797
harden public macro, and converted params logic
samliok Nov 20, 2023
16d9dcd
reorder comments
samliok Nov 20, 2023
bfb7338
HostArgument type + Vec Example(rust)
samliok Nov 21, 2023
17cab87
added marshaling to go side, and token examples work(hype)
samliok Nov 21, 2023
a9993af
letsgoo, finally passing dynamic vecs working(needs clean up(from deb…
samliok Nov 21, 2023
b487e6a
cleanup logs
samliok Nov 21, 2023
a483cf5
combine HostArg + Arg
samliok Nov 21, 2023
1793386
vec<u8> -> &[u8]
samliok Nov 21, 2023
d97f278
avoid reallocation in as_bytes
samliok Nov 21, 2023
96190d4
temporary string example/method
samliok Nov 21, 2023
077d36b
remove VecArg junk
samliok Nov 21, 2023
ffa1dd9
cargo fmt
samliok Nov 21, 2023
21f1d81
lint
samliok Nov 21, 2023
67b69c4
flatten out tuple
samliok Nov 22, 2023
378d578
simplify ParamKind logic
samliok Nov 22, 2023
dd66f33
borsh serialization working(go/rust)
samliok Nov 22, 2023
6c45d95
move all from serde -> borsh(except simulator)
samliok Nov 22, 2023
033004a
call_program function
samliok Nov 22, 2023
4c15795
re added arg types, going to address call_program in another pr
samliok Nov 22, 2023
8dd98dc
unsafe + temp removal
samliok Nov 22, 2023
754c7bc
lint
samliok Nov 22, 2023
7c0ca41
go lint
samliok Nov 22, 2023
1e8fd38
mint recipient struct
samliok Nov 23, 2023
d97a849
mint recipient struct
samliok Nov 23, 2023
912ecc1
Update x/programs/rust/wasmlanche_sdk/src/types.rs
samliok Nov 23, 2023
0944839
lint
samliok Nov 23, 2023
c272666
remove temp go stuff
samliok Nov 24, 2023
813ffdc
tidy
samliok Nov 28, 2023
3d61aee
remove comment
samliok Nov 28, 2023
2f0090e
decompose newPtr method + nits
samliok Nov 30, 2023
ede907a
remove fixedLengthKey method
samliok Nov 30, 2023
bc9fa1a
refactor host calls
samliok Dec 1, 2023
968661c
return result in from_raw_ptr
samliok Dec 2, 2023
ef4cb9d
merge main
samliok Dec 2, 2023
a4f4a15
conflicts from merge
samliok Dec 2, 2023
236e963
represent pointers as *const u8
samliok Dec 2, 2023
2d240c8
comments
samliok Dec 2, 2023
cdd09a3
remove import
samliok Dec 2, 2023
4449ad7
remove len
samliok Dec 2, 2023
ed5ab6a
rust lint
samliok Dec 2, 2023
f207a5f
lfg some progress on serialize_param macro
samliok Dec 3, 2023
1ee07b1
why are we not putting units in second runtime?
samliok Dec 3, 2023
e1c319a
comments
samliok Dec 3, 2023
6c2cde5
counter test cleanup
samliok Dec 3, 2023
5d29b27
comment cleanup
samliok Dec 3, 2023
7db59e5
nits
samliok Dec 3, 2023
d19f883
program struct refactor
samliok Dec 4, 2023
ef3d0cc
yesss, external function calls working(needs cleanup)
samliok Dec 4, 2023
da30514
cleanup
samliok Dec 5, 2023
2f9a228
cargo fmt
samliok Dec 5, 2023
c879e1c
Fix token benchmark
hexfusion Dec 5, 2023
bc6741e
nits + Deref on Key struct
samliok Dec 6, 2023
b6facbc
bitwise operations on ptrs passing to the host
samliok Dec 8, 2023
cbe1000
Merge remote-tracking branch 'origin/refactor-statekey' into refactor…
samliok Dec 8, 2023
5ea23bb
bitwise operations working pasing parameters into wasm
samliok Dec 8, 2023
c4efc96
full circle -> external function calls(needs cleanup)
samliok Dec 8, 2023
caab4f3
ptr cleanup
samliok Dec 8, 2023
5595b01
comments and nit go cleanup
samliok Dec 8, 2023
245b06c
updated call_program host function
samliok Dec 9, 2023
764077d
SmartPtr type & cleanup utils
samliok Dec 10, 2023
cc96b79
go lint
samliok Dec 10, 2023
a17803d
rust lint
samliok Dec 10, 2023
158bfd2
update program impl
samliok Dec 10, 2023
2bd46d4
return result from rust side host function wrappers
samliok Dec 10, 2023
ee4507d
small rename
samliok Dec 10, 2023
2ab2bb1
rust lint
samliok Dec 10, 2023
f991a95
into_bytes function
samliok Dec 11, 2023
866febf
smart ptr method refactor
samliok Dec 11, 2023
f2e9f72
comments
samliok Dec 11, 2023
7cb99c4
int64 conversionn
samliok Dec 11, 2023
40f45d0
Merge branch 'main' into refactor-statekey
hexfusion Dec 12, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 9 additions & 9 deletions x/programs/examples/counter_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -52,15 +52,15 @@ func TestCounterProgram(t *testing.T) {
err = storage.SetProgram(ctx, db, programID, counterProgramBytes)
require.NoError(err)

programIDPtr, err := runtime.NewSmartPtr(programID, rt)
programIDPtr, err := argumentToSmartPtr(programID, rt.Memory())
require.NoError(err)

// generate alice keys
_, aliceKey, err := newKey()
require.NoError(err)

// write alice's key to stack and get pointer
alicePtr, err := runtime.NewSmartPtr(aliceKey, rt)
alicePtr, err := argumentToSmartPtr(aliceKey, rt.Memory())
require.NoError(err)

// create counter for alice on program 1
Expand Down Expand Up @@ -93,11 +93,11 @@ func TestCounterProgram(t *testing.T) {
err = storage.SetProgram(ctx, db, program2ID, counterProgramBytes)
require.NoError(err)

programID2Ptr, err := runtime.NewSmartPtr(program2ID, rt2)
programID2Ptr, err := argumentToSmartPtr(program2ID, rt2.Memory())
require.NoError(err)

// write alice's key to stack and get pointer
alicePtr2, err := runtime.NewSmartPtr(aliceKey, rt2)
alicePtr2, err := argumentToSmartPtr(aliceKey, rt2.Memory())
require.NoError(err)

// initialize counter for alice on runtime 2
Expand All @@ -107,7 +107,7 @@ func TestCounterProgram(t *testing.T) {

// increment alice's counter on program 2 by 10
incAmount := int64(10)
incAmountPtr, err := runtime.NewSmartPtr(incAmount, rt2)
incAmountPtr, err := argumentToSmartPtr(incAmount, rt2.Memory())
require.NoError(err)
result, err = rt2.Call(ctx, "inc", programID2Ptr, alicePtr2, incAmountPtr)
require.NoError(err)
Expand All @@ -128,7 +128,7 @@ func TestCounterProgram(t *testing.T) {
}

// increment alice's counter on program 1
onePtr, err := runtime.NewSmartPtr(int64(1), rt)
onePtr, err := argumentToSmartPtr(int64(1), rt.Memory())
require.NoError(err)
result, err = rt.Call(ctx, "inc", programIDPtr, alicePtr, onePtr)
require.NoError(err)
Expand All @@ -142,17 +142,17 @@ func TestCounterProgram(t *testing.T) {
)

// write program id 2 to stack of program 1
programID2Ptr, err = runtime.NewSmartPtr(program2ID, rt)
programID2Ptr, err = argumentToSmartPtr(program2ID, rt.Memory())
require.NoError(err)

caller := programIDPtr
target := programID2Ptr
maxUnitsProgramToProgram := int64(10000)
maxUnitsProgramToProgramPtr, err := runtime.NewSmartPtr(maxUnitsProgramToProgram, rt)
maxUnitsProgramToProgramPtr, err := argumentToSmartPtr(maxUnitsProgramToProgram, rt.Memory())
require.NoError(err)

// increment alice's counter on program 2
fivePtr, err := runtime.NewSmartPtr(int64(5), rt)
fivePtr, err := argumentToSmartPtr(int64(5), rt.Memory())
require.NoError(err)
result, err = rt.Call(ctx, "inc_external", caller, target, maxUnitsProgramToProgramPtr, alicePtr, fivePtr)
require.NoError(err)
Expand Down
12 changes: 6 additions & 6 deletions x/programs/examples/imports/program/program.go
Original file line number Diff line number Diff line change
Expand Up @@ -70,17 +70,17 @@ func (i *Import) callProgramFn(
) int64 {
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
client := runtime.NewExportClient(caller)
memory := runtime.NewMemory(runtime.NewExportClient(caller))
// get the entry function for invoke to call.
functionBytes, err := runtime.FromSmartPtr(client, runtime.SmartPtr(function))
functionBytes, err := runtime.SmartPtr(function).Bytes(memory)
if err != nil {
i.log.Error("failed to read function name from memory",
zap.Error(err),
)
return -1
}

programIDBytes, err := runtime.FromSmartPtr(client, runtime.SmartPtr(programID))
programIDBytes, err := runtime.SmartPtr(programID).Bytes(memory)
if err != nil {
i.log.Error("failed to read id from memory",
zap.Error(err),
Expand Down Expand Up @@ -131,7 +131,7 @@ func (i *Import) callProgramFn(
}
}()

argsBytes, err := runtime.FromSmartPtr(client, runtime.SmartPtr(args))
argsBytes, err := runtime.SmartPtr(args).Bytes(memory)
if err != nil {
i.log.Error("failed to read program args name from memory",
zap.Error(err),
Expand Down Expand Up @@ -167,7 +167,7 @@ func getCallArgs(ctx context.Context, memory runtime.Memory, buffer []byte, prog
if err != nil {
return nil, err
}
argPtr, err := runtime.ToSmartPtr(uint32(invokeProgramIDPtr), uint32(len(programIDBytes)))
argPtr, err := runtime.NewSmartPtr(uint32(invokeProgramIDPtr), len(programIDBytes))
if err != nil {
return nil, err
}
Expand All @@ -187,7 +187,7 @@ func getCallArgs(ctx context.Context, memory runtime.Memory, buffer []byte, prog
if err != nil {
return nil, err
}
argPtr, err := runtime.ToSmartPtr(uint32(ptr), length)
argPtr, err := runtime.NewSmartPtr(uint32(ptr), int(length))
if err != nil {
return nil, err
}
Expand Down
14 changes: 7 additions & 7 deletions x/programs/examples/imports/pstate/pstate.go
Original file line number Diff line number Diff line change
Expand Up @@ -59,25 +59,25 @@ func (i *Import) Register(link runtime.Link, meter runtime.Meter, _ runtime.Supp
}

func (i *Import) putFn(caller *wasmtime.Caller, id int64, key int64, value int64) int32 {
client := runtime.NewExportClient(caller)
memory := runtime.NewMemory(runtime.NewExportClient(caller))
// memory := runtime.NewMemory(client)
programIDBytes, err := runtime.FromSmartPtr(client, runtime.SmartPtr(id))
programIDBytes, err := runtime.SmartPtr(id).Bytes(memory)
if err != nil {
i.log.Error("failed to read program id from memory",
zap.Error(err),
)
return -1
}

keyBytes, err := runtime.FromSmartPtr(client, runtime.SmartPtr(key))
keyBytes, err := runtime.SmartPtr(key).Bytes(memory)
if err != nil {
i.log.Error("failed to read key from memory",
zap.Error(err),
)
return -1
}

valueBytes, err := runtime.FromSmartPtr(client, runtime.SmartPtr(value))
valueBytes, err := runtime.SmartPtr(value).Bytes(memory)

if err != nil {
i.log.Error("failed to read value from memory",
Expand All @@ -101,15 +101,15 @@ func (i *Import) putFn(caller *wasmtime.Caller, id int64, key int64, value int64
func (i *Import) getFn(caller *wasmtime.Caller, id int64, key int64) int64 {
client := runtime.NewExportClient(caller)
memory := runtime.NewMemory(client)
programIDBytes, err := runtime.FromSmartPtr(client, runtime.SmartPtr(id))
programIDBytes, err := runtime.SmartPtr(id).Bytes(memory)
if err != nil {
i.log.Error("failed to read program id from memory",
zap.Error(err),
)
return -1
}

keyBytes, err := runtime.FromSmartPtr(client, runtime.SmartPtr(key))
keyBytes, err := runtime.SmartPtr(key).Bytes(memory)
if err != nil {
i.log.Error("failed to read key from memory",
zap.Error(err),
Expand Down Expand Up @@ -142,7 +142,7 @@ func (i *Import) getFn(caller *wasmtime.Caller, id int64, key int64) int64 {
}
return -1
}
argPtr, err := runtime.ToSmartPtr(uint32(ptr), uint32(len(val)))
argPtr, err := runtime.NewSmartPtr(uint32(ptr), len(val))
if err != nil {
i.log.Error("failed to convert ptr to argument",
zap.Error(err),
Expand Down
16 changes: 8 additions & 8 deletions x/programs/examples/token.go
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@ func (t *Token) Run(ctx context.Context) error {
return err
}

programIDPtr, err := runtime.NewSmartPtr(programID, rt)
programIDPtr, err := argumentToSmartPtr(programID, rt.Memory())
if err != nil {
return err
}
Expand Down Expand Up @@ -97,7 +97,7 @@ func (t *Token) Run(ctx context.Context) error {
}

// write alice's key to stack and get pointer
alicePtr, err := runtime.NewSmartPtr(aliceKey, rt)
alicePtr, err := argumentToSmartPtr(aliceKey, rt.Memory())
if err != nil {
return err
}
Expand All @@ -109,7 +109,7 @@ func (t *Token) Run(ctx context.Context) error {
}

// write bob's key to stack and get pointer
bobPtr, err := runtime.NewSmartPtr(bobKey, rt)
bobPtr, err := argumentToSmartPtr(bobKey, rt.Memory())
if err != nil {
return err
}
Expand All @@ -125,7 +125,7 @@ func (t *Token) Run(ctx context.Context) error {

// mint 100 tokens to alice
mintAlice := int64(1000)
mintAlicePtr, err := runtime.NewSmartPtr(mintAlice, rt)
mintAlicePtr, err := argumentToSmartPtr(mintAlice, rt.Memory())
if err != nil {
return err
}
Expand Down Expand Up @@ -158,7 +158,7 @@ func (t *Token) Run(ctx context.Context) error {

// transfer 50 from alice to bob
transferToBob := int64(50)
transferToBobPtr, err := runtime.NewSmartPtr(transferToBob, rt)
transferToBobPtr, err := argumentToSmartPtr(transferToBob, rt.Memory())
if err != nil {
return err
}
Expand All @@ -171,7 +171,7 @@ func (t *Token) Run(ctx context.Context) error {
zap.Int64("to bob", transferToBob),
)

onePtr, err := runtime.NewSmartPtr(int64(1), rt)
onePtr, err := argumentToSmartPtr(int64(1), rt.Memory())
if err != nil {
return err
}
Expand Down Expand Up @@ -217,7 +217,7 @@ func (t *Token) Run(ctx context.Context) error {
},
}

mintersPtr, err := runtime.NewSmartPtr(minters, rt)
mintersPtr, err := argumentToSmartPtr(minters, rt.Memory())
if err != nil {
return err
}
Expand Down Expand Up @@ -270,7 +270,7 @@ func (t *Token) RunShort(ctx context.Context) error {
return err
}

programIDPtr, err := runtime.NewSmartPtr(programID, rt)
programIDPtr, err := argumentToSmartPtr(programID, rt.Memory())
if err != nil {
return err
}
Expand Down
18 changes: 18 additions & 0 deletions x/programs/examples/utils.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ import (
"github.com/ava-labs/avalanchego/database/memdb"
"github.com/ava-labs/hypersdk/crypto/ed25519"
"github.com/ava-labs/hypersdk/state"
"github.com/ava-labs/hypersdk/x/programs/runtime"
"github.com/near/borsh-go"
)

func newKey() (ed25519.PrivateKey, ed25519.PublicKey, error) {
Expand All @@ -21,6 +23,22 @@ func newKey() (ed25519.PrivateKey, ed25519.PublicKey, error) {
return priv, priv.PublicKey(), nil
}

// SerializeParameter serializes [obj] using Borsh
func serializeParameter(obj interface{}) ([]byte, error) {
bytes, err := borsh.Serialize(obj)
return bytes, err
}

// Serialize the parameter and create a smart ptr
func argumentToSmartPtr(obj interface{}, memory runtime.Memory) (runtime.SmartPtr, error) {
bytes, err := serializeParameter(obj)
if err != nil {
return 0, err
}

return runtime.BytesToSmartPtr(bytes, memory)
}

var (
_ state.Mutable = &testDB{}
_ state.Immutable = &testDB{}
Expand Down
47 changes: 47 additions & 0 deletions x/programs/runtime/memory.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,10 @@ type memory struct {
client WasmtimeExportClient
}

// SmartPtr is an int64 where the first 4 bytes represent the length of the bytes
// and the following 4 bytes represent a pointer to WASM memeory where the bytes are stored.
type SmartPtr int64

func NewMemory(client WasmtimeExportClient) *memory {
return &memory{
client: client,
Expand Down Expand Up @@ -164,3 +168,46 @@ func WriteParams(m Memory, p []CallParam) ([]int64, error) {

return params, nil
}

func (s SmartPtr) Get() int64 {
hexfusion marked this conversation as resolved.
Show resolved Hide resolved
return int64(s)
}

func (s SmartPtr) Len() uint32 {
return uint32(s >> 32)
}

func (s SmartPtr) PtrOffset() uint32 {
return uint32(s)
}

func (s SmartPtr) Bytes(memory Memory) ([]byte, error) {
// read the range of PtrOffset + length from memory
bytes, err := memory.Range(uint64(s.PtrOffset()), uint64(s.Len()))
if err != nil {
return nil, err
}

return bytes, nil
}

func BytesToSmartPtr(bytes []byte, memory Memory) (SmartPtr, error) {
hexfusion marked this conversation as resolved.
Show resolved Hide resolved
ptr, err := WriteBytes(memory, bytes)
if err != nil {
return 0, err
}

return NewSmartPtr(uint32(ptr), len(bytes))
}

func NewSmartPtr(ptr uint32, len int) (SmartPtr, error) {
// ensure length of bytes is not greater than int32 to prevent overflow
if !EnsureIntToInt32(len) {
return 0, fmt.Errorf("length of bytes is greater than int32")
}

lenUpperBits := int64(len) << 32
ptrLowerBits := int64(ptr)

return SmartPtr(lenUpperBits | ptrLowerBits), nil
}
Loading
Loading