# Absolute encoder package

# Fabien Le Mentec lementec@esrf.fr

version: SVN revision 446:482M

# Contents

| 1        | Des  | scription          |
|----------|------|--------------------|
|          | 1.1  | Overview           |
|          | 1.2  | Supported features |
|          | 1.3  | Performances       |
|          | 1.4  | Architecture       |
| <b>2</b> | Inte | erfaces            |
|          | 2.1  | abs_enc_pkg.master |
|          | 2.2  | abs_enc_pkg.slave  |
| 3        |      | amples             |
|          | 3.1  | master             |
|          | 3.2  | slave              |

# 1 Description

#### 1.1 Overview

The abs\_enc\_pkg implements components for absolute encoder masters and slaves.

The term *master* refers to the component driving the clock, or at least initiating the data transfer. It is sometimes called the controller. The term *slave* refers to the actual encoder device.

This package is optimized for applications that can be dynamically configured to implement one amongst different types of encoders at a particular time. As much as possible, exclusive resources that can be shared across encoder types are factorized (counters, comparators, shift registers ...). However, and in order to avoid penalizing simpler applications, static configuration allows to exclude resources associated with an unused encoder type.

## 1.2 Supported features

TODO:

The following encoder types are available:

- ENDAT (version 2.1, send position mode),
- BISS,
- SSI.

#### 1.3 Performances

TODO:

#### 1.4 Architecture

TODO:

## 2 Interfaces

## 2.1 abs\_enc\_pkg.master

Extracted from file ./../src/abs\_enc\_pkg.vhd at line 332

# 2.2 abs\_enc\_pkg.slave

Extracted from file ./../src/abs\_enc\_pkg.vhd at line 152

```
component slave
generic
(
    CLK_FREQ: integer;
    ENABLE_ENDAT: boolean := TRUE;
    ENABLE_ISIS: boolean := TRUE;
    ENABLE_SSI: boolean := TRUE
);
port
(
    -- local clock
    clk: in std_logic;
    rst: in std_logic;
    -- master clock
    ma_clk: in std_logic;
    -- master in, slave out
    miso: out std_logic;
    mosi: in std_logic;
    -- gate to drive output (1 to drive it)
    gate: out std_logic;
```

```
-- data and length
data: in std_logic_vector;
len: in unsigned;
-- encoder type
enc_type: in integer
);
end component;
```

# 3 Examples

#### 3.1 master

Extracted from file ./../sim/common/main.vhd at line 90

```
master: work.abs_enc_pkg.master
generic map
(
    CLK_FREQ \Rightarrow CLK_FREQ
)
port map
(
    clk \Rightarrow clk,
    rst \Rightarrow rst,
    ma_fdiv \Rightarrow ma_fdiv,
    ma_clk \Rightarrow ma_clk,
    mosi \Rightarrow mosi,
    miso \Rightarrow miso,
    gate \Rightarrow open,
    data \Rightarrow master_data,
    len \Rightarrow len.
enc_type \Rightarrow enc_type
);
```

## 3.2 slave

Extracted from file ./../sim/common/main.vhd at line 71

```
slave: work.abs_enc_pkg.slave
generic map
(
   CLK_FREQ => CLK_FREQ
)
port map
(
   clk => clk,
   rst => rst,
   ma_clk => ma_clk,
   miso => miso,
   mosi => mosi,
   gate => open,
   data => slave_data,
   len => len,
   enc_type => enc_type
);
```