-
Notifications
You must be signed in to change notification settings - Fork 9
Optimize check owned by removing json and fix double rkyv serialization bug #115
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Overall looks good, but there are few nits to change, one very important tied to performance and scalar multiplication.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Still few things to change, but we're on the right track. Be sure to do not derive the keys inside any loops, but doing so upfront. If we notice this as common pattern, (the need of sk
and vk
together), we might also have an inline function that does that for us, so we don't have to repeat it.
tests/wallet.rs
Outdated
@@ -336,7 +336,7 @@ mod node { | |||
.into_iter() | |||
.map(|value| { | |||
let obfuscated = (rng.next_u32() & 1) == 1; | |||
let idx = rng.next_u64() % MAX_KEY as u64; | |||
let idx = rng.next_u64() % (MAX_KEY) as u64; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You don't need to wrap the MAX_KEY
in parentheses, the previous code would works fine.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There is the part related to the loops and labels usage (see the comment). Once it's fixed I will approve immediately (that loop and others like that).
I would suggest to fix it in this PR to avoid open a separate issue, but if you're more comfortable to file a new issue and fix it there immediately please file the issue and add its link as reply to the conversation in this review concerning the matter; I'm also fine with that as soon as it's fixed ASAP.
src/ffi.rs
Outdated
let sks: [SecretKey; MAX_KEY] = | ||
core::array::from_fn(|i| key::derive_sk(&seed, i as _)); | ||
let vks: [ViewKey; MAX_KEY] = | ||
core::array::from_fn(|i| key::derive_vk(&seed, i as _)); | ||
|
||
'outer: for note in notes { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You still didn't modify this loop as discussed.
- The comment is wrong, or best case scenario misleading
- The usage of labels makes the flow harder to follow from top to bottom – it's "GOTO-like" –; therefore the labels should be used only when there is not any decent alternative available
- Due to the label usage, the code makes use of a temp var called
keys_len
that shouldn't be there.
All those should be fixed, if you don't want to do it in this PR feel free to open immediately a new one – but also an issue related to that – to apply those changes. I suggested to do it in this PR since you're already touching this code and in addition you can skip to create a separate issue. But if you prefer to file a new issue and fix it immediately in a new PR, it's also fine.
My suggestion, as I already mentioned to you, would be modify this using a more functional approach with try_fold
. Here is the code:
let nullifiers = notes.iter().try_fold(
Vec::with_capacity(notes.len()),
|mut nullifiers, note| {
if let Some(idx) = (0..MAX_KEY).find(|&i| vks[i].owns(note)) {
let nullifier = note.gen_nullifier(&sks[idx]);
nullifiers.push(nullifier);
Ok(nullifiers)
} else {
Err(())
}
},
);
match nullifiers {
Ok(n) => utils::rkyv_into_ptr(n),
Err(_) => utils::fail(),
}
Basically, if you cannot decrypt a note with any of the keys you own, than the function calls utils::fail
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I removed the comment and the label, I think any greater refractor than that would be counter productive since the "big" refractor is imminent, I have already created the EPIC for refractor I'll add this content to it
#117
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, just few minor nits before merging. See the comments, but to summarize:
- rename
vk_idx
intoidx
- remove the unused
core::mem
as stated by github too. - remove the sorrounding parentheses from
MAX_KEY
from tests.
src/ffi.rs
Outdated
} | ||
} | ||
for note in notes { | ||
let Some(vk_idx) = vks.iter().position(|vk| vk.owns(¬e)) else { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I forgot about position
, this is much better. Just call it idx
or i
.
Closes #113 and #114
This is the wasm binary that is in the latest dusk-wallet-js version, we should merge into main ASAP