📄 fixed_synth.vhdl
字号:
end loop jcloop; j1loop : for j in 3 downto 1 loop in1array (j) := in1array(j-1); end loop j1loop; j2loop : for j in 3 downto 1 loop in2array (j) := in2array(j-1); end loop j2loop; in1array(0) := in1reg3; in2array(0) := in2reg3; tmp := to_slv (in2array(3)(in2reg3'high downto in2reg3'high-1)); if (tmp = "00") then -- Signed to sfixed and back tmpsig := to_signed (in1array(3), tmpsig'length); outarray(0) := to_sfixed (tmpsig, outarray(0)); elsif (tmp = "01") then -- unsigned to ufixed and back tmpuns := to_unsigned (ufixed(in1array(3)), tmpuns'length); outarray(0) := sfixed(to_ufixed (tmpuns, outarray(0)'high, outarray(0)'low)); elsif (tmp = "10") then tmpint := to_integer (in1array(3)); outarray(0) := to_sfixed (tmpint, outarray(0)); else tmpint := to_integer (ufixed(in1array(3))); outarray(0) := sfixed(to_ufixed (tmpint, outarray(0)'high, outarray(0)'low)); end if; end if; end process cmd9reg; -- purpose: "1010" test the reciprocal, abs, - test cmd10reg : process (clk, rst_n) is variable tmp : STD_LOGIC_VECTOR (1 downto 0); -- temp variable in1recip : sfixed (-in1reg3'low+1 downto -in1reg3'high); variable uin1recip : ufixed (-in1reg3'low downto -in1reg3'high-1); variable in1pin2 : sfixed (SFixed_high(7, -8, '+', 7, -8) downto SFixed_low(7, -8, '+', 7, -8)); variable outarray : cry_type; -- array for output variable in1array, in2array : cry_type; -- array for input begin -- process cmd0reg if rst_n = '0' then -- asynchronous reset (active low) outarray10 <= (others => '0'); jrloop : for j in 0 to 4 loop outarray (j) := (others => '0'); in1array (j) := to_sfixed(1, in1reg3); in2array (j) := (others => '0'); end loop jrloop; elsif rising_edge(clk) then -- rising clock edge outarray10 <= outarray(4); jcloop : for j in 4 downto 1 loop outarray (j) := outarray(j-1); end loop jcloop; j1loop : for j in 3 downto 1 loop in1array (j) := in1array(j-1); end loop j1loop; j2loop : for j in 3 downto 1 loop in2array (j) := in2array(j-1); end loop j2loop; if (in1reg3 = 0) then in1array(0) := to_sfixed(1, in1reg3); else in1array(0) := in1reg3; end if; in2array(0) := in2reg3; tmp := to_slv (in2array(3)(in2reg3'high downto in2reg3'high-1)); if (tmp = "00") then in1recip := reciprocal (in1array(3)); outarray(0) := resize (in1recip, outarray(0)'high, outarray(0)'low); elsif (tmp = "01") then uin1recip := reciprocal (ufixed(in1array(3))); outarray(0) := sfixed(resize (uin1recip, outarray(0)'high, outarray(0)'low)); elsif (tmp = "10") then -- abs in1pin2 := abs(in1array(3)); outarray(0) := resize (in1pin2, outarray(0)'high, outarray(0)'low); else -- - in1pin2 := - in1array(3); outarray(0) := resize (in1pin2, outarray(0)'high, outarray(0)'low); end if; end if; end process cmd10reg; -- purpose: "1011" test the mod operator cmd11reg : process (clk, rst_n) is variable in1min2 : sfixed (SFixed_high(7, -8, 'M', 7, -8) downto SFixed_low(7, -8, 'm', 7, -8)); variable outarray : cry_type; -- array for output variable in1array, in2array : cry_type; -- array for input begin -- process cmd0reg if rst_n = '0' then -- asynchronous reset (active low) outarray11 <= (others => '0'); jrloop : for j in 0 to 4 loop outarray (j) := (others => '0'); in1array (j) := (others => '0'); in2array (j) := to_sfixed(1, in2array(0)); end loop jrloop; elsif rising_edge(clk) then -- rising clock edge outarray11 <= outarray(4); jcloop : for j in 4 downto 1 loop outarray (j) := outarray(j-1); end loop jcloop; j1loop : for j in 3 downto 1 loop in1array (j) := in1array(j-1); end loop j1loop; j2loop : for j in 3 downto 1 loop in2array (j) := in2array(j-1); end loop j2loop; in1array(0) := in1reg3; if (in2reg3 = 0) then in2array(0) := to_sfixed(1, in2array(0)); else in2array(0) := in2reg3; end if; in1min2 := in1array(3) mod in2array(3); outarray(0) := resize (in1min2, outarray(0)); end if; end process cmd11reg; -- purpose: "1100" test the rem operator cmd12reg : process (clk, rst_n) is variable in1min2 : sfixed (SFixed_high(7, -8, 'R', 7, -8) downto SFixed_low(7, -8, 'r', 7, -8)); variable outarray : cry_type; -- array for output variable in1array, in2array : cry_type; -- array for input begin -- process cmd0reg if rst_n = '0' then -- asynchronous reset (active low) outarray12 <= (others => '0'); jrloop : for j in 0 to 4 loop outarray (j) := (others => '0'); in1array (j) := (others => '0'); in2array (j) := to_sfixed(1, in2array(0)); end loop jrloop; elsif rising_edge(clk) then -- rising clock edge outarray12 <= outarray(4); jcloop : for j in 4 downto 1 loop outarray (j) := outarray(j-1); end loop jcloop; j1loop : for j in 3 downto 1 loop in1array (j) := in1array(j-1); end loop j1loop; j2loop : for j in 3 downto 1 loop in2array (j) := in2array(j-1); end loop j2loop; in1array(0) := in1reg3; if (in2reg3 = 0) then in2array(0) := to_sfixed(1, in2array(0)); else in2array(0) := in2reg3; end if; in1min2 := in1array(3) rem in2array(3); outarray(0) := resize (in1min2, outarray(0)); end if; end process cmd12reg; -- purpose: "1101" test the srl operator cmd13reg : process (clk, rst_n) is variable outarray : cry_type; -- array for output variable in1array, in2array : cry_type; -- array for input begin -- process cmd0reg if rst_n = '0' then -- asynchronous reset (active low) outarray13 <= (others => '0'); jrloop : for j in 0 to 4 loop outarray (j) := (others => '0'); in1array (j) := (others => '0'); in2array (j) := (others => '0'); end loop jrloop; elsif rising_edge(clk) then -- rising clock edge outarray13 <= outarray(4); jcloop : for j in 4 downto 1 loop outarray (j) := outarray(j-1); end loop jcloop; j1loop : for j in 3 downto 1 loop in1array (j) := in1array(j-1); end loop j1loop; j2loop : for j in 3 downto 1 loop in2array (j) := in2array(j-1); end loop j2loop; in1array(0) := in1reg3; in2array(0) := in2reg3; outarray(0) := in1array(3) srl to_integer(in2array(3)); end if; end process cmd13reg; -- purpose: "1110" test the sra operator cmd14reg : process (clk, rst_n) is variable outarray : cry_type; -- array for output variable in1array, in2array : cry_type; -- array for input begin -- process cmd0reg if rst_n = '0' then -- asynchronous reset (active low) outarray14 <= (others => '0'); jrloop : for j in 0 to 4 loop outarray (j) := (others => '0'); in1array (j) := (others => '0'); in2array (j) := (others => '0'); end loop jrloop; elsif rising_edge(clk) then -- rising clock edge outarray14 <= outarray(4); jcloop : for j in 4 downto 1 loop outarray (j) := outarray(j-1); end loop jcloop; j1loop : for j in 3 downto 1 loop in1array (j) := in1array(j-1); end loop j1loop; j2loop : for j in 3 downto 1 loop in2array (j) := in2array(j-1); end loop j2loop; in1array(0) := in1reg3; in2array(0) := in2reg3; outarray(0) := in1array(3) sra to_integer(in2array(3)); end if; end process cmd14reg; -- purpose: "1111" test the sra operator cmd15reg : process (clk, rst_n) is constant match_data : sfixed16 := "01HL----10HL----"; -- for ?= command variable outarray : cry_type; -- array for output variable in1array, in2array : cry_type; -- array for input begin -- process cmd0reg if rst_n = '0' then -- asynchronous reset (active low) outarray15 <= (others => '0'); jrloop : for j in 0 to 4 loop outarray (j) := (others => '0'); in1array (j) := (others => '0'); in2array (j) := (others => '0'); end loop jrloop; elsif rising_edge(clk) then -- rising clock edge outarray15 <= outarray(4); jcloop : for j in 4 downto 1 loop outarray (j) := outarray(j-1); end loop jcloop; j1loop : for j in 3 downto 1 loop in1array (j) := in1array(j-1); end loop j1loop; j2loop : for j in 3 downto 1 loop in2array (j) := in2array(j-1); end loop j2loop; in1array(0) := in1reg3; in2array(0) := in2reg3; -- compare test if (in1array(3) = in2array(3)) then outarray(0)(-8) := '1'; else outarray(0)(-8) := '0'; end if; if (in1array(3) /= in2array(3)) then outarray(0)(-7) := '1'; else outarray(0)(-7) := '0'; end if; if (in1array(3) < in2array(3)) then outarray(0)(-6) := '1'; else outarray(0)(-6) := '0'; end if; if (in1array(3) > in2array(3)) then outarray(0)(-5) := '1'; else outarray(0)(-5) := '0'; end if; if (in1array(3) <= in2array(3)) then outarray(0)(-4) := '1'; else outarray(0)(-4) := '0'; end if; if (in1array(3) >= in2array(3)) then outarray(0)(-3) := '1'; else outarray(0)(-3) := '0'; end if; if (in1array(3) = 45) then outarray(0)(-2) := '1'; else outarray(0)(-2) := '0'; end if; if (in1array(3) = 3.125) then outarray(0)(-1) := '1'; else outarray(0)(-1) := '0'; end if; -- add integer and real outarray(0)(0) := \?=\ (in1array(3), in2array(3) + 45); if (in1array(3) = in2array(3) + 3.125) then outarray(0)(1) := '1'; else outarray(0)(1) := '0'; end if; if (std_match (in1array(3), match_data)) then outarray(0)(2) := '1'; else outarray(0)(2) := '0'; end if; outarray(0)(3) := nor_reduce (in1array(3) or in2array(3)); outarray(0)(4) := xnor_reduce (in1array(3) xor in2array(3)); outarray(0)(5) := nand_reduce (not in1array(3)); outarray(0)(6) := or_reduce ('1' and ufixed(in1array(3))); if find_leftmost(in1array(3), '1') = 3 then outarray(0)(7) := '1'; else outarray(0)(7) := '0'; end if; end if; end process cmd15reg; -- purpose: register the inputs and the outputs -- type : sequential -- inputs : clk, rst_n, in1, in2 -- outputs: out1 cmdreg : process (clk, rst_n) is variable outreg : sfixed16; -- register stages variable in1reg, in2reg : sfixed16; -- register stages variable in1reg2, in2reg2 : sfixed16; -- register stages begin -- process mulreg if rst_n = '0' then -- asynchronous reset (active low) in1reg := (others => '0'); in2reg := (others => '0'); in1reg2 := (others => '0'); in2reg2 := (others => '0'); in1reg3 <= (others => '0'); in2reg3 <= (others => '0'); out1 <= (others => '0'); outreg := (others => '0'); rcloop : for i in 1 to 15 loop cmdarray (i) <= (others => '0'); end loop rcloop; elsif rising_edge(clk) then -- rising clock edge out1 <= to_slv (outreg); outregc : case cmdarray (13) is when "0000" => outreg := outarray0; when "0001" => outreg := outarray1; when "0010" => outreg := outarray2; when "0011" => outreg := outarray3; when "0100" => outreg := outarray4; when "0101" => outreg := outarray5; when "0110" => outreg := outarray6; when "0111" => outreg := outarray7; when "1000" => outreg := outarray8; when "1001" => outreg := outarray9; when "1010" => outreg := outarray10; when "1011" => outreg := outarray11; when "1100" => outreg := outarray12; when "1101" => outreg := outarray13; when "1110" => outreg := outarray14; when "1111" => outreg := outarray15; when others => null; end case outregc; cmdpipe : for i in 15 downto 3 loop cmdarray (i) <= cmdarray (i-1); end loop cmdpipe; cmdarray (2) <= STD_ULOGIC_VECTOR(cmd); in1reg3 <= in1reg2; in2reg3 <= in2reg2; in1reg2 := in1reg; in2reg2 := in2reg; in1reg := to_sfixed (in1, in1reg); in2reg := to_sfixed (in2, in2reg); end if; end process cmdreg;end architecture rtl;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -