УДК 004.3 ## Approach to Realization of Compositional Microprogramming Control Unit with Code Converter on Custom-Made Matrix A. A .Barkalov<sup>1</sup>, I.J. Zelenyova<sup>2</sup>, A.N. Miroshkin <sup>2</sup>, Hathot Biayrek<sup>2</sup> <sup>1</sup>University of Zielona Gora, Poland A.Barkalov@iie.uz.zgora.p1 <sup>2</sup>Donetsk National Technical University, Donetsk, Ukraine miroshkin@cs.dgtu.donetsk.ua, allah\_karem90@yahoo.com ## Abstract Barkalov O., Zelenyova I.J., Miroshkin A.N., Hathot Biayrek. Approach to Realization of Compositional Microprogramming Control Unit with Code Converter on Custom-Made Matrix. The method of compositional microprogramming control unit realization on custom matrix is proposed. Using of code converter allows reducing the area of custom-made VLSI in logic circuit of control unit. Analysis of proposed method and results of modeling for flow-charts of control algorithm is carried out. ### Introduction The properties of the interpreted control algorithm have great influence on the hardware amount of corresponding control units. One of such properties is the existence of operational linear chains (OLC) corresponding to the graph-scheme of algorithm (GSA) paths, which include operator vertices only [1]. There are many of the approaches for linear graph-scheme of algorithm interpretation and one of them is the use of compositional microprogram control units (CMCU), which can be viewed as a composition of the finite state machine and microprogram control unit [2]. In this case control unit can be implemented as composition of automaton with "hardware" logic, realizing addressing of transitions, and automaton with "programmable" logic. The given article explains method of **CMCU** synthesis microinstructions code converter. <u>The purpose of the research</u> is realization of logic circuit of control unit on custom-made VLSI as interpretation of linear control algorithm. The task of the research is development of method for CMCU with microinstructions codes converter synthesis of microinstructions addresses that allows reducing the area of custom-made matrix for its logic circuit. The control algorithm is represented in the form of GSA. ## Basic definitions and general provisions Transformation of microinstruction addresses is oriented at the reduction of hardware amount in CMCU logic circuit. This method uses the transformation of microinstruction addresses of operational linear chains outputs into codes of the classes of pseudoequivalent OLC. Let initial GSA have starting vertex $b_0$ , final vertex $b_E$ , the set of the operational vertices $B_1$ (the set of states of Moore automata), and conditional vertices set $B_2$ . Vertices $b_q \in B_1$ contains microoperations $Y(b_q) \subseteq Y$ , where $Y = \{y_1, ..., y_N\}$ is the set of microoperations. In the vertices $b_q \in B_2$ elements from the set of logic conditions $X = \{x_1, ..., x_N\}$ are contained. Vertices GSA are connected by arches $\left\langle b_t, b_q \right\rangle$ , forming the set E. $B_j = \left\{ B_0, ..., B_{J-1} \right\}$ is the set of the classes of pseudoequivalent OLC [2]. Let us introduce some of definitions necessary for the further material explanation. $\begin{array}{c} \underline{Definition\ 1} \hbox{: An operational linear chain of} \\ GSA\ is\ a\ finite\ vector\ of\ operator\ vertices \\ \alpha_g = \{b_{g(1)},...,b_{g(Fg)}\}, \quad \text{such} \quad \text{that} \quad \text{an} \quad \text{arch} \\ \left\langle b_{g(i)},b_{g(i+1)}\right\rangle \in E \quad \text{corresponds} \ \ \text{to} \ \ \text{each} \ \ \text{pair} \ \ \text{of} \\ \text{adjacent vertices} \ \ b_{g(i)},\ \ b_{g(i+1)}, \ \ \text{where} \ \ i \ \ \text{is} \ \ \text{the} \\ \text{component number of vector} \ \ \alpha_g \ . \end{array}$ $\label{eq:definition 3} \begin{array}{ll} \underline{\text{Definition 3}} \text{: An operator vertex } b_t \in D^g \text{ is} \\ \text{called the output of OLC } \alpha_g \text{, if there is an arch} \\ \left\langle b_t, b_q \right\rangle \!\! \in \! E \text{, where } b_q = b_E \text{ or } b_q \in B_2 \quad \text{ or } \\ b_q \not \in \alpha^g \text{.} \end{array}$ Any OLC $\alpha_g$ can have more than one input, let us designate $\,j\,$ input OLC $\,\alpha_g\,$ like $\,{I_g}^{\,j},$ every OLC contain only one output $\,O_g$ , entering in the set $O = \{O_1, ..., O_G\}$ of OLC outputs. The set of operator vertices of GSA is OLC satisfying $C = \{\alpha_1, \dots, \alpha_G\}$ the following conditions: $$\begin{cases} \alpha^{i} \cap \alpha^{j} = \emptyset; & (i \neq j; i, j \in [1..G]), \\ \alpha^{1} \cup \alpha^{2} \cup ... \cup \alpha^{G} = B_{1} \end{cases}$$ (1) At performance of conditions (1) every vertex $b_q \in B_1$ enters exactly into one OLC $\alpha_g \in C$ . A set of inputs $I(\Gamma)$ of the operational linear chains of GSA $\Gamma$ is $$I(\Gamma) = \bigcup_{\alpha=1}^{G} I(\alpha_g) . \tag{2}$$ Also we have a set of outputs $O(\Gamma)$ of the operational linear chains of GSA: $$O(\Gamma) = \bigcup_{g=1}^{G} O(\alpha_g).$$ (3) Let $A(b_q)$ be a binary address microinstructions corresponding $b_q \in B_1$ includes $$R_A = \lceil \log_2 M \rceil \tag{4}$$ $\begin{aligned} R_A = & \lceil \log_2 M \rceil \\ \text{where} \quad \text{the} \quad \text{total} \end{aligned}$ bits, number of microinstructions is equal to $M = |B_1|$ . The natural microinstruction addressing can be executed for microinstructions corresponding to the adjacent components of each OLC $\alpha_g \in C$ : $$A(b_{g(i+1)}) = A(b_{g(i)}) + 1;$$ (5) Let us encode each class $B_i \in \Pi_C$ by a binary code K(B<sub>J</sub>) of $$R_{B} = \lceil \log_2 I \rceil \tag{6}$$ bits, using variables $\tau_r \in \tau$ , where $|\tau| = R_B$ , for encoding the classes $B_i \in \Pi_C$ . It is possible now the initial GSA be interpreted using the model of CMCU with microinstructions codes converter [2], designated in the further symbol U<sub>1</sub> (Fig.1), where an address converter AT converts output address of OLC $\alpha_g \in B_i$ into the codes of classes $B_i \in \Pi_C$ . In compositional microprogram control unit, combinational circuit CC implements the input memory functions $$D = F(\tau, x) . (7)$$ And address converter AT implements functions of the system $$\tau = F(T). \tag{8}$$ **CMCU** with converter The of microinstructions (Fig. 1) operates as follows: Figure 1 – Structural diagram of CMCU U<sub>1</sub> Pulse Start is used to load a zero address into the counter CT and to set up the flip-flop T (it gives Fetch = 1). If microinstruction $Y(b_a)$ , where $b_q \neq Q_g$ $g = [1..G_1]$ , is read out of the CM, signal y<sub>0</sub> is generated and content of the counter is incremented, order to in microinstruction corresponds to next component of the current OLC. If $b_q = O_g$ , a transition address is generated by combinational circuit CC using outputs of the address transformer AT and logical conditions. If microinstruction with $y_E = 1$ is read out of the CM and flip-flop T is cleared and operation of CMCU terminated. Method of synthesis of CMCU U includes the following stages: - Creating the transformation of initial flow-chart. - Addition of internal control microoperations $y_0$ and $y_E$ . - Creation of the set $C = \{\alpha_1, ..., \alpha_G\}$ of - Natural addressing of microinstructions. 4. - 5. Forming the content of control memory - Splitting the set C of OLC on classes of pseudoequivalent OLC: $B_{j} = \{B_{0},...,B_{J-1}\}.$ - 7. Encoding of classes $B_j \in B$ . - Construction the table of converter AT. - Construction the table of code converter. - 10. Creation the logical circuit of CMCU U in the given element basis. #### Matrix realization of **CMCU** with microinstruction addresses converter For implementation of the CMCU scheme on custom-made matrices we proposed to represent the CC circuit in the form of conjunctive matrix $M_1$ and disjunctive matrix M2, CM is presented as matrix $M_3$ and disjunctive matrix $M_4$ while the converter device is introduced as M<sub>5</sub> matrix (Fig. 2): Figure 2 —Matrix realization of CMCU U<sub>1</sub> From Fig. 2 we can calculate $S^{CC}_{CMCU}$ , where $S^{CC}_{CMCU}$ is the area of CMCU U: $$S_{\text{CMCU}}^{\text{CC}} = S_{M_1} + S_{M_2} + S_{M_3} + S_{M_4} + S_{M_5};$$ (9) $$S_{M_1} = 2*(L+R_B)*H;$$ (10) $$S_{M_2} = H * R_A;$$ (11) $$S_{M_3} = 2*(R_A + 1)*2^{R_A};$$ (12) $$S_{M_4} = 2^{R_A} * (N+2);$$ (13) $$S_{M_5} = 2^{R_A} * R_B. (14)$$ # Example of application of CMCU with converter of microinstructions Let us consider the example of CMCU synthesis method application with using initial GSA (figure 3). At first we add internal microoperations $y_0$ and $y_E$ to the operational vertices and define the set of operational vertices $B_1 = \{b_1,...,b_6\}$ ; M = 6, $R_A = \lceil \log_2 M \rceil = 3$ . Then we try to form the set of operator vertices of initial GSA OLC, $$\begin{split} &C = \left\{ \!\!\! \left\{ \alpha_1, ..., \alpha_4 \right\} \right. \text{ from the set we can now determine} \\ &G = 4 \,, \quad \alpha_1 = \left\{ b_1 \right\}, \quad \alpha_2 = \left\{ b_2, b_3 \right\}, \quad \alpha_3 = \left\{ b_4 \right\}, \\ &\alpha_4 = \left\{ b_5, b_6 \right\}. \end{split}$$ Then we will create the partition $K(B_i)$ for our example, which contains blocks $\left\{B_0,...,B_2\right\}$ , where $B_0 = \left\{\alpha_1\right\}$ , $B_1 = \left\{\alpha_2,\alpha_3\right\}$ , $B_2 = \left\{\alpha_4\right\}$ . So, for encoding of pseudoequivalent OLC classes $B_j \in \Pi_C$ it is enough $R_B = 2$ variables $\tau = \left\{\tau_1, \tau_2\right\}$ . Let us encode classes $B_i \in \Pi_C$ in such way: $K(B_0) = 00$ ,..., $K(B_2) = 10$ . Table of transitions CMCU has the following columns: $B_i$ – class of pseudoequivalent OLC, $K(B_i)$ – code of class $B_i$ , $I_g{}^j$ , $A(I_g{}^j)$ , $X_h$ , $\Phi_h$ , h. Table of transitions for CMCU $U_1$ is given (Table 2). We don't need to consider transition from OLC $\alpha_4 \in B_2$ as it goes to ending node. Applying of method of address converter is similar to applying of converter of states' codes in codes of classes of pseudoequivalent states of Moore automaton. Table 1. Addressing of control memory words for CMCU | Address | Content | | | | , | - | - i | | | | |-------------|---------|-------|-------|-----------------------|-------|-------------|---------|--------------------|-------------|-------| | $D_3D_2D_1$ | yo | $y_1$ | $y_2$ | <b>y</b> <sub>3</sub> | $y_4$ | $y_{\rm E}$ | $B_{I}$ | $\Pi_{\mathrm{C}}$ | $I_g^{\ 1}$ | $O_g$ | | 000 | 1 | 0 | 0 | 0 | 0 | 0 | b0 | - | - | = | | 001 | 0 | 1 | 0 | 1 | 0 | 0 | b1 | $\alpha_1$ | $I_1$ | $O_1$ | | 010 | 1 | 0 | 1 | 1 | 0 | 0 | b2 | $\alpha_2$ | $I_2$ | - | | 011 | 0 | 1 | 0 | 0 | 1 | 0 | b3 | $\alpha_2$ | - | $O_2$ | | 100 | 0 | 0 | 1 | 0 | 0 | 0 | b4 | $\alpha_3$ | $I_3$ | $O_3$ | | 101 | 1 | 0 | 0 | 1 | 0 | 0 | b5 | $\alpha_4$ | $I_4^{-1}$ | - | | 110 | 0 | 1 | 0 | 1 | 1 | 1 | b6 | $\alpha_4$ | $I_4^2$ | $O_4$ | Figure 3 – Initial GSA for CMCU U<sub>1</sub> Table 2. Transitions for CMCU with code converter | B <sub>i</sub> | $K(B_i)$ $\tau_1 \tau_2$ | $I_g^{j}$ | $A(I_g^{j})$ | X <sub>h</sub> | $\Phi_{ m h}$ | h | | |----------------|--------------------------|------------|--------------|-------------------------------|---------------|---|--| | $\mathbf{B}_0$ | 0.0 | $I_2$ | 010 | $\mathbf{x}_1$ | $D_1$ | 1 | | | | 0 0 | $I_3$ | 100 | $\frac{-}{x_1}$ | $D_2$ | 2 | | | B <sub>1</sub> | 0 1 | $I_2$ | 010 | $x_2 \overline{x_3}$ | $D_1$ | 3 | | | | | $I_4^{-1}$ | 101 | ${x_2}$ | $D_2$ , $D_0$ | 4 | | | | | $I_4^2$ | 110 | x <sub>2</sub> x <sub>3</sub> | $D_2, D_1$ | 5 | | With the table we can build system function (2), for example: $$\begin{split} D_1 = F_1 \vee F_3 \vee F_5 = \overline{\tau_1} \overline{\tau_2} x_1 \vee \overline{\tau_1} \overline{\tau_2} x_2 \overline{x_3} \vee \overline{\tau_1} \overline{\tau_2} x_2 x_3 \,. \end{aligned} \tag{15} \\ \text{Table of the converter of addresses of microinstructions contains columns: } O_g \,, \ A(O_g) \,, \end{split}$$ $B_i$ , $K(B_i)$ , $\tau_j$ , g. If $\alpha_g \in B_j$ , then row g of table contains corresponded information. For our example address converter is given in table 3: Table 3 – Table of code converter | $O_g$ | A(O <sub>g</sub> ) | B <sub>i</sub> | K(B <sub>i</sub> ) | $\tau_{j}$ | g | |-------|--------------------|----------------|--------------------|------------|---| | $O_1$ | 001 | $\mathbf{B}_0$ | 0 0 | - | 1 | | $O_2$ | 011 | $\mathbf{B}_1$ | 0 1 | $\tau_1$ | 2 | | $O_3$ | 100 | $\mathbf{B}_1$ | 0 1 | $\tau_1$ | 3 | | $O_4$ | 110 | $B_2$ | 10 | $\tau_2$ | 4 | With the help of this table we can form system of functions $$\tau_{r} = \bigvee_{g=1}^{G} C_{rg} A_{g}, (r = 1,...,R_{0}), \qquad (16)$$ where $C_{rg}$ is boolean variable. It is equal to "1", if and only if $\alpha_g \in B_i$ and bit r of $K(B_i)$ is equal to "1", $A_g$ is a conjunction of variables $Q_r \in Q$ , which corresponds to address $A(O_g)$ of OLC output $\alpha_g \in B_i$ . ## Results of the modelling Dependence custom-made matrix area on parameters of initial GSA is explored using expressions (9)-(14) and statistics of EXCEL (fig.4). Figure 4 –Dependence matrix area on number of transitions Results of research shows that effectiveness of code converter using depends most of all on possibility of classes forming and transition number reducing . ## **Conclusion** The proposed CMCU synthesis method targets to decrease in hardware amount, used area of the custom-made matrices. The method is based on encoding of the classes of pseudoequivalent OLC permitting decrease of the transition table lines in comparison with CMCU with base structure. Results of experiments show that the area of matrices is decreased up to 15%. Of course, application of proposed method is possible only for interpretation of linear GSA. The next step in research is exploration of possibility for given method application in case of standard elementary basis (CPLD, FPGA). ## References - 1. Barkalov A.A., Titarenko L.A. Synthesis Of Operational And Control Automata. Donetsk: Unitech, 2005. 256 pp. - 2. Barkalov A.A., Titarenko L.A. Logic Synthesis for Compositional Microprogram Control Units,2008 272 pp. - 3. Smith M. Application Specific Integrated Circuits. Boston: Addison Wesley, 1997. 836 pp. 4. Baranov S. Logic Synthesis For Control Automata. Boston: Kluwer Academic Publisher. Automata. – Boston: Kluwer Academic Publisher, 1954. – 312 pp. Received 29.03.2010