Team up: Cooperative memory management in embedded systems

Publikation: Beitrag in Buch/Bericht/Sammelwerk/KonferenzbandAufsatz in KonferenzbandForschungPeer-Review

Autorschaft

  • Isabella Stilkerich
  • Philip Taffner
  • Christoph Erhardt
  • Christian Dietrich
  • Christian Wawersich
  • Michael Stilkerich

Externe Organisationen

  • Friedrich-Alexander-Universität Erlangen-Nürnberg (FAU Erlangen-Nürnberg)
Forschungs-netzwerk anzeigen

Details

OriginalspracheEnglisch
Titel des SammelwerksCASES '14: Proceedings of the 2014 International Conference on Compilers, Architecture and Synthesis for Embedded Systems
ISBN (elektronisch)9781450330503
PublikationsstatusVeröffentlicht - Okt. 2014
Extern publiziertJa
Veranstaltung2014 International Conference on Compilers, Architecture and Synthesis for Embedded Systems, CASES 2014 - New Delhi, Indien
Dauer: 12 Okt. 201417 Okt. 2014

Abstract

The use of a managed, type-safe languages such as Java in realtime and embedded systems can offer productivity and, in particular, safety and dependability benefits over the dominating unsafe languages at reasonable costs. A JVM that has dynamic memory-management needs to provide an implicit memory-management strategy, that is, for example, a garbage collector (GC) or stack allocation provided by the escape analysis of the JVM's compiler: Explicit management of dynamically allocated memory (i.e., by use of functions such as C's malloc() and free()) is vulnerable to programming errors such as neglected or false memory release operations causing memory leaks or dangling pointers. Such operations have the potential to break the soundness of the type system and are therefore usually not available for strongly typed languages. Type-safe languages in combination with static analyses - which respect hardware as well as system-specific information - can efficiently be employed to provide a runtime system including memory management (MM) that is specifically suited to an embedded application on a particular hardware device. In the context of this paper, we present novel memory-management strategy we implemented in our KESO JVM. It is a latency-aware garbage-collection algorithm called LAGC. Also, we introduce the static analyses that can assist LAGC. The application developers have to ensure that there is enough time for the GCs to run. Hardware characteristics such as soft-error proneness of the hardware or the memory layout can also be taken into consideration as demanded by the system configuration. This is achieved by integrating the GCs in the design process of the whole system just as any other user application, which is the reason why this approach is called cooperative memory management. The suggested strategies require reasonably low overhead.

ASJC Scopus Sachgebiete

Zitieren

Team up: Cooperative memory management in embedded systems. / Stilkerich, Isabella; Taffner, Philip; Erhardt, Christoph et al.
CASES '14: Proceedings of the 2014 International Conference on Compilers, Architecture and Synthesis for Embedded Systems. 2014.

Publikation: Beitrag in Buch/Bericht/Sammelwerk/KonferenzbandAufsatz in KonferenzbandForschungPeer-Review

Stilkerich, I, Taffner, P, Erhardt, C, Dietrich, C, Wawersich, C & Stilkerich, M 2014, Team up: Cooperative memory management in embedded systems. in CASES '14: Proceedings of the 2014 International Conference on Compilers, Architecture and Synthesis for Embedded Systems. 2014 International Conference on Compilers, Architecture and Synthesis for Embedded Systems, CASES 2014, New Delhi, Indien, 12 Okt. 2014. https://doi.org/10.1145/2656106.2656129
Stilkerich, I., Taffner, P., Erhardt, C., Dietrich, C., Wawersich, C., & Stilkerich, M. (2014). Team up: Cooperative memory management in embedded systems. In CASES '14: Proceedings of the 2014 International Conference on Compilers, Architecture and Synthesis for Embedded Systems https://doi.org/10.1145/2656106.2656129
Stilkerich I, Taffner P, Erhardt C, Dietrich C, Wawersich C, Stilkerich M. Team up: Cooperative memory management in embedded systems. in CASES '14: Proceedings of the 2014 International Conference on Compilers, Architecture and Synthesis for Embedded Systems. 2014 doi: 10.1145/2656106.2656129
Stilkerich, Isabella ; Taffner, Philip ; Erhardt, Christoph et al. / Team up: Cooperative memory management in embedded systems. CASES '14: Proceedings of the 2014 International Conference on Compilers, Architecture and Synthesis for Embedded Systems. 2014.
Download
@inproceedings{4da8965a19054019bdb7e83df19add8d,
title = "Team up: Cooperative memory management in embedded systems",
abstract = "The use of a managed, type-safe languages such as Java in realtime and embedded systems can offer productivity and, in particular, safety and dependability benefits over the dominating unsafe languages at reasonable costs. A JVM that has dynamic memory-management needs to provide an implicit memory-management strategy, that is, for example, a garbage collector (GC) or stack allocation provided by the escape analysis of the JVM's compiler: Explicit management of dynamically allocated memory (i.e., by use of functions such as C's malloc() and free()) is vulnerable to programming errors such as neglected or false memory release operations causing memory leaks or dangling pointers. Such operations have the potential to break the soundness of the type system and are therefore usually not available for strongly typed languages. Type-safe languages in combination with static analyses - which respect hardware as well as system-specific information - can efficiently be employed to provide a runtime system including memory management (MM) that is specifically suited to an embedded application on a particular hardware device. In the context of this paper, we present novel memory-management strategy we implemented in our KESO JVM. It is a latency-aware garbage-collection algorithm called LAGC. Also, we introduce the static analyses that can assist LAGC. The application developers have to ensure that there is enough time for the GCs to run. Hardware characteristics such as soft-error proneness of the hardware or the memory layout can also be taken into consideration as demanded by the system configuration. This is achieved by integrating the GCs in the design process of the whole system just as any other user application, which is the reason why this approach is called cooperative memory management. The suggested strategies require reasonably low overhead.",
keywords = "Design, Garbage collection, Languages, Memory management",
author = "Isabella Stilkerich and Philip Taffner and Christoph Erhardt and Christian Dietrich and Christian Wawersich and Michael Stilkerich",
year = "2014",
month = oct,
doi = "10.1145/2656106.2656129",
language = "English",
booktitle = "CASES '14: Proceedings of the 2014 International Conference on Compilers, Architecture and Synthesis for Embedded Systems",
note = "2014 International Conference on Compilers, Architecture and Synthesis for Embedded Systems, CASES 2014 ; Conference date: 12-10-2014 Through 17-10-2014",

}

Download

TY - GEN

T1 - Team up: Cooperative memory management in embedded systems

AU - Stilkerich, Isabella

AU - Taffner, Philip

AU - Erhardt, Christoph

AU - Dietrich, Christian

AU - Wawersich, Christian

AU - Stilkerich, Michael

PY - 2014/10

Y1 - 2014/10

N2 - The use of a managed, type-safe languages such as Java in realtime and embedded systems can offer productivity and, in particular, safety and dependability benefits over the dominating unsafe languages at reasonable costs. A JVM that has dynamic memory-management needs to provide an implicit memory-management strategy, that is, for example, a garbage collector (GC) or stack allocation provided by the escape analysis of the JVM's compiler: Explicit management of dynamically allocated memory (i.e., by use of functions such as C's malloc() and free()) is vulnerable to programming errors such as neglected or false memory release operations causing memory leaks or dangling pointers. Such operations have the potential to break the soundness of the type system and are therefore usually not available for strongly typed languages. Type-safe languages in combination with static analyses - which respect hardware as well as system-specific information - can efficiently be employed to provide a runtime system including memory management (MM) that is specifically suited to an embedded application on a particular hardware device. In the context of this paper, we present novel memory-management strategy we implemented in our KESO JVM. It is a latency-aware garbage-collection algorithm called LAGC. Also, we introduce the static analyses that can assist LAGC. The application developers have to ensure that there is enough time for the GCs to run. Hardware characteristics such as soft-error proneness of the hardware or the memory layout can also be taken into consideration as demanded by the system configuration. This is achieved by integrating the GCs in the design process of the whole system just as any other user application, which is the reason why this approach is called cooperative memory management. The suggested strategies require reasonably low overhead.

AB - The use of a managed, type-safe languages such as Java in realtime and embedded systems can offer productivity and, in particular, safety and dependability benefits over the dominating unsafe languages at reasonable costs. A JVM that has dynamic memory-management needs to provide an implicit memory-management strategy, that is, for example, a garbage collector (GC) or stack allocation provided by the escape analysis of the JVM's compiler: Explicit management of dynamically allocated memory (i.e., by use of functions such as C's malloc() and free()) is vulnerable to programming errors such as neglected or false memory release operations causing memory leaks or dangling pointers. Such operations have the potential to break the soundness of the type system and are therefore usually not available for strongly typed languages. Type-safe languages in combination with static analyses - which respect hardware as well as system-specific information - can efficiently be employed to provide a runtime system including memory management (MM) that is specifically suited to an embedded application on a particular hardware device. In the context of this paper, we present novel memory-management strategy we implemented in our KESO JVM. It is a latency-aware garbage-collection algorithm called LAGC. Also, we introduce the static analyses that can assist LAGC. The application developers have to ensure that there is enough time for the GCs to run. Hardware characteristics such as soft-error proneness of the hardware or the memory layout can also be taken into consideration as demanded by the system configuration. This is achieved by integrating the GCs in the design process of the whole system just as any other user application, which is the reason why this approach is called cooperative memory management. The suggested strategies require reasonably low overhead.

KW - Design

KW - Garbage collection

KW - Languages

KW - Memory management

UR - http://www.scopus.com/inward/record.url?scp=84910674971&partnerID=8YFLogxK

U2 - 10.1145/2656106.2656129

DO - 10.1145/2656106.2656129

M3 - Conference contribution

BT - CASES '14: Proceedings of the 2014 International Conference on Compilers, Architecture and Synthesis for Embedded Systems

T2 - 2014 International Conference on Compilers, Architecture and Synthesis for Embedded Systems, CASES 2014

Y2 - 12 October 2014 through 17 October 2014

ER -