# Summarizing Circuits with Serial Semantics

Ying Qin, ShengYu Shen, Member, IEEE, and Yan Jia

Abstract—Many communication and multimedia circuits have succinct representation when their input and output are taken as serial bit streams. But when implemented in register transition level with multibit width datapath, their structures become very complicate due to the different datapath width of submodules, and the need to match bandwidth between these submodules with flow control mechanism. Such complication make it very difficult to verify such circuits.

To facilitate the job of verifying such circuits, we propose in this paper a novel algorithm to recover a succinct summarization of the circuit's functionality by flatten its multibit width datapth into serial bit streams, which consequently avoid the need to match bandwidth between submodules with flow control mechanism.

To further simplify the summarization, we provide the ability to define some complex logic block as uninterpreted function, such that ???.

Index Terms—Complementary Synthesis, Inferring Assertion, Cofactoring, Craig Interpolation, Functional Dependency

### I. INTRODUCTION

One of the most difficult tasks in designing communication chips is to design the complex circuit pair  $(E,E^{-1})$ , in which the encoder E transforms information into a particular format, while its decoder  $E^{-1}$  recovers this information.

Thus, complementary synthesis [1] was proposed to automatically synthesize an encoder's decoder. As shown in Fig. ??a), it includes three steps: i) manually specifying an assertion that assigns constant value on the encoder's configuration pins to prevent it from reaching the non-working states without a decoder; ii) determining the decoder's existence by checking whether the encoder's input can be uniquely determined by its output; and iii) characterizing the decoder's Boolean function.

To manually specify an assertion, the user must read extensive documentation and often perform laborious trial-anderror process. For example, our most complex benchmark—the XFI encoder— has 120 configuration pins. Finding out their meaning and correct combinations was a very difficult and lengthy process, which had already been experienced by the first author in [1]. To avoid this tedious task, this paper propose the following three algorithms.

First, an algorithm is proposed to automatically infer this assertion [2], which corresponds to the first step of the new approach in Fig. ??b). This algorithm iteratively discovers the encoder's configuration value that leads to the decoder's nonexistence, and then uses Craig interpolation to infer a new formula that covers a larger set of such invalid configuration values. These inferred formulas will be ruled out until no more invalid configuration values can be found. The final assertion is obtained by anding the inverses of all these inferred formulas.

The authors are with the School of Computer, National University of Defense Technology, ChangSha, HuNan, 410073 CHINA. e-mail: {yingqin, syshen, yjia}@nudt.edu.cn.

Second, under this inferred assertion, however, multiple decoders may exist simultaneously. Thus, as shown in the second step of Fig. ??b), a second algorithm is proposed to discover all these decoders by iteratively testing whether  $\mathbb{R}$ , the Boolean relation that uniquely determines the encoder's input, functionally depends [5] on these discovered decoders. For every configuration value c that fails this test, a new decoder's Boolean relation is discovered by asserting c into  $\mathbb{R}$ . This step is repeated until all decoders are discovered.

Third, to help the user select the correct decoder, a third algorithm is proposed to characterize a precondition formula for each decoder, which represents the configuration value set that leads to this decoder's existence. The user can easily select the correct decoder by inspecting these preconditions.

For example, for the two decoders of XFI discovered by our algorithm, their corresponding precondition formulas refer to only three pins, only two of which have different values. Therefore, to select the correct decoder, one only needs to find out the meaning of these two pin, instead of all 120 pins. More details can be found in the experimental results section, which indicates that our algorithm can significantly save the human effort in specifying assertion and selecting decoder. All the Experimental Results and programs can be downloaded from http://www.ssypub.org.

The remainder of this paper is organized as follows. Section III introduces background materials. Section III presents the algorithm that infers assertions. Section IV discusses how to discover all decoders and characterize their precondition formulas. Sections V and VI present the experimental results and related works. Finally, Section VII provides the conclusion.

# II. PRELIMINARIES

To save space, we assume the readers' familiarity with propositional satisfiability (SAT), cofactoring [7], Craig interpolant generation [8], and functional dependency [5].

The encoder is modeled using *Mealy finite state machine* with configuration  $M=(S,s_0,I,C,O,T)$ , consisting of a finite state set S, an initial state  $s_0 \in S$ , a finite input letter set I, a finite configuration letter set C, a finite output letter set I, and a transition function  $I : S \times I \times C \to S \times O$  that computes the next state and output letter from the current state, input letter, and configuration letter.

We denote the state, input letter, output letter, and configuration letter at the n-th cycle as  $s_n$ ,  $i_n$ ,  $o_n$ , and  $c_n$ , respectively. We further denote the sequence of state, input letter, output letter, and configuration letter from the n-th to the m-th cycle as  $s_n^m$ ,  $i_n^m$ ,  $o_n^m$ , and  $c_n^m$ , respectively.

An assertion (or formula) on configuration pins is defined as a configuration letter set R. R(c) means  $c \in R$ . If R(c) holds, we also say that R covers c.

The decoder exists if the encoder's input can be uniquely determined by its output. As shown in Fig. ??a), this can be formally defined as follows.

**Definition** 1: Parameterized complementary condition (PC): For encoder E, assertion R, and parameters p, d, and l,  $E \models PC(p,d,l,R)$  holds if  $i_n$  can be uniquely determined by  $o_{n+d-l}^{n+d-1}$ , and R covers the constant configuration letter c. This amounts to the unsatisfiability of  $F_{PC}(p,d,l,R)$  in Equation (1).

Lines 2 and 3 of Equation (1) correspond to two state sequences of E, respectively. Line 4 forces the output sequences of these two state sequences to be the same, while Line 5 forces their input letters to be different. The last line constrains c to be covered by R.

The algorithm based on checking PC [1] just enumerates all combinations of p, d, and l, from small to large, until  $F_{PC}(p,d,l,R)$  becomes unsatisfiable, which means that the decoder exists.

# III. A HALTING ALGORITHM TO INFER ASSERTION

In Subsection III-A, we first define how to determine the decoder's nonexistence for a particular configuration letter. And then, in Subsection III-B, we introduce the algorithm that infers assertion by iteratively detecting and removing all invalid configuration letters.

# A. Determining the decoder's nonexistence

According to Definition 1, the decoder exists for a set of configuration letters R if there is a parameter value tuple < p, d, l > that makes  $E \models PC(p, d, l, R)$  holds true. Therefore, intuitively, the decoder does not exist if for every parameter value tuple < p, d, l >, we can always find another tuple < p', d', l' > with p' > p, l' > l and d' > d, such that  $E \models PC(p', d', l', R)$  does not hold.

This case can be detected by the SAT instance shown in Figure  $\ref{eq:sate}$ , which is similar to that of Figure  $\ref{eq:sate}$ , except that three new constraints are inserted to detect loops on  $s_{n-p}^{n+d-l}, s_{n+d-l+1}^n$ , and  $s_{n+1}^{n+d}$ .

Thus, the decoder's nonexistence can be determined by:

**Definition** 2: Loop-like Non-complementary Condition (LN): For encoder  $E, E \models LN(p,d,l,R)$  holds if  $i_n$  can not be uniquely determined by  $o_{n+d-1}^{n+d-1}$  on  $s_{n-p}^{n+d-1}$ , and there are loops on  $s_{n-p}^{n+d-l}$ ,  $s_{n+d-l+1}^{n}$ , and  $s_{n+1}^{n+d}$ . This amounts to the satisfiability of  $F_{LN}(p,d,l,R)$  in Equation (2).

$$F_{LN}(p,d,l,R) \stackrel{def}{=} \begin{cases} F_{PC}(p,d,l,R) \\ \wedge \bigvee_{x=n-p}^{n+d-l-1} \bigvee_{y=x+1}^{n+d-l} \{s_x \equiv s_y \wedge s_x' \equiv s_y'\} \\ \wedge \bigvee_{x=n+d-l+1}^{n-1} \bigvee_{y=x+1}^{n} \{s_x \equiv s_y \wedge s_x' \equiv s_y'\} \\ \wedge \bigvee_{x=n+1}^{n+d-1} \bigvee_{y=x+1}^{n+d} \{s_x \equiv s_y \wedge s_x' \equiv s_y'\} \end{cases}$$
(2)

#### B. Algorithm implementation

```
Algorithm 1 InferAssertion
 1: NA = \{\}
 2: for x=0\to\infty do
       < p, d, l > = < 2x, x, 2x >
       if F_{PC}(p,d,l,\bigwedge_{na\in NA} \neg na) is unsatisfiable then
          Halt. The final assertion is \bigwedge_{na \in NA} \neg na, the decoder
          exists if it is satisfiable.
       else
 6:
 7:
          while F_{LN}(p, d, l, \bigwedge_{na \in NA} \neg na) is satisfiable do
             Assume A(c) is c's satisfying assignment leading
 8:
             to the decoder's nonexistence.
 9:
             na \leftarrow InferCoveringFormula(A(c))
             NA \leftarrow NA \cup \{na\}
10:
          end while
11:
       end if
12:
13: end for
```

Algorithm 1 is used to infer assertion on configuration pins that can lead to the decoder's existence. Intuitively, it iteratively tests all combinations of  $\langle p,d,l \rangle$  in Line 3. For every A(c) found in Line 8 that can lead to the decoder's nonexistence, a larger set of such configuration letters are discovered by the procedure InferCoveringFormula in Line 9, and ruled out in Line 10. This loop is repeated until the formula  $F_{PC}$  in Line 4 is unsatisfiable.

InferCoveringFormula uses cofactoring [7] to assert the satisfying assignments of  $i_{n-p}^{n+d-1}$ ,  $(i')_{n-p}^{n+d-1}$ ,  $s_{n-p}$ , and  $(s')_{n-p}$  back to  $F_{LN}$ , and then uses Craig interpolation [8] to characterize a larger set of invalid configuration letters. More details can be found in [2], which had proved that Algorithm 1 is a halting one.

### IV. DISCOVERING MULTIPLE DECODERS

Subsection IV-A introduces how to discover decoders and its correctness proof, while Subsection IV-B presents how to characterize the precondition formula of each discovered decoder, to help the user select the correct one.

### A. Constructing SAT instance to discover decoders

Assume the assertion inferred by Algorithm 1 is:

$$IA \stackrel{def}{=} \bigwedge_{na \in NA} \neg na \tag{3}$$

To simplify the presentation, we denote  $o_{n+d-l}^{n+d-1}$  and  $i_n$  as:

$$X \stackrel{def}{=} o_{n+d-l}^{n+d-1}$$

$$Y \stackrel{def}{=} i_n$$
(4)

Thus, the Boolean relation that uniquely determines  $i_n$  from  $o_{n+d-1}^{n+d-1}$  and c can be denoted as:

$$\mathbb{R}(c, X, Y) \stackrel{def}{=} F_{PC}(p, d, l, IA) \tag{5}$$

 $\mathbb{R}(c,X,Y)$  defines a mapping from c and X to Y, which is actually a function f:

$$Y = f(c, X) \tag{6}$$

For every configuration letter  $c_i \in IA$ , there is a  $\mathbb{R}_{c_i}$ :

$$\mathbb{R}_{c_i}(X,Y) \stackrel{def}{=} \mathbb{R}(c,X,Y) \wedge c \equiv c_i \tag{7}$$

Two different  $c_i$  and  $c_j$  may share the same  $\mathbb{R}_{c_i}$ . Therefore, IA can be partitioned into  $\{IA_1,\ldots,IA_n\}$ , such that all c in the same  $IA_i$  share the same  $\mathbb{R}_i$ , while two c and c' in two different  $IA_i$  and  $IA_{i'}$  do not. So we call  $IA_i$  the precondition formula of  $\mathbb{R}_i$ , which means  $IA_i$  is the set of all configuration letters that leads to the decoder  $\mathbb{R}_i$ 's existence. When there exists multiple decoders, the user can select the correct one by inspecting  $\{IA_1,\ldots,IA_n\}$  characterized in Subsection IV-B.

Thus,  $\mathbb{R}_i$  defines a mapping from X to Y, which is actually a function  $f_i: X \to Y$ . Therefore, f can be rewritten as:

$$f(c,X) = \bigvee_{i=1}^{n} \{ IA_i(c) \wedge f_i(X) \}$$
 (8)

Thus, our task here is to find out the set  $\{\mathbb{R}_1, \ldots, \mathbb{R}_n\}$  step—by–step. Assume that we have already discovered a set of decoders' Boolean relations  $\{\mathbb{R}_1, \ldots, \mathbb{R}_m\}$ . To test whether it contains  $\{\mathbb{R}_1, \ldots, \mathbb{R}_n\}$ , that is, whether all decoders have already been discovered, we construct the following SAT instance, which is also shown in Fig. ??:

$$\begin{cases}
\mathbb{R}(c, X, Y) \wedge \bigwedge_{i=1}^{m} \mathbb{R}_{i}(X, Y_{i}) \\
\wedge \mathbb{R}'(c, X', Y') \wedge \bigwedge_{i=1}^{m} \mathbb{R}'_{i}(X', Y'_{i}) \\
\wedge \bigwedge_{i=1}^{m} Y_{i} \equiv Y'_{i} \\
\wedge Y \neq Y'
\end{cases}$$
(9)

Line 1 of Equation (9) represents the Boolean relations in  $\{\mathbb{R}_1,\ldots,\mathbb{R}_m\}$  and  $\mathbb{R}$ . Line 2 is a copy of Line 1. The only common variable shared by them is c. Line 3 forces all  $Y_i$  and  $Y_i'$  to take on the same values, while the last line forces Y and Y' to be different.

The following theorem proves that, if Equation (9) is unsatisfiable, then all decoders have been discovered.

**Theorem** 1: If Equation (9) is unsatisfiable, then  $\{\mathbb{R}_1, \dots, \mathbb{R}_m\}$  contains  $\{\mathbb{R}_1, \dots, \mathbb{R}_n\}$ .

*Proof:* The proof is by contradiction. Assume  $\mathbb{R}_n \notin \{\mathbb{R}_1, \dots, \mathbb{R}_m\}$ , and  $IA_n$  is its corresponding set of configuration letters, and  $c_n \in IA_n$ .

We can construct an assignment A such that  $A(c) \equiv c_n$ . Thus, we have  $\{\mathbb{R}(c,X,Y) \land A(c) \equiv c_n\} \equiv \mathbb{R}_n(X,Y)$ , that is, we can change  $\mathbb{R}$  and  $\mathbb{R}'$  shown in Fig. ?? to  $\mathbb{R}_n$  with A.

As  $\mathbb{R}_n \notin \{\mathbb{R}_1, \dots, \mathbb{R}_m\}$ , there must be an assignment A', such that when we assign A'(X) to X and A'(X') to X', we can make both  $\bigwedge_{i=1}^m Y_i \equiv Y_i'$  and  $Y \neq Y'$  hold.

Therefore, by combining A and A', Equation (9) becomes satisfied. This contradiction concludes the proof.

On the other hand, if Equation (9) is satisfiable, we need to prove the following theorem.

**Theorem** 2: If Equation (9) is satisfiable, then there must be at least one decoder that has not been discovered.

*Proof:* The proof is by contradiction. Assume that all decoders have already been discovered, that is,  $\{\mathbb{R}_1, \dots, \mathbb{R}_m\}$  contains  $\{\mathbb{R}_1, \dots, \mathbb{R}_n\}$ . Thus, for any assignment A that makes the first three lines of Equation (9) satisfied, we have:

$$Y = \bigvee_{i=1}^{m} \{ IA_i(c) \land Y_i \} = \bigvee_{i=1}^{m} \{ IA_i(c) \land Y_i' \} = Y'$$
 (10)

Thus, the last line of Equation (9) will never be satisfied. Therefore, Equation (9) is unsatisfiable. This contradiction concludes the proof.

With the satisfying assignment A,  $\mathbb{R}_{m+1}$  defined below is a newly discovered decoder's Boolean relation:

$$\mathbb{R}_{m+1} \stackrel{def}{=} \mathbb{R}(c, X, Y) \wedge c \equiv A(c) \tag{11}$$

Theorem 3 proves that  $\mathbb{R}_{m+1}$  hasn't been discovered before: **Theorem** 3:  $\mathbb{R}_{m+1} \notin \{\mathbb{R}_1, \dots, \mathbb{R}_m\}$ 

*Proof:* The proof is by contradiction. Assume that there is  $0 \le i \le m$  such that  $\mathbb{R}_i \equiv \mathbb{R}_{m+1}$ .

As  $\mathbb{R}_i$  can uniquely determine Y from X, while  $\mathbb{R}$  can uniquely determine Y from X as well as c, and  $\mathbb{R}_{m+1} \equiv \mathbb{R}_i$ , it is obvious that we can make  $Y \equiv Y_i$  by forcing c to be A(c) in Equation (11). Similarly, we have  $Y_i' \equiv Y'$ .

According to Line 5 of Equation (9), we have  $Y \equiv Y_i \equiv Y_i' \equiv Y'$ . This is in contradiction with  $Y \neq Y'$  in the last line of Equation (9), which concludes the proof.

Based on these discussions, the following Algorithm 2 describes how to discover the Boolean relations of all decoders.

# Algorithm 2 DiscoveringDecoders

- 1: while Equation (9) is satisfiable do
- 2: Insert  $\mathbb{R}_{m+1}$  of Equation (11) into  $\{\mathbb{R}_1, \dots, \mathbb{R}_m\}$
- 3: end while
- 4: The set of decoders' Boolean relations is  $\{\mathbb{R}_1, \dots, \mathbb{R}_m\}$

The loop in Algorithm 2 monotonically increases the size of  $\{\mathbb{R}_1, \dots, \mathbb{R}_m\}$ . As the number of decoders that compute Y from X is finite, Algorithm 2 will eventually halt.

# B. Characterizing $\{IA_1, \ldots, IA_m\}$

Assume  $\{\mathbb{R}_1, \dots, \mathbb{R}_m\}$  is the set of all decoders' Boolean relations discovered by Algorithm 2. To help the user select the correct decoder, we need to characterize their precondition formulas  $\{IA_1, \dots, IA_m\}$ . According to Fig. ??, the relation between Y and all  $Y_i$  can be written as:

$$Y = \bigvee_{i=1}^{m} \{ IA_i(c) \wedge Y_i \}$$
 (12)

TABLE I Information on Benchmarks

|                  | XGXS | XFI | scrambler | PCIE | T2 Ethernet |
|------------------|------|-----|-----------|------|-------------|
| #line of verilog | 214  | 466 | 24        | 1139 | 1073        |
| #regs            | 15   | 135 | 58        | 22   | 48          |
| Data path width  | 8    | 64  | 66        | 10   | 10          |
| #Config pin      | 3    | 120 | 1         | 16   | 26          |

Assume Y and all  $Y_i$  are vectors of the same length v, whose j-th bit are  $y^j$  and  $y_i^j$ , respectively. Therefore, we can rewrite Equation (12) by splitting it into bits, and the relation between the j-th bits of Y and all  $Y_i$  can be written as:

$$y^{j} = \bigvee_{i=1}^{m} \{ IA_{i}^{j}(c) \wedge y_{i}^{j} \}$$
 (13)

According to Lee et al. [5], it is obvious that Equation (13) represents a functional dependency problem. We can characterize  $IA_i^j(c)$  with the functional dependency algorithm proposed by Lee et al. [5] with the following two formulas:

$$\phi_{A} \stackrel{def}{=} \left\{ \begin{array}{cc} & \mathbb{R}(c, X, Y) \wedge \bigwedge_{i=1}^{m} \mathbb{R}_{i}(X, Y_{i}) \\ \wedge & y^{j} \equiv 1 \end{array} \right\}$$

$$\phi_{B} \stackrel{def}{=} \left\{ \begin{array}{cc} & \mathbb{R}'(c, X', Y') \wedge \bigwedge_{i=1}^{m} \mathbb{R}'_{i}(X', Y'_{i}) \\ \wedge & \bigwedge_{i=1}^{m} y_{i}^{j} \equiv y_{i}^{\prime j} \\ \wedge & y^{\prime j} \equiv 0 \end{array} \right\}$$

$$(14)$$

It is obvious that  $\phi_A \wedge \phi_B$  is very similar to Equation (9), except that only the *j*-th bits are constrained to be the same, and the  $y^j$  and  $y'^j$  are constrained to be different constants.

Therefore,  $\phi_A \wedge \phi_B$  is unsatisfiable. The support set of its interpolant  $ITP: C \times \mathbb{B}^m \to \mathbb{B}$  is  $\{c, y_1^j, \dots, y_m^j\}$ . According to Equation (13), ITP is the over-approximation of  $\bigvee_{i=1}^m \{IA_i^j(c) \wedge y_i^j\}$ . Thus, an over-approximation of  $IA_i^j(c)$  can be obtained by setting  $y_i^j$  to 1, and all other  $y_k^j$  to 0:

$$ITP \wedge \bigwedge_{k \neq i} y_k^j \equiv 0 \wedge y_i^j \equiv 1$$
 (15)

As  $\phi_A \wedge \phi_B$  is unsatisfiable, this over-approximation of  $IA_i^j(c)$  can make  $y^j \equiv 1$ . Therefore, we can take it as  $IA_i^j(c)$ . Thus,  $IA_i(c)$  can be defined as:

$$IA_i(c) = \bigwedge_{i=0}^{v-1} IA_i^j(c)$$
 (16)

In Subsection V-C, we will show that by inspecting these  $IA_i$ , the user can easily select the correct decoder.

# V. EXPERIMENTAL RESULTS

We have implemented this algorithm and solved the generated SAT instances with Minisat [6]. All experiments have been run on a PC with a 2.4GHz Intel Core 2 Q6600 processor, 8 GB memory, and Ubuntu 10.04 Linux.

Table I shows information on the following benchmarks: the XGXS and XFI encoders compliant to clause 48 and 49 of IEEE-802.3ae 2002 standard [4]; a 66-bit scrambler used to ensure that a data sequence has sufficient 0-1 transitions; a PCI-E physical coding module [3]; and the Ethernet module of Sun's OpenSparc T2 processor.

TABLE II EXPERIMENTAL RESULTS

|       |              | XG-   | XFI    | scra- | PCI-  | T2 E-  |
|-------|--------------|-------|--------|-------|-------|--------|
|       |              | XS    |        | mbler | E     | ther   |
| [10]  | Runtime(sec) | 0.07  | 17.84  | 2.70  | 0.47  | 30.59  |
|       | d, p, l      | 1,2,1 | 0,3,2  | 0,2,2 | 2,2,1 | 4,2,1  |
|       | Runtime 1    | 4.53  | 264.19 | 13.03 | 10.39 | 426.12 |
| this  | Runtime 2    | 0.11  | 12.11  | 1.26  | 0.27  | 3.07   |
| paper | Runtime 3    | 0.13  | 13.69  | 1.49  | 0.23  | 2.86   |
|       | d, p, l      | 1,5,1 | 0,5,2  | 0,5,2 | 2,5,1 | 4,5,1  |

### A. Comparing the results with previous work

Table II compares the halting algorithm proposed in [10] and this paper's approach. The algorithm in [10] needs a manually specified assertion, while our approach does not.

The second row of Table II shows the runtime of the halting algorithm proposed in [10], which checks whether the decoders exist, and the third row shows the value of d, p, and l discovered by that algorithm.

Our algorithm includes three steps: inferring assertions, discovering decoders, and inferring preconditions. Their runtimes are shown in the fourth to the sixth rows of Table II. The seventh row shows the value of the discovered d, p, and l.

By comparing the second and the fourth rows, it is obvious that our approach is much slower than that of [10], which is caused by the much more complicated procedure InferCoveringFormula. The fifth and sixth rows indicate that the runtimes of the second and third steps are relatively small than the first step.

The third and the seventh rows indicate that there are some minor differences in those parameter values, which is caused by the difference between the embedded assertions and inferred assertions. The latter contain much more configuration letters than the former.

### B. Inferred assertions

For XGXS: ( ( !bad\_code ) )
For XFI: ((RESET&!TEST\_MODE)|(!RESET&DATA
\_VALID&!TEST\_MODE))
For scrambler: True

For PCI-E: ((CNTL\_RESETN\_P0&!TXELECIDLE&
!CNTL\_Loopback\_P0&CNTL\_TXEnable\_P0))

For T2 ethernet: ((tx\_enc\_conf\_sel[1]&tx\_enc \_conf\_sel[3]&!txd\_sel[1]&!txd\_sel[0]&!jit ter\_study\_pci[0]&!jitter\_study\_pci[1]&!re set\_tx) | (tx\_enc\_conf\_sel[1]&!tx\_enc\_conf\_ sel[3]&!txd sel[1]&!txd sel[0]&!jitter stu dy\_pci[0]&!jitter\_study\_pci[1]&!reset\_tx& tx enc conf sel[0]&tx enc conf sel[2]&link \_up\_loc) | (tx\_enc\_conf\_sel[1] &!tx\_enc\_conf \_sel[3]&!txd\_sel[1]&!txd\_sel[0]&!jitter\_st udy\_pci[0]&!jitter\_study\_pci[1]&!reset\_tx& tx\_enc\_conf\_sel[0]&!tx\_enc\_conf\_sel[2])| (tx\_enc\_conf\_sel[1]&!tx\_enc\_conf\_sel[3]& !txd\_sel[1]&!txd\_sel[0]&!jitter\_study\_pci[0] &!jitter\_study\_pci[1]&!reset\_tx&!tx\_enc\_ conf\_sel[0]&link\_up\_loc)|(!tx\_enc\_conf\_sel [1] &tx\_enc\_conf\_sel[3] &!txd\_sel[1] &!txd\_

sel[0]&!jitter\_study\_pci[0]&!jitter\_study\_pci[4] "IEEE Standard for Information technology Telecommunications and [1]&!reset\_tx&tx\_enc\_conf\_sel[2])|(!tx\_enc \_conf\_sel[1]&tx\_enc\_conf\_sel[3]&!txd\_sel[1] &!txd\_sel[0]&!jitter\_study\_pci[0]&!jitter\_st udy\_pci[1]&!reset\_tx&!tx\_enc\_conf\_sel[2]&li nk\_up\_loc) | (!tx\_enc\_conf\_sel[1] &!tx\_enc\_con f\_sel[3]&!txd\_sel[1]&!txd\_sel[0]&!jitter\_stu dy\_pci[0]&!jitter\_study\_pci[1]&!reset\_tx& link\_up\_loc))

For T2 ethernet with complex assertion, it is very important to use the algorithms in Section IV to chose the decoder.

### C. Dealing with multiple decoders

For the two decoders of the scrambler, their corresponding precondition formulas are reset and !reset. By inspecting the Verilog source code of the scrambler, we found that the reset is used to reset the scrambler when it is True. Thus, the scrambler will work in normal mode when reset is False. Therefore, the second decoder is the correct one.

For the two decoders of the most complex XFI encoder [4], their corresponding precondition formulas !TEST MODE&RESET and !TEST MODE &!RESET&DATA\_VALID. The only differences between them are the values of RESET and DATA VALID. By inspecting the Verilog source code of XFI, we found that the RESET is used to reset the XFI encoder when it is True, and DATA VALID means that the input data is valid when it is True. Thus, the XFI encoder will work in normal mode when RESET is False and DATA\_VALID is True. Therefore, the second decoder is the correct one.

### VI. RELATED WORKS

Complementary synthesis was first proposed in [1]. Shen et al. [9] and Liu et al. [11] improved its runtime with unsatisfiable core extraction and Craig interpolation, respectively. Shen et al. [10] and Liu et al. [11] proposed halting algorithms to determine the existence of the decoders by detecting loops.

The protocol converter synthesis [12] is the problem that automatically generates a translator between two different communication protocols, by computing a greatest fixed point for the update function of the buffer's control states.

# VII. CONCLUSIONS

This paper has proposed a fully automatic approach to infer assertion for complementary synthesis and generate all decoders. Experimental results indicate that our approach can significantly reduce the human effort in specifying assertion.

### REFERENCES

- [1] S. Shen, J. Zhang, Y. Qin, and S. Li, "Synthesizing complementary circuits automatically," in ICCAD09. IEEE, Nov. 2009, pp. 381–388.
- S. Shen, Y. Qin, J. Zhang, and S. Li, "Inferring Assertion for Complementary Synthesis,"in ICCAD11. ACM, Nov. 2011, pp. 404-411.
- "PCI Express Base Specification Revision 1.0". [Online]. Available: http: //www.pcisig.com

- information exchange between systems Local and metropolitan area networks Specific requirements Part 3: Carrier Sense Multiple Access with Collision Detection (CSMA/CD) Access Method and Physical Layer Specifications Amendment: Media Access Control (MAC) Parameters. Physical Layers, and Management Parameters for 10 Gb/s Operation", IEEE Std. 802.3, 2002.
- [5] C.-C. Lee, J.-H. R. Jiang, C.-Y. Huang, and A. Mishchenko, "Scalable exploration of functional dependency by interpolation and incremental SAT solving," in ICCAD07. IEEE, Nov. 2007, pp. 227-233.
- [6] N. Eén and N. Sörensson. An extensible sat-solver. In SAT03, pages 502-518. Springer, May 2003.
- [7] M. K. Ganai, A. Gupta, and P. Ashar, "Efficient SAT-based unbounded symbolic model checking using circuit cofactoring," in ICCAD04. IEEE, Nov. 2004, pp. 510-517.
- [8] K. L. McMillan, "Interpolation and SAT-based model checking," in CAV03. Springer, July 2003, pp. 1-13.
- [9] S. Shen, Y. Qin, K. Wang, L. Xiao, J. Zhang, and S. Li, "Synthesizing complementary circuits automatically," IEEE trans. on CAD of Integrated Circuits and Systems, vol. 29, no. 8, pp. 1191-1202, Aug. 2010.
- S. Shen, Y. Qin, L. Xiao, K. Wang, J. Zhang, and S. Li, "A halting algorithm to determine the existence of the decoder," IEEE trans. on CAD of Integrated Circuits and Systems, vol. 30, no. 10, pp. 1556-1563,
- [11] S. Liu, Y. Chou, C. Lin, and J. Jiang, "Towards completely automatic decoder synthesis," in ICCAD11. ACM, Nov. 2011, pp. 389-395.
- K. Avnit, V. D'Silva, A. Sowmya, S. Ramesh, and S. Parameswaran, "A formal approach to the protocol converter problem," in DATEO8. IEEE, Mar. 2008, pp. 294-299.