I want to send 8 bit data from FPGA to PC, 9600 baudrate, 8 bit data, 1 start&stop bit, no parity. I did coded my Basys3 Fpga and connected to PC. By using Tera Term, wanted to see how it works out. But probably something big I'm missing out. I just wrote a transmitter code and somewhere I saw that some people used button&top modules too. Do I need them to see a 8-bit data's ASCII equivalent on my PC? How can I handle?
library ieee;
use ieee.std_logic_1164.all;
entity rs232_omo is
generic(clk_max:integer:=10400); --for baudrate
port(
clk : in std_logic;
rst : in std_logic;
start : in std_logic;
input : in std_logic_vector(7 downto 0);
done : out std_logic;
output : out std_logic;
showstates: out std_logic_vector(3 downto 0)
);
end entity;
architecture dataflow of rs232_omo is
type states is (idle_state,start_state,send_state,stop_state);
signal present_state,next_state : states;
signal data,data_next : std_logic;
begin
process(clk,rst)
variable count : integer range 0 to clk_max;
variable index : integer range 0 to 10;
begin
if rst='1' then
present_state<=idle_state;
count:=0;
data<='1';
elsif rising_edge(clk) then
present_state<=next_state;
count:=count+1;
index:=index+1;
data<=data_next;
end if;
end process;
process(present_state,data,clk,rst,start)
variable count : integer range 0 to clk_max;
variable index : integer range 0 to 10;
begin
done<='0';
data_next<='1';
case present_state is
when idle_state =>
showstates<="1000";
data_next<='1';
if start='1' and rst='0' then
count:=count+1;
if count=clk_max then
next_state<=start_state;
count:=0;
end if;
end if;
when start_state =>
showstates<="0100";
data_next<='0';
count:=count+1;
if count=clk_max then
next_state<=send_state;
count:=0;
end if;
when send_state =>
showstates<="0010";
count:=count+1;
data_next<=input(index);
if count=clk_max then
if index=7 then
index:=0;
next_state<=stop_state;
else
index:=index+1;
end if;
count:=0;
end if;
when stop_state =>
showstates<="0001";
count:=count+1;
if count=clk_max then
next_state<=idle_state;
done<='1';
count:=0;
end if;
end case;
end process;
output<=data;
end architecture;
Constraints:
set_property PACKAGE_PIN V17 [get_ports {input[0]}]
set_property PACKAGE_PIN V16 [get_ports {input[1]}]
set_property PACKAGE_PIN W16 [get_ports {input[2]}]
set_property PACKAGE_PIN W17 [get_ports {input[3]}]
set_property PACKAGE_PIN W15 [get_ports {input[4]}]
set_property PACKAGE_PIN V15 [get_ports {input[5]}]
set_property PACKAGE_PIN V14 [get_ports {input[6]}]
set_property PACKAGE_PIN W13 [get_ports {input[7]}]
set_property IOSTANDARD LVCMOS33 [get_ports {input[7]}]
set_property IOSTANDARD LVCMOS33 [get_ports {input[6]}]
set_property IOSTANDARD LVCMOS33 [get_ports {input[5]}]
set_property IOSTANDARD LVCMOS33 [get_ports {input[4]}]
set_property IOSTANDARD LVCMOS33 [get_ports {input[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {input[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {input[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {input[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {showstates[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {showstates[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {showstates[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {showstates[0]}]
set_property PACKAGE_PIN L1 [get_ports {showstates[3]}]
set_property PACKAGE_PIN P1 [get_ports {showstates[2]}]
set_property PACKAGE_PIN N3 [get_ports {showstates[1]}]
set_property PACKAGE_PIN P3 [get_ports {showstates[0]}]
set_property PACKAGE_PIN W5 [get_ports clk]
set_property IOSTANDARD LVCMOS33 [get_ports clk]
set_property PACKAGE_PIN R2 [get_ports rst]
set_property PACKAGE_PIN T1 [get_ports start]
set_property IOSTANDARD LVCMOS33 [get_ports start]
set_property IOSTANDARD LVCMOS33 [get_ports rst]
set_property IOSTANDARD LVCMOS33 [get_ports done]
set_property IOSTANDARD LVCMOS33 [get_ports output]
set_property PACKAGE_PIN V3 [get_ports done]
set_property PACKAGE_PIN V13 [get_ports output]
My testbench simulation got attached.
And on-board, apparently I stuck with 'idle_state'.
For any kind of help, I thank y'all in advance.