70 lines
2.3 KiB
Systemverilog
70 lines
2.3 KiB
Systemverilog
`default_nettype none
|
|
|
|
|
|
module SevenSegmentControl(
|
|
input wire logic clk,
|
|
input wire logic reset,
|
|
input wire logic [15:0] dataIn,
|
|
input wire logic [3:0] digitDisplay,
|
|
input wire logic [3:0] digitPoint,
|
|
output logic [3:0] anode,
|
|
output logic [7:0] segment
|
|
);
|
|
|
|
parameter integer COUNT_BITS = 17;
|
|
|
|
logic [COUNT_BITS-1:0] count_val;
|
|
logic [1:0] anode_select;
|
|
logic [3:0] cur_anode;
|
|
logic [3:0] cur_data_in;
|
|
|
|
|
|
always_ff @(posedge clk) begin
|
|
if (reset)
|
|
count_val <= 0;
|
|
else
|
|
count_val <= count_val + 1;
|
|
end
|
|
|
|
assign anode_select = count_val[COUNT_BITS-1:COUNT_BITS-2];
|
|
|
|
assign cur_anode =
|
|
(anode_select == 2'b00) ? 4'b1110 :
|
|
(anode_select == 2'b01) ? 4'b1101 :
|
|
(anode_select == 2'b10) ? 4'b1011 :
|
|
4'b0111;
|
|
|
|
assign anode = cur_anode | (~digitDisplay);
|
|
|
|
assign cur_data_in =
|
|
(anode_select == 2'b00) ? dataIn[3:0] :
|
|
(anode_select == 2'b01) ? dataIn[7:4] :
|
|
(anode_select == 2'b10) ? dataIn[11:8] :
|
|
dataIn[15:12] ;
|
|
|
|
assign segment[7] =
|
|
(anode_select == 2'b00) ? ~digitPoint[0] :
|
|
(anode_select == 2'b01) ? ~digitPoint[1] :
|
|
(anode_select == 2'b10) ? ~digitPoint[2] :
|
|
~digitPoint[3] ;
|
|
|
|
assign segment[6:0] =
|
|
(cur_data_in == 0) ? 7'b1000000 :
|
|
(cur_data_in == 1) ? 7'b1111001 :
|
|
(cur_data_in == 2) ? 7'b0100100 :
|
|
(cur_data_in == 3) ? 7'b0110000 :
|
|
(cur_data_in == 4) ? 7'b0011001 :
|
|
(cur_data_in == 5) ? 7'b0010010 :
|
|
(cur_data_in == 6) ? 7'b0000010 :
|
|
(cur_data_in == 7) ? 7'b1111000 :
|
|
(cur_data_in == 8) ? 7'b0000000 :
|
|
(cur_data_in == 9) ? 7'b0010000 :
|
|
(cur_data_in == 10) ? 7'b0001000 :
|
|
(cur_data_in == 11) ? 7'b0000011 :
|
|
(cur_data_in == 12) ? 7'b1000110 :
|
|
(cur_data_in == 13) ? 7'b0100001 :
|
|
(cur_data_in == 14) ? 7'b0000110 :
|
|
7'b0001110;
|
|
|
|
|
|
endmodule |