-
Notifications
You must be signed in to change notification settings - Fork 98
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
Remove --function
option
#2129
Comments
We could also just search the symtab files directly, it might be simpler that way. |
Do we mean parse the symtab file or invoke some goto utility to print the functions available? |
The former for now, and hopefully if we're able to directly generate goto binaries that will also come later with the ability to open and parse those |
I am leaning towards adding information to the Metadata because is more reliable and it will work well even with mangled names. Since this will only be done for the target crate, the cost shouldn't be too high. |
Kani compiler used to generate one `goto-program` for all harnesses in one crate. In some cases, this actually had a negative impact on the harness verification time. This was first reported in #1659 The main changes were done in the compiler's module `compiler_interface` and the module `project` from the driver. The compiler will now gather all the harnesses beforehand and it will perform reachability + codegen steps for each harness. All files related to a harness `goto-program` will follow the naming convention bellow: ``` <BASE_NAME>_<MANGLED_NAME>.<EXTENSION> ``` This applies to symtab / goto / type_map / restriction files. The metadata file is still generated once per target crate, and its name is still the same (`<BASE_NAME>.kani-metadata.json`). On the driver side, the way we process the artifacts have changed. The driver will now read the metadata for each crate, and collect all artifacts based on the symtab goto file that is recorded in the metadata of each harness. These changes do not apply for `--function`. We still keep all artifacts based on the crate's `<BASE_NAME>` and we have a separate logic to handle that. Fixing this is captured by #2129.
We no longer have a use for this flag. We used to keep it for the book runner, but we no longer use that. Users should use harnesses instead. |
This is a legacy argument that we have very limited support to. We kept it around for bookrunner tests, which has been removed already. Resolves #2129
Proposed change: We should include information about the public functions as part of the KaniMetadata when the reachability mode is
pub_fns
. We should stop merging all the metadata and goto binaries together.Motivation: We have a special handling for
--function
today insidekani-driver
because we cannot tell which artifacts are relevant to some function. So we just merge everything. If we treat functions as potential harnesses, we can get rid of the hack described above. We should also restrict the metadata to include functions that don't take any parameter.The text was updated successfully, but these errors were encountered: