|
This article is cited in 2 scientific papers (total in 2 papers)
Static verification of operating system monolithic kernels
E. M. Novikov Institute for System Programming of the Russian Academy of Sciences
Abstract:
The most of modern widely used operating systems have monolithic kernels since this architecture aims at reaching maximum performance. Usually monolithic kernels without various extensions like device drivers consist of several million lines of code in the programming language C/C++ and in the assembly language. With time, their source code evolves quite intensively: a new functionality is supported, various operations are optimized, bugs are fixed. The high practical value of operating system monolithic kernels defines strict requirements for their functionality, security, reliability and performance. Approaches for software quality assurance which are currently used in practice help to identify and to fix quite a number of bugs, but none of them allows to detect all possible bugs of kinds sought for. This article shows that different approaches to static verification, which are aimed at solving this task, have significant restrictions if applied to monolithic kernels as a whole, primarily due to a large size and complexity of source code that is constantly evolving. As a first step towards static verification of operating system monolithic kernels a method is proposed for decomposition of kernels into subsystems.
Keywords:
operating system, monolithic kernel, microkernel, software quality, static verification, formal specification, program decomposition.
Citation:
E. M. Novikov, “Static verification of operating system monolithic kernels”, Proceedings of ISP RAS, 29:2 (2017), 97–116
Linking options:
https://www.mathnet.ru/eng/tisp212 https://www.mathnet.ru/eng/tisp/v29/i2/p97
|
Statistics & downloads: |
Abstract page: | 228 | Full-text PDF : | 86 | References: | 38 |
|