summaryrefslogtreecommitdiff
path: root/projects/01/Mux.hdl
blob: 7a27aa963605d3e1aaa9f9a9dd1d43722a862fb2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
// This file is part of www.nand2tetris.org
// and the book "The Elements of Computing Systems"
// by Nisan and Schocken, MIT Press.
// File name: projects/01/Mux.hdl

/** 
 * Multiplexor:
 * out = a if sel == 0
 *       b otherwise
 */

CHIP Mux {
    IN a, b, sel;
    OUT out;

    PARTS:
    Not(in=sel, out=notsel);
    And(a=a, b=notsel, out=maska);
    And(a=b, b=sel, out=maskb);
    Or(a=maska, b=maskb, out=out);
}