TY - GEN
T1 - AutoPA
T2 - 16th International Symposium on Code Generation and Optimization, CGO 2018
AU - Bai, Jia Ju
AU - Wang, Yu Ping
AU - Hu, Shi Min
N1 - Publisher Copyright:
© 2018 Association for Computing Machinery.
PY - 2018/2/24
Y1 - 2018/2/24
N2 - Original device drivers are often passive in common operating systems, and they should correctly handle synchronization when concurrently invoked by multiple external threads. However, many concurrency bugs have occurred in drivers due to incautious synchronization. To solve concurrency problems, active driver is proposed to replace original passive driver. An active driver has its own thread and does not need to handle synchronization, thus the occurrence probability of many concurrency bugs can be effectively reduced. But previous approaches of active driver have some limitations. The biggest limitation is that original passive driver code needs to be manually rewritten. In this paper, we propose a practical approach, AutoPA, to automatically generate efficient active driver from original passive driver code. AutoPA uses function analysis and code instrumentation to perform automated driver generation, and it uses an improved active driver architecture to reduce performance degradation. We have evaluated AutoPA on 20 Linux drivers. The results show that AutoPA can automatically and successfully generate usable active drivers from original driver code. And generated active drivers can work normally with or without the synchronization primitives in original driver code. To check the effect of AutoPA on driver reliability, we perform fault injection testing on the generated active drivers, and find that all injected concurrency faults are well tolerated and the drivers can work normally. And the performance of generated active drivers is not obviously degraded compared to original passive drivers.
AB - Original device drivers are often passive in common operating systems, and they should correctly handle synchronization when concurrently invoked by multiple external threads. However, many concurrency bugs have occurred in drivers due to incautious synchronization. To solve concurrency problems, active driver is proposed to replace original passive driver. An active driver has its own thread and does not need to handle synchronization, thus the occurrence probability of many concurrency bugs can be effectively reduced. But previous approaches of active driver have some limitations. The biggest limitation is that original passive driver code needs to be manually rewritten. In this paper, we propose a practical approach, AutoPA, to automatically generate efficient active driver from original passive driver code. AutoPA uses function analysis and code instrumentation to perform automated driver generation, and it uses an improved active driver architecture to reduce performance degradation. We have evaluated AutoPA on 20 Linux drivers. The results show that AutoPA can automatically and successfully generate usable active drivers from original driver code. And generated active drivers can work normally with or without the synchronization primitives in original driver code. To check the effect of AutoPA on driver reliability, we perform fault injection testing on the generated active drivers, and find that all injected concurrency faults are well tolerated and the drivers can work normally. And the performance of generated active drivers is not obviously degraded compared to original passive drivers.
KW - Automation
KW - Code instrumentation
KW - Concurrency reliability
KW - Device driver
KW - Program transformation
UR - http://www.scopus.com/inward/record.url?scp=85052762140&partnerID=8YFLogxK
U2 - 10.1145/3168809
DO - 10.1145/3168809
M3 - Conference contribution
AN - SCOPUS:85052762140
T3 - CGO 2018 - Proceedings of the 2018 International Symposium on Code Generation and Optimization
SP - 288
EP - 299
BT - CGO 2018 - Proceedings of the 2018 International Symposium on Code Generation and Optimization
PB - Association for Computing Machinery, Inc
Y2 - 24 February 2018 through 28 February 2018
ER -