Howdy, Stranger!

It looks like you're new here. If you want to get involved, click one of these buttons!


Welcome to the new platform of Programmer's Heaven! We apologize for the inconvenience caused, if you visited us from a broken link of the previous version. The main reason to move to a new platform is to provide more effective and collaborative experience to you all. Please feel free to experience the new platform and use its exciting features. Contact us for any issue that you need to get clarified. We are more than happy to help you.

Type mismatch error in vhdl

Greetings! This is my first thread.

I have a package that contains the following type:

[code]type t_rgb_64x48 is array(0 to 47) of std_logic_vector(63 downto 0);[/code]

and is being used in my file.vhd file.


file.vhd contains an entity that contains the type of the package mentioned earlier:

[code]RData_in : in t_rgb_64x48;
ColumnAddress_Start : in integer;
ColumnAddress_End : in integer;
RowAddress_Start : in integer;
RowAddress_End : in integer;[/code]

It also contains a signal with its corresponding type:

[code]type t_vgaram is array(0 to 479) of std_logic_vector(639 downto 0);
signal s_rstorage : t_vgaram;

I need to access s_rstorage through the following statement:

[code]s_rstorage(ColumnAddress_End downto ColumnAddress_Start)
(RowAddress_End downto RowAddress_Start)
<= RData_in(ColumnAddress_End downto
(RowAddress_End downto RowAddress_Start);
to store the value of RData_in to s_rstorage and making sure that they are of the same width in 2D.

The problem is this error:

[code]Type of s_rstorage is incompatible with type of RData_in.[/code]

I know that they have different types as the cause of the error. But how do I fix this problem?
Sign In or Register to comment.