



# AIM

Association for Information and Image Management

1100 Wayne Avenue, Suite 1100  
Silver Spring, Maryland 20910  
301/587-8202

## Centimeter



Inches



MANUFACTURED TO AIIM STANDARDS  
BY APPLIED IMAGE, INC.

1 of 1

**Final Report  
Support for Development of a  
Custom VLSI and FPGA Logic Chips based on a  
VHDL Top-Down Design Approach**

**Subcontract Number:  
2676L0013-9Q**

**Prepared by:  
InnovASIC, Inc.  
1107 Woodland NW.  
Albuquerque, NM 87107**

**Prepared for:  
University of California  
Los Alamos National Laboratories  
SST-11  
P.O. Box 990  
Los Alamos, NM 87545**

**DISCLAIMER**

This report was prepared as an account of work sponsored by an agency of the United States Government. Neither the United States Government nor any agency thereof, nor any of their employees, makes any warranty, express or implied, or assumes any legal liability or responsibility for the accuracy, completeness, or usefulness of any information, apparatus, product, or process disclosed, or represents that its use would not infringe privately owned rights. Reference herein to any specific commercial product, process, or service by trade name, trademark, manufacturer, or otherwise does not necessarily constitute or imply its endorsement, recommendation, or favoring by the United States Government or any agency thereof. The views and opinions of authors expressed herein do not necessarily state or reflect those of the United States Government or any agency thereof.

**MASTER** 06/2003  
2003

ALL INFORMATION CONTAINED IN THIS DOCUMENT IS UNCLASSIFIED

### Abstract

The objective of this contract was to perform the beginning stages of development for two Application Specific Integrated Circuits: CMOS-1 and CMOS-2D. This work includes specification writing, behavioral modeling, and beginning design. In addition, the design work is required to be done in the VHSIC Hardware Description Language (VHDL).

InnovASIC, Inc. completed all the tasks required of this contract. The specifications were written, VHDL for CMOS-1 was completed, a behavioral model of CMOS-2D was written, and a system simulation was performed.

### Contract Objectives

This section describes the objectives as defined in the Statement of Work, and the accomplishments toward achieving each objective.

I. Methodology Development. This task required the development of a design methodology that was used in the remaining tasks. To achieve this objective, InnovASIC, Inc. wrote a document named Development Plan for the CMOS-1 ASIC. This document is included in Attachment 1.

II. Specification Generation. This task required the development of a specification that describes the functional requirements of the CMOS-1 ASIC. InnovASIC, Inc. wrote a specification named Specification for the CMOS-1 ASIC to accomplish the objective. This document is included in Attachment 2.

III. Partitioning. The partitioning task was to result in the breakdown of the design into pieces that are codable and synthesizable in VHDL. Although no formal documents were developed for this task, the partitioning can be seen from the VHDL code structure.

IV. CMOS-1 RTL Model Development. This task was the major task of the contract. It required writing VHDL code for each of the partitions described above, simulating each piece individually, tying all the pieces together, and simulating the whole entity. This was accomplished by coding the VHDL on a Personal Computer, simulating each piece using the Model Technologies Simulator, writing a Test Bench in VHDL, and simulating the entire design. The following figure shows the file structure used to create the design.

|                                  |                                     |                                              |                                                 |                                                   |                                        |
|----------------------------------|-------------------------------------|----------------------------------------------|-------------------------------------------------|---------------------------------------------------|----------------------------------------|
| Testbench<br><b>testbnch.vhd</b> | Top-level CMOS-<br>l<br>cl_func.vhd | Input Stage<br><b>in_stg.vhd</b>             | DDS entity<br><b>dds_ent.vhd</b>                | Timetag counter<br><b>timetag.vhd</b>             |                                        |
|                                  |                                     | Data Driven<br>Storage<br><b>dds_top.vhd</b> |                                                 |                                                   | Mode Control<br><b>modecntl.vhd</b>    |
|                                  |                                     |                                              |                                                 | Storage<br><b>stor_ent.vhd</b>                    | counter<br><b>cnt3_ent.vhd</b>         |
|                                  |                                     |                                              |                                                 |                                                   | comparator<br><b>comp_ent.vhd</b>      |
|                                  |                                     |                                              |                                                 |                                                   | memory<br><b>mem_ent.vhd</b>           |
|                                  |                                     | Compression<br>Engine<br><b>compress.vhd</b> | compression<br>register<br><b>compreg.vhd</b>   |                                                   |                                        |
|                                  |                                     |                                              | header builder<br><b>header.vhd</b>             |                                                   |                                        |
|                                  |                                     |                                              | edge detector<br><b>edge_ent.vhd</b>            |                                                   |                                        |
|                                  |                                     |                                              | hit detector<br><b>hitlogic.vhd</b>             |                                                   |                                        |
|                                  |                                     |                                              | edge counter<br><b>edgcount.vhd</b>             |                                                   |                                        |
|                                  |                                     |                                              | block counter<br><b>selcount.vhd</b>            |                                                   |                                        |
|                                  |                                     |                                              | input mux<br><b>mux16.vhd</b>                   |                                                   |                                        |
|                                  |                                     |                                              | compressor<br>controller<br><b>compcntl.vhd</b> |                                                   |                                        |
|                                  |                                     | Output Stage<br><b>out_stg.vhd</b>           | read out<br>controller<br><b>rd_cntl.vhd</b>    |                                                   |                                        |
|                                  |                                     |                                              | output buffer<br><b>omem_ent.vhd</b>            |                                                   |                                        |
|                                  |                                     |                                              | Hit tracker<br><b>hitrckr.vhd</b>               |                                                   |                                        |
|                                  |                                     |                                              | Buffer write<br>control<br><b>wrt_cntl.vhd</b>  | Write address<br>generator<br><b>wadd_ent.vhd</b> | address counter<br><b>cnt5_ent.vhd</b> |
|                                  |                                     |                                              |                                                 |                                                   | Math Package<br><b>math_pak.vhd</b>    |

Extensive simulations were run on the VHDL code to make sure the design met LANL's requirements. This was reviewed during the code review as described below. A partial simulation result is shown in the following diagram. In addition to the above code, JTAG code for the CMOS-1 chip was generated. This code was not fully tested or integrated into the entire simulation.

All code generated is contained on the floppy disk delivered with this document, as well as printed in Attachment 3.

**V. CMOS-2 Specification Generation.** This task entailed generating a preliminary specification for the CMOS-2D ASIC. InnovASIC, Inc. wrote a specification named Specification for the CMOS-2D ASIC to accomplish the objective. This document is included in Attachment 4.

**VI. CMOS-2 Behavioral Model/System Simulation.** This task was the culmination of the effort for the contract. The first objective was to write, in VHDL, a behavioral model of the CMOS-2D chip. The second objective was to modify the testbench to tie the CMOS-2 behavioral model together with 5 instantiations of the CMOS-1 model, and simulate the two together. InnovASIC completed the task using the Model Technologies Simulator on a Personal Computer. The following file structure under the CMOS-2 directory was used for this:

Test Bench  
**testbch.vhd**

CMOS-1 model As shown above  
**c1\_func.vhd**

CMOS-1  
behavioral  
model  
**behave.vhd**





## **VII. Design Reviews**

3 Design reviews were held at Los Alamos National Laboratories. The first was the Specification review held on July 28, 1993. The objective of this was to review the CMOS-1 specification to ensure that it meet LANL's needs.

The second review was the code review held on September 1st. The objective was to review the CMOS-1 code and simulation results of the CMOS-1 VHDL model. The code structure was reviewed and a simulation was run at LANL's site.

The third review was held on September 30, and was a final review. The objective of the review was to go over the CMOS-2 simulation results and cover any issues related to what is needed for completion of the ASIC design. The simulation results were reviewed, and the issues as shown in the Issues section of this document were discussed.

## Deliverables

The following is a list of items delivered for this contract. All of them have been included on the floppy disk included with this document.

I. Development Plan. Included in this document as attachment 1, and on the floppy in WordPerfect 5.1 format.

II. CMOS-1 Specification. Included in this document as attachment 2, and on the floppy in WordPerfect 5.1 format.

III. Vendor study Statement of Work. Included in this document as attachment 5, and on the floppy in WordPerfect 5.1 format.

IV. CMOS-2 Specification. Included in this document as attachment 4, and on the floppy in WordPerfect 5.1 format.

V. VHDL code. Included in this document as attachment 3, and on the floppy in ASCII text format.

VI. Simulation Files. Files included in the ./source/test directory on the floppy with an extension of .do are the files used to simulate the individual entities of the design. The file ./source/test/testvect.txt contains the test vectors used to simulate the CMOS-1 design. The file ./cmos2/testvect.txt contains the test vectors used to simulate the CMOS-1/CMOS-2 system.

## Issues

- I. Tasks needed to be completed for a final ASIC design
  - A. The JTAG code must be completed and integrated with the rest of the CMOS-1 code.
  - B. The specifications should be scrubbed thoroughly and revised.
  - C. The CMOS-1/CMOS-2D system should be reviewed to determine if the manner it is handling hit and trigger overloads is adequate. There is a question whether the system will perform well if more triggers are received than can be processed.
  - D. The CMOS-2 synthesizable VHDL needs to be written.
  - E. Area studies should be performed on both CMOS-1 and CMOS-2.
  - F. The handling of adders needs to be modified to fit into Mentor Graphics synthesis scheme.
  - G. Full VHDL simulation with both CMOS-1 and CMOS-2 synthesizable code should be run.
  - H. Synthesis, gate simulation, layout, etc.
- II. The interface between the analog and digital portions of the system are not completely defined. This needs to be faced before the entire system can be finished.

DATE  
FILMED

7/8/94

END

