|国家预印本平台
首页|Prime Path Coverage in the GNU Compiler Collection

Prime Path Coverage in the GNU Compiler Collection

Prime Path Coverage in the GNU Compiler Collection

来源:Arxiv_logoArxiv
英文摘要

We describe the implementation of the prime path coverage support introduced the GNU Compiler Collection 15, a structural coverage metric that focuses on paths of execution through the program. Prime path coverage strikes a good balance between the number of tests and coverage, and requires that loops are taken, taken more than once, and skipped. We show that prime path coverage subsumes modified condition/decision coverage (MC/DC). We improve on the current state-of-the-art algorithms for enumerating prime paths by using a suffix tree for efficient pruning of duplicated and redundant subpaths, reducing it to $O(n^2m)$ from $O(n^2m^2)$, where $n$ is the length of the longest path and $m$ is the number of candidate paths. We can efficiently track candidate paths using a few bitwise operations based on a compact representation of the indices of the ordered prime paths. By analyzing the control flow graph, GCC can observe and instrument paths in a language-agnostic manner, and accurately report what code must be run in what order to achieve coverage.

J?rgen Kvalsvik

计算技术、计算机技术

J?rgen Kvalsvik.Prime Path Coverage in the GNU Compiler Collection[EB/OL].(2025-04-25)[2025-07-17].https://arxiv.org/abs/2505.14694.点此复制

评论