2023-01-01 22:28:56 +00:00
|
|
|
`timescale 1ns / 1ps
|
|
|
|
|
|
|
|
// 2**N to N Priority encoder
|
|
|
|
module PriorityEncoder #(
|
2023-01-29 04:55:22 +00:00
|
|
|
parameter int N = 4
|
|
|
|
) (
|
|
|
|
input logic [2**N - 1:0] data_in,
|
|
|
|
output logic [N - 1:0] data_out,
|
2023-01-01 22:28:56 +00:00
|
|
|
output logic valid
|
|
|
|
);
|
2023-01-29 04:55:22 +00:00
|
|
|
always_comb begin
|
2023-02-01 16:20:37 +00:00
|
|
|
data_out = 3'dx;
|
2023-01-29 04:55:22 +00:00
|
|
|
for (int i = 0; i < 2 ** N; i++) begin
|
2023-02-01 16:20:37 +00:00
|
|
|
if (data_in[i]) data_out = i[N-1:0];
|
2023-01-01 22:28:56 +00:00
|
|
|
end
|
2023-01-29 04:55:22 +00:00
|
|
|
if (data_in == 0) valid = 0;
|
|
|
|
else valid = 1;
|
|
|
|
end
|
2023-01-01 22:28:56 +00:00
|
|
|
endmodule
|