Modelsim reading riting and rithmetic

B

Brad Smallridge

The code below is cut from a testbench I wrote that reads the header of a
BMP file, and writes another BMP file as output. I have tried to shorten
this code by putting the file reading, file writing, multiply and add in a
separate function, however I get an error saying that the read / write are
not somehow doable in a "pure" function. Obviously something is not going
on the way I expect a VHDL function to run like a string of operations like
in C.
Can somebody show me a readable and concise way of doing this?

Thanks,
Brad Smallridge

-- the next 4 bytes are the file size
read (my_file, my_char_v);
write(my_file2,my_char_v);
file_size := character'pos(my_char_v);

read (my_file, my_char_v);
write(my_file2,my_char_v);
file_size := file_size+ 256*(character'pos(my_char_v));

read (my_file, my_char_v);
write(my_file2,my_char_v);
file_size := file_size+ 256*256*(character'pos(my_char_v));

read (my_file, my_char_v);
write(my_file2,my_char_v);
file_size := file_size+ 256*256*256*(character'pos(my_char_v));

ETC. ETC. ETC. Very verbose.
 
R

rickman

I am no expert, but it seems that a PURE subroutine is one that does not
explicitly access signals and such. Are you using signals or files
without passing them into the function? Or can you just declare the
function as IMPURE?

How about an example of the function?


Brad said:
The code below is cut from a testbench I wrote that reads the header of a
BMP file, and writes another BMP file as output. I have tried to shorten
this code by putting the file reading, file writing, multiply and add in a
separate function, however I get an error saying that the read / write are
not somehow doable in a "pure" function. Obviously something is not going
on the way I expect a VHDL function to run like a string of operations like
in C.
Can somebody show me a readable and concise way of doing this?

Thanks,
Brad Smallridge

-- the next 4 bytes are the file size
read (my_file, my_char_v);
write(my_file2,my_char_v);
file_size := character'pos(my_char_v);

read (my_file, my_char_v);
write(my_file2,my_char_v);
file_size := file_size+ 256*(character'pos(my_char_v));

read (my_file, my_char_v);
write(my_file2,my_char_v);
file_size := file_size+ 256*256*(character'pos(my_char_v));

read (my_file, my_char_v);
write(my_file2,my_char_v);
file_size := file_size+ 256*256*256*(character'pos(my_char_v));

ETC. ETC. ETC. Very verbose.

--

Rick "rickman" Collins

(e-mail address removed)
Ignore the reply address. To email me use the above address with the XY
removed.

Arius - A Signal Processing Solutions Company
Specializing in DSP and FPGA design URL http://www.arius.com
4 King Ave 301-682-7772 Voice
Frederick, MD 21701-3110 301-682-7666 FAX
 
B

Brad Smallridge

I suspect that Modelsim complained because the files are opened and closed
in the main body of the testbench and not in the function. So the function
doesn't know about the files. I did not know that I could declare a
function as IMPURE. I would show you the function but it has been awhile, I
had it working the verbose way, and I can't find it now. I am not sure if
a function is the way to go.
 
M

Mike Treseler

Brad said:
The code below is cut from a testbench I wrote that reads the header of a
BMP file, and writes another BMP file as output. I have tried to shorten
this code by putting the file reading, file writing, multiply and add in a
separate function, however I get an error saying that the read / write are
not somehow doable in a "pure" function.

A plain function cannot read or write files.
Consider a procedure or impure function.

-- Mike Treseler
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

No members online now.

Forum statistics

Threads
474,164
Messages
2,570,898
Members
47,439
Latest member
shasuze

Latest Threads

Top