-
Notifications
You must be signed in to change notification settings - Fork 13
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
[RFC] Formal model written in cat and tool support for simulation #32
Comments
The possibility to find liveness bugs is probably the main advantage of what we propose wrt to alloy model. Let me give some details about this. While one may think that axiomatic memory models (based on finite executions) cannot be used to define liveness properties, this is wrong. The theory that allows to do this is explained in this paper. The overall idea is as follows: if there is a load coming from a spinloop which reads from a coherence-last write and the read value does not break the spinning, a liveness violation has been found. The XF-Barrier (an inter-workgroup execution barrier) mentioned above can deadlock if there is no proper synchronization.
Below we can see an execution leading to a liveness violation. Event The issue is not just a deadlock, but also that the execution has a data race. Both problems can be solved by making some of the memory accesses atomic.
|
Together with @hernanponcedeleon, we wrote the vulkan model in the cat language (a standard language to formalize memory models), ported all the tests in this repository to a more standardized format, and added tool support for simulation/verification.
We believe the tool would be valuable for the community and we wanted to get feedback if it would make sense to have the model and the tests in this repository.
The new tool has the following advantages
goto
instructions which allow to write more realistic examples e.g. the XF-barrier.The text was updated successfully, but these errors were encountered: