Affiliation:
1. University of Central Florida, Orlando, USA
2. University of Texas, Austin, USA
3. Inria, Paris, France
Abstract
The Linux kernel is highly-configurable, with a build system that takes a configuration file as input and automatically tailors the source code accordingly. Configurability, however, complicates testing, because different configuration options lead to the inclusion of different code fragments. With thousands of patches received per month, Linux kernel maintainers employ extensive automated continuous integration testing. To attempt patch coverage, i.e., taking all changed lines into account, current approaches either use configuration files that maximize total statement coverage or use multiple randomly-generated configuration files, both of which incur high build times without guaranteeing patch coverage. To achieve patch coverage without exploding build times, we propose krepair, which automatically repairs configuration files that are fast-building but have poor patch coverage to achieve high patch coverage with little effect on build times. krepair works by discovering a small set of changes to a configuration file that will ensure patch coverage, preserving most of the original configuration file's settings. Our evaluation shows that, when applied to configuration files with poor patch coverage on a statistically-significant sample of recent Linux kernel patches, krepair achieves nearly complete patch coverage, 98.5% on average, while changing less than 1.53% of the original default configuration file in 99% of patches, which keeps build times 10.5x faster than maximal configuration files.
Funder
National Science Foundation
Publisher
Association for Computing Machinery (ACM)
Reference80 articles.
1. 2018. Busybox website. https://busybox.net/.
2. 2020. syzkaller commit 67fa1f59b87f “executor: add support for USB fuzzing on NetBSD”. https://github.com/google/syzkaller/commit/67fa1f59b87fed7268b465f7e9540a590a250c65, Last accessed May 4, 2022.
3. 2020. syzkaller commit 80a0690249dc “dashboard/config: regenerate all configs”. https://github.com/google/syzkaller/commit/80a0690249dc4dbbbed95ba197192b99c73694c5, Last accessed May 4, 2022.
4. 2021. Mainline Linux Git Repository. https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git.
5. 2021. whatthepatch. https://pypi.org/project/whatthepatch/.