A generalized model of a FASTBUS master is presented. The model is used with simulation tools to aid in the specification, design, and production of FASTBUS slave modules. The model provides a mechanism to interact with the electrical schematics and software models to predict performance.
-Abstract
A generalized model of a FASTBUS master is presented. The model is used with simulation tools to aid in the specification, design, and production of FASTBUS slave modules. The model provides a mechanism to interact with the electrical schematics and software models to predict performance.
The model is written in the IEEE std 1076-1987 hardware description language VHDL. A model of the ATC logic is also presented.
VHDL was chosen to provide portability to various platforms and simulation tools. The models, in conjunction with most commercially available simulators, will perform all of the transactions specified in IEEE std . The models may be used to study the behavior of electrical schematics and other software models and detect violations of the FASTBUS protocol.
For example, a hardware design of a slave module could be studied, protocol violations detected and corrected before committing money to proto type development.
The master-model accepts a stream of high level commands from an ASCII file to initiate FASTBUS transactions.
The high level command language is based on the FASTBUS standard routines listed in IEEE std . Using this standard-based command language to direct the model of the master, hardware engineers can simulate FASTBUS transactions in the language used by physicists and programmers to operate FASTBUS systems.
I. INTx~DUCTI~N We have developed tools that allow the designer of a FASTBUS [l] module to simulate electronic design schematics with high level language commands of the type used by the programmers, engineers, and physicists to interact with real FASTBUS modules. These tools aid in determining that a design complies with the FASTBUS specification.
Moreover, the code developed by the designer to exercise the design can be used as an effective starting point for developing the code that will be used to test and operate the fabricated design.
A Thus the most difficult aspect of electrical system design today is the synthesis of a behavioral model into an electrical schematic.
To address this problem, hardware description languages (most notably VHDL [2] and Verilog [3] ) have become common approaches to behavioral modeling.
Models written in a hardware description language may be as abstract as those written in a pure simulation language; they can also be as specific as an electrical schematic.
This spectrum of application from behavioral to structural allows hardware description languages to describe, simulate, and represent designs continuously throughout the design process. This in turn eases the transition from abstract model to physical implementation.
To effectively simulate a behavioral model of a FAST-BUS board being designed, it is necessary to simulate (or at least approximate) the environment that the board will be used in, i.e., a "virtual" FASTBUS crate. This is the motivation for the VHDL models developed by this work. By providing a simple FASTBUS master and slave, electrical schematics of modules under design can be tested against virtual modules in a virtual crate.
These same ideas were explored by Willwerth et al. [4, 5] using the nonstandard DABL language available from Daisy Systems Corporation (now Dazix) [6] . The models described below, however, were developed in VHDL so as to be portable between CAE systems, and were constructed with the FASTBUS standard routines in mind as -_ a language for control. Traditional simulation packages require that the design testing be done in terms of specifying individual signals at specific times. The simulation proceeds in a fixed, predefined time sequence. Using the native language of most simulators limits the transaction to a fixed time step transaction.
This does not allow for variable response of the addressed slave design. A CSR space read might look like the example in Fig. 1 [8] , was originally developed on behalf of the Department of Defense to represent (document) electrical systems delivered to the government [9] . Currently a mandate for deliverables to the DOD, most CAE vendors are providing (or promising) VHDL support in their products.
Thus VHDL is a suitable choice for developing models to be portable to various platforms.
Three VHDL models were developed to assist in the design of FASTBUS modules: a virtual master (VIM), a virtual slave (VIS), and the arbitration and broadcast timing controller (ATC) that services a virtual crate. The designer must provide a high level module that connects either a VIM or a VIS (or both) and the ATC to the module being designed. In many CAE systems, this would involve a single electrical schematic drawing to connect the models.
If the module being designed is a FASTBUS master, then the VIS model would be used as a basis for exercising the master. Causing the master being designed to perform the desired FASTBUS cycles is the responsibility of the designer.
If the module being designed is a FASTBUS slave, then the VIM model would be used to exercise the slave. In this case, the FASTBUS operations performed by the VIM on the slave are provided by an ASCII character control file (easily manipulated by any text editor) containing the FASTBUS cycles and arguments. Finally, the VIM, VIS, and ATC may be used together as a teaching tool to aid in understanding FASTBUS transactions.
The VHDL models for the VIM, VIS, and ATC are discussed in the next section; the basic input language to the VIM is described in the section after. , an electrical schematic of the crate can be used to connect the models. This drawing is translated to VHDL by the CAE system for simulation.
One possible view of the design process has the electrical design schematic on the top level of the design set, III. BASE-LEVEL INPUT TO VIM The VIM microsequencer state machine accepts a stream of low-level commands from an ASCII text file to specify the sequence of cycles to be performed. These commands are largely a subset of the FASTBUS standard subroutines defined by IEEE std 1177, with emphasis on the "Primitive Action Routines." These commands allow the VIM and the FASTBUS simulation to be directed in abstract terms, and allow for variable response from the addressed slave.
Due to the nature of the VHDL I/O routines, these commands must be presented one per line, and the arguments to these commands must also stand alone on separate lines. Thus, the previous example of a CSR space read would be coded as shown in Fig. 4 .
Timing is not specified in this file. The VIM will initiate address or data cycles, but will proceed only when the addressed slave responds.
Thus the slave's responses define the timing of the simulation.
This reflects the behavior of a real FASTBUS system, where system timing is not specified by the designer, but arises from the interaction of devices. The designer is relieved of the burden of insuring that the timing of the individual signals is correct. Translation from the language of Fig. 6 to the low-level input needed by the VIM (Fig. 4) is performed through the use of a parser-compiler, available from the authors. This translator accepts free-form input containing the commands and arguments for the VIM, and restructures them into a line-at-a-time command file. Complex FASTBUS commands are decomposed into sequences of FASTBUS cycles used to direct the VIM for simulation.
These can be readily adopted for use in a real system to communicate with the implemented design. Although these are microsequencing masters for FASTBUS, there is no physical implementation of a "VIM"; thus master-specific changes to the high-level VIM commands may be needed to allow the control of actual FASTBUS masters. It must be noted that the syntax of the high level language isnot precisely that of the IEEE standard FAST-BUS routines.
Due to the relative simplicity of the VIM model (compared to a real FASTBUS master), many of the standard subroutine arguments are inappropriate. For -example, the environment arguments of the standard routines are meaningless in most simulation environments. Thus, the argument lists contain only the arguments necessary to perform the requested simulation operations. With the above considerations about required masterspecific changes, this discrepancy was not considered unacceptable.
While the argument lists may vary, the FAST-BUS subroutine names and functions have been maintained exactly.
V. PORTABILITY
A. VHDL
The original version of the VIM, VIS, and ATC models were developed using a VHDL implementation purchased from Viewlogics Systems, Incorporated
[IO] (a fullspectrum CAE vendor). The code was developed at SLAC according to the guidelines provided by Viewlogics for the creation of "portable" models. The code was then "ported" to run under a VHDL environment pur&ased from Intermetrics, Incorporated [ll]. Several "incompatibilities"
were encountered that may be of concern to other users of this code, or others involved in the creation of "portable" VHDL models. It should be noted that Intermetrics has been involved in the development of the VHDL language since its inception; thus VHDL code that does not port easily to the Intermetrics environment probably will not port easily elsewhere. The most immediate problem in porting the models was the choice of base logic signals, and the use of file I/O. As a language, VHDL supports user defined logic types which can have user defined logic values, typically "0" and "1" for true and false, "X" for unknown, etc. Simulators from different vendors are optimized for different definitions.
Viewlogics has optimized their simulator to support a 4-level logic variable; Intermetrics has not. The controversy over the "best" multilevel logic package is still in progress. For more information on stdlogic-1164, contact the VHDL consulting group [12] . Also, although the VHDL as a language supports a simple notion of file input and output, the specific implementations are vendor-specific. File I/O is extremely important to the VIM, both for reading the command stream, and for generating run-time messages for the user, describing VIM operation, error conditions, and protocol violations.
Other harmless, but annoying porting problems occurred because of semantic shortcuts offered by Viewlogic, but not supported by Intermetrics. For example, "prising(AS)" is a Viewlogic conditional to test if AS is changing from 0 to 1. Intermetrics does not support this shortcut; the more formal VHDL syntax is "(not AS'stable) and (AS='l')"
. For the sake of portability, these shortcuts had to be identified and eliminated.
B. Unix
The high level translator was developed using the standard lex parser generator and yacc compiler compiler [14, 15] and the standard C compiler on several platforms. The translator code was compiled and tested on SUN UNIX, SC0 XENIX system, and AIX systems at SLAC. The source code is available for compiling on the target system.
The high level translator was also tested using the Free Software Foundation
[13] jl ex and bison on a Sun workstation. There were some differences between lex and flex and between yacc and bison, leading to some minor problems. The best results and the easiest porting were achieved using the UNIX or XENIX system supplied lex parser generator and yacc compiler compiler.
A UNIX make file was created to generate the parser and the compiler and to compile the resulting C code.
All of the above are available in source code form from the authors (see below). The llib and ylib libraries needed by lex and yacc are normally supplied with the UNIX system, and cannot be provided.
VII. FUTURE WORK
Many of the features of the VIM, VIS, and ATC are inherently simple to make simulation debugging easier. However, theses models are highly modular in nature, and code modification is straightforward. For the VIM, improved error handling and protocol violation checking/reporting are to be added. Also, as the FASTBUS standard evolves to incorporate more sophisticated broadcast and block-transfer operations, the VIM model will be updated to support these modes.
For the VIS, full functionality is planned (broadcast and logical addressing, block transfer, CSR registers that conform precisely with the FASTBUS standard, uniform SS codes, etc.). There are two reasons for developing a well organized, FASTBUS compliant slave as a reference -_ model. First, masters can be tested in a fully consistent manner; the results of simulation can be expected to correspond very closely to a real FASTBUS environment. Second, and perhaps more important, the "technically perfect" slave could also serve as a reference model (starting point) for designing real slave modules using "cut-andpaste" design methods. This is one of the real values of using hardware description languages. All of the code described above, as well aa the corresponding documentation, is available via electronic mail and/or file transfer protocols.
Information on the VHDL implementation and the translator may be obtained by electronic mail from tomdean@slacvm.slac.stanford.edu or from mjhQeng3.hep.uiuc.edu.
The source code may be obtained by sending electronic mail to uihepa::mjh or mjhQeng3.hep.uiuc.edu.
