libcin

Generated by Doxygen 1.8.13

# **Contents**

| 1 | Fast | CCD Co   | ommunication Library (libcin)      | 1  |
|---|------|----------|------------------------------------|----|
| 2 | Mod  | ule Inde | ex                                 | 3  |
|   | 2.1  | Module   | es                                 | 3  |
| 3 | Clas | s Index  |                                    | 5  |
|   | 3.1  | Class    | List                               | 5  |
| 4 | File | Index    |                                    | 7  |
|   | 4.1  | File Lis | st                                 | 7  |
| 5 | Mod  | ule Dod  | cumentation                        | 9  |
|   | 5.1  | Cin Co   | ontrol Initialization Routines     | 9  |
|   |      | 5.1.1    | Detailed Description               | 9  |
|   |      | 5.1.2    | Function Documentation             | 9  |
|   |      |          | 5.1.2.1 cin_ctl_destroy()          | 9  |
|   |      |          | 5.1.2.2 cin_ctl_init()             | 10 |
|   |      |          | 5.1.2.3 cin_ctl_set_msg_callback() | 10 |
|   |      |          | 5.1.2.4 cin_data_send_magic()      | 11 |
|   | 5.2  | Cin Co   | ontrol Read/Rwite Routines         | 12 |
|   |      | 5.2.1    | Detailed Description               | 12 |
|   |      | 5.2.2    | Function Documentation             | 12 |
|   |      |          | 5.2.2.1 cin_ctl_read()             | 12 |
|   |      |          | 5.2.2.2 cin_ctl_stream_write()     | 12 |
|   |      |          | 5.2.2.3 cin_ctl_write()            | 13 |

ii CONTENTS

|      |         | 5.2.2.4 cin_ctl_write_with_readback()         | <br>13 |
|------|---------|-----------------------------------------------|--------|
| 5.3  | Cin Po  | wer Routines                                  | <br>15 |
|      | 5.3.1   | Detailed Description                          | <br>15 |
|      | 5.3.2   | Function Documentation                        | <br>15 |
|      |         | 5.3.2.1 cin_ctl_fp_pwr()                      | <br>15 |
|      |         | 5.3.2.2 cin_ctl_pwr()                         | <br>15 |
| 5.4  | CIN Fir | mware Upload Routines                         | <br>16 |
|      | 5.4.1   | Detailed Description                          | <br>16 |
| 5.5  | CIN FO  | CLK Configuration Routines                    | <br>17 |
|      | 5.5.1   | Detailed Description                          | <br>17 |
| 5.6  | CIN Sta | atus Routines                                 | <br>18 |
|      | 5.6.1   | Detailed Description                          | <br>18 |
| 5.7  | CIN Co  | ontrol Bias Routines                          | <br>19 |
|      | 5.7.1   | Detailed Description                          | <br>19 |
| 5.8  | CIN CO  | Ontrol Timing Routines                        | <br>20 |
|      | 5.8.1   | Detailed Description                          | <br>20 |
| 5.9  | CIN Da  | ita Initialization Routines                   | <br>21 |
|      | 5.9.1   | Detailed Description                          | <br>21 |
|      | 5.9.2   | Function Documentation                        | <br>21 |
|      |         | 5.9.2.1 cin_data_destroy()                    | <br>21 |
|      |         | 5.9.2.2 cin_data_init()                       | <br>21 |
| 5.10 | CIN Da  | ta Framestore Functions                       | <br>24 |
|      | 5.10.1  | Detailed Description                          | <br>24 |
|      | 5.10.2  | Function Documentation                        | <br>24 |
|      |         | 5.10.2.1 cin_data_framestore_disable()        | <br>24 |
|      |         | 5.10.2.2 cin_data_framestore_skip()           | <br>24 |
|      |         | 5.10.2.3 cin_data_framestore_trigger()        | <br>25 |
|      |         | 5.10.2.4 cin_data_framestore_trigger_enable() | <br>25 |
|      |         | 5.10.2.5 cin_data_get_framestore_counter()    | <br>25 |

CONTENTS

| 6 | Clas | s Documentation                            | 27 |
|---|------|--------------------------------------------|----|
|   | 6.1  | cin_config_timing Struct Reference         | 27 |
|   |      | 6.1.1 Member Data Documentation            | 27 |
|   |      | 6.1.1.1 cols                               | 27 |
|   |      | 6.1.1.2 data                               | 27 |
|   |      | 6.1.1.3 data_len                           | 27 |
|   |      | 6.1.1.4 fclk_freq                          | 28 |
|   |      | 6.1.1.5 framestore                         | 28 |
|   |      | 6.1.1.6 name                               | 28 |
|   |      | 6.1.1.7 overscan                           | 28 |
|   |      | 6.1.1.8 rows                               | 28 |
|   | 6.2  | cin_ctl Struct Reference                   | 28 |
|   |      | 6.2.1 Member Data Documentation            | 29 |
|   |      | 6.2.1.1 fclk_time_factor                   | 29 |
|   | 6.3  | cin_ctl_id Struct Reference                | 29 |
|   | 6.4  | cin_ctl_listener Struct Reference          | 29 |
|   | 6.5  | cin_ctl_pwr_mon_t Struct Reference         | 30 |
|   | 6.6  | cin_ctl_pwr_val Struct Reference           | 30 |
|   | 6.7  | cin_data Struct Reference                  | 30 |
|   | 6.8  | cin_data_callbacks Struct Reference        | 31 |
|   | 6.9  | cin_data_descramble_map_t Struct Reference | 31 |
|   | 6.10 | cin_data_frame Struct Reference            | 32 |
|   | 6.11 | cin_data_packet Struct Reference           | 32 |
|   | 6.12 | cin_data_proc Struct Reference             | 32 |
|   | 6.13 | cin_data_stats Struct Reference            | 33 |
|   | 6.14 | cin_data_threads Struct Reference          | 33 |
|   | 6.15 | cin_map_t Struct Reference                 | 33 |
|   | 6.16 | cin_port Struct Reference                  | 34 |
|   | 6.17 | fifo Struct Reference                      | 34 |

iv CONTENTS

| 7 | File | Docume   | entation     |                             | 35 |
|---|------|----------|--------------|-----------------------------|----|
|   | 7.1  | src/cin. | .h File Refe | erence                      | 35 |
|   |      | 7.1.1    | Detailed     | Description                 | 40 |
|   |      | 7.1.2    | LICENSE      | <b></b>                     | 40 |
|   |      | 7.1.3    | DESCRI       | PTION                       | 41 |
|   |      | 7.1.4    | Macro De     | efinition Documentation     | 41 |
|   |      |          | 7.1.4.1      | CIN_CONFIG_MAX_TIMING_DATA  | 41 |
|   |      |          | 7.1.4.2      | CIN_CONFIG_MAX_TIMING_MODES | 41 |
|   |      |          | 7.1.4.3      | CIN_CTL_BIAS_OFFSET         | 41 |
|   | 7.2  | src/cin_ | _register_r  | map.h File Reference        | 42 |
|   |      | 7.2.1    | Detailed     | Description                 | 46 |
|   |      | 7.2.2    | LICENSE      | <b>.</b>                    | 47 |
|   |      | 7.2.3    | DESCRIF      | PTION                       | 47 |
|   |      | 7.2.4    | TIMING       |                             | 47 |
|   |      | 7.2.5    | Macro De     | efinition Documentation     | 47 |
|   |      |          | 7.2.5.1      | CMD_DISABLE_CLKS            | 47 |
|   |      |          | 7.2.5.2      | CMD_ENABLE_CLKS             | 48 |
|   |      |          | 7.2.5.3      | CMD_FCLK_250                | 48 |
|   |      |          | 7.2.5.4      | CMD_FCLK_COMMIT             | 48 |
|   |      |          | 7.2.5.5      | CMD_MON_START               | 48 |
|   |      |          | 7.2.5.6      | CMD_MON_STOP                | 48 |
|   |      |          | 7.2.5.7      | CMD_PS_ENABLE               | 48 |
|   |      |          | 7.2.5.8      | CMD_PS_POWERDOWN            | 48 |
|   |      |          | 7.2.5.9      | CMD_READ_REG                | 48 |
|   |      |          | 7.2.5.10     | CMD_RESET_FRAME_COUNT       | 49 |
|   |      |          | 7.2.5.11     | CMD_SEND_FCRIC_CONFIG       | 49 |
|   |      |          | 7.2.5.12     | CMD_SEND_SYNC_PULSE         | 49 |
|   |      |          | 7.2.5.13     | CMD_SYNC_DETECTOR2READOUT   | 49 |
|   |      |          | 7.2.5.14     | CMD_WR_CCD_BIAS_REG         | 49 |
|   |      |          | 7.2.5.15     | CMD_WR_CCD_CLOCK_REG        | 49 |

CONTENTS

| 7.2.5.16 | REG_BIASCONFIGREGISTER0_REG      | 49 |
|----------|----------------------------------|----|
| 7.2.5.17 | REG_BIASREGISTERDATAOUT          | 49 |
| 7.2.5.18 | REG_CLOCK_EN_REG                 | 50 |
| 7.2.5.19 | REG_CLOCKCONFIGREGISTER0_REG     | 50 |
| 7.2.5.20 | REG_COMMAND                      | 50 |
| 7.2.5.21 | REG_DEBUGCOUNTER04_REG           | 50 |
| 7.2.5.22 | REG_DELAYTOSHUTTERLSB_REG        | 50 |
| 7.2.5.23 | REG_ETH_ENABLE                   | 50 |
| 7.2.5.24 | REG_ETH_RESET                    | 50 |
| 7.2.5.25 | REG_EXPOSURETIMELSB_REG          | 51 |
| 7.2.5.26 | REG_EXPOSURETIMEMSB_REG          | 51 |
| 7.2.5.27 | REG_FCLK_I2C_ADDRESS             | 51 |
| 7.2.5.28 | REG_FCLK_I2C_DATA_RD             | 51 |
| 7.2.5.29 | REG_FCLK_I2C_DATA_WR             | 51 |
| 7.2.5.30 | REG_FCLK_SET5                    | 51 |
| 7.2.5.31 | REG_FPGA_VERSION                 | 51 |
| 7.2.5.32 | REG_FRM_10GbE_SEL                | 52 |
| 7.2.5.33 | REG_FRM_FPGA_VERSION             | 52 |
| 7.2.5.34 | REG_FRM_RESET                    | 52 |
| 7.2.5.35 | REG_FRM_SANDBOX_REG0F            | 52 |
| 7.2.5.36 | REG_FRM_STREAM_TYPE              | 52 |
| 7.2.5.37 | REG_IMON_ADC0_CHF                | 52 |
| 7.2.5.38 | REG_MAC_CFG_VECTOR1              | 52 |
| 7.2.5.39 | REG_MAC_CFG_VECTOR2              | 52 |
| 7.2.5.40 | REG_MAC_STATS2_FAB2B1            | 53 |
| 7.2.5.41 | REG_PHY1_MDIO_CMD                | 53 |
| 7.2.5.42 |                                  | 53 |
| 7.2.5.43 | REG_PS_SYNC_DIV0                 | 53 |
| 7.2.5.44 | REG_PS_SYNC_DIV1                 | 53 |
| 7.2.5.45 | REG_PS_SYNC_DIV2                 | 53 |
| 7.2.5.46 | REG_PS_SYNC_DIV3                 | 53 |
| 7.2.5.47 | REG_PS_SYNC_DIV4                 | 53 |
| 7.2.5.48 | REG_SANDBOX_REG0F                | 54 |
| 7.2.5.49 | REG_SI570_REG3                   | 54 |
| 7.2.5.50 | REG_SRAM_COMMAND                 | 54 |
| 7.2.5.51 | REG_SRAM_STATUS0                 | 54 |
| 7.2.5.52 | REG_STREAM_TYPE                  | 54 |
| 7.2.5.53 | REG_TRIGGERMASK_REG              | 54 |
| 7.2.5.54 | REG_TRIGGERREPETITIONTIMELSB_REG | 54 |
| 7.2.5.55 | REG_TRIGGERREPETITIONTIMEMSB_REG | 54 |
|          |                                  | 55 |
|          |                                  |    |

Index

## **Chapter 1**

# **FastCCD Communication Library (libcin)**

## Introduction

This library, based in C is designed to control the FastCCD detector from Lawrence Berkeley National Laboratory. It controls both camera control functions and data acquisition (frame acquisition). It is separated into two distinct parts, the control part <code>,cin\_ctl</code>, and the data (image) part named <code>cin\_data</code>. It was written in part for use with areaDetector.

## **Prerequisites**

The library relies on the following:

- libbsd (Used for string manipulation)
- libconfig (Used for nice config files)
- libpthread (Used for threading)
- librt (Used for time functions)

## Installation

Installation of the library is like most unix based source packages:

<sup>./</sup>make ./make doc ./make test

<sup>./</sup>make install

## **TCP/IP Stack Tuning**

In order for the CIN data to operate efficiently, the 10G interface on the host computer needs to be tuned. This needs to be done by adding the following to the file /etc/sysctl.conf.

```
# Increase the maximum buffer that user programs can request
# 2147483647 = 2048 Mb
net.core.rmem_max=2147483647
net.core.wmem_max=2147483647
# Set a default value 10 times bigger
net.core.rmem_default=1000000
net.core.wmem_default=1000000
# increase the length of the processor input queue
net.core.netdev_max_backlog = 250000
# recommended for hosts with jumbo frames enabled
net.ipv4.tcp_mtu_probing=1
```

These can be reread by the system without rebooting by entering the command:

```
$sudo sysctl --system
```

## Versioning

For the versions available, see the tags on this repository.

#### **Authors**

• Stuart B. Wilkins - stuwilkins

See also the list of contributors who participated in this project.

## License

This project is licensed under the BSD License - see the LICENSE file for details

### **Acknowledgments**

A huge thanks to Peter Dennes, John Joseph and the detector team at LBNL and the team at Sydor Instruments.

# Chapter 2

# **Module Index**

## 2.1 Modules

## Here is a list of all modules:

| Cin Control Initialization Routines . |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  |   | <br> | . 9  |
|---------------------------------------|--|--|--|--|--|--|--|--|--|--|------|--|--|--|---|------|------|
| Cin Control Read/Rwite Routines .     |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  |   | <br> | . 12 |
| Cin Power Routines                    |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  |   | <br> | . 15 |
| CIN Firmware Upload Routines          |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  |   | <br> | . 16 |
| CIN FCLK Configuration Routines .     |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  |   | <br> | . 17 |
| CIN Status Routines                   |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  |   | <br> | . 18 |
| CIN Control Bias Routines             |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  |   | <br> | . 19 |
| CIN COntrol Timing Routines           |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  |   |      | . 20 |
| CIN Data Initialization Routines      |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  |   | <br> | . 21 |
| CIN Data Framestore Functions         |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  | _ | <br> | . 24 |

4 Module Index

# **Chapter 3**

# **Class Index**

## 3.1 Class List

Here are the classes, structs, unions and interfaces with brief descriptions:

| cin_config_timing                                                                | 27 |
|----------------------------------------------------------------------------------|----|
|                                                                                  | 28 |
| $ cin\_ctl\_id  \dots  \dots  \dots  \dots  \dots  \dots  \dots  \dots  \dots  $ | 29 |
| cin_ctl_listener                                                                 | 29 |
|                                                                                  | 30 |
|                                                                                  | 30 |
|                                                                                  | 30 |
| cin_data_callbacks                                                               | 31 |
|                                                                                  | 31 |
|                                                                                  | 32 |
|                                                                                  | 32 |
|                                                                                  | 32 |
|                                                                                  | 33 |
|                                                                                  | 33 |
| $cin_{map}\underline{t}\;\ldots\ldots\ldots\ldots\ldots\ldots\ldots$             | 33 |
| cin_port                                                                         | 34 |
| fifo                                                                             | 34 |

6 Class Index

## **Chapter 4**

# File Index

## 4.1 File List

Here is a list of all documented files with brief descriptions:

| src/cin.h            |      |   |  |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  | <br> |  |  | 35 |
|----------------------|------|---|--|--|--|--|--|--|--|--|--|--|--|------|--|--|--|------|--|--|----|
| src/cin_register_map | o.h  |   |  |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  | <br> |  |  | 42 |
| src/cinregisters.h   |      |   |  |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  | <br> |  |  | ?? |
| src/common.h         |      |   |  |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  | <br> |  |  | ?? |
| src/config.h         |      |   |  |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  | <br> |  |  | ?? |
| src/control.h        |      |   |  |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  | <br> |  |  | ?? |
| src/data.h           |      |   |  |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  | <br> |  |  | ?? |
| src/descramble.h     |      |   |  |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  | <br> |  |  | ?? |
| src/descramble_ma    | ıp.h | 1 |  |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  | <br> |  |  | ?? |
| src/fifo.h           | ٠.   |   |  |  |  |  |  |  |  |  |  |  |  | <br> |  |  |  | <br> |  |  | ?? |
| src/report.h         |      |   |  |  |  |  |  |  |  |  |  |  |  |      |  |  |  |      |  |  | 22 |

8 File Index

## **Chapter 5**

## **Module Documentation**

## 5.1 Cin Control Initialization Routines

## **Functions**

- int cin\_ctl\_init (cin\_ctl\_t \*cin, char \*addr, uint16\_t port, uint16\_t sport, char \*bind\_addr, uint16\_t bind\_port, uint16\_t bind\_sport)
- int cin\_ctl\_destroy (cin\_ctl\_t \*cin)
- void cin\_ctl\_set\_msg\_callback (cin\_ctl\_t \*cin, cin\_ctl\_msg\_callback callback, void \*ptr)
- int cin\_data\_send\_magic (cin\_data\_t \*cin)

## 5.1.1 Detailed Description

## 5.1.2 Function Documentation

## 5.1.2.1 cin\_ctl\_destroy()

Destroy (close) the cin control library

Close connections, free memory and exit library

## **Parameters**

```
cin handle to cin library
```

## Returns

Returns 0 on sucsess non-zero if error

### 5.1.2.2 cin\_ctl\_init()

Initialize the cin control library

Initialize the control structures and communications with the CIN via the control interface. This function opens the UDP ports and starts a listening thread to recieve packets from the CIN.

#### **Parameters**

| cin        | handle to cin library          |
|------------|--------------------------------|
| addr       | ip address of CIN base address |
| port       | UDP port of cin                |
| sport      | stream output UDP port of cin  |
| bind_addr  | ip address to bind to          |
| bind_port  | input udp port of cin          |
| bind_sport | stream input udp port of cin   |

## Returns

Returns 0 on sucsess non-zero if error

## 5.1.2.3 cin\_ctl\_set\_msg\_callback()

Register a function to recieve status messages

Close connections, free memory and exit library

## **Parameters**

| cin      | handle to cin library                            |
|----------|--------------------------------------------------|
| callback | function pointer to callback function            |
| ptr      | user pointer which is passed to callback routine |

## 5.1.2.4 cin\_data\_send\_magic()

Send a magic packet to the CIN to initialize data

## **Parameters**

cin handle to cin library

## Returns

Returns 0 on sucsess non-zero if error

## 5.2 Cin Control Read/Rwite Routines

## **Functions**

- int cin\_ctl\_read (cin\_ctl\_t \*cin, uint16\_t reg, uint16\_t \*val, int wait)
- int cin\_ctl\_write (cin\_ctl\_t \*cin, uint16\_t reg, uint16\_t val, int wait)
- int cin\_ctl\_stream\_write (cin\_ctl\_t \*cin, unsigned char \*val, int size)
- int cin\_ctl\_write\_with\_readback (cin\_ctl\_t \*cin, uint16\_t reg, uint16\_t val)

## 5.2.1 Detailed Description

## 5.2.2 Function Documentation

## 5.2.2.1 cin\_ctl\_read()

## Read register from CIN

#### **Parameters**

| cin  | handle to cin library                                             |  |
|------|-------------------------------------------------------------------|--|
| reg  | register to read                                                  |  |
| val  | variable to read value of register to                             |  |
| wait | if non-zero, wait a predefined time before read command (for i2c) |  |

#### Returns

Returns 0 on sucsess non-zero if error

### 5.2.2.2 cin\_ctl\_stream\_write()

### Write stream data to CIN

#### **Parameters**

| cin  | handle to cin library           |
|------|---------------------------------|
| val  | array of values to write        |
| size | size of array pointed to by val |

Write stream data to cin in form of 16 bit array.

## Returns

Returns 0 on sucsess non-zero if error

#### 5.2.2.3 cin\_ctl\_write()

Write register to CIN

## **Parameters**

| cin  | handle to cin library      |
|------|----------------------------|
| reg  | register to write to       |
| val  | value to write to register |
| wait | if non-zero                |

Write register value to CIN. If wait is non-zero then wait a sleep time of i CIN\_CTL\_WRITE\_SLEEP before releasing the mutex to add flow control to the cin.

#### Returns

Returns 0 on sucsess non-zero if error

## 5.2.2.4 cin\_ctl\_write\_with\_readback()

Write register to CIN with readback verification

## **Parameters**

| cin | handle to cin library      |
|-----|----------------------------|
| reg | register to write to       |
| val | value to write to register |

Write register value to CIN. Follow write with read of register and compare value. CIN\_CTL\_WRITE\_SLEEP before releasing the mutex to add flow control to the cin.

## Returns

Returns 0 on sucsess non-zero if error

5.3 Cin Power Routines 15

## 5.3 Cin Power Routines

## **Functions**

```
    int cin_ctl_pwr (cin_ctl_t *cin, int pwr)
    int cin_ctl_fp_pwr (cin_ctl_t *cin, int pwr)
    int cin_ctl_fo_test_pattern (cin_ctl_t *cin, int on_off)
```

## 5.3.1 Detailed Description

These routine control power to the CIN for the Frame FPGA and the Front Panel

## 5.3.2 Function Documentation

## Control CIN Frame FPGA Power

Turn on and off the frame FPGA power. If pwr is 0 then turn off power. If pwr is 1 turn on power.

cin handle to cin library pwr power status

CIN\_OK on sucsess, CIN\_ERROR on an error

## 5.4 CIN Firmware Upload Routines

## **Functions**

- int cin\_ctl\_load\_firmware (cin\_ctl\_t \*cin)
- int cin\_ctl\_load\_firmware\_file (cin\_ctl\_t \*cin, char \*filename)
- int cin\_ctl\_load\_firmware\_data (cin\_ctl\_t \*cin, unsigned char \*data, int data\_len)
- int cin\_ctl\_load\_config (cin\_ctl\_t \*cin, char \*filename)

## 5.4.1 Detailed Description

Firmware upload routines

## 5.5 CIN FCLK Configuration Routines

## **Functions**

- int cin\_ctl\_get\_fclk (cin\_ctl\_t \*cin, int \*clkfreq)
- int cin\_ctl\_set\_fclk (cin\_ctl\_t \*cin, int clkfreq)

## 5.5.1 Detailed Description

FCLK (Internal FPGA Clock) Routines

## 5.6 CIN Status Routines

## **Functions**

- int cin\_ctl\_get\_cfg\_fpga\_status (cin\_ctl\_t \*cin, uint16\_t \*\_val)
- int cin\_ctl\_get\_id (cin\_ctl\_t \*cin, cin\_ctl\_id\_t \*\_val)
- int cin\_ctl\_get\_dcm\_status (cin\_ctl\_t \*cin, uint16\_t \*\_val)
- int cin\_ctl\_get\_power\_status (cin\_ctl\_t \*cin, int full, int \*pwr, cin\_ctl\_pwr\_mon\_t \*values)

## 5.6.1 Detailed Description

Status Routines

## 5.7 CIN Control Bias Routines

## **Functions**

- int cin\_ctl\_set\_bias (cin\_ctl\_t \*cin, int val)
- int cin\_ctl\_get\_bias (cin\_ctl\_t \*cin, int \*val)
- int cin\_ctl\_set\_bias\_regs (cin\_ctl\_t \*cin, uint16\_t \*vals, int verify)
- int cin\_ctl\_get\_bias\_regs (cin\_ctl\_t \*cin, uint16\_t \*vals)
- int cin\_ctl\_set\_bias\_voltages (cin\_ctl\_t \*cin, float \*voltage, int verify)
- int cin\_ctl\_get\_bias\_voltages (cin\_ctl\_t \*cin, float \*voltage, uint16\_t \*regs)

## 5.7.1 Detailed Description

Initialization group

## 5.8 CIN COntrol Timing Routines

## **Functions**

- int cin\_ctl\_set\_timing\_regs (cin\_ctl\_t \*cin, uint16\_t \*vals, int vals\_len)
- int cin\_ctl\_get\_timing\_regs (cin\_ctl\_t \*cin, uint16\_t \*vals, int vals\_len)

## 5.8.1 Detailed Description

Timing setup group

## 5.9 CIN Data Initialization Routines

## **Functions**

- int cin\_data\_init (cin\_data\_t \*cin, char \*addr, uint16\_t port, char \*bind\_addr, uint16\_t bind\_port, int rcvbuf, int packet\_buffer\_len, int frame\_buffer\_len, cin\_data\_callback push\_callback, cin\_data\_callback pop\_callback, void \*usr\_ptr)
- void cin\_data\_destroy (cin\_data\_t \*cin)

## 5.9.1 Detailed Description

Initialization group

#### 5.9.2 Function Documentation

## 5.9.2.1 cin\_data\_destroy()

Close the cin data library and cleanup

Stop all the processing threads and join them to the main thread. This function blocks until all threads have joined the main thread (program). This should be called to clean up the library before the program is exited

#### **Parameters**

```
cin Handle to cin data library
```

### 5.9.2.2 cin\_data\_init()

Initialize the cin data library

Initialize the data handeling routines and start the threads for listening.

## **Parameters**

| cin               | Handle to cin data library                                             |
|-------------------|------------------------------------------------------------------------|
| addr              | IP-Address of cin (if NULL defaults to standard)                       |
| port              | UDP Port of CIN                                                        |
| bind_addr         | IP-Address to bind to (if NULL binds to 0.0.0.0)                       |
| bind_port         | UDP Port of host                                                       |
| rcvbuf            | TCP/IP Kernel recieve buffer size                                      |
| packet_buffer_len | Length of packet buffer fifo (in units number of packets)              |
| frame_buffer_len  | Length of frame (assembler) buffer fifo (in units of number of frames) |
| push_callback     | This function is called when a data structure is needed                |
| pop_callback      | This function is called when an image has been processed               |
| usr_ptr           | Pointer passed to callback functions                                   |
|                   |                                                                        |

## 5.10 CIN Data Framestore Functions

## **Functions**

- void cin\_data\_framestore\_trigger (cin\_data\_t \*cin, int count)
- void cin\_data\_framestore\_skip (cin\_data\_t \*cin, int count)
- int cin\_data\_get\_framestore\_counter (cin\_data\_t \*cin)
- void cin\_data\_framestore\_disable (cin\_data\_t \*cin)
- void cin\_data\_framestore\_trigger\_enable (cin\_data\_t \*cin)

## 5.10.1 Detailed Description

Framestore Group

#### 5.10.2 Function Documentation

## 5.10.2.1 cin\_data\_framestore\_disable()

### Disable the framestore modes

This function disables the framestore modes (software trigger and skip). If the camera is hardware triggering then the images will start to be processed.

## **Parameters**

```
cin | Handle to the cin library
```

### 5.10.2.2 cin\_data\_framestore\_skip()

### Enable framestore skip mode

Enable the framestore skip mode. This function should be called before hardware triggering the camera. This causes the data processing to skip

#### **Parameters**

| count | frames from the first images to be read. This is usually done to stop the first few frames from being over exposed. |
|-------|---------------------------------------------------------------------------------------------------------------------|
| cin   | handle to the cin_data library                                                                                      |

#### 5.10.2.3 cin\_data\_framestore\_trigger()

## Send a framestore (software) trigger

Send a software trigger to the CIN by timestamping the request time and allow images to be processed when recieved after this time. The count option sets the number of frames to trigger. A value of -1 indicated that the trigger should not count images but run indefinately after the trigger has occured.

#### **Parameters**

| cin   | handle to the cin_data library |
|-------|--------------------------------|
| count | number of frames to trigger    |

## 5.10.2.4 cin\_data\_framestore\_trigger\_enable()

## Enable the framestore trigger mode

This function enables the framestore trigger mode. It cases the images to not be processed pending a call to the function to (software) trigger the camera.

## **Parameters**

```
cin Handle to the cin library
```

## 5.10.2.5 cin\_data\_get\_framestore\_counter()

Get the value of the framestore counter

Return the number of frames in the framestore counter. In trigger mode, this returns the number of frames to go. In skip mode, this returns the number of frames that have to be skipped.

## **Parameters**

cin handle to the cin\_data library

## Returns

Number of frames to go in trigger

## **Chapter 6**

## **Class Documentation**

## 6.1 cin\_config\_timing Struct Reference

## **Public Attributes**

- uint16\_t \* data
- int data\_len
- char name [40]
- int rows
- int cols
- · int overscan
- int fclk freq
- · int framestore

## 6.1.1 Member Data Documentation

```
6.1.1.1 cols
```

int cin\_config\_timing::cols

Cols for this timing setup

6.1.1.2 data

uint16\_t\* cin\_config\_timing::data

Pointer to timing data

6.1.1.3 data\_len

int cin\_config\_timing::data\_len

timing data length

28 Class Documentation

#### 6.1.1.4 fclk\_freq

int cin\_config\_timing::fclk\_freq

#### FCLK Frequency to use

#### 6.1.1.5 framestore

int cin\_config\_timing::framestore

Flag (not zero means framestore

#### 6.1.1.6 name

char cin\_config\_timing::name[40]

String for config name

#### 6.1.1.7 overscan

int cin\_config\_timing::overscan

Number of overscan cols for this setup

#### 6.1.1.8 rows

int cin\_config\_timing::rows

Rows for this timing setup

The documentation for this struct was generated from the following file:

• src/cin.h

## 6.2 cin\_ctl Struct Reference

## **Public Attributes**

- char \* addr
- char \* bind\_addr
- int port
- int bind\_port
- int sport
- int bind\_sport
- cin\_port\_t ctl\_port
- cin\_port\_t stream\_port
- cin\_config\_timing\_t timing [CIN\_CONFIG\_MAX\_TIMING\_MODES]
- int timing\_num
- cin\_config\_timing\_t \* current\_timing
- · float fclk\_time\_factor
- cin\_ctl\_listener\_t \* listener
- pthread\_mutex\_t access
- · pthread mutexattr taccess attr
- void(\* msg\_callback )(const char \*, int, void \*)
- void \* msg\_callback\_ptr

#### 6.2.1 Member Data Documentation

#### 6.2.1.1 fclk\_time\_factor

```
float cin_ctl::fclk_time_factor
```

#### In micro seconds

The documentation for this struct was generated from the following file:

• src/cin.h

## 6.3 cin\_ctl\_id Struct Reference

#### **Public Attributes**

- uint16\_t base\_board\_id
- uint16\_t base\_serial\_no
- uint16\_t base\_fpga\_ver
- uint16\_t fabric\_board\_id
- uint16\_t fabric\_serial\_no
- uint16\_t fabric\_fpga\_ver

The documentation for this struct was generated from the following file:

• src/cin.h

## 6.4 cin\_ctl\_listener Struct Reference

#### **Public Attributes**

- struct cin\_port \* cp
- fifo ctl\_fifo
- · pthread\_t thread\_id
- · pthread\_barrier\_t barrier

The documentation for this struct was generated from the following file:

• src/cin.h

30 Class Documentation

## 6.5 cin\_ctl\_pwr\_mon\_t Struct Reference

#### **Public Attributes**

- · cin\_ctl\_pwr\_val\_t bus\_12v0
- cin\_ctl\_pwr\_val\_t mgmt\_3v3
- cin\_ctl\_pwr\_val\_t mgmt\_2v5
- cin\_ctl\_pwr\_val\_t mgmt\_1v2
- cin\_ctl\_pwr\_val\_t enet\_1v0
- cin\_ctl\_pwr\_val\_t s3e\_3v3
- cin\_ctl\_pwr\_val\_t gen\_3v3
- cin ctl pwr val t gen 2v5
- cin\_ctl\_pwr\_val\_t v6\_0v9
- cin\_ctl\_pwr\_val\_t v6\_1v0
- cin\_ctl\_pwr\_val\_t v6\_2v5
- cin\_ctl\_pwr\_val\_t fp

The documentation for this struct was generated from the following file:

• src/cin.h

## 6.6 cin\_ctl\_pwr\_val Struct Reference

#### **Public Attributes**

- double i
- double **v**

The documentation for this struct was generated from the following file:

• src/cin.h

## 6.7 cin\_data Struct Reference

#### **Public Attributes**

- fifo \* packet\_fifo
- fifo \* frame\_fifo
- · cin\_data\_threads\_t listen\_thread
- · cin\_data\_threads\_t assembler\_thread
- cin\_data\_threads\_t descramble\_thread
- pthread\_mutex\_t descramble\_mutex
- pthread\_mutex\_t stats\_mutex
- pthread\_mutex\_t framestore\_mutex
- cin\_data\_callbacks\_t callbacks
- char \* addr
- char \* bind\_addr
- int port

- int bind\_port
- int recv\_buf
- cin\_port\_t dp
- · struct timespec framerate
- unsigned long int dropped\_packets
- unsigned long int mallformed\_packets
- uint16\_t last\_frame
- cin\_data\_descramble\_map\_t map
- int framestore\_mode
- struct timespec framestore\_trigger
- int framestore\_counter

The documentation for this struct was generated from the following file:

• src/cin.h

## 6.8 cin\_data\_callbacks Struct Reference

#### **Public Attributes**

```
void *(* push )(cin_data_frame_t *, void *usr_ptr)
```

- void \*(\* pop )(cin\_data\_frame\_t \*, void \*usr\_ptr)
- cin\_data\_frame\_t \* frame
- void \* usr\_ptr

The documentation for this struct was generated from the following file:

• src/cin.h

## 6.9 cin\_data\_descramble\_map\_t Struct Reference

#### **Public Attributes**

- uint32\_t \* map
- int size x
- int size\_y
- int overscan
- int rows

The documentation for this struct was generated from the following file:

• src/cin.h

32 Class Documentation

## 6.10 cin\_data\_frame Struct Reference

#### **Public Attributes**

- uint16\_t \* data
- uint16\_t number
- · struct timespec timestamp
- int size\_x
- int size\_y

The documentation for this struct was generated from the following file:

• src/cin.h

## 6.11 cin\_data\_packet Struct Reference

#### **Public Attributes**

- unsigned char \* data
- int size
- · struct timespec timestamp

The documentation for this struct was generated from the following file:

• src/data.h

## 6.12 cin\_data\_proc Struct Reference

#### **Public Attributes**

- void \*(\* input\_get )(void \*, int)
- void \*(\* input\_put )(void \*, int)
- void \* input\_args
- · int reader
- void \*(\* output\_put )(void \*)
- void \*(\* output\_get )(void \*)
- void \* output\_args
- cin\_data\_t \* parent

The documentation for this struct was generated from the following file:

• src/data.h

## 6.13 cin\_data\_stats Struct Reference

#### **Public Attributes**

- int last\_frame
- · double framerate
- double packet\_percent\_full
- double frame\_percent\_full
- double image\_percent\_full
- long int packet\_overruns
- long int frame\_overruns
- long int image\_overruns
- long int packet\_used
- long int frame\_used
- long int image\_used
- long int dropped\_packets
- long int mallformed\_packets

The documentation for this struct was generated from the following file:

• src/cin.h

## 6.14 cin\_data\_threads Struct Reference

#### **Public Attributes**

- pthread\_t thread\_id
- pthread\_barrier\_t barrier
- · int started

The documentation for this struct was generated from the following file:

• src/cin.h

## 6.15 cin\_map\_t Struct Reference

#### **Public Attributes**

- char \* name
- uint16\_t reg

The documentation for this struct was generated from the following file:

src/cinregisters.h

34 Class Documentation

## 6.16 cin\_port Struct Reference

#### **Public Attributes**

- · int sockfd
- struct timeval tv
- struct sockaddr\_in sin\_srv
- struct sockaddr\_in sin\_cli
- socklen\_t slen

The documentation for this struct was generated from the following file:

• src/cin.h

## 6.17 fifo Struct Reference

#### **Public Attributes**

- void \* data
- void \* head
- void \* tail
- void \* end
- · long int size
- int elem\_size
- int full
- · long int overruns
- pthread\_mutex\_t mutex
- pthread\_cond\_t signal

The documentation for this struct was generated from the following file:

• src/cin.h

## **Chapter 7**

## **File Documentation**

#### 7.1 src/cin.h File Reference

```
#include <stdint.h>
#include <stdio.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <sys/time.h>
#include <pthread.h>
```

#### **Classes**

- struct fifo
- struct cin\_ctl\_listener
- struct cin\_port
- struct cin\_config\_timing
- struct cin\_ctl
- struct cin\_data\_frame
- struct cin\_data\_stats
- struct cin\_data\_threads
- · struct cin data callbacks
- struct cin\_data\_descramble\_map\_t
- struct cin\_data
- struct cin\_ctl\_id
- struct cin\_ctl\_pwr\_val
- struct cin\_ctl\_pwr\_mon\_t

#### **Macros**

- #define CIN\_OK 0
- #define CIN ERROR -1
- #define CIN\_CTL\_MSG\_OK 0
- #define CIN\_CTL\_MSG\_MINOR 1
- #define CIN\_CTL\_MSG\_MAJOR 2

- #define CIN CTL IP "192.168.1.207"
- #define CIN\_CTL\_CIN\_PORT 49200
- #define CIN\_CTL\_BIND\_PORT 50200
- #define CIN CTL FRMW CIN PORT 49202
- #define CIN CTL FRMW BIND PORT 50202
- #define CIN\_CTL\_RCVBUF 10
- #define CIN CTL MAX READ TRIES 5
- #define CIN\_CTL\_MAX\_WRITE\_TRIES 5
- #define CIN\_CTL\_WRITE\_SLEEP 100
- #define CIN CTL READ SLEEP 100
- #define CIN CTL BIAS SLEEP 100000
- #define CIN CTL FO SLEEP 500000
- #define CIN\_CTL\_CONFIG\_SLEEP 100
- #define CIN\_CTL\_DCO\_SLEEP 1000000
- #define CIN\_CTL\_FCLK\_SLEEP 200000
- #define CIN CTL STREAM CHUNK 512
- #define CIN CTL STREAM SLEEP 5
- #define CIN CTL POWER ENABLE 0x001F
- #define CIN\_CTL\_POWER\_DISABLE 0x0000
- #define CIN\_CTL\_FP\_POWER\_ENABLE 0x0020
- #define CIN\_CTL\_DCM\_LOCKED 0x0001
- #define CIN CTL DCM PSDONE 0x0002
- #define CIN CTL DCM STATUS0 0x0004
- #define CIN\_CTL\_DCM\_STATUS1 0x0008
- #define CIN CTL DCM STATUS2 0x0010
- #define CIN\_CTL\_DCM\_TX1\_READY 0x0020
- #define CIN\_CTL\_DCM\_TX2\_READY 0x0040
- #define CIN CTL DCM ATCA ALARM 0x0080
- #define CIN CTL TRIG INTERNAL 0x0000
- #define CIN\_CTL\_TRIG\_EXTERNAL\_1 0x0001
- #define CIN\_CTL\_TRIG\_EXTERNAL\_2 0x0002
- #define CIN CTL TRIG EXTERNAL BOTH 0x0003
- #define CIN\_CTL\_FOCUS\_BIT 0x0002
- #define CIN\_CTL\_FCLK\_125 0x0000
- #define CIN\_CTL\_FCLK\_200 0x0001
- #define CIN CTL FCLK 250 0x0002
- #define CIN\_CTL\_FCLK\_125\_C 0x0003
- #define CIN\_CTL\_FCLK\_200\_C 0x0004
- #define CIN\_CTL\_FCLK\_250\_C 0x0005
- #define CIN CTL FCLK 156 C 0x0006
- #define CIN\_CTL\_FPGA\_STS\_CFG 0x8000
- #define CIN\_CTL\_FPGA\_STS\_FP\_PWR 0x0008
- #define CIN\_CTL\_DCM\_STS\_ATCA 0x0080
- #define CIN\_CTL\_DCM\_STS\_LOCKED 0x0001
- #define CIN\_CTL\_DCM\_STS\_OVERIDE 0x0800
- #define CIN CTL MUX1 VCLK1 0x0001
- #define CIN CTL MUX1 VCLK2 0x0002
- #define CIN CTL MUX1 VCLK3 0x0003
- #define CIN\_CTL\_MUX1\_ATG 0x0004
- #define CIN\_CTL\_MUX1\_VFSCLK1 0x0005
- #define CIN CTL MUX1 VFSCLK2 0x0006
- #define CIN\_CTL\_MUX1\_VFSCLK3 0x0007
- #define CIN CTL MUX1 HCLK1 0x0008
- #define CIN CTL MUX1 HCLK2 0x0009
- #define CIN\_CTL\_MUX1\_OSW 0x000A

7.1 src/cin.h File Reference 37

- #define CIN\_CTL\_MUX1\_RST 0x000B
- #define CIN\_CTL\_MUX1\_CONVERT 0x000C
- #define CIN\_CTL\_MUX1\_SHUTTER 0x000D
- #define CIN CTL MUX1 SWTRIGGER 0x000E
- #define CIN CTL MUX1 TRIGMON 0x000F
- #define CIN\_CTL\_MUX1\_EXPOSE 0x0000
- #define CIN CTL MUX2 VCLK1 0x0010
- #define CIN\_CTL\_MUX2\_VCLK2 0x0020
- #define CIN\_CTL\_MUX2\_VCLK3 0x0030
- #define CIN CTL MUX2 ATG 0x0040
- #define CIN CTL MUX2 VFSCLK1 0x0050
- #define CIN CTL MUX2 VFSCLK2 0x0060
- #define CIN\_CTL\_MUX2\_VFSCLK3 0x0070
- #define CIN CTL MUX2 HCLK1 0x0080
- #define CIN\_CTL\_MUX2\_HCLK2 0x0090
- #define CIN CTL MUX2 HCLK3 0x00A0
- #define CIN CTL MUX2 OSW 0x00B0
- #define CIN CTL MUX2 RST 0x00C0
- #define CIN CTL MUX2 CONVERT 0x00D0
- #define CIN\_CTL\_MUX2\_SAVE 0x00E0
- #define CIN\_CTL\_MUX2\_HWTRIG 0x00F0
- #define CIN CTL MUX2 EXPOSE 0x0000
- #define CIN CTL FO REG1 0x821D
- #define CIN\_CTL\_FO\_REG2 0x821E
- #define CIN\_CTL\_FO\_REG3 0x821F
- #define CIN\_DATA\_IP "10.0.5.207"
- #define CIN\_DATA\_BIND\_PORT 49201
- #define CIN\_DATA\_CIN\_PORT 49203
- #define CIN\_DATA\_FRAME\_BUFFER\_LEN 1000
- #define CIN\_DATA\_PACKET\_BUFFER\_LEN 10000
- #define CIN DATA MAX MTU 9000
- #define CIN DATA UDP HEADER 8
- #define CIN\_DATA\_MAGIC\_PACKET UINT64\_C(0x0000F4F3F2F1F000)
- #define CIN\_DATA\_MAGIC\_PACKET\_MASK UINT64\_C(0x0000FFFFFFFFF00)
- #define CIN\_DATA\_TAIL\_MAGIC\_PACKET UINT64\_C(0x010DF0ADDEF2F1F0)
- #define CIN\_DATA\_DROPPED\_PACKET\_VAL 0x2000
- #define CIN\_DATA\_DATA\_MASK 0x1FFF
- #define CIN\_DATA\_CTRL\_MASK 0xE000
- #define CIN DATA SIGN MASK 0x1000
- #define CIN DATA GAIN 8 0xC000
- #define CIN\_DATA\_GAIN\_4 0x4000
- #define CIN\_DATA\_PACKET\_LEN 8184
- #define CIN\_DATA\_MAX\_PACKETS 542
- #define CIN\_DATA\_RCVBUF (100\*1024\*1024)
- #define CIN DATA MAX FRAME X 1152
- #define CIN DATA MAX FRAME Y 2050
- #define CIN DATA MAX STREAM 2400000
- #define CIN\_DATA\_CCD\_COLS 96
- #define CIN\_DATA\_CCD\_COLS\_PER\_CHAN 10
- #define CIN DATA PIPELINE FLUSH 1344
- #define CIN\_CTL\_NUM\_BIAS 20
- #define CIN CTL BIAS OFFSET 0x0030
- #define CIN CTL BIAS POSH 0
- #define CIN CTL BIAS NEGH 1

- #define CIN\_CTL\_BIAS\_POSRG 2
- #define CIN\_CTL\_BIAS\_NEGRG 3
- · #define CIN CTL BIAS POSSW 4
- #define CIN CTL BIAS NEGSW 5
- #define CIN CTL BIAS POSV 6
- #define CIN CTL BIAS NEGV 7
- #define CIN\_CTL\_BIAS\_POSTG 8
- #define CIN\_CTL\_BIAS\_NEGTG 9
- #define CIN\_CTL\_BIAS\_POSVF 10
- #define CIN CTL BIAS NEGVF 11
- #define CIN CTL BIAS NEDGE 12
- #define CIN\_CTL\_BIAS\_OTG 13
- #define CIN\_CTL\_BIAS\_VDDR 14
- #define CIN\_CTL\_BIAS\_VDD\_OUT 15
- #define CIN CTL BIAS BUF BASE 16
- #define CIN\_CTL\_BIAS\_BUF\_DELTA 17
- #define CIN\_CTL\_BIAS\_SPARE1 18
- #define CIN CTL BIAS SPARE2 19
- #define DEBUG\_PRINT(fmt, ...) if(\_debug\_print\_flag) { fprintf(stderr, "%s:%d:%s(): " fmt, \_\_FILE\_\_, \_\_LI ← NE\_\_, \_\_func\_\_, \_\_VA\_ARGS\_\_); }
- #define DEBUG\_COMMENT(fmt) if(\_debug\_print\_flag) { fprintf(stderr, "%s:%d:%s(): " fmt, \_\_FILE\_\_, \_\_ ←
   LINE\_\_, \_\_func\_\_); }
- #define ERROR\_COMMENT(fmt) if(\_error\_print\_flag) { fprintf(stderr, "%s:%d:%s(): " fmt, \_\_FILE\_\_, \_\_LI ← NE\_\_, \_\_func\_\_); }
- #define ERROR\_PRINT(fmt, ...) if(\_error\_print\_flag) { fprintf(stderr, "%s:%d:%s(): " fmt, \_\_FILE\_\_, \_\_LIN←
   E\_\_, \_\_func\_\_, \_\_VA\_ARGS\_\_); }
- #define CIN\_CONFIG\_MAX\_STRING 40
- #define CIN CONFIG MAX TIMING DATA 880
- #define CIN\_CONFIG\_MAX\_TIMING\_MODES 20

#### **Typedefs**

- typedef struct cin\_ctl\_listener cin\_ctl\_listener\_t
- typedef struct cin\_port cin\_port\_t
- typedef struct cin\_config\_timing cin\_config\_timing\_t
- typedef struct cin\_ctl cin\_ctl\_t
- typedef struct cin data frame cin data frame t
- typedef struct cin\_data\_stats cin\_data\_stats\_t
- typedef struct cin data threads cin data threads t
- typedef struct cin\_data\_callbacks cin\_data\_callbacks\_t
- typedef struct cin\_data cin\_data\_t
- typedef void(\* cin\_data\_callback) (cin\_data\_frame\_t \*, void \*usr\_ptr)
- typedef void(\* cin\_ctl\_msg\_callback) (const char \*, int, void \*)
- typedef struct cin\_ctl\_id cin\_ctl\_id\_t
- typedef struct cin\_ctl\_pwr\_val cin\_ctl\_pwr\_val\_t

#### **Functions**

```
    void cin set debug print (int debug)

    void cin_set_error_print (int error)

    void cin report (FILE *fp, int details)

• int cin ctl init (cin ctl t *cin, char *addr, uint16 t port, uint16 t sport, char *bind addr, uint16 t bind port,
  uint16 t bind sport)
int cin_ctl_destroy (cin_ctl_t *cin)

    void cin_ctl_set_msg_callback (cin_ctl_t *cin, cin_ctl_msg_callback callback, void *ptr)

    int cin_data_send_magic (cin_data_t *cin)

• int cin ctl read (cin ctl t *cin, uint16 t reg, uint16 t *val, int wait)
• int cin_ctl_write (cin_ctl_t *cin, uint16_t reg, uint16 t val, int wait)
• int cin ctl stream write (cin ctl t *cin, unsigned char *val, int size)

    int cin_ctl_write_with_readback (cin_ctl_t *cin, uint16_t reg, uint16_t val)

int cin_ctl_pwr (cin_ctl_t *cin, int pwr)
• int cin_ctl_fp_pwr (cin_ctl_t *cin, int pwr)
• int cin ctl fo test pattern (cin ctl t *cin, int on off)
• int cin_ctl_load_firmware (cin_ctl_t *cin)
• int cin ctl load firmware file (cin ctl t *cin, char *filename)
• int cin_ctl_load_firmware_data (cin_ctl_t *cin, unsigned char *data, int data_len)

    int cin_ctl_load_config (cin_ctl_t *cin, char *filename)

    int cin_ctl_get_fclk (cin_ctl_t *cin, int *clkfreq)

• int cin ctl set fclk (cin ctl t *cin, int clkfreq)
• int cin ctl get cfg fpga status (cin ctl t *cin, uint16 t * val)
int cin_ctl_get_id (cin_ctl_t *cin, cin_ctl_id_t *_val)
• int cin ctl get dcm status (cin ctl t *cin, uint16 t * val)
• int cin_ctl_get_power_status (cin_ctl_t *cin, int full, int *pwr, cin_ctl_pwr_mon_t *values)
• int cin ctl set bias (cin ctl t *cin, int val)

    int cin ctl get bias (cin ctl t *cin, int *val)

• int cin ctl set bias regs (cin ctl t *cin, uint16 t *vals, int verify)

    int cin ctl get bias regs (cin ctl t *cin, uint16 t *vals)

    int cin_ctl_set_bias_voltages (cin_ctl_t *cin, float *voltage, int verify)

• int cin_ctl_get_bias_voltages (cin_ctl_t *cin, float *voltage, uint16_t *regs)
• int cin ctl set timing regs (cin ctl t *cin, uint16 t *vals, int vals len)
• int cin_ctl_get_timing_regs (cin_ctl_t *cin, uint16_t *vals, int vals_len)

    int cin_ctl_get_camera_pwr (cin_ctl_t *cin, int *val)

    int cin_ctl_set_camera_pwr (cin_ctl_t *cin, int val)

    int cin ctl set clocks (cin ctl t *cin, int val)

    int cin_ctl_get_clocks (cin_ctl_t *cin, int *val)

    int cin ctl set trigger (cin ctl t *cin, int val)

    int cin ctl get trigger (cin ctl t *cin, int *val)

    int cin_ctl_set_focus (cin_ctl_t *cin, int val)

    int cin_ctl_get_focus (cin_ctl_t *cin, int *val)

    int cin_ctl_get_triggering (cin_ctl_t *cin, int *trigger)

• int cin ctl int trigger start (cin ctl t *cin, int nimages)

    int cin_ctl_int_trigger_stop (cin_ctl_t *cin)

• int cin_ctl_ext_trigger_start (cin_ctl_t *cin, int trigger_mode)

    int cin_ctl_ext_trigger_stop (cin_ctl_t *cin)

• int cin_ctl_set_exposure_time (cin_ctl_t *cin, float e_time)
• int cin_ctl_set_trigger_delay (cin_ctl_t *cin, float t_time)

    int cin_ctl_set_cycle_time (cin_ctl_t *cin, float ftime)

• int cin ctl frame count reset (cin ctl t *cin)

    int cin_ctl_set_mux (cin_ctl_t *cin, int setting)

    int cin_ctl_get_mux (cin_ctl_t *cin, int *setting)
```

int cin\_ctl\_set\_fcric\_clamp (cin\_ctl\_t \*cin, int clamp)

- int cin\_ctl\_set\_fcric\_gain (cin\_ctl\_t \*cin, int gain)
- int cin\_ctl\_set\_fcric\_regs (cin\_ctl\_t \*cin, uint16\_t \*reg, int num\_reg)
- int cin\_ctl\_set\_fcric (cin\_ctl\_t \*cin)
- int cin\_ctl\_set\_fabric\_address (cin\_ctl\_t \*cin, char \*ip)
- int cin ctl bias dump (cin ctl t \*cin, FILE \*fp)
- int cin\_ctl\_reg\_dump (cin\_ctl\_t \*cin, FILE \*fp)
- int cin config read file (cin ctl t \*cin, const char \*file)
- int cin\_data\_init (cin\_data\_t \*cin, char \*addr, uint16\_t port, char \*bind\_addr, uint16\_t bind\_port, int rcvbuf, int packet\_buffer\_len, int frame\_buffer\_len, cin\_data\_callback push\_callback, cin\_data\_callback pop\_callback, void \*usr\_ptr)
- void cin data destroy (cin data t \*cin)
- void cin\_data\_framestore\_trigger (cin\_data\_t \*cin, int count)
- void cin\_data\_framestore\_skip (cin\_data\_t \*cin, int count)
- int cin\_data\_get\_framestore\_counter (cin\_data\_t \*cin)
- void cin\_data\_framestore\_disable (cin\_data\_t \*cin)
- void cin data framestore trigger enable (cin data t \*cin)
- struct cin\_data\_frame \* cin\_data\_get\_next\_frame (cin\_data\_t \*cin)
- void cin\_data\_release\_frame (cin\_data\_t \*cin, int free\_mem)
- struct cin\_data\_frame \* cin\_data\_get\_buffered\_frame (void)
- void cin\_data\_release\_buffered\_frame (void)
- void cin\_data\_compute\_stats (cin\_data\_t \*cin, cin\_data\_stats\_t \*stats)
- void cin data show stats (FILE \*fp, cin data stats t stats)
- void cin data reset stats (cin data t \*cin)
- int cin\_data\_set\_descramble\_params (cin\_data\_t \*cin, int rows, int overscan)
- void cin data get descramble params (cin data t \*cin, int \*rows, int \*voverscan, int \*xsize, int \*ysize)
- int cin\_com\_boot (cin\_ctl\_t \*cin\_ctl, cin\_data\_t \*cin\_data, const char \*mode)
- int cin\_ctl\_upload\_bias (cin\_ctl\_t \*cin)

#### **Variables**

- const char \* cin\_build\_git\_time
- · const char \* cin build git sha
- · const char \* cin build version
- · int debug print flag
- int \_error\_print\_flag

#### 7.1.1 Detailed Description

**Author** 

Stuart B. Wilkins swilkins@bnl.gov

#### 7.1.2 LICENSE

Copyright (c) 2014, Brookhaven Science Associates, Brookhaven National Laboratory All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.

7.1 src/cin.h File Reference 41

2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

The views and conclusions contained in the software and documentation are those of the authors and should not be interpreted as representing official policies, either expressed or implied, of the FreeBSD Project.

#### 7.1.3 DESCRIPTION

Header file for CIN communications

#### 7.1.4 Macro Definition Documentation

#### 7.1.4.1 CIN\_CONFIG\_MAX\_TIMING\_DATA

#define CIN\_CONFIG\_MAX\_TIMING\_DATA 880

Max = 55 per state, 16 states

#### 7.1.4.2 CIN\_CONFIG\_MAX\_TIMING\_MODES

#define CIN\_CONFIG\_MAX\_TIMING\_MODES 20

20 states max

#### 7.1.4.3 CIN\_CTL\_BIAS\_OFFSET

#define CIN\_CTL\_BIAS\_OFFSET 0x0030

Offset in address to read bias

### 7.2 src/cin\_register\_map.h File Reference

#### **Macros**

- #define REG COMMAND 0x0001
- #define REG READ ADDRESS 0x0002
- #define REG\_STREAM\_TYPE 0x0003
- #define CMD FCLK 125 0xB000
- #define CMD\_FCLK\_200 0x7000
- #define CMD FCLK 250 0x3000
- #define REG IF MAC0 0x0010
- #define REG\_IF\_MAC1 0x0011
- #define REG IF MAC2 0x0012
- #define REG\_IF\_IP0 0x0013
- #define REG IF IP1 0x0014
- #define REG\_IF\_CMD\_PORT\_NUM 0x001A
- #define REG IF STREAM IN PORT NUM 0x001C
- #define REG IF STREAM OUT PORT NUM 0x001D
- #define REG\_ETH\_RESET 0x0020
- #define REG ETH ENABLE 0x0021
- #define REG\_PHY1\_MDIO\_CMD 0x0022
- #define REG PHY1 MDIO CMD DATA 0x0023
- #define REG PHY1 MDIO STATUS 0x0024
- #define REG PHY1 MDIO RD ADDR 0x0025
- #define REG PHY1 MDIO RD DATA 0x0026
- #define REG\_MAC\_CFG\_VECTOR1 0x0027
- #define REG PHY2 MDIO CMD 0x0028
- #define REG\_PHY2\_MDIO\_CMD\_DATA 0x0029
- #define REG\_PHY2\_MDIO\_STATUS 0x002A
- #define REG\_PHY2\_MDIO\_RD\_ADDR 0x002B
- #define REG\_PHY2\_MDIO\_RD\_DATA 0x002C
- #define REG MAC CFG VECTOR2 0x002D
- #define CMD PS ENABLE 0x0021
- #define CMD PS POWERDOWN 0x0022
- #define REG PS ENABLE 0x0030
- #define REG\_PS\_SYNC\_DIV0 0x0031
- #define REG\_PS\_SYNC\_DIV1 0x0032
- #define REG\_PS\_SYNC\_DIV2 0x0033
- #define REG\_PS\_SYNC\_DIV3\_0x0034
- #define REG PS SYNC DIV4 0x0035
- #define CMD\_PROGRAM\_FRAME 0x0041
- #define REG\_FRM\_RESET 0x0036
- #define REG\_FRM\_10GbE\_SEL 0x0037;
- #define CMD\_ENABLE\_CLKS 0x0031
- #define CMD\_DISABLE\_CLKS 0x0032
- #define REG CLOCK EN REG 0x0038
- #define REG SI570 REG0 0x0039
- #define REG SI570 REG1 0x003A
- #define REG\_SI570\_REG2 0x003B
- #define REG\_SI570\_REG3 0x003C
- #define CMD\_MON\_STOP 0x0011
- #define CMD\_MON\_START 0x0012
- #define REG\_VMON\_ADC1\_CH1 0x0040 /\* V12P\_BUS Voltage Monitor \*/
- #define REG\_IMON\_ADC1\_CH0 0x0041 /\* V12P\_BUS Current Monitor \*/

- #define REG VMON ADC0 CH5 0x0042 /\* V3P3 MGMT Voltage Monitor \*/
- #define REG IMON ADC0 CH5 0x0043 /\* V3P3 MGMT Current Monitor \*/
- #define REG\_VMON\_ADC0\_CH4 0x0044 /\* V3P3\_S3E Voltage Monitor \*/
- #define REG IMON ADC0 CH4 0x0045 /\* V3P3 S3E Current Monitor \*/
- #define REG VMON ADC0 CH7 0x0046 /\* V2P5 MGMT Voltage Monitor \*/
- #define REG\_IMON\_ADC0\_CH7 0x0047 /\* V2P5\_MGMT Current Monitor \*/
- #define REG VMON ADC0 CH6 0x0048 /\* V1P8 MGMT Voltage Monitor \*/
- #define REG\_IMON\_ADC0\_CH6 0x0049 /\* V1P8\_MGMT Current Monitor \*/
- #define REG VMON ADC0 CH2 0x004A /\* V1P2 MGMT Voltage Monitor \*/
- #define REG IMON ADC0 CH2 0x004B /\* V1P2 MGMT Current Monitor \*/
- #define REG VMON ADC0 CH3 0x004C /\* V1P0 ENET Voltage Monitor \*/
- #define REG\_IMON\_ADC0\_CH3 0x004D /\* V1P0\_ENET Current Monitor \*/
- #define REG VMON ADC0 CH8 0x004E /\* V3P3 GEN Voltage Monitor \*/
- #define REG IMON ADCO CH8 0x004F /\* V3P3 GEN Current Monitor \*/
- #define REG\_VMON\_ADC0\_CH9 0x0050 /\* V2P5\_GEN Voltage Monitor \*/
- #define REG IMON ADC0 CH9 0x0051 /\* V2P5 GEN Current Monitor \*/
- #define **REG VMON ADCO CHE** 0x0052 /\* V0P9 V6 Voltage Monitor \*/
- #define REG IMON ADC0 CHE 0x0053 /\* V0P9 V6 Current Monitor \*/
- #define REG\_VMON\_ADC0\_CHD 0x0054 /\* V2P5\_V6 Voltage Monitor \*/
- #define REG\_IMON\_ADC0\_CHD 0x0055 /\* V2P5\_V6 Current Monitor \*/
- #define REG\_VMON\_ADC0\_CHB 0x0056 /\* V1P0\_V6 Voltage Monitor \*/
- #define REG IMON ADC0 CHB 0x0057 /\* V1P0 V6 Current Monitor \*/ #define REG VMON ADC0 CHC 0x0058 /\* V1P2 V6 Voltage Monitor \*/
- #define REG\_IMON\_ADC0\_CHC 0x0059 /\* V1P2\_V6 Current Monitor \*/
- #define REG VMON ADC0 CHF 0x005A /\* V5P0 FP Voltage Monitor (1/2) \*/
- #define REG\_IMON\_ADC0\_CHF 0x005B /\* V5P0\_FP Current Monitor (1/2) \*/
- #define REG DCM STATUS 0x0080
- #define REG FPGA STATUS 0x0081
- #define REG BOARD ID 0x008D
- #define REG\_HW\_SERIAL\_NUM 0x008E
- #define REG FPGA VERSION 0x008F
- #define REG SANDBOX REG00 0x00F0
- #define REG\_SANDBOX\_REG01 0x00F1
- #define REG SANDBOX REG02 0x00F2
- #define REG SANDBOX REG03 0x00F3 #define REG SANDBOX REG04 0x00F4
- #define REG SANDBOX REG05 0x00F5
- #define **REG\_SANDBOX\_REG06** 0x00F6
- #define REG SANDBOX REG07 0x00F7
- #define REG SANDBOX REG08 0x00F8
- #define REG SANDBOX REG09 0x00F9
- #define REG SANDBOX REG0A 0x00FA
- #define REG SANDBOX REG0B 0x00FB
- #define REG\_SANDBOX\_REG0C 0x00FC
- #define REG SANDBOX REGOD 0x00FD
- #define REG SANDBOX REG0E 0x00FE
- #define REG SANDBOX REGOF 0x00FF
- #define REG FRM COMMAND 0x8001
- #define REG\_FRM\_READ\_ADDRESS 0x8002
- #define REG\_FRM\_STREAM\_TYPE 0x8003
- #define CMD SEND SYNC PULSE 0x0100
- #define CMD SYNC DETECTOR2READOUT 0x0101
- #define CMD WR CCD BIAS REG 0x0102
- #define CMD WR CCD CLOCK REG 0x0103
- #define CMD\_SEND\_FCRIC\_CONFIG 0x0105

- #define CMD RESET FRAME COUNT 0x0106
- #define REG\_IF\_MAC\_FAB1B0 0x8010
- #define REG\_IF\_MAC\_FAB1B1 0x8011
- #define REG IF MAC FAB1B2 0x8012
- #define REG IF IP FAB1B0 0x8013
- #define REG\_IF\_IP\_FAB1B1 0x8014
- #define REG IF CMD PORT NUM FAB1B 0x8015
- #define REG\_IF\_STREAM\_IN\_PORT\_NUM\_FAB1B 0x8016
- #define REG\_IF\_STREAM\_OUT\_PORT\_NUM\_FAB1B 0x8017
- #define REG XAUI FAB1B 0x8018
- #define REG MAC CONFIG VEC FAB1B0 0x8019
- #define REG MAC CONFIG VEC FAB1B1 0x801A
- #define REG MAC STATS1 FAB1B0 0x801B
- #define REG MAC STATS1 FAB1B1 0x801C
- #define REG\_MAC\_STATS2\_FAB1B0 0x801D
- #define REG MAC STATS2 FAB1B1 0x801E
- #define REG IF MAC FAB2B0 0x8020
- #define REG IF MAC FAB2B1 0x8021
- #define REG IF MAC FAB2B2 0x8022
- #define REG\_IF\_IP\_FAB2B0 0x8023
- #define REG\_IF\_IP\_FAB2B1 0x8024
- #define REG IF CMD PORT NUM FAB2B 0x8025
- #define REG IF STREAM IN PORT NUM FAB2B 0x8026
- #define REG\_IF\_STREAM\_OUT\_PORT\_NUM\_FAB2B 0x8027
- #define REG XAUI FAB2B 0x8028
- #define REG\_MAC\_CONFIG\_VEC\_FAB2B0 0x8029
- #define REG\_MAC\_CONFIG\_VEC\_FAB2B1 0x802A
- #define REG MAC STATS1 FAB2B0 0x802B
- #define REG MAC STATS1 FAB2B1 0x802C
- #define REG MAC STATS2 FAB2B0 0x802D
- #define REG MAC STATS2 FAB2B1 0x802E
- #define REG SRAM COMMAND 0x8030
- #define REG\_SRAM\_START\_ADDR1 0x8031
- #define REG\_SRAM\_START\_ADDR0 0x8032
- #define REG\_SRAM\_STOP\_ADDR1 0x8033
- #define REG\_SRAM\_STOP\_ADDR0 0x8034
- #define REG\_SRAM\_FRAME\_DATA\_OUT1 0x8035
- #define REG SRAM FRAME DATA OUT0 0x8036
- #define REG SRAM FRAME DATA IN1 0x8037
- #define REG\_SRAM\_FRAME\_DATA\_IN0\_0x8038
- #define REG SRAM FRAME DV 0x8039
- #define REG\_SRAM\_STATUS1 0x803A
- #define REG\_SRAM\_STATUS0 0x803B
- #define CMD\_FCLK\_COMMIT 0x0012
- #define REG\_FCLK\_I2C\_ADDRESS 0x8040
- #define REG FCLK I2C DATA WR 0x8041
- #define REG\_FCLK\_I2C\_DATA\_RD 0x8042
- #define REG\_TRIGGERSELECT\_REG 0x8050
- #define REG\_TRIGGERMASK\_REG\_0x8051
- #define REG\_CCDFCLKSELECT\_REG 0x8052
- #define REG CDICLKDISABLE REG 0x8053
- #define REG FCLK SET0 0xB007
- #define REG FCLK SET1 0xB008
- #define REG FCLK SET2 0xB009
- #define REG FCLK SET3 0xB00A

- #define REG FCLK SET4 0xB00B
- #define REG\_FCLK\_SET5 0xB00C
- #define REG\_FRM\_DCM\_STATUS 0x8080
- #define REG FRM FPGA STATUS 0x8081
- #define REG FRM BOARD ID 0x808D
- #define REG\_FRM\_HW\_SERIAL\_NUM 0x808E
- #define REG\_FRM\_FPGA\_VERSION 0x808F
- #define REG\_FRM\_SANDBOX\_REG00 0x80F0
- #define REG\_FRM\_SANDBOX\_REG01 0x80F1
- #define REG FRM SANDBOX REG02 0x80F2
- #define REG\_FRM\_SANDBOX\_REG03 0x80F3
- #define REG\_FRM\_SANDBOX\_REG04\_0x80F4
- #define REG\_FRM\_SANDBOX\_REG05 0x80F5
- #define REG\_FRM\_SANDBOX\_REG06 0x80F6
- #define REG\_FRM\_SANDBOX\_REG07 0x80F7
- #define REG FRM SANDBOX REG08 0x80F8
- #define REG\_FRM\_SANDBOX\_REG09\_0x80F9
- #define REG FRM SANDBOX REGOA 0x80FA
- #define REG FRM SANDBOX REG0B 0x80FB
- #define REG FRM SANDBOX REGOC 0x80FC
- #define REG\_FRM\_SANDBOX\_REGOD 0x80FD
- #define REG FRM SANDBOX REG0E 0x80FE
- #define REG\_FRM\_SANDBOX\_REG0F\_0x80FF
- #define REG\_DETECTOR\_REVISION\_REG 0x8100
- #define REG DETECTOR CONFIG REG1 0x8101
- #define REG\_DETECTOR\_CONFIG\_REG2 0x8102
- #define REG DETECTOR CONFIG REG3 0x8103
- #define REG\_DETECTOR\_CONFIG\_REG4 0x8104
- #define REG\_DETECTOR\_CONFIG\_REG5 0x8105
- #define REG\_DETECTOR\_CONFIG\_REG6 0x8106
- #define REG\_DETECTOR\_CONFIG\_REG7 0x8107
- #define REG\_DETECTOR\_CONFIG\_REG8 0x8108
- #define REG\_IMG\_PROC\_REVISION\_REG 0x8120
- #define REG\_IMG\_PROC\_CONFIG\_REG1 0x8121
- #define REG\_IMG\_PROC\_CONFIG\_REG2 0x8122
- #define REG\_IMG\_PROC\_CONFIG\_REG3 0x8123
   #define REG\_IMG\_PROC\_CONFIG\_REG4 0x8124
- #define REG IMG PROC CONFIG REG5 0x8125
- #define REG IMG PROC CONFIG REG6 0x8126
- #define **REG IMG PROC CONFIG REG7** 0x8127
- #define REG IMG PROC CONFIG REG8 0x8128
- #define REG\_BIASANDCLOCKREGISTERADDRESS 0x8200
- #define REG\_BIASANDCLOCKREGISTERDATA 0x8201
- #define REG\_CLOCKREGISTERDATAOUT 0x8202
- #define REG\_BIASREGISTERDATAOUT 0x8203
- #define REG\_BIASCONFIGREGISTER0\_REG\_0x8204
- #define REG\_CLOCKCONFIGREGISTER0\_REG\_0x8205
- #define REG BIASPARAM READ START 0x3000
- #define REG\_EXPOSURETIMEMSB\_REG\_0x8206
- #define REG EXPOSURETIMELSB REG 0x8207
- #define REG\_ALTEXPOSURETIMEMSB\_REG\_0x8306
- #define REG ALTEXPOSURETIMELSB REG 0x8307
- #define REG\_TRIGGERREPETITIONTIMEMSB\_REG\_0x8208
- #define REG\_TRIGGERREPETITIONTIMELSB\_REG\_0x8209
- #define REG DELAYTOEXPOSUREMSB REG 0x820A

- #define REG DELAYTOEXPOSURELSB REG 0x820B
- #define REG\_NUMBEROFEXPOSURE\_REG 0x820C
- #define REG SHUTTERTIMEMSB REG 0x820D
- #define REG SHUTTERTIMELSB REG 0x820E
- #define REG\_DELAYTOSHUTTERMSB\_REG\_0x820F
- #define REG DELAYTOSHUTTERLSB REG 0x8210
- #define REG FCRIC MASK REG1 0x8211
- #define REG FCRIC MASK REG2 0x8212
- #define REG FCRIC MASK REG3 0x8213
- #define REG\_LVDS\_OVERFLOW\_ERROR\_REG1 0x8214
- #define REG\_LVDS\_OVERFLOW\_ERROR\_REG2 0x8215
- #define REG LVDS OVERFLOW ERROR REG3 0x8216
- #define REG\_LVDS\_PARITY\_ERROR\_REG1 0x8217
- #define REG\_LVDS\_PARITY\_ERROR\_REG2\_0x8218
- #define REG\_LVDS\_PARITY\_ERROR\_REG3 0x8219
- #define REG LVDS STOP BIT ERROR REG1 0x821A
- #define REG\_LVDS\_STOP\_BIT\_ERROR\_REG2\_0x821B
- #define REG LVDS STOP BIT ERROR REG3 0x821C
- #define REG\_FCRIC\_WRITE0\_REG 0x821D
- #define REG FCRIC WRITE1 REG 0x821E
- #define REG\_FCRIC\_WRITE2\_REG 0x821F
- #define REG FCRIC READO REG 0x8220
- #define REG FCRIC READ1 REG 0x8221
- #define REG FCRIC READ2 REG 0x8222
- #define REG DEBUGVIDEO0 REG 0x8223
- #define REG DEBUGVIDEO1 REG 0x8224
- #define REG\_DEBUGVIDEO2\_REG 0x8225
- #define REG DEBUGVIDEO3 REG 0x8226
- #define REG DEBUGVIDEO4 REG 0x8227
- #define REG DEBUGVIDEO5 REG 0x8228
- #define REG\_DEBUGVIDEO6\_REG 0x8229
- #define REG\_DEBUGVIDEO7\_REG 0x822A
- #define REG\_DEBUGVIDEO8\_REG 0x822B
- #define REG\_DEBUGVIDEO9\_REG 0x822C
- #define REG\_DEBUGVIDEO10\_REG 0x822D
- #define REG DEBUGVIDEO11 REG 0x822E
- #define REG DEBUGCOUNTER00 REG 0x822F
- #define REG DEBUGCOUNTER01 REG 0x8230
- #define REG\_DEBUGCOUNTER02\_REG 0x8231
- #define REG\_DEBUGCOUNTER03\_REG 0x8232
- #define REG\_DEBUGCOUNTER04\_REG 0x8233
- #define CMD\_READ\_REG 0x0001

#### 7.2.1 Detailed Description

<

**Author** 

Stuart B. Wilkins swilkins@bnl.gov

#### 7.2.2 LICENSE

Copyright (c) 2014, Brookhaven Science Associates, Brookhaven National Laboratory All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

- Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
- 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

The views and conclusions contained in the software and documentation are those of the authors and should not be interpreted as representing official policies, either expressed or implied, of the FreeBSD Project.

#### 7.2.3 DESCRIPTION

Control and Frame FPGA Register Map

#### **7.2.4 TIMING**

The exposure time is set through the REG\_EXPOSURETIMEMSB\_REG and REG\_EXPOSURETIMELSB\_REG registers. Their value in wall time depends on the fclk frequency. At 200 MHz fclk a register value of 0x00000001 corresponds to 20 us. At 125 MHz, a value of 0x00000001 corresponds to 32 us.

#### 7.2.5 Macro Definition Documentation

#### 7.2.5.1 CMD\_DISABLE\_CLKS

#define CMD\_DISABLE\_CLKS 0x0032

Disable Frame FPGA clock crystals

#### 7.2.5.2 CMD\_ENABLE\_CLKS

#define CMD\_ENABLE\_CLKS 0x0031

Enable selected Frame FPGA clock crystals

7.2.5.3 CMD\_FCLK\_250

#define CMD\_FCLK\_250 0x3000

Ethernet Interface

7.2.5.4 CMD\_FCLK\_COMMIT

#define CMD\_FCLK\_COMMIT 0x0012

Start I2C Write/Read

7.2.5.5 CMD\_MON\_START

#define CMD\_MON\_START 0x0012

Start voltage and current monitor

7.2.5.6 CMD\_MON\_STOP

#define CMD\_MON\_STOP 0x0011

Stop voltage and current monitor

7.2.5.7 CMD\_PS\_ENABLE

#define CMD\_PS\_ENABLE 0x0021

**Enable Selected Power Modules** 

7.2.5.8 CMD\_PS\_POWERDOWN

#define CMD\_PS\_POWERDOWN 0x0022

Start power down sequence

7.2.5.9 CMD\_READ\_REG

#define CMD\_READ\_REG 0x0001

Read Register CIN\_REGISTER\_MAP\_H

7.2.5.10 CMD\_RESET\_FRAME\_COUNT

#define CMD\_RESET\_FRAME\_COUNT 0x0106

RESET STATISTICS/DEBUG COUNTERS Ethernet Interface

7.2.5.11 CMD\_SEND\_FCRIC\_CONFIG

#define CMD\_SEND\_FCRIC\_CONFIG 0x0105

SEND CONFIG DATA TO FRIC

7.2.5.12 CMD\_SEND\_SYNC\_PULSE

#define CMD\_SEND\_SYNC\_PULSE 0x0100

ISSUES A SYNC PULSE

7.2.5.13 CMD\_SYNC\_DETECTOR2READOUT

#define CMD\_SYNC\_DETECTOR2READOUT 0x0101

COMMAND TO SYNC DETECTOR AND READOUT (SEE IMAGE PROCESSING)

7.2.5.14 CMD\_WR\_CCD\_BIAS\_REG

#define CMD\_WR\_CCD\_BIAS\_REG 0x0102

WRITE CCD BIAS REGISTERS

7.2.5.15 CMD\_WR\_CCD\_CLOCK\_REG

#define CMD\_WR\_CCD\_CLOCK\_REG 0x0103

WRITE CCD CLOCK REGISTER

7.2.5.16 REG\_BIASCONFIGREGISTER0\_REG

#define REG\_BIASCONFIGREGISTERO\_REG 0x8204

Clock Static Registers

7.2.5.17 REG\_BIASREGISTERDATAOUT

#define REG\_BIASREGISTERDATAOUT 0x8203

Bias Static Registers

Generated by Doxygen

#### 7.2.5.18 REG\_CLOCK\_EN\_REG

#define REG\_CLOCK\_EN\_REG 0x0038

Clock Enable Register Programmable Si570 Clock Registers

#### 7.2.5.19 REG\_CLOCKCONFIGREGISTER0\_REG

#define REG\_CLOCKCONFIGREGISTER0\_REG 0x8205

Bias Voltage

#### 7.2.5.20 REG\_COMMAND

#define REG\_COMMAND 0x0001

< Command Registers

#### 7.2.5.21 REG\_DEBUGCOUNTER04\_REG

#define REG\_DEBUGCOUNTER04\_REG 0x8233

\_\_\_\_\_\_

#### **CIN Commands**

Common Commands

#### 7.2.5.22 REG\_DELAYTOSHUTTERLSB\_REG

#define REG\_DELAYTOSHUTTERLSB\_REG 0x8210

Digitizer Registers

#### 7.2.5.23 REG\_ETH\_ENABLE

#define REG\_ETH\_ENABLE 0x0021

Enable Eth Hardware 1=Rx, 2=Tx, 3=Both

#### 7.2.5.24 REG\_ETH\_RESET

#define REG\_ETH\_RESET 0x0020

Reset Eth Hardware 1=Rx, 2=Tx, 3=Both

#### 7.2.5.25 REG\_EXPOSURETIMELSB\_REG

#define REG\_EXPOSURETIMELSB\_REG 0x8207

Exposure time LSB

## 7.2.5.26 REG\_EXPOSURETIMEMSB\_REG

#define REG\_EXPOSURETIMEMSB\_REG 0x8206

Exposure time MSB

#### 7.2.5.27 REG\_FCLK\_I2C\_ADDRESS

#define REG\_FCLK\_I2C\_ADDRESS 0x8040

[ Slave Address(7), RD/WRn(1), Reg Adress(8) ] Slave adddress Hx58 -> HxB when shifted up by 1

#### 7.2.5.28 REG\_FCLK\_I2C\_DATA\_RD

#define REG\_FCLK\_I2C\_DATA\_RD 0x8042

[ Read Failed (1), Write Failed(1), Toggle bit(1), 0(5), Read Data (8) ]

#### 7.2.5.29 REG\_FCLK\_I2C\_DATA\_WR

#define REG\_FCLK\_I2C\_DATA\_WR 0x8041

[ Clock Select(2), Clock Enable (1), 0(5), Write Data (8) ] Clock Select: (00): 250 MHz (01): 200 MHz (10): FPGA FCRIC Clk (11): Si570 Programmable

#### 7.2.5.30 REG\_FCLK\_SET5

#define REG\_FCLK\_SET5 0xB00C

FRM Status

#### 7.2.5.31 REG\_FPGA\_VERSION

#define REG\_FPGA\_VERSION 0x008F

#### Sandbox Registers

7.2.5.32 REG\_FRM\_10GbE\_SEL

#define REG\_FRM\_10GbE\_SEL 0x0037;

10GbE Link Select Clock Enables

7.2.5.33 REG\_FRM\_FPGA\_VERSION

#define REG\_FRM\_FPGA\_VERSION 0x808F

Sandbox Registers

7.2.5.34 REG\_FRM\_RESET

#define REG\_FRM\_RESET 0x0036

Frame Reset

7.2.5.35 REG\_FRM\_SANDBOX\_REG0F

#define REG\_FRM\_SANDBOX\_REGOF 0x80FF

Image Processing Registers

7.2.5.36 REG\_FRM\_STREAM\_TYPE

#define REG\_FRM\_STREAM\_TYPE 0x8003

List of Commands

7.2.5.37 REG\_IMON\_ADC0\_CHF

#define REG\_IMON\_ADCO\_CHF 0x005B /\* V5P0\_FP Current Monitor (1/2) \*/

Status Registers

7.2.5.38 REG\_MAC\_CFG\_VECTOR1

#define REG\_MAC\_CFG\_VECTOR1 0x0027

Ethernet Hardware Conf

7.2.5.39 REG\_MAC\_CFG\_VECTOR2

#define REG\_MAC\_CFG\_VECTOR2 0x002D

Ethernet Hardware Conf Power Supply Control

7.2.5.40 REG\_MAC\_STATS2\_FAB2B1

#define REG\_MAC\_STATS2\_FAB2B1 0x802E

SRAM Test Interface

7.2.5.41 REG\_PHY1\_MDIO\_CMD

#define REG\_PHY1\_MDIO\_CMD 0x0022

Start(1), RnW(1), WDRd(1), PHY Addr(5), REG Addr(5)

7.2.5.42 REG\_PS\_ENABLE

#define REG\_PS\_ENABLE 0x0030

Power Supply Enable:

7.2.5.43 REG\_PS\_SYNC\_DIV0

#define REG\_PS\_SYNC\_DIV0 0x0031

2.5V Gen

7.2.5.44 REG\_PS\_SYNC\_DIV1

#define REG\_PS\_SYNC\_DIV1 0x0032

3.3V Gen

7.2.5.45 REG\_PS\_SYNC\_DIV2

#define REG\_PS\_SYNC\_DIV2 0x0033

2.5V Frame

7.2.5.46 REG\_PS\_SYNC\_DIV3

#define REG\_PS\_SYNC\_DIV3 0x0034

0.9V Frame

7.2.5.47 REG\_PS\_SYNC\_DIV4

#define REG\_PS\_SYNC\_DIV4 0x0035

5.0V FP Frame FPGA Control

Generated by Doxygen

#### 7.2.5.48 REG\_SANDBOX\_REG0F

#define REG\_SANDBOX\_REGOF 0x00FF

-----< Frame FPGA Registers > Command Registers

7.2.5.49 REG\_SI570\_REG3

#define REG\_SI570\_REG3 0x003C

**Power Monitor Registers** 

7.2.5.50 REG\_SRAM\_COMMAND

#define REG\_SRAM\_COMMAND 0x8030

1 bit [0] >> Read NOT Write 2 bits [3:2] >> Modes: - Single RW 0x00 - Burst RW 0x01 - Test/Diagnostic 10 - Sleep 11 1 bit [4] >> start/stop

7.2.5.51 REG\_SRAM\_STATUS0

#define REG\_SRAM\_STATUS0 0x803B

Programmable Clock

7.2.5.52 REG\_STREAM\_TYPE

#define REG\_STREAM\_TYPE 0x0003

**FCLK Values** 

7.2.5.53 REG\_TRIGGERMASK\_REG

#define REG\_TRIGGERMASK\_REG 0x8051

[00]==SW Trigger, [01]==FP TrigIn2, [10]==FP TrigIn1, [11]==FP TrigIn1OR2

7.2.5.54 REG\_TRIGGERREPETITIONTIMELSB\_REG

#define REG\_TRIGGERREPETITIONTIMELSB\_REG 0x8209

Trigger Cycle Time LSB

7.2.5.55 REG\_TRIGGERREPETITIONTIMEMSB\_REG

#define REG\_TRIGGERREPETITIONTIMEMSB\_REG 0x8208

Trigger Cycle Time MSB

# Index

| CIN COntrol Timing Routines, 20        | cin register map.h, 49                  |
|----------------------------------------|-----------------------------------------|
| CIN Control Bias Routines, 19          | Cin Control Initialization Routines, 9  |
| CIN Data Framestore Functions, 24      | cin ctl destroy, 9                      |
| cin_data_framestore_disable, 24        | cin_ctl_init, 10                        |
| cin_data_framestore_skip, 24           | cin_ctl_set_msg_callback, 10            |
| cin_data_framestore_trigger, 25        | cin_data_send_magic, 11                 |
| cin_data_framestore_trigger_enable, 25 | Cin Control Read/Rwite Routines, 12     |
| cin_data_get_framestore_counter, 25    | cin_ctl_read, 12                        |
| CIN Data Initialization Routines, 21   | cin_ctl_stream_write, 12                |
| cin_data_destroy, 21                   | cin_ctl_write, 13                       |
| cin_data_init, 21                      | cin_ctl_write_with_readback, 13         |
| CIN FCLK Configuration Routines, 17    | Cin Power Routines, 15                  |
| CIN Firmware Upload Routines, 16       | cin_ctl_fp_pwr, 15                      |
| CIN Status Routines, 18                | cin_ctl_pwr, 15                         |
| CIN_CONFIG_MAX_TIMING_DATA             | cin.h                                   |
| cin.h, 41                              | CIN CONFIG MAX TIMING DATA, 41          |
| CIN_CONFIG_MAX_TIMING_MODES            | CIN_CONFIG_MAX_TIMING_MODES, 41         |
| cin.h, 41                              | CIN_CTL_BIAS_OFFSET, 41                 |
| CIN_CTL_BIAS_OFFSET                    | cin config timing, 27                   |
| cin.h, 41                              | cols, 27                                |
| CMD_DISABLE_CLKS                       | data, 27                                |
| cin_register_map.h, 47                 | data, 27<br>data_len, 27                |
| CMD ENABLE CLKS                        | fclk_freq, 27                           |
| cin register map.h, 47                 | framestore, 28                          |
| CMD FCLK 250                           | name, 28                                |
| cin_register_map.h, 48                 | overscan, 28                            |
| CMD FCLK COMMIT                        | rows, 28                                |
| cin_register_map.h, 48                 |                                         |
| CMD_MON_START                          | cin_ctl, 28                             |
| cin_register_map.h, 48                 | fclk_time_factor, 29 cin_ctl_destroy    |
| CMD MON STOP                           | Cin Control Initialization Routines, 9  |
|                                        |                                         |
| cin_register_map.h, 48 CMD PS ENABLE   | cin_ctl_fp_pwr Cin Power Routines, 15   |
|                                        |                                         |
| cin_register_map.h, 48                 | cin_ctl_id, 29                          |
| CMD_PS_POWERDOWN                       | cin_ctl_init                            |
| cin_register_map.h, 48                 | Cin Control Initialization Routines, 10 |
| CMD_READ_REG                           | cin_ctl_listener, 29                    |
| cin_register_map.h, 48                 | cin_ctl_pwr                             |
| CMD_RESET_FRAME_COUNT                  | Cin Power Routines, 15                  |
| cin_register_map.h, 48                 | cin_ctl_pwr_mon_t, 30                   |
| CMD_SEND_FCRIC_CONFIG                  | cin_ctl_pwr_val, 30                     |
| cin_register_map.h, 49                 | cin_ctl_read                            |
| CMD_SEND_SYNC_PULSE                    | Cin Control Read/Rwite Routines, 12     |
| cin_register_map.h, 49                 | cin_ctl_set_msg_callback                |
| CMD_SYNC_DETECTOR2READOUT              | Cin Control Initialization Routines, 10 |
| cin_register_map.h, 49                 | cin_ctl_stream_write                    |
| CMD_WR_CCD_BIAS_REG                    | Cin Control Read/Rwite Routines, 12     |
| cin_register_map.h, 49                 | cin_ctl_write                           |
| CMD_WR_CCD_CLOCK_REG                   | Cin Control Read/Rwite Routines, 13     |

56 INDEX

| cin_ctl_write_with_readback                         | REG_FCLK_SET5, 51                    |
|-----------------------------------------------------|--------------------------------------|
| Cin Control Read/Rwite Routines, 13                 | REG_FPGA_VERSION, 51                 |
| cin_data, 30                                        | REG_FRM_10GbE_SEL, 51                |
| cin_data_callbacks, 31                              | REG_FRM_FPGA_VERSION, 52             |
| cin_data_descramble_map_t, 31                       | REG_FRM_RESET, 52                    |
| cin_data_destroy                                    | REG_FRM_SANDBOX_REG0F, 52            |
| CIN Data Initialization Routines, 21                | REG_FRM_STREAM_TYPE, 52              |
| cin_data_frame, 32                                  | REG_IMON_ADC0_CHF, 52                |
| cin_data_framestore_disable                         | REG_MAC_CFG_VECTOR1, 52              |
| CIN Data Framestore Functions, 24                   | REG_MAC_CFG_VECTOR2, 52              |
| cin_data_framestore_skip                            | REG_MAC_STATS2_FAB2B1, 52            |
| CIN Data Framestore Functions, 24                   | REG_PHY1_MDIO_CMD, 53                |
| cin_data_framestore_trigger                         | REG_PS_ENABLE, 53                    |
| CIN Data Framestore Functions, 25                   | REG_PS_SYNC_DIV0, 53                 |
| cin_data_framestore_trigger_enable                  | REG_PS_SYNC_DIV1, 53                 |
| CIN Data Framestore Functions, 25                   | REG_PS_SYNC_DIV2, 53                 |
| cin_data_get_framestore_counter                     | REG_PS_SYNC_DIV3, 53                 |
| CIN Data Framestore Functions, 25                   | REG_PS_SYNC_DIV4, 53                 |
| cin data init                                       | REG_SANDBOX_REG0F, 53                |
| CIN Data Initialization Routines, 21                | REG_SI570_REG3, 54                   |
| cin data packet, 32                                 | REG_SRAM_COMMAND, 54                 |
| cin_data_proc, 32                                   | REG_SRAM_STATUS0, 54                 |
| cin_data_send_magic                                 | REG_STREAM_TYPE, 54                  |
| Cin Control Initialization Routines, 11             | REG_TRIGGERMASK_REG, 54              |
| cin_data_stats, 33                                  | REG_TRIGGERREPETITIONTIMELSB_REG, 54 |
| cin_data_threads, 33                                | REG_TRIGGERREPETITIONTIMEMSB_REG, 54 |
| cin_map_t, 33                                       | cols                                 |
| cin_port, 34                                        | cin_config_timing, 27                |
| cin_register_map.h                                  |                                      |
| CMD_DISABLE_CLKS, 47                                | data                                 |
| CMD ENABLE CLKS, 47                                 | cin_config_timing, 27                |
| CMD FCLK 250, 48                                    | data_len                             |
| CMD_FCLK_COMMIT, 48                                 | cin_config_timing, 27                |
| CMD MON START, 48                                   |                                      |
| CMD MON STOP, 48                                    | fclk_freq                            |
| CMD_PS_ENABLE, 48                                   | cin_config_timing, 27                |
| CMD_PS_POWERDOWN, 48                                | fclk_time_factor                     |
| CMD_READ_REG, 48                                    | cin_ctl, 29                          |
| CMD_RESET_FRAME_COUNT, 48                           | fifo, 34                             |
| CMD_SEND_FCRIC_CONFIG, 49                           | framestore                           |
| CMD_SEND_1 CHIO_CON IG, 49  CMD SEND SYNC PULSE, 49 | cin_config_timing, 28                |
| CMD_SYNC_DETECTOR2READOUT, 49                       |                                      |
| CMD_WR_CCD_BIAS_REG, 49                             | name                                 |
| CMD_WR_CCD_CLOCK_REG, 49                            | cin_config_timing, 28                |
|                                                     |                                      |
| REG_BIASCONFIGREGISTERO_REG, 49                     | overscan                             |
| REG_BIASREGISTERDATAOUT, 49                         | cin_config_timing, 28                |
| REG_CLOCK_EN_REG, 49                                |                                      |
| REG_CLOCKCONFIGREGISTER0_REG, 50                    | REG_BIASCONFIGREGISTER0_REG          |
| REG_COMMAND, 50                                     | cin_register_map.h, 49               |
| REG_DEBUGCOUNTER04_REG, 50                          | REG_BIASREGISTERDATAOUT              |
| REG_DELAYTOSHUTTERLSB_REG, 50                       | cin_register_map.h, 49               |
| REG_ETH_ENABLE, 50                                  | REG_CLOCK_EN_REG                     |
| REG_ETH_RESET, 50                                   | cin_register_map.h, 49               |
| REG_EXPOSURETIMELSB_REG, 50                         | REG_CLOCKCONFIGREGISTER0_REG         |
| REG_EXPOSURETIMEMSB_REG, 51                         | cin_register_map.h, 50               |
| REG_FCLK_I2C_ADDRESS, 51                            | REG_COMMAND                          |
| REG_FCLK_I2C_DATA_RD, 51                            | cin_register_map.h, 50               |
| REG_FCLK_I2C_DATA_WR, 51                            | REG_DEBUGCOUNTER04_REG               |

INDEX 57

cin\_register\_map.h, 50 cin\_register\_map.h, 54 REG DELAYTOSHUTTERLSB REG **REG SRAM STATUS0** cin register map.h, 54 cin\_register\_map.h, 50 REG\_STREAM\_TYPE REG\_ETH\_ENABLE cin\_register\_map.h, 54 cin register map.h, 50 REG TRIGGERMASK REG REG ETH RESET cin register map.h, 54 cin register map.h, 50 REG TRIGGERREPETITIONTIMELSB REG REG EXPOSURETIMELSB REG cin register map.h, 54 cin\_register\_map.h, 50 REG TRIGGERREPETITIONTIMEMSB REG REG\_EXPOSURETIMEMSB\_REG cin\_register\_map.h, 54 cin register map.h, 51 rows REG\_FCLK\_I2C\_ADDRESS cin\_config\_timing, 28 cin\_register\_map.h, 51 REG\_FCLK\_I2C\_DATA\_RD src/cin.h, 35 cin register map.h, 51 src/cin\_register\_map.h, 42 REG\_FCLK\_I2C\_DATA\_WR cin\_register\_map.h, 51 **REG FCLK SET5** cin\_register\_map.h, 51 REG\_FPGA\_VERSION cin\_register\_map.h, 51 REG\_FRM\_10GbE\_SEL cin\_register\_map.h, 51 REG FRM FPGA VERSION cin register map.h, 52 REG FRM RESET cin register map.h, 52 REG\_FRM\_SANDBOX\_REG0F cin\_register\_map.h, 52 REG\_FRM\_STREAM\_TYPE cin register map.h, 52 REG\_IMON\_ADC0\_CHF cin\_register\_map.h, 52 REG MAC CFG VECTOR1 cin\_register\_map.h, 52 REG\_MAC\_CFG\_VECTOR2 cin register map.h, 52 REG\_MAC\_STATS2\_FAB2B1 cin\_register\_map.h, 52 REG PHY1 MDIO CMD cin\_register\_map.h, 53 REG\_PS\_ENABLE cin register map.h, 53 REG PS SYNC DIV0 cin register map.h, 53 REG PS SYNC DIV1 cin\_register\_map.h, 53 REG\_PS\_SYNC\_DIV2 cin\_register\_map.h, 53 REG PS SYNC DIV3 cin\_register\_map.h, 53 REG PS SYNC DIV4 cin register map.h, 53 REG\_SANDBOX\_REG0F cin\_register\_map.h, 53 REG SI570 REG3 cin\_register\_map.h, 54 REG\_SRAM\_COMMAND