Remote specialization for efficient embedded operating systems

被引:4
|
作者
Bhatia, Sapan [1 ]
Consel, Charles
Pu, Calton [2 ]
机构
[1] Princeton Univ, Princeton, NJ 08544 USA
[2] Georgia Inst Technol, Atlanta, GA 30332 USA
关键词
performance; design; experimentation; remote specialization; specialization server; compilers; performance analysis;
D O I
10.1145/1377492.1377497
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Prior to their deployment on an embedded system, operating systems are commonly tailored to reduce code size and improve runtime performance. Program specialization is a promising match for this process: it is predictable and modules, and it allows the reuse of previously implemented specializations. A specialization engine for embedded systems must overcome three main obstacles: (i) Reusing existing compilers for embedded systems, (ii) supporting specialization on a resource-limited system and (iii) coping with dynamic applications by supporting specialization on demand. In this article, we describe a runtime specialization infrastructure that addresses these problems. Our solution proposes: ( i) Specialization in two phases of which the former generates specialized C templates and the latter uses a dedicated compiler to generate efficient native code. ( ii) A virtualization mechanism that facilitates specialization of code at a remote location. ( iii) An API and supporting OS extensions that allow applications to produce, manage and dispose of specialized code. We evaluate our work through two case studies: ( i) The TCP/IP implementation of Linux and ( ii) The TUX embedded web server. We report appreciable improvements in code size and performance. We also quantify the overhead of specialization and argue that a specialization server can scale to support a sizable workload.
引用
收藏
页数:32
相关论文
共 50 条
  • [41] Embedded operating systems face greater productivity demands
    Werner, L
    [J]. ELECTRONIC DESIGN, 1998, 46 (22) : 51 - +
  • [42] Transparent management of reconfigurable hardware in embedded operating systems
    Kosciuszkiewicz, Krzysztof
    Morgan, Fearghal
    Kepa, Krzysztof
    [J]. IEEE COMPUTER SOCIETY ANNUAL SYMPOSIUM ON VLSI, PROCEEDINGS: EMERGING VLSI TECHNOLOGIES AND ARCHITECTURES, 2006, : 432 - +
  • [43] Embedded operating systems take on tools, languages, and modules
    Williams, T
    [J]. ELECTRONIC DESIGN, 1998, 46 (02) : 67 - +
  • [44] Cloud Platforms and Embedded Computing - The Operating Systems of the Future
    Rellermeyer, Jan S.
    Lee, Seong-Won
    Kistler, Michael
    [J]. 2013 50TH ACM / EDAC / IEEE DESIGN AUTOMATION CONFERENCE (DAC), 2013,
  • [45] Compiler-Injected SIHFT for Embedded Operating Systems
    Baroffio, Davide
    Reghenzani, Federico
    [J]. PROCEEDINGS OF THE 20TH ACM INTERNATIONAL CONFERENCE ON COMPUTING FRONTIERS 2023, CF 2023, 2023, : 337 - 343
  • [46] Real-time operating systems for embedded computing
    Li, YB
    Potkonjak, M
    Wolf, W
    [J]. INTERNATIONAL CONFERENCE ON COMPUTER DESIGN - VLSI IN COMPUTERS AND PROCESSORS, PROCEEDINGS, 1997, : 388 - 392
  • [47] An Experimental Laboratory Environment for Teaching Embedded Operating Systems
    Brylow, Dennis
    [J]. SIGCSE'08: PROCEEDINGS OF THE 39TH ACM TECHNICAL SYMPOSIUM ON COMPUTER SCIENCE EDUCATION, 2008, : 192 - 196
  • [48] A HAL for component-based embedded operating systems
    Teng, QM
    Wang, H
    Chen, XQ
    [J]. PROCEEDINGS OF THE 29TH ANNUAL INTERNATIONAL COMPUTER SOFTWARE AND APPLICATIONS CONFERENCE, WORKSHOPS AND FAST ABSTRACTS, 2005, : 23 - 24
  • [49] Operating system support for procedural abstraction in embedded systems
    Yim, Keun Soo
    Yoo, Jeong-Joon
    Lee, Jae Don
    Kim, Jihong
    [J]. 12TH IEEE INTERNATIONAL CONFERENCE ON EMBEDDED AND REAL-TIME COMPUTING SYSTEMS AND APPLICATIONS, PROCEEDINGS, 2006, : 378 - +
  • [50] Formal verification of a task scheduler for embedded operating systems
    Sun, Haiyong
    Lei, Hang
    [J]. JOURNAL OF INTELLIGENT & FUZZY SYSTEMS, 2020, 38 (02) : 1391 - 1399