## The Pseudo Dual-Edge D-Flipflop

# Ralf Hildebrandt *Dresden, Germany*

Dresden, Germany Ralf-Hildebrandt@gmx.de



Fig. 1. FM0 encoding; initial state determines waveform

```
process (reset, clock)
begin

if (reset='1') then

--- reset

elsif rising_edge(clock) then

--- synchronous behavior

elsif falling_edge(clock) then

--- synchronous behavior

end if;
end process;
```

Listing 1. not synthesizable dual-edge behavior in VHDL

Abstract—Although only one edge of the clock should always be used, sometimes it would be convenient to use both edges. This paper<sup>1</sup> describes the fully synthesizable pseudo dual-edge D-flipflop.

### I. INTRODUCTION

One important design rule is to use only one edge of the clock signal. Although this is a good design practice in some special cases it might be helpful to use both edges.

One example is low-power signal processing, where all state machines should run at the symbol frequency to avoid unnecessary switching. But the signal frequency might be higher than the symbol frequency. FMO encoding (fig. 1) is an example. With FMO encoding always the signal switches at the begin of every symbol. Another signal switch is done in the middle of the symbol, if zero has to be transmitted. If a transmitter wants so send a FMO encoded data stream and runs only at the symbol frequency, the output signal has to be switched with the rising edge of clock and additionally with the falling edge, if zero is transmitted.

Another example for dual-edge behavior are clock dividers. For odd divisors the divided clock signal has to be switched at the falling edge of the fast clock, to get the same length for the low and the high period.

## II. THE PROBLEM

There are two problems if dual-edge behvaior is desired:



Fig. 2. Pseudo Dual-Edge D-Flipflop (pde\_dff)

- 1) Most cell libraries do not provide a dual-edge flipflops.
- 2) In VHDL dual-edge behavior can be described as shown in listing 1, but most synthesis tools do **not** support this. Only few are capable of handling such a description. Therefore we need another way to model dual-edge behavior.

### III. THE PSEUDO DUAL-EDGE D-FLIPFLOP

Although dual-edge behavior is not supported by VHDL, synthesis and the cell libraries, a dual-edge flipflop can be described as shown in fig. 2. Note that synthesis tools will transform the multiplexers into XOR gates.

The pde\_dff consists of 2 cross-coupled flipflops, one triggered by the rising and the other one triggered by the falling edge of the clock signal c. The outputs of the flipflops are connected via an XOR gate. Although not shown in fig. 2, asynchronous set and reset are possible.

The synthesizable VHDL source code of the pde\_dff is shown in listing 2. Both asynchronous set (sn) and reset (rn) can be turned on or off using generic parameters.

Using both edges of the clock means doubling the clock frequency. Propagation paths have to be half as long for dual-edge logic compared to common single-edge logic.

Although the pde\_dff looks symmetric it has in general asymmetric behavior in terms of the propagation time for the rising and the falling edge of the data output q. It depends on the data input d, the stored values in the two flipflops and the propagation times of both the flipflops and the final XOR gate. For the example of FM0 encoding (fig. 1) this means that for a continous transmission of the symbol zero in general the time of the output q being high is not equal to the time of the output being low. Such an assymmetry is not uncommon even for single-edge flipflops but for the pde\_dff it is slightly bigger.

<sup>&</sup>lt;sup>1</sup>This paper has not been published anywhere and contains free information. You may use it and modify it at free will.

#### IV. SUMMARY

The advantage of the pde\_dff is the local use of both edges of the clock, which means the use of the doubled frequency. All other parts of the design can use the main clock.

The alternative is to double the main clock, use it for the cases, where the pde\_dff could be used, and divide it by two for all the other parts of the design. This results in an unnecessary high main clock.

The pde\_dff should be used only for special cases. In most cases a synchronous design running at the rising edge of the main clock is the better choice.

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL, IEEE. Numeric_std.ALL;
entity pdedff is
generic (
 impl_rn : integer:=1; — with async reset if 1
 impl_sn : integer:=1 ); — with async
                                           set if 1
port (
 rn
         : in
               std_ulogic; -- low-active
                std_ulogic; — low-active
 sn
           in
                std_ulogic;
 d
         : in
                std_ulogic;
         : in
 С
           out std_ulogic );
end pdedff;
- pseudo dual-edge D-flipflop
  reset and set are low active and can be
- (de)activated using the generic paramters
architecture behavior of pdedff is
signal ff_rise, ff_fall: std_ulogic;
begin
process(rn,sn,c)
begin
if (impl_rn=1 AND rn='0') then
        ff_rise <= '0';
elsif (impl_sn=1 \text{ AND } sn='0') then
        ff_rise <= '1';
elsif rising_edge(c) then
        if (d='1') then
                 ff_rise <= NOT(ff_fall);
        else
                 ff_rise \le ff_fall;
        end if;
end if:
end process;
process (rn, sn, c)
begin
if (impl_rn=1 AND rn='0') then
        ff_fall <= '0'
elsif (impl_sn=1 AND sn='0') then
        ff_{-}fall <= '0';
elsif falling_edge(c) then
        if (d='1') then
                 ff_fall <= NOT(ff_rise);
                 ff_-fall \ll ff_-rise;
        end if;
end if;
end process;
q \ll 0' when (impl_rn=1 \text{ AND } rn=0') else
     '1' when (impl_sn=1 \text{ AND } sn='0') else
     ff_rise XOR ff_fall;
     — rn and sn used to suppress spikes
```

Listing 2. The Pseudo Dual-Edge D-FF in VHDL