A pipeline hazards description describes mainly reservations of processor functional units by an instruction during its execution. The instruction reservations are given by regular expression describing nondeterministic finite state automaton (NDFA).
Pipeline hazards description structure has the following layout which is similar to one of YACC file.
     DECLARATIONS
     %%
     EXPRESSIONS
     %%
     ADDITIONAL C/C++ CODE
The section of declarations contains declarations of functional units and instructions of a processor. The section also may contain declarations of automata on which result automaton are split in order to decrease size of tables needed for fast recognition of pipeline hazards. And finally the section may contain subsections of code on C/C++.
The next section contains expressions list which describes functional units reservations by instructions. Regular expressions in general case correspond to nondeterministic final state automaton. The expression list can be empty. In this case the result automaton can contains only arcs marked by special token corresponding advancing cycle.
The additional C/C++ code can contain any C/C++ code you want to use. Often functions which are not generated by the translator but are needed to work of the instruction scheduler go here. This code without changes is placed at the end of file generated by the translator.
The section of declarations may contain the following construction:
     %instruction IDENTIFIER ...
     %reservation IDENTIFIER ...
     %unit <automaton identifier> IDENTIFIER ...
Sometimes it is necessary to describe that some units can not be reserved simultaneously, e.g. floating point unit is pipelined but can execute only single or double floating point operation. The following construction is useful in such situations
     %exclude IDENTIFIER ... : IDENTIFIER ...
All automaton identifiers present in unit declarations must be declared in the following construction
     %automaton IDENTIFIER ...
     %local {
        C/C++ DECLARATIONS
     }
     %import {
        C/C++ DECLARATION
     }
     and
     %export {
        C/C++ DECLARATION
     }
The section of declarations is followed by section of expressions. A expression is described the following construction
     instruction or reservation identifiers : expression;
      EXPRESSION   EXPRESSION
      EXPRESSION + EXPRESSION
      EXPRESSION * NUMBER
      EXPRESSION | EXPRESSION
      %nothing
      UNIT OR RESERVATION IDENTIFIER
      [ EXPRESSION ]
      ( EXPRESSION )
Reservation identifier is simply changed by the construction `(the corresponding reservation expression)'.
The construction `EXPRESSION * NUMBER' is simply abbreviation of `EXPRESSION EXPRESSION ...' where the expression is repeated by given positive number times.
The construction `EXPRESSION | EXPRESSION' means that the instructions reserve units according to the left or to the right expression (so called alternative). If an unit is present only on one alternative it should belong to the same automaton as units on other alternative. OKA checks this and reports if it is not true.
All binary operators have the left associativity and the following priority:
      `*'          - the highest priority
      `+' and ` '  - the middle priority
      `|'          - the lowest priority
The construction `[EXPRESSION]' serves for describing optional construction and is simply abbreviation of the following construction ` | EXPRESSION'.
The parentheses are used to grouping sub-expressions in another order then the one given by priorities and associativities of operators.
Full YACC syntax (with some hints in order to transform into LALR (1)-grammar) of pipeline hazards description language is placed in Appendix 1.