OpenCores
URL https://opencores.org/ocsvn/System09/System09/trunk

Subversion Repositories System09

[/] [System09/] [trunk/] [rtl/] [VHDL/] [ACIA_Clock.vhd] - Diff between revs 66 and 99

Go to most recent revision | Show entire file | Details | Blame | View Log

Rev 66 Rev 99
Line 1... Line 1...
-----------------------------------------------------------------
--===========================================================================--
 
--                                                                           --
 
--  ACIA_Clock.vhd - Synthesizable Baud Rate Clock Divider                   --
 
--                                                                           --
 
--===========================================================================--
--
--
-- ACIA Clock Divider for System09
--  File name      : ACIA_Clock.vhd
--
--
-----------------------------------------------------------------
--  Purpose        : Implements a baud rate clock divider for a 6850 compatible
 
--                   Asynchronous Communications Interface Adapter 
 
--                  
 
--  Dependencies   : ieee.std_logic_1164
 
--                   ieee.std_logic_arith
 
--                   ieee.std_logic_unsigned
 
--                   ieee.numeric_std
 
--                   unisim.vcomponents
 
--                   work.bit_funcs
 
--
 
--  Author         : John E. Kent
 
--
 
--  Email          : dilbert57@opencores.org      
 
--
 
--  Web            : http://opencores.org/project,system09
 
--
 
--  ACIA_Clock.vhd is baud rate clock divider for a 6850 compatible ACIA core.
 
-- 
 
--  Copyright (C) 2003 - 2010 John Kent
 
--
 
--  This program is free software: you can redistribute it and/or modify
 
--  it under the terms of the GNU General Public License as published by
 
--  the Free Software Foundation, either version 3 of the License, or
 
--  (at your option) any later version.
 
--
 
--  This program is distributed in the hope that it will be useful,
 
--  but WITHOUT ANY WARRANTY; without even the implied warranty of
 
--  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
--  GNU General Public License for more details.
 
--
 
--  You should have received a copy of the GNU General Public License
 
--  along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
--
 
--===========================================================================--
 
--                                                                           --
 
--                              Revision  History                            --
 
--                                                                           --
 
--===========================================================================--
 
--
 
-- Revision Name          Date             Description
 
-- 0.1      John Kent     unknown          Initial version
 
-- 1.0      John Kent     30th May 2010    Added GPL header 
--
--
library IEEE;
 
   use IEEE.std_logic_1164.all;
 
   use IEEE.std_logic_arith.all;
 
   use IEEE.std_logic_unsigned.all;
 
 
 
package bit_funcs is
 
   function log2(v: in natural) return natural;
 
end package bit_funcs;
 
 
 
library IEEE;
 
   use IEEE.std_logic_1164.all;
 
   use IEEE.std_logic_arith.all;
 
   use IEEE.std_logic_unsigned.all;
 
 
 
package body bit_funcs is
 
   function log2(v: in natural) return natural is
 
      variable n: natural;
 
      variable logn: natural;
 
   begin
 
      n := 1;
 
      for i in 0 to 128 loop
 
         logn := i;
 
         exit when (n>=v);
 
         n := n * 2;
 
      end loop;
 
      return logn;
 
   end function log2;
 
 
 
end package body bit_funcs;
 
 
 
library ieee;
library ieee;
   use ieee.std_logic_1164.all;
   use ieee.std_logic_1164.all;
   use IEEE.STD_LOGIC_ARITH.ALL;
   use ieee.std_logic_arith.all;
   use IEEE.STD_LOGIC_UNSIGNED.ALL;
   use ieee.std_logic_unsigned.all;
   use ieee.numeric_std.all;
   use ieee.numeric_std.all;
library unisim;
library unisim;
        use unisim.vcomponents.all;
        use unisim.vcomponents.all;
library work;
library work;
   use work.bit_funcs.all;
   use work.bit_funcs.all;
 
 
entity ACIA_Clock is
entity acia_clock is
  generic (
  generic (
     SYS_Clock_Frequency  : integer;
     SYS_CLK_FREQ  : integer;
          ACIA_Clock_Frequency : integer
          ACIA_CLK_FREQ : integer
  );
  );
  port(
  port(
    clk      : in  Std_Logic;  -- System Clock input
    clk      : in  Std_Logic;  -- System Clock input
         ACIA_Clk : out Std_Logic   -- ACIA Clock output
         acia_clk : out Std_Logic   -- ACIA Clock output
  );
  );
end ACIA_Clock;
end acia_clock;
 
 
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
-- Architecture for ACIA_Clock
-- Architecture for ACIA_Clock
-------------------------------------------------------------------------------
-------------------------------------------------------------------------------
architecture rtl of ACIA_Clock is
architecture rtl of ACIA_Clock is
 
 
constant FULL_CYCLE : integer :=  (SYS_Clock_Frequency / ACIA_Clock_Frequency);
constant FULL_CYCLE : integer :=  (SYS_CLK_FREQ / ACIA_CLK_FREQ);
constant HALF_CYCLE : integer :=  (FULL_CYCLE / 2);
constant HALF_CYCLE : integer :=  (FULL_CYCLE / 2);
signal   ACIA_Count  : Std_Logic_Vector(log2(FULL_CYCLE) downto 0) := (Others => '0');
signal   acia_count : Std_Logic_Vector(log2(FULL_CYCLE) downto 0) := (Others => '0');
 
 
begin
begin
--
--
-- Baud Rate Clock Divider
-- Baud Rate Clock Divider
--
--
-- 25MHz / 27  = 926,000 KHz = 57,870Bd * 16
-- 25MHz / 27  = 926,000 KHz = 57,870Bd * 16
-- 50MHz / 54  = 926,000 KHz = 57,870Bd * 16
-- 50MHz / 54  = 926,000 KHz = 57,870Bd * 16
--
--
--my_ACIA_clock: process( clk, ACIA_Count  )
my_acia_clock: process( clk  )
my_ACIA_clock: process( clk  )
 
begin
begin
    if(clk'event and clk = '0') then
    if(clk'event and clk = '0') then
                if( ACIA_Count = (FULL_CYCLE - 1) )     then
                if( acia_count = (FULL_CYCLE - 1) )     then
                        ACIA_Clk   <= '0';
                        acia_clk   <= '0';
                   ACIA_Count <= (others => '0'); --"000000";
                   acia_count <= (others => '0'); --"000000";
                else
                else
                   if( ACIA_Count = (HALF_CYCLE - 1) )  then
                   if( acia_count = (HALF_CYCLE - 1) )  then
                                ACIA_Clk <='1';
                                acia_clk <='1';
                        end if;
                        end if;
                   ACIA_Count <= ACIA_Count + 1;
                   acia_count <= acia_count + 1;
                end if;
                end if;
    end if;
    end if;
end process;
end process;
 
 
end rtl;
end rtl;

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.