Design of Digital Systems II Combinational Logic Design Practices (2) Moslem Amiri, Vaclav Prenosil Embedded Systems Laboratory Faculty of Informatics, Masaryk University Brno, Czech Republic amiriOmail.muni.cz prenosilOfi.muni.cz November, 2012 Decoders • A decoder is a multiple-input, multiple-output logic circuit that converts coded inputs into coded outputs, where input and output codes are different • Input code generally has fewer bits than output code • There is a one-to-one mapping from input code words into output code words • In a one-to-one mapping, each input code word produces a different output code word Decoder output code word Figure 1 Decoder circuit structure. Moslem Amiri, Václav Přenosi Design of Digital Systems II November, 2012 2/69 Decoders • Enable inputs must be asserted for decoder to perform its normal mapping function • Otherwise, it maps all input code words into a single, "disabled," output code word • Most commonly used input code is an n-bit binary code • An n-bit word represents one of 2" different coded values • Most commonly used output code is a 1-out-of-m code • m bits where one bit is asserted at any time Moslem Amiri, Václav Přenosi Design of Digital Systems II 3/69 Decoders: Binary Decoders • Binary decoder is an n-to-2" decoder • It has an n-bit binary input code and a l-out-of-2" output code Figure 2: A 2-to-4 decoder: (a) inputs and outputs; (b) logic diagram. 4/69 Decoders: Binary Decoders Table 1: Truth table for a 2-to-4 binary decoder. Inputs Outputs EN 11 10 Y3 Y2 Yl Y0 0 X X 0 0 0 0 1 0 0 0 0 0 1 1 0 1 0 0 1 0 1 1 0 0 1 0 0 1 1 1 1 0 0 0 • Input code of an n-bit binary decoder need not represent integers from 0 through 2" - 1 • E.g., it can be in Gray code (appropriately assign inputs to outputs) • It is not necessary to use all of outputs of a decoder, or even to decode all possible input combinations • E.g., a BCD decoder decodes only first ten binary input combinations 0000-1001 to produce outputs Y0-Y9 Moslem Amiri, Václav Přenosil Design of Digital Systems II 5/69 Decoders: The 74x139 Dual 2-to-4 Decoder • 74x139 is a single MSI part containing two independent and identical 2-to-4 decoders 6/69 Decoders: The 74x139 Dual 2-to-4 Decoder 1G 1Y0 1Y1 1A 1Y2 1B 1Y3 2G 2Y0 2Y1 2A 2Y2 2B 2Y3 G YO Y1 A Y2 B Y3 2A <-|> Figure 3: The 74x139 dual 2-to-4 decoder: (a) logic diagram, including pin numbers for a standard 16-pin dual in-line package; (b) traditional logic symbol; (c) logic symbol for one decoder. 7/69 Moslem Amiri, Václav Přenosi Decoders: The 74x139 Dual 2-to-4 Decoder • Outputs and enable input of '139 are active-low • Inverting gates are generally faster than noninverting ones • '139 has extra inverters on its select inputs • Without these inverters, each select input would present three AC or DC loads instead of one, consuming much more of fanout budget of device that drives it Table 2: Truth table for one-half of a 74x139 dual 2-to-4 decoder. Inputs Outputs G_L B A Y3_L Y2_L Y1_L YCLL 1 X X 1 1 1 1 0 0 0 1 1 1 0 0 0 1 1 1 0 1 0 1 0 1 0 1 1 0 1 1 0 1 1 1 Moslem Amiri, Václav Přenosil Design of Digital Systems II 8/69 Decoders: The 74x138 3-to-8 Decoder Figure 4: The 74x138 3-to-8 decoder: (a) logic diagram, including pin numbers for a standard 16-pin dual in-line package; (b) traditional logic symbol. 9/69 Decoders: The 74x138 3-to-8 Decoder Table 3: Truth table for a 74x138 3-to-8 decoder. Inputs Outputs Gl G2A_L G2EĽL C B A Y7_L Y6-L Y5-L Y4_L Y3-L Y2_L Y1_L Y0_L 0 X X X x x 1 1 1 1 1 1 1 1 X 1 X X x x 1 1 1 1 1 1 1 1 X X 1 X x x 1 1 1 1 1 1 1 1 1 0 0 0 0 0 1 1 1 1 1 1 1 1 0 0 0 0 1 1 1 1 1 1 1 1 1 0 0 0 1 0 1 1 1 1 1 1 1 1 0 0 0 1 1 1 1 1 1 1 1 1 1 0 0 1 0 0 1 1 1 1 1 1 1 1 0 0 1 0 1 1 1 1 1 1 1 1 1 0 0 1 1 0 1 0 1 1 1 1 1 1 1 0 0 1 1 1 0 1 1 1 1 1 1 1 Moslem Amiri, Václav Přenosil Design of Digital Systems II 10 / 69 Decoders: Cascading Binary Decoders • Multiple binary decoders can be used to decode larger code words Figure 5: Design of a 4-to-16 decoder using 74x138s. 11/69 Decoders: Cascading Binary Decoders • To handle larger code words, binary decoders can be cascaded hierarchically 12 / 69 Decoders: Cascading Binary Decoders - DEC24_L DEC25_L DEC2B_L - DEC27_L - DEC2S_L - DEC29_L - DEC31_L Figure 6: Design of a 5-to-32 decoder using 74x138s and a 74x139. 13 / 69 Decoders in Verilog Table 4: Structural-style Verilog module for the decoder in Fig. 2. module Vr2to4dec(I0, II, EN, YO, Yl, Y2, Y3); input 10, II, EN; output YO, Yl, Y2, Y3; wire N0TI0, N0TI1; INV Ul (NOTIO, 10); INV U2 (MOTU, II) ; AND3 U3 (YO, NOTIO, MOTH, EN) AND3 U4 (Yl, 10, N0TI1, EN) AND3 U5 (Y2, NOTIO, II, EN) AND3 U6 (Y3, 10, II, EN) endmodule 2-to-4 decoder 10—p n_|-[>0- 10' 10 ir n EN Y2 EN Y3 ==d- Moslem Amiri, Václav Přenosil Design of Digital Systems II November, 2012 14 / 69 Decoders in Verilog Table 5: Functional-style Verilog module for a 74xl38-like 3-to-8 binary decoder. module Vr74xl38a(Gl, G2A_L, input Gl, G2A_L, G2B_L; input [2:0] A; output [0:7] Y_L; reg [0:7] Y_L; G2B_L, A, Y_L) ; always @ (Gl or G2A_L or G2B_L or A) begin if (Gl it ~G2A_L & ~G2B_L) case (A) 0: Y_L = 1: Y_L = 2: Y_L = 3: Y_L = 4: Y_L = 5: Y_L = 6: Y_L = 7: Y_L = default: endcase else Y_L = 8'bllllllll end endmodule 8'b01111111; 8'blOllllll; B'bllOlllll; 8'blllOllll; 8'bllllOlll; 8'blllll011; 8'bllllll01; 8'blllllllO; Y.L = S'bllllllll; Moslem Amiri, Václav Přenosi Design of Digital Systems II 15 / 69 Decoders in Verilog • In Tab. 5 • Constants and inversions that handle the fact that two inputs and all outputs are active low are scattered throughout the code • While its true that most Verilog programs are written almost entirely with active-high signals, if we are defining a device with active-low external pins, we should handle them in a more systematic and easily maintainable way • Tab. 6 • Decoder function is defined in terms of only active-high signals • The design can be easily modified in just a few well-defined places if changes are required in external active levels Moslem Amiri, Václav Přenosi Design of Digital Systems II 16 / 69 Decoders in Verilog Table 6: Verilog module with a maintainable approach to active-level handling. module Vr74xl38MGl, G2A_L, Input Gl, G2A_L, G2B_L; input [2:0] A; output [0:7] Y_L; reg G2A.G2B; reg [0:7] Y_L, Y; G2B_L, A, Y_L) ; always 3 (Gl or G2A_L or G2B_L or A or Y) begin G2A = ~G2A_L; // Convert inputs G2B = ~G2B_L; Y_L = ~Y; if (Gl & G2A & // Convert outputs G2B) case (A) 0 Y - í 'blOOOOOOO 1 Y = £ 'bOlOOOOOO 2 Y = ( 'bOOlOOOOO 3 Y = £ 'bOOOlOOOO 4 Y = ( 'bOOOOlOOO 5 Y = ( 'bOOOOOlOO 6 Y = í 'bOOOOOOlO 7 Y - í 'bOOOOOOOl default Y = 8'bOOOOOOOO; endcase else Y = 8'bOOOOOOOO; end endmodule Moslem Amiri, Václav Přenosil Design of Digital Systems II 17 / 69 Decoders in Verilog Table 7: Hierarchical definition of 74xl38-like decoder with active-level handling. module Vr74xl38c(Gl, G2A_L, G2B_L, A, Y_L); input Gl, G2A_L, G2B_L; input [2:0] A; output [0:7] Y_L; Kire G2A.G2B; Mire [0:7] Y; assign G2A = ~G2A_L; // Convert inputs assign G2B = ~G2B_L; assign Y_L = ~Y; // Convert outputs Vr3to8deca Ul (Gl, G2A, G2B, A, Y); endmodule Table 8: Verilog functional definition of an active-high 3-to-8 decoder. module Vr3to8deca(Gl, G2, G3, A, Y); input Gl, G2, G3; input [2:0] A; output [0:7] Y; reg [0:7] Y; always 8 (Gl or G2 or G3 or A) begin ii (Gl St G2 k G3) case (A) 0: Y = 8'blOOOOOOO; 1: Y = 8'bOlOOOOOO; 2: Y = 8'bOOlOOOOO; 3: Y = 8'bOOOlOOOO; 4: Y = 8'bOOOOlOOO; 5: Y = 8'bOOOOOlOO; S: Y = 8'bOOOOOOlO; 7: Y = 8'bOOOOOOOl; default: Y = 8'bOOOOOOOO; endcase else Y = 8'bOOOOOOOO; end endmodule Moslem Amiri, Václav Přenosi Design of Digital Systems II 18 / 69 Decoders in Verilog module Vr74x138c G1 Y_L[0:7] G2A_L G2BL A[2:0] (a) (b) module Vr74x138c G1 G2A_L G2BL A[2:0] {Zr CZr module Vr3to8deca G2A G2B G1 G2 G3 A[2:0] Y[0:7] Y[0:7] Y_L[0:7] Figure 7: Verilog module 74x138c: (a) top level; (b) internal structure using module Vr3to8deca. Moslem Amiri, Václav Přenosí Design of Digital Systems II 19 / 69 Decoders in Verilog Table 9: Behavioral Verilog definition for a 3-to-8 decoder. module Vr3to8decb{Gl, G2, G3, A, Y); input Gl, G2, G3; input [2:0] A; output [0:7] Y; reg [0:7] Y; integer i; always 3 (Gl or G2 or G3 or A) begin Y = 8'bOOOOOOOO; if (Gl & G2 & G3) for (i=0; i<=7; i=i+l) if (i == A) Y[i] = 1; end endmodule Moslem Amiri, Václav Přenosi Design of Digital Systems II 20 / 69 Decoders: Seven-Segment Decoders • A seven-segment decoder has 4-bit BCD as its input code and "seven-segment code" as its output code a d (a) (b) Figure 8: Seven-segment display: (a) segment identification; (b) decimal digits. Moslem Amiri, Václav Přenosi Design of Digital Systems II 21 / 69 Decoders: Seven-Segment Decoders Figure 9: The 74x49 seven-segment decoder: (a) logic diagram, including pin numbers; (b) traditional logic symbol. 22 / 69 Decoders: Seven-Segment Decoders Table 10: Truth table for a 74x49 seven-segment decoder. Inputs Outputs BLL D c B A a b c d e f g 0 X x x x 0 0 0 0 0 0 0 1 0 0 0 0 1 1 1 1 1 1 0 1 0 0 0 1 0 1 1 0 0 0 0 1 0 0 1 0 1 1 0 1 1 0 1 1 0 0 1 1 1 1 1 1 0 0 1 1 0 1 0 0 0 1 1 0 0 1 1 1 0 1 0 1 1 0 1 1 0 1 1 1 0 1 1 0 0 0 1 1 1 1 1 1 0 1 1 1 1 1 1 0 0 0 1 1 0 0 0 1 1 1 1 1 1 1 1 1 0 0 1 1 1 1 0 0 1 1 1 1 0 1 0 0 0 0 1 1 0 1 1 1 0 1 1 0 0 1 1 0 0 1 1 1 1 0 0 0 1 0 0 0 1 1 1 1 1 0 1 1 0 0 1 0 1 1 1 1 1 1 0 0 0 0 1 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 Moslem Amiri, Václav Přenosil Design of Digital Systems II 23 / 69 Decoders: Seven-Segment Decoders • Each output of 74x49 is a minimal POS realization for corresponding segment, assuming don't-cares for non-decimal input combinations • INVERT-OR-AND structure used for each output is equivalent to an AND-OR-INVERT gate, which is a fast and compact structure to build in CMOS or TTL • Modern seven-segment display elements have decoders built into them • A 4-bit BCD word can be applied directly to device Moslem Amiri, Václav Přenosi Design of Digital Systems II 24 / 69 Decoders: Seven-Segment Decoders Table 11: Verilog program for a seven-segment decoder. module Vr7seg(A, B, C, D, EN, SEGA, SEGB, SEGC, SEGD, SEGE, SEGF, SEGG); input A, B, C, D, EN; output SEGA, SEGB, SEGC, SEGD, SEGE, SEGF, SEGG; reg SEGA, SEGB, SEGC, SEGD, SEGE, SEGF, SEGG; reg [1:7] SEGS; always @ (A or B or C or D or EN) begin if (EN) case ({D.C.B.A}) // Segment patterns abcdefg 0 SEGS = 7'bllllllO // 0 1 SEGS = 7'bOUOOOO // 1 2 SEGS = 7'bll01101 // 2 3 SEGS = 7'bllllOOl // 3 4 SEGS = 7'bOllOOll // 4 5 SEGS = 7'blOllOll // 5 6 SEGS = 7'bOOlllll // 6 7 SEGS = 7'blllOOOO // 7 8 SEGS = 7'blllllll // 8 9 SEGS = 7'blllOOll // 9 (no 'tail') (no 'tail') default SEGS = 7'bx; endcase else SEGS = 7'bO; {SEGA, SEGB, SEGC, SEGD, SEGE, SEGF, SEGG} = SEGS; end endmodule Moslem Amiri, Václav Přenosil Design of Digital Systems II 25 / 69 Encoders • If a device's output code has fewer bits than input code, it is called an encoder • Simplest encoder to build is a 2"-to-n or binary encoder • Its input code is l-out-of-2" code and its output code is n-bit binary 2" inputs < (a) Binary encoder YO Y1 n outputs (b) Figure 10: Binary encoder: (a) general structure; (b) 8-to-3 encoder. Moslem Amiri, Václav Přenosil Y0 = /1 + /3 + /5 + /7 Yl = 12 + 13 + 16 + 17 Y2 = 14 + 15 + 16 + 17 Design of Digital Systems II November, 2012 26 / 69 Encoders: Priority Encoders • Consider a system with 2" inputs, each of which indicates a request for service • This structure is often found in microprocessor input/output subsystems where inputs might be interrupt requests • Binary encoder works properly only if inputs are guaranteed to be asserted at most one at a time • If multiple requests can be made simultaneously, the encoder gives undesirable results Request encoder Requests for service ' REQ1 - REQ2- REQ3- Requestor's < ^ REQN- Figure 11: A system with 2" requestors, and a "request encoder" that indicates which request signal is asserted at any time. 27 / 69 Encoders: Priority Encoders • We assign priority to input lines, so that when multiple requests are asserted, encoder produces the number of the highest-priority requestor • Such a device is called priority encoder Priority encoder 17 16 A2 15 A1 14 AO 13 12 IDLE 11 10 Figure 12: Logic symbol for a generic 8-input priority encoder. 28 / 69 Encoders: Priority Encoders • Logic equations for priority encoder's outputs (Fig. 12) • Input 17 has the highest priority • Outputs A2-A0 contain number of the highest-priority asserted input • IDLE is asserted if no inputs are asserted • First we define eight intermediate variables H0-H7 • Using AV0-AV7, equations for A2-A0 are similar to ones for a binary encoder H7 = 17 H6 = 16 ■ 17' H5 = 15 ■ 16' ■ 17' HO — 10 ■ II' ■ 12' ■ 13' ■ 14' ■ 15' ■ 16' ■ 17' A2 = HA + H5 + H6 + H7 Al = H2 + AV3 + H6 + H7 AO = HI + AV3 + AV5 + AV7 /DZ.E = /0' • II' ■ 12' ■ 13' ■ I A' ■ 15' ■ 16' ■ 17' 29 / 69 Encoders: The 74x148 Priority Encoder • 74x148 is an MSI 8-input priority encoder 74x148 5. ' El 17 16 A2 15 A1 14 AO 13 12 GS 11 EO I0 Figure 13: Logic symbol for the 74x148 8-input priority encoder. Moslem Amiri, Václav Přenosil Design of Digital Systems II 30 / 69 Encoders: The 74x148 Priority Encoder Figure 14: Logic diagram for the 74x148 8-input priority encoder, including pin numbers for a standard 16-pin dual in-line package. 31 / 69 Encoders: The 74x148 Priority Encoder Table 12: Truth table for a 74x148 8-input priority encoder. Inputs Outputs ELL 10-L ll-L I2_L 13-L I4_L 15-L 16-L I7_L A2_L A1_L AO-L GS-L EO-L 1 X x x x x x x x 1 1 1 1 1 0 x x x x x x x 0 0 0 0 0 1 0 x x x x x x 0 1 0 0 1 0 1 0 x x x x x 0 1 1 0 1 0 0 1 0 x x x x 0 1 1 1 0 1 1 0 1 0 x x x 0 1 1 1 1 1 0 0 0 1 0 x x 0 1 1 1 1 1 1 0 1 0 1 0 x 0 1 1 1 1 1 1 1 1 0 0 1 0 0 1 1 1 1 1 1 1 1 1 1 0 1 0 1 1 1 1 1 1 1 1 1 1 1 1 0 Moslem Amiri, Václav Přenosil Design of Digital Systems II 32 / 69 Encoders: The 74x148 Priority Encoder • Instead of an IDLE output, '148 has a GS_L (Group Select) output • It is asserted when device is enabled and one or more of request inputs are asserted • EO_L signal is an enable output used for cascading • It is designed to be connected to ELL input of another '148 that handles lower-priority requests • EO_L is asserted if ELL is asserted but no request input is asserted; thus, a low-priority '148 may be enabled 33 / 69 Encoders: The 74x148 Priority Encoder Figure 15: Four 74x148s cascaded to handle 32 requests. Moslem Amiri, Václav Přenosil Design of Digital Systems II November, 2012 34 / 69 Encoders: The 74x148 Priority Encoder • In Fig. 15 • There are 32 request inputs and a 5-bit output, RA4-RA0, indicating the highest-priority requestor • Since A2-A0 outputs of at most one '148 will be enabled at any time, outputs of individual '148s can be ORed to produce RA2-RA0 • Individual GS_L outputs can be combined in a 4-to-2 encoder to produce RA4 and RA3 • RGS output is asserted if any GS output is asserted Moslem Amiri, Václav Přenosi Design of Digital Systems II 35 / 69 Encoders in Verilog Table 13: Behavioral Verilog module for a 74xl48-like 8-input priority encoder. module Vr74xl48(EI_L, I_L, A_L, EO_L, GS_L); input EI_L; input [7:0] I_L; output [2:0] A_L; output E0_L, GS_L; reg [7:0] I; reg [2:0] A, A_L; reg EI, E0_L, EO, GS_L, GS; integer j; always a (EI_L or EI or I_L or I or A or EO or GS) begin EI = ~EI_L; I = ~I_L; // convert inputs ED_L - "ED; GS_L - "GS; A_L = "A; // convert outputs ED = 1; GS = 0; A = 0; // default output values begin if (EI==0) EQ = 0; else for Cj=0; j<=7; j=j+l) // check low priority first if CI[j]—1) begin GS = 1; E0=0; A = j; end end end endmodule Moslem Amiri, Václav Přenosi Design of Digital Systems II November, 2012 36 / 69 Three-State Devices: Three-State Buffers • The most basic three-state device is a three-state buffer, often called a three-state driver ^ ^ ^ (a) (b) (c) (d) Figure 16: Various three-state buffers: (a) non-inverting, active-high enable; (b) non-inverting, active-low enable; (c) inverting, active-high enable; (d) inverting, active-low enable. • When enable input is asserted, device behaves like an ordinary buffer or inverter • When enable input is negated, device output floats • It goes to a high-impedance (Hi-Z), disconnected state and functionally behaves as if it were not even there • Three-state devices allow multiple sources to share a single "party line," as long as only one device talks on the line at a time Moslem Amiri, Václav Přenosil Design of Digital Systems II 37 / 69 Three-State Devices: Three-State Buffers 1-bit party line EN1 - /EN2 -/EN3 - SSRCO-SSRC1-SSRC2- Figure 17: Eight sources sharing a three-state party line. Moslem Amiri, Václav Přenosil Design of Digital Systems II November, 2012 38 / 69 Three-State Devices: Three-State Buffers • Three-state devices are designed so that they go into Hi-Z state faster than they come out of Hi-Z state • and tpHz are both less than tpzi_ and tpzH • If outputs of two three-state devices are connected to same party line, and we simultaneously disable one and enable other, the first device will get off party line before the second one gets on • If both devices were to drive party line at same time, and if both were trying to maintain opposite output values (0 and 1), then excessive current would flow and create noise in system (fighting) • Delays and timing skews in control circuits make it difficult to ensure that enable inputs of different three-state devices change simultaneously • Even when this is possible, a problem arises if three-state devices from different-speed logic families are connected to same party line • tpZL or tpZH of a fast device may be shorter than tpiz or tpnz of a slow one Moslem Amiri, Václav Přenosi Design of Digital Systems II 39 / 69 Three-State Devices: Three-State Buffers o The only safe way to use three-state devices is to design control logic that guarantees a dead time on party line during which no one is driving it • Dead time must be long enough to account for worst-case differences between turn-off and turn-on times of devices and for skews in three-state control signals »™ 7 XX Q xx i xx /EN2, /EN3 _J-\_^_pl_/~\_ s data ZS-SZEtSZBž-3Z3HH max(tpLZmax. tpHZmax) — ~- — min('pZLmin' 'pZHminl dead time Figure 18: Timing diagram for the three-state party line of Fig. 17. Moslem Amiri, Václav Přenosi Design of Digital Systems II November, 2012 40 / 69 Three-State Devices: SSI and MSI Three-State Buffers • Each of 74x125 and 74x126 contains four independent non-inverting three-state buffers in a 14-pin package (1) (13) (1) (13) 74x125 Figure 19: Pinouts of the 74x125 and 74x126 three-state buffers. Moslem Amiri, Václav Přenosi Design of Digital Systems II 41 / 69 Three-State Devices: SSI and MSI Three-State Buffers • Most party-line applications use a bus with more than one bit of data • E.g., in an 8-bit microprocessor system, data bus is eight bits wide, and peripheral devices place data on bus eight bits at a time • A peripheral device enables eight three-state drivers to drive bus, all at the same time • To reduce package size in wide-bus applications, MSI parts contain multiple three-state buffers with common enable inputs Moslem Amiri, Václav Přenosil Design of Digital Systems II 42 / 69 Three-State Devices: SSI and MSI Three-State Buffers Figure 20: The 74x541 octal three-state buffer: (a) logic diagram, including pin numbers for a standard 20-pin dual in-line package; (b) traditional logic symbol. 43 / 69 Three-State Devices: SSI and MSI Three-State Buffers Microprocessor DO D1 D2 D3 D4 D5 D6 D7 READ 0-INSEL1 0-INSEL2 0-INSEL3 3- -O 01 Input Port 1 User . nputs * A1 A2 A3 A4 A5 A6 A7 A8 Y2 Y3 Y4 Y5 Y6 Y7 Y8 -O 01 02 Input Port 2 User . nputs > A1 A2 A3 A4 A5 A6 A7 A8 Y1 Y2 Y3 Y4 Y5 Y6 Y7 Y8 DB[0:7] Figure 21: Using a 74x541 as a microprocessor input port. Moslem Amiri, Václav Přenosil Design of Digital Systems II November, 2012 44 / 69 Three-State Devices: SSI and MSI Three-State Buffers • In Fig. 21, microprocessor selects Input Port 1 (top 74x541) by asserting INSEL1 and requests a read operation by asserting READ • Selected 74x541 responds by driving microprocessor data bus with user-supplied input data • Other input ports may be selected when a different INSEL line is asserted along with READ • A bus transceiver contains pairs of three-state buffers connected in opposite directions between each pair of pins, so that data can be transferred in either direction • A bus transceiver is typically used between two bidirectional buses Moslem Amiri, Václav Přenosi Design of Digital Systems II 45 / 69 Three-State Devices: SSI and MSI Three-State Buffers Figure 22: The 74x245 octal three-state transceiver: (a) logic diagram; (b) traditional logic symbol. 46 / 69 Three-State Devices: SSI and MSI Three-State Buffers Figure 23: Bidirectional buses and transceiver operation. Moslem Amiri, Václav Přenosil Design of Digital Systems II November, 2012 47 / 69 Three-State Devices: SSI and MSI Three-State Buffers Table 14: Modes of operation for a pair of bidirectional buses. ENTFFLL ATOB Operation 0 0 Transfer data from a source on bus B to a destination on bus A 0 1 Transfer data from a source on bus A to a destination on bus B 1 X Transfer data on buses A and B independently Moslem Amiri, Václav Přenosil Design of Digital Systems II 48 / 69 Three-State Devices: Three-State Outputs in Verilog Table 15: Verilog module for a 74x541-like 8-bit three-state driver. module Vr74x540(Gl_L, G2_L, A, Y); input G1_L, G2_L; input [1:8] A; output [1:8] Y; assign Y = (~G1_L & ~G2_L) ? A : 8'bz; endmodule Moslem Amiri, Václav Přenosi Design of Digital Systems II 49 / 69 Three-State Devices: Three-State Outputs in Verilog Table 16: Verilog module for a 74x245-like 8-bit transceiver. module Vr74x245(G_L, DIR, A, B); input G_L, DIR; inout [1:8] A, B; assign A = (~G_L & "DIR) 7 B : 8'bz; assign B = (~G_L & DIR) 7 A : 8'bz; endmodule Moslem Amiri, Vaclav Přenosi Design of Digital Systems II 50 / 69 Table 17: Verilog module for a four-way, 8-bit bus transceiver. module VrXcvr4x8U, B, C, D, S, A0E_L, B0E_L, CQE_L, D0E_L, M0E_L) ; input [2:0] S; input A0E_L, BOE.L, C0E_L, DOE.L, KOE.L; inout [1:8] A, B, C, D; reg [1:8] ibus; always @ (A or B or C or D or S) begin if (S[2] == 0) ibus = {4{S[1:0]}>; else case CS[1:0]) 0: ibus = A; 1: ibus = B; 2: ibus = C; 3: ibus = D; endca.se end assign A assign B assign C assign D C("AQE_L ft ((~BGE_L & ((~C0E_L ft (C~D0E_L & MGE_L) &&