### **Application Note AN007** Using syn1588® Event I/Os #### Version 1.17.0 - October 2023 ## **Abstract** This application note describes the capabilities and configuration of the syn1588® event I/Os namely the Trigger output, the Period output, and the Event input. With the next release of the syn1588® Software Suite a completely new API will be available. This new API encapsulates all register access which will dramatically simplify using the Event/Trigger/Period functions. Thus, we strongly recommend new customers not to use the direct register access but wait for the new API. Please contact Oregano Systems' support for further information. # syn1588® Clock Structure The generation (Trigger/Period output) and capturing (Event input) of syn1588® I/Os is directly controlled by the highly accurate, synchronized syn1588® hardware clock. The syn1588® hardware clock is an adder based clock, whose increment is depending on the configured STEP value; basically the period of the syn1588® hardware clock. Please note that the nominal STEP value may not be chosen freely but has to defined with respect to capabilities of the hardware. E.g. the syn1588® PCIe NIC Revision 2 relies on a syn1588® clock frequency of 125 MHz (8 ns period). The clock frequency used in a syn1588® PCIe NIC can be verified by reading register 0x204 via the syn1588 utility as shown below; it returns the clock frequency in Hz. >0x204 0x07735940 In the example above, the register read out value corresponds to 125 MHz. This value may change with the firmware of the card. Figure 1 shows the graphical illustration of the syn1588<sup>®</sup> clock value being incremented as a function of the STEP value at every rising edge of the system clock. Figure 1 At every rising edge of the system clock, syn1588®clock increments with STEP value. # syn1588® Hardware The behaviour of the syn1588® hardware clock and their functions EVNT input, TRIGGER and PERIOD output are in general identical for all syn1588® hardware. Due to the limitations of board capabilities some restrictions will apply. The syn1588® PCle NIC and syn1588® VIP Evaluation Board Revision 3 will fully support the functions as described in this application note. For the syn1588® Dual NIC the two syn1588® hardware clock functions have to share the same four user I/Os of the PCle card. The user is responsible to assign each user I/O just to one function of any of the two syn1588® hardware clocks (associated with the two network interfaces). If one violates this sequence the assignment for interface 2 will supersede. Please check AN036 for details on the syn1588® Dual NIC GPIOs. Additionally all board related components like the jitter cleaner PLL are just available with interface 1 of the syn1588® Dual NIC. For the following examples a syn1588® PCle NIC is used. # Example: Manually configuring the syn1588® clock All values of the adder based clock are configured automatically using their respective start-up values whenever the syn1588® PTP Stack is invoked. However, both the step size and the start-up value of the clock can be configured manually as well as part of a custom initialization procedure. For example, to start the syn1588® clock with an absolute time of 12 sec and 10 ns together with a STEP value of 8 ns, the following registers need to be written. Please note that the appropriate clock period has to be used to configure the STEP size. Please note that these commands shall not be executed when the syn1588® PTP Stack is already running. Please note, that after changing the STEP value for some temporary experiments, the syn1588® PTP Stack has to be started with the additional option "-G" (clean-start), to restore the correct default STEP value. | • | Write SHDWSTEP_L[31:0] = 0 sub-ns | (Addr. 0x50) | |---|-----------------------------------|--------------| | • | Write SHDWSTEP_H[31:0] = 8 ns | (Addr. 0x54) | | • | Write SHDWTIME_NS[31:0] = 10 ns | (Addr. 0x84) | | • | Write SHDWTIME_SEC[31:0] = 12 sec | (Addr. 0x88) | - After writing the desired values to the SHDWSTEP and SHDWTIME registers they have to be loaded into the syn1588<sup>®</sup> clock synchronously. This is done by setting bit 0 of the TIMECTRL register which initiates the transfer of all values from the shadow registers to the actual clock registers. - Write TIMECTRL = 0x00000001 (Addr. 0x48). This will enable loading of the shadow registers above configured to the actual registers. As soon as the clock increment is set to a value greater than zero the syn1588® clock will start functioning. The syn1588 utility commands for this command script sequence is shown below. ``` >0x050 0x0 >0x054 0x00000800 >0x084 0x0000000A >0x088 0x0000000C >0x048 0x00000001 ``` Please refer to the syn1588® Register Map Application Note (AN001, Version 1.60 - April 2021) for a detailed description of the IEEE 1588 register layout and for details of all the registers. # syn1588® Event I/O s This section presents the example scenarios of generation and capturing of the syn1588® events. Please note, that for all examples it is assumed: if the syn1588® PCle NIC with the syn1588® PTP Stack running is in slave mode it is already synchronized to the master. ### **Example: Generate a Trigger Output** In this example we will generate a Trigger, i.e. a single event at a given precise time in the future. Typically there are two Trigger outputs available that may be independently controlled: Trigger0 and Trigger1. Trigger0 is a FIFO based implementation that allows generation of densely packed events. Trigger0 allows generation of up to 16 Trigger events. Trigger1 is a register based implementation that allows generation of a single Trigger event. The following steps describe the actions needed for the generation of a single Trigger event on Trigger0 at an absolute time of 11 sec, 10 ns with an output state '1'. - The syn1588® hardware clock needs to be initialized with the required STEP value as described in the above example. Alternatively one may synchronize the card to an external Grandmaster using the syn1588® PTP Stack. In this case the syn1588® PTP Stack will manage STEP and TIME registers. - The desired time in future where the Trigger event shall be generated and also the desired output state of the Trigger event has to be written to the corresponding TRIGTIMEO\_L/TRIGTIMEO\_H registers. - Write EventCTRL = 0x00000004, which enables the Trigger0 function. - Write TRIGTIME0\_L[31:0] = 10 ns - Write TRIGTIME0\_H[19:0] = 11 sec and TRIGTIME0\_H[21:20] = "01" to select the Trigger output state '1' - Always write to the lower register first. The syn1588 utility commands for this command sequence is shown below. ``` >0x084 0x0000000A >0x088 0x0000000A >0x048 0x80000000 >0x04C 0x00000004 >0x0D0 0x0000000A >0x0D4 0x0010000B ``` Please note that the appropriate clock period has to be used to configure the STEP size. Please further note, that this example also contains the commands to set the time, which is not recommended when the syn1588® PTP Stack is running. After writing to the above said registers, the Trigger changes its output state to '1' precisely at the point in time when the value of the clock reached the value configured in TRIGTIME. Firing of the Trigger output will happen only when the local TIME of the syn1588® hardware clock is greater than or equal to the configured TRIGTIME. Due to the architecture of the syn1588® hardware clock as seen from Figure 1, the next local TIME of the syn1588® hardware clock will be incremented by the STEP value. Hence, the Trigger event may not exactly happen at the configured TRIGTIME but it may take an additional clock cycle and therefore happen in the time interval "TRIGTIME" and "TRIGTIME + STEP". Figure 2 illustrates that if T0 is the configured TRIGTIME, T1 is the actual time when the Trigger is fired. Figure 2 Trigger output after the TRIGTIME elapsed. The Trigger output is set to '1' in this case. To is the configured TRIGTIME and T1 is the actual time when the Trigger is fired. Please note that the example given above assumes that the previous state of the Trigger output had been '0'. If it would have been already '1' no state transition will occur on the Trigger output signal. One may choose to set the Trigger output signal on a Trigger event to '0', to '1' or to toggle it's state. ## **Example: Generate a Period Output** In this example we will generate a Period signal with a configured PERIODTIME. Typically there are two Period outputs available that may be independently controlled: Period0 and Period1. It is possible to generate a purely static value on the Period signal as well as a standard (i.e. 50% duty cycle) Period signal. This functionality is identical for both Period0 and Period1. In addition to this, it is possible to generate a Period0 signal with a programmable duty cycle. This functionality is available only for the Period0 signal. In this case, Period1 signal is disabled and cannot be used, because both the PERIODTIMEX\_L/PERIODTIMEX\_H registers of Period0 and Period1 are used to configure the frequency as well as the duty cycle for Period0 signal. An alternative method to configure the period outputs, is to use the syn1588 utility (for the syn1588® PCle NIC) with the "frequency" command. Note, that the maximum allowed frequency of the period output is dependent on the clock frequency. The minimal half-period time is 4.5 clock periods. This results in a maximal frequency of the period output of clock\_frequency/9. The following steps describe the actions needed for the generation of a Period0 signal with a period of 1000 us and with an initial value '1', starting immediately. - The syn1588® hardware clock is assumed to be already initialized with the required STEP value as shown in the first example. Again the syn1588® PTP Stack may be used to control the operation of the syn1588® hardware clock. - The desired half-period time has to be written into the PeriodTIME0\_L/PeriodTIME0\_H registers. Thus the generated Period0 signal contains a time period equal to 2\*PERIODTIME configured. - Write PERIODTIMEO\_L[31:0] = 0xA1200000 - Write PERIODTIMEO\_H[31:0] = 0x00000007 - Always write to the lower register first. - Write EVENTCTRL = 0x00000150, which enables the Period0 function, enables the Period0 output and also sets the initial value to '1'. The syn1588 utility commands for this command sequence is shown below. If the Period0 is already running, it has to be stopped first by first clearing bit 4 of the EVENTCTRL register. Afterwards the period0 output has to be set to zero by clearing bit 9, so there can be seen a transition at the start-time. ``` >0x0F0 0xA1200000 >0x0F4 0x00000007 >0x04C 0x00000150 ``` After writing to the above said registers, the Period0 signal starts with ON state. After the configured PERIODTIME elapses, the Period0 signal switches to the OFF state. Due to the architecture of the syn1588® hardware clock, the actual switching of the Period output signal will be in the time interval "PERIODTIME" and "PERIODTIME + STEP", similar to that of the Trigger function explained in the example above. Please note that this uncertainty is limited to a single edge on the output signal. The next occurrence of the next edge is computed using the accurate time. This uncertainty will not (!) be accumulated thus is will not affect the precise value of the frequency. Figure 3 illustrates this example. Figure 3 The relation between the actual PERIOD and the configured PERIODTIME is depicted in this figure. ### **Example: Capture an Event Input** In this example we will capture an Event and read the EVENTTIME registers. Typically there are two Event inputs available that may be controlled independently: Event0 and Event1. Event0 is a FIFO based implementation that allows capturing densely packed events. It allows to capture up to 16 events at a time without the need to access the Event0 register. Event1 is a register based implementation that allows to capture a single event. An Event input is captured whenever a rising edge of the event input signal occurs. Also the timestamp is drawn after a three stage synchronization of the event input signal. Figure 4 Capturing of the Event input after a three-stage synchronization and the uncertainty involved while drawing the corresponding Event timestamp (EVENTTIME) is shown in this figure. As seen from Figure 4, event\_i is the Event input and sync\_event is the synchronized Event input. EVENTTIME is recorded at 3<sup>rd</sup> or 4<sup>th</sup> occurrence of the system clock, due to the uncertainty of the synchronizer stage. Therefore, on average, a delay of 2.5\*(STEP) is added to the EVENTTIME (with STEP as the syn1588® clock period). Also, in order to effectively monitor the rising edge of the Event input, both edges of the system clock may be used to sample the Event input in the design. Therefore, in the case where the Event input is detected on the negative edge of the system clock, an additional half period time of the system clock is added to the timestamp drawn. Hence, ``` EVENTTIME = Expected TIME + 2.5* (syn1588® clock period) \pm (Half of system clock period) ``` The following steps describe the actions needed to capture the Event0 input. - The syn1588® hardware clock is assumed to be already initialized with the required STEP value. The syn1588® PTP Stack may be used to control the operation of the syn1588® hardware clock. - The EVENTCTRL register needed to be configured to enable the Event0 function. - Write EVENTCTRL = 0x00000001, to enable the Event0 function. The syn1588 utility commands for starting the syn1588® clock and to writing the above said registers is shown below. ``` >0x04C 0x0000001 ``` The syn1588 utility commands for reading the EventTIMEO\_L/H registers is shown below. ``` >0x0A4 0x00000000 >0x0A8 0x00000000 ``` At the expected time of the Event input rising edge, start reading EVENTTIMEO\_L/H registers to get the first EVENTTIME. As Event0 is capable to store dense events, 16 entries can be stored. As explained above, the read out values of the EVENTTIME will have an additional delay. Read out the Event0 FIFO until it is empty, so that next set of events can be stored. In order to determine, if the Event0 FIFO has become empty, read out the EVENTTIME0\_L/H registers until a 0x0 value pair is read. Always access the lower register first. ## Example: Enable Period with a Trigger In this example we will enable a Period signal while firing a Trigger event. This allows starting the generation of a periodical signal at an exact time (simultaneously on all nodes in the network). In addition to starting the Period signal independently, one can also start it with the Trigger event. In case of continuous Trigger output changes (in case of Trigger 0 for example), the Period function will continue to operate independently of the Trigger as soon as the very first Trigger condition is met. The following steps describe the actions needed to enable the Period0 signal with a time period of 1000 us, when the Trigger0 is fired at an absolute time of 11 sec and 10 ns. - The syn1588® hardware clock is assumed to be initialized already with the required STEP value, but the absolute time is set in this example. The syn1588® PTP Stack may be used to control the operation of the syn1588® hardware clock. - The desired half-period time has to be written into the PERIODTIMEO\_L/PeriodTIMEO\_H registers. Thus the generated Period0 signal contains a time period equal to 2\*PERIODTIME configured. - Write PERIODTIMEO\_L[31:0] = 0xA1200000 - Write PERIODTIMEO\_H[31:0] = 0x00000007 - Always write to the lower register first. - Before writing the Trigger Time, enable Trigger 0 in the EVENTCTRL register - The desired time in the future where the Trigger event shall be generated as well as the desired output state of the Trigger event has to be written to the corresponding TRIGTIMEO\_L/TRIGTIMEO\_H registers. - Write TRIGTIMEO L[31:0] = 10 ns - Write TRIGTIMEO\_H[19:0] = 11 sec and TRIGTIMEO\_H[21:20] = "00" to select the Trigger output state '0'. - Always write to the lower register first. - Write EVENTCTRL = 0x00018054, which enables Trigger0, sets Trigger0 output state to '0', enables Period0 function, enables Period0 output, sets initial value of Period0 to '0' and starts Period0 function when Trigger0 is fired. The syn1588 utility commands for starting the syn1588® clock and to writing the above said registers is shown below. Please note that the appropriate clock period has to be used to configure the STEP size. Please further note, that this example also contains the commands to set the time, which is not recommended when the syn1588®PTP Stack is running. ``` >0x084 0x0000000A >0x088 0x0000000A >0x048 0x80000000 >0x0F0 0xA1200000 >0x0F4 0x00000007 >0x04C 0x00000004 >0x0D0 0x0000000A >0x0D4 0x0000000B >0x04C 0x00018054 ``` Figure 5 shows that the Period function is enabled as soon as the Trigger condition is met. It can be seen that if TRIGTIME is the configured time, at time instant T1, the Trigger is fired and the value of Period output is '0' as defined by the initial value configured in EVENTCTRL register. At time instant T2 = T1 + PT (range(PERIODTIME, (PERIODTIME + STEP))), the Period output is changed to '1'. Similarly, if the Period function is still enabled, the Period output toggles at the next time instant within the interval "PERIODTIME – 0" to "PERIODTIME + STEP" as shown in the figure below. As explained before, the uncertainty will not (!) be accumulated. Figure 5 Firing of Trigger condition enables the Period function. The relation of the time between the Trigger and Period events is depicted in the figure. In this figure, the initial value of the Period output is configured as '0'. ### **Example: Loopback Trigger/Period to Event** In this example, we will enable a Period with a Trigger and then loopback the Period output to the Event input. Enabling the Period output with Trigger has already been explained in the example above. With the help of the IOMATRIX control register, one can loopback the Trigger or Period output signals to the Event input so that the required EVENTTIME can be captured. The following steps describe the actions needed to enable the Period0 signal with a time period of 1000 us, when the Trigger0 is fired at an absolute time of 20 sec and 10 ns and also to loopback the Period0 signal to the Event input and finally read the EVENTTIME registers. - The syn1588® hardware clock is assumed to be initialized already with the required STEP value, but the absolute time is set in this example. The syn1588® PTP Stack may be used to control the operation of the syn1588® hardware clock. - The desired half-period time has to be written into the PERIODTIMEO\_L/PERIODTIMEO\_H registers. Thus the generated Period0 signal contains a time period equal to 2\*PERIODTIME configured. - Write PERIODTIMEO\_L[31:0] = 0xA1200000 - Write PERIODTIMEO\_H[31:0] = 0x00000007 - Always write to the lower register first. - In order to loopback the Period0 to Event0, one has to write to the IOMATRIX control register. The default value of the register is 0x00430059. - Since we are interested only in the pins driving the Event input, we leave the remaining bits as they are and set only the required bits of the IOMATRIX register. - Write IOMATRIX control register = 0x00450059, which loops back the Period0 output to the Event0 input. - Before writing the Trigger Time, enable Trigger 0 in the EVENTCTRL register - The desired time in future where the Trigger event shall be generated and also the desired output state of the Trigger event has to be written to the corresponding TRIGTIMEO\_L/TRIGTIMEO\_H registers. - Write TRIGTIME0\_L[31:0] = 10 ns - Write TRIGTIMEO\_H[19:0] = 20 sec and TRIGTIMEO\_H[21:20] = "00" to select the Trigger output state '0' - Always write to lower register first. Write EVENTCTRL = 0x00018055, which enables Event0 function, enables Trigger0 function, sets Trigger0 output state to '0', enables Period0 function, enables Period0 output, sets initial value of Period0 to '0' and starts Period0 function when Trigger0 is fired. The syn1588 utility commands for starting the syn1588® clock and to writing the above said registers is shown below. Please note that the appropriate clock period has to be used to configure the STEP size. Please further note, that this example also contains the commands to set the time, which is not recommended when the syn1588® PTP Stack is running. ``` >0x084 0x0000000A >0x088 0x0000000A >0x048 0x80000000 >0x0F0 0xA1200000 >0x0F4 0x00000007 >0x200 0x00450059 >0x04C 0x00000004 >0x0D0 0x0000000A >0x0D4 0x00000014 >0x0D4 0x0000014 ``` The syn1588 utility commands for reading the TIME registers and EVENTTIMEO\_L/H registers of the syn1588® hardware clock are shown below ``` >time 9833,055784110 >0x0A4 0x00000000 >0x0A8 0x00000000 ``` As shown in the script above 'time' command returns the current TIME of the syn1588® hardware clock with the notation "seconds, nanoseconds". By reading the current 'time', we can determine if the expected time has elapsed and then read the EventTIME0 registers 0x0A4 and 0x0A8 to get the timestamp of the captured Event. Always access the lower register first. In this example, we have initialized the syn1588® hardware clock with an absolute time of 10 sec and 10 ns. And, the Trigger0 is configured with a TRIGTIME of 20 sec and 10 ns. This means that, the Trigger0 fires and starts the Period0 function at 20 sec and 10 ns with an uncertainty of "0 to STEP" value. But, the initial value of the Period0 is configured as '0', which means that in order to detect a rising edge on the Event input, it needs an additional time of PERIODTIME plus an uncertainty of "0 to STEP" value. Also the 3-stage synchronizer adds a delay of $2.5*(\text{syn1588}^{\$} \text{ clock period}) \pm (\text{half of system clock period}).$ Therefore, in this example the first EVENTTIME captured will be range((TRIGTIME - 0), (TRIGTIME + STEP)) + range((PERIODTIME - 0), (PERIODTIME + STEP)) + 2.5\*(syn1588® clock period) ± (Half of system clock period) = range([20 sec, 10 ns], [20 sec, 20 ns]) + range([500 us -0], [500 us + 10 ns]) + $[2.5*(10 \text{ ns}) \pm (5 \text{ ns})]$ . Figure 6 illustrates the sequence of events in this example along with the calculation involved. Figure 6 The figure depicts that the Period signal is started with the Trigger and is looped back to the Event input. The Event input follows the Period output, while the synchronized Event input has a delay equal to that of the 3-stage synchronizer. ### Example: Generate Period0 with programmable duty cycle In this example, we will generate Period0 signal with a programmable duty cycle. When we use the programmable duty cycle function for Period0, Period1 function is not available anymore, as both the PERIODTIMEX\_L/H registers of Period0 and Period1 are used to generate a configurable ON/OFF time for Period0 signal. Always, the first transition of the Period0 signal is determined by the PERIODTIME0\_L/H register pair while the next transition is determined by the PERIODTIME1\_L/H register pair. This sequence is repeated. If the initial state of the Period0 signal is configured as '0', the OFF cycle starts first. Therefore in this case, the PERIODTIME0\_L/H register pair define the OFF time while the PERIOTIME1\_L/H register pair define the ON time. Similarly, if the initial state of the Period0 signal is configured as '1', it means that the ON cycle starts first. Therefore in this case, the PERIODTIME0\_L/H register pair defines the ON time while the PERIODTIME1\_L/H register pair defines the OFF time. The following steps describe the actions needed to generate the Period0 signal with an ON time of 500 us and OFF time of 600 us. - The syn1588® hardware clock is assumed to be initialized already with the required STEP value. The syn1588® PTP Stack may be used to control the operation of the syn1588® hardware clock. - The ON time of 500 us has to be written to the PERIODTIMEO\_L and PERIODTIMEO\_H registers. - Write PERIODTIMEO L[31:0] = 0xA1200000 - Write PERIODTIMEO\_H[31:0] = 0x000000007 - Always write to the lower register first. - Similarly the OFF time of 600 us has to be written to the PERIODTIME1\_L and PERIODTIME1\_H registers. - Write PERIODTIME1\_L[31:0] = 0x27C00000 - Write PERIODTIME1\_H[31:0] = 0x00000009 - Always write to the lower register first. - Write EVENTCTRL = 0x00002150, which enables the Period0 function, enables the Period0 output, sets the initial value to '1' and enables the duty cycle function for Period0. The syn1588 utility commands for starting the syn1588® clock and to writing the above said registers is shown below. ``` >>0x0F0 0xA1200000 >0x0F4 0x00000007 >0x100 0x27C00000 >0x104 0x00000009 >0x04C 0x00002150 ``` After writing to the above said registers, the Period0 function starts with an ON cycle as the initial state is configured to '1'. Hence in this case, the time defined by the PERIODTIMEO\_L/H register pair corresponds to the ON time. After the ON time elapses with an additional uncertainty value between "0 to STEP" value, the OFF cycle starts whose duration is equal to the value defined by PERIODTIME1\_L/H register pair plus an uncertainty value between "0 to STEP" value. Figure 7 illustrates this example. Also, the figure shows the situation when the initial state of the Period0 signal is configured as '0'. Figure 7 The figure depicts the programmable duty cycle of the Period0 signal. It can be observed that, the time defined by PERIODTIME0\_L/H and PERIODTIME1\_L/H registers can become ON time or OFF time of the signal depending on the configured initial state of the Period0 signal. # **Register Overview** The following is an excerpt of the syn1588® register map described in the application note "an\_register\_map.pdf", showing all registers mentioned in this application note. | Address | Name | Function | Mode | |---------|---------------|------------------------------------------------------------------------------------|------| | 0x040 | IRSRC | Interrupt source | R/W | | 0x044 | IREN | Enables various interrupts | R/W | | 0x048 | TIMECTRL | Controls operation of the local clock | R/W | | 0x04C | EVENTCTRL | Control of events | R/W | | 0x050 | SHDWSTEP_L | Preload of new step size, lower 32 bit | R/W | | 0x054 | SHDWSTEP_H | Preload of new step size, upper 32 bit | R/W | | 0x084 | SHDWTIME_NS | Preload of new time of the clock, nanoseconds 32 bit | W | | 0x088 | SHDWTIME_SEC | Preload of new time of the clock, seconds 32 bit | W | | 0x0A4 | EVENTTIME0_L | Time of last event 0, low 32 bit | R | | 0x0A8 | EVENTTIMEO_H | Time of last event 0, upper 32 bit | R | | 0x0B0 | EVENTTIME1_L | Time of last event 1, low 32 bit | R | | 0x0B4 | EVENTTIME1_H | Time of last event 1, upper 32 bit | R | | 0x0B8 | FRAC_NUM | Numerator of fractional divider for precision period | R/W | | 0x0BC | FRAC_DENUM | Denumerator of fractional divider for precision period | R/W | | 0x0D0 | TRIGTIME0_L | Time to trigger event 0, first 32 bit | R/W | | 0x0D4 | TRIGTIME0_H | Time to trigger event 0, upper 32 bit | R/W | | 0x0D8 | TRIGTIME1_L | Time to trigger event 1, first 32 bit | R/W | | 0x0DC | TRIGTIME1_H | Time to trigger event 1, upper 32 bit | R/W | | 0x0F0 | PERIODTIMEO_L | Period of timer 0, lower 32 bit | R/W | | 0x0F4 | PERIODTIMEO_H | Period of timer 0, upper 32 bit | R/W | | 0x100 | PERIODTIME1_L | Period of timer 1, lower 32 bit | R/W | | 0x104 | PERIODTIME1_H | Period of timer 1, upper 32 bit | R/W | | 0x200 | IOMATRIX | External IO Interconnection definition (Not located in the syn1588® Clock IP core) | R/W | # **Connecting External Signals** Please carefully check the syn1588® NIC's datasheet prior connecting external signals to the SMA connectors. The datasheet specifies the ratings of all interfaces. One must not directly connect $5\,V$ or standard TTL signals to the SMA connectors of any syn1588® NIC! We suggest to use an attenuator in such a case. For attaching $5\,V$ signals we recommend a 6dB attenuator like this example: https://www.mouser.com/ProductDetail/Cinch-Connectivity-Solutions/27-9300-6?qs=CNbePw1FdJk6WqmW%252BhJrpA%3D%3D Franzosengraben 8 A-1030 Vienna Austria http://oregano.at contact@oregano.at Copyright © 2023 Oregano Systems - Design & Consulting GmbH ALL RIGHTS RESERVED. Oregano Systems does not assume any liability arising out of the application or use of any product described or shown herein nor does it convey any license under its patents, copyrights, or any rights of others. Licenses or any other rights such as, but not limited to, patents, utility models, trademarks or tradenames, are neither granted nor conveyed by this document, nor does this document constitute any obligation of the disclosing party to grant or convey such rights to the receiving party. Oregano Systems reserves the right to make changes, at any time without notice, in order to improve reliability, function or design. Oregano Systems will not assume responsibility for the use of any circuitry described herein. All trademarks used in this document are the property of their respective owners.