-- UART Receiver with integral 16 byte FIFO buffer -- -- 8 bit, no parity, 1 stop bit -- -- Version : 1.00 -- Version Date : 16th October 2002 -- -- Start of design entry : 16th October 2002 -- -- Ken Chapman -- Xilinx Ltd -- Benchmark House -- 203 Brooklands Road -- Weybridge -- Surrey KT13 ORH -- United Kingdom -- -- chapman@xilinx.com -- ------------------------------------------------------------------------------------ -- -- NOTICE: -- -- Copyright Xilinx, Inc. 2002. This code may be contain portions patented by other -- third parties. By providing this core as one possible implementation of a standard, -- Xilinx is making no representation that the provided implementation of this standard -- is free from any claims of infringement by any third party. Xilinx expressly -- disclaims any warranty with respect to the adequacy of the implementation, including -- but not limited to any warranty or representation that the implementation is free -- from claims of any third party. Futhermore, Xilinx is providing this core as a -- courtesy to you and suggests that you contact all third parties to obtain the -- necessary rights to use this implementation. -- ------------------------------------------------------------------------------------ -- -- Library declarations -- -- The Unisim Library is used to define Xilinx primitives. It is also used during -- simulation. The source can be viewed at %XILINX%\vhdl\src\unisims\unisim_VCOMP.vhd -- library IEEE; use IEEE.STD_LOGIC_1164.ALL; use IEEE.STD_LOGIC_ARITH.ALL; use IEEE.STD_LOGIC_UNSIGNED.ALL; library unisim; use unisim.vcomponents.all; -- ------------------------------------------------------------------------------------ -- -- Main Entity for UART_RX -- entity uart_rx is Port ( serial_in : in std_logic; data_out : out std_logic_vector(7 downto 0); read_buffer : in std_logic; reset_buffer : in std_logic; en_16_x_baud : in std_logic; buffer_data_present : out std_logic; buffer_full : out std_logic; buffer_half_full : out std_logic; clk : in std_logic); end uart_rx; -- ------------------------------------------------------------------------------------ -- -- Start of Main Architecture for UART_RX -- architecture macro_level_definition of uart_rx is -- ------------------------------------------------------------------------------------ -- -- Components used in UART_RX and defined in subsequent entities. -- ------------------------------------------------------------------------------------ -- -- Constant (K) Compact UART Receiver -- component kcuart_rx Port ( serial_in : in std_logic; data_out : out std_logic_vector(7 downto 0); data_strobe : out std_logic; en_16_x_baud : in std_logic; clk : in std_logic); end component; -- -- 'Bucket Brigade' FIFO -- component bbfifo_16x8 Port ( data_in : in std_logic_vector(7 downto 0); data_out : out std_logic_vector(7 downto 0); reset : in std_logic; write : in std_logic; read : in std_logic; full : out std_logic; half_full : out std_logic; data_present : out std_logic; clk : in std_logic); end component; -- ------------------------------------------------------------------------------------ -- -- Signals used in UART_RX -- ------------------------------------------------------------------------------------ -- signal uart_data_out : std_logic_vector(7 downto 0); signal fifo_write : std_logic; -- ------------------------------------------------------------------------------------ -- -- Start of UART_RX circuit description -- ------------------------------------------------------------------------------------ -- begin -- 8 to 1 multiplexer to convert parallel data to serial kcuart: kcuart_rx port map ( serial_in => serial_in, data_out => uart_data_out, data_strobe => fifo_write, en_16_x_baud => en_16_x_baud, clk => clk ); buf: bbfifo_16x8 port map ( data_in => uart_data_out, data_out => data_out, reset => reset_buffer, write => fifo_write, read => read_buffer, full => buffer_full, half_full => buffer_half_full, data_present => buffer_data_present, clk => clk); end macro_level_definition; ------------------------------------------------------------------------------------ -- -- END OF FILE UART_RX.VHD -- ------------------------------------------------------------------------------------