📄 i43hostmot2.vhd
字号:
library IEEE;use IEEE.STD_LOGIC_1164.ALL;use IEEE.STD_LOGIC_ARITH.ALL;use IEEE.STD_LOGIC_UNSIGNED.ALL;---- Copyright (C) 2007, Peter C. Wallace, Mesa Electronics-- http://www.mesanet.com---- This program is is licensed under a disjunctive dual license giving you-- the choice of one of the two following sets of free software/open source-- licensing terms:---- * GNU General Public License (GPL), version 2.0 or later-- * 3-clause BSD License-- ---- The GNU GPL License:-- -- 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 2 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, write to the Free Software-- Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA-- -- -- The 3-clause BSD License:-- -- Redistribution and use in source and binary forms, with or without-- modification, are permitted provided that the following conditions-- are met:-- -- * Redistributions of source code must retain the above copyright-- notice, this list of conditions and the following disclaimer.-- -- * Redistributions in binary form must reproduce the above-- copyright notice, this list of conditions and the following-- disclaimer in the documentation and/or other materials-- provided with the distribution.-- -- * Neither the name of Mesa Electronics nor the names of its-- contributors may be used to endorse or promote products-- derived from this software without specific prior written-- permission.-- -- -- Disclaimer:-- -- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS-- "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT-- LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS-- FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE-- COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,-- INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,-- BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;-- LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER-- CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT-- LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN-- ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE-- POSSIBILITY OF SUCH DAMAGE.-- use work.IDROMParms.all; entity i43hostmot2 is generic ( STEPGENs: integer := 0; QCOUNTERS: integer := 8; PWMGens: integer := 8; SPIs: integer := 0; SSIs: integer := 0; UARTs: integer := 0; PWMRefWidth: integer := 13; -- PWM resolution is PWMRefWidth-1 bits StepGenTableWidth: integer := 6; -- How many output bits from stepgen IDROMType: integer := 2; SepClocks: boolean := true; OneWS: boolean := true; SVST8_24Pinout: boolean := false; SVST8_8Pinout: boolean := false; SVST4_8Pinout: boolean := false; SVST8_4Pinout: boolean := false; SVST4_4Pinout: boolean := false; SVST4_6Pinout: boolean := false; QCtrOnlyPinout: boolean := false; QCtrOnlyPinoutWithIMask: boolean := false; I30Pinout: boolean := true; I44pinout: boolean := false; ConnsWithI30: integer := 2; StartingI30Conn: integer := 0; ConnsWithI44: integer := 0; StartingI44Conn: integer := 0; ConnsWithStepGen: integer := 0; StartingStepGenConn: integer := 0; UseStepGenPrescaler : boolean := false; UseIRQLogic: boolean := true; UseWatchDog: boolean := true; OffsetToModules: integer := 64; OffsetToPinDesc: integer := 512; ClockHigh: integer := ClockHigh43; ClockLow: integer := ClockLow43; BoardNameLow : std_Logic_Vector(31 downto 0) := BoardNameMESA; BoardNameHigh : std_Logic_Vector(31 downto 0) := BoardName7I43; FPGASize: integer := 400; FPGAPins: integer := 144; IOPorts: integer := 2; IOWidth: integer := 48; PortWidth: integer := 24; BusWidth: integer := 32; AddrWidth: integer := 16; InstStride0: integer := 4; InstStride1: integer := 16; RegStride0: integer := 256; RegStride1: integer := 4; LEDCount: integer := 8 ); Port ( CLK : in std_logic; LEDS : out std_logic_vector(7 downto 0); IOBITS : inout std_logic_vector(47 downto 0); EPP_DATABUS : inout std_logic_vector(7 downto 0); EPP_DSTROBE : in std_logic; EPP_ASTROBE : in std_logic; EPP_WAIT : out std_logic; EPP_READ : in std_logic; RECONFIG : out std_logic; PARACONFIG : out std_logic; SPICLK : out std_logic;-- SPIIN : in std_logic; SPIOUT : out std_logic; SPICS : out std_logic );end i43hostmot2;architecture Behavioral of i43hostmot2 is signal afcnt : std_logic_vector(2 downto 0);signal afilter : std_logic_vector(1 downto 0);signal dfcnt : std_logic_vector(2 downto 0);signal dfilter : std_logic_vector(1 downto 0);signal rfcnt : std_logic_vector(1 downto 0);signal rfilter : std_logic;signal waitpipe : std_logic_vector(9 downto 0);alias waitpipeend: std_logic is waitpipe(9);signal alatch : std_logic_vector(AddrWidth-1 downto 0); signal seladd : std_logic_vector(AddrWidth-1 downto 0);signal aread : std_logic;signal awritele : std_logic;signal wasaddr : std_logic;signal dread : std_logic;signal dreadle : std_logic;signal dreadte : std_logic;signal dwritele : std_logic; signal dwritete : std_logic; signal dstrobete : std_logic; signal astrobete : std_logic; signal depp_dstrobe : std_logic;signal depp_astrobe : std_logic;signal depp_read : std_logic;signal wdlatch : std_logic_vector(31 downto 0);signal rdlatch : std_logic_vector(31 downto 0);signal obus : std_logic_vector(31 downto 0);signal translateaddr : std_logic_vector(AddrWidth-1 downto 0);alias translatestrobe : std_logic is translateaddr(AddrWidth-1);signal loadtranslateram : std_logic;signal readtranslateram : std_logic;signal translateramsel : std_logic;signal read32 : std_logic;signal write32 : std_logic;signal ReconfigSel : std_logic;signal idata: std_logic_vector(7 downto 0);signal ReConfigreg : std_logic := '0';signal fclk : std_logic;signal clkfx: std_logic;signal clk0: std_logic;beginahostmot2: entity HostMot2 generic map ( stepgens => STEPGENs, qcounters => QCOUNTERS, pwmgens => PWMGens, spis => SPIs, ssis => SSIs, uarts => UARTs, pwmrefwidth => PWMRefWidth, stepgentablewidth => StepGenTableWidth, idromtype => IDROMType, sepclocks => SepClocks, onews => OneWS, svst8_24pinout => SVST8_24Pinout, svst8_8pinout => SVST8_8Pinout, svst4_8pinout => SVST4_8Pinout, svst8_4pinout => SVST8_4Pinout, svst4_4pinout => SVST4_4Pinout, svst4_6pinout => SVST4_6Pinout, i30pinout => I30Pinout, i44pinout => I44pinout, qctronlypinout => QCtrOnlyPinout, qctronlypinoutwithimask => QCtrOnlyPinoutWithIMask, connswithi30 => ConnsWithI30, startingi30conn => Startingi30Conn, connswithi44 => ConnsWithI44, startingi44conn => Startingi44Conn, connswithstepgen => ConnsWithStepgen, startingstepgenconn => StartingStepGenConn, usestepgenprescaler => UseStepGenPrescaler, useirqlogic => UseIRQLogic, usewatchdog => UseWatchDog, offsettomodules => OffsetToModules, offsettopindesc => OffsetToPinDesc, clockhigh => ClockHigh, clocklow => ClockLow, boardnamelow => BoardNameLow, boardnamehigh => BoardNameHigh, fpgasize => FPGASize, fpgapins => FPGAPins, ioports => IOPorts, iowidth => IOWidth, portwidth => PortWidth, buswidth => BusWidth, addrwidth => AddrWidth, inststride0 => InstStride0, inststride1 => InstStride1, regstride0 => RegStride0, regstride1 => RegStride1, ledcount => LEDCount ) port map ( ibus => wdlatch, obus => obus, addr => seladd(AddrWidth-1 downto 2), read => read32, write => write32, clklow => CLK, clkhigh => fclk,-- int => INT, iobits => IOBITS, leds => LEDS ); transmogrifier: entity atrans generic map ( width => AddrWidth, depth => 8) port map( clk => CLK, wea => loadtranslateram, rea => readtranslateram, reb => '1', adda => alatch(9 downto 2), addb => alatch(7 downto 0), din => wdlatch(15 downto 0), douta => obus(15 downto 0), doutb => translateaddr ); ClockMult : DCM generic map ( CLKDV_DIVIDE => 2.0, CLKFX_DIVIDE => 2, CLKFX_MULTIPLY => 4, -- 4 FOR 100 MHz
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -