Do İfdefs Influence the Occurrence of Vulnerabilities? An Empirical Study of the Linux Kernel
Title | Do İfdefs Influence the Occurrence of Vulnerabilities? An Empirical Study of the Linux Kernel |
Publication Type | Conference Paper |
Year of Publication | 2016 |
Authors | Ferreira, Gabriel, Malik, Momin, Kästner, Christian, Pfeffer, Jürgen, Apel, Sven |
Conference Name | Proceedings of the 20th International Systems and Software Product Line Conference |
Publisher | ACM |
Conference Location | New York, NY, USA |
ISBN Number | 978-1-4503-4050-2 |
Keywords | composability |
Abstract | Preprocessors support the diversification of software products with \#ifdefs, but also require additional effort from developers to maintain and understand variable code. We conjecture that \#ifdefs cause developers to produce more vulnerable code because they are required to reason about multiple features simultaneously and maintain complex mental models of dependencies of configurable code. We extracted a variational call graph across all configurations of the Linux kernel, and used configuration complexity metrics to compare vulnerable and non-vulnerable functions considering their vulnerability history. Our goal was to learn about whether we can observe a measurable influence of configuration complexity on the occurrence of vulnerabilities. Our results suggest, among others, that vulnerable functions have higher variability than non-vulnerable ones and are also constrained by fewer configuration options. This suggests that developers are inclined to notice functions appear in frequently-compiled product variants. We aim to raise developers' awareness to address variability more systematically, since configuration complexity is an important, but often ignored aspect of software product lines. |
URL | http://doi.acm.org/10.1145/2934466.2934467 |
DOI | 10.1145/2934466.2934467 |
Citation Key | ferreira_ifdefs_2016 |