## AN INTRODUCTION TO THE DDL-P LANGUAGE

W.E. Cory, J.R. Duley, W.X. vancleemput

Technical Report No. 163

March 1979

Computer Systems Laboratory Stanford University Stanford, California 94305

## ABSTRACT

This report describes the Pascal-based implementation of DDL (Digital Design Language) and its simulator.

INDZX TERMS: Design automation, computer-aided design, hardware description languages, DDL, digital design language.

- ii -

# TABLE OF CONTENTS



- iii -



- iv -



#### Chapter 1

#### INTRODUCTION

This report is one of two manuals describing a compiler and simulator for DDL-P, a subset of DDL (Digital Design Language). DDL is a language for describing the behavior  $of$ digital systems at the Boolean equation, register transfer, and algorithmic levels. It uses a finite state machine notation and it may be used to describe systems over a wide range of levels.

DDL was originally formulated by Duley at the Univer- . sity of Wisconsin in **1967 t5, 6, 31.** A translator and simulator for a subset of DDL were implemented in FORTRAN 11, 7, **4, 8, 9, 101.** In **1971-73,** J. Duley, B. Clark, and J. Welsch implemented an interactive simulation system for a subset of DDL (with modified syntax) on the HP 2100 system in HP-Algol at Hewlett-Packard Laboratories. The DDL-P language, compiler, and simulator are based on this HP implementation. In order to enhance portability the system was rewritten in PASCAL on the DEC-20 system under the TOPS-20 Operating System at Stanford University. Small changes were made to the

**l-**

syntax, mainly to enhance the readability. The system will still accept the input format of the original HP-Algol version.

This report describes the DDL-P subset of the language as it was implemented at Stanford. Several examples are given together with instructions for using the compiler on the LOTS DEC-20 system at Stanford. The appendices contain a list of the error messages and a formal BNF definition of the language accepted by the compiler. A companion manual describes the use of the simulator and its command language **121.**

Chapter 2

CHARACTER SET, IDENTIFIERS, AND CONSTANTS

## 2.1 CHARACTER SET

;

**I**

**I**

<sup>I</sup> letter ::= AlBlClDlEiFlGlHlIlJlKlLlMl **<sup>I</sup>** NlOlPlQlRlSlTlUlVlwlXlYlZl **<sup>I</sup>** alblcldlelflglhliljlklllml <sup>I</sup> nlolplqlrlsltlulvlwlxlylz **<sup>I</sup>** digit ::= **011121314151617181 9**

DDL-P uses a subset of the 7-bit ASCII character set, . including the letters A-Z,a-z and the digits O-9. Upper and lower case letters are considered to be equivalent; in the listing generated by DDL-P, all letters are printed in upper case. The following non-alphanumeric characters are also used ("SSR" stands for "state sequencing register"): Octal Char. Use 042 **w** Comment delimiter 043 **#** NOT EQUAL relational operator or SSR marker  $(Optional)$  end of file marker



 $-3 -$ 



In addition to the above symbols, DDL-P uses the following multiple-character special symbols:

Symbol Use



OUTPUT Output action LEVEL Return to higher level state machine RETURN Set-next-state action (by RETURN) REGISTER Register declaration header MEMORY Memory declaration header<br>TERMINAL Terminal declaration head Terminal declaration header OPERATION Operation section header CONTROL State machine declaration header

All printing characters not mentioned above are illegal characters and should appear only in comments.

Note that on input, the compiler maps the characters **it \ tt it P { it , it <sup>1</sup> it , it } 0 , tt <sup>~</sup> it ,** and DEL (ASCII code 177 octal) into **0 a 1 a**  $\mathbf{u} \cdot \mathbf{v}$  **i**  $\mathbf{v} \cdot \mathbf{v}$  **i**  $\mathbf{v} \cdot \mathbf{v}$  is the spectively. For this reason, avoid the use of  $"\prime", "\prime", etc.$ 

# - 2.2 IDENTIFIERS

**I** <sup>I</sup> **<sup>I</sup>** letter-or-digit ::= letter I digit **<sup>I</sup> I I** I identifier ::= letter { II letter-or-digit }\*\*\* **I I**

Identifiers in DDL-P are made up of letters and digits. Upper and lower case letters are equivalent.

r III a bha an chuid an chuid

Examples

RegisterName rEgIsTeRnAmE (equivalent to RegisterName) Identif iersCanBeVeryLong mln2

Note that in the last example, "2" would be interpreted as a subscript if "min" were previously declared. This is discussed in Section **5.1.1.**

Identifiers must start with a letter and may be of any length up to 132 characters. The alphabetic special symbols listed in Section 2.1 are keywords and may not be used as identifiers.

Unless otherwise noted in this manual, all identifiers \*declared in DDL-P are global; that is, an identifier may only be declared once in a DDL-P description.

**-6-**

I **I**

```
I hex-digit : := digit I A I B I C I D I E I F I
I I
 I octal-digit : := 01112131415161 7 I
I I
I quartal-digit ::= 0 I 1 I 2 I 3 I
I I
I bit : := 0 I 1 I
I I
I decimal-constant : := digit { I | digit I***
I I
I constant ::= decimal-constant I
      I I decimal-constant II B 1 II . I II bit I
                          I { II bit Is** I
      I I decimal-constant II Q 1 II . 1 I
                   I II quartal-digit I
                  I 1 II quartal-digit 3*** I
      I I decimal-constant I I 8 1 I I . 3 I
                   I II octal-digit I
                  I 1 II octal-digit I*** I
      I I decimal-constant II D II decimal-constant I
      I decimal-constant II H \{ II \}. I- ll hex-digit I
I 1 II hex-digit I*** I
I I
```
I **I**

Every constant in DDL-P has two attributes, its value and its length in bits. Generally the length of a constant is given explicitly. The general format for a constant follows:

**- 7 -**

Length (in decimal) of constant in bits, followed by base designator B base 2 Q base 4 a base 8 <sup>D</sup> base 10 H base 16 optionally followed by  $\cdot$ .' denoting left-justification, followed by value (before left-justification) in appropriate base.

The length of a constant must be in the range 0 < length <= 256.

If a constant is left-justified, then it is truncated on the right or padded on the right with zeroes to make it the proper length. Decimal constants may not be left-justified.

. - Note that leading zeroes in the left-most digit of a left-justified constant ARE NOT truncated; hence left-justification does not imply that the most significant bit is set to one.

If a constant is not left-justified, then it is truncated on the left or extended on the left with zeroes to make it the proper length.

#### Examples

Constant Binary representation



 $- 8 -$ 



A decimal constant may be written without the length specification and base designator 'D', in which case a default length of 16 is assumed. The value specified must then be in the range  $0 \leq x$  value  $\leq 65535$ .

#### Examples

Constant Binary representation



 $\epsilon$  -  $\epsilon$  .

#### 2.4 COMMENTS

A comment (any text not containing a  $\cdot \cdot \cdot$ ) is contained on one line and enclosed in double quotes '"':

" This is a valid comment . "

The second double quote may be omitted, in which case the entire line following the first  $\cdots$  is treated as a comment:

it This is also a valid comment .

**- 9 -**

Comments are ignored by DDL-P and may be inserted freely for documentation anywhere blanks are permitted (see next section>.

## 2.5 DDL-P DESCRIPTION FORMAT

A DDL-P description is free-format. Blanks may be inserted at will to improve readability, except that blanks must not be embedded in constants, identifiers, or the multiple-character special symbols listed in Section 2.1. Comments may also appear anywhere blanks are allowed.

DDL-P expands the non-printing character HT (tab, ASCII code **011** octal) to blanks; tabs may appear anywhere blanks . are permitted, All other non-printing characters (except DEL, noted in Section 2.1) are ignored.

All lines should be no longer than **132** characters (AFTER tabs are expanded). DDL-P truncates longer lines. The end of a line may occur anywhere blanks are allowed.

**- 10 -**

#### Chapter 3

DDL-P DESCRIPTION STRUCTURE

```
i i se obrazovanje u obraz
  ddl_description ::= declaration {operation_decl}
                                 I control-decl I$3 I
I I
  declaration ::= register-decl {memory_decl}
                              I {terminal-decl) I
| I memory-decl {terminal decl}
I I terminal-decl I
```
A DDL-P description in general contains the following sections in the order given: . -

I **I**

Chapter



The REGISTER and MEMORY sections contain declarations of synchronous and asynchronous storage elements, respectively. The terminal section contains declarations of combinational networks. The OPERATION section defines data transfers which may occur, along with optional timing infor-

**- 11 -**

mation. The CONTROL section contains the finite state machine, which controls the use of the physical facilities previously defined. The dollar sign at the end of the description is optional.

Each of these sections is presented in turn in the following chapters, with a discussion of Boolean expressions in chapter 5.

#### Chapter 4

#### REGISTER AND MEMORY DECLARATIONS

DDL-P allows the declaration of synchronous and asynchronous storage elements in REGISTER and MEMORY declarations, respectively.

#### **4.1** REGISTER DECLARATIONS

I <sup>I</sup> register-decl ::= REGISTER register-spec I and  $\qquad \qquad \{ \quad \text{register-space} \quad \}$  \*\*\*  $I-$ I register-spec ::= {#} identifier<br>| { | {cons <sup>1</sup> [ {constant:} constant] <sup>1</sup>  $\mathbf{I}$ I identifier I *{constant:}* constant ,  $\mathbf{I}$ {constant:} constant <sup>I</sup>  $\mathsf{l}$ 

 $\mathbf{I}$ 

In DDL-P, registers are storage elements which may be written either synchronously or asynchronously. The timing of synchronous vs. asynchronous stores is covered in chapters 7 and 8.

**- 13 -**

All registers are declared in a list following the keyword 'REGISTER' and terminated by period '.'. A register may be a Single flip-flop? or it may be a one- or two-dimensional array of flip-flops.

Example

# REGISTER V, C, N, Z, R[0:7, 15:0],<br>X[10:1, 5:10], Y[200:100].

In the above example? VF CF NF and Z are each declared to be unsubscripted single-bit registers. Register R is a two-dimensional array of bits logically organized as eight 16-bit words. The bits in each word are labeled  $15,14,13,\ldots,1,0$ . Bit 15 is the most significant bit  $(MSB)$ . The 16-bit words of R are labeled 0 through 7.

The declarations of X and Y in the example illustrate two points:

- **1.** The subscript range need not begin or end with 0 or 1.
- 2. The subscript range may be either ascending (5:10) or descending **(200: 100).** Note that in register XF the MSB of each word is bit 5, while in register Y, the MSB is bit 200.

**- 14 -**

The first number and colon ':' may be omitted from a subscript range? in which case a bound of one is assumed.

Example

"same as 'ARRAY[1:10,1:20]'" REGISTER ARRAY<sup>[</sup> 10, 201.

## 4.1.1 State Sesuencins Resisters

. -

A state sequencing register may be used to encode the states of the finite state machine defined in the CONTROL section. A state sequencing register is declared by immediately preceding the identifier by '#' in the REGISTER declarations. It may not have two dimensions.

Example

#### REGISTER  $A$ ,  $B$ ,  $#SSR[3:0]$ ,  $C$ .

Up to seven state sequencing registers may be declared. The use of state sequencing registers is discussed in chapter 8.

.

```
I
I memory-decl ::= MEMORY memory-spec I
                        \left\{ \begin{array}{ccc} 0 & \text{if } 0 \leq x \leq 1 \end{array} \right\}I I
I memory-spec ::= identifier {[ (constant:} constant ]}
             I identifier [ {constant:} constant F
                           I {constant:} constant I I
I I
```
 $\ddot{\phantom{1}}$ **I**

Memories in DDL-P are storage elements which may be written asynchronously only. All memories are declared in a list following the keyword 'MEMORY' and terminated by period  $\cdot$  .

The syntax of the list is identical to that for the re-'gister list? with the following exception: State sequencing registers may not be declared as memories; hence, the symbol \*#' must not appear in the MEMORY declarations.

> Example MEMORY PM[0:1023,15:0], C[0:511,7:0],  $X, Y, SI 2048$ .

# 4.3 MEMORY SIZE LIMITATIONS

The current implementation of DDL-P will support rather complex simulations ? but only with modest memory sizes. The

**- 16 -**

designer should restrict the total **register?** memory ? and terminal space declared  $to, say, 50000$  bits. (Terminals are discussed in Chapter 6.)

#### Chapter 5

#### BOOLEAN EXPRESSIONS AND OPERATORS

In DDL-P, a Boolean expression is a string of one or more bits formed by zero or more operations **on registers ? memories ?** terminals ? and/or constants. (Terminals are discussed in the next chapter.)

First, the syntax for specifying the operands is presented. Then the operators will be discussed.

## **. 5-. 1** OPERANDS IN BOOLEAN EXPRESSIONS

i

**I**

**I**

term ::= reference <sup>I</sup> **I** INpUT(constant,identifier\_ref {, identifier\_ref}\*\*\*) **<sup>I</sup> I** CASE boolean-exp DO boolean-exp I DO boolean-exp <sup>I</sup> 1 DO boolean-exp I\*\*\* ENDCASE l  $$$ boolean\_exp $$$  boolean-exp ; boolean-exp  $\{$ ; boolean\_exp $\}$ \*\*\* . **<sup>I</sup> I** IF boolean-exp THEN boolean-exp **<sup>I</sup>** ELSE boolean-exp ENDIF **<sup>I</sup> I** constant **<sup>I</sup> I** ( boolean-exp <sup>1</sup> **<sup>I</sup>** reference ::= identifier-ref **I** terminal-ref

**I I I I I I I I I I** I **I I I** I **I**

**- 18 -**

An operand to which an operator is applied in a Boolean expression may be an identifier reference? a terminal reference? an INPUT function? a conditional expression? a Boolean expression enclosed in parentheses, or a constant.

# 5.1.1 Identifier References

**I**

**I**

**I I I**

**I**

**. I**

**I I** I **I I I I I** field ::= boolean-exp : boolean-exp identifier-ref ::= identifier **<sup>I</sup>** identifier **I I** decimal-constant identifier ( boolean-exp ) **<sup>I</sup>** identifier **II** decimal-constant 1 boolean-exp <sup>1</sup> **<sup>I</sup>** identifier 1 boolean-exp I C boolean-exp <sup>1</sup> | identifier | boolean-exp <sub>F</sub> boolean-exp ] **<sup>I</sup>** identifier 1 field <sup>1</sup> **<sup>I</sup>** identifier **I** I decimal-constant I field <sup>1</sup> I identifier [ boolean-exp ] [ field ] I identifier [ boolean-exp field ]

i **I I I I** I I **I I** I **I i** I **I**

**1**

An identifier reference is a reference to one or more contiguous bits in a facility? where a 'facility' is a register? memory? or terminal. The bits referenced may be specified by subscripts (Boolean expressions enclosed in brackets) following the facility identifier. The allowed kinds of subscripting operations are illustrated by example

 $- 19 -$ 

MEMORY ZERO, ONEI **16~1** IF TWOI **16?0:31** I.

Examples of valid references:

ZERO

Reference to the bit named 'ZERO'. This is the only allowable type of reference to ZERO; ZERO may not be subscripted.

#### ONE171

Reference to the bit labeled 7 in the facility ONE. Note that 7 is in the allowed range  $16:1:$ Note that  $7$  is in the allowed range  $16:1;$ ONE1201 would be an invalid reference? by contrast.

#### ONEflO:6]

Reference to the string of five bits ONE[10] through ONE[6] inclusive. The order of the expresssions in the field (increasing or decreasing) must be the same as in the declaration;  $e.g.,$ . - ONE[6:10] is an invalid reference.

#### ONE

Reference to the entire facility ONE; equivalent to ONE[16: **11.**

# **TW0[8,17** <sup>1</sup>

Reference to the bit labeled **17** in the word labeled 8 in the facility TWO.

## TWO[Sl[ **171**

Equivalent to TWO[8,17].

#### TWO[4,16:23]

Reference to the string of eight bits  $TWO[4, 16]$ through TWO[4,23] inclusive.

**- 20 -**

## TW0[41[ 16:231

Equivalent to **TWo[4,16:23].**

# **TW0[151**

Reference to the entire word labeled 15 in facility TWO; equivalent to TWO[  $15,0:31$ ].

The above examples show all valid kinds of subscripting operations. In particular ? note that in a Boolean expres**sion ?** the identifer for a two-dimensional facility must be followed by at least one subscript, and this first subscript must not be a field.

In the above examples? all subscripts were constants. In general F however, a subscript may be any valid Boolean . expression.

When the first subscript following an identifier is a constant? then in some cases the subscript, expressed in decimal may be concatenated to the identifier without being enclosed in brackets. For example? 'ID[n]' may be written as 'IDn', where 'n' denotes a decimal constant. This  $f$  eature is designed to reduce the need for brackets in complicated Boolean expressions. Its use is subject to two restrictions:

**- 21 -**

- 1. The identifier name \*ID\* must not end with a decimal digit. Hence, 'EX3[21' cannot be written as 'EX32'.
- **2.** The identifier 'IDn' must not have been declared. That is, 'EXAMPLE5' does NOT mean 'EXAMPLE[5]' if 'EXAMPLE5' is itself a declared identifier.

Examples (assuming restrictions satisfied) Reference Equivalent to ONE8<br>
TWO 11[311 TWO [1] TW011[311 TW0[11,31]<br>TW016[A:B] TW0[16,A:R

 $TWO[16, A:B]$ 

**I**

DDL-P may apply subscript concatenation in unexpected For example? an identifier 'L3' cannot be declared places. if the identifier 'L' was previously declared. A good rule is to not declare identifiers of the form 'IDn' ('n'=decimal constant ? 'ID' ends in letter) if 'ID' will also be declared.

## **5.1. 2** Terminal References

i

~~ --I **<sup>I</sup>** terminal-ref ::= identifier ( boolean-exp **<sup>I</sup> I** {, boolean\_exp}\*\*\* )

- **<sup>22</sup>**-

**I I**

Most facility references are of the forms described in the above section. The exception is the special case of a terminal reference with an actual-parameter list. The actual parameters supplied in such a terminal reference are inputs to the combinational network represented by the terminal. These parameters may be arbitrary Boolean expressions. (Recall that an unsubscripted two-dimensional facility name is NOT a valid Boolean **expression?** however.>

#### Examples

## SUM(X[11:16], 16D2) PRODucT(7,X)

Note that a terminal reference with a parameter list may not be subscripted. Terminals are discussed in Chapter 6.

#### **5.1. 3** INPUT Function

The INPUT function is an action discussed in Chapter 7. In short, it allows for the setting of facilities by the user from the teletype at simulation-time. When an INPUT action appears as a function in a Boolean **expression ?** then the function receives as **its** value the last number entered by the user.

**- 23 -**

For example? if the user inputs the value 16D2 for IN-CREMENT in the expression  $R(+)$ INPUT(1, INCREMENT), then the expression is equivalent to  $R(+)$  2.

## **5.1. 4** Conditional Expressions

In a conditional expression? a selector expression appears along with at least two alternative expressions.  $A_{C}$ cording to the value of the selector expression? one of the alternative expressions is evaluated and used as the value of the conditional expression. A conditional expression

CASE select DO expr 1 DO expr 2 . . . DO expr n-l DO expr n ENDCASE

is evaluated by

 $\mathbf{r} = \mathbf{r} \cdot \mathbf{r}$ 

if select=1 then expression value = expr 1 else if select=2 then expression value =  $\exp r$  2 else else if select=n-1 then expression value = expr n-l else expression value = expr n.

Note that expression n above is chosen for select=0 and for select>=n. Conditional expressions may be nested.

Two other forms of the conditional expression are allowed. The above conditional expression may alternately be written

- **<sup>24</sup>**-

 $\frac{1}{2}$  select  $\frac{1}{2}$  expr 1 ; expr 2 ; . . . expr n-l ; expr n .

(with period terminating the expression). This notation has the advantage of being compact. <sup>A</sup> conditional expression with just two cases may be written

IF select THEN expr 1 ELSE expr 2 ENDIF .

#### **5.1. 5** Other Boolean Expression Operands

An arbitrarily complex Boolean expression enclosed in parentheses may itself be an operand in another Boolean expression. The enclosing parentheses may be omitted, in which case the order in which operators are applied is determined by operator precedence.

Constants may also appear as operands in Boolean expressions.

**- 25 -**

I I I I I I I **I I I I** I **I** I **I I I I I I I I** . I I **I I I I I I I I**

```
boolean-exp ::= minterm [ + minterm }***
minterm ::= product \{ \ ]+\} product \}***
product ::= complement 1 * complement I***
complement ::= \{-\} reduction { CON reduction } ***
reduction ::= adjustment
            I + RED adjustment
            I * RED adjustment
            I [+I RED adjustment
            I (+I RED adjustment
adjustment ::= relation
             1 adjustment EXT arithmetic-exp
             I adjustment TAIL arithmetic-exp
             I adjustment HEAD arithmetic-exp
relation ::= arithmetic-exp
           I arithmetic-exp (=) arithmetic-exp
           I arithmetic-exp # arithmetic-exp
           I arithmetic-exp < arithmetic-exp
           I arithmetic-exp > arithmetic-exp
            i arithmetic-exp >= arithmetic-exp
            I arithmetic-exp <= arithmetic-exp
arithmetic-exp ::= { (-) } term
                  I arithmetic-exp (+) term
                 l arithmetic-exp (-) term
```
**I** I I I **I** I **I I I I I I I I I I I I I**

> **I I I I I I I I I** I **I**

The syntax of Boolean expressions defines a precedence of operators. Operators with higher precedence are applied before operators with lower precedence unless a different order is specified with parentheses. Operators of the same precedence in an expression are applied left to right; e.g.,

 $- 26 -$ 

A EXT B TAIL C HEAD D

is equivalent to

((A EXT B) TAIL C) HEAD D .

The operators are listed below in order of precedence, highest to lowest. All operators on the same line have the same precedence. The reduction (RED) operators and '-' are unary operators. The  $\lq\lq\lq\lq$  operator may be either unary or binary. The remaining operators are binary.



#### 5.3 OPERATORS

The operators are discussed in order of decreasing precedence, except for the reduction operators, which are discussed last. Recall that a Boolean expression has two attributes, its length in bits and its value. Hence, for each operator, the length of the result, as well as its value, must be defined. A warning on the detection of negative results from subtraction appears at the end of this section.

 $- 27 -$ 

In the examples below, the operators are used with constant operands. However, operands can be quite general, as discussed above in OPERANDS IN BOOLEAN EXPRESSIONS.

## 5.3.1 Arithmetic Operators

The arithmetic addition operator is  $"(+)"$ . The two operands in an addition are considered to be non-negative binary numbers generating a non-negative sum. If one operand is shorter than the other, the shorter operand is extended on the left with zeroes before the addition. The length of the result is the length of the longer operand plus one, where the extra bit on the left is the carry out.

Examples

. <br> <br> -  $\bullet$ 



The arithmetic subtraction operator is  $"(-)"$ . As with addition, the two operands in a subtraction are considered to be non-negative binary numbers, the operands need not be the same length, and the length of the result is the length of the longer operand plus one. However, the result of a subtraction is a two's complement signed binary number, with a one in the carry out denoting a negative result.

 $- 28 -$ 

The  $''(-)''$  operator may also be used for unary  $two's$ complement negation, in which case the result length is the same as that of the operand.

Examples



## 5.3.2 Relational Operators

In relational operations, the two operands are considered to be non-negative binary numbers. The result of the operations is 1Bl if the indicated relation is true and 1BO . otherwise. The two operands need not be the same length.

The relations denoted by the operators are as follow:



Examples



 $- 29 -$ 

## 5.3.3 Substrins Operators

The operators "EXT", "TAIL", and "HEAD" access parts of the first operand or replicate the first operand as indicated by the count given as the second operand. The operation "ARG EXT n" concatenates ARG with itself n-1 times. The operations "ARG HEAD n" and "ARG TAIL n" yield the most significant (leftmost) n bits of ARG and the least significant n bits of ARG, respectively. A run-time error occurs if the length of an EXT operation result exceeds 256 bits, or if the number of bits specified in a HEAD or TAIL operation is greater than the length of the first operand.

Examples



## 5.3.4 Concatenation

. -

The "CON" operator concatenates its two operands. The left operand becomes the most significant (leftmost) portion of the result. A run-time error occurs if the result is longer than 256 bits.

#### Examples



 $- 30 -$ 

#### 5.3.5 One's Complement

The one's complement operator "-" complements each bit of the operand. The length of the result is the same as that of the operand.

Examples



# 5.3.6 Binary Logical **Operator <sup>s</sup>**

A binary logical operator performs the indicated bitwise logical function on its two operands. If the two operands are of differing lengths, then a run-time warning is issued and the shorter operand is extended with zeroes before the operation. The length of the result is the same as that of the longer operand.

The functions denoted by the operators are as follow:



Examples



 $- 31 -$
5.3.7 Reduction Operators

Using the bits of its single operand as arguments, a reduction operator performs the indicated operation n-l times, where n is the length of the operand. For example,

 $[+]$  RED ARG $[1:4]$ 

is equivalent to

ARGl [+I ARG2 [+I ARG3 [+I ARG4 ,

where ARG is singly dimensioned. The result is a single bit, except in the case of addition, where the result has length 16.

Examples



## 5.3.8 Warning on Use of Subtraction

As noted earlier, the result of a subtraction is a two's complement signed binary number. However, the other arithmetic and relational operators always consider their operands to be unsigned non-negative numbers. Hence the expression

A C-1 B < 0

 $- 32 -$ 

does not perform the desired function of detecting a negative result. In fact, the expression always evaluates as lB0, since no unsigned number is less than zero. A simple expression performing the desired function in this case is

A  $(-)$  B HEAD 1,

or even simpler,

 $A \leq B$  .

In general, care is required when using arithmetic or relational operators with negative numbers.

Chapter 6

TERMINAL DECLARATIONS

```
I terminal-decl ::= TERMINAL terminal-spec I
I 1 , terminal-spec I*** . I
I I
I terminal-spec ::= identifier I
I 1 I {constant:} constant 1 1 I
I I identifier 1 {constant:} constant , I
I (constant:} constant I I
I I identifier I
I (identifier {,identifier}*** ) }
I 1 [{constant:} constant] 1 I
I = boolean-exp I
I I
```
. . **I**

Terminal identifiers are names for the outputs of combinational networks, called 'terminals' in DDL-P. All terminals are declared in a list following the keyword 'TERMINAL' and terminated by period '.'.

It is convenient to consider a combinational network in three parts:

**1.** OUTPUTS

I **I**

**- 34 -**

- 2. INPUTS Constants, registers, memories, and other terminals
- 3. FUNCTION Logical function (combinational circuitry) mapping inputs to the outputs

When a terminal is declared, the function mapping the inputs to the outputs may or may not be given. If the function is given, then the inputs themselves may be completely specified, or some inputs may be left unspecified; the unspecified inputs will be given later via a parameter list.

In general, terminals may be one-dimensional. Some terminals may also be two-dimensional. The syntax for specifying terminal dimensions is identical to that for giving  $\ddot{\phantom{a}}$ . the dimensions of registers or memories.

# **6.1** TERMINALS WITH UNSPECIFIED FUNCTIONS

In the simplest case, terminals are declared without giving the associated functions. Such terminals may be singly or doubly subscripted.

#### Example

TERMINAL A,B,C, "one bit each" "equivalent to D[1: 10 ]" T[5:161,S[7:0,15:41.

**- 35 -**

The values or functions to be associated with these terminals may be specified in the OPERATION or CONTROL section. This will be discussed in chapters 7 and 8.

## 6.2 TERMINALS WITH SPECIFIED FUNCTIONS AND INPUTS

The function associated with a terminal may be specified with a Boolean expression in the declaration. Terminals so defined may be singly-subscripted.

Example

TERMINAL SUMXY  $[1:16] = X(+)Y$  TAIL 16, YL17= SCORE<17, NEXTQ= CASE J CON K DO 1BO DO **1Bl**  $DO -O$ DO Q ENDCASE , ONE[l:81= 8B00000001.

Any terminals referenced in Boolean expressions in TERMINAL declarations must be declared prior to their appearance in the Boolean expressions.

#### 6.3 TERMINALS WITH UNSPECIFIED INPUTS

 $\ddot{\phantom{a}}$ 

When a terminal function is specified in the terminal declaration, some or all of the inputs may not be identified. These inputs are represented by formal parameters in

 $- 36 -$ 

the declaration, where the formal parameters appear in a list following the terminal identifier. Whenever such a terminal is referenced, the unspecified inputs must then be supplied in an actual-parameter list. A terminal with a formal parameter list may be singly subscripted.

Example TERMINAL SUM(X, Y)[1:12] = (10D0 CON  $X(+)$ Y) TAIL 12.

In this example, inputs X and Y are unspecified. A valid reference to SUM might then be

SUM(IR[21:32], R[IR[17:20]]) ,

where IR and R are registers. The formal parameters are assumed to be Boolean expressions, but no assumption is made regarding the lengths of the parameters. . -

Parameter passing is by value. The following restrictions apply:

- 1. Formal parameters may not be subscripted. A subscripting operation may be simulated with HEAD and TAIL, although this is less efficient than normal subscripting.
- 2. A formal parameter may not appear in the INPUT function.

 $- 37 -$ 

Formal parameter names are declared locally to the terminal definition; the names may be re-declared outside the terminal definition.

# Chapter 7

# OPERATION SECTION

As used in this chapter, the term "operation" refers to a named sequence of actions, where actions may specify data transfers, sequencing or timing information, or other (previously defined) operations to be invoked. These named sequences of actions are defined in the operations section.

The several possible actions are presented first, followed by a discussion of operation definitions.

I I I I I I I I I **I I I I I I I I I I** I **I I**

 $\mathbf{r}$ 

 $\mathbf{I}$  $\mathbf{I}$   $action :: = identifier-ref$   $\{CON identifier-ref\}$ <- boolean-exp identifier-ref {CON identifier-ref} = boolean-exp  $\mathbf{I}$ identifier-ref a INPUT ( constant , identifier-ref  $\mathbf{I}$  $\{ ,\text{ identifier-ref }\}$ \*\*\* ) OUTPUT ( constant , reference  $\{$ , reference  $\}$ \*\*\* ) identifier { ( boolean-exp  $\mathbf{1}$ <sup>1</sup> , boolean-exp I\*\*\* <sup>1</sup> <sup>1</sup>  $\mathbf{1}$ CASE boolean-exp DO action { , action }\*\*\* { DO action { , action I\*\*\* I\*\*\* ENDCASE  $\mathbf{I}$ +boolean\_exp4 action { , action } \*\*\*  $\{ ; \text{ action } \{ , \text{ action } \}***$   $\}***$ IF boolean-exp  $\mathbf{1}$ THEN action { , action } \*\*\* { ELSE action { , action  $}$ \*\*\* } ENDIF TIME boolean-exp  $\mathbf{I}$  $\mathbf{1}$ -> identifier identifier : action

**I**

**I I I I I I** I I **I I**

> **I I I I I**

**I I I I I**

## **7.1. 1** Immediate and Delayed Stores

The store actions  $"=" " and "<-"" indicate that the Boo-$ lean expression on the right hand side is to be evaluated immediately and its value assigned to or stored in the facility given on the left hand side. Two facility references may be concatenated on the left hand side, in which case the

 $- 40 -$ 

right hand facility in the concatenation receives the rightmost bits in the Boolean expression, and the left hand facility gets the bits to the left. For example,

At1:31 CON B[1:51 = 8B10101100 is equivalent to

 $A[1:3] = 3B101$ ,  $B[1:5] = 5B01100$ .

The length in bits of the facility reference(s) on the left hand side should be the same as the length of the Boo-1 ean expression on the right hand side. If these two lengths differ, then a run-time warning is issued. If the Boolean expression is too long, then high order (leftmost) bits will be truncated as necessary. If the Boolean expression is too short, then high order bits of the destination facility will be LEFT UNCHANGED.

The evaluation of the Boolean expression on the right occurs exactly once (each time the store action is encountered); any subsequent changes to operands in the right side do not cause a re-evaluation and assignment. Consider, for example, the following sequence where A, B, and R are single-bit flip-flops and T is a terminal:

> $[R = 1B1,$  $T = R$ ,  $A = T$ ,  $R = 1B0,$  $B = T$

> > $- 41 -$

The assignment of  $180$  to R in the fourth line does not cause a re-evaluation of T. The value assigned to B is the same as that assigned to  $A$ , namely **1B1.** Even though terminals were described in Chapter 6 as representing combinational networks, their use (as above) may suggest the existence of additional sequential circuitry, if indeed the DDL-P description corresponds closely to the hardware design.

The above example should be contrasted with the following, in which  $A$ ,  $B$ ,  $R$ , and  $T$  are as before, but the function associated with T is defined in the TERMINAL section:

```
MEMORY A, B, R.
TERMINAL T = R.
OPERATION EXAMPLE =
  [R = 1B1,A = T,
    R = 1B0,B = T ].
```
. -

In this case, T is re-evaluated each time it is referenced in the operation. Hence, A is set to 1B1, but B is set to 1BO.

This illustrates an important difference between the specification of a terminal function in the TERMINAL section and the assignment of a function to a terminal as an action in an operation. Another important difference is that an assignment to a terminal made in an operation is not permanent. This will be discussed further in the next chapter.

 $- 42 -$ 

#### 7.1.1.1 Immediate Store

In an immediate store, denoted by  $"$ =", the value of the right hand side is assigned IMMEDIATELY to the facility on the left hand side. This facility may be any facility (register, memory, or terminal) EXCEPT a state sequencing register or a terminal for which a function was already assigned in the TERMINAL section.

Examples

 $T[7:4] = 4D9,$  $MENT[R[IR[6:8]]] = R[IR[9:11]]$ 

#### 7.1.1.2 Delayed Store

. and  $\alpha$ In a delayed store, denoted by "<-", the right hand side is evaluated immediately, but the resulting value is not assigned to the facility until the end of the current "state". Subsequent references to the left hand facility made before the end of the current state will access the old, not the new, value of the facility.

This timing will be discussed further in the next chapter; for now it will suffice to understand that the sequence of actions

 $A \leftarrow B$ ,  $B \leftarrow A$ 

 $- 43 -$ 

will effect a swap of facilities A and B. By contrast, the sequence

 $A = B$ ,  $B = A$ 

will not effect a swap, but is equivalent to  $'A=B"$  alone.

The destination in a delayed store must be a register.

Examples

 $R[NUM]$  <- MBR,  $ACC \leftarrow ALU(ACC, R[I], 2)$ 

## **7.1. 2** Set-Terminal Action

DDL-P provides a shorthand notation for an immediate store where the left hand side is a terminal of length one bit and the right hand side is 1B1. The action

 $T = 1B1$ 

may be written as

 $T \quad \partial \quad$ 

The advantage of this notation, aside from its brevity, is that it may also appear in the CONTROL section (Chapter 8), whereas the store actions  $"=" " and "<-" may not.$ 

**- 44 -**

## **7.1. 3** INPUT Action

The INPUT action allows the user to enter facility values from the teletype at simulation time. The first item in the list enclosed in parentheses is a device number, which is ignored for the INPUT action in the current implementation of DDL-P. The identifier references following the device number indicate the facilities to be input. Any valid identifier reference may appear, and the input values are stored in the facilities immediately.

Examples

# INPUT(1,ACC),  $INPUT(1, R[1], T[L:R])$

The values entered by the user should have the same . a lengths in bits as the corresponding facilities being set. If the lengths do not agree, then the actions taken are the same as those for a store in which the lengths do not agree (Section **7.1.1).**

The user will be prompted for new values each time the INPUT action is encountered, even if new values were previously supplied during the current operation. Each value input will be shown in the listing file.

 $- 45 -$ 

# 7.1.4 OUTPUT Action

The OUTPUT action immediately lists the values of the indicated facilities either at the teletype (if device number is zero or one) or in the listing file (if device number is greater than one). The device number is the first item in the OUTPUT list; the remaining references indicate the facilities to be displayed. Any valid facility reference may appear in this list.

Examples



#### **7.1. 5** Operation Reference 7.1.5

An action may be the name of a previously defined operation, in which case the sequence of actions appearing in that definition is executed. If the operation was defined with formal parameters (Section 7.21, then a corresponding list of actual parameters (arbitrary Boolean expressions) must be supplied enclosed in parentheses following the operation name.

An operation may invoke itself (recursion), but forward references are not allowed.

**46 -**

#### Examples

INITIALIZE, GETREGCNUM, MEMIADDR])

#### **7.1. 6** Conditional Action

The interpretation of conditional actions is similar to that of conditional expressions. A selector expression appears along with one or more lists of actions. According to the value of the selector expression, one of the lists will be executed. The action

> CASE selector DO list of actions 1 DO list of actions 2 . . . DO list of actions n-l DO list of actions n ENDCASE

is executed as

 $\alpha = 1/2$ 

if selector=1 then list of actions 1 else if selector=2 then list of actions 2 else else if selector=n-1 then list of actions n-l else list of actions n .

The alternative forms for the conditional syntax presented in Section 5.1.4 may also be used.

A special case occurs when only one list is specified. In this case, the list is executed only if the selector has value one; otherwise, the entire action is skipped.  $A$  conditional action with just one list may be written

- **<sup>47</sup>**-

IF selector THEN list of actions ENDIF

Conditional actions may be nested.

Examples

IF I>8 THEN ACC<-16DO ELSE R[I]<-16DO ENDIF , IF OVFL THEN PC <- EMA ENDIF CASE NA DO K=B DO IF FF THEN X=B ELSE Y=-B ENDIF ENDCASE

The last example may also be written using the alternate form in the following way:

 $\triangleleft$  NA  $\triangleleft$  K=B ;  $\triangleleft$  FF  $\triangleleft$  X=B ; Y=-B . .

#### **7.1. 7** Labels and Gotos

Any action may be preceded by one or more labels (iden- . a tifiers), each followed by a colon. The course of execution may then be altered with a goto  $"->"$ . A goto must point to a label in the same operation definition. Forward referencing of labels is permitted.

Labels and gotos are useful for specifying loops within operations.

**- 48 -**

Example

"Initialize M[1:100,15:0] to all ones"

 $ADDR = 8D1,$  $L: M[ADDR] = 16HFFT$ ADDR =  $ADDR(+)1 TAIL 8$ , IF ADDR <= 100 THEN ->L ENDIF

## 7.1.8 SIME cification

The designer may specify that a certain action or operation requires T units of time, where T is an arbitrary Boolean expression, and a "unit of time" is a convenient unit selected by the designer. This timing is specified by the action . -

TIME T .

The default length of time assumed is one. All actions in an operation are considered as occurring in parallel, so the total length of time required for an operation will be

maximum { times required for each action

executed in the operation }

A TIME of zero should not be given; such an action will be ignored.

 $- 49 -$ 

```
I I
I operation-decl ::= OPERATION operation-def
                  \{, operation def}*** .
I I
 I operation-def ::= identifier I
               I ( (identifier {,identifier}*** 1 1 I
              I = 1 action C, action}*** 1 I
```
**I I**

**I 1**

The OPERATION section consists of a list of operation definitions. The list is preceded by "OPERATION" and followed by period. A simple operation definition gives the operation name followed by a list of actions enclosed in brackets. The actions in an operation must form a "compatible set of actions." This term is defined in Chapter 8; ba-<sup>1</sup> sically, it denotes a group of actions in which illegal simultaneous stores to a register do not occur.

The operation name may optionally be followed by a formal parameter list enclosed in parentheses. When such an operation is referenced later, a corresponding list of actual parameters must be supplied. Parameter passing is by value. The following restrictions apply to actual and formal parameters:

 $-50 -$ 

- **1.** Actual parameters must be valid Boolean expressions. In particular, an unsubscripted two-dimensional facility name may not be an actual parameter.
- 2. Formal parameters may not be subscripted. A subscripting operation may be simulated with HEAD and TAIL, although this is less efficient than normal subscripting.
- 3. No assignment of a value may be made to a formal parameter.
- 4. Formal parameters may not appear in INPUT or OUT-PUT lists.

Formal parameter names are declared locally'to the operation definition; the names may be re-declared outside the operation definition.

## Example

 $\mathbf{r} = \mathbf{r}$ 

OPERATION READCADDR) = [MBR=MIADDRI, M[ADDRl=8DO, TIME **41,** "ALU is assumed to be a terminal"  $ARTH(FCT) = [ACC-ALU(FCT)],$ CLEAR(N) =  $[$  IF  $N>7$  THEN ACC<-8D0 ELSE REG[N]<-8D0 ENDIF ], TTYINP =  $[INPUT(1, ACC)],$ 

**- 51 -**

INIT =  $[$  N=8D0,  $L: REG[N]=8D0$ ,  $N=N(+)$  | TAIL 8, IF N<=7 THEN ->L ENDIF, ACC=8DOl, DOFET = [ADDR=PC, PC<-PC(+)1 TAIL 16, READ(ADDR)].

## Chapter 8

## CONTROL SECTION

In the preceding chapters, we have seen how to define the facilities in a system (REGISTER, MEMORY, and TERMINAL declarations) and how to specify actions which may occur within the system (OPERATION section). Using this base, we must now specify the overall behavior of the system. In DDL-P this is done by describing the system as a finite state machine in the CONTROL sections.

#### **8 .1** THE FINITE STATE MACHINE

 $\sim$ 

i i se osnovnom komunismom obrazu i se osnovnom komunismom obrazu i se osnovnom komunismom obrazu i se osnovno<br>U se osnovnom komunismom obrazu i se osnovnom komunismom obrazu i se osnovnom komunismom obrazu i se osnovnom **<sup>I</sup>** level-decl ::= CONTROL state-def 1 state-def I\*\*\* **<sup>I</sup> I** <sup>I</sup> **I** state-def ::= {identifier 1 (constant) <sup>1</sup> :} **<sup>I</sup>**  $\{$  state-action  $\{$ , state-action $\}***$   $\}$  /

**I** <sup>I</sup>

In general, a DDL-P description may have more than one CONTROL section. These sections are called "interpretively linked machines? For now, however, consider the case where there is just one CONTROL section, or level.

**- 53 -**

A finite state machine consists of one or more states. A state is an abstract expression of the condition of the machine, where the condition may be as simple as the contents of a register, or may be far more complex. The finite state machine is in one state at any given time, and has rules for determining the outputs and the next state, given the current state and the inputs.

Hence, the CONTROL section is a list of state definitions, where each state has up to three parts:

- **1.** Optional label (identifier> naming the state.
- 2. Optional constant, enclosed in parentheses, denoting the value which should be in the state se- . quencing register when the system is in this state. The same value may not be assigned to two different states.
	- 3. Optional state actions for determining the next state and the values of facilities when the system is in this state.

The state actions are separated by commas. Each state definition is terminated by " $\prime$ ".

 $-54 -$ 

```
I
I state-action ::=
I
I I
I I
I I
I I
I I
I
I
I
I I
I I
I
I
I
I I
I
         identifier { (boolean-exp {, boolean exp}***) }
       l identifier-ref a
       -> identifier
       => identifier
       | RETURN
       CASE boolean-exp
                DO state-action {, state-action}***
              { DO state-action \{, state_action}*** }***
                ENDCASE
        | ¢boolean_exp¢ state-action {, state_action}***
                    {; state-action
                    1, state-action}*** I*** .
        IF boolean-exp
                THEN state-action {, state-action}***
              { ELSE state-action {, state-action \}*** }
                ENDIF
        L LEVEL
```
I **I I I** I **I I I I I I I I I I** I I **I I** I

## 8.2.1 Determination of Facility Values

Two state actions exist for modifying facility contents or functions. One action names an operation, defined in the OPERATION section, to be executed. The syntax and semantics of this action are identical to those for the operation reference discussed in Section 7.1.5. The number of actual parameters in the reference must match the number of formal parameters in the definition.

**- 55 -**

The second action is the set-terminal action, which was discussed in Section 7.1.2. Its syntax is

 $id$ entifier-ref  $\mathfrak{a}$  ;

it denotes that the named one-bit terminal is to be set immediately to 1Bl.

Examples

"Operation references" READ(ADDR[1:16]), ARITH(4B1011), CLEAR(4), TTYINP,

"Set terminals to 1Bl" Ta, BITS[100,12] a, BUS[8] a

# 8.2.2 Determination of Next State

The next state may be specified explicitly, implicitly, . or by default. Only one next state may be given explicitly or implicitly, with the exception that two next states may be specified if exactly one of them was given with a subroutine call  $"=>"$ .

#### **8.2.2. 1** Explicit Next State

The next state may be set explicitly by any of three actions. The action

-> STATE

**- 56 -**

specifies that the name of the next state is "STATE". A subroutine capability is also provided; the action

### => STATE

will cause the next state to be "STATE", and the system will remember where this call was made. When the third action

#### RETURN

is encountered, then the next state will be the return state; the return state is the one which would have been the next state if the original "=> STATE" had been missing. Subroutine calls may be nested.

These actions will be illustrated by example in Section 8.2.2.4.

## 8.2.2.2 Implicit Next State

 $\mathbf{r}=\mathbf{r}$  .

The next state is specified implicitly when the state sequencing register for this CONTROL declaration is written by a delayed store "<-". This may occur in an operation invoked by a state action, Such a store is equivalent to a got0 "->" to the corresponding state.

 $-57 -$ 

# 8.2.2.3 Default Next State

If the next state is not specified explicitly or implicitly, then by default the next state is the state following the current state in the CONTROL declaration. Note that no default exists for the last state in a CONTROL declaration; in the last state, a next state must be specified implicitly or by goto "->" or "RETURN".

# 8.2.2.4 Example

The following example illustrates the next-state actions:

```
REGISTER #SSR[2:0].
.. OPERATION SETSSR(N) = [SSR<-N TAIL 3].
     CONTROL P(1): ->>SQ(2): = >T/R(3): ->p, =>U/S(4): SETSSR(2), =>V/
              T(5): /U(6): SETSSR(O)/
              v : =\frac{1}{2} \times 1W(O): RETURN/
              X(7): RETURN, =>W/.
```
State sequence for this example:

System starts in first state, P.

\*\*\*\*\*STATE=P, SSR=3Dl, RETURN STATE STACK IS EMPTY.

Next state is  $S$  by goto "->".

\*\*\*\*\*STATE=S, SSR=3D4, RETURN STATE STACK IS EMPTY.

 $-58 -$ 

If "=>V" were missing, then "SETSSR(2)" would imply next state is Q. State Q goes on return state stack, and next state is V. State V has no SSR value specified, so SSR is left equal to the value set in state S. If state V did have an SSR value given, then it would override the value supplied in state S.

\*\*\*\*\*STATE=V, SSR=3D2, RETURN STATE STACK = Q.

A nested call. If "=>X" were missing, then next state would be W by default.

\*s\*\*\*STATE=X, SSR=3D7, RETURN STATE STACK = Q,W.

If  $" =>W"$  were missing, then next state would be W by RETURN. State W is popped off the stack by RETURN, but then pushed back on the stack by "=>W".

\*\*\*\*\*STATE=W, SSR=3DO, RETURN STATE STACK = Q,W.

Next state is W by RETURN.

\*\*\*\*\*STATE=W, SSR=3DO, RETURN STATE STACK = Q.

Next state is Q by RETURN.

. -

\*\*\*\*\*STATE=Q, SSR=3D2, RETURN STATE STACK IS EMPTY.

If "=>T" were missing, then next state would be R by default.

\*\*\*\*\*STATE=T, SSR=3D5, RETURN STATE STACK = R.

Next state is U by default.

\*\*\*\*\*STATE=U, SSR=3D6, RETURN STATE STACK = R.

"SETSSR(0)" implies next state is W. \*\*\*\*\*STATE=W, SSR=3DO, RETURN STATE STACK = R.

**- 59 -**

Next state is R by RETURN.

\*\*\*\*\*STATE=R, SSR=3D3, RETURN STATE STACK IS EMPTY.

If  $"=\frac{1}{v}$  were missing, then next state would be P by  $qot0$   $"->"$ . \*\*\*\*\*STATE=U, SSR=3D6, RETURN STATE STACK = P.

"SETSSR(O)" implies next state is W. \*\*\*\*\*STATE=W, SSR=3D0, RETURN STATE STACK = P.

Next state is P by RETURN. This completes the cycle. \*\*\*\*\*STATE=P, SSR=3Dl, RETURN STATE STACK IS EMPTY.

## 8.2.3 Other State Actions

 $\cdot$   $\cdot$  The conditional state action looks and behaves like the conditional action discussed in Section 7.1.6. According to the value of a selector expression, one of several lists of actions is executed. The action

> CASE selector DO list of state actions 1 DO list of state actions 2 DO list of state actions n-l DO list of state actions n ENDCASE

is executed as

 $- 60 -$ 

if selector=1 then list of state actions 1 else if selector=2 then list of state actions 2 else . . . else if selector=n-1 then list of state actions n-l else list of state actions n .

In the special case where only one list of actions is specified, the list is executed only if the selector has value one; otherwise, the entire state action is skipped. Conditional state actions may be nested.

#### Example

IF SCORE<17 THEN  $->B$ ELSE IF SCORE<22 THEN ->JK ELSE IF FF THEN ->D ENDIF, KFF, TMT ENDIF ENDIF

 $\bullet$  -  $\bullet$  -  $\bullet$  -  $\bullet$ The last state action is LEVEL. This is mentioned here for completeness only. LEVEL will be discussed in Section 8.4.

## 8.3 TIMING CONSIDERATIONS

## 8.3.1 Timing of Immediate and Delayed Stores

As the simulation of a state is carried out, store or input actions may be encountered. The timing for such actions is as follows:

**- 61 -**

- **1.** If a store action  $(\cdot\cdot\cdot\cdot, \cdot\cdot\cdot\cdot, \text{ or } \cdot\cdot\cdot\cdot)$  is encountered, the right hand side is evaluated immediately. This evaluation occurs just once, as discussed in Section **7.1.1.** If an INPUT action is encountered, the input value is requested immediately.
- 2. In the case of an immediate store  $("="" or "a")$  or INPUT action, the new value is stored in or assigned to the specified facility immediately. In the case of a delayed store to a register ("<-"), the new value is not stored immediately, but is saved in a temporary buffer.
- $\cdot$   $\cdot$  3. At the end of the state, the simulator checks to see if it should halt the simulation or do any I/O. This occurs BEFORE the new register values specified in delayed stores are stored. Hence, any register values accessed or output by the simulator at this time are still old values.
	- 4. When the simulation continues, the new values given in delayed stores are stored in the registers. At the same time, any terminals which were set are cleared to zero. Hence, any assignment to

 $- 62 -$ 

a terminal is temporary and lasts (at most) until the end of the current state.

5. After the registers have been updated and the terminals cleared, the simulator begins simulation of the next state.

This timing is illustrated by the following example with waveforms:

Example

```
REGISTER A,B,R,S.
MEMORY M.
TERMINAL T.
OPERATION
  SWAP = [A<-B, B<-A],AIMM(X) = [A=X], BHMM(X) = [B=X],RIMM(X) = [R=X],SIMM(X) = [S=X], SDEL(X) = [S<-X],MIMM(X) = [M=X],TIM(X) = [T=X].CONTROL
  INIT: AIMMClBO), BIMM(lB11, RIMM(lBO),
        SIMM(1B0), MIMM(1B1), TIMM(1B0), ->P/P : SWAP, RIMM(1B1), SDEL(1B1),
       MIMMCS), T ii), ->Q/
  Q : MIMM(1B1), -\frac{1}{2}Q'.
```


Note that the value assigned to M in state P is lB0, the "old" value of S, even though the delayed store to S has already been encountered. The value assigned to S is stored at the beginning of state Q. Also, terminal T is cleared before the start of state Q. Finally, note how the swapping of values of A and B occurs.

During the simulation, once a delayed store to a register is specified, any further stores to the same bits during

**- 64 -**

the same state will cause a "SIMULTANEOUS STORE" warning message to be issued and the previously specified delayed store canceled. Such an error indicates an illegal attempt to simultaneously store multiple values into the same register. A set of actions in which such errors do not occur is called a "compatible set of actions."

# 8.3.2 Timing of Operations and States

All the operations in a state are considered as occurring in parallel. Furthermore, all the actions in an operation occur in parallel. Hence, the time required for a state is just the time required for the longest action in- \* voked by the state. This time is one by default and may be increased by the TIME action. Note that the times required for the actions in a state may vary widely, but ALL the actions will be completed before the system moves to the next state, even if this in some sense implies that a large portion of the system is "id1e" much of the time.

The designer may specify that the actions in a state occur sequentially, rather than in parallel, by splitting the state into a sequence of states. This idea is illustrated in the example below.

 $- 65 -$ 

Example

REGISTER A[ 101, B[ 10], OVERFLOW.<br>MEMORY MEM[ 1024, 101. MEMORY MEM[ 1024,101.<br>OPERATION ADD = [OVERFI  $ADD = [OVERLOW CON A <- A(+)B],$ STORE =  $[MEM[A] < - A$ , TIME 21.

In the above specification, one unit of time is implied for operation ADD while two units of time are specified for STORE. If the two operations are executed in parallel in one state,

# ADD, STORE/

then the time required for the operations is two units. The designer may alternately specify that ADD and STORE are executed sequentially by breaking the state into a sequence of two states, as in

. - ADD/ STORE/ .

This sequence will take three units of time.

Note that the choice of parallel vs. sequential execution will have a marked effect on system operation. In the example above, suppose that A and B originally contained lOD5 and lOD10, respectively. Then in the first case, operation STORE accesses the old value of A and stores lOD5 in MEMi51, while in the second case, STORE accesses the new value of A and stores **lOD15** in MEM[151.

**- 66 -**
The technique of splitting states can be used in the description of a system with a multi-phase clock. Each clock cycle may be specified as a sequence of states, where each state represents one phase, as suggested below:



Alternately, a designer may describe a system with a multiphase clock as two interpretively linked machines (next section); a state in the higher level machine would correspond to one clock cycle, while a state in the lower level machine would correspond to one phase. This illustrates the freedom the designer has in choosing the level of detail and the . significance of a "state" in a DDL-P description.

## 8.4 INTERPRETIVELY LINKED MACHINES

 $\mathbf{I}$ 

| control-decl ::= level-decl { level-decl }\*\*\* .  $\qquad \qquad$ 

In general, a DDL-P description may have several (up to seven) CONTROL sections. Each CONTROL section defines a

**I I**

 $\mathbf{I}$ 

 $- 67 -$ 

complete finite state machine. The several machines have a hierarchical relationship; the first machine defined is at the highest or top level, level 1. The succeeding machines are at level 2, level 3, etc.

The higher level machines are typically control machines which set terminals serving as control lines. The lower level machines test these terminals and "interpret" them, executing the indicated functions. Hence, the machines are said to be "interpretively linked machines?

During the simulation, control must pass from state machine to state machine in some orderly fashion. The LEVEL action aids in this process. When the state action

. - LEVEL

is encountered in a machine, then control will pass to the next higher level machine at the end of the current state, AFTER the new values of registers changed at this level have been stored, AFTER terminals set at this level have been cleared, and BEFORE simulation of the next state at this level begins. A LEVEL in the top level machine is ignored.

Conversely, control will pass unconditionally to the next lower level machine, if such a level exists, at the end of the current state, AFTER all actions in the current state

 $- 68 -$ 

have been executed, BEFORE the new values of registers changed at this level have been stored, and BEFORE terminals set at this level have been cleared.

Simulation always begins in the level 1 machine. BY default, the very first state to be executed at each level will be the first state in the corresponding level declaration, although the designer may specify different starting states on each level at simulation time. The simulation of the finite state machine at level  $i$  (call it machine(i)) will then proceed as follows:

- **1.** If a higher level machine exists (if  $i>1$ ), then  $machine(i-1)$  passes control to machine $(i)$  at the end of a level i-l state.
- **2.** The simulator executes the actions for the next state in machine(i) (where the next state was previously determined). It completes immediate stores while saving delayed-store values as discussed in Section 8.3.1. The simulator also determines the next state for machine(i).
- **3.** At the end of this state (but BEFORE register values are stored), machine(i) passes control to ma-

 $- 69 -$ 

 $chine(i+1)$ . If there is no such machine, then the simulator checks to see if it should halt or do any I/O. (These actions are requested by the designer at simulation time; see DDL-P Command Lanquaqe Manual.) Note that register values accessed by lower level machines will not reflect changes by delayed stores at level-i in the previous state, the new values not yet having been stored.

- 4. When control is returned to machine(i) from  $ma$ chine(i+l) or from simulator I/O activity, then machine(i) stores the new register values given in the previous level-i state, also clearing terminals that were set in that state.
- 5. If a LEVEL command was not encountered in the previous level-i state, then machine(i) proceeds with the execution of the next level-i state. Otherwise,  $machine(i)$  passes control to  $machine(i-1)$ . In the latter case, machine $(i)$  remembers what the next level-i state will be when control is returned from  $machine(i-1)$ .

The system is considered as being in one state in each machine at any given time. The "total state" of the system

 $- 70 -$ 

is then a list of states, with one state from each machine. An example of a three-level control declaration is given below, followed by a description of the simulation of state A. The simulation begins at level 1 in "total state" A:C:E.

> CONTROL A: OPA, ->B/  $B:$  OPB,  $\rightarrow A/$ CONTROL C: OPC, ->D/  $D:$  OPD,  $->C$ , LEVEL/ CONTROL  $E:$  OPE,  $\rightarrow$ F/ F: OPF, LEVEL,  $\rightarrow$ E/.

> > Execution of State A

TOTAL STATE

A:C:E: Start at level 1 in total state A:C:E. A:C:E: Execute OPA, next machine(1) state will be B.<br>A:C:E: Drop to level 2. Drop to level 2.  $A:C:E:$  Execute OPC, next machine(2) state will be D.<br> $A:C:E:$  Drop to level 3. Drop to level 3. A:C:E: Execute OPE, next machine(3) state will be F.<br>A-:C:E: Check for simulator I/O or halt. A-:C:E: Check for simulator I/0 or halt.<br>A:C:E: Store registers, clear terminals A:C:E: Store registers, clear terminals from OPE.<br>A:C:F: Execute OPF, next machine(3) state will be A:C:F: Execute OPF, next machine(3) state will be E.<br>A:C:F: Check for simulator I/0 or halt. A:C:F: Check for simulator I/0 or halt.<br>A:C:F: Store registers, clear terminals A:C:F: Store registers, clear terminals from OPF.<br>A:C:E: Rise to level 2. Rise to level 2. A:C:E: Store registers, clear terminals from OPC.<br>A:D:E: Execute OPD, next machine(2) state will be  $A:D:E:$  Execute OPD, next machine(2) state will be C.<br> $A:D:E:$  Drop to level 3. Drop to level 3. A:D:E: Execute OPE, next machine(3) state will be F.<br>A:D:E: Check for simulator I/O or halt. A:D:E: Check for simulator I/0 or halt.<br>A:D:E: Store registers, clear terminals A:D:E: Store registers, clear terminals from OPE.<br>A:D:F: Execute OPF, next machine(3) state will be A:D:F: Execute OPF, next machine(3) state will be E.<br>A:D:F: Check for simulator I/O or halt A:D:F: Check for simulator I/0 or halt.<br>A:D:F: Store registers, clear terminals A:D:F: Store registers, clear terminals from OPF.<br>A:D:E: Rise to level 2. Rise to level 2. A: D: E: Store registers, clear terminals from OPD.<br>A: C: E: Rise to level 1. Rise to level 1.

**71 -**

A:C:E: Store registers, clear terminals from OPA, completing simulation of state A. Simulation of state B will proceed in similar fashion.

State Sesuencins Reqisters. Each finite state machine may have its own state sequencing register (S.S.R.). The first S.S.R. declared is associated with the highest level machine, the second S.S.R. declared is associated with the level-2 machine, etc.

Restrictions. The following restrictions apply in the specification of multiple-level control declarations:

1. A finite state machine should not modify the state sequencing register for a lower level machine. For example, the machine at level 2 should not modify the S.S.R. for level 3.

. -

2. All state gotos "->" and subroutine calls "=>" must point to states within the same finite state machine. It is not possible, for example, to use one group of states as a subroutine in two different finite state machines. The following is not permitted:

> CONTROL  $A: -> C$ / "<-- ERROR"  $B: -\geq A/$ CONTROL C: ->B/. "<-- ERROR"

> > $-72 -$

**3.** The LEVEL action should not appear in a state which is in a subroutine or which contains a subroutine call "=>". If this rule is violated, unpredictable simulator errors may occur.

 $\bullet$  -  $\bullet$ 

# Chapter 9

## EXAMPLES

Five complete DDL-P descriptions are now presented with brief discussions.

The first machine plays Blackjack by dealer's rules, accepting cards until its score exceeds 16, and counting the first Ace as eleven unless that causes its score to exceed 21. The machine shows its status in terminals HIT, STAND, and BROKE. Card values are entered through terminal VALUE, and YCRD is a "card ready" strobe.<br>..

Example 1

```
" BLACKJACK
                        MACH I
                                    NE. "
REGISTER SCORE[5], CARDBUF[5], FF.
TERMINAL HIT, BROKE, STAND,
   VALUE[1:5] = INPUT(1,VALUE),
   YCRD = INPUT(1,YCRD),YL17 = SCORE <math>17</math>, <math>YL22 = SCORE <math>22</math>.NACE = CARDBUF#1.OPERATION
   TPT = [CAPBUF < - 5D10],TMT = [CAPBUF < - 5D22],TVC = [CARDBUF < - VALUE],
   IHT = [HIT = 1B1],ISTD = {STAND=1B1}, IBRK = {BROKE=1B1},CLS = [SCORE < - 5D0],ADD=[SCORE <-(SCORE(+)CARDBUF)TAIL 51,
   KFF = [FF<-1D0], JFF = [FF < -1D1 1CONTROL
   A:
       CLS, KFF, -> B/IHIT, TVC,
   B:IF YCRD THEN ->C ELSE ->B ENDIF/
       IF YCRD THEN ->C ELSE ->D ENDIF/
   \mathfrak{C}:
   D:ADD, IF NACE+FF THEN -3F
                         ELSE ->E ENDIF/
        JFF, TPT, ->D/E:\cdot \cdot \cdot F:
        IF YL17 THEN ->B ELSE ->G ENDIF/
   G:IF YL22 THEN ->K ELSE ->H ENDIF/
   H:KFF, TMT,
        IF FF THEN ->D ELSE ->J ENDIF/
   J:IBRK,
        IF YCRD THEN ->A ELSE ->J ENDIF/
   K:ISTD,
        IF YCRD THEN ->A ELSE ->K ENDIF/. $
```
The second machine is identical to the first except that states  $F$ ,  $G$ ,  $H$ ,  $J$ , and  $K$  have been combined into two states, F and JK. This example shows nested conditional state actions, and also suggests the flexibility possible in describing a system as a finite state machine.

 $-75 -$ 

Example 2

```
ii BLACKJAC K MACHINE. "
REGISTER SCORE[51, CARDBUF[5], FF.
TERMINAL HIT, BROKE, STAND,
   VALUE[1:5] = INPUT(1, VALUE),
   YCRD = INPUT(1,YCRD),
   YL17 = SCORE<sub>17</sub>, YL22 = SCORE<sub>2</sub>NACE = CARDBUF#1.OPERATION
   TPT = [CARDBUF < - 5D10],TMT = [CARDBUF < - 5D22],TVC = [CARDBUF < - VALUE],
   I \text{ HIT} = [HIT=1B1 I,ISTD = {STAND=1B1}, IBRK = {BROKE=1B1},CLS = [SCORE <math>- 5D0]</math>,ADD=[SCORE <-(SCORE(+)CARDBUF)TAIL 51,
   KFF = [FF < -1D0], JFF = [FF < -1D1]CONTROL
   A: CLS, KFF, ->B/
   B: IHIT, TVC, IF YCRD THEN ->C ELSE ->B ENDIF/
   c: IF YCRD THEN ->C ELSE ->D ENDIF/<br>D: ADD, IF NACE+FF THEN ->F ELSE ->
      ADD, IF NACE+FF THEN ->F ELSE ->E ENDIF/
   E: JFF, TPT, ->D \wedgeF: IF YL17 THEN ->BELSE IF YL22 THEN ->JK
                              ELSE IF FF THEN ->D ENDIF,
                                    KFF, TMT
                ENDIF ENDIF/
   JK: IF YL22 THEN ISTD ELSE IBRK ENDIF,
        IF YCRD THEN ->A ELSE ->JK ENDIF/.$
```
The third machine is functionally equivalent to the first two, but its state is encoded in a state sequencing register Q consisting of three J-K flip-flops. The characteristic functions and input equations for register Q are given in operation NS. The next state in this machine is then implied by the results of operation NS.

- **<sup>76</sup>**-

Note the heavy use of subscript concatenation (e.g., "Q1") in operation NS.

```
Example 3
```

```
MACH I NE."
" BLACKJACK
REGISTER SCORE[5], CARDBUF[5], FF, # Q[3:1].
TERMINAL HIT, BROKE, STAND, TMP,
   J[3:1], K[3:1],VALUE[1:5] = INPUT(1,VALUE),
   YCRD = INPUT(1,YCRD),YL17 = SCORE <17, YL22 = SCORE <22,
   NACE = CARDBUF#1.OPERATION
   NS = [TMP = YCRD,J1 = -Q3*(FF+NACE)+-Q2*-Q3,K1 = Q2* - Q3* - TMP + -Q2*Q3 + Q3*-YLI7*YL22,Q1<- CASE J1 CON K1 DO 1D0 DO 1D1
                             DO -Q1 DO Q1 ENDCASE,
         J2 = Q1 * Q3 * FF + Q1 * - Q3 * TMP,K2 = Q1 * Q3,
         Q2<- CASE J2 CON K2 DO 1D0
                                     DO 101
                             DO -Q2 DO Q2 ENDCASE,
         J3 = -Q1*Q2,
         K3= 33 + -Q1*TMP + Q2*YL17 + Q1*-Q2*FF,
         Q3<- CASE J3 CON K3 DO 1D0 DO 1D1
                             DO -Q3 DO 03 ENDCASE],
   TPT = [CARDBUF < - 5D10],TMT = [CARDBUF < - 5D22],
   TVC = [CARDBUF < - VALUE],
   IHT = [HIT=1B1],ISTD = [STAND=1B1], IBRK = [BROKE=1B1],CLS = [SCORE < - 5D0],ADD=[SCORE <- (SCORE(+)CARDBUF)TAIL 51,
   KFF = [FF<-1D0], JFF = [FF<-1D1 1CONTROL
   A(0): CLS, KFF, NS/
   B(1): IHIT, TVC, NSZC(3): NS/
   D(2):ADD, NS/
   E(6): TPT, JFF, NS/
   FG(7): NSZTMT, KFF, NS/
   H(5):JK(4): IF YL22 THEN ISTD ELSE IBRK ENDIF, NS/. $
```
 $-77 -$ 

The fourth example has two finite state machines. The top level machine simply sets terminals which are interpreted by the lower level machine. On receipt of a signal START, the system computes the sum of the 256 words of MEM. Note the destructive-read/restore sequence simulated by the lower level machine.

#### Example 4

W EXAMPLE OF INTERPRETIVELY LINKED MACHINE <sup>W</sup> REGISTER At **161,** B[161, ADDR[81. MEMORY MEM[O:255, **161.** YCLR, YINC, YADD, YREAD,  $NDONE = ADDR + 255$ , START = INPUT **(1,** START). OPERATION CLEAR = [A <- 16D0, ADDR <- 8D0], INC =  $[ADDR < - ADDR(+)8D1 TAIL 81]$ , ADD =  $[A \leftarrow A(+)B TAIL 161]$ ,  $READ = [B \le - MEM[ADDR],$  $MEM[ADDR] = 16D0$ ],  $RESTORE = [MEM[ADDR] = Bl.$ CONTROL  $P1: IF START THEN YCLR a. YREAD a. ->P2$ ELSE ->Pl ENDIF/  $P2: YADD$  a. IF NDONE THEN YINC ii), YREAD  $\varpi, ->P2$ ELSE ->P1 ENDIF/ CONTROL **Ql:** IF YINC THEN INC ENDIF, IF YCLR THEN CLEAR ENDIF, IF YADD THEN ADD ENDIF, IF YREAD THEN ->Q2 ELSE ->Q1, LEVEL ENDIF/  $Q2: READ, ->Q3$ Q3: RESTORE, LEVEL, ->Q1/.\$

The last example shows terminals and operations with parameters. The concatenation in terminals SUM and AND ensures that the results are at least 16 bits long, even for short operands. Note that the actual parameters may be of varying lengths, and the formal parameters of EXM may be used as the actual parameters of SUM and AND.

Example 5

```
MEMORY R[1:16].
TERMINAL S1[1:2]=INPUT(1,S1),
          S2[1:2]=INPUT(1,S2),
          L1[1:12]=INPUT(1,L1),
          L2[1:12]=INPUT(1,L2),
          SUM(Al,A2)[1:161=(16DO CON (Al(+)A2)) TAIL 16,
          AND(Al,B2)[1:161=(16DO CON (Al * B2)) TAIL 16.
OPERATION EXM(X,Y)=[
         R = SUM(X, Y), OUTPUT(1,R),
         R=AND(X,Y), OUTPUT(1,R)<sup>1</sup>.
CONTROL Q: EXM(S1, S2), EXM(L1, L2), ->Q/. $
\sim \sim
```
## Chapter 10

#### HOW TO RUN DDL-P

The procedure for using DDL-P should be roughly the same on any TOPS-20 installation; only the file names should differ. The procedure described below for Stanford LOTS is typical.

- **1.** Prepare the DDL-P description. The file containing the description may have any valid file name with the following restrictions:
	- i) The file name (excluding extension) must have no more than six characters.
	- ii) The extension must have no more than three characters.
- 2. Type the RUN command for DDL-P. At Stanford LOTS, the command is ?9<sources.ddl>ddl .
- 3. DDL-P will prompt for INPUT and OUTPUT file names. If a directory specification is to be supplied with a file name, then it must be in the form of a PPN in brackets following the file name, e.g., DESC.DDL[4,524] The INPUT file is the DDL-P description. A listing is written to the OUTPUT file; also, any simulation-time disk output goes to the same file.
- 4. DDL-P will now ask for a third file name, "DDLINI = ". At Stanford LOTS, respond with the file name

DDL,INI[4,1550] .

 $- 80 -$ 

- 5. After prompting for the above file names, DDL-P will type TO CONTINUE, HIT THE RETURN KEY \* and wait for a line of input. Just press <RETURN> to get started.
- 6. If there are no fatal errors, DDL-P will request the radix to be used for all output. Choose base 2, 4, 8, 10, or 16.
- 7. The ">" prompt will be printed indicating readiness to accept simulation commands. Use of the DDL-P Simulator is described in DDL-P Command Lanquaqe Manual [2].

# Chapter 11

# SAMPLE COMPILER OUTPUT

The listings generated by the DDL-P compiler for two examples from Chapter 9 are shown on the next two pages. SIMADDR is an internal location counter; the values of SI-MADDR included in the listing are useful for pinpointing the places where simulation errors occur.

SIMADDR

 $\ddot{\bullet}$  .

I





 $-83 -$ 

## SIMADDR

 $\sigma_{\rm{max}}$ 

 $\overline{\phantom{a}}$ 





 $-84 -$ 

## Appendix A

#### ERROR MESSAGES

The error messages issued by the DDL-P compiler are listed below, along with their severity codes. When the compiler detects errors in the DDL-P description, DDL-P lists the appropriate error message both at the teletype and in the listing file.

DDL-P will halt compilation immediately if an error of severity ABORT appears. Such an error occurs when DDL-P \* runs out of memory. If FATAL errors are detected, the compilation will proceed to completion, but simulation will not be allowed. If the most severe errors are WARNINGS, then simulation will be allowed.

A brief discussion of a few of the errors follows the list.



 $- 85 -$ 

warning fatal fatal fatal fata l fatal fatal warning fata l fata l fatal fata l fatal fata l fatal fatal fatal fata l fata l fatal fatal fatal fata l fatal fata l fatal  $·$  fatal fatal fatal fatal fatal fatal warning warning fatal fatal fatal fata l fatal fatal fatal fata l fatal fatal fatal fatal fatal fatal "END" not expected here " T H E N " not expected here " E L S E " not expected here "ENDIF" not expected here  $1$ DO<sup> $n$ </sup> not expected here 'ENDCASE" not expected here ";" not expected here <sup>11 11</sup> not expected here Undeclared identifier Multiply-defined identifier Too many dimensions (just 2 allowed) This identifier may not be subscripted Two-dimensional array requires subscript This identifier may only have 1 subscript Field can't be used to denote range of words Subscripting nested too deeply (>10 levels) Improper field or access to non-existent bits Too many dimensions (>2) or invalid field Formal parameter subscripted Predef ined terminal subscripted More than 63 arguments Missing argument list Wrong number of arguments This identifier may not have arguments This identifier not allowed in expression Operation identifier not allowed in expr. Output operation not allowed in expression Need >l case in conditional expression Constants required in field in declaration State sequencing register too big' State sequencing reg. can't have 2 dimensions Predefined terminal may not have 2 dimensions Delayed store will be changed to immediate Immediate store will be changed to delayed More than two-part concatenation Formal parameter may not appear in I/O list Operation identifier not allowed in I/O list Predefined terminal not allowed in input list Improper label (wrong type) Illegal use of label defined in other section Undefined state label referenced Undefined statement label referenced Assignment to identifier of wrong type Operand must be terminal (and not predefined) No SSR specified for this I.L.M. level Value too big to fit into SSR Same SSR value assigned to different states More than 7 I.L.M. levels are not allowed

**- 86 -**



The term "predefined terminal" refers to a terminal for which a function was specified in the TERMINAL declarations (Sections 6.2-6.3). An \*\*argument\*\* is the same as an "actual parameter.\*\*

The abbreviation "I.L.M." stands for "interpretively linked machine," Section 8.4, while "SSR" stands for "state sequencing register." . -

The message

## SYNTAX ERROR

flags many kinds of errors in DDL-P descriptions. In case of such errors, the designer should refer to the DDL-P BNF to determine the proper syntax.

DDL-P allocates table space of 2\*\*n words for a state sequencing register of width n bits. The message

STATE SEQUENCING REGISTER TOO BIG

 $- 87 -$ 

will appear only if the register is wider than 35 bits. However, a MEMORY OVERFLOW problem is likely for state sequencing registers wider than, say, 10 to 12 bits.

The error message

## MORE THAN TWO-PART CONCATENATION

refers only to concatenation in the left hand side of an immediate or delayed store ("=" or "<-"). In general, an arbitrary number of operands may be concatenated in Boolean expressions. (However, the width of the result must not exceed 256 bits.1

If the error

TOO MANY CONDITIONAL CASES (TRY NESTING) \* occurs (it won't unless the number of conditional cases is well into the hundreds), then it may be corrected by nesting, as illustrated below. The two examples are equivalent, but the one on the right uses nesting.



# Appendix B

## DDL-P BNF

The complete Backus-Naur Form for DDL-P is listed below. Non-terminals are written in lower-case letters and underscore; "ddl\_description" is a non-terminal, e.g.  $\text{All}$ other symbols are terminals except for the following special symbols ("meta-symbols"):

- : :  $=$  $REPLACEMENT$  SYMBOL - Left-hand side may be replaced by right-hand side.
- enclosed in braces is optional. 1 I . - OPTIONAL STRING SYMBOL - String of symbols
- <sup>1</sup> 3\*\*\* REPETITION SYMBOL String of symbols enclosed **may** appear zero or more times in succession.
- II CONCATENATION SYMBOL Symbol on left must be concatenated with symbol on right (i.e., with no intervening blanks or end-of-line).
- <sup>I</sup> OR SYMBOL This separates several right-hand sides of productions.

 $- 90 -$ 

In a DDL description, a comment is any string of symbols except double-quote (") enclosed in double-quotes and contained on one line, e.g., "THIS IS A COMMENT". A comment may appear anywhere a blank is permitted.

The REGISTER, MEMORY, TERMINAL, OPERATION, and CONTROL declaration sections may be terminated by "END" instead of period ".". The underscore "\_" may be used as the delayed store action in place of "<-".

```
letter :: = A|B|C|D|E|F|G|H|I|J|K|L|M|NOPQRSTUVUXXYZ
            albicidielfigihiijikliimi
            nlolplqlrisitiulviulxlylz
digit ::= 0111213141516171819hex-digit \cdot := digit A \cup B \cup C \cup D \cup E \cup Foctal-digit ::= 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7
quartal_digit ::= 0 | 1 | 2 | 3
bit \qquad \qquad : = 0 \quad | \quad 1decimal-constant ::= digit { II digit } ***
constant ::= decimal-constant
        I decimal-constant II B { II . } II bit
                                            \{ II bit \}***
        I decimal-constant \parallel Q \parallel \parallel . }
                               I I quartal digit
                            \{ \blacksquare Il quartal_digit }***
        I decimal-constant II 8 { II . }
                               Il octal-digit
                            \{ \parallel octal-digit \}***
        I decimal-constant II D II decimal-constant
        I decimal-constant \parallel H { \parallel . }
                              ll hex-digit
                            { II hex-digit } ***
```
 $-91 -$ 

letter-or-digit ::= letter **I** digit identifier ::= letter { **II** letter-or-digit }\*\*\* field ::= boolean-exp : boolean-exp identifier-ref ::= identifier **<sup>I</sup>** identifier **II** decimal-constant **<sup>I</sup>** identifier 1 boolean-exp I **<sup>I</sup>** identifier **II** decimal-constant 1 boolean-exp <sup>I</sup> I identifier [ boolean-exp 1 [ boolean-exp I **<sup>I</sup>** identifier 1 boolean-exp , boolean-exp 1 **<sup>I</sup>** identifier [ field I **<sup>I</sup>** identifier **II** decimal-constant [ field 1 **<sup>I</sup>** identifier 1 boolean-exp 1 1 field 1 **<sup>I</sup>** identifier 1 boolean-exp , field 1 terminal-ref ::= identifier ( boolean-exp  $\{$ , boolean\_exp}\*\*\* ) reference ::= identifier-ref **I** terminal-ref boolean-exp ::= minterm  $\{ + \text{minterm } } \$ \*\*\* minterm  $::=$  product  $\{ \mid + \mid \text{ product } \}$ \*\*\* product ::= complement 1 \* complement I\*\*\* complement ::= {-} reduction { CON reduction } \*\*\* reduction ::= adjustment **I** + RED adjustment **I** \* RED adjustment  $\iota$  **i** + 1 RED adjustment **I** (+I RED adjustment adjustment ::= relation **I** adjustment EXT arithmetic-exp **I** adjustment TAIL arithmetic-exp **I** adjustment HEAD arithmetic-exp

```
relation ::= arithmetic-exp
           I arithmetic-exp (=) arithmetic-exp
           I arithmetic-exp # arithmetic-exp
           I arithmetic-exp < arithmetic-exp
           I arithmetic-exp > arithmetic-exp
            I arithmetic-exp >= arithmetic-exp
           I arithmetic-exp <= arithmetic-exp
arithmetic-exp ::= { (- ) } l term
                 I arithmetic-exp (+I term
                 l arithmetic-exp (-) term
term ::= reference
     I INPUT(constant,identifier_ref
                    C,identifier-refj***)
     I CASE boolean-exp DO boolean-exp
                        DO boolean-exp
                      1 DO boolean-exp I*** ENDCASE
     I *boolean_exp* boolean-exp ; boolean-exp
                                 \{; boolean_exp}*** .
     I IF boolean-exp THEN boolean-exp
                      ELSE boolean-exp ENDIF
     I constant
     I ( boolean-exp 1
dd1_description ::= declaration {operation_decl}
                                  control-dec1 \{\\}
declaration ::= register-decl {memory_decl}
                               {terminal_decl3
             I memory-decl {terminal_decl}
             I terminal-decl
register-decl ::= REGISTER register-spec
                        \{, reqister-spec \}*** .
register-spec ::= {#} identifier
                        \{ [ \{ constant: ) constant 1 \}I identifier 1 {constant:1 constant ,
                            {constant:} constant I
memory-decl ::= MEMORY memory-spec
                            \{, memory-spec \}*** .
memory-spec ::= identifier {[ {constant:} constant ]}
             I identifier 1 {constant:} constant ,
                               {constant:} constant 1
```
 $-93 -$ 

```
terminal-decl ::= TERMINAL terminal-spec
                          \{, terminal-spec \}***.
terminal-spec ::= identifier
                          \{ \begin{array}{c} \{ \\ \end{array} \} constant 1 }
              \int identifier \int (constant:) constant,
                               {constant:} constant 1
              I identifier
                       { (identifier {,identifier}*** ) }<br>{ [{constant:} constant] }
                                               = boolean-exp
operation-decl ::= OPERATION operation-def
                             \{, operation_def}***.
operation-def ::= identifier{ (identifier {, identifier}*** ) }
                       = [ action [, action]*** ]
action :: = identifier-ref \ {CON identifier-ref}<- boolean-exp
           identifier-ref {CON identifier_ref}
         \mathbf{I}= boolean-exp
         i identifier-ref a
         I INPUT ( constant , identifier-ref
                             { , identifier-ref }*** )
         \mathbf{L}OUTPUT ( constant , reference
                              {, reference }*** )
           identifier { ( boolean-exp
         \mathbf{I}{ , boolean-exp } * * ) }
         \overline{1}CASE boolean-exp
               DO action { , action } ***
              { DO action { , action } *** } *** ENDCASE
            ¢boolean_exp¢
         \mathbf{I}action \{ , action \}***
             \{ ; \text{ action } \{ , \text{ action } \} *** I*** .
           IF boolean-exp
         \overline{1}THEN action { , action } ***
             { ELSE action { , action }*** } ENDIF
           TIME boolean-exp
         | -> identifier
           identifier : action
         \perpcontrol-decl :: = level-decl { level-decl }level-decl ::= CONTROL state-def { state-def }***
```
 $-94 -$ 

```
state-def ::= {identifier { (constant) } :}
                { state-action {, state-action}*** } /
state-action :: =identifier { (boolean-exp {, boolean_exp}***) }
     I identif ier_ref @
     | -> identifier
     | => identifier
     | RETURN
     I CASE boolean-exp
              DO state-action {, state-action}***
            { DO state-action {, state_action}*** }***
              ENDCASE
     I ¢boolean_exp¢ state-action {, state_action}***
                  {; state-action
                  \{ , state-action}*** }*** .
     I IF boolean-exp
              THEN state-action {, state-action}***
            { ELSE state-action {, state_action} *** }
              ENDIF
     | LEVEL
```
#### REFERENCES

- **1.** Arndt, R.L. and Dietmeyer, D.L. "DDLSIM--A Digital Design Language Simulator," Proc. National Electronics Conf **.,** Vol. 26, pp. **116-118,** December 1970.
- 2. Cory, W.E., Duley, J.R., and vanCleemput, W.M. DDL-P Command Lanquaqe Manual. Palo Alto: Stanford University, Computer Systems Laboratory, March **1979,** 39 pp.
- 3. Dietmeyer, D.L. and Duley, J.R. "Register Transfer Languages and Their Translation" in Disital System Desiqn Automation:. Lanquaqes, Simulation and Data Base. Woodland Hills, CA.: Computer Science Press, Inc., 1975, pp. 117-218.
- 4. Dietmeyer, D.L. Translation of DDL Descriptions of Digital Systems, ECE-77-13. Madison: U. of Wisconsin, Dept. of Electrical and Computer Engineering, September **1977, 46** pp.
- 5. Duley, J.R. DDL<sup>--</sup>A Disital System Desisn Language. Madison: U. of Wisconsin, Ph.D. Thesis, **1967.**
- 6. Duley, J.R. and Dietmeyer, D.L. "A Digital System Ey, U.R. and Brownight, There is a series of vol. c-17 (September **19681,** pp. 850-861.
- 7. Duley, J.R. and Dietmeyer, D.L. "Translation of a DDL Digital System Specification to Boolean Equations," IEEE Trans. Camp. Vol. C-18 (April **19691,** pp. **305-313 .**
- 8. N, Diqital Desiqn Lanquage Translator--DDLTRN. Madison: U. of Wisconsin, Dept. of Electrical and Computer Engineering, 13 pp.

 $-96$   $-$ 

9. N, Disital Desisn Lanquaqe Simulator--DDLSIM. Madison: U. of Wisconsin, Dept. of Electrical and Computer Engineering, 36 pp.

ł

**10.** Soares, L.E.R. An Implementation of Diqital Desisn Lanquaqe. Madison: U. of Wisconsin, Dept. of Electrical and Computer Engineering, M.S. thesis, 1970.