Mitigating False Positives in Static Memory Safety Analysis of Rust Programs via Reinforcement Learning

๐Ÿ“… 2026-05-05
๐Ÿ“ˆ Citations: 0
โœจ Influential: 0
๐Ÿ“„ PDF

career value

212K/year
๐Ÿค– AI Summary
This study addresses the high false positive rate of static analysis tools in Rust memory safety detection, which undermines developer trust and increases manual review costs. The authors propose a novel approach that integrates reinforcement learning with hybrid dynamicโ€“static analysis to filter false alarms by leveraging contextual features from Rustโ€™s Mid-level Intermediate Representation (MIR). Reinforcement learning is employed to automatically classify and suppress spurious warnings, while feedback from cargo-fuzz dynamic fuzzing refines the decision-making process. Experimental results demonstrate that the method achieves an accuracy of 65.2% and an F1 score of 0.659, outperforming the best large language model (LLM) baseline by 17.1%. Notably, precision improves substantially from 25.6% to 59.0%, with a recall of 74.6%, significantly enhancing both the accuracy and practical utility of memory safety verification in Rust.
๐Ÿ“ Abstract
Static analysis tools are essential for ensuring memory safety in Rust programs, particularly as Rust gains adoption in safety-critical domains. However, existing tools such as Rudra and MirChecker suffer from high false positive rates, which diminish developer trust, increase manual review effort, and may obscure genuine vulnerabilities. This paper presents a novel reinforcement learning (RL)-based approach for automatically classifying and suppressing spurious warnings in static memory safety analysis for Rust. To achieve this, we design an RL agent that learns a warning suppression policy by extracting contextual features from Rust's Mid-level Intermediate Representation (MIR) and optimizing its decisions through interaction with static analysis outputs. To improve decision quality, we integrate dynamic validation via cargo-fuzz as an auxiliary feedback mechanism, allowing the agent to selectively validate suspicious warnings through targeted fuzz testing. Our evaluation shows that the proposed approach significantly outperforms state-of-the-art LLM-based baselines, achieving 65.2% accuracy and an F1 score of 0.659, an improvement of 17.1% over the best LLM baseline. With a recall of 74.6%, our method successfully identifies nearly three-quarters of true bugs while substantially reducing false positives, improving precision from 25.6% in raw Rudra output to 59.0%. Incorporating dynamic fuzzing further boosts performance, yielding additional improvements of 10.7 percentage points in accuracy and 8.6 percentage points in F1 score over the RL-only variant. Overall, our work demonstrates that combining reinforcement learning with hybrid static-dynamic analysis can substantially reduce false positives and improve the practical usability of memory safety verification tools for Rust.
Problem

Research questions and friction points this paper is trying to address.

false positives
static analysis
memory safety
Rust
warning suppression
Innovation

Methods, ideas, or system contributions that make the work stand out.

reinforcement learning
false positive reduction
static-dynamic analysis
Rust MIR
fuzz testing
๐Ÿ”Ž Similar Papers
No similar papers found.