forked from cores/microwatt
55 lines
1.4 KiB
VHDL
55 lines
1.4 KiB
VHDL
library ieee;
|
|
use ieee.std_logic_1164.all;
|
|
|
|
library work;
|
|
use work.common.all;
|
|
|
|
package crhelpers is
|
|
function fxm_to_num(fxm: std_ulogic_vector(7 downto 0)) return integer;
|
|
function num_to_fxm(num: integer) return std_ulogic_vector;
|
|
end package crhelpers;
|
|
|
|
package body crhelpers is
|
|
|
|
function fxm_to_num(fxm: std_ulogic_vector(7 downto 0)) return integer is
|
|
begin
|
|
-- If multiple fields are set (undefined), match existing
|
|
-- hardware by returning the first one.
|
|
for i in 0 to 7 loop
|
|
-- Big endian bit numbering
|
|
if fxm(7-i) = '1' then
|
|
return i;
|
|
end if;
|
|
end loop;
|
|
|
|
-- If no fields are set (undefined), also match existing
|
|
-- hardware by returning cr7.
|
|
return 7;
|
|
end;
|
|
|
|
function num_to_fxm(num: integer) return std_ulogic_vector is
|
|
begin
|
|
case num is
|
|
when 0 =>
|
|
return "10000000";
|
|
when 1 =>
|
|
return "01000000";
|
|
when 2 =>
|
|
return "00100000";
|
|
when 3 =>
|
|
return "00010000";
|
|
when 4 =>
|
|
return "00001000";
|
|
when 5 =>
|
|
return "00000100";
|
|
when 6 =>
|
|
return "00000010";
|
|
when 7 =>
|
|
return "00000001";
|
|
when others =>
|
|
return "00000000";
|
|
end case;
|
|
end;
|
|
|
|
end package body crhelpers;
|