Academia.edu no longer supports Internet Explorer.
To browse Academia.edu and the wider internet faster and more securely, please take a few seconds to upgrade your browser.
1986
The applications for which Ada was developed require distributed implementations of thc language and extensive use of tasking facilities. Debugging and testing technology as it applies IO parallel features of languages currently falls short of needs. Thus, the development of cnibeddcd systems using Ada poses special challenges to the software engineer. Techniques for distriburlng Ada programs, support for simulating distributed target machines, testing facilities for taskcd programs, and debugging support applicable to simulated and to real targets all need t o bc addressed. This paper presents a technique for debugging Ada programs that use tasking and it describes a debugger, called AdaTAD, to support the technique. The debugging techniqiic. IS presented together with the user interface to AdaTAD. The component of AdaTAD that monitors and controls communication among tasks has been designed in Ada and is presented through ;in example with a \imple tasked program. 0 3. I. 1 .
IEEE Transactions on Software Engineering, 1991
An execution of a concurrent program P with input X nondeterministically exercises a sequence of synchronization events, called a synchronization sequence (or SYN-sequence). Thus, multiple executions of P with the same input X may exercise different SYN-sequences and produce different results. When debugging an erroneous execution of P with input X, it is often necessary to repeat this execution in order to collect more debugging information. However, there is no guarantee that this execution will be repeated by executing P with input X. To solve this problem requires deterministic execution debugging, which is to force a deterministic execution of a concurrent program according to the SYNsequence of a previous execution of this program. In this paper, we present a languagebased approach to deterministic execution debugging of concurrent Ada programs. Our approach is to define SYN-sequences of a concurrent Ada program in terms of Ada language constructs and to replay such SYN-sequences without the need of system-dependent debugging tools. We Brst show how to define a SYNsequence of a concurrent Ada program in order to provide sufficient information for deterministic execution. Then we show how to transform a concurrent Ada program P so that the SYN-sequences of previous executions of P can be replayed. This transformation adds an Ada task to P that controls program execution by synchronizing with the original tasks in P. We also briefly describe the implementation of tools supporting deterministic execution debugging of concurrent Ada programs.
1987
A new correctness concept, called partial-order preserving property, for event-driven execution monitoring of Ada tasking programs is presented. By using this concept, we can describe whether or not the tasking behavior of monitored Ada programs refrains from interference by monitoring actions of an event-driven execution monitor. In this paper, we define the equivalence of dynamic concurrent structures with respect to Ada program transformation, and propose this equivalence as a partial-order preserving criterion of the $pro$gram transformation used in a preprocessor of an event-driven execution monitor of Ada tasking programs. The equivalence is formally based on the lattice of dynamic concurrent structure of Ada programs which provides an abstraction of the tasking behavior of Ada programs in terms of task interactions. 85b, LeBlanc-85, LeDoux-85, Maio-85]. Execution monitoring is one of the facilities to be supported by an Ada programming support environment (APSE) [DoD-80, Fairley-80, Taylor-85]. On the basis of this requirement, we are developing an event-driven execution monitor for Ada tasking programs. Our execution monitor is a testing andlor debugging tool. It monitors the execution of a target Ada tasking program, reports information about dynamic tasking behavior of the program, detects tasking communication deadlocks (if any) during execution of the program, saves traces of tasking behavior of the program, analyses timing of task interactions, and answers the queries about saved tasking behavior of the program to users. \ c o p y r i g h t Ada is a registered trademark of the U. S. Government (Ada Joint Progam Offce).
1986
Despite considerable commercial exploitation of fault tolerance systems, significant and difficult research problems remain in such areas as fault detection and correction. A research project is described which constructs a distributed computing test bed for loosely coupled computers. The project is constructing a tool kit to support research into distributed control algorithms, including a distributed Ada compiler, distributed debugger, test harnesses, and environment monitors. The Ada compiler is being written in Ada and will implement distributed computing at the subsystem level. The design goal is to provide a variety of control mechanics for distributed programming while retaining total transparency at the code level.
ACM SIGAda Ada Letters, 1985
This paper describes a simple and efficient approach to implementing the Ada operations of entry calls, conditional and timed entry calls, accept statements, selective wait statements and delay statements. This is accomplished by describing the tasking supervisor-a collection of programs which control the tasking operations. Rda definitions of the data structures and the supervisor procedures are given. The semantics of the Ada tasking operations are related to the supervisor by following the description of tasking in Chapter 9 of the Reference Manual for the Ada Programmir~ Language (1983). The structure of the object code for various Ada source language constructs is given. The interaction between the Ada object code and the run-time supervisor is described in detail. The remaining tasking operations are described in Part 1 of this report (Riccardi and Baker [984).
Proceedings of the conference on TRI-Ada '91 today's accomplishments; tomorrow's expectations - TRI-Ada '91, 1991
IFAC Proceedings Volumes, 1983
This paper analyzes the efficiency problems related to the implementation of the ADA tasking facilities on monoprocessor and multiprocessor systems. Three different implementations of the basic communication mechanism in ADA-the rendezvous concept-are discussed and compared. The implementation approac h is the same in the three cases and it consists of translating the ADA parallel constructs into procedural calls to kerne l primi ti ves. The kernel primi ti ves corresponding to the most complex implementation are described.
Proceedings of the 1987 annual ACM SIGAda international conference on Ada - SIGAda '87, 1987
A standard package of low-level Ada tasking operations is needed, to support real-time embedded applications for which the existing Ada tasking operations are too slow or provide insufficient control over timing. This paper suggests criteria for such a package, and gives examples of how specific low-level tasking operations might be used to solve some important realtime problems.
SIGAda Conference, 1992
The draft standard Threads Extension to the POSIXPortable Operating System Interface provides an applicationprogram interface to services supporting thecreation and execution of multiple threads of controlsharing the address space and file descriptors of a singlePOSIX process. This paper reports on the progress ofan effort to test the compatibility of POSIX threads andAda by implementing Ada tasking using the proposedstandard POSIX
ACM Transactions on Programming Languages and Systems, 1990
A method is presented for using symbolic execution to generate the verification conditions required for proving correctness of programs written in a tasking subset of Ada. The symbolic execution rules are derived from proof systems that allow tasks to be verified independently in local proofs, which are then checked for cooperation. The isolation nature of this approach to symbolic execution of concurrent programs makes it better suited to formal verification than the more traditional interleaving approach, which suffers from combinatorial problems. The criteria for correct operation of a concurrent program include partial correctness, as well as more general safety properties, such as mutual exclusion and freedom from deadlock.
ACM SIGPLAN Notices, 1981
An implementation of Ada's tasking facilities, on the LSI-11 microcomputer, is described.The performance and the size of the kernel are compared with those of another language having the same basic characteristics, but with a synchronization mechanism based on shared data.The execution of typical test examples shows that the time spent in the two kernels is more or less the same.
ACM Transactions on Software Engineering and Methodology, 1995
Information and Software Technology, 1994
In this paper, we have developed a dynamic analyser for Ada programs, called AIDA. In software engineering, dynamic analysers that have been built previously have often incorporated first-order-logic assertion languages. For dynamic testing of both sequential and concurrent programs, however, temporal logic may be advantageous since it deals with the development of situations over time. AIDA investigates the applicability of temporal logic in building a dynamic analyser for Ada programs. AIDA is designed to test, debug and specify programs written in the Ada language. It affects the instrumentation of programs as well as the collecting, organizing and reporting of results of the executions of the instrumented program. The instrumentation approach is based on the idea that the intended function of a program can often be specified in terms of assertions or values that must be assumed by variables, at certain strategic paints in the program. This paper describes the design, implementation and experimental evaluation of AIDA. The goal of this work is to apply AIDA as a comprehensive dynamic analyser for Ada programs. AIDA can handle sequential processes, and concurrent tasks as well as it can understand fully all Ada statements.
ACM SIGAda Ada Letters, 1985
A b&act A runtime monitoring system for detecting and describing tasking errors in Ada programs is presented Basic concepts for classifying tasking errors, called deadness errors, are defined. These concepts indicate which aspects of an Ada computation must be monitored in order to detect deadness errors resulting from attempts to rendezvous or terminate. They also provide a basis for the definition and proof of correct detection. Descriptions of deadness errors are given in terms of the basic concepts. The monitoring system has two parts: (1) a separately compiled runtime monitor that is added to any Ada source text to be monitored, and (2) a pre-processor that transforms the Ada source text so that necessary descriptive data is communicated to the monitor at runtime. Some basic preprocessing transformations and an abstract monitoring for a limited class of errors were previously presented in [2]. Here an Ada implementation of a monitor and a more extensive set of pre-processing transformations are described. This system provides an experimental automated tool for detecting deadness errors in Ada83 tasking and supplies useful diagnostics. The use of the runtime monitor for debugging and for programming evasive actions to avoid imminent errors is described and examples of experiments are given.
Proceedings of the fifth Washington Ada symposium on Ada - WADAS '88, 1988
The DAPSE (Distributed Ada Programming Support Environment) research project aims at (i) producing a technology base for developing future Ada programming support environments and (ii) demonstrating the suitability of this technology base by using it to build a prototype environment for the development of distributed Ada software. In this paper we emphasize those parts of the DAPSE project that specifically address the methodology and software tool support for building distributed applic~ tions in Ada. Our paper is structured into three major parts: (1) a brief overview of the entire DAPSE project and a general framework for distributed programming, (2) the specific distribution strategy chosen for the DAPSE project and the initial DAPSE distribution tool kit intended to support the chosen distribution strategy (including first lessons learned), and (3) future plans. 1 I n t r o d u c t i o n Ada has been designed to support the development of sequen-tial~ parallel~ and distributed software applications. As of today, however, none of the existing compilers, run-time environments, or Ada Programming Support Environments provide adequate support for developing distributed Ada programs. The state-of-the-practice in developing distributed Ada applications is to manually distribute distinct Ada programs and implement the required communication between them (e.g., substituting the regular Ada communication mechanisms by system calls to an underlying communication layer).
Safety of Computer Control Systems 1990 (Safecomp '90), 1990
Among existing techniques used to improve software reliability symbolic execution plays an important role. Symbolic testing is potentially more effective than numeric testing, since a symbolic execution represents a class of numeric executions. Symbolic execution can also be used to generate the necessary verification conditions that ensure program (partial) correctness, by adding to the program first order predicates describing its logical properties. Several tools have been built to provide environments in which symbolic execution can be performed. However all of these tools are quite unsatisfactory when dealing with programs that use arrays and/or pointers. In this paper we present a tool (SYMBAD) that provides an environment in which it is possible to perform both symbolic testing and verification on sequential Ada components. Furthermore SYMBAD can be used to find out which restrictions must be placed on input variables of a program in order to execute a particular path. SYMBAD has been designed and implemented at Dipartimento di Elettronica of Politecnico di Milano; it runs under Unix operating system and it is written in C and Lisp. The main SYMBAD features are presented; problems encountered in dealing with arrays and pointers and the adopted solutions are discussed; finally an example of a SYMBAD session is reported.
Language-level concurrency is becoming more widely available in programming languages, placing parallel programming features in the hands of many programmers for the rst time. Unfortunately, the precise semantics of these features is frequently not well understood, principally because of the informal way in which such features are described. Typical of such informal description techniques is the manner in which technical English is used in the Ada Language Reference Manual to de ne the tasking facilities of Ada.
Proceedings of the 15th IFAC World Congress, 2002, 2002
Ada tasking is a powerful abstraction mechanism for developing concurrent embedded systems. However, many implementations of concurrent tasking have been seen as potentially unsafe for critical systems because of their high degree of indeterminism. The Ravenscar profile is a subset of Ada 95 tasking with purpose of providing a basis for the implementation of certifiable critical systems. ORK is an open-source real-time kernel which provides full conformance with the Ravenscar profile on embedded computers. The kernel has a reduced size and complexity, and has been carefully designed to allow the building of reliable software for embedded applications. This kernel is integrated in a cross-compilation system based on GNAT 3.13, supporting the subset of Ada 95 tasking which is allowed by the Ravenscar profile in an efficient and compact way. It is closely integrated with other tools, including a tasking-aware version of GDB.
Proceedings of the conference on TRI-Ada '92 - TRI-Ada '92, 1992
DProto is a computer-aided software engineering (CASE) system for rapidly prototyping concurrent applications. The environment supports codesign and analysis of high-level software and hardware architectures early in the system life cycle. DProto comprises a comprehensive tool set for editing hierarchical dataflow specifications, objectbased data modeling, component reuse, resource modeling, user-interface prototyping, software/hardware allocation, interacti e simulation, and code genemtion. This paper conr eentrate on the methodology and tools in DPmto that support a high-level executable specification language for rapid construction of prototypes and the Ada code generation facility for building target applications. Emphasis is placed on describing the concurrent modeling primitives of the visual specification language and their translation into multitasked Ada for carrying out implementation details.
IEEE Transactions on Parallel and Distributed Systems, 1990
As computer systems have become more and more decentralized and parallel in operation, interest in concurrent and distributed software has grown. One very important and challenging problem for distributed-software engineering is program behavior analysis. We have advocated the use of Petri nets to d e h e a general static analysis framework for Ada tasking. The framework has evolved into a collection of tools that have proven to be a very valuable platform for experimental research. In this paper, we d e h e and discuss the design and implementation of tools that make up our Tasking-Oriented Toolkit for the Ada Language (TOTAL). Both modeling and query /analysis methods and tools are discussed. Example Ada tasking programs are used to demonstrate the utility of each tool individually as well as the way the tools integrate together.
Computer Languages, 1985
The Ada task system is critically evaluated from the point of view of real-time applications. Based on such an evaluation an abstract machine, supplying both an operational semantics and an implementation schema for it, is derived. Such a schema, depending on parameters, may supply a standard implementation following the Ada Reference Manual specifications, or may allow the user to implement ad hoc policies required by the time constraints of the specific application.
Loading Preview
Sorry, preview is currently unavailable. You can download the paper by clicking the button above.