- 
                Notifications
    You must be signed in to change notification settings 
- Fork 13.9k
Check that a query has not completed and is not executing before starting it #108845
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
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.
IIUC, the race happens because we remove executed queries from the execution state when they complete. Could you add a comment explaining how the race happens?
Should we just avoid removing the executed queries from the execution state?
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.
This check should happen in JobOwner::try_start which should return a JobCompleted.
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.
try_start isn't generic over query values, presumably for compile time reasons. Also JobCompleted is currently used as "job completed after blocking". It might make sense to refactor try_execute_query and try_start, but I'll wait for some PRs to merge before trying that.
| I added a more extended explanation. 
 That sounds like an expensive way to avoid this check. It is very likely hot in cache for the common  | 
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.
The session is already accessible, no need for an extra method.
| if cfg!(parallel_compiler) && qcx.is_sync() { | |
| if cfg!(parallel_compiler) && qcx.dep_context().sess().threads() > 1 { | 
r=me with the is_sync method removed.
| ☔ The latest upstream changes (presumably #108167) made this pull request unmergeable. Please resolve the merge conflicts. | 
| @bors r+ rollup=iffy | 
| ☀️ Test successful - checks-actions | 
| Finished benchmarking commit (938afba): comparison URL. Overall result: no relevant changes - no action needed@rustbot label: -perf-regression Instruction countThis benchmark run did not return any relevant results for this metric. Max RSS (memory usage)ResultsThis is a less reliable metric that may be of interest but was not used to determine the overall result at the top of this comment. 
 CyclesThis benchmark run did not return any relevant results for this metric. | 
This fixes a race in the query system where we only checked if the query was currently executing, but not if it was already completed, causing queries to re-execute.
r? @cjgillot