

# **Rtc**Master**Clock**

Reference Manual

| Product Info    |            |
|-----------------|------------|
| Product Manager | Sven Meier |
| Author(s)       | Sven Meier |
| Reviewer(s)     | -          |
| Version         | 1.3        |
| Date            | 03.07.2024 |



# **Copyright Notice**

Copyright © 2025 NetTimeLogic GmbH, Switzerland. All rights reserved. Unauthorized duplication of this document, in whole or in part, by any means, is prohibited without the prior written permission of NetTimeLogic GmbH, Switzerland.

All referenced registered marks and trademarks are the property of their respective owners

# Disclaimer

The information available to you in this document/code may contain errors and is subject to periods of interruption. While NetTimeLogic GmbH does its best to maintain the information it offers in the document/code, it cannot be held responsible for any errors, defects, lost profits, or other consequential damages arising from the use of this document/code.

NETTIMELOGIC GMBH PROVIDES THE INFORMATION, SERVICES AND PROD-UCTS AVAILABLE IN THIS DOCUMENT/CODE "AS IS," WITH NO WARRANTIES WHATSOEVER. ALL EXPRESS WARRANTIES AND ALL IMPLIED WARRANTIES, INCLUDING WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTIC-ULAR PURPOSE, AND NON-INFRINGEMENT OF PROPRIETARY RIGHTS ARE HEREBY DISCLAIMED TO THE FULLEST EXTENT PERMITTED BY LAW. IN NO EVENT SHALL NETTIMELOGIC GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, SPECIAL AND EXEMPLARY DAMAGES, OR ANY DAMAGES WHATSOEVER, ARISING FROM THE USE OR PERFORMANCE OF THIS DOCUMENT/CODE OR FROM ANY INFORMATION, SERVICES OR PRODUCTS PROVIDED THROUGH THIS DOCUMENT/CODE, EVEN IF NETTIMELOGIC GMBH HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

IF YOU ARE DISSATISFIED WITH THIS DOCUMENT/CODE, OR ANY PORTION THEREOF, YOUR EXCLUSIVE REMEDY SHALL BE TO CEASE USING THE DOCU-MENT/CODE.



# Overview

NetTimeLogic's Real Time Clock (RTC) Master Clock is a full hardware (FPGA) only implementation of a synchronization core able to synchronize an RTC or gets synchronized by an RTC. In addition, the time can be read and written aligned with the RTC PPS event. The RTC Master Clock core is designed to allow fast synchronization on startup, run in holdover mode when no other synchronization source is available and keep the Time of Day when powered down. The whole algorithms and calculations are implemented in the core, no CPU is required. This allows running RTC synchronization completely independent and standalone from the user application. The core can be configured/supervised either by signals or by an AXI4Lite-Slave Register interface.

# **Key Features:**

- Real Time Clock (RTC) Master Clock
- Supports DS1307 and MCP7941x (and compatible) Real Time Clocks (RTC) and self-configuration at startup
- Allows to synchronize the internal clock to the RTC and vise versa
- Built-in I2C controller with configurable baudrate
- Aligned writing and reading of time with the RTC PPS
- Hardware time conversion from Time of Day format (hh:mm:ss dd:mm:yyyy) into seconds since midnight 1.1.1970 (Linux, TAI, PTP)
- PI Servo Loop in hardware
- In combination with a Adjustable Counter Clock from NetTimeLogic: synchronization accuracy: +/- 100ns
- AXI4Lite register set or static configuration



# **Revision History**

This table shows the revision history of this document.

| Version | Date       | Revision                                           |
|---------|------------|----------------------------------------------------|
| O.1     | 04.01.2017 | First draft                                        |
| 1.0     | 24.02.2017 | First release and added CoreInfo type              |
| 1.1     | 20.12.2017 | Status interface added                             |
| 1.2     | 03.01.2023 | Added Vivado upgrade version description           |
| 1.3     | 03.07.2024 | Split I2C SDA into input, output and output enable |

Table 1: Revision History



# Content

| 1                                      | INTRODUCTION                                                                                | 8                                |
|----------------------------------------|---------------------------------------------------------------------------------------------|----------------------------------|
| 1.1                                    | Context Overview                                                                            | 8                                |
| 1.2                                    | Function                                                                                    | 9                                |
| 1.3                                    | Architecture                                                                                | 10                               |
| 2                                      | RTC BASICS                                                                                  | 12                               |
| 2.1                                    | RTC Internals                                                                               | 12                               |
| 2.2                                    | Interface                                                                                   | 12                               |
| 2.3                                    | RTC Registers                                                                               | 14                               |
| 2.4                                    | UTC vs TAI time bases                                                                       | 15                               |
| 3                                      | REGISTER SET                                                                                | 16                               |
| 3.1                                    | Register Overview                                                                           | 16                               |
| 3.2<br>3.2.                            | Register Descriptions<br>1 General                                                          | 17<br>17                         |
| 4                                      | DESIGN DESCRIPTION                                                                          | 26                               |
| 4.1                                    | Top Level – Rtc Master                                                                      | 26                               |
| 4.2<br>4.2<br>4.2<br>4.2<br>4.2<br>4.2 | <ul><li>.2 Control Processor</li><li>.3 Read Processor</li><li>.4 Write Processor</li></ul> | 35<br>35<br>38<br>41<br>45<br>48 |
| 4.3<br>4.3<br>4.3                      | -                                                                                           | 51<br>51<br>51                   |



| 4.4<br>4.4<br>4.4 | -                                          | 52<br>52<br>52 |
|-------------------|--------------------------------------------|----------------|
| 5                 | RESOURCE USAGE                             | 54             |
| 5.1               | Intel/Altera (Cyclone V)                   | 54             |
| 5.2               | AMD/Xilinx (Artix 7)                       | 54             |
| 6                 | DELIVERY STRUCTURE                         | 55             |
| 7                 | TESTBENCH                                  | 56             |
| 7.1               | Run Testbench                              | 56             |
| 8                 | REFERENCE DESIGNS                          | 58             |
| 8.1               | Intel/Altera: Terasic SocKit               | 58             |
| 8.2<br>8.2        | AMD/Xilinx: Digilent Arty<br>2.1 RTC CLock | 59<br>60       |
| 8.3               | AMD/Xilinx : Vivado version                | 61             |



# Definitions

| Definitions      |                                                             |
|------------------|-------------------------------------------------------------|
| RTC Master Clock | A clock that can synchronize or be synchronized by an       |
| RIC Master Clock | RTC                                                         |
| PI Servo Loop    | Proportional-integral servo loop, allows for smooth correc- |
|                  | tions                                                       |
| Offset           | Phase difference between clocks                             |
| Drift            | Frequency difference between clocks                         |

Table 2: Definitions

# Abbreviations

| Abbreviations |                                                |
|---------------|------------------------------------------------|
| AXI           | AMBA4 Specification (Stream and Memory Mapped) |
| IRQ           | Interrupt, Signaling to e.g. a CPU             |
| PPS           | Pulse Per Second                               |
| RTC           | Real Time Clock                                |
| RM            | RTC Master                                     |
| TS            | Timestamp                                      |
| ТВ            | Testbench                                      |
| LUT           | Look Up Table                                  |
| FF            | Flip Flop                                      |
| RAM           | Random Access Memory                           |
| ROM           | Read Only Memory                               |
| FPGA          | Field Programmable Gate Array                  |
| VHDL          | Hardware description Language for FPGA's       |

Table 3: Abbreviations



# 1 Introduction

## 1.1 Context Overview

The RTC Master Clock is meant as a co-processor handling an Real Time Clock (RTC). It can read and write the RTC registers via I2C and aligns these reads and writes aligned to the 1Hz square wave output (RTC PPS) of the RTC. For that, it self-configures the RTC to the correct mode at startup and enables the clock. The RTC maintains its own time reference also when the FPGA is powered down due to its battery backed oscillator. This is especially useful for Systems where the clock shall immediately run on a reference at startup and to have absolute time when no other synchronization source is available.

For synchronization, the core takes a snapshot of the local Counter Clock whenever a RTC PPS event happens, reads the seconds part of the time via I2C, converts the time from BCD encoded time of day format to binary seconds, calculates the offset and drift and adjusts the counter clock.

The RTC Master Clock is designed to work in cooperation with the Counter Clock core from NetTimeLogic (not a requirement).

In addition to synchronization the core allows to read and write the RTC time via registers or signals. For a read it maintains also a nanoseconds part which represents the time until the time was read and converted since the PPS happens. This is useful when the read time is used for comparison, since at the time the valid flag is set the whole time (including nanoseconds) is accurate.







# 1.2 Function

The RTC Master Clock takes a snapshot of the local Counter Clock whenever a RTC PPS event of configurable polarity happens, reads the seconds part of the time via I2C, converts the time from BCD encoded time of day format to binary seconds, calculates the offset and drift and adjusts the counter clock.

In addition to synchronization the core allows to read and write the RTC time via registers or signals. For a write the binary time in seconds/nanoseconds format is converted into BCD encoded time of day format and written to the corresponding time registers of the RTC via I2C right after the RTC PPS. For a read the corresponding time registers of the RTC are read via I2C right after the RTC PPS and decoded from the BCD encoded time of day format into binary time ins seconds/nanoseconds format. The read processor resets the nanosecond counter when a RTC PPS event occurs which runs during the reading and encoding, this gives nanosecond accuracy when the valid flag of the time is set.

Alignment with the RTC PPS is done to ensure the time value will not change during the I2C access. The RTC updates its time registers at the moment the RTC PPS happens. Also the time is always written/read in the order year, month, day, hour, minute, seconds. Reading and writing to the RTC can therefore take up to one second since it waits for the next RTC PPS to happen before accessing the RTC.



# 1.3 Architecture

The core is split up into different functional blocks for reduction of the complexity, modularity and maximum reuse of blocks. The interfaces between the functional blocks are kept as small as possible for easier understanding of the core.



Figure 2: Architecture Block Diagram

#### **Register Set**

This block allows reading status values and writing configuration. It also enables a CPU to read and write the RTC time values.

#### I2C

This is the I2C controller converting the internal parallel register access to the serial I2C access. There is arbitration between the Read-, Write- and Control-Processor which can access the I2C bus.

#### **Control Processor**

This configures the RTC clock at startup to run in the correct mode and to put out the 1Hz square wave output. Once ready it releases the Read- and Write-Processor

#### **Read Processor**

This reads the time from the RTC via I2C at the RTC PPS event, converts it to binary time, calculates offset and drift and adjusts the clock.



#### Write Processor

This converts the time to BCD time of day format and writes the time to the RTC via I2C at the RTC PPS event.



# 2 RTC Basics

# 2.1 RTC Internals

A Real Time Clock (RTC) is a battery backed clock running on an local oscillator providing the time over register access and square wave output to the user. The oscillator frequency is divided to achieve a 1Hz internal signal which is the used for incrementing the time. To get sub second accuracy the 1Hz signal has to be mapped to the square wave output where the IP core can synchronize itself to by adjusting subsecond phase and the clock frequency.



Figure 3: I2C Waveform

## 2.2 Interface

An RTC is commonly connected via an I2C interface. The I2C interface is a simple two wire bus containing a data line (SDA) and a clock line (SCL) allowing up to 127 slaves running at 100 or 400 kHz. The bus is open drain allowing all slaves to pull low using pull-ups to get the signals to high.

There are several access mechanisms defined but the RTC Master Clock described here only uses the byte wise access to the registers.

An I2C access consists always of the following parts (in this order):

- A Start condition (SDA goes from high to low while SC is high, also for repeated Start)
- 8 Data bits (MSB first)
- An Acknowledge (low for ACK, high for NACK, on write driven by the I2C slave, on read by the I2C Master)
- A Stop condition (SDA goes from low to high while SC is high)





Figure 4: I2C Waveform

There are three different types of cycles in a byte wise I2C access:

- A device address cycle
- A register address cycle
- A data cycle

For a write the I2C access looks as following:

| START | DEVICE ADDR | R/W | ACK | REGISTER ADDR | ACK | REGISTER WRITE DATA | ACK | STOP |
|-------|-------------|-----|-----|---------------|-----|---------------------|-----|------|
|       |             | 0   |     |               |     |                     |     |      |

Figure 5: I2C Write Access

For a read the I2C access looks as following:

| START | DEVICE ADDR | R/W A | ٩СК | REGISTER ADDR | ACK START | DEVICE ADDR | R/W | ACK | REGISTER READ DATA | NOT<br>ACK STOP |
|-------|-------------|-------|-----|---------------|-----------|-------------|-----|-----|--------------------|-----------------|
|       |             | 0     |     |               |           |             | 1   |     |                    |                 |

Figure 6: I2C Read Access

For more information on I2C check this link: <u>http://www.nxp.com/documents/user\_manual/UM10204.pdf</u>

In addition to the I2C interface an RTC normally consists of a square wave output which allow to generate different frequencies from the oscillator driving the RTC. The frequencies can be set normally to 32.768kHz, 8.192kHz, 4.096kHz and 1Hz. For this RTC Master Clock core the square wave output frequency must be set to 1Hz (PPS). Setting the frequency is done by the core via I2C during startup. The duty cycle of the square wave output is normally set to 50% and the polarity is active low. On the falling edge, the internal clock counter values are updated.





Figure 7: RTC PPS Waveform

## 2.3 RTC Registers

Depending on the RTC used the register set off the RTC differs slightly. What they all have in common is the time registers as binary encoded decimal value (BCD) in time of year format hh:mm:ss dd:mm:yy format and a control register for the squarewave output. To make use of the time in the FPGA and the other cores, the time must be converted from time of year in BCD to binary time since midnight 1.1.1970, taking leap years and into account.



The registersets of the two supported RTCs look as following:

Figure 8: RTC Registersets



# 2.4 UTC vs TAI time bases

The RTC clock contains the time of day on TAI base. UTC has an offset to TAI which is the time base normally used for the Counter Clock. This time offset has to be handled by the user so the local clock can still run on a TAI base. UTC in comparison to TAI or GPS time has so called leap seconds. A leap second is an additional second which is either added or subtracted from the current time to adjust for the earth rotation variation over time. Until 2016 UTC had additional 36 leap seconds, therefore TAI time is currently 36 seconds ahead of UTC. The issue with UTC time is, that the time makes jumps with the leap seconds. Leap seconds are normally introduced at midnight of either the 30 of June or 31 of December. For an additional leap second the seconds counter of the UTC time will count to 60 before wrapping around to zero, for one fewer leap second the UTC second counter will wrap directly from 58 to 0 by skipping 59 (this has not happened yet).



## **3** Register Set

This is the register set of the RTC Master Clock. It is accessible via AXI4Lite Memory Mapped. All registers are 32bit wide, no burst access, no unaligned access, no byte enables, no timeouts are supported. Register address space is not contiguous. Register addresses are only offsets in the memory area where the core is mapped in the AXI inter connects. Non existing register access in the mapped memory area is answered with a slave decoding error.

## 3.1 Register Overview

| Registerset Overview          |                                    |           |        |  |  |  |  |  |  |
|-------------------------------|------------------------------------|-----------|--------|--|--|--|--|--|--|
| Name                          | Description                        | Offset    | Access |  |  |  |  |  |  |
| Rtc MasterControl Reg         | Rtc Master Enable Control Register | 0x0000000 | RW     |  |  |  |  |  |  |
| Rtc MasterStatus Reg          | Rtc Master Error Status Register   | 0x0000004 | WC     |  |  |  |  |  |  |
| Rtc MasterPolarity Reg        | Rtc Master Polarity Register       | 0x0000008 | RW     |  |  |  |  |  |  |
| Rtc MasterVersion Reg         | Rtc Master Version Register        | 0x000000C | RO     |  |  |  |  |  |  |
| Rtc MasterTimeReadValueL Reg  | RTC write Time Nanosecond Register | 0x0000010 | RO     |  |  |  |  |  |  |
| Rtc MasterTimeReadValueH Reg  | RTC write Time Second Register     | 0x0000014 | RO     |  |  |  |  |  |  |
| Rtc MasterTimeWriteValueL Reg | RTC write Time Nanosecond Register | 0x0000020 | RW     |  |  |  |  |  |  |
| Rtc MasterTimeWriteValueH Reg | RTC write Time Second Register     | 0x0000024 | RW     |  |  |  |  |  |  |

Table 4:Register Set Overview



## 3.2 Register Descriptions

## 3.2.1 General

## 3.2.1.1 RTC Master Control Register

Used for general control over the RTC Master Clock. To get a new time snapshot the time read flag has to be set and the read done flag is asserted as soon as the time is read from the RTC. Since the time values are multi register values, a set flag is available to mark validity of the whole value.

| Rto            | : Ma      | ste   | rCor | ntro | l Re | g  |    |    |    |    |    |    |    |     |         |      |     |    |    |    |    |   |   |   |   |   |   |   |   |                |        |
|----------------|-----------|-------|------|------|------|----|----|----|----|----|----|----|----|-----|---------|------|-----|----|----|----|----|---|---|---|---|---|---|---|---|----------------|--------|
| Reg            | g Des     | scrip | tion |      |      |    |    |    |    |    |    |    |    |     |         |      |     |    |    |    |    |   |   |   |   |   |   |   |   |                |        |
| 31             | 30        | 29    | 28   | 27   | 26   | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16      | 15   | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1              | 0      |
| TIME_READ_DONE | TIME_READ |       |      |      |      |    |    |    |    |    |    |    |    |     |         | I    |     |    |    |    |    |   |   |   |   |   |   |   |   | TIME_WRITE_VAL | ENABLE |
| RO             | RW        |       |      |      |      |    |    |    |    |    |    |    |    |     | R       | 0    |     |    |    |    |    |   |   |   |   |   |   |   |   | RW             | RW     |
|                |           |       |      |      |      |    |    |    |    |    |    |    | R  |     | :: OxC  |      |     | 0  |    |    |    |   |   |   |   |   |   |   |   |                |        |
| 1              |           |       |      |      |      |    |    |    |    |    |    |    |    | Off | fset: ( | 0x00 | 000 |    |    |    |    |   |   |   |   |   |   |   |   |                |        |

| Name           | Description                  | Bits    | Access |
|----------------|------------------------------|---------|--------|
| TIME_READ_DONE | Time Read done (autocleared) | Bit: 31 | RO     |



| TIME_READ      | Time Read (autocleared)        | Bit: 30   | RW |
|----------------|--------------------------------|-----------|----|
| -              | Reserved, read O               | Bit: 29:2 | RO |
| TIME_WRITE_VAL | Time Write Valid (autocleared) | Bit: 1    | RW |
| ENABLE         | Enable                         | Bit: O    | RW |



## 3.2.1.2 RTC Master Status Register

Shows the current status of the RTC Master Clock. Each controller (Read, Write, Ctrl, I2C) has its own error flag.

| кеg | Desc | cript | ion |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |           |             |            |   |
|-----|------|-------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|-----------|-------------|------------|---|
| 31  |      | 29    | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3         | 2           | 1          | 0 |
|     |      |       |     |    |    |    |    |    |    |    |    |    |    | ı  |    |    |    |    |    |    |    |   |   |   |   |   |   | I2C_ERROR | WRITE_ERROR | READ_ERROR |   |
|     |      |       |     |    |    |    |    |    |    |    |    |    | R  | С  |    |    |    |    |    |    |    |   |   |   |   |   |   | WC        | WC          | WC         | W |

| Name       | Description      | Bits      | Access |
|------------|------------------|-----------|--------|
| -          | Reserved, read 0 | Bit: 21:4 | RO     |
| I2C_ERROR  | Error (sticky)   | Bit: 3    | WC     |
| WRITE_ERRO | Error (sticky)   | Bit: 2    | WC     |
| READ_ERROR | Error (sticky)   | Bit: 1    | WC     |
| CTRL_ERROR | Error (sticky)   | Bit: O    | WC     |



### 3.2.1.3 RTC Master Polarity Register

Used for setting the RTC PPS signal input polarity of the RTC Master Clock, shall only be done when disabled. Default value is set by the InputPolarity\_Gen generic.

| Rtc Mas  | sterP  | ola  | rity | Reg | 3  |    |    |    |    |    |    |    |     |       |      |     |     |    |    |    |   |   |   |   |   |   |   |   |   |         |
|----------|--------|------|------|-----|----|----|----|----|----|----|----|----|-----|-------|------|-----|-----|----|----|----|---|---|---|---|---|---|---|---|---|---------|
| Reg Desc | riptic | on   |      |     |    |    |    |    |    |    |    |    |     |       |      |     |     |    |    |    |   |   |   |   |   |   |   |   |   |         |
| 31 30    | 29 2   | 28 2 | 27 2 | 6   | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16    | 15   | 14  | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|          |        |      |      |     |    |    |    |    |    |    |    |    |     |       |      |     |     |    |    |    |   |   |   |   |   |   |   |   |   |         |
|          |        |      |      |     |    |    |    |    |    |    |    |    |     |       |      |     |     |    |    |    |   |   |   |   |   |   |   |   |   |         |
|          |        |      |      |     |    |    |    |    |    |    |    |    |     |       |      |     |     |    |    |    |   |   |   |   |   |   |   |   |   | $\succ$ |
|          |        |      |      |     |    |    |    |    |    |    |    |    |     |       |      |     |     |    |    |    |   |   |   |   |   |   |   |   |   | LIA,    |
|          |        |      |      |     |    |    |    |    |    |    |    |    |     |       | I    |     |     |    |    |    |   |   |   |   |   |   |   |   |   | DLA     |
|          |        |      |      |     |    |    |    |    |    |    |    |    |     |       |      |     |     |    |    |    |   |   |   |   |   |   |   |   |   | РО      |
|          |        |      |      |     |    |    |    |    |    |    |    |    |     |       |      |     |     |    |    |    |   |   |   |   |   |   |   |   |   |         |
|          |        |      |      |     |    |    |    |    |    |    |    |    |     |       |      |     |     |    |    |    |   |   |   |   |   |   |   |   |   |         |
|          |        |      |      |     |    |    |    |    |    |    |    |    |     | R     | )    |     |     |    |    |    |   |   |   |   |   |   |   |   |   | RW      |
|          |        |      |      |     |    |    |    |    |    |    |    |    | Res | et: 0 | x000 | 000 | XOC |    |    |    |   |   |   |   |   |   |   |   |   |         |
|          |        |      |      |     |    |    |    |    |    |    |    |    |     | )ffse |      |     |     |    |    |    |   |   |   |   |   |   |   |   |   |         |

| Name     | Description                                           | Bits     | Access |
|----------|-------------------------------------------------------|----------|--------|
| -        | Reserved, read 0                                      | Bit:31:1 | RO     |
| POLARITY | RTC PSS Signal Polarity (1 active high, 0 active low) | Bit: O   | RW     |



## 3.2.1.4 RTC Master Version Register

Version of the IP core, even though is seen as a 32bit value, bits 31 down to 24 represent the major, bits 23 down to 16 the minor and bits 15 down to 0 the build numbers.

| Rto | c Ma               | aste  | rVer | sior | n Re | g  |    |    |    |    |    |    |    |     |      |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|--------------------|-------|------|------|------|----|----|----|----|----|----|----|----|-----|------|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reg | g Des              | scrip | tion |      |      |    |    |    |    |    |    |    |    |     |      |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 31  | 30                 | 29    | 28   | 27   | 26   | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16   | 15     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|     |                    |       |      |      |      |    |    |    |    |    |    |    |    |     |      |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                    |       |      |      |      |    |    |    |    |    |    |    |    |     |      |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                    |       |      |      |      |    |    |    |    |    |    |    |    |     |      |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                    |       |      |      |      |    |    |    |    |    |    |    |    |     |      |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     | LEKSION<br>LEKSION |       |      |      |      |    |    |    |    |    |    |    |    |     |      |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                    |       |      |      |      |    |    |    |    |    |    |    |    |     |      | S<br>S |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                    |       |      |      |      |    |    |    |    |    |    |    |    |     |      | Ш<br>> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                    |       |      |      |      |    |    |    |    |    |    |    |    |     |      | -      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                    |       |      |      |      |    |    |    |    |    |    |    |    |     |      |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                    |       |      |      |      |    |    |    |    |    |    |    |    |     |      |        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                    |       |      |      |      |    |    |    |    |    |    |    |    |     | 1    | RO     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                    |       |      |      |      |    |    |    |    |    |    |    |    | 0x  |      | XXX    | XX |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                    |       |      |      |      |    |    |    |    |    |    |    |    |     |      | 0x00   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                    |       |      |      |      |    |    |    |    |    |    |    |    | 011 | JUL. | 0.00   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Name    | Description         | Bits      | Access |
|---------|---------------------|-----------|--------|
| VERSION | Version of the core | Bit: 31:0 | RO     |



### 3.2.1.5 RTC Master Time Read Value Low Register

Time snapshot value nanosecond part. This represents the number of nanoseconds after the seconds pulse of the RTC when the time was converted. This is an internally generated value and not from the RTC.

| Rto | c Ma   | aste  | rTim | neRe | ead | ∕alu | eL I | Reg |    |    |    |    |    |       |       |            |     |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|-----|--------|-------|------|------|-----|------|------|-----|----|----|----|----|----|-------|-------|------------|-----|--------|----|----|----|---|---|---|---|---|---|---|---|---|---|---|
| Reg | g De   | scrip | tion |      |     |      |      |     |    |    |    |    |    |       |       |            |     |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
| 31  | 30     | 29    | 28   | 27   | 26  | 25   | 24   | 23  | 22 | 21 | 20 | 19 | 18 | 17    | 16    | 15         | 14  | 13     | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 2 | 1 | 3 | 2 | 1 | 0 |
|     |        |       |      |      |     |      |      |     |    |    |    |    |    |       |       |            |     |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|     |        |       |      |      |     |      |      |     |    |    |    |    |    |       |       |            |     |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|     |        |       |      |      |     |      |      |     |    |    |    |    |    |       |       |            |     |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|     | S<br>Z |       |      |      |     |      |      |     |    |    |    |    |    |       |       |            |     |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|     |        |       |      |      |     |      |      |     |    |    |    |    |    |       |       |            |     |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|     |        |       |      |      |     |      |      |     |    |    |    |    |    |       |       |            |     |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|     |        |       |      |      |     |      |      |     |    |    |    |    |    |       |       | TIME       |     |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|     |        |       |      |      |     |      |      |     |    |    |    |    |    |       |       | 1          |     |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|     |        |       |      |      |     |      |      |     |    |    |    |    |    |       |       |            |     |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|     |        |       |      |      |     |      |      |     |    |    |    |    |    |       |       |            |     |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|     |        |       |      |      |     |      |      |     |    |    |    |    |    |       |       | 20         |     |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|     |        |       |      |      |     |      |      |     |    |    |    |    | Г  | Docot |       | 70<br>2000 |     | $\cap$ |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|     |        |       |      |      |     |      |      |     |    |    |    |    | F  |       |       |            |     | U      |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|     |        |       |      |      |     |      |      |     |    |    |    |    |    | Of    | TSET: | 0x0        | 010 |        |    |    |    |   |   |   |   |   |   |   |   |   |   |   |

| Name    | Description          | Bits      | Access |
|---------|----------------------|-----------|--------|
| TIME_NS | Read Time Nanosecond | Bit: 31:0 | RO     |



## 3.2.1.6 RTC Master Time Read Value High Register

Time snapshot value second part. This is the RTC time converted from time of day into seconds when the PPS has happened. Time is always read when the RTC PPS has ocured

| Rt  | c M | aste   | rTin | neRe | ead | ∕alu | eH | Reg |    |    |    |    |    |       |      |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|-----|--------|------|------|-----|------|----|-----|----|----|----|----|----|-------|------|------|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reg | g D | escrip | tion |      |     |      |    |     |    |    |    |    |    |       |      |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 31  | 30  | 29     | 28   | 27   | 26  | 25   | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17    | 16   | 15   | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|     |     |        |      |      |     |      |    |     |    |    |    |    |    |       |      |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |     |        |      |      |     |      |    |     |    |    |    |    |    |       |      |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |     |        |      |      |     |      |    |     |    |    |    |    |    |       |      |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     | N   |        |      |      |     |      |    |     |    |    |    |    |    |       |      |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |     |        |      |      |     |      |    |     |    |    |    |    |    |       |      |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |     |        |      |      |     |      |    |     |    |    |    |    |    |       |      |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |     |        |      |      |     |      |    |     |    |    |    |    |    |       |      | ΤΜΕ  |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |     |        |      |      |     |      |    |     |    |    |    |    |    |       |      |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |     |        |      |      |     |      |    |     |    |    |    |    |    |       |      |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |     |        |      |      |     |      |    |     |    |    |    |    |    |       |      |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |     |        |      |      |     |      |    |     |    |    |    |    |    |       |      |      |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |     |        |      |      |     |      |    |     |    |    |    |    |    |       |      | RO   |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |     |        |      |      |     |      |    |     |    |    |    |    | F  | Reset |      | 0000 | 000 | 0  |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |     |        |      |      |     |      |    |     |    |    |    |    |    |       |      | 0x0  |     | -  |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |     |        |      |      |     |      |    |     |    |    |    |    |    | UI    | 1301 | 0.00 |     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Name   | Description      | Bits      | Access |
|--------|------------------|-----------|--------|
| TIME_S | Read Time Second | Bit: 31:0 | RO     |



## 3.2.1.7 RTC Master Time Write Value Low Register

Write time nanoseconds part value. This is currently unused.

| Rtc MasterTimeWriteValueL Reg                                                       |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------|---|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Reg Description                                                                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| $\mathbf{\bar{s}}$                                                                  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                                                                                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| RW                                                                                  |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset: 0x0000000                                                                    |   |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Offset: 0x0020                                                                      |   |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Name          | Description              | Bits      | Access |
|---------------|--------------------------|-----------|--------|
| TIME_WRITE_NS | OverwriteTime Nanosecond | Bit: 31:0 | RW     |



## 3.2.1.8 RTC Master Time Write Value High Register

Write time seconds part value. The time will be written to the Clock at the next RTC PPS event.

| Rtc | Mast             | terT | īme | eW | rite | Valu | ıeH | Reg | J  |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|------------------|------|-----|----|------|------|-----|-----|----|----|----|----|----|----|----|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reg | Reg Description  |      |     |    |      |      |     |     |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 31  | 30 2             | 9 :  | 28  | 27 | 26   | 25   | 24  | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|     |                  |      |     |    |      |      |     |     |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                  |      |     |    |      |      |     |     |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                  |      |     |    |      |      |     |     |    |    |    |    |    |    |    | ഗ    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                  |      |     |    |      |      |     |     |    |    |    |    |    |    |    | Щ    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                  |      |     |    |      |      |     |     |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                  |      |     |    |      |      |     |     |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                  |      |     |    |      |      |     |     |    |    |    |    |    |    |    | Щ    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                  |      |     |    |      |      |     |     |    |    |    |    |    |    |    | TIME |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                  |      |     |    |      |      |     |     |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     |                  |      |     |    |      |      |     |     |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     | RW               |      |     |    |      |      |     |     |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     | Reset: 0x0000000 |      |     |    |      |      |     |     |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     | Offset: 0x0024   |      |     |    |      |      |     |     |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|     | Offset. 0x0024   |      |     |    |      |      |     |     |    |    |    |    |    |    |    |      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Name         | Description          | Bits      | Access |
|--------------|----------------------|-----------|--------|
| TIME_WRITE_S | OverwriteTime Second | Bit: 31:0 | RW     |



# 4 Design Description

The following chapters describe the internals of the RTC Master Clock: starting with the Top Level, which is a collection of subcores, followed by the description of all subcores.

# 4.1 Top Level - Rtc Master

## 4.1.1.1 Parameters

The core must be parametrized at synthesis time. There are a couple of parameters which define the final behavior and resource usage of the core.

| Name              | Туре             | Size | Description                     |
|-------------------|------------------|------|---------------------------------|
| StaticConfig_Gen  | boolean          | 1    | If Static Configuration or AXI  |
| 3_                |                  |      | is used                         |
|                   | Rtc_ClockType_   |      | DS1307_E or MCP7941x_E are      |
| RtcClockType_Gen  | Type             | 1    | supported to define the type    |
|                   |                  |      | of RTC connected                |
| ClockClkPeriod    | natural          | 1    | Clock Period in Nanosecond:     |
| Nanosecond_Gen    |                  | 1    | Default for 50 MHz = 20 ns      |
|                   |                  |      | I2C clock Period in Nanosec-    |
| I2cClkPeriod      | natural          | 1    | ond:                            |
| Nanosecond_Gen    | naturai          | I    | Default for 100 kHz = 10000     |
|                   |                  |      | ns                              |
| l2cAdress_Gen     | natural          | 1    | I2C 7 bit address of the RTC    |
| InputDelay        |                  |      | Input delay of the PPS from     |
| Nanosecond_Gen    | natural          | 1    | the output signal to the con-   |
| Nanosecona_Gen    |                  |      | nector.                         |
| InputDolority Con | boolean          | 1    | true = high active, false = low |
| InputPolarity_Gen | boolean          | I    | active                          |
| AxiAddressRange   | sta lagio vestor | 32   | AXI Base Address                |
| Low_Gen           | std_logic_vector | 32   |                                 |
|                   |                  |      | AXI Base Address plus Regis-    |
| AxiAddressRange   | std_logic_vector | 32   | terset Size                     |
| High_Gen          |                  |      | Default plus 0xFFFF             |
|                   |                  | 1    | If in Testbench simulation      |
| Sim_Gen           | boolean          | 1    | mode:                           |



|  | true = Simulation, false = |
|--|----------------------------|
|  | Synthesis                  |

Table 5:Parameters

## 4.1.1.2 Structured Types

#### 4.1.1.2.1 Clk\_Time\_Type

Defined in Clk\_Package.vhd of library ClkLib

Type represents the time used everywhere. For this type overloaded operators + and - with different parameters exist.

| Field Name  | Туре             | Size | Description                    |  |  |  |
|-------------|------------------|------|--------------------------------|--|--|--|
| Second      | std_logic_vector | 32   | Seconds of time                |  |  |  |
| Nanosecond  | std_logic_vector | 32   | Nanoseconds of time            |  |  |  |
| Fraction    | std_logic_vector | 2    | Fraction numerator (mostly     |  |  |  |
|             |                  | ~    | not used)                      |  |  |  |
| Sign        | std_logic        | 1    | Positive or negative time, 1 = |  |  |  |
| Sign        |                  | 1    | negative, 0 = positive.        |  |  |  |
| TimeJump    | std_logic        | 1    | Marks when the clock makes a   |  |  |  |
| - ninesump- | sta_logic        |      | time jump (mostly not used)    |  |  |  |

Table 6:Clk\_Time\_Type

#### 4.1.1.2.2 Clk\_CoreInfo\_Type

Defined in Clk\_Package.vhd of library ClkLib

This is the type used for getting info about the cores state status.

| Field Name | Туре             | Size | Description                     |  |  |  |
|------------|------------------|------|---------------------------------|--|--|--|
| State      | Clk_CoreState_T  | 1    | State of the core: Unknown_E,   |  |  |  |
|            | уре              |      | Slave_E or Master_E             |  |  |  |
| Accuracy   | std_logic_vector | 8    | Accuracy of the core, higher is |  |  |  |
| Accuracy   |                  | 0    | better                          |  |  |  |
| Enabled    | std_logic        | 1    | If the core is enabled          |  |  |  |
| InSync     | std_logic        | 1    | If the core is synchronized     |  |  |  |
| Error      | std_logic        | 1    | If the core has an error        |  |  |  |

Table 7:Clk\_CoreInfo\_Type



#### 4.1.1.2.3 Rtc\_MasterStaticConfig\_Type

Defined in Rtc\_MasterAddrPackage.vhd of library RtcLib This is the type used for static configuration.

| Field Name | Туре          | Size | Description                            |  |  |
|------------|---------------|------|----------------------------------------|--|--|
| Polarity   | std_logic     | 1    | '1' = high active, '0' = low<br>active |  |  |
| WriteTime  | Clk_Time_Type | 1    | Time to write                          |  |  |

Table 8:Rtc\_MasterStaticConfig\_Type

#### 4.1.1.2.4 Rtc\_MasterStaticConfigVal\_Type

Defined in Rtc\_MasterAddrPackage.vhd of library RtcLib This is the type used for valid flags of the static configuration.

| Field Name    | Туре      | Size | Description            |  |  |
|---------------|-----------|------|------------------------|--|--|
| Enable_Val    | std_logic | 1    | Enables the PPS Master |  |  |
| WriteTime_Val | std_logic | 1    | Writes the time        |  |  |

Table 9:Rtc\_MasterStaticConfigVal\_Type

#### 4.1.1.2.5 Rtc\_MasterStaticStatus\_Type

Defined in Rtc\_MasterAddrPackage.vhd of library RtcLib This is the type used for static status supervision.

| Field Name | Туре                  | Size | Description                 |  |  |
|------------|-----------------------|------|-----------------------------|--|--|
| CoreInfo   | Clk_CoreInfo_<br>Type | 1    | Infor about the Cores state |  |  |
| ReadTime   | Clk_Time_Type         | 1    | Read time                   |  |  |

Table 10:Rtc\_MasterStaticConfig\_Type

#### 4.1.1.2.6 Rtc\_MasterStaticStatusVal\_Type

Defined in Rtc\_MasterAddrPackage.vhd of library RtcLib

This is the type used for valid flags of the static status supervision.



| Field Name   | Туре      | Size | Description     |
|--------------|-----------|------|-----------------|
| CoreInfo_Val | std_logic | 1    | Core Info valid |
| ReadTime_Val | std_logic | 1    | Read time valid |

 Table 11:
 Rtc\_MasterStaticConfigVal\_Type



## 4.1.1.3 Entity Block Diagram



Figure 9: RTC Master Clock

## 4.1.1.4 Entity Description

#### I2C

This module is the I2C controller converting the internal parallel register access to the serial I2C access. There is arbitration between the Read-, Write- and Control-Processor which can access the I2C bus.

See 4.2.1 for more details.

#### **Control Processor**

This module configures the RTC clock at startup to run in the correct mode and to put out the 1Hz square wave output. Once ready it releases the Read- and Write-Processor

See 4.2.2 for more details.

#### **Read Processor**

This module reads the time from the RTC via I2C at the RTC PPS event, converts it to binary time, calculates offset and drift and adjusts the clock. See 4.2.3 for more details.

#### Write Processor

This module converts the time to BCD time of day format and writes the time to the RTC via I2C at the RTC PPS event.

See 4.2.4 for more details.

#### **Register Set**



This module is an AXI4Lite Memory Mapped Slave. It provides access to all registers and allows configuring the RTC Master Clock. It can be configured to either run in AXI or StaticConfig mode. If in StaticConfig mode, the configuration of the registers is done via signals and can be easily done from within the FPGA without CPU. If in AXI mode, an AXI Master has to configure the registers with AXI writes to the registers, which is typically done by a CPU. It also provides a status interface which allows similar to the static configuration to supervise the status via signals. See 4.2.5 for more details.

## 4.1.1.5 Entity Declaration

| Name                             | Dir | Туре               | Size | Description                                                                          |
|----------------------------------|-----|--------------------|------|--------------------------------------------------------------------------------------|
|                                  |     | Generics           |      |                                                                                      |
| General                          |     |                    |      |                                                                                      |
| RtcClockType                     | -   | Rtc_ClockType_Type | 1    | DS1307_E or<br>MCP7941x_E are<br>supported to define<br>the type of RTC<br>connected |
| StaticConfig_Gen                 | -   | boolean            | 1    | If Static Configura-<br>tion or AXI is used                                          |
| ClockClkPeriod<br>Nanosecond_Gen | -   | natural            | 1    | Integer Clock Period                                                                 |
| I2cClkPeriod<br>Nanosecond_Gen   | -   | natural            | 1    | I2C clock Period in<br>Nanosecond:<br>Default for 100 kHz<br>= 10000 ns              |
| l2cAdress_Gen                    | -   | natural            | 1    | I2C 7 bit address of the RTC                                                         |
| InputDelay<br>Nanosecond_Gen     | -   | natural            | 1    | Input delay of the<br>PPS from the con-<br>nector to the input<br>signal             |
| InputPolarity_Gen                | -   | boolean            | 1    | True: High active,<br>False: Low active                                              |
| AxiAddressRange<br>Low_Gen       | -   | std_logic_vector   | 32   | AXI Base Address                                                                     |



|                              |     |                                        |    | AXI Base Address                   |
|------------------------------|-----|----------------------------------------|----|------------------------------------|
| AxiAddressRange<br>High_Gen  | -   | std_logic_vector                       | 32 | plus Registerset<br>Size           |
| Sim_Gen                      | -   | boolean                                | 1  | If in Testbench<br>simulation mode |
|                              |     | Ports                                  |    |                                    |
| System                       |     |                                        | 1  |                                    |
| SysClk_ClkIn                 | in  | std_logic                              | 1  | System Clock                       |
| SysRstN_RstIn                | in  | std_logic                              | 1  | System Reset                       |
| Config<br>StaticConfig_DatIn | in  | Rtc_Master<br>StaticConfig_Type        | 1  | Static Configuration               |
| StaticConfig_ValIn           | in  | Rtc_Master<br>StaticConfigVal<br>_Type | 1  | Static Configuration<br>valid      |
| Status                       |     |                                        |    |                                    |
| StaticStatus_DatOut          | out | Rtc_Master<br>StaticStatus_Type        | 1  | Static Status                      |
| StaticStatus_ValOut          | out | Rtc_Master<br>StaticStatusVal<br>_Type | 1  | Static Status valid                |
| Timer                        |     |                                        |    | Millisecond timer                  |
| Timer1ms_EvtIn               | in  | std_logic                              | 1  | adjusted with the<br>Clock         |
| Time Input                   |     |                                        |    |                                    |
| ClockTime_DatIn              | in  | Clk_Time_Type                          | 1  | Adjusted PTP Clock<br>Time         |
| ClockTime_ValIn              | in  | std_logic                              | 1  | Adjusted PTP Clock<br>Time valid   |
| AXI4 Lite Slave              |     |                                        | •  |                                    |
| AxiWriteAddrValid<br>_ValIn  | in  | std_logic                              | 1  | Write Address Valid                |
| AxiWriteAddrReady<br>RdyOut  | out | std_logic                              | 1  | Write Address<br>Ready             |
| AxiWriteAddrAddress<br>AdrIn | in  | std_logic_vector                       | 32 | Write Address                      |
| AxiWriteAddrProt<br>_DatIn   | in  | std_logic_vector                       | 3  | Write Address<br>Protocol          |
| AxiWriteDataValid<br>_ValIn  | in  | std_logic                              | 1  | Write Data Valid                   |



|                                     |            |                             | Γ  |                                                      |
|-------------------------------------|------------|-----------------------------|----|------------------------------------------------------|
| AxiWriteDataReady<br>RdyOut         | out        | std_logic                   | 1  | Write Data Ready                                     |
| AxiWriteDataData<br>_DatIn          | in         | std_logic_vector            | 32 | Write Data                                           |
| AxiWriteDataStrobe<br>DatIn         | in         | std_logic_vector            | 4  | Write Data Strobe                                    |
| <br>AxiWriteRespValid<br>ValOut     | out        | std_logic                   | 1  | Write Response<br>Valid                              |
| AxiWriteRespReady<br>_RdyIn         | in         | std_logic                   | 1  | Write Response<br>Ready                              |
| AxiWriteResp<br>Response_DatOut     | out        | std_logic_vector            | 2  | Write Response                                       |
| AxiReadAddrValid<br>Valln           | in         | std_logic                   | 1  | Read Address Valid                                   |
| AxiReadAddrReady<br>RdyOut          | out        | std_logic                   | 1  | Read Address<br>Ready                                |
| AxiReadAddrAddress<br>AdrIn         | in         | std_logic_vector            | 32 | Read Address                                         |
| AxiReadAddrProt<br>DatIn            | in         | std_logic_vector            | 3  | Read Address<br>Protocol                             |
| AxiReadDataValid<br>ValOut          | out        | std_logic                   | 1  | Read Data Valid                                      |
| AxiReadDataReady<br>RdyIn           | in         | std_logic                   | 1  | Read Data Ready                                      |
| AxiReadData<br>Response_DatOut      | out        | std_logic_vector            | 2  | Read Data                                            |
| <br>AxiReadDataData<br>DatOut       | out        | std_logic_vector            | 32 | Read Data Re-<br>sponse                              |
| I2C Interface                       | 1          |                             | 1  |                                                      |
| I2cClk_ClkOut                       | in         | std_logic                   | 1  | I2C clock output                                     |
| l2cSda_DatIn                        | in         | std_logic                   | 1  | I2C data input                                       |
| l2cSda_DatOut                       | out        | std_logic                   | 1  | I2C data output                                      |
| l2cSdaOe_ValOut                     | out        | std_logic                   | 1  | I2C data output<br>enable                            |
| RTC Pulse Per Second I<br>Rtc_EvtIn | nput<br>in | std_logic                   | 1  | PPS input                                            |
| Time Adjustment Outpu               |            | _ 3                         |    |                                                      |
| TimeAdjustment<br>_DatOut           | out        | Clk_TimeAdjustment<br>_Type | 1  | Time to set hard<br>(unused)                         |
| TimeAdjustment<br>_ValOut           | out        | std_logic                   | 1  | Time valid<br>(unused)                               |
| Offset Adjustment Out               | out        |                             |    |                                                      |
| OffsetAdjustment<br>_DatOut         | out        | Clk_TimeAdjustment<br>_Type | 1  | Calculated new<br>Offset between<br>Master and Slave |



| OffsetAdjustment<br>_ValOut | out | std_logic;                  | 1 | Calculated new<br>Offset valid                            |  |  |  |
|-----------------------------|-----|-----------------------------|---|-----------------------------------------------------------|--|--|--|
| Drift Adjustment Output     |     |                             |   |                                                           |  |  |  |
| DriftAdjustment<br>_DatOut  | out | Clk_TimeAdjustment<br>_Type | 1 | Calculated new Drift<br>between Master and<br>Slave       |  |  |  |
| DriftAdjustment<br>_ValOut  | out | std_logic;                  | 1 | Calculated new Drift valid                                |  |  |  |
| Offset Adjustment Inpu      | t   |                             |   |                                                           |  |  |  |
| OffsetAdjustment<br>_DatIn  | in  | Clk_TimeAdjustment<br>_Type | 1 | Calculated new<br>Offset after the PI<br>Servo loop       |  |  |  |
| OffsetAdjustment<br>_ValIn  | in  | std_logic;                  | 1 | Calculated new<br>Offset after the PI<br>Servo loop valid |  |  |  |
| Drift Adjustment Input      |     |                             |   |                                                           |  |  |  |
| DriftAdjustment<br>_DatIn   | in  | Clk_TimeAdjustment<br>_Type | 1 | Calculated new Drift<br>after the PI Servo<br>loop        |  |  |  |
| DriftAdjustment<br>_ValIn   | in  | std_logic                   | 1 | Calculated new Drift<br>after the PI Servo<br>loop valid  |  |  |  |

Table 12: RTC Master Clock



## 4.2 Design Parts

The RTC Master Clock core consists of a couple of subcores. Each of the subcores itself consist again of smaller function block. The following chapters describe these subcores and their functionality.

## 4.2.1 I2C

## 4.2.1.1 Entity Block Diagram



Figure 10: I2C

## 4.2.1.2 Entity Description

#### I2C

This module handles the I2C interface it uses the control signals from the parallel register interface and converts it into an I2C access. Via the register control interface the device address, the register address, read or write data and a read/write flag can be set.

The I2C module then creates the following I2C access cycles:



Figure 11: I2C Write Access



Figure 12: I2C Read Access

The module also supervises and creates the ACK signals and state and signals an error if not correct.

Once the access is completed it signals this to the Control-, Read- or Write-Processor, which will then start another register access until all bytes are handled.



The I2C controller only supports single byte access, no continuous read or block read or write. This is not the highest performance mechanism but the simplest and least resource consuming mechanism, which is perfectly fine since no high performance or throughput is required.

## 4.2.1.3 Entity Declaration

| Name                        | Dir | Туре             | Size | Description                       |  |  |  |  |
|-----------------------------|-----|------------------|------|-----------------------------------|--|--|--|--|
| Generics                    |     |                  |      |                                   |  |  |  |  |
| General                     |     | _                |      |                                   |  |  |  |  |
| ClockClkPeriod              | -   | natural          | 1    | Clock Period in                   |  |  |  |  |
| Nanosecond_Gen              |     |                  |      | Nanosecond                        |  |  |  |  |
| 12C                         |     |                  |      | 12C clock Period in               |  |  |  |  |
| DeclyDevied                 |     |                  |      |                                   |  |  |  |  |
| I2cClkPeriod                | -   | natural          | 1    | Nanosecond:                       |  |  |  |  |
| Nanosecond_Gen              |     |                  |      | Default for 100 kHz<br>= 10000 ns |  |  |  |  |
| Ports                       |     |                  |      |                                   |  |  |  |  |
| System                      | ·   |                  |      |                                   |  |  |  |  |
| SysClk_ClkIn                | in  | std_logic        | 1    | System Clock                      |  |  |  |  |
| SysRstN_RstIn               | in  | std_logic        | 1    | System Reset                      |  |  |  |  |
| I2C Interface<br>Clk_ClkOut | out | std logic        | 1    | 12C Cleak Output                  |  |  |  |  |
|                             | out | std_logic        | 1    | I2C Clock Output                  |  |  |  |  |
| Sda_DatIn                   | in  | std_logic        | 1    | I2C Data Input                    |  |  |  |  |
| Sda_DatOut                  | out | std_logic        | 1    | I2C Data Output                   |  |  |  |  |
| SdaOe_ValOut                | out | std_logic        | 1    | I2C Data Output                   |  |  |  |  |
|                             |     |                  |      | enable                            |  |  |  |  |
| I2C Control Interface       | in  | std logic        | 1    | $(1)$ , $\Lambda/\kappa$ to       |  |  |  |  |
| ReadWrite_DatIn             | in  | std_logic        | I    | '1': Write,                       |  |  |  |  |
|                             |     |                  |      | '0': Read                         |  |  |  |  |
| WriteData_DatIn             | in  | std_logic_vector | 8    | Write Data                        |  |  |  |  |
| ReadData_DatOut             | out | std_logic_vector | 8    | Read Data                         |  |  |  |  |
| ChipAddress_AdrIn           | in  | std_logic_vector | 7    | I2C 7 bit RTC                     |  |  |  |  |
|                             |     |                  |      | address                           |  |  |  |  |
| RegAddress_AdrIn            | in  | std_logic_vector | 8    | Register address                  |  |  |  |  |
| Access_ErrOut               | out | std_logic        | 1    | I2C error                         |  |  |  |  |
| Access_Valln                | in  | std_logic        | 1    | Do Access                         |  |  |  |  |



| Access_ValOut | out | std_logic | 1 | Access done |
|---------------|-----|-----------|---|-------------|
|               |     |           |   |             |

Table 13: I2C



### **4.2.2 Control Processor**

#### 4.2.2.1 Entity Block Diagram



Figure 13: Control Processor

#### 4.2.2.2 Entity Description

#### **Control Processor**

This module configures and enables the RTC on startup. It sets the correct frequency of 1Hz on the square wave output and puts the RTC in a mode where it continuously runs (also in battery holdover mode). Once enabled it waits for a second and one RTC PPS event before releasing the Read- and Write-Processor. This is done this way to ensure the Read- and Write Processor start at a second boundary. This procedure repeats when the core is disabled and reenabled. Once enabled the Control Processor stays silent.

#### 4.2.2.3 Entity Declaration

| Name              | Dir               | Туре               | Size | Description         |  |  |
|-------------------|-------------------|--------------------|------|---------------------|--|--|
| Generics          |                   |                    |      |                     |  |  |
| General           |                   |                    |      |                     |  |  |
|                   |                   |                    |      | DS1307_E or         |  |  |
|                   |                   |                    |      | MCP7941x_E are      |  |  |
| RtcClockType      | -                 | Rtc_ClockType_Type | 1    | supported to define |  |  |
|                   |                   |                    |      | the type of RTC     |  |  |
|                   |                   |                    |      | connected           |  |  |
| ClockClkPeriod    |                   | patural            | 1    | Clock Period in     |  |  |
| Nanosecond_Gen    | -                 | natural            | I    | Nanosecond          |  |  |
| Sim Con           |                   | booloop            | 1    | If in Testbench     |  |  |
| Sim_Gen           | -                 | boolean            | Ι    | simulation mode     |  |  |
| Control Processor | Control Processor |                    |      |                     |  |  |
| InputDelay        | _                 | natural            | 1    | Input delay of the  |  |  |
| Nanosecond_Gen    |                   |                    | Ι    | PPS from the con-   |  |  |



|                                                                                                                                                                                                             |                                                   |                                                                                                                                                      |                                           | nector to the input<br>signal                                                                                                                                                                     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                             |                                                   | Ports                                                                                                                                                |                                           |                                                                                                                                                                                                   |
| System                                                                                                                                                                                                      | •                                                 |                                                                                                                                                      | 1                                         |                                                                                                                                                                                                   |
| SysClk_ClkIn                                                                                                                                                                                                | in                                                | std_logic                                                                                                                                            |                                           | System Clock                                                                                                                                                                                      |
| SysRstN_RstIn                                                                                                                                                                                               | in                                                | std_logic                                                                                                                                            |                                           | System Reset                                                                                                                                                                                      |
| Timer<br>Timer1ms_EvtIn                                                                                                                                                                                     | in                                                | std_logic                                                                                                                                            | 1                                         | Millisecond timer<br>adjusted with the<br>Clock                                                                                                                                                   |
| Time Input<br>ClockTime_DatIn                                                                                                                                                                               | in                                                | Clk_Time_Type                                                                                                                                        | 1                                         | Adjusted PTP Clock<br>Time                                                                                                                                                                        |
| ClockTime_ValIn                                                                                                                                                                                             | in                                                | std_logic                                                                                                                                            | 1                                         | Adjusted PTP Clock<br>Time valid                                                                                                                                                                  |
| RTC Pulse Per Second F                                                                                                                                                                                      | Polarity                                          | ý                                                                                                                                                    |                                           | '1': High active,                                                                                                                                                                                 |
| RtcPolarity_DatIn                                                                                                                                                                                           | in                                                | std_logic                                                                                                                                            | 10                                        | '0': Low active                                                                                                                                                                                   |
| RTC Pulse Per Second I<br>Rtc_EvtIn                                                                                                                                                                         | nput<br>in                                        | std_logic                                                                                                                                            | 1                                         | PPS input                                                                                                                                                                                         |
| RTC Error Output                                                                                                                                                                                            | 11.1                                              | 0                                                                                                                                                    |                                           |                                                                                                                                                                                                   |
|                                                                                                                                                                                                             |                                                   |                                                                                                                                                      |                                           |                                                                                                                                                                                                   |
| Rtc_ErrOut                                                                                                                                                                                                  | out                                               | std_logic                                                                                                                                            | 1                                         | Indicates an access<br>error                                                                                                                                                                      |
| Rtc_ErrOut<br>I2C Control Interface                                                                                                                                                                         |                                                   |                                                                                                                                                      | 1                                         | error                                                                                                                                                                                             |
| Rtc_ErrOut                                                                                                                                                                                                  | out<br>out                                        | std_logic<br>std_logic                                                                                                                               | 1                                         |                                                                                                                                                                                                   |
| Rtc_ErrOut<br>I2C Control Interface                                                                                                                                                                         |                                                   |                                                                                                                                                      | 1<br>1<br>8                               | error<br>'1': Write,                                                                                                                                                                              |
| Rtc_ErrOut<br>I2C Control Interface<br>ReadWrite_DatOut                                                                                                                                                     | out                                               | std_logic                                                                                                                                            |                                           | error<br>'1': Write,<br>'O': Read                                                                                                                                                                 |
| Rtc_ErrOut<br>I2C Control Interface<br>ReadWrite_DatOut<br>WriteData_DatOut                                                                                                                                 | out<br>out                                        | std_logic_<br>std_logic_vector                                                                                                                       | 8                                         | error<br>'1': Write,<br>'0': Read<br>Write Data                                                                                                                                                   |
| Rtc_ErrOut<br>I2C Control Interface<br>ReadWrite_DatOut<br>WriteData_DatOut<br>ReadData_DatIn                                                                                                               | out<br>out<br>in                                  | std_logic_vector<br>std_logic_vector                                                                                                                 | 8                                         | error<br>'1': Write,<br>'0': Read<br>Write Data<br>Read Data<br>I2C 7 bit RTC                                                                                                                     |
| Rtc_ErrOut<br>I2C Control Interface<br>ReadWrite_DatOut<br>WriteData_DatOut<br>ReadData_DatIn<br>ChipAddress_AdrOut                                                                                         | out<br>out<br>in<br>out                           | std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector                                                                         | 8<br>8<br>7                               | error<br>'1': Write,<br>'0': Read<br>Write Data<br>Read Data<br>I2C 7 bit RTC<br>address                                                                                                          |
| Rtc_ErrOut<br>I2C Control Interface<br>ReadWrite_DatOut<br>WriteData_DatOut<br>ReadData_DatIn<br>ChipAddress_AdrOut<br>RegAddress_AdrOut                                                                    | out<br>out<br>in<br>out<br>out                    | std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector                                                     | 8<br>8<br>7<br>8<br>8                     | error<br>'1': Write,<br>'0': Read<br>Write Data<br>Read Data<br>I2C 7 bit RTC<br>address<br>Register address                                                                                      |
| Rtc_ErrOut<br>12C Control Interface<br>ReadWrite_DatOut<br>WriteData_DatOut<br>ReadData_DatIn<br>ChipAddress_AdrOut<br>RegAddress_AdrOut<br>AccessReq_ValOut                                                | out<br>out<br>in<br>out<br>out<br>out             | std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector                                 | 8<br>8<br>7<br>8<br>8<br>1                | error<br>'1': Write,<br>'0': Read<br>Write Data<br>Read Data<br>I2C 7 bit RTC<br>address<br>Register address<br>Reguest I2C access                                                                |
| Rtc_ErrOut<br>I2C Control Interface<br>ReadWrite_DatOut<br>WriteData_DatOut<br>ReadData_DatIn<br>ChipAddress_AdrOut<br>RegAddress_AdrOut<br>AccessReq_ValOut<br>AccessAck_ValIn                             | out<br>in<br>out<br>out<br>out<br>in              | std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic<br>std_logic                           | 8<br>8<br>7<br>8<br>1<br>1                | error<br>'1': Write,<br>'0': Read<br>Write Data<br>Read Data<br>I2C 7 bit RTC<br>address<br>Register address<br>Reguest I2C access<br>I2C Access granted                                          |
| Rtc_ErrOut<br>I2C Control Interface<br>ReadWrite_DatOut<br>WriteData_DatOut<br>ReadData_DatIn<br>ChipAddress_AdrOut<br>RegAddress_AdrOut<br>AccessReq_ValOut<br>Access_ErrIn                                | out<br>in<br>out<br>out<br>out<br>in<br>in        | std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic<br>std_logic<br>std_logic              | 8<br>8<br>7<br>8<br>1<br>1<br>1<br>1      | error<br>'1': Write,<br>'0': Read<br>Write Data<br>Read Data<br>I2C 7 bit RTC<br>address<br>Register address<br>Reguest I2C access<br>I2C Access granted<br>I2C error                             |
| Rtc_ErrOut<br>I2C Control Interface<br>ReadWrite_DatOut<br>WriteData_DatOut<br>ReadData_DatIn<br>ChipAddress_AdrOut<br>RegAddress_AdrOut<br>AccessReq_ValOut<br>Access_ErrIn<br>Access_ValOut               | out<br>in<br>out<br>out<br>out<br>in<br>in<br>out | std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic<br>std_logic<br>std_logic<br>std_logic | 8<br>8<br>7<br>8<br>1<br>1<br>1<br>1<br>1 | error<br>'1': Write,<br>'0': Read<br>Write Data<br>Read Data<br>I2C 7 bit RTC<br>address<br>Register address<br>Reguest I2C access<br>I2C Access granted<br>I2C error<br>Do Access<br>Access done |
| Rtc_ErrOut<br>I2C Control Interface<br>ReadWrite_DatOut<br>WriteData_DatOut<br>ReadData_DatIn<br>ChipAddress_AdrOut<br>AccessReq_ValOut<br>AccessAck_ValIn<br>Access_ErrIn<br>Access_ValOut<br>Access_ValIn | out<br>in<br>out<br>out<br>out<br>in<br>in<br>out | std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic_vector<br>std_logic<br>std_logic<br>std_logic<br>std_logic | 8<br>8<br>7<br>8<br>1<br>1<br>1<br>1<br>1 | error<br>'1': Write,<br>'0': Read<br>Write Data<br>Read Data<br>I2C 7 bit RTC<br>address<br>Register address<br>Reguest I2C access<br>I2C Access granted<br>I2C error<br>Do Access                |



| Enable_EnaOut | out | std_logic | 1 | Enables the other processors |
|---------------|-----|-----------|---|------------------------------|
|---------------|-----|-----------|---|------------------------------|

Table 14:Control Processor



### 4.2.3 Read Processor

### 4.2.3.1 Entity Block Diagram





### 4.2.3.2 Entity Description

#### **Read Processor**

This module reads the time when the RTC PPS event is detected. A timestamp of the local clock is taken at this event and a nanosecond counter reset, both taking input delays into account. At this event it starts to read the years part first and reads all registers one by one until the seconds part. Then it decodes the BCD encoded register values into straight binary values. After that it converts the straight binary values of the time in time of day format into time in seconds since midnight 1.1.1970 (TAI) taking leap years into account. Last the nanosecond counter, which was reset at the RTC PPS event, is merged with the just decoded second part and the Read Time is validated. Before the nanosecond counter is merged with the decoded seconds value the time is passed to the Adjustment Calculator module together with the timestamp taken at the RTC PPS event for offset and drift calculation. The two values passed, represent the two times of the two clocks at the same moment in time and can therefore be used for comparison. This mechanism guarantees that the time is always valid since the RTC only updates its time once a second and the read of individual registers hall not happen during an update cycle, but on the other hand this also only allows to update the time once a second.

#### **Adjustment Calculator**

This module calculates the drift and offset of the local clock against the RTC time and corrects it. After enabling or error detection the calculation waits for two consecutive time reads of the Read Processor before adjusting the clock again.



## 4.2.3.3 Entity Declaration

| Name                                           | Dir        | Туре                   | Size | Description                                                                          |  |  |
|------------------------------------------------|------------|------------------------|------|--------------------------------------------------------------------------------------|--|--|
| Generics                                       |            |                        |      |                                                                                      |  |  |
| General<br>RtcClockType                        | _          | Rtc_ClockType_Type     | 1    | DS1307_E or<br>MCP7941x_E are<br>supported to define<br>the type of RTC<br>connected |  |  |
| ClockClkPeriod<br>Nanosecond_Gen               | -          | natural                | 1    | Clock Period in<br>Nanosecond                                                        |  |  |
| Sim_Gen                                        | -          | boolean                | 1    | If in Testbench<br>simulation mode                                                   |  |  |
| Read Processor<br>InputDelay<br>Nanosecond_Gen | _          | natural                | 1    | Input delay of the<br>PPS from the con-<br>nector to the input<br>signal             |  |  |
|                                                |            | Ports                  |      |                                                                                      |  |  |
| System<br>SysClk_ClkIn<br>SysRstN_RstIn        | in<br>in   | std_logic<br>std_logic | 1    | System Clock<br>System Reset                                                         |  |  |
| Timer<br>Timer1ms_EvtIn                        | in         | std_logic              | 1    | Millisecond timer<br>adjusted with the<br>Clock                                      |  |  |
| Time Input<br>ClockTime_DatIn                  | in         | Clk_Time_Type          | 1    | Adjusted PTP Clock<br>Time                                                           |  |  |
| ClockTime_ValIn                                | in         | std_logic              | 1    | Adjusted PTP Clock<br>Time valid                                                     |  |  |
| RTC Pulse Per Second I<br>RtcPolarity_DatIn    | in         | std_logic              | 10   | '1': High active,<br>'0': Low active                                                 |  |  |
| RTC Pulse Per Second I<br>Rtc_EvtIn            | nput<br>in | std_logic              | 1    | PPS input                                                                            |  |  |
| RTC Error Output<br>Rtc_ErrOut                 | out        | std_logic              | 1    | Indicates an access<br>error                                                         |  |  |



| RTC Read Time Output                       |     |                      | 1 |                      |
|--------------------------------------------|-----|----------------------|---|----------------------|
| ReadTime_DatOut                            | out | Clk_Time_Type        | 1 | RTC Read Time        |
| ReadTime_ValOut                            | out | std logic            | 1 | RTC Read Time        |
|                                            |     |                      |   | valid                |
| Offset Adjustment Out                      | out |                      |   |                      |
| OffsetAdjustment<br>DatOut                 |     | Clk_TimeAdjustment   |   | Calculated new       |
|                                            | out | <br>Type             | 1 | Offset between       |
|                                            |     |                      |   | Master and Slave     |
| OffsetAdjustment                           |     |                      | 1 | Calculated new       |
| _ValOut                                    | out | std_logic;           | 1 | Offset valid         |
| Drift Adjustment Outpu                     | it  |                      |   |                      |
| DriftAdjustment                            |     | Clly Time Adjustment |   | Calculated new Drift |
| _DatOut                                    | out | Clk_TimeAdjustment   | 1 | between Master and   |
|                                            |     | _Туре                |   | Slave                |
| DriftAdjustment                            |     |                      |   | Calculated new Drift |
| _ValOut                                    | out | std_logic;           | 1 | valid                |
| Offect Adjustment Innu                     | +   |                      |   | Valia                |
| Offset Adjustment Inpu<br>OffsetAdjustment | L   |                      |   | Calculated new       |
| _Datin                                     | ·   | Clk_TimeAdjustment   | 1 | Offset after the PI  |
|                                            | in  | _Type                | 1 |                      |
|                                            |     |                      |   | Servo loop           |
| OffsetAdjustment<br>_Valln                 |     |                      |   | Calculated new       |
|                                            | in  | std_logic;           | 1 | Offset after the PI  |
|                                            |     |                      |   | Servo loop valid     |
| Drift Adjustment Input                     | 1   |                      | 1 |                      |
| DriftAdjustment                            |     | Clk_TimeAdjustment   |   | Calculated new Drift |
| _DatIn                                     | in  |                      | 1 | after the PI Servo   |
|                                            |     | _Туре                |   | loop                 |
| DriftAdjustment                            |     |                      |   | Calculated new Drift |
| _Valln                                     | in  | std_logic            | 1 | after the PI Servo   |
|                                            |     |                      |   | loop valid           |
| I2C Control Interface                      |     |                      |   |                      |
| ReadWrite_DatOut                           | out | std logic            | 1 | '1': Write,          |
|                                            |     |                      |   | 'O': Read            |
| WriteData DatOut                           | out | std_logic_vector     | 8 | Write Data           |
| ReadData_DatIn                             | in  |                      | 8 | Read Data            |
|                                            |     | std_logic_vector     |   |                      |
| ChipAddress_AdrOut                         | out | std_logic_vector     | 7 | I2C 7 bit RTC        |
|                                            |     |                      |   | address              |
| RegAddress_AdrOut                          | out | std_logic_vector     | 8 | Register address     |
| AccessReq_ValOut                           | out | std_logic            | 1 | Request I2C access   |
|                                            |     | ~                    |   |                      |



| AccessAck_Valln | in  | std_logic | 1 | I2C Access granted  |
|-----------------|-----|-----------|---|---------------------|
| Access_ErrIn    | in  | std_logic | 1 | I2C error           |
| Access_ValOut   | out | std_logic | 1 | Do Access           |
| Access_ValIn    | in  | std_logic | 1 | Access done         |
| Enable Input    |     |           |   |                     |
|                 |     |           |   | Enables the reading |
| Enable_EnaIn    | in  | std_logic | 1 | of the RTC and      |
|                 |     |           |   | Clock adjustment    |

Table 15: Read Processor



### 4.2.4 Write Processor

### 4.2.4.1 Entity Block Diagram



Figure 15: Write Processor

#### 4.2.4.2 Entity Description

#### Write Processor

This module writes the time when the RTC PPS event is detected and a write time request is pending. At this event it starts to convert the time in seconds since midnight 1.1.1970 (TAI) into straight binary values in the time of day format. Then it encodes the straight binary values into BCD encoded values. After that it writes the BCD encoded values to the RTC by writing the years part first and writing all registers one by one until the seconds part.

This mechanism guarantees that the time is always valid when written and the RTC updates after the write, but on the other hand this also only allows to update the time once a second. When the time shall be written, an extra second shall be added to the time and the write command shall be also set before and aligned with the next RTC PPS event, this guarantees that the right second is written since RTC also updates its only once a second and a write to the individual registers shall not happen during an update cycle.

#### 4.2.4.3 Entity Declaration

| Name           | Dir | Туре               | Size | Description                                                                          |
|----------------|-----|--------------------|------|--------------------------------------------------------------------------------------|
|                |     | Generics           |      |                                                                                      |
| General        |     |                    |      |                                                                                      |
| RtcClockType   | -   | Rtc_ClockType_Type | 1    | DS1307_E or<br>MCP7941x_E are<br>supported to define<br>the type of RTC<br>connected |
| ClockClkPeriod | -   | natural            | 1    | Clock Period in                                                                      |



| Nanosecond_Gen                 |          |                             |    | Nanosecond                                                               |
|--------------------------------|----------|-----------------------------|----|--------------------------------------------------------------------------|
| Sim_Gen                        | -        | boolean                     | 1  | If in Testbench<br>simulation mode                                       |
| Write Processor                |          |                             |    |                                                                          |
| InputDelay<br>Nanosecond_Gen   | -        | natural                     | 1  | Input delay of the<br>PPS from the con-<br>nector to the input<br>signal |
|                                |          | Ports                       |    |                                                                          |
| System                         |          |                             | 1  |                                                                          |
| SysClk_ClkIn                   | in       | std_logic                   | 1  | System Clock                                                             |
| SysRstN_RstIn                  | in       | std_logic                   | 1  | System Reset                                                             |
| Timer<br>Timer1ms_EvtIn        | in       | std_logic                   | 1  | Millisecond timer<br>adjusted with the<br>Clock                          |
| Time Input                     |          |                             |    | Adjusted PTP Clock                                                       |
| ClockTime_DatIn                | in       | Clk_Time_Type               | 1  | Time                                                                     |
| ClockTime_Valln                | in       | std_logic                   | 1  | Adjusted PTP Clock<br>Time valid                                         |
| RTC Pulse Per Second F         | Polarity | /                           |    | 11': Lligh active                                                        |
| RtcPolarity_DatIn              | in       | std_logic                   | 10 | '1': High active,<br>'0': Low active                                     |
| RTC Pulse Per Second I         | nput     |                             |    |                                                                          |
| Rtc_EvtIn                      | in       | std_logic                   | 1  | PPS input                                                                |
| RTC Error Output<br>Rtc_ErrOut | out      | std_logic                   | 1  | Indicates an access<br>error                                             |
| RTC Write Time Input           | in       | Clk_Time_Type               | 1  | RTC Write Time                                                           |
| WriteTime_DatIn                |          |                             | 1  |                                                                          |
| WriteTime_Valln                | in       | std_logic                   | 1  | RTC Write Time<br>valid                                                  |
| RTC Time Adjustment I          | nput     |                             |    |                                                                          |
| TimeAdjustment<br>_DatIn       | in       | Clk_TimeAdjustment<br>_Type | 1  | Time to set hard                                                         |
| TimeAdjustment<br>_ValIn       | in       | std_logic                   | 1  | Time valid                                                               |
| I2C Control Interface          | <u></u>  |                             | 1  | $(1)$ $\Lambda/rito$                                                     |
| ReadWrite_DatOut               | out      | std_logic                   | 1  | '1': Write,<br>'0': Read                                                 |



| WriteData_DatOut   | out | std_logic_vector | 8 | Write Data                     |
|--------------------|-----|------------------|---|--------------------------------|
| ReadData_DatIn     | in  | std_logic_vector | 8 | Read Data                      |
| ChipAddress_AdrOut | out | std_logic_vector | 7 | I2C 7 bit RTC                  |
|                    |     |                  |   | address                        |
| RegAddress_AdrOut  | out | std_logic_vector | 8 | Register address               |
| AccessReq_ValOut   | out | std_logic        | 1 | Request I2C access             |
| AccessAck_Valln    | in  | std_logic        | 1 | I2C Access granted             |
| Access_ErrIn       | in  | std_logic        | 1 | I2C error                      |
| Access_ValOut      | out | std_logic        | 1 | Do Access                      |
| Access_ValIn       | in  | std_logic        | 1 | Access done                    |
| Enable Input       |     |                  |   |                                |
| Enable_Enaln       | in  | std_logic        | 1 | Enables the writing of the RTC |

Table 16: Write Processor



### 4.2.5 Registerset

### 4.2.5.1 Entity Block Diagram



Figure 16: Registerset

### 4.2.5.2 Entity Description

#### **Register Set**

This module is an AXI4Lite Memory Mapped Slave. It provides access to all registers and allows configuring the RTC Master Clock. AXI4Lite only supports 32 bit wide data access, no byte enables, no burst, no simultaneous read and writes and no unaligned access. It can be configured to either run in AXI or StaticConfig mode. If in StaticConfig mode, the configuration of the registers is done via signals and can be easily done from within the FPGA without CPU. For each parameter a valid signal is available, the enable signal shall be set last (or simultaneously). To change configuration parameters the clock has to be disabled and enabled again, the time can be changed at runtime. If in AXI mode, an AXI Master has to configure the registers with AXI writes to the registers, which is typically done by a CPU. Parameters can in this case also be changed at runtime.

For status supervision, similar to the static configuration the static status signals are available which allows to use the values also directly from within the FPGA without CPU.

| Dir | Туре     | Size     | Description                             |
|-----|----------|----------|-----------------------------------------|
|     | Generics |          |                                         |
|     |          |          |                                         |
| -   | boolean  | 1        | True: High active,<br>False: Low active |
| -   | boolean  | 1        | If Static Configura-                    |
|     |          | Generics | - boolean 1                             |

#### 4.2.5.3 Entity Declaration



|                                 |     |                                        |    | tion or AXI is used                          |
|---------------------------------|-----|----------------------------------------|----|----------------------------------------------|
| AxiAddressRange<br>Low_Gen      | -   | std_logic_vector                       | 32 | AXI Base Address                             |
| AxiAddressRange<br>High_Gen     | -   | std_logic_vector                       | 32 | AXI Base Address<br>plus Registerset<br>Size |
|                                 |     | Ports                                  |    |                                              |
| System<br>SysClk_ClkIn          | in  | std_logic                              | 1  | System Clock                                 |
| SysRstN_RstIn                   | in  | std_logic                              | 1  | System Reset                                 |
| Config                          |     |                                        |    |                                              |
| StaticConfig_DatIn              | in  | Rtc_Master<br>StaticConfig_Type        | 1  | Static Configuration                         |
| StaticConfig_ValIn              | in  | Rtc_Master<br>StaticConfigVal<br>_Type | 1  | Static Configuration<br>valid                |
| Status                          |     |                                        |    |                                              |
| StaticStatus_DatOut             | out | Rtc_Master<br>StaticStatus_Type        | 1  | Static Status                                |
| StaticStatus_ValOut             | out | Rtc_Master<br>StaticStatusVal<br>_Type | 1  | Static Status valid                          |
| AXI4 Lite Slave                 |     |                                        |    |                                              |
| AxiWriteAddrValid<br>Valln      | in  | std_logic                              | 1  | Write Address Valid                          |
| <br>AxiWriteAddrReady<br>RdyOut | out | std_logic                              | 1  | Write Address<br>Ready                       |
| AxiWriteAddrAddress<br>AdrIn    | in  | std_logic_vector                       | 32 | Write Address                                |
| AxiWriteAddrProt<br>_DatIn      | in  | std_logic_vector                       | 3  | Write Address<br>Protocol                    |
| AxiWriteDataValid<br>Valln      | in  | std_logic                              | 1  | Write Data Valid                             |
| AxiWriteDataReady<br>_RdyOut    | out | std_logic                              | 1  | Write Data Ready                             |
| AxiWriteDataData<br>DatIn       | in  | std_logic_vector                       | 32 | Write Data                                   |
| AxiWriteDataStrobe<br>DatIn     | in  | std_logic_vector                       | 4  | Write Data Strobe                            |
| AxiWriteRespValid<br>ValOut     | out | std_logic                              | 1  | Write Response<br>Valid                      |
| AxiWriteRespReady<br>_RdyIn     | in  | std_logic                              | 1  | Write Response<br>Ready                      |



| AxiWriteResp<br>Response_DatOut                                                                                                                                               | out                                   | std_logic_vector                                                | 2         | Write Response                                                                                                             |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|-----------------------------------------------------------------|-----------|----------------------------------------------------------------------------------------------------------------------------|--|--|
| AxiReadAddrValid<br>_Valln                                                                                                                                                    | in                                    | std_logic                                                       | 1         | Read Address Valid                                                                                                         |  |  |
| <br>AxiReadAddrReady<br>RdyOut                                                                                                                                                | out                                   | std_logic                                                       | 1         | Read Address<br>Ready                                                                                                      |  |  |
| AxiReadAddrAddress<br>_AdrIn                                                                                                                                                  | in                                    | std_logic_vector                                                | 32        | Read Address                                                                                                               |  |  |
| <br>AxiReadAddrProt<br>DatIn                                                                                                                                                  | in                                    | std_logic_vector                                                | 3         | Read Address<br>Protocol                                                                                                   |  |  |
| AxiReadDataValid<br>ValOut                                                                                                                                                    | out                                   | std_logic                                                       | 1         | Read Data Valid                                                                                                            |  |  |
|                                                                                                                                                                               | in                                    | std_logic                                                       | 1         | Read Data Ready                                                                                                            |  |  |
| AxiReadData<br>Response_DatOut                                                                                                                                                | out                                   | std_logic_vector                                                | 2         | Read Data                                                                                                                  |  |  |
| AxiReadDataData<br>_DatOut                                                                                                                                                    | out                                   | std_logic_vector                                                | 32        | Read Data Re-<br>sponse                                                                                                    |  |  |
| RTC Pulse Per Second Polarity                                                                                                                                                 |                                       |                                                                 |           |                                                                                                                            |  |  |
| RTC Pulse Per Second I                                                                                                                                                        | <u>Polarity</u>                       | <u>y</u>                                                        | -1        |                                                                                                                            |  |  |
| RtcPolarity_DatOut                                                                                                                                                            | out                                   | y<br>std_logic                                                  | 10        | '1': High active,<br>'O': Low active                                                                                       |  |  |
|                                                                                                                                                                               | out                                   |                                                                 | 10        | 'O': Low active                                                                                                            |  |  |
| RtcPolarity_DatOut<br>Pulse Per Second Error<br>Rtc_ErrIn                                                                                                                     | out                                   |                                                                 | 10        | -                                                                                                                          |  |  |
| RtcPolarity_DatOut<br>Pulse Per Second Error<br>Rtc_ErrIn<br>Read Time Input                                                                                                  | out<br>Input<br>in                    | std_logic<br>std_logic_vector                                   | 4         | 'O': Low active<br>Indicates a time<br>jump                                                                                |  |  |
| RtcPolarity_DatOut<br>Pulse Per Second Error<br>Rtc_ErrIn                                                                                                                     | out<br>Input                          | std_logic                                                       |           | 'O': Low active<br>Indicates a time<br>jump<br>RTC Read Time                                                               |  |  |
| RtcPolarity_DatOut<br>Pulse Per Second Error<br>Rtc_ErrIn<br>Read Time Input                                                                                                  | out<br>Input<br>in                    | std_logic<br>std_logic_vector                                   | 4         | 'O': Low active<br>Indicates a time<br>jump                                                                                |  |  |
| RtcPolarity_DatOut<br>Pulse Per Second Error<br>Rtc_ErrIn<br>Read Time Input<br>ReadTime_DatIn                                                                                | out<br>Input<br>in<br>in<br>in        | std_logic<br>std_logic_vector<br>Clk_Time_Type<br>std_logic     | 4         | 'O': Low active<br>Indicates a time<br>jump<br>RTC Read Time<br>RTC Read Time<br>valid                                     |  |  |
| RtcPolarity_DatOut<br>Pulse Per Second Error<br>Rtc_ErrIn<br>Read Time Input<br>ReadTime_DatIn<br>ReadTime_ValIn                                                              | out<br>Input<br>in<br>in              | std_logic<br>std_logic_vector<br>Clk_Time_Type                  | 4         | 'O': Low active<br>Indicates a time<br>jump<br>RTC Read Time<br>RTC Read Time                                              |  |  |
| RtcPolarity_DatOut<br>Pulse Per Second Error<br>Rtc_ErrIn<br>Read Time Input<br>ReadTime_DatIn<br>ReadTime_ValIn<br>Write Time Output<br>WriteTime_DatOut<br>WriteTime_ValOut | out<br>Input<br>in<br>in<br>in        | std_logic<br>std_logic_vector<br>Clk_Time_Type<br>std_logic     | 4         | 'O': Low active<br>Indicates a time<br>jump<br>RTC Read Time<br>RTC Read Time<br>valid                                     |  |  |
| RtcPolarity_DatOut<br>Pulse Per Second Error<br>Rtc_ErrIn<br>Read Time Input<br>ReadTime_DatIn<br>ReadTime_ValIn<br>Write Time Output<br>WriteTime_DatOut                     | out<br>Input<br>in<br>in<br>in<br>out | std_logic_vector<br>Clk_Time_Type<br>std_logic<br>Clk_Time_Type | 4 1 1 1 1 | 'O': Low active<br>Indicates a time<br>jump<br>RTC Read Time<br>RTC Read Time<br>valid<br>RTC Write Time<br>RTC Write Time |  |  |

Table 17: Registerset



## 4.3 Configuration example

In both cases the enabling of the core shall be done last, after or together with the configuration.

### 4.3.1 Static Configuration

```
constant RtcStaticConfigMaster_Con : Rtc_MasterStaticConfig_Type := (
                            => '1',
 Polarity
  WriteTime
                  => (
   Second
                   => x"12345678", -- seconds
   Nanosecond
                   => (others => '0'), -- no nanoseconds
                    => (others => '0'), -- no fractions
   Fraction
                    => '0', -- UTC correct in positive
   Sign
   TimeJump
                    => '0'),
);
constant RtcStaticConfigValMaster_Con : Rtc_MasterStaticConfigVal_Type := (
 Enable_Val => '1'
 WriteTime_Val
                               => '1'
);
```

Figure 17: Static Configuration

The time can be written at runtime.

### 4.3.2 AXI Configuration

The following code is a simplified pseudocode from the testbench: The base address of the RTC Master Clock is 0x10000000.

```
-- RTC MASTER

-- Config

-- enable RTC Master

AXI WRITE 10000000 00000001

-- write time

AXI AXIO WRITE 10000024 12345678

AXI AXIO WRITE 10000000 00000003
```

Figure 18: AXI Configuration

In the example the core is enabled and the time written.



## 4.4 Clocking and Reset Concept

### 4.4.1 Clocking

To keep the design as robust and simple as possible, the whole RTC Master Clock, including the Counter Clock and all other cores from NetTimeLogic are run in one clock domain. This is considered to be the system clock. Per default this clock is 50MHz. Where possible also the interfaces are run synchronous to this clock. For clock domain crossing asynchronous fifos with gray counters or message patterns with meta-stability flip-flops are used. Clock domain crossings for the AXI interface is moved from the AXI slave to the AXI interconnect.

| Clock         | Frequency | Description                            |
|---------------|-----------|----------------------------------------|
| System        |           |                                        |
| System Cleak  | 50MHz     | System clock where the RTC Master runs |
| System Clock  | (Default) | on as well as the counter clock etc.   |
| AXI Interface |           |                                        |
| AXI Clock     | 50MHz     | Internal AXI bus clock, same as the    |
| AATCIOCK      | (Default) | system clock                           |
| I2C Interface |           |                                        |
| I2C Clock     | 100kHz    | I2C clock generated out of the system  |
|               | (Default) | clock                                  |

Table 18: Clocks

#### 4.4.2Reset

In connection with the clocks, there is a reset signal for each clock domain. All resets are active low. All resets can be asynchronously set and shall be synchronously released with the corresponding clock domain. All resets shall be asserted for the first couple (around 8) clock cycles. All resets shall be set simultaneously and released simultaneously to avoid overflow conditions in the core. See the reference designs top file for an example of how the reset shall be handled.

| Reset        | Polarity   | Description                                                 |
|--------------|------------|-------------------------------------------------------------|
| System       |            |                                                             |
| System Reset | Active low | Asynchronous set, synchronous release with the system clock |



| AXI Interface |            |                                          |
|---------------|------------|------------------------------------------|
|               |            | Asynchronous set, synchronous release    |
| AXI Reset     | Active low | with the AXI clock, which is the same as |
|               |            | the system clock                         |

Table 19: Resets



# 5 Resource Usage

Since the FPGA Architecture between vendors and FPGA families differ there is a split up into the two major FPGA vendors.

# 5.1 Intel/Altera (Cyclone V)

| Configuration              | FFs  | LUTs | BRAMs | DSPs |
|----------------------------|------|------|-------|------|
| Minimal<br>(Static config) | 1830 | 5831 | 0     | 0    |
| Maximal<br>(AXI config)    | 1972 | 5943 | 0     | 0    |

Table 20:Resource Usage Intel/Altera

## 5.2 AMD/Xilinx (Artix 7)

| Configuration              | FFs  | LUTs | BRAMs | DSPs |
|----------------------------|------|------|-------|------|
| Minimal<br>(Static config) | 1789 | 6552 | 0     | 0    |
| Maximal<br>(AXI config)    | 1927 | 6713 | 0     | 0    |

Table 21:Resource Usage AMD/Xilinx



# 6 Delivery Structure

| AXI        | AXI library folder                              |
|------------|-------------------------------------------------|
| -Library   | AXI library component sources                   |
| -Package   | AXI library package sources                     |
|            |                                                 |
| CLK        | CLK library folder                              |
| -Library   | CLK library component sources                   |
| -Package   | CLK library package sources                     |
|            |                                                 |
| COMMON     | COMMON library folder                           |
| -Library   | COMMON library component sources                |
| -Package   | COMMON library package sources                  |
|            |                                                 |
| RTC        | RTC library folder                              |
| -Core      | RTC library cores                               |
| -Doc       | RTC library cores documentations                |
| -Library   | RTC library component sources                   |
| -Package   | RTC library package sources                     |
| -Refdesign | RTC library cores reference designs             |
| -Testbench | RTC library cores testbench sources and sim/log |
|            |                                                 |
| SIM        | SIM library folder                              |
| -Doc       | SIM library command documentation               |
| -Package   | SIM library package sources                     |
| -Testbench | SIM library testbench template sources          |
| -Tools     | SIM simulation tools                            |
|            |                                                 |



# 7 Testbench

The RTC Master testbench consist of 3 parse/port types: AXI, CLK and RTC. The RTC Slave port takes the time of the CLK port instance as initial reference, this can be overwritten by the ip core. The RTC Slave has an internal RTC shadow register set which the core can read and write via I2C. The RTC Slave port runs an internal clock which runs with the frequency of the CLK port and generates the RTC PPS event if enabled.

In addition for configuration and result checks an AXI read and write port is used in the testbench and for accessing more than one AXI slave also an AXI interconnect is required.



Figure 19: Testbench Framework

For more information on the testbench framework check the Sim\_ReferenceManual documentation.

With the Sim parameter set the time base for timeouts are divided by 1000 to 100000 to speed up simulation time.

## 7.1 Run Testbench

1. Run the general script first source XXX/SIM/Tools/source with args.tcl

#### 2. Start the testbench with all test cases

src XXX/RTC/Testbench/Core/RtcMaster/Script/run Rtc Master Tb.tcl



3. Check the log file LogFile1.txt in the XXX/RTC/Testbench/Core/RtcMaster/Log/ folder for simulation results.



## 8 Reference Designs

The RTC Master reference design contains a PLL to generate all necessary clocks (cores are run at 50 MHz), an instance of the RTC Master Clock IP core and an instance of the Adjustable Counter Clock IP core (needs to be purchased separately). The Reference Design is intended to be connected to a DS1307 or MCP7941x (or compatible) Real Time Clocks (RTC) which has an I2C interface, a 1Hz square wave output and a compatible register set of one of the RTC types supported. Optionally it also contains an instance of a PPS Master Clock IP core (has to be purchased separately). To instantiate the optional IP core, change the corresponding generic (PpsMasterAvailable\_Gen) to true via the tool specific wizards. The Reference Design is intended to run just standalone, show the instantiation and generate a PPS output. The PPS Master Clock is used to create a PPS output which is compensated for the output delay and has a configurable duty cycle, if not available an uncompensated PPS is directly generated out of the MSB of the Time. All generics can be adapted to the specific needs.



Figure 20: Reference Design

## 8.1 Intel/Altera: Terasic SocKit

The SocKit board is an FPGA board from Terasic Inc. with a Cyclone V SoC FPGA from Intel/Altera. (<u>http://www.terasic.com.tw/cgi-bin/page/archive.pl?Language=English&CategoryNo=205&No=816</u>)

- 1. Open Quartus 16.x
- 2. Open Project /RTC/Refdesign/Altera/SocKit/RtcMaster/RtcMaster.qpf
- 3. If the optional core PPS Master Clock is available add the files from the corresponding folders (PPS/Core, PPS/Library and PPS/Package)



- 4. Change the generics (PpsMasterAvailable\_Gen) in Quartus (in the settings menu, not in VHDL) to true for the optional cores that are available.
- 5. Rerun implementation
- 6. Download to FPGA via JTAG





For the ports on the HSMC connector the GPIO to HSMC adapter from Terasic Inc. was used.

## 8.2 AMD/Xilinx: Digilent Arty

The Arty board is an FPGA board from Digilent Inc. with an Artix7 FPGA from AMD/Xilinx. (<u>http://store.digilentinc.com/arty-board-artix-7-fpga-development-board-for-makers-and-hobbyists/</u>)

- Open Vivado 2019.1 Note: If a different Vivado version is used, see chapter 8.3.
- 2. Run TCL script /RTC/Refdesign/Xilinx/Arty/RtcMaster/RtcMaster.tcl
  - a. This has to be run only the first time and will create a new Vivado Project



- 3. If the project has been created before open the project and do not rerun the project TCL
- 4. If the optional core PPS Master Clock is available add the files from the corresponding folders (PPS/Core, PPS/Library and PPS/Package) to the corresponding Library (PpsLib).
- 5. Change the generics (PpsMasterAvailable\_Gen) in Vivado (in the settings menu, not in VHDL) to true for the optional cores that are available.
- 6. Rerun implementation
- 7. Download to FPGA via JTAG



Figure 22: Arty (source Digilent Inc)

### 8.2.1 RTC CLock

The RTC Clock used in the reference design is a PMOD RTC from Digilent Inc. (<u>http://store.digilentinc.com/pmod-rtcc-real-time-clock-calendar</u>) which can be directly connected to the PMOD JA on the Arty. The RTC PPS has to be connected via a cable from the pinheader of the PMOD RTC to the pin on the upper row of PMOD JA next to the SCL (See Figure 22: )

The RTC needs an additional battery to be able to update the time when the board is powered down.





Figure 23: PMOD RTC (source Digilent Inc)

### 8.3 AMD/Xilinx : Vivado version

The provided TCL script for creation of the reference-design project is targeting AMD/Xilinx Vivado 2019.1.

If a lower Vivado version is used, it is recommended to upgrade to Vivado 2019.1 or higher.

If a higher Vivado version is used, the following steps are recommended:

- Before executing the project creation TCL script, the script's references of Vivado 2019 should be manually replaced to the current Vivado version. For example, if version Vivado 2022 is used, then:
  - The statement occurrences:

set\_property flow "Vivado Synthesis 2019" \$obj
shall be replaced by:

set\_property flow "Vivado Synthesis 2022 \$obj

• The statement occurrences:

set\_property flow "Vivado Implementation 2019" \$obj
shall be replaced by:

set\_property flow "Vivado Implementation 2022" \$obj

- After executing the project creation TCL script, the AMD/Xilinx IP cores, such as the Clocking Wizard core, might be locked and a version upgrade might be required. To do so:
  - 1. At "Reports" menu, select "Report IP Status".
  - 2. At the opened "IP Status" window, select "Upgrade Selected". The tool will upgrade the version of the selected IP cores.



# A List of tables

| Table 1:  | Revision History               | 4  |
|-----------|--------------------------------|----|
| Table 2:  | Definitions                    | 7  |
| Table 3:  | Abbreviations                  | 7  |
| Table 4:  | Register Set Overview          | 16 |
| Table 5:  | Parameters                     | 27 |
| Table 6:  | Clk_Time_Type                  | 27 |
| Table 7:  | Clk_CoreInfo_Type              | 27 |
| Table 8:  | Rtc_MasterStaticConfig_Type    |    |
| Table 9:  | Rtc_MasterStaticConfigVal_Type |    |
| Table 10: | Rtc_MasterStaticConfig_Type    |    |
| Table 11: | Rtc_MasterStaticConfigVal_Type | 29 |
| Table 12: | RTC Master Clock               |    |
| Table 13: | I2C                            |    |
| Table 14: | Control Processor              |    |
| Table 15: | Read Processor                 | 44 |
| Table 16: | Write Processor                | 47 |
| Table 17: | Registerset                    | 50 |
| Table 18: | Clocks                         |    |
| Table 19: | Resets                         | 53 |
| Table 20: | Resource Usage Intel/Altera    | 54 |
| Table 21: | Resource Usage AMD/Xilinx      | 54 |
|           |                                |    |

# **B** List of figures

| Figure 1:  | Context Block Diagram      | 9  |
|------------|----------------------------|----|
| Figure 2:  | Architecture Block Diagram | 10 |
| Figure 3:  | I2C Waveform               |    |
| Figure 4:  | I2C Waveform               |    |
| Figure 5:  | I2C Write Access           |    |
| Figure 6:  | I2C Read Access            |    |
| Figure 7:  | RTC PPS Waveform           | 14 |
| Figure 8:  | RTC Registersets           | 14 |
| Figure 9:  | RTC Master Clock           |    |
| Figure 10: | I2C                        |    |
| Figure 11: | I2C Write Access           |    |
| Figure 12: | I2C Read Access            |    |



| Figure 13: | Control Processor              |    |
|------------|--------------------------------|----|
| Figure 14: | Read Processor                 | 41 |
| Figure 15: | Write Processor                | 45 |
| Figure 16: | Registerset                    |    |
| Figure 17: | Static Configuration           |    |
| Figure 18: | AXI Configuration              | 51 |
| Figure 19: | Testbench Framework            |    |
| Figure 20: | Reference Design               |    |
| Figure 21: | SocKit (source Terasic Inc)    |    |
| Figure 22: | Arty (source Digilent Inc)     | 60 |
| Figure 23: | PMOD RTC (source Digilent Inc) | 61 |