mirror of
https://github.com/pConst/basic_verilog.git
synced 2025-01-14 06:42:54 +08:00
38 lines
914 B
Systemverilog
38 lines
914 B
Systemverilog
|
//------------------------------------------------------------------------------
|
||
|
// hex2ascii.sv
|
||
|
// published as part of https://github.com/pConst/basic_verilog
|
||
|
// Konstantin Pavlov, pavlovconst@gmail.com
|
||
|
//------------------------------------------------------------------------------
|
||
|
|
||
|
// INFO ------------------------------------------------------------------------
|
||
|
// Converts 4-bit binary nibble to 8-bit human-readable ASCII char
|
||
|
// For example, 4'b1111 befomes an "F" char, 4'b0100 becomes "4" char
|
||
|
//
|
||
|
|
||
|
|
||
|
/* --- INSTANTIATION TEMPLATE BEGIN ---
|
||
|
|
||
|
hex2ascii HA (
|
||
|
.hex( ),
|
||
|
.ascii( )
|
||
|
);
|
||
|
|
||
|
--- INSTANTIATION TEMPLATE END ---*/
|
||
|
|
||
|
|
||
|
module hex2ascii (
|
||
|
input [3:0] hex,
|
||
|
output [7:0] ascii
|
||
|
);
|
||
|
|
||
|
always_comb begin
|
||
|
if( hex[3:0] < 4'hA ) begin
|
||
|
ascii[7:0] = hex[3:0] + 8'd48; // 0 hex -> 48 ascii
|
||
|
end else begin
|
||
|
ascii[7:0] = hex[3:0] + 8'd55; // A hex -> 65 ascii
|
||
|
end
|
||
|
end
|
||
|
|
||
|
endmodule
|
||
|
|