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

Returned values from main are set to public (Successor) #731

Merged
merged 43 commits into from
Feb 3, 2023

Conversation

kevaundray
Copy link
Contributor

Related issue(s)

Resolves #455

Description

This is #634 however, the PR reverts back to commit #21c0b and merges the updated master into it.

This PR does not require a new release of ACVM/ACIR since we do not need to have public outputs . A different method was suggested where we could possibly avoid deduplication, however both methods require deduplication, so I have opted to revert back to this simpler change.

Summary of changes

See #634

  • Return values are no longer supplied by the prover, they are computed.
  • Setting the return value of the main function to be public boils down to adding witness indices into the public_inputs vector

Dependency additions / changes

Test additions / changes

Checklist

  • I have tested the changes locally.
  • I have formatted the changes with Prettier and/or cargo fmt with default settings.
  • I have linked this PR to the issue(s) that it resolves.
  • I have reviewed the changes on GitHub, line by line.
  • I have ensured all changes are covered in the description.

Additional context

- Add a SetPub Expression
- Instead of adding a constrain statement and adding a `return` parameter to main, we now specify that the return type should be set as public. This is then dealt with in the ssa pass.
- `get_or_generate_witness` is not named `generate_witness`
- This can be done as a separate PR. Removing it to make PR easier to review, an issue has been opened up for this
generate_witness will panic when trying to generate a witness for a constant
codegening an array and calling to_node_ids will produce a single node_id, whereas we want to fetch all elements of the array
- When a public input is return as a public output (return value), it is then added into the public input list twice.

Using the current code, we need this duplication since we want to write the return values into the toml files. For proving and verifying we want to remove these duplicate values
- The prover no longer supplies a `return` field in toml.
- The ABI will have a `return` field, so when proving, we use the `skip_output` flag to ignore the `return` field in the ABI
- As noted in the comments, this will look cleaner when we add a `public_outputs` field
…esponds to private input from the ABI (main parameters)
- Additionally, private ABI inputs are not allowed
- Only create the Return Operation if the return type from main is not Unit
Copy link
Contributor

@guipublic guipublic left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The return value in the prover.toml should not be removed, as this is not a fix for the issue and it removes a feature.

crates/nargo/src/cli/mod.rs Outdated Show resolved Hide resolved
crates/nargo/src/cli/mod.rs Outdated Show resolved Hide resolved
crates/nargo/src/cli/mod.rs Show resolved Hide resolved
crates/noirc_abi/src/lib.rs Show resolved Hide resolved
Copy link
Contributor

@jfecher jfecher left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Frontend parts look fine to me. I am fine with merging once the existing comments are resolved.

crates/nargo/src/cli/prove_cmd.rs Outdated Show resolved Hide resolved
@kevaundray kevaundray force-pushed the kw/revert-21c0b-fix-return-type branch from 07c2f1c to de7d81e Compare February 2, 2023 19:42
@kevaundray kevaundray force-pushed the kw/revert-21c0b-fix-return-type branch from de7d81e to ba2e28b Compare February 2, 2023 20:50
@kevaundray kevaundray requested a review from guipublic February 2, 2023 23:01
@kevaundray kevaundray merged commit 90b6036 into master Feb 3, 2023
@kevaundray kevaundray deleted the kw/revert-21c0b-fix-return-type branch February 3, 2023 11:35
TomAFrench added a commit to TomAFrench/noir that referenced this pull request Feb 3, 2023
* master:
  feat(noir)!:  Returned values are no longer required by the prover (noir-lang#731)
TomAFrench added a commit that referenced this pull request Feb 3, 2023
* master:
  Rename methods that use `conditionalize` to be more descriptive (#739)
  feat(noir)!:  Returned values are no longer required by the prover (#731)
  chore: explicit versions for dependencies (#727)
  chore: readability improvements (#726)
  feat(nargo): include short git commit in cli version output (#721)
  Remove print to console for named proofs in `nargo prove` (#718)
  chore: clean up serde-related dependencies (#722)
  Handle out-of-bound errors in CSE (#471) (#673)
  Remove unused dependencies and only use workspace inheritance on shared deps (#671)
  feat(std_lib)!: modulus bits/bytes methods, and to_bits -> to_le_bits (#697)
  Implement numeric generics (#620)
  Review some TODO in SSA (#698)
  Replace `toml_map_to_field` and `toml_remap` with traits to map between `InputValue`s and `TomlTypes` (#677)
  Apply witness visibility on a parameter level rather than witness level (#712)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Auto return doesn't work with arrays
4 participants