-
Notifications
You must be signed in to change notification settings - Fork 234
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
FStar.Reflection.Typing.subst_term
extracts to dangerous code
#3504
Comments
I suppose the first problem here is that I was also thinking the typing judgments in Reflection.Typing could be made ghost. We mostly used them under an For assuming the equality, I think we do something exactly that in Pulse (Pulse.Syntax.Naming.subst_host_term). Ideally we would avoid it altogether with the previous bullet? |
My thinking was that forcing Reflection.Typing.typing to be erased could preclude some applications, whereas defining it as concrete still allows applications to work with That said, making it erased from the get go would make most applications simpler, rather than forcing them to pay the cost of working with erased types & coercions, for hypothetical applications that might need a concrete derivation. (May a not so hypothetical application is bootstrapping a certifier, as in this self-certification paper https://dl.acm.org/doi/10.1145/2103621.2103723 which involved generating a concrete typing derivation and exporting it to Coq to be re-checked there.) With Pulse typing, the reason it's not erased is as Guido says: to support extraction from derivations. But, we don't do that anymore. |
Okay, I tried to make the typings and the associated functions ghost. But to my suprise, there were plenty more functions with a questionable implementation based on the tactic/reflection API ("questionable" in the sense that they give different and incorrect results compared to the built-in versions):
Should we redefine all of them in terms of their built-in versions?
Is there a reason we can't just reflect the full syntax? Providing partial views will always result in information loss in corner cases like this. FWIW, returning Tv_Unsupp doesn't fix the general issue at all:
There we are converting between the reflection substitution type and the regular one. Could we consolidate on a single substitution type?
That's an interesting paper! Obviously that kind of approach only becomes interesting once the F* type checker uses reflection typings, so this is probably really far away from becoming a concern. |
The reflection API only exposes a portion of the syntax AST. Since
FStar.Reflection.Typing.subst_term
is written as a syntax traversal using this limited API, it will silently drop various flags when used as executable code. It should also used delayed substitions, obviously.I ran into this the other day in FStarLang/pulse#209. This
subst_term
function silently dropped the effect flag in the let, breaking extraction.This implementation of substitution should clearly not be executable, whether from extracted code or tactics. Some ideas:
equiv_arrow
references it, and the reflected typing judgements are not erased. Is it intentional thattyping
and co. are not erased?FStar.Stubs.Reflection.V2.Builtins.subst_term
function instead and assume the equalities as axioms.@mtzguido Any thoughts?
The text was updated successfully, but these errors were encountered: