# MIX – Micronas Interconnect Spec expander

# Introduction

# **Management Summary**

# **Overview**

## Table of contents:

| MIX – Micronas Interconnect Spec expander |     |
|-------------------------------------------|-----|
| Introduction                              |     |
| Management Summary                        |     |
| Overview                                  |     |
| Table of contents:                        |     |
| Installation                              |     |
| Getting Started                           |     |
| A simple example                          |     |
| Mix it!                                   |     |
| You get what you typed                    |     |
| Details                                   |     |
| Initialization with -init                 | . 7 |
| Common excel worksheet properties         | . 7 |
| HIER sheet properties                     | . 8 |
| HIER columns details                      | . 8 |
| :: use Add Project Specific Libraries     | . 9 |
| Special HIER sheet properties             |     |
| CONN sheet details                        |     |
| CONN columns details                      | 10  |
| Special CONN sheet signals                |     |
| %OPEN% aka. open                          |     |
| Constants                                 |     |
| Generics and Parameters                   |     |
| Predefined and user macros                |     |
| CONN sheet macros                         |     |
| Generator statements                      |     |
| IO sheet                                  |     |
| IO sheet column header                    |     |
| IO sheet %SEL% rows                       |     |
| IO sheet pad rows                         |     |
| IO cell and Pad connections               |     |
| IO Parser global configuration            |     |
| I2C sheet                                 |     |
| VI2C sheet                                |     |
| Alarm clock example                       |     |
| ·                                         |     |
| MIX converter man page                    |     |
| Synopsis                                  |     |
| Command line switches                     |     |
| Runtime options and configuration         | 19  |

| Misc features                                                   | 20 |
|-----------------------------------------------------------------|----|
| -delta mode                                                     | 20 |
| Intermediate Excel Sheet                                        | 20 |
| Output Redirection                                              | 20 |
| Alarm clock example                                             | 21 |
| Core logic                                                      |    |
| IO logic                                                        | 21 |
| Other examples                                                  |    |
| Known Bugs and limitations                                      | 21 |
| Issue tracking: CADNET -> Issue tracking -> CAD Software -> MIX | 21 |
| Links                                                           | 21 |
| MIX paper and documentation                                     | 21 |
| Micronas internal                                               |    |
| Others                                                          | 21 |
| Resources                                                       | 21 |
| Used Software                                                   | 22 |
| Release Notes:                                                  | 22 |
| 20030716                                                        | 22 |
| 20030709                                                        | 22 |
| 20030605                                                        | 22 |

## Installation

The MIX toolset uses the <u>Perl</u> scripting language. Please install a recent version of Perl on your workstation, e.g. the freely available <u>ActiveState Perl</u> from K:\PROJECTS\MIX\PROG\ActivePerl-5.6.1.633-MSWin32-x86.msi. Apart from that no installation is required.

Start MIX from the network drive like described in the examples below. That will also make sure, that you are using the most recent release automatically. After the Perl installation, you can run MIX. immediately. Open a command shell on your desktop workstation

```
\label{eq:start} \mbox{Start} \mbox{ -> Ausführen -> cmd} \\ \mbox{and type}
```

K:\Projects\MIX\PROG\mix\_0.pl foo.xls Caveat: Currently MIX is available on MS-Windows, only!

# **Getting Started**

To receive useful results, MIX reads in various input spreadsheet data. At least you will need to prepare a description of your design hierarchy (HIER) and the connectivity sheet (CONN). Optionally MIX will convert a input/output sheet IO, listing input/output pads and iocells and how these are linked to the core logic into appropriate hierarchy and connection lists.

# A simple example

To understand the usage of the various tables and options, a very simple example is shown and extended step by step. The simple example just has two components **a** and **b**, which are connected by the signal **sigfoo**. The two instances have a common parent **chip** 

#### mix\_simple.xls



Image 1: Simple mix\_simple.xls

The equivalent description of this simple design in MIX is made up from a worksheet **HIER**.

| ::ign | ::gen                                         | ::variants | ::parent  | ::inst | ::entity | ::config        | ::comment |  |  |  |  |
|-------|-----------------------------------------------|------------|-----------|--------|----------|-----------------|-----------|--|--|--|--|
| # Mix | # Mix SimpleExample, V0.1, 20030630, hierachy |            |           |        |          |                 |           |  |  |  |  |
|       |                                               | Default    | TESTBENCH | chip   | chip_e   | chip_e_rtl_conf |           |  |  |  |  |
|       |                                               | Default    | chip      | а      | a_e      | a_e_rtl_conf    |           |  |  |  |  |
|       |                                               | Default    | chip      | b      | bе       | b e rtl conf    |           |  |  |  |  |

The first row defines the table headers names. The names have to be in the form "::NAME". Several of the columns are required, some are optional and you can define additional columns on your own. For HIER sheets the "::inst" column is the primary key. One design element will be generated for each new name of an ::inst row. If a name is defined several times, these lines will be overloaded or summarized, depending on built-in rules of the MIX converter.

The "::ign" column has to come first. If it starts with a #, the rest of this row will be ignored. All other columns can be added in arbitrary order.

The second required worksheet is **CONN**:

| ::ign | ::gen                                          | ::bundle | ::class | ::clock | ::type     | ::high | ::low | ::mode | ::name | ::out     | ::in      | ::descr | ::comment |
|-------|------------------------------------------------|----------|---------|---------|------------|--------|-------|--------|--------|-----------|-----------|---------|-----------|
| # Mix | # Mix SimpleExample, V0.1, 20030630, hierarchy |          |         |         |            |        |       |        |        |           |           |         |           |
|       |                                                | Chip     | Data    | Clk     | std_ulogic |        |       | S      | sigfoo | a/port_ao | b/port_bi | Simple  |           |

As you see, this worksheet also starts with the table header definition line. The primary field is the "::name" column. The "::in" and "::out" columns are used to define the drivers and loads for the signals.

#### Mix it!

Run the MIX converter tool in the directory the excel spread sheet is stored in:

\$ cd \work\MIX\doc\parts\simple

\$ K:\Projects\MIX\PROG\mix\_0.pl mix\_simple.xls

This reads in the design description and evaluates the various sheets. It creates output files with an intermediate excel design description (mix\_simple-mixed.xls) and the same data in a internal format (mix\_simple.pld). A log file (mix\_0.pl.log) and the HDL output files are written in the same run. Image 2 shows a screenshot of the mix\_simpe.xls conversion. Only the most important errors and warnings are written to the

screen, while a lot of information will be written to the log file. Search for the keywords "ERROR" and "WARNING" to verify proper conversion.

Image 2: Screenshot mix\_simple conversion

All output files are stored in the current working directory. Old versions of the output files are overwritten. Except the log file that is appended by each converter run. The intermediate excel description file keeps a history of previous HIER and CONN sheets by rotating N extended worksheet names.



#### You get what you typed

MIX generates various HDL files defined by the input data. If you select VHDL (also the default language) as output description for a hierarchy element, each element results in an appropriate entity, architecture and configuration description. By default MIX writes one file for all entities, one for all architecture and one for all configuration descriptions. Those file names are derived from the last excel input file name by stripping of the .xls extension and attaching a —e.vhd, -a.vhd and —c.vhd.

Here the working directory of the simple example contains a file mix.cfg, which is the convenient storage for MIX run-time configuration options. The lines "MIXCFG outarch ARCH", "MIXCFG outenty ENTY", and "MIXCFG outconf CONF" switch MIX outputs to separate files for each entity, architecture and configuration. In this case the file names are defined by the element name:

| Туре          | Basename        | Extension  | Example                       |
|---------------|-----------------|------------|-------------------------------|
| Entity        | ::entity-column | -e.vhd     | <i>chip_e</i> -e.vhd          |
| Architecture  | ::entity-column | -rtl-a.vhd | <i>chip_e</i> -rtl-a.vhd      |
| Configuration | ::conf-column   | -c.vhd     | <i>chip_e-rtl-conf-</i> c.vhd |

<sup>&</sup>quot; " in the filenames extensions are converted to -.

By default MIX does not write output data for leaf blocks (instances which are not parent for other instances). Adding a line like "MIXCFG generate.output.arch leaf" into the mix.cfg file changes that.

The generated output files contain head, body and footer sections. See the screenshots of the file a-e-e.vhd and chip-e-rtl-a.vhd for examples of an entity and an architecture definition.

```
a-e-e.txt (H:\work\MIX\doc) - GVIM1
                                                                                  Datei Editieren Werkzeuge Syntax Puffer Ansicht Hilfe

    Entity Declaration for a_e

-- Generator: mix_0.pl Version: Revision: 1.12 , wilfried.gaensheimer@micronas.com
-- (C) 2003 Micronas GmbH
library IEEE;
use IEEE.std_logic_1164.all;
-- Start of Generated Entity a_e
entity a_e is
       -- Generated Port Declaration:
               port(
               -- Generated Port for Entity a_e
sig_a : out std_ulogic
               -- End of Generated Port for Entity a_e
               );
end a_e;
-- End of Generated Entity a_e
--!End of Entity/ies
                                                                    15,13
                                                                                Alles
```

Image 3: Entity a-e-e.vhd

```
chip-e-rtl-a.vhd + (H:\work\MIX\doc\parts\simple) - GVIM1
                                                                               Datei Editieren Werkzeuge Syntax Puffer Ansicht Hilfe
-- Start of Generated Architecture rtl of chip_e
architecture rtl of chip_e is
        -- Generated Components
        component a_e
                port (
                 -- Generated Port for Entity a_e
                sig_a : out std_ulogic
-- End of Generated Port for Entity a_e
                ):
        end component;
        . . .
                       signal sigfoo : std_ulogic;
begin
        -- Generated Instances and Rort Mappings
-- Generated Instance Port Map for a
                a: a_e
                port map (
                        sig_a => sigfoo
                );
-- End of Generated Instance Port Map for a
                -- Generated Instance Port Map for b
                port map (
                        sig_b => sigfoo
                );
-- End of Generated Instance Port Map for b
--!End of Entity/ies
                                                                 47,9
                                                                               Ende
```

Image 4: architecture chip-e-rtl-a.vhd

#### **Details**

#### Initialization with -init

You can use the —init command line option to create the needed files: \$ mix\_0.pl -init foo.vhd bar.xls

will create the file bar.xls, which has the following three worksheet categories:

- empty HIER, CONN and IO sheets
- template sheets with numerous examples TMPL (HIER|CONN|IO)
- import sheets IMP\_HIER and IMP\_CONN (only if one or more \*.vhd or \*.v files are given as command line arguments).

You will also get a mix.cfg file.

If bar.xls or mix.cfg already exist, the command will exit without changes. The import of \*.vhd and \*.v files is experimental and meant to give a way of getting a start description of your design. In case of VHDL files, only entity descriptions are imported. Take care of getting signal names and instance names properly.

## Common excel worksheet properties

All excel worksheets parsed by MIX share some common properties. There needs to be a header line consisting only of keywords with leading double colon. All data before the header row is ignored. Only the first header row will be evaluated. Data in columns with no header or malformed headers will be ignored.

Commonly understood table headings are <code>::ign</code> and <code>::comment</code>. The <code>::ign</code> column is special, because it needs to be the first column of a sheet. If a cell in the <code>::ign</code> column starts with a # or a //, the complete row is ignored. The <code>::comment</code> column can contain user or program generated comments for a given row. It's data will be appended to it's contents as it appears. MIX reads the excel cell values. This is what you see, not the real contents of the cells. Thus all excel formulas can be used to define the cell values. A lot of predefined <code>text macros</code> are understood and converted by MIX. A text macro is made up by a name surrounded by % signs. Retrieve a complete list of macros with the <code>-listconf</code> command line switch and grep all lines starting with "MIXCFG <code>macro</code>". The table %macro% gives a list of predefined macros, their default settings and wether this macro can be used by the user. You can use text macros inside of any cell.

| ::ign                                                          | ::gen | ::variants | ::parent  | ::inst | ::lang     | ::entity   | ::config            | ::comment |  |
|----------------------------------------------------------------|-------|------------|-----------|--------|------------|------------|---------------------|-----------|--|
| #Mix SimpleExample, Macro Expansion, V0.1, 20030630, hierarchy |       |            |           |        |            |            |                     |           |  |
|                                                                |       | Default    | TESTBENCH | chip   | VHDL       | %::inst%_e | %::inst%_e_rtl_conf |           |  |
|                                                                |       | Default    | chip      | а      | VHDL       | %::inst%_e | %::inst% e rtl_conf |           |  |
|                                                                |       | Default    | chip      | b      | %LANGUAGE% | %::inst%_e | %::inst%_e_rtl_conf |           |  |

A second type of macros are available to reference data from other columns like through %::NAME%. This macro will be replaced by the contents of the ::NAME column of this row. ::NAME has to be defined for the current worksheet, obviously. In the above example %::inst%\_e will evaluate to chip\_e, a\_e and b\_e accordingly. %LANGUAGE% becomes vhdl. Macro expansion happens just before the intermediate design data is written out, after evaluation of all input data. Recursive macro expansion is not

implemented. Macros in primary keys like signal and instance names are evaluated at signal or instance creation time.

All macros are expanded as late as possible.

## HIER sheet properties

The hierarchy of a design is defined in the HIER sheet. By default the HIER sheet is named HIER, but you can set the configuration value hier.xls to a Perl regular expression. MIX will then consider all worksheets which names match the perl regular expression, to be HIER definitions. In that case you are free to use different header definitions on different sheets.

The HIER sheets require at least the columns marked man. (mandatory) in the following table.

| Column name | Description                                 | Default value   | Req. | Example    |
|-------------|---------------------------------------------|-----------------|------|------------|
| ::ign       | Ignore line                                 | <empty></empty> | man. | # comm.    |
| ::gen       | Generator and match                         | <empty></empty> | man. | see below  |
| ::variants  | Variant selector                            | Default         | opt. | Var1       |
| ::parent    | Instance name of this instances parent cell | W_NO_PARENT     | man. | chip       |
| ::inst      | Instance name, primary key!                 | n/a             | man. | a_i1       |
| ::lang      | Language definition                         | VHDL            | opt. | vhdl       |
| ::entity    | Entity name                                 | W_NO_ENTITY     | man. | а          |
| ::config    | Configuration name                          | W_NO_CONFIG     | man. | a_rtl_conf |
| ::shortname | Short name                                  | <empty></empty> | opt. | text       |
| ::use       | Additional, project specific libraries      | <empty></empty> | opt. | padlib.foo |
| ::comment   | Comment field                               | <empty></empty> | opt. | text       |

Internally the kewords ::debug, ::hierarchy, ::skip and ::default are used. Please do not use them. Apart from that you are free to add columns of your own. User defined columns are usable in %::NAME% macro expansion and are listed in the intermediate design data output.

Only the ::inst column has to contain a value in each row (which could be a %::NAME% macro, though). All other columns will receive more or less reasonable default values in case they are left empty.

#### HIER columns details

- : : gen If a cell here is not empty, the line will be considered as generator. See description of generator statements below.
- ::variantsSelect a line depending on the -variant command line switch. If -variant VARFOO is set, only lines with ::variant cell containing the word VARFOO or empty are selected and read in. Several variants may be given in one cell, separated by comma. Rows with empty ::variant cell are read in always. Lines with the keyword Default are read in only if no variant is choosen.

- ::inst Defines the instance name. If the same name appears in several rows, the resulting row will be overloaded from all input rows. The exact behaviour depends on the column name. Some are concatenated, some are replaced.
- ::lang HDL language selection, case insensitive. If this column is omitted or empty, VHDL output is generated. The default value can ve changed by means of the macro.%LANGUAGE% macro. Currently only VHDL and Verilog are supported.

::config Define the configuration name. It defaults to

```
%DEFAULT_CONFIG%, which evaluates to
%::entity% %::arch% conf.
```

If the language of this entity is set to Verilog, no configuration will be printed nor will it be added to parent cell configurations.

The keyword %NO\_CONFIG% will also suppress output of configuration for this entity.

#### Additional columns:

::arch If no ::arch column is given, architecture will default to "rtl". This is defined by the configuration hier.field.::arch.[3] = rtl; and cannot be changed globally.

:: use Add project specific libraries and work packages to the HDL description files.

#### :: use Add Project Specific Libraries

The optional "::use" column allows to add libraries and work packages for a entity. Several libraries can be added, separated by comma or white space. In case of VHDL output, the use statement is added to the entity declaration, only. You can override that by adding a leading ALL:, ARCH: or CONF: keyword for this instance/entity. To change that globally, modify the configuration variable output.generate.use.

For each given library an appropriate text sequence is added:

```
foo.lib, bar.lib.something
will be printed as
    library foo;
    use foo.lib.all;
    library bar;
    use bar.lib.something.all;
```

If different instantiations of a entity have different ::use definitions, MIX adds up all these.

To change the global default value of

```
library IEEE;
```

use IEEE.std logic 1164.all;

modify macro.%VHDL USE DEFAULT%.

To add a library globally, add the appropriate text to the

macro.%VHDL\_NOPROJ% configuration, which will be used if no library is defined in the ::use column.

A second usage is to suppress the component declaration output by the %NDC% or %NO\_COMPONENT\_DECLARATION% keyword. This is useful for instances, whose entities are taken from libraries.

Examples: see t/sigport.xls and t/sigport/use/\*.vhd for more examples.

Configuration: output.generate.use = enty

## Special HIER sheet properties

%TOP% is a pseudo instance and used for internal purposes, only.

#### CONN sheet details

The design connections are defined in the CONN sheet. The primary key of this sheet is the signalname as given in "::name". Signalnames are globally known for the design. All appearances of a name are connected, creating intermediate ports as needed.

#### CONN columns details

## Special CONN sheet signals

Special signal names: %LOW%, %HIGH%, %LOW\_BUS%, %HIGH\_BUS%

## %OPEN% aka. open

Used the %OPEN% signal to leave some pins of module bar port a open MIX has no knowledge about ports. Everything is defined in terms of signals and instances. Use the "open" pseudo signal to define the extra pins.

E.g.: wire foo/a port to bar/a port. bar/a has extra pins.

signal\_a, ::high 7, ::low 0, ::out foo/a ::in bar/a
%OPEN%, ::high 1, ::low 0, ::out -, ::out bar/a(9:8)
XXX write this in spreadsheet XXX
You could also force the ::in pins to high or low, instead, e.g. use %HIGH%,
%HIGH\_BUS%, %LOW
or %LOW\_BUS%. Or a constant.

#### **Constants**

Constant values can be defined and used in several ways in the CONN worksheet. Constants can be marked with a C in the ::mode column. Basically anything resembling a number written in the ::out column will be considered to be a constant value. String and bit vector constants are enclosed in single or double quotes.

Remember to type two single quotes in excel to start a single quote string. Excel takes the first quote character to prevent the following string to be interpolated by excel.

If you do not name a constant (leave the ::name field empty), MIX will generate a name like mix\_const\_N. N starts by zero and increments for each new constant value.

Constant values can be assigned to instance ports in the ::in column of that constant.

Depending on the form of a constant and the output language, MIX tries to convert the constant value into something suitable. See the constant.xls example (XXXLINK).

| ::ign :                                                             | :gen  | ::bundle        | ::class | ::clock | ::type            | ::high | ::low | ::mode | ::name   | ::out        | ::in                          |
|---------------------------------------------------------------------|-------|-----------------|---------|---------|-------------------|--------|-------|--------|----------|--------------|-------------------------------|
|                                                                     |       | CONSTANT        | •       | •       | std_ulogic        |        |       | С      | const_01 | 0            | inst_aa/const_01_p            |
|                                                                     |       | CONSTANT        |         |         | std_ulogic        |        |       | С      | const_02 | 1            | inst_aa/const_02_p            |
|                                                                     |       | const_signal    | c_sig   |         | std_ulogic_vector | 6      | 0     |        | const_03 | %CONST%/'64' | inst_aa/const_03              |
|                                                                     |       | const_signal    | c_sig   |         | std_ulogic_vector | 3      | 0     |        | const_04 | %CONST%/'32' | inst_ab/const_04              |
|                                                                     |       | const_signal    | c_sig   |         | std_ulogic        |        |       |        | const_05 | 1            | inst_aa/const_05              |
|                                                                     |       | const_signal    | c_sig   |         | std_ulogic_vector | 6      | 0     |        | const_06 | 0xf          | inst_ea/const_06_p            |
| # Allowed formats: 0x[0-9a-f], 0[0-7], 10101, 'xxxx', 'zzzz', "abc" |       |                 |         |         |                   |        |       |        |          |              |                               |
|                                                                     |       | Formats         |         |         | std_ulogic        |        |       |        |          |              | inst_aa/zero_p                |
|                                                                     |       | Formats         |         |         | std_ulogic        |        |       |        |          | 1            | inst_aa/one_p                 |
|                                                                     |       | Formats         |         |         | integer           |        |       |        |          |              | inst_aa/integer_p             |
|                                                                     |       | Formats         |         |         | real              |        |       |        |          | 10.2         | inst_aa/real_p                |
|                                                                     |       | Formats         |         |         | real              |        |       |        |          | 1_000_000.0  | inst_aa/under_p               |
|                                                                     |       | Formats         |         |         | integer           |        |       |        |          | 16#FF#       | inst_aa/vhdl_basehex_p        |
|                                                                     |       | Formats         |         |         | integer           |        |       |        |          | 2#1010_1010# | inst_aa/vhdlbase2_p           |
|                                                                     |       | Formats         |         |         | real              |        |       |        |          | 2.2E-6       | inst_aa/reale_p               |
|                                                                     |       | Formats         |         |         | time              |        |       |        |          | 10 ns        | inst_aa/int_time_p            |
|                                                                     |       | Formats         |         |         | time              |        |       |        |          | 2.27us       | inst_aa/real_time_p           |
|                                                                     |       | Formats         |         |         | string            |        |       |        |          | "ein string" | inst_aa/string_p              |
|                                                                     |       | Formats         |         |         | bit_vector        | 7      | 0     |        |          | "11111111"   | inst_aa/bit_vector_p          |
|                                                                     |       | Formats         |         |         | bit_vector        | 7      | 0     |        |          | "1010"       | inst_ea/bad_width_p           |
|                                                                     |       | Formats         |         |         | std_ulogic_vector | 7      | 0     |        |          | '01010101'   | inst_aa/std_ulogic_vector_p   |
| # Vari                                                              | ous o | ther constant f | ormats  |         |                   |        |       |        |          |              |                               |
|                                                                     |       | Std_ulogic      |         |         | std_ulogic_vector | 7      | 0     |        |          | 16#FF#       | inst_aa/std_u_logic_vport     |
|                                                                     |       | Std_ulogic      |         |         | std_ulogic_vector | 7      | 0     |        |          | 16#11#       | inst_aa/std_u_11_vport        |
|                                                                     |       | Std_ulogic      |         |         | std_ulogic_vector | 10     | 0     |        |          | 16#FF#       | inst_aa/std_u_logic_vport_ext |
|                                                                     |       | Std_ulogic      |         |         | std_ulogic_vector | 7      | 0     |        |          | 0xff         | inst_aa/std_u_logic_port_02   |
|                                                                     |       | Std_ulogic      |         |         | std_ulogic_vector | 7      | 0     |        |          | 0b01010101   | inst_aa/std_u_logic_bin_p     |
|                                                                     |       | Std_ulogic      |         |         | std_ulogic_vector | 7      | 0     |        |          | 8#07#        | inst_aa/std_u_logic_octv_p    |
|                                                                     |       | Std_ulogic      |         |         | std_ulogic_vector | 7      | 0     |        |          | 2#11001100#  | inst_aa/std_u_logic_binv_p    |
|                                                                     |       | Std_ulogic      |         |         | std_ulogic_vector | 7      | 0     |        |          | 4#3030#      | inst_aa/std_u_logic_quadv_p   |
|                                                                     |       | Std_ulogic      |         |         | std_ulogic_vector | 3      | 0     |        |          | 16#ee#       | inst_aa/std_u_logic_hexerr_p  |

Image 5 Examples for constants

If the target language is VHDL, XXXXX MIX looks like in the following screenshot:

```
mix_simple_const_inst-a-e-rtl-a.vhd (H:\work\MIX\doc\parts\simple) - GVIM5
                                                                                                            Datei Editieren Werkzeuge Syntax Puffer Ansicht Hilfe
'9 G | % 📵 📵 | Q. 원. 원. 원. 🏝 | 📤 🙏 | T W 🛍 🖵 |
  Generated Signal List, Excerpt ...
       constant const_01_c : std_ulogic := '0';
       signal const_01 : std_ulogic;
       constant const_02_c : std_ulogic := '1';
       signal const_02 : std_ulogic;
       constant const_03_c : std_ulogic_vector(6 dounto 0) := "64"; -- __I_VectorConv
       signal const_03 : std_ulogic_vector(6 dounto 0);
       constant mix_const_10_c : string := "ein string"; -- __I_ConstNoconv
       signal mix_const_10 : string{
constant mix_const_14_c : std_ulogic_vector(7 downto_0) := "111111111"; -- __I_ConvConstant: 16#FF#
       signal mix_const_14 : std_ulogic_vector(7 dounto 0) constant mix_const_15_c : std_ulogic_vector(7 dounto 0) := "00010001"; -- __I_ConvConstant: 16#11#
       signal mix_const_15 : std ulogic vector(7 dounto 0);
       constant mix_const_16_c : std_ulogic_vector(10 dounto 0) := "000111111111"; -- __I_ConvConstant: 16#FF#
       signal mix_const_16 : std_ulogic_vector(10 dounto 0);
begin
  Generated Signal Assignments
       const_01 <= const_01_c;
       const_02 <= const_02_c;
       const D3 <= const D3 c;
       mix_const_10 <= mix_const_10_c;</pre>
       mix_const_14 <= mix_const_14_c;</pre>
       mix_const_15 <= mix_const_15_c;</pre>
       mix_const_16 <= mix_const_16_c;</pre>
 - Generated Instance Port Map for inst_aa
inst_aa: inst_aa_e
port nap
       const 01 p => const 01,
       const_02_p \Rightarrow const_02,
       const_03 => const_03,
       string_p => mix_const_10,
       std_u_11_vport => mix_const_15,
       std_u_logic_vport => mix_const_14,
       std_u_logic_vport_ext => mix_const_16,
  End of Generated Instance Port Map for inst_aa
                                                                                                10,31-37
                                                                                                           Anfano
```

Image 6 Example constant output

Search for lines with \_\_E in the comments to detect constants MIX was not able to translate properly. Verilog constant output is not very mature as of today.

#### Generics and Parameters

Generics for entities are defined by a **G** in the ::mode column. The ::name column defines the generics name. If the ::out column contains a string or a number, the value will be the default of this generic.

A **P** in the ::mode column marks parameters. The value given in the ::out column will be applied to the instances in the ::in column.

If the ::name column is empty, MIX will assign a generated name. The HDL generic name is either the "port" name given in the ::in column or the ::name.

A example description taken from a CONN sheet will create the following output in VHDL:

| ::type  | ::mode | ::name      | ::out       | ::in        |
|---------|--------|-------------|-------------|-------------|
| integer | G      | generic_a   | 7           | g/generic_a |
| integer | Р      | parameter_a | 16          | g/generic_a |
| string  | G      | generic_b   | "text"      | g/generic_b |
| string  | Р      | parameter_b | "text para" | g/generic_b |

```
generic_chip_e-rtl-a.vhd + ...MIX\doc\parts\simple) - GVIM2
                                                               Datei Editieren Werkzeuge Syntax Puffer Ansicht Hilfe
- Generated Architecture Declaration for rtl of generic_chip_e
architecture rtl of generic chip e is
       component q e
               generic (
                       generic_a : integer
generic_b : string
                                                  := 7;
:= "text"
               );
       end component;
begin
               g: g e
               generic map (
                       generic_a => 16,
                       generic_b => "text para"
               H
end rtl;
                                         V
--!End of Architecture/s
                                                  20,3-17
                                                             Alles
```

Image 7: Definition of Generics: G and P

#### Predefined and user macros

The following table contains a list of predefined macros. Some of them are defined at run time (e.g. the current date), some are for internal purposes only. macros marked with a yes in the "User" column can be set freely by the user on the command line or in the mix.cfg configuration file.

| Macro Name     | Default Value                   | Description    | User     |
|----------------|---------------------------------|----------------|----------|
| %0%            | mix_0.pl                        | Program name   | run time |
| %ARGV%         | K:\Projects\MIX\PROG\mix_0.pl - | Program        | run time |
|                | listoncf                        | arguments      |          |
| %BUFFER%       | buffer                          |                | yes      |
| %BUS_TYPE%     | std_ulogic_vector               |                | yes      |
| %CONST%        | CONST                           |                | yes      |
| %DATE%         | Mon Jun 30 16:22:41 2003-06-30  | Current date   | run time |
| %DEFAULT_MODE% | S                               | Signal default | yes      |
| _              |                                 | mode           |          |
| %EMPTY%        |                                 | Empty string   | yes      |

| %GENERIC%                | GENERIC                                           |                              | -        |
|--------------------------|---------------------------------------------------|------------------------------|----------|
| %H%                      | \$                                                | internal                     | -        |
| %HIGH%                   | mix_logic1                                        | Name of logic high value     | yes      |
| %HIGH_BUS%               | mix_logic1_bus                                    | Name of logic high value bus | yes      |
| %HOME%                   | H:\                                               |                              | -        |
| %IOCELL_SELECT_P<br>ORT% | select                                            |                              | yes      |
| %IOCELL TYPE%            | E DEFAULT IOCELL                                  |                              | _        |
| %IOCR%                   | \n                                                |                              | -        |
| %LANGUAGE%               | vhdl                                              |                              | yes      |
| %LOW%                    | mix_logic0                                        |                              | yes      |
| %LOW BUS%                | mix logic0 bus                                    |                              | yes      |
| %NULL%                   | 0                                                 |                              | -        |
| %OPEN%                   | open                                              |                              | -        |
| %PAD CLASS%              | PAD                                               |                              | yes      |
| %PAD TYPE%               | E DEFAULT PAD                                     |                              | -        |
| %PARAMETER%              | PARAMETER                                         |                              | -        |
| %PROJECT%                | NO PROJECT SET                                    |                              | yes      |
| %SIGNAL%                 | std ulogic                                        |                              | yes      |
| %SPACE%                  |                                                   |                              | yes      |
| %TAB%                    | \t                                                |                              | -        |
| %TBD%                    | W TO BE DEFINED                                   |                              | -        |
| %TOP%                    | TOP                                               |                              | yes      |
| %UNDEF%                  | ERROR_UNDEF                                       |                              | -        |
| %UNDEF_1%                | ERROR_UNDEF_1                                     |                              | -        |
| %UNDEF_2%                | ERROR_UNDEF_2                                     |                              | -        |
| %UNDEF_3%                | ERROR_UNDEF_3                                     |                              | -        |
| %UNDEF_4%                | ERROR_UNDEF_4                                     |                              | -        |
| %USER%                   | wig                                               |                              | run time |
| %VERILOG_TIMESC          | 'timescale 1ns / 1ns;                             |                              | yes      |
| ALE%                     |                                                   |                              |          |
| %VERSION%                | Revision: 1.12                                    |                              | -        |
| %VHDL_NOPROJ%            | No project specific VHDL libraries                |                              | -        |
| %VHDL_USE%               | No project specific VHDL libraries                |                              | yes      |
| %VHDL_USE_ARCH<br>%      | %VHDL_USE_DEFAULT%\n%V<br>HDL_USE%                |                              | yes      |
| %VHDL_USE_CONF<br>%      | %VHDL_USE_DEFAULT%\n%V<br>HDL_USE%                |                              | yes      |
| %VHDL_USE_DEFAU<br>LT%   | library IEEE;\n<br>use IEEE.std_logic_1164.all;\n |                              | yes      |
| %VHDL_USE_ENTY<br>%      | %VHDL_USE_DEFAULT%\n%V<br>HDL_USE%                |                              | yes      |
| <u> </u>                 | · · · · · · · · · · · · · ·                       | 1                            |          |

The default values can be changed by using -conf macro.%THIS\_MACRO%=my\_value

command line switch. New macros can be defined the same way. Alternatively a line like

MIXCFG macro.%THIS\_MACRO% my\_value to the mix.cfg configuration file will achieve the same result.

# **CONN** sheet macros

not text macros, but MH, MD and MX generators:

MH: Macro header: needs to match against the MX line (\$X defines variables)

MD: Body of macro. Will be inserted after variable replacement.

MX: Triggers macro expansion. Will be matched against all MH lines known.

Defines variable values.

#### **Generator statements**

#### IO sheet

A third category of input specification is the IO sheet. The contents of the IO sheet is parsed and translated into instances of io cell blocks and pad cells and connections of the io logic with the design core logic.



Image 8: IO Cell and Pad Layout

The IO sheet is a simple way to specify the connections of the IO cell to the design core logic. MIX will derive the connections of the DI(0..n), DO(0..n), PU(0..n), PD(0..n), EN(0..n) and the accompanying select lines. MIX will not add special purpose connections and the IO cell to Pad cell connections. This should be done by using the macro and generator statements in the CONN sheets.

A simple example illustrates the various input fields and their usage.

| ::ign ::dass | ::ispin | ::pin | ::pad | ::type  | ::iocell       | ::port | ::name  | ::muxopt   | ::muxopt      | ::muxopt  | ::muxopt  |
|--------------|---------|-------|-------|---------|----------------|--------|---------|------------|---------------|-----------|-----------|
| %SEL%        |         |       |       |         |                | sel    | pad     | iosel_0    | iosel_1       | iosel_2   | iosel_3   |
| DATA_I       | 1       | 1     | 1 '   | w_pad_i | icc_g_i        | di     | data_i1 | data_i1.0  | data_i1.1     | data_i1.2 | data_i1.3 |
| DATA_O       |         | 1     | 2     | w_pad_o | icc <u>g</u> o | do     | data_o1 | data_o1.0  | data_o1.1     | data_o1.2 | data_01.3 |
| %SEL%        |         |       |       |         |                | sel    | pad     | iosel_disp | iosel_ls_min  |           |           |
| DISPLAY      | 1       | 12    | 12    | w_disp  | icc_r_io       | di,    | disp_2  | di2.0,     | ,             |           |           |
|              |         |       |       |         |                | do,    |         | disp2.0,   | dis_ls_min.0, |           |           |
|              |         |       |       |         |                | en     |         | disp2_en.0 | dis_ls_en     |           |           |
| DISPLAY      | 1       | 13    | 13    | w_disp  | $ioc\_r\_io$   | di,    | disp_3  | di2.1,     | ,             |           |           |
|              |         |       |       |         |                | do,    |         | disp2.1,   | dis_ls_min.1, |           |           |
|              |         |       |       |         |                | en     |         | disp2_en.1 | dis_ls_en     |           |           |
| DISPLAY      | 1       | 14    | 14    | w_disp  | $ioc\_r\_io$   | di,    | disp_4  | di2.3,     | ,             |           |           |
|              |         |       |       |         |                | do,    |         | disp2.3,   | dis_ls_min.2, |           |           |
|              |         |       |       |         |                | en     |         | disp2_en.3 | dis_ls_en     |           |           |
| DISPLAY      | 1       | 15    | 15    | w_disp  | $ioc\_r\_io$   | di,    | disp_5  | di2.4,     | ,             |           |           |
|              |         |       |       |         |                | do,    |         | disp2.4,   | dis_ls_min.3, |           |           |
|              |         |       |       |         |                | en     |         | disp2_en.4 | dis_ls_en     |           |           |

Image 9: IO Sheet Example

#### IO sheet column header

The IO sheet starts with the usual header line, defining mandatory and optional columns:

- ::ign A # marks a comment line. Has to be first column. Optional.
- ::class The class name is forwarded to the ::class field of the CONN sheet. (opt.)
- ::ispin Set to one it this pad is actually bonded (ignored by MIX).
- ::pin Number or name of the pin. (ignored by MIX)
- ::pad The primary key of the IO sheet. Has to an integer value. The pad numbers do not have to be consecutive. Mandatory column.
- ::type Defines the entity of the generated pad cell.
- ::iocell Defines name and entitive of the generated in cell
- ::port Define the io cell port name towards to the core logic. Port names are separated by , and/or <Alt><CR>.
- ::name pad name
- ::muxopt Connection matrix of io cell ports to core logic. Signals are separated by , and/or <Alt>-<CR>. Signals may be single bits or a one bit bus slice. Type core\_sig.N or core\_sig(N) for bit N of the core signale core\_sig. ::muxopt is allowed to appear several times. The number of signals and the order matches the port names in the ::port field.

#### IO sheet %SEL% rows

The rows with the key \$SEL\$ in the ::class field define the wiring of the IO cells multiplexer select lines. The name in the ::port field defined the io cell port to connect to. The ::name field is ignored. The signal names listed in the ::muxopt columns are connected from the designs core with the appropriate slice of the io cell multiplexer select lines (one hot select lines). The leftmost ::muxopt connects to bit 0, the next to bit 1 and so forth. core\_sel.N or core\_cel(N). can be used to wire select buses. The number of non-empty

consecutive :: muxopt fields also define the width of the multiplexer. The actual multiplexer width is stored in the %:: \_muxwidth\_% field.

The given values for the select lines are valid until the last row or another %SEL% line is found.

%NOSEL% will stop usage of in/out multiplexer and select lines.

Setting the configuration switch "iocell.select" to "bus" changes from a one-hot architecture to a select bus architecture. The select bus name is take in the leftmost ::muxopt column, an appropriate width is calculated by the number of defined ::muxopt columns.

## 10 sheet pad rows

All other rows make up the connection matrix. For each row an io cell is instantiated. By default this io cell's name is composed by the type listed in the ::type field with the ::pad number attached, separated by a \_. Secondly a pad cell is instantiated. By default this pad cell's name is composed from the prefix pad\_ and the pad number as given in the ::pad field.

The default naming for both io cell and pad is given by the configuration variables

```
pad.name = %PREFIX_PAD_GEN%%::pad%
iocell.name = %::iocell%_%::pad%
```

You can leave unused ::muxopt columns empty. Then MIX will reduce the number of select lines accordingly.

#### IO cell and Pad connections

MIX IO sheet parser connects the IO cell internal interface towards the design core logic, only. Connections between pad and io cell need to be defined explicitely, usually be means of ::gen match operators.

Additional wires for NAND tree or boundary scan are specified the same way. Signal busses need to be defined properly, esp. the width and type. MIX will derive these properties from the definition.

The generated pad and iocells need to be linked into the design hierarchy properly, e.g. by adding :: gen match operators in the HIER sheet.

|                                                              | HER         |            |          |          |        |            |                 |           |
|--------------------------------------------------------------|-------------|------------|----------|----------|--------|------------|-----------------|-----------|
| ::ign                                                        | ::gen       | ::variants | ::parent | ::inst   | ::lang | ::entity   | ::config        | ::comment |
| #Pads, name is pad_NN, NN is the number from::pad adlumin IO |             |            |          |          |        |            |                 |           |
|                                                              |             | Default    | %TOP%    | padframe | vhd    | padframe_e | %::entity%_conf |           |
|                                                              | /pad_(\d+)/ | Default    | padframe | pad_\$1  | vhd    |            | %::entity%_conf |           |
|                                                              | /ioc_(.*)/  | Default    | padframe | icc_\$1  | vhd    |            | %::entity%_conf |           |
|                                                              |             |            |          |          |        |            |                 |           |

|       | CON                                                                                                                           |          |        |          |            |        |       |        |            |                  |                  |            |
|-------|-------------------------------------------------------------------------------------------------------------------------------|----------|--------|----------|------------|--------|-------|--------|------------|------------------|------------------|------------|
| ::ign | ::gen                                                                                                                         | ::bunde  | ::dass | ::dock   | ::type     | ::high | ::low | ::mode | ::name     | ::cut            | ::in             | ::descr    |
| #Sta  | #Standard Pad Cells wiring: do, en, d; triggered by iccell name which is d the formico_[rg]_[io]. N will be derived by the IO |          |        |          |            |        |       |        |            |                  |                  |            |
|       | /ioc_(\w_\w*o\w*)_(\d+)/                                                                                                      | PAD_CTPL | Ю      | multiple | std_ulogic |        |       |        | pad_do_\$2 | icc_\$1_\$2/p_do | pad_\$2/do       | dataout    |
|       | /ioc_(\w_\w*o\w*)_(\d+)/                                                                                                      | PAD_CTPL | Ю      | multiple | std_ulogic |        |       |        | pad_en_\$2 | icc_\$1_\$2/p_en | pad_\$2/en       | pad enable |
|       | /ioc_(\w_\w*i\w*)_(\d+)/                                                                                                      | PAD_CTFL | Ю      | multiple | std_ulogic |        |       |        | pad_di_\$2 | pad_\$2/di       | icc_\$1_\$2/p_di | datain     |

Image 10: Defining IO and pad cell connections

# IO Parser global configuration

Some global configuration are available to tailor the IO sheet parser behaviour:

| iocell.name       | Rule determines the naming of the io cell instances. Default: '%::iocell%_%::pad%'                                                                                                                                                                                                                            |  |  |  |  |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| iocell.auto       | If set to "bus", create busses as needed. Otherwise MIX relies on appropriate definition of busses by the CONN sheets.                                                                                                                                                                                        |  |  |  |  |
| iocell.bus        | If iocell.auto is set to bus, MIX will attach the keyword listed here (_vector) to signal type definitions.                                                                                                                                                                                                   |  |  |  |  |
| iocell.defaultdir | Defines default iocell port direction.  Default: in                                                                                                                                                                                                                                                           |  |  |  |  |
| iocell.in         | comma and/or white-space separated list of in ports Default: do, en, pu, pd, xout                                                                                                                                                                                                                             |  |  |  |  |
| iocell.out        | list of io-cells out ports Default: di, xin                                                                                                                                                                                                                                                                   |  |  |  |  |
| iocell.select     | List of keywords defining the select multiplexer connections: onehot use one hot architecture for select lines bus use a select line bus auto calculate width of select bus or one-hot based on actually wired ports const calculate width of select bus or one-hot based on %SEL% width Default: onehot,auto |  |  |  |  |
| pad.name          | Rule determines the naming of the pad instances.  Default: '%PREFIX_PAD_GEN%%::pad%'                                                                                                                                                                                                                          |  |  |  |  |

## **I2C** sheet

t.b.d.

## VI2C sheet

# Alarm clock example

# MIX converter man page

# Synopsis

#### Command line switches

- -out OUTPUTFILE.ext defines output filename and type
- -outenty OUT-e.vhd|ENTY|COMB
  - -- Write all entities into OUT-e.vhd.
  - -- If argument is ENTY, each entity will be written into a file called *entityname-e.vhd.*. (The exact naming depends on changeable rules).
  - -- If argument is COMB, entity, architecture and configuration will all be written into one file called *entityname.vhd*
- -outarch OUT-rtl-a.vhd|ARCH|COMB

See description of outenty option.

-outconf OUT-c.vhd|CONF|COMB

See description of outenty option.

-combine

write entity, architecture and configuration into one file for each entity. Shortcut for setting —out[enty|arch|conf] to COMB individually.

-dir DIRECTORY

write intermediate, internal and backend data into the given DIRECTORY. By default MIX writes to the current working directory -top TOPCELL

use TOPCELL as top. Default is TESTBENCH or daughter of TESTBENCH.

-adump

dump internal data in ASCII format, too (debugging, use with small data set).

-variant VAR1

Select VAR1 from the HIER worksheet.

-conf key.key=value

Overload \$EH{key}{key} with value or add a new configuration variable.

-listconf

Print out all available/predefined configurations options

-delta

Output will be compared against previous runs.

-sheet SHEET=MATCH

SHEET can be one of "hier", "conn", "vi2c". MATCH is a perl regular expression.

- init [foo.vhd foo2.v ...] bar.xls

create an empty bar.xls and mix.cfg, import entity and design description from \*.vhd.

-import foo.vhd [foo2.v foo3.vhd ...] bar.xls

import entity and design description from HDL files into the IMP HIER and IMP CONN sheets of the bar.xls spreadsheet.

# Add your options here ....

"Standard" options:

my @stdopts = qw(help|h! verbose|v! quiet|q! nobanner! debug:i makeopts=s@ gmakeopts=s@);

Caveat: the -h option will not work on MS-Windows

# Runtime options and configuration

Runtime configuration is controlled by (increasing precedence):

- built-in default values
- mix.cfg files

if found \$HOME, \$PROJECT and/or in current directory.

Format is: MIXCFG name.of.conf value

- CONF sheet found in input xls files
- command line switch

-conf foo.bar=value

dedicated command line options

MIX reads in mix.cfg configuration files in the following locations:

- \$ENV{HOME}
   'HOMEDRIVE', 'HOMEPATH', 'USERPROFILE' or 'C:\'
   (only from the first matching location)
- 2. \$ENV{PROJECT}
- 3. . (*cwd*)

Order: HOME / HOME / cwd() / -conf (last wins)

#### Misc features

#### -delta mode

Do not change output files, but report number of changes. Adds extra sheets DIFF\_CONN and DIFF\_HIER (and old versions of them) to the intermediate output. The FOO.pld internal output gets overwritten, though. All messages are appended to mix\_0.pl

If a new HDL-file needs to be created by the changes, the –delta mode is not be applied for that file, but it is generated as new. If you never have written a FOO-mixed.xls intermediate output, there is no HIER or CONN sheet generated.

By adding the following two lines to your configuration (e.g. ./mix.cfg), delta mode will be the default:

```
MIXCFG output.generate.delta 1 MIXCFG output.delta sort,remove
```

See the configuration option description for more details.

-nodelta switches delta mode off, then.

#### **Intermediate Excel Sheet**

Format of intermediate xls sheet will be kept as is as long as the number and order of columns is unchanged.

MIX saves three old versions of the generated HIER and CONN sheets. The worksheets names are rotated by a trailing \_ and number.

## **Output Redirection**

MIX writes all output into the current working directory. By using the <code>-dir DIRECTORY</code>

option, you can set the output directory for all intermediate, internal and HDL files to DIRECTORY. Absolute path names defined by other options (e.g. – out) are not changed, though. If DIRECTORY does not exist it will be created. To have separate output directories, use the mix.cfg file:

```
MIXCFG output.path HDLDIRS
MIXCFG internal.path MIXINTERNAL
MIXCFG intermediate MIXINTERMEDIATE
```

writes internal, intermediate and HDL files to the given pathes. All directories have to exist and will not be created.

# Alarm clock example

Core logic

10 logic

# Other examples

# **Known Bugs and limitations**

MS-Win/UNIX end-of-line issue:

Some EDA tools are not able to cope with the different end-of-line (CR vs LF/CR) of UNIX and MS-Windows. Use

\$ module load freeware; recode "pc..lat1" \*.vhd
to fix that after transferring data.

# Issue tracking: CADNET -> Issue tracking -> CAD Software -> MIX

If you find unexpected or buggy behavior, please issue a trouble ticket. Don't forget to add a short description. The test case should contain all source files and also log files, the exact command line switches and configuration files applied.

Please provide a comprehensive description of issues found including all required input data and command line switch to allow fast debugging and fixing.

#### Links

# MIX paper and documentation

EDP\_2003\_final\_030331.pdf

MIX\_Specification.xls (see \\\\Galaxy\\\\Development\\\\PROJECTS\\\MIX\\)

MIX\_Intro.ppt (see \\Galaxy\Development\PROJECTS\MIX)

#### Micronas internal

Micronas HDL coding guidelines.pdf

#### **Others**

#### Resources

Downloads for:

- IO examples
- Standard bus examples
- NAND Tree
- BS example
- miscellaneous useful macros

# **Used Software**

Perl Kommodo Vim WinCVS

## Release Notes:

# 20030716

see doc\release\_20030716.txt

## 20030709

see doc\release\_20030709.txt

# 20030605

See doc\release\_20030605.txt