0
mirror of https://gitlab.com/hyperglitch/jellyfish.git synced 2025-11-09 21:27:59 +00:00
2025-03-09 00:37:34 +01:00

30 lines
952 B
Verilog

// SPDX-FileCopyrightText: 2025 Igor Brkic <igor@hyperglitch.com>
// SPDX-License-Identifier: GPL-3.0-or-later
module demux8
(
input [2:0] i_sel,
input i_in,
input i_en,
output reg o_out0,
output reg o_out1,
output reg o_out2,
output reg o_out3,
output reg o_out4,
output reg o_out5,
output reg o_out6,
output reg o_out7
);
assign o_out0 = !i_sel[2] & !i_sel[1] & !i_sel[0] & i_en ? i_in : 1'b0;
assign o_out1 = !i_sel[2] & !i_sel[1] & i_sel[0] & i_en ? i_in : 1'b0;
assign o_out2 = !i_sel[2] & i_sel[1] & !i_sel[0] & i_en ? i_in : 1'b0;
assign o_out3 = !i_sel[2] & i_sel[1] & i_sel[0] & i_en ? i_in : 1'b0;
assign o_out4 = i_sel[2] & !i_sel[1] & !i_sel[0] & i_en ? i_in : 1'b0;
assign o_out5 = i_sel[2] & !i_sel[1] & i_sel[0] & i_en ? i_in : 1'b0;
assign o_out6 = i_sel[2] & i_sel[1] & !i_sel[0] & i_en ? i_in : 1'b0;
assign o_out7 = i_sel[2] & i_sel[1] & i_sel[0] & i_en ? i_in : 1'b0;
endmodule