Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
skip to main content
10.1145/2236576.2236581acmotherconferencesArticle/Chapter ViewAbstractPublication PagesscopesConference Proceedingsconference-collections
research-article

Debugging component-based embedded applications

Published: 15 May 2012 Publication History
  • Get Citation Alerts
  • Abstract

    With the advent of parallel architectures in the domain of embedded systems, developing applications fully adapted to their underlying platform becomes more and more complicated. Finding and fixing bugs in such environments is even trickier. Furthermore, current complex applications cannot be developed from scratch, only based on programming language primitives. They have to follow advanced programming models and their execution will be driven by the APIs of the key underlying libraries.
    In this paper, we propose a new approach for source-level debuggers. Going beyond their long-established ability to support sequential programming languages, we describe the functionalities a debugger should be able to provide to debug embedded and parallel component-based applications. Then we demonstrate our solution to this problem with a debugger targeting the component framework used on an MPSoC platform. We also explain the development challenges we faced during the implementation of this GDB-based debugger and illustrate its efficiency though a case study of an image processing application.

    References

    [1]
    Allinea Software. Parallel Debugging is Easy, 2008.
    [2]
    S. M. Balle, B. R. Brett, C.-P. Chen, and D. LaFrance-Linden. Extending a Traditional Debugger to Debug Massively Parallel Applications. J. Parallel Distrib. Comput., 64: 617--628, May 2004.
    [3]
    J.-Y. Bouguet. Pyramidal Implementation of the Lucas Kanade Feature Tracker. Description of the Algorithm. http://robots.stanford.edu/cs223b04/algo_tracking.pdf, 2000.
    [4]
    J. Cownie and W. Gropp. A Standard Interface for Debugger Access to Message Queue Information in MPI. In Proceedings of the 6th European PVM/MPI Users' Group Meeting on Recent Advances in Parallel Virtual Machine and Message Passing Interface, pages 51--58, London, UK, 1999. Springer-Verlag.
    [5]
    I. Crnkovic. Component-Based Approach for Embedded Systems. In Ninth International Workshop on Component-Oriented Programming, June 2004.
    [6]
    Free Standards Group. The DWARF debugging standard. http://dwarf.freestandards.org/.
    [7]
    H. Jifeng, X. Li, and Z. Liu. Component-Based Software Engineering---The Need to Link Methods and their Theories. In Proc. of ICTAC05, International Colloquium on Theoretical Aspects of Computing, Lecture Notes in Computer Science 3722, pages 72--97. Springer, 2005.
    [8]
    D. Lea. A java fork/join framework. In Proceedings of the ACM 2000 conference on Java Grande, JAVA '00, pages 36--43, New York, NY, USA, 2000. ACM.
    [9]
    Message Passing Interface Forum. MPI: A message-passing interface standard, 1994.
    [10]
    J. Ressia, A. Bergel, and O. Nierstrasz. Object-centric debugging. In In Proceeding of the 34rd international conference on Software engineering, ICSE '12, 2012. To appear.
    [11]
    B. Schaeli, A. Al-Shabibi, and R. D. Hersch. Visual Debugging of MPI Applications. In Proceedings of the 15th European PVM/MPI Users' Group Meeting on Recent Advances in Parallel Virtual Machine and Message Passing Interface, pages 239--247, Berlin, Heidelberg, 2008. Springer-Verlag.
    [12]
    STMicroelectronics and CEA. Platform 2012: A Many-core Programmable Accelerator for Ultra-Efficient Embedded Computing in Nanometer Technology. http://www.cmc.ca/WhatWeOffer/~/media/WhatWeOffer/TechPub/20101105_Whitepaper_Final.pdf, 2010.
    [13]
    The Gnu Project. GDB. http://www.gnu.org/software/gdb/.
    [14]
    T. Wilde and J. A. Kohl. Port Monitor: A Monitoring & Debugging Approach For Component Frameworks. In Workshop on Component Models and Frameworks in High Performance Computing (CompFrame 2005), Atlanta GA, 2005.

    Cited By

    View all
    • (2020)Unit Testing Framework for Embedded Component Systems2020 IEEE 18th International Conference on Embedded and Ubiquitous Computing (EUC)10.1109/EUC50751.2020.00013(41-48)Online publication date: Dec-2020
    • (2018)Runtime Component Information on Embedded Component Systems2018 IEEE 16th International Conference on Embedded and Ubiquitous Computing (EUC)10.1109/EUC.2018.00032(166-173)Online publication date: Oct-2018
    • (2013)Interactive Debugging of Dynamic Dataflow Embedded ApplicationsProceedings of the 2013 IEEE 27th International Symposium on Parallel and Distributed Processing Workshops and PhD Forum10.1109/IPDPSW.2013.23(345-354)Online publication date: 20-May-2013

    Recommendations

    Comments

    Information & Contributors

    Information

    Published In

    cover image ACM Other conferences
    SCOPES '12: Proceedings of the 15th International Workshop on Software and Compilers for Embedded Systems
    May 2012
    82 pages
    ISBN:9781450313360
    DOI:10.1145/2236576
    • General Chair:
    • Henk Corporaal,
    • Program Chair:
    • Sander Stuijk
    Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. Copyrights for components of this work owned by others than ACM must be honored. Abstracting with credit is permitted. To copy otherwise, or republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Request permissions from [email protected]

    Sponsors

    • EDAA: European Design Automation Association

    In-Cooperation

    Publisher

    Association for Computing Machinery

    New York, NY, United States

    Publication History

    Published: 15 May 2012

    Permissions

    Request permissions for this article.

    Check for updates

    Author Tags

    1. MPSoC
    2. component
    3. components
    4. debugging
    5. embedded
    6. parallel

    Qualifiers

    • Research-article

    Conference

    Map2MPSoC/SCOPES'12
    Sponsor:
    • EDAA

    Acceptance Rates

    Overall Acceptance Rate 38 of 79 submissions, 48%

    Contributors

    Other Metrics

    Bibliometrics & Citations

    Bibliometrics

    Article Metrics

    • Downloads (Last 12 months)1
    • Downloads (Last 6 weeks)0
    Reflects downloads up to 09 Aug 2024

    Other Metrics

    Citations

    Cited By

    View all
    • (2020)Unit Testing Framework for Embedded Component Systems2020 IEEE 18th International Conference on Embedded and Ubiquitous Computing (EUC)10.1109/EUC50751.2020.00013(41-48)Online publication date: Dec-2020
    • (2018)Runtime Component Information on Embedded Component Systems2018 IEEE 16th International Conference on Embedded and Ubiquitous Computing (EUC)10.1109/EUC.2018.00032(166-173)Online publication date: Oct-2018
    • (2013)Interactive Debugging of Dynamic Dataflow Embedded ApplicationsProceedings of the 2013 IEEE 27th International Symposium on Parallel and Distributed Processing Workshops and PhD Forum10.1109/IPDPSW.2013.23(345-354)Online publication date: 20-May-2013

    View Options

    Get Access

    Login options

    View options

    PDF

    View or Download as a PDF file.

    PDF

    eReader

    View online with eReader.

    eReader

    Media

    Figures

    Other

    Tables

    Share

    Share

    Share this Publication link

    Share on social media