## Handshake signaling for data transfer

Oprițoiu Flavius flavius.opritoiu@cs.upt.ro

September 18, 2023

### Introduction

## Objectives:

Use handshake signaling for reliable data exchange between digital components

## For reading:

• Chris Fletcher: "EECS150: Interfaces: "FIFO" (a.k.a. Ready/Valid)", [Flet09c]

Handshake signaling permits rate adaption for the case of data transfers. For brevity, consider the case of two sequentially, synchronous components, exchanging data. One component is said to produce data (the producer) and the other is said to consume data (the consumer). The two are exchanging data in packets, using a common data bus.



## Adjusting transfer rate

If the producer can generate one data packet each clock cycle and the consumer is capable of processing it in the same clock cycle no handshake signaling is needed.

If the producer cannot generate packets at the rate the consumer can process them, a signal *valid* is added to producer, as an output, asserted when a new packet was put on the common data lines. The situation is depicted in the figure bellow:



Consumer polls, each clock cycle, producer's *valid* output and, if asserted, retrieves the packet for further processing. If *valid* is not active consumer waits its assertion.



<sup>(</sup>c) 2023 Oprițoiu Flavius. All Rights Reserved.

# Adjusting transfer rate (contd.)

If the consumer cannot process packets at the rate the producer generates them, an output signal, *ready*, is added to consumer, asserted when new data can be received. The situation is depicted in the figure bellow:



Producer puts the current packet on the data lines. It then polls the *ready* line and, if asserted, continues with generating the next packet, otherwise keeps the current packet on the data lines. The timing diagram bellow exemplifies the transfer:



# Handshake signaling

If both producer's generating new data and consumer's processing current packet require additional time, a valid/ready handshake protocol can be used. The *valid* and *ready* signals operates as described in the previous 2 slides. This interface is depicted bellow:



The interface is known also as FIFO interface, or "Ready/Valid" interface. Data transfer takes place on the rising edge of the clock cycle, when both *valid* and *ready* signals are asserted.



<sup>© 2023</sup> Opriţoiu Flavius. All Rights Reserved.

## Solved problem

Control unit for the input preprocessing module of a cryptographic application

The input preprocessing unit (IPU, or simply the unit) of a Secure Hash Algorithm 2 (SHA-2) unit receives 64-bit packets of the message and assembles and delivers them, in 512-bit blocks, to the hash engine [FIPS15]. After receiving the complete message, the unit pads it and append message's size. The unit's data flow is depicted in the figure below. In either perspective, one component produces data and another one consumes it.



The packet processing perspective

For brevity, no handshake signaling is used in communication with the *message deliverer*. After activation of the reset signal,  $rst_{-}b$ , in each clock cycle, a new packet is delivered to the unit. The last packet of the message is marked by the deliverer by activating its  $lst_{-}pkt$  output.

The unit reads and stores a new packet in each clock cycle, delivering to the *hash engine*, a new block once every 16 cycles. After receiving the last packet (asserted *lst\_pkt*) the unit adds one padding packet and, depending on the length of the message, it appends 0, 1 or more zero packets. In the last block deliver at its output, the unit append in the least significant 64 bits the length in bits of the message.

The block processing perspective

For communicating with the hash engine, a *valid* signal is used, *blk\_val* asserted by the unit when a new block is available at its output. When delivering, the last block, along activation of *blk\_val*, the unit asserts another output, *msg\_end* marking completion of message transmission.

Control unit of the input preprocessing module:

- implements SHA-2's preprocessing phase
- manages unit's datapath
- evaluate signals from the message deliverer
- signal specific conditions to the hash engine

### SHA-2 input preprocessing algorithm

```
1: procedure DeliverMessage
2:
       MessageLength \leftarrow 0

    ⊳ set message size to 0

3.
       index \leftarrow 0
                                              ▷ set current register file index to 0
4.
      loop
5:
          RegisterFile[index] = packet
                                            > store received packet in register file
          index \leftarrow (index + 1) \mod 2^3
6:
                                                   ▷ increment register file index
7:
          MessageLength \leftarrow MessageLength + 64
                                                      ▷ increment message's size
8:
          if index == 0 then signal new block
9:
          if lst\_pkt == 1 then
                                                        10:
             ▷ 1 followed by 63 of 0s
             index \leftarrow (index + 1) \mod 2^3
11:
12.
             while index \neq 7 do \triangleright when index is 7, append message size packet
13:
                if index == 0 then signal new block
14.

    □ all-zero packet

                index \leftarrow (index + 1) \mod 2^3
15
16:
             end while
17.
             RegisterFile[index] = MessageLength
                                                          ▷ message size packet
             signal new block
18:
19:
             signal message end
                                           20.
             break
                                                       ▷ leave transmission loop
21:
       end loop
22: end procedure
```

<sup>© 2023</sup> Opritoiu Flavius. All Rights Reserved.

Control path of the unit

The signals used by the control path to manage the datapath:

- $c_{-}up$ : increments the counter storing register file's index
- clr. clears the register storing the message size and the counter storing register file's index
- mgln\_pkt: appends the message length packet
- pad\_pkt: appends a padding packet
- st\_pkt: stores the current packet in the register file
- zero\_pkt: appends a zero packet

The control path takes the register file's current index, idx, as input.

Unit's interface with message deliverer and hash engine

Unit's interface signals with the message deliverer:

- lst\_pkt (input): asserted when receiving the final packet
- pkt (64-bit input): current message packet

Unit's interface signals with the hash engine:

- blk (512-bit output): the current block
- blk\_val (output): asserted when a new block is available
- msg\_end (output): asserted when delivering the final block

### Control unit's transition diagram



Control unit's transition diagram

Preprocessing module's control unit is defined as a Mealy Finite State Machine (FSM).

#### Internal states:

- START: initial state, reached after activation of rst\_b
- RX\_PKT: receive a new packet until lst\_pkt is asserted
- PAD: append a padding packet
- ZERO: append a zero packet
- MGLN: append message length packet
- MSG\_END: announce the end of message transmission
- STOP: final state; no output is activated

## References

- [Flet09c] C. Fletcher. EECS150: Interfaces: "FIFO" (a.k.a. Ready/Valid). [Online]. Available: https: //inst.eecs.berkeley.edu/ $\sim$ cs150/Documents/Interfaces.pdf (Last accessed 25/10/2017).
- [FIPS15] National Institute of Standards and Technology, "FIPS PUB 180-4: Secure Hash Standard," Gaithersburg, MD 20899-8900, USA, Tech. Rep., Aug. 2015. [Online]. Available: http://dx.doi.org/10.6028/NIST.FIPS.180-4 (Last accessed 06/04/2016).