# microSPARC<sup>TM</sup>-IIep Design Application Note



THE NETWORK IS THE COMPUTER

901 San Antonio Road Palo Alto, CA 94303 USA 650 960-1300 fax 650 969-9131

Part No.: 806-2519-01 Revision 01, September 1999 Copyright © 1999 Sun Microsystems, Inc. All rights reserved. The contents of this documentation is subject to the current version of the Sun Community Source License, microSPARC-II ("the License"). You may not use this documentation except in compliance with the License. You may obtain a copy of the License by searching for "Sun Community Source License" on the World Wide Web at http://www.sun.com. See the License for the rights, obligations, and limitations governing use of the contents of this documentation.

Sun Microsystems, Inc. has intellectual property rights relating to the technology embodied in this documentation. In particular, and without limitation, these intellectual property rights may include one or more U.S. patents, foreign patents, or pending applications.

Sun, Sun Microsystems, the Sun logo, all Sun-based trademarks and logos, Solaris, Java and all Java-based trademarks and logos are trademarks or registered trademarks of Sun Microsystems, Inc. in the United States and other countries. microSPARC is a trademark or registered trademark of SPARC International, Inc. All SPARC trademarks are used under license and are trademarks or registered trademarks of SPARC International, Inc. in the U.S. and other countries. Products bearing SPARC trademarks are based upon an architecture developed by Sun Microsystems, Inc.

THIS PUBLICATION IS PROVIDED "AS IS" AND ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE DISCLAIMED, EXCEPT TO THE EXTENT THAT SUCH DISCLAIMERS ARE HELD TO BE LEGALLY INVALID.

THIS PUBLICATION COULD INCLUDE TECHNICAL INACCURACIES OR TYPOGRAPHICAL ERRORS. CHANGES ARE PERIODICALLY ADDED TO THE INFORMATION HEREIN; THESE CHANGES WILL BE INCORPORATED IN NEW EDITIONS OF THE PUBLICATION. SUN MICROSYSTEMS, INC. MAY MAKE IMPROVEMENTS AND/OR CHANGES IN THE PRODUCT(S) AND/OR THE PROGRAM(S) DESCRIBED IN THIS PUBLICATION AT ANY TIME.





# microSPARC<sup>TM</sup>-IIep Design Application Note

This document explains how to set up and run a simulation of the microSPARC-IIep design. It contains the following sections:

- Directory Structure on page 3
- *Tool Requirements* on page 4
- Setup of the Simulation Environment on page 4
- Creation of the RTL Model on page 6
- *Simulation* on page 7
- Appendix A: Warning Messages During Compilation on page 9
- Appendix B: Error and Warning Messages During Simulation on page 20

# **Directory Structure**

TABLE 1 details the directory structure for the microSPARC-IIep design database.

TABLE 1 Database Directory Structure

| Directory | Contents                                                                                                                       |
|-----------|--------------------------------------------------------------------------------------------------------------------------------|
| diag      | Diagnostic routines and executables for Cadence Verilog-XL and Synopsys VCS                                                    |
| docs      | Documentation and Verilog design code in HTML format                                                                           |
| env       | Executables and scripts for running the simulation and compilation of the results                                              |
| lib       | Generic components for design and RTL simulation                                                                               |
| log       | Simulation results. You can change this path according to the path for the environment variable RESULTSDIR in the .cshrc file. |

TABLE 1 Database Directory Structure (Continued)

| Directory | Contents                                                            |
|-----------|---------------------------------------------------------------------|
| ssparc    | Design code                                                         |
| system    | Files related to the test bench                                     |
| tools     | ssparc tools, such as Verilog PLI routines and PCI interface models |

## Tool Requirements

To simulate the source distribution for the microSPARC-IIep design, you must use the following tools:

- Sun<sup>TM</sup> C compiler
- Perl (version 4.0) Use Perl to run some of the simulation scripts, which may refer to the absolute path location of Perl. In that case, edit those scripts and point to the location in your environment, where you have installed Perl.
- A Verilog simulator Use a simulator such as Cadence Verilog-XL (version 2.7.x) or Synopsys VCS (version 4.0.1) on the Solaris 2.5.x operating environment or a compatible version.

**Note** — The microSPARC-IIep design kit supports the Sun C compiler only. Though the design may function correctly with other Verilog simulators, Sun has tested the microSPARC-IIep RTL core with Cadence Verilog-XL and Synopsys VCS only. In addition, that design kit uses the Sun make utility and does not support GNU make.

# Setup of the Simulation Environment

To set up the simulation environment, do the following:

1. Assuming you use the csh shell, edit the user.cshrc file in the env directory to reflect the correct paths and define the appropriate environment variables and paths for the Verilog simulator and C compiler.

A template of the user.cshrc file, as shown in CODE EXAMPLE 1, is in: \$SPARCV8HOME/\$PROJECT/user.cshrc. Comments are preceded by the # symbol.

```
### Set the environment variable SPARCV8HOME, as follows.
setenv SPARCV8HOME directory-where-you-untarred-the-distribution
setenv PROJECT sparc_v8
### Set the environment variables for the Sun C compiler, as follows.
setenv CC_PATH path-for-the-Sun-C-compiler
setenv CC_NAME cc
### Set the environment variable RESULTSDIR, which points to the directory
### where to store regression results, as follows. Create one if that directory
### does not exist. By default, it points to:
### $SPARCV8HOME/$PROJECT/log/results.
### You must create the directories SPARCV8HOME/$PROJECT/log and
### SPARCV8HOME/$PROJECT/log/results.
setenv RESULTSDIR $SPARCV8HOME/$PROJECT/log/results
### Set the paths for the Verilog executables, as follows.
# Define the location of simv, the Synopsys VCS executable compiled with the RTL
# code.
setenv SIMV_PATH $SPARCV8HOME/$PROJECT/diag/vcs
# If you plan to run RTL simulations with Cadence Verilog-XL, set the following
# environment variables.
setenv VERITOOLS_PATH path-to-the-Verilog-tools-directory
seteny VLOG PATH path-to-the-Verilog-directory
# Example: setenv VLOG_PATH $VERITOOLS_PATH/verilog
setenv VLOG_NAME generated-executable-of-Verilog-XL-
# Example: setenv VLOG_NAME my_verilog
# Define the location of vlist, the configuration file that lists the Verilog
# files that are required to run simulations.
setenv VLIST_PATH $SPARCV8HOME/$PROJECT/diag
# Set the Library path for the tools.
setenv LD_LIBRARY_PATH ${LD_LIBRARY_PATH}:$VERITOOLS_PATH/lib
```

#### CODE EXAMPLE 1 Contents of the user.cshrc Template File In the env Directory

- # Set the path for the additional library for compilation of the Verilog-XL
  # executable.

  setenv LD\_LIBRARY\_PATH \${LD\_LIBRARY\_PATH}:\${VERITOOLS\_PATH}/tools/lib

  # If you plan to run RTL simulations with Synopsys VCS, ensure that VCS is on
  # your path. Also, define the environment variables for running VCS and their
  # paths.

  # Define the environment variables and paths for the EDA tools.

  # Source the project-specific environment variables.

  source \$SPARCV8HOME/\$PROJECT/env/project.cshrc
  rehash
  - 2. Source the user.cshrc file by typing:
    - % source user.cshrc

## Creation of the RTL Model

Next, you must create the RTL model by generating the Verilog executables for the Cadence Verilog-XL or Synopsys VCS compiler. Then take the following step:

- If you use the Synopsys VCS simulator, type:
  - % makevcs

#### If you use the Cadence Verilog-XL simulator, type:

% makeverilog

For Verilog-XL, you can change the name of the executable by modifying the VLOG\_NAME environment variable in the user.cshrc file, as described in the previous section.

For information on the warnings displayed during compilation, see *Appendix A:* Warning Messages During Compilation on page 9.

### Simulation

Before running the simulation, do the following:

1. Create a directory to store the results from the simulations.

The default is: \$SPARCV8HOME/\$PROJECT/log/results. You must create the directories SPARCV8HOME/\$PROJECT/log and SPARCV8HOME/\$PROJECT/log/results.

**Note** — If you create a different directory, be sure to use that path name for the RESULTSDIR environment variable in the user.cshrc file.

2. Verify that you have read, write, and execute permissions for the following directories:

\$RESULTSDIR
\$SPARCV8HOME/\$PROJECT/diag/bin

3. Run the diagnostics, as follows.

The complete set of diagnostics (all.eagle.vcs and all.eagle.xl for Synopsys VCS and Cadence Verilog-XL, respectively) are in the directory \$SPARCV8HOME/\$PROJECT/env/regress/script/rtl/edo. Run the scripts that contain the diagnostic run commands.

For starters, we recommend that you run the scripts rtl\_mini\_regression and rtl\_mini\_regression.verilog\_xl, which are two scripts for running a subset of the diagnostics, rtl\_mini\_regression (for Synopsys VCS) and rtl\_mini\_regression.verilog\_xl (for Cadence Verilog-XL). These scripts are located at \$SPARCV8HOME/\$PROJECT/env/regress/script.

#### For example:

■ To run a diagnostic with Synopsys VCS, type:

% run -simm32 -vcsmodel \$SIMV\_PATH/simv -S -asm2ver datapath\_virt \
tlb32\_rst

■ To run a diagnostic with Cadence Verilog-XL, type:

% run -simm32 -S -asm2ver datapath virt tlb32 rst

#### 4. Execute the command:

% compile\_summary summary-filename

#### For example:

% compile\_summary verilog\_xl\_summary

summary-filename is the file that stores the summary of the simulation runs and resides in the SRESULTSDIR directory. It provides a synopsis of the vectors that have passed or failed. TABLE 2 lists the notations used in summary files.

TABLE 2 Notations In Summary Files

| Notation | Description                                                                                         |
|----------|-----------------------------------------------------------------------------------------------------|
| S        | Simulation errors from Verilog                                                                      |
| M        | Memory miscompares                                                                                  |
| R        | Register miscompares                                                                                |
| F        | Floating point miscompares                                                                          |
| V        | Sparse memory miscompares                                                                           |
| RDW      | <pre>N = Not used + = Warning messages present * = Differences in the sas_verilog.dif file</pre>    |
| PASF     | Diagnostics complete, but with expected error messages, memory miscompares, or register miscompares |

# Appendix A: Warning Messages During Compilation

Following is a list of some of the warning messages generated by the Synopsys VCS and Cadence Verilog-XL compilers. You can ignore them because the compilation proceeds despite these warnings.

## From the Synopsys VCS Compiler

The Synopsys VCS compiler generates the following warning messages.

```
Warning: system function $dist normal is not implemented (.../
../../sparc_v8/env/rtl/task.v line 1164)
Warning: system function $dist normal is not implemented (../
../../sparc_v8/env/rtl/task.v line 1177)
Warning: Too few module port connections
(../../sparc_v8/ssparc/mmu/rtl/mmu.v line 1011)
recompiling module fpufpc
recompiling module fpusas_sig
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/rtl/fpusas_sig.v line 107)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/rtl/fpusas_sig.v line 110)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/rtl/fpusas_sig.v line 127)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/rtl/fpusas_sig.v line 132)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/rtl/fpusas_sig.v line 135)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/rtl/fpusas_sig.v line 207)
```

```
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_ctl/rtl/microcoderom.v line 49)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v line 185)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v line 191)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v line 207)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v line 232)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v_line_237)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v_line_244)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v_line_247)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v_line_252)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v_line_270)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v line 294)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v line 297)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v line 300)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v line 303)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v line 316)
Warning: Too few module port connections
(../../sparc v8/ssparc/fpu/fp fpc/rtl/fhold ctl.v line 491)
```

```
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v_line_536)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v line 544)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fhold_ctl.v line 548)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/fp_qst.v line 198)
recompiling module qcore_ctl
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 147)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 150)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 268)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 271)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/gcore_ctl.v_line_274)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 327)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 330)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 333)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 344)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/gcore_ctl.v line 385)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 388)
```

```
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/gcore_ctl.v_line_391)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 427)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 430)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 433)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 472)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 475)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/gcore_ctl.v_line_478)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/gcore_ctl.v_line_547)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/gcore_ctl.v_line_550)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/gcore_ctl.v_line_553)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 808)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 834)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 842)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 844)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/qcore_ctl.v line 846)
Warning: Too few module port connections
(../../sparc v8/ssparc/fpu/fp fpc/rtl/gcore ctl.v line 848)
```

```
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/gcore_ctl.v line 858)
recompiling module rfrw_ctl
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/rfrw_ctl.v line 99)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/rfrw_ctl.v line 192)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/rfrw_ctl.v line 197)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/rfrw_ctl.v line 205)
recompiling module stat_ctl
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/stat_ctl.v line 113)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/stat_ctl.v line 116)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/stat_ctl.v line 176)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/stat_ctl.v line 178)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/stat_ctl.v line 180)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/stat_ctl.v line 183)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/stat_ctl.v line 184)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/stat_ctl.v line 206)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpc/rtl/stat_ctl.v line 229)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/carry51.v line 64)
```

```
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/carry51.v line 77)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/fpm_exp.v_line_117)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/fpm_exp.v line 122)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/fpm_exp.v line 127)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/fpm_exp.v_line_225)
recompiling module fpm_frac
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/fpm_frac.v_line_134)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/fpm_frac.v_line_140)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/fpm_frac.v_line_146)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/fpm_frac.v_line_222)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/fpm_frac.v line 343)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/sign.v line 59)
recompiling module special
recompiling module sticky
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/sticky.v line 64)
Warning: Too few module port connections
(../../sparc_v8/ssparc/fpu/fp_fpm/rtl/sticky.v line 69)
Warning: Too few module port connections
(../../sparc v8/ssparc/mmu/m mmu cntl/rtl/m mmu cntl.v line
1448)
```

```
Warning: Too few module port connections
(../../sparc v8/ssparc/mmu/m mmu cntl/rtl/rl mmu lqc.v line
1443)
Warning: Too few module port connections
(../../sparc_v8/ssparc/clkbuf/rtl/clkbuf_c.v line 121)
recompiling module ssparc_chip
Warning: Too few module port connections
(../../sparc_v8/ssparc/rtl/ssparc.v line 591)
recompiling module ssparc_core
Warning: Too few module port connections
(../../sparc_v8/ssparc/rtl/ssparc_core.v line 523)
Warning: Too few module port connections
(../../sparc_v8/ssparc/rtl/ssparc_core.v line 1019)
recompiling module misc
Warning: Too few module port connections
(../../sparc v8/ssparc/clk misc/misc/rtl/misc.v line 251)
Warning: Too few module port connections
(../../sparc_v8/ssparc/clk_misc/misc/rt1/misc.v_line_259)
Warning: Too few module port connections
(../../sparc_v8/ssparc/clk_misc/rl_jtag_cntl/rtl/
jtag_subblocks.v line 899)
Warning: Too few module port connections
(../../sparc_v8/ssparc/pcic/afxmaster/rtl/afxmaster.v line
1206)
Warning: Too few module port connections
(../../sparc_v8/ssparc/pcic/pci_core/rtl/pci_core.v line 751)
Warning: Too few module port connections
(../../sparc_v8/ssparc/pcic/pci_core/rtl/pci_core.v line 826)
Warning: Too few module port connections
(../../sparc_v8/ssparc/pcic/pci_core/rtl/pci_core.v line
1118)
Warning: Too few module port connections
(../../sparc v8/ssparc/pcic/pci core/rtl/pci core.v line
1272)
```

```
Warning: Too few module port connections
(../../sparc v8/ssparc/pcic/pci core/rtl/pci core.v line
1290)
Warning: Too few module port connections
(../../sparc_v8/ssparc/pcic/pci_core/rtl/pci_core.v line
1369)
Warning: Too few module port connections
(../../sparc_v8/ssparc/pcic/pci_core/rtl/pci_core.v line
1394)
Warning: Too few module port connections
(../../sparc v8/ssparc/pcic/pci core/rtl/pci core.v line
1421)
Warning: Too few module port connections
(../../sparc_v8/ssparc/pcic/rtl/pcic.v line 684)
Warning: Too few module port connections
(../../sparc_v8/ssparc/pcic/rtl/pcic.v line 1003)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/cells.v line 305)
recompiling module MflipflopR
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/cells.v line 322)
recompiling module Mflipflop noop
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/cells.v line 481)
recompiling module Mflipflop_r
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/cells.v line 450)
recompiling module Mflipflop_rh
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/cells.v line 394)
recompiling module Mflipflop_s
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/cells.v line 433)
recompiling module Mflipflop_sh
```

```
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/cells.v line 376)
recompiling module Mflipflop_sr
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/cells.v line 413)
recompiling module Mflipflop_srh
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/cells.v line 345)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/cells.v line 467)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 1852)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 1864)
recompiling module con1
recompiling module dual_adder13
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 1766)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 1774)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2179)
recompiling module FDREG_1Byte
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2186)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2187)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2188)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2189)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2190)
```

```
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2191)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2192)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2193)
recompiling module FREG_1Bit
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2199)
recompiling module FREG_1Byte
Warning: Too few module port connections
(../../sparc v8/lib/rt1/me cells.v line 2206)
Warning: Too few module port connections
(../../sparc v8/lib/rt1/me cells.v line 2207)
Warning: Too few module port connections
(../../sparc v8/lib/rt1/me cells.v line 2208)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2209)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2210)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2211)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2212)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2213)
recompiling module ME BUF C
recompiling module ME NOR2 D
recompiling module FREG_2bit
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/me_cells.v line 2554)
```

```
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/BSCN.v line 584)
816 of 853 modules done
recompiling module MEM_BI
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/BSCN.v line 320)
recompiling module MEM BI NS
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/BSCN.v line 604)
Warning: Too few module port connections
(.../.../sparc_v8/lib/rtl/BSCN.v line 474)
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/BSCN.v line 483)
recompiling module MEM OUT NS
Warning: Too few module port connections
(../../sparc_v8/lib/rtl/BSCN.v line 664)
recompiling module PCI_BI
Warning: Too few module port connections
(.../.../sparc_v8/lib/rtl/BSCN.v line 203)
```

## From the Cadence Verilog-XL Compiler

The Cadence Verilog-XL compiler generates the following warning message:

```
"/import/seagle-rgrA/cadence/project/soleil/sparc_v8/tools/
verilog/scanlink/pli/ipp.c", line 50: warning: assignment type
mismatch:
pointer to struct ipp_struct {pointer to function() returning
int accept, pointer to function() returning int close,
pointer... "=" pointer to char
```

# Appendix B: Error and Warning Messages During Simulation

Following is a list of some of the error and warning messages generated by the Synopsys VCS and Cadence Verilog-XL simulators. You can ignore them because the simulation proceeds despite these errors and warnings.

## From the Synopsys VCS Simulator

The Synopsys VCS simulator generates the following warning messages:

```
Error: DRAM at 0 rasb 1 violates tRP(ras precharge time
Error: DRAM at 0 tCSR(cas setup time(w.r.t rasb_1), CBR
refresh) violated
(rasb_low_cycle - cas_low_cycle) == 0
Error: DRAM at 0 rasb l violates tRP(ras precharge time
Error: DRAM at 0 tCSR(cas setup time(w.r.t rasb_1), CBR
refresh) violated
(rasb_low_cycle - cas_low_cycle) == 0
Error: DRAM at 0 rasb l violates tRP(ras precharge time
Error: DRAM at 0 tCSR(cas setup time(w.r.t rasb_1), CBR
refresh) violated
(rasb_low_cycle - cas_low_cycle) == 0
Error: DRAM at 0 rast_l violates tRP(ras precharge time
Error: DRAM at 0 tCSR(cas setup time(w.r.t rast_1), CBR
refresh) violated
Error: DRAM at 0 tCSR(cas setup time(w.r.t rast_1), CBR
refresh) violated
Error: DRAM at 0 tCSR(cas setup time(w.r.t rast_1), CBR
refresh) violated
```

Error: DRAM at 0 tCSR(cas setup time(w.r.t rast\_1), CBR
refresh) violated

"Cannot open COMMAND file pcislave\_tst.cmd. No commands are preloaded!"

WARNING at 0 from

Msystem.lmc\_slave1.fm.get\_addr\_tbl\_elmnt.loop\_get

"GET\_ADDR\_TBL\_ELMNT: main not found in table"

"Illegal function call, function main not declared"

"Cannot open data file pcislave tst.io. No data is preloaded!"

"Cannot open data file pcislave\_tst.cfg. No data is preloaded!"

Note at time 0 from Msystem.lmc\_slave1.fm.report\_slave "SYNOPSYS PCISLAVE MODEL 5.3"

WARNING at time 0 from Msystem.lmc\_master1.fm.exe\_call "Cannot open COMMAND file lmc\_master1.cmd. No commands are preloaded!"

WARNING at 0 from

Msystem.lmc\_master1.fm.get\_addr\_tbl\_elmnt.loop\_get
"GET ADDR TBL ELMNT: main not found in table"

WARNING at 0 from Msystem.lmc\_master1.fm.exe\_call "Illegal function call, function main not declared"

Setup sparse mem model for ravi slave memory

Setup sparse mem model for ravi slave io

afx\_slave: setting read/write latencies to 0

INFO: standby mode == 0

WARNING at time 3100 from Msystem.lmc\_master1.fm.pclk\_check "Unknown value on pin pclk will be ignored"

WARNING at time 3100 from Msystem.ul.fm.clk\_check "Unknown value on pin clk will be ignored"

### From the Cadence Verilog-XL Simulator

The Cadence Verilog-XL simulator generates the following warning messages:

```
Compiling source file "/import/seagle-rgrA/cadence/project/
soleil/sparc_v8/system/rtl/memif_defs.h"
Warning! Text macro (RD) redefined -
replaced with new definition [Verilog-TMREN]
"/import/seagle-rgrA/cadence/project/soleil/sparc
v8/system/rtl/memif defs.h", 300:
Warning! Text macro (lmv_timescale) redefined -
replaced with new definition [Verilog-TMREN]
"/import/seagle-rgrA/cadence/project/soleil/sparc_v8/system/lmc/
rt1/1mc_8.v", 83:
Warning! Text macro (time scale multiplier) redefined -
replaced with new definition [Verilog-TMREN]
"/import/seagle-rgrA/cadence/project/soleil/sparc_v8/system/lmc/
rtl/lmc 8.v", 84:
Warning! Text macro (TRUE) redefined -
replaced with new definition [Verilog-TMREN]
"/import/seagle-rgrA/cadence/project/soleil/sparc_v8/system/lmc/
rtl/lmc_8.v", 92:
Warning! Text macro (FALSE) redefined -
replaced with new definition [Verilog-TMREN]
"/import/seagle-rgrA/cadence/project/soleil/sparc_v8/system/lmc/
rtl/lmc_8.v", 94:
"Cannot open data file pcislave_tst.io. No data is preloaded!"
"Cannot open data file pcislave_tst.cfg. No data is preloaded!"
"Cannot open COMMAND file pcislave_tst.cmd. No commands are
preloaded!"
WARNING at 0 from
Msystem.lmc_slave1.fm.get_addr_tbl_elmnt.loop_get
"GET ADDR TBL ELMNT: main not found in table"
"Illegal function call, function main not declared"
Note at time 0 from Msystem.lmc_slave1.fm.report_slave
WARNING at time 0 from Msystem.lmc master1.fm.exe call
"Cannot open COMMAND file lmc master1.cmd. No commands are
preloaded!"
```

WARNING at 0 from
Msystem.lmc\_master1.fm.get\_addr\_tbl\_elmnt.loop\_get
"GET\_ADDR\_TBL\_ELMNT: main not found in table"

WARNING at 0 from Msystem.lmc\_master1.fm.exe\_call "Illegal function call, function main not declared"

WARNING at time 3100 from Msystem.ul.fm.clk\_check "Unknown value on pin clk will be ignored"

WARNING at time 3100 from Msystem.lmc\_master1.fm.pclk\_check "Unknown value on pin pclk will be ignored"

Warning! Text macro (ssparc\_chip\_file) redefined replaced with new definition [Verilog-TMREN]
"sparc\_v8/system/rtl/ssparc\_chiplsidump.v", 35: