File reading and writing is a very useful thing to know in Verilog. The possibility to read test input values from files, and write output values for later verification makes testbench codes easy to write and understand.
There are few ways to read or write files in Verilog. I have already explained one method in my last post, File Reading and Writing in Verilog - Part 1. The method described in this new post will help you to read the contents of a file line by line, instead of reading everything together. This is helpful when the size of file is too big.
In this post, we will learn:
Verilog code for File Read and Write:
`timescale 1ns / 1ps
module tb();
reg [7:0] A; //register declaration for storing each line of file.
integer outfile0,outfile1,outfile2,outfile3; //file descriptors
initial begin
    
//The $fopen function opens a file and returns a multi-channel descriptor
//in the format of an unsized integer.
outfile0=$fopen("A_hex.txt","r"); //"r" means reading and "w" means writing
outfile1=$fopen("A_write_dec.txt","w");
outfile2=$fopen("A_write_bin.txt","w");
outfile3=$fopen("A_write_hex.txt","w");
    
//read the contents of the file A_hex.txt as hexadecimal values into register "A".
while (! $feof(outfile0)) begin //read until an "end of file" is reached.
$fscanf(outfile0,"%h\n",A); //scan each line and get the value as an hexadecimal
//Write the read value into text files.
$fdisplay(outfile1,"%d",A); //write as decimal
$fdisplay(outfile2,"%b",A); //write as binary
$fdisplay(outfile3,"%h",A); //write as hexadecimal
#10;
end
//once reading and writing is finished, close all the files.
$fclose(outfile0);
$fclose(outfile1);
$fclose(outfile2);
$fclose(outfile3);
//wait and then stop the simulation.
#100;
$stop;
end
      
endmodule
The above code is for reading a hexadecimal file and writing hex, binary and decimal numbers to a file. But with small changes we can make it read binary or decimal numbers too.
For Reading Binary numbers from the file,
There are few ways to read or write files in Verilog. I have already explained one method in my last post, File Reading and Writing in Verilog - Part 1. The method described in this new post will help you to read the contents of a file line by line, instead of reading everything together. This is helpful when the size of file is too big.
In this post, we will learn:
- How to read hexadecimal/binary/decimal values from a file using fopen and fscanf function.
- How to write a file with hexadecimal/binary/decimal values using fopen and fdisplay.
Verilog code for File Read and Write:
`timescale 1ns / 1ps
module tb();
reg [7:0] A; //register declaration for storing each line of file.
integer outfile0,outfile1,outfile2,outfile3; //file descriptors
initial begin
//The $fopen function opens a file and returns a multi-channel descriptor
//in the format of an unsized integer.
outfile0=$fopen("A_hex.txt","r"); //"r" means reading and "w" means writing
outfile1=$fopen("A_write_dec.txt","w");
outfile2=$fopen("A_write_bin.txt","w");
outfile3=$fopen("A_write_hex.txt","w");
//read the contents of the file A_hex.txt as hexadecimal values into register "A".
while (! $feof(outfile0)) begin //read until an "end of file" is reached.
$fscanf(outfile0,"%h\n",A); //scan each line and get the value as an hexadecimal
//Write the read value into text files.
$fdisplay(outfile1,"%d",A); //write as decimal
$fdisplay(outfile2,"%b",A); //write as binary
$fdisplay(outfile3,"%h",A); //write as hexadecimal
#10;
end
//once reading and writing is finished, close all the files.
$fclose(outfile0);
$fclose(outfile1);
$fclose(outfile2);
$fclose(outfile3);
//wait and then stop the simulation.
#100;
$stop;
end
endmodule
The above code is for reading a hexadecimal file and writing hex, binary and decimal numbers to a file. But with small changes we can make it read binary or decimal numbers too.
For Reading Binary numbers from the file,
Replace the line outfile0=$fopen("A_hex.txt","r");
with    outfile0=$fopen("A_bin.txt","r");     to change the name of the file.
Replace the line $fscanf(outfile0,"%h\n",A);
with    $fscanf(outfile0,"%b\n",A);     to change the type of data read from the file.
Similarly for Reading Decimal numbers from the file,
Similarly for Reading Decimal numbers from the file,
Replace the line outfile0=$fopen("A_hex.txt","r");
with    outfile0=$fopen("A_dec.txt","r");     to change the name of the file.
Replace the line $fscanf(outfile0,"%h\n",A);
with    $fscanf(outfile0,"%d\n",A);     to change the type of data read from the file.
 That's all! The output files should look the same in both the cases.
A screenshot of input files and output files is given below:
The input files can be downloaded from here,
The code was tested using Xilinx ISE 14.6 tool.

 
