module binary_to_bcd #( parameter BINARY_WIDTH = 8, // e.g., 8-bit binary input parameter BCD_DIGITS = 3 // 8-bit binary max = 255 → 3 BCD digits )( input wire [BINARY_WIDTH-1:0] binary, output reg [4*BCD_DIGITS-1:0] bcd ); integer i; reg [4*BCD_DIGITS-1:0] temp; reg [BINARY_WIDTH-1:0] bin;
for (i = 0; i < BIN_WIDTH; i = i + 1) begin // Shift left bcd_reg = bcd_reg[4*BCD_DIGITS-2:0], bin_reg[BIN_WIDTH-1]; bin_reg = bin_reg[BIN_WIDTH-2:0], 1'b0;
always @(*) begin bcd_reg = 0; bin_reg = bin;
bin2bcd #(.BIN_WIDTH(8), .BCD_DIGITS(3)) uut ( .bin(binary), .bcd(bcd) );
// Add 3 to digits > 4 for (j = 0; j < BCD_DIGITS; j = j + 1) begin if (bcd_reg[4*j +: 4] > 4) bcd_reg[4*j +: 4] = bcd_reg[4*j +: 4] + 3; end end
bcd = bcd_reg; end endmodule module tb_bin2bcd; reg [7:0] binary; wire [11:0] bcd;
module binary_to_bcd #( parameter BINARY_WIDTH = 8, // e.g., 8-bit binary input parameter BCD_DIGITS = 3 // 8-bit binary max = 255 → 3 BCD digits )( input wire [BINARY_WIDTH-1:0] binary, output reg [4*BCD_DIGITS-1:0] bcd ); integer i; reg [4*BCD_DIGITS-1:0] temp; reg [BINARY_WIDTH-1:0] bin; Binary To Bcd Verilog Code
for (i = 0; i < BIN_WIDTH; i = i + 1) begin // Shift left bcd_reg = bcd_reg[4*BCD_DIGITS-2:0], bin_reg[BIN_WIDTH-1]; bin_reg = bin_reg[BIN_WIDTH-2:0], 1'b0; module binary_to_bcd #( parameter BINARY_WIDTH = 8, // e
always @(*) begin bcd_reg = 0; bin_reg = bin; output reg [4*BCD_DIGITS-1:0] bcd )
bin2bcd #(.BIN_WIDTH(8), .BCD_DIGITS(3)) uut ( .bin(binary), .bcd(bcd) );
// Add 3 to digits > 4 for (j = 0; j < BCD_DIGITS; j = j + 1) begin if (bcd_reg[4*j +: 4] > 4) bcd_reg[4*j +: 4] = bcd_reg[4*j +: 4] + 3; end end
bcd = bcd_reg; end endmodule module tb_bin2bcd; reg [7:0] binary; wire [11:0] bcd;