21 Commits
v1.0 ... master

Author SHA1 Message Date
Philip Smart
45ca436d0f Create license.txt 2022-09-04 18:17:43 +01:00
Philip Smart
6e8fcf9e0a Updates not checked in 2021-08-22 09:49:27 +01:00
Philip Smart
074374e61e Tidy 2021-02-19 00:09:33 +00:00
Philip Smart
2f8e0da319 Re-organisation of CAD files, previous version not useable as files missing 2021-02-18 13:14:44 +00:00
Philip Smart
36be2f3ddf Added schematics, kicad and pcb gerber files 2021-02-06 18:02:43 +00:00
Philip Smart
6daafef9bc Updates to video logic 2020-11-14 23:34:53 +00:00
Philip Smart
6a8da13e6f Bug fixes and tweaks 2020-11-10 22:39:10 +00:00
Philip Smart
52d0700aca Updates to Video Module 2020-11-08 00:18:40 +00:00
Philip Smart
82a4166db1 New video module developments 2020-11-02 01:19:20 +00:00
Philip Smart
ba31018942 Changes to the serialiser in order to get the pixel mapped graphics working - needs more changes as it isnt reliable at 4MHz mainboard frequency 2020-09-08 11:54:29 +01:00
Philip Smart
9505bc4583 Updates for better compatibility with the tranZPUter v2.2 board and mainboard overclocking 2020-09-05 23:26:20 +01:00
Philip Smart
17e9ff0e24 Forgot to save!! 2020-09-04 16:10:16 +01:00
Philip Smart
0982a7e984 Initial release of the Video Module 2020-09-04 13:43:29 +01:00
Philip Smart
ed356e77ab Initial cut of the Video Module. Basic design works but on mode switch there is a sync issue which needs resolving. Need to test out the MZ80B pixel graphics 2020-09-02 11:59:18 +01:00
Philip Smart
01ed62446f Tweaks to the CGROM for tranZPUter SW MZ700 mode 2020-07-30 22:04:04 +01:00
Philip Smart
6527f2e460 Updates 2020-07-05 12:16:01 +01:00
Philip Smart
54d7f4af50 Updates 2020-07-05 12:15:33 +01:00
Philip Smart
673f94a7a9 Added docker 2020-07-05 12:11:34 +01:00
Philip Smart
985865fc53 Updated schematics 2020-07-04 17:49:31 +01:00
Philip Smart
0831b416bb WIP Video Module v2 2020-07-04 17:34:46 +01:00
Philip Smart
cd629622f2 Removed temp file 2020-03-24 23:13:29 +00:00
233 changed files with 372468 additions and 4 deletions

65
.gitignore vendored Normal file
View File

@@ -0,0 +1,65 @@
*.swp
.*.swp
*.swo
.*.swo
CPLD/build/VideoInterface.csv
CPLD/build/VideoInterface.qsf.bak
CPLD/build/db/
CPLD/build/incremental_db/
CPLD/build/old/
CPLD/build/output_files/
CPLD/build/simulation/
FPGA/build/.qsys_edit/
FPGA/build/Clock_50to100.cnx
FPGA/build/Clock_50to100.cnxerr
FPGA/build/PLLJ_PLLSPE_INFO.txt
FPGA/build/VideoController.out.sdc
FPGA/build/VideoController.srf
FPGA/build/VideoController_assignment_defaults.qdf
FPGA/build/db/
FPGA/build/incremental_db/
FPGA/build/old/
FPGA/build/output_files/
FPGA/build/simulation/
FPGA/build/test.bsf
FPGA/build/test.cmp
FPGA/build/test.html
FPGA/build/test.qsys
FPGA/build/test.sopcinfo
FPGA/build/test/
FPGA/build/test_generation.rpt
FPGA/build/test_generation_1.rpt
FPGA/devices/
FPGA/functions.vhd
schematics/MZ80-80CLR/
FPGA/build/VideoController.qws
docker/QuartusPrime/Dockerfile.13.0.1.old
docker/QuartusPrime/Quartus-web-13.0.1.232-linux.tar
docker/QuartusPrime/files/13.0/
docker/QuartusPrime/files/13.1/
docker/QuartusPrime/files/17.1/
docker/QuartusPrime/local/
docker/QuartusPrime/quartus_docker.sh
pin2lib.py
schematics/MZ80_80CLR_v2.0a.pdf
CPLD/VideoInterface.vhd.orig
CPLD/VideoInterface_Toplevel.vhd.orig
CPLD/VideoInterface_pkg.vhd.orig
CPLD/build/VideoInterface.out.sdc
CPLD/build/VideoInterface.qsf.orig
CPLD/build/VideoInterface_constraints.sdc.orig
FPGA/VideoController.vhd.inpro
FPGA/VideoController.vhd.orig
FPGA/VideoController_Toplevel.vhd.orig
FPGA/VideoController_pkg.vhd.orig
FPGA/build/VideoController-Unconstrained Paths.rpt
FPGA/build/VideoController.qsf.orig
FPGA/build/VideoController_constraints.sdc.orig
FPGA/build/abc.qip
FPGA/build/greybox_tmp/
video_22082020.tar.gz
CPLD/VideoInterface.vhd.16mhz
CPLD/VideoInterface_Toplevel.vhd.16mhz
FPGA/build/core
FPGA/vidsav
CPLD/build/VideoInterface.qws

628
CPLD/VideoInterface.vhd Normal file
View File

@@ -0,0 +1,628 @@
---------------------------------------------------------------------------------------------------------
--
-- Name: VideoInterface.vhd
-- Created: June 2020
-- Author(s): Philip Smart
-- Description: MZ80A Video Module v2.0 CPLD logic definition file.
-- This module contains the definition of the logic used in v2.0 of the Sharp MZ80A
-- Video Module. The design uses a CPLD for glue logic and voltage translation and a
-- Cyclone III to realise the video circuitry.
-- The sizing of the CPLD is probably overkill but like most developments, more is better
-- until the design is finalised as it gives you more options.
--
-- Credits:
-- Copyright: (c) 2018-20 Philip Smart <philip.smart@net2net.org>
--
-- History: June 2020 - Initial creation.
-- Sep 2020 - First release.
--
---------------------------------------------------------------------------------------------------------
-- This source file 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 source file 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->.
---------------------------------------------------------------------------------------------------------
library ieee;
library pkgs;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
use ieee.numeric_std.all;
use work.VideoInterface_pkg.all;
entity VideoInterface is
--generic (
--);
port (
-- Primary video clock.
CLOCK_50 : in std_logic; -- 50Hz base clock for system board, video timing and gate clocking.
-- Z80 Address and Data. Address is muxed with video addressing, not direct.
A : in std_logic_vector(10 downto 0); -- Z80 Address bus, multiplexed with video address. 13..11 come from the tranZPUter board.
D : inout std_logic_vector(7 downto 0); -- Z80 Data bus, from the Colour Card CN! connector.
-- Z80 Control signals.
WRn : in std_logic; -- Z80 Write signal from the Colour Card CN! connector.
RDn : in std_logic; -- Z80 Read signal from the Colour Card CN! connector.
RESETn : in std_logic; -- Z80 RESET signal from the tranZPUter board.
-- Video and Mainboard signals.
SRVIDEO_OUT : out std_logic; -- Shift Register 74LS165 Video Output onto mainboard.
CLK_31_5K_OUT : out std_logic; -- 31.5KHz time base for the 8253 on mainboard. Signal was from the MB14298.
CLK_1MHZ_OUT : out std_logic; -- 1MHZ video timing clock output to mainboard. Signal was from the MB14298.
CLK_2MHZ_OUT : out std_logic; -- 2MHZ main CPU clock output to mainboard. Signal was from the MB14298.
HBLNK_OUTn : out std_logic; -- Horizontal Blanking output. Signal was from the MB14298.
HSY_OUT : out std_logic; -- Horizontal sync output. Signal was from the MB14298.
SYNCH_OUT : out std_logic; -- Vertical sync output. Signal was from the MB14298.
VBLNK_OUTn : out std_logic; -- Vertical blanking output. Signal was from the MB14298.
MB_HBLNKn : in std_logic; -- Mainboard Horizontal Blanking from the Colour Card CN! connector.
MB_SYNCH : in std_logic; -- Mainboard Vertical sync from the Colour Card CN! connector.
MB_V_HBLNKn : in std_logic; -- Mainboard combined vertical/horizontal sync from the Colour Card CN! connector.
MB_VIDEO : in std_logic; -- Mainboard Video (74LS165 output combined with GATE) from the Colour Card CN! connector.
MB_LOAD : in std_logic; -- Mainboard shift register load signal from the Colour Card CN! connector.
VRAM_CS_INn : in std_logic; -- Chip Select for access to the Video RAM from the mainboard IC15 socket.
GTn : in std_logic; -- GATE signal from the Colour Card CN! connector.
CSn : in std_logic; -- Chip Select for the Video Attribute RAM from the Colour Card CN! connector.
OUTCLK : out std_logic; -- CPU signal serialiser clock.
INDATA : in std_logic_vector(3 downto 0); -- Incoming serialised CPU signals.
-- V[name] = Voltage translated signals which mirror the mainboard signals but at a lower voltage.
VADDR : out std_logic_vector(15 downto 0); -- Z80 Address bus, multiplexed with video address.
VDATA : inout std_logic_vector(7 downto 0); -- Z80 Data bus from mainboard Colour Card CD connector..
VRAMD : inout std_logic_vector(7 downto 0); -- Z80 Data bus from the VRAM chip, gated according to state signals.
--VMEM_CSn : out std_logic; -- Extended memory select to FPGA.
VVRAM_CS_INn : out std_logic; -- Chip Select for access to the Video RAM from the mainboard IC15 socket.
VWAITn : in std_logic; -- WAIT signal from FPGA asserted during active frame display period.
VZ80_IORQn : out std_logic; -- IORQn to FPGA.
VZ80_RDn : out std_logic; -- Z80_RDn from tranZPUter to FPGA.
VCSn : out std_logic; -- Video RAM Attribute Chip Select (CSn) to FPGA.
VGTn : out std_logic; -- Video Gate (GTn)
VZ80_WRn : out std_logic; -- WRn to FPGA.
--
VSRVIDEO_OUT : in std_logic; -- Video out from 74LS165 on mainboard, pre-GATE.
VHBLNK_OUTn : in std_logic; -- Horizontal blanking.
VHSY_OUT : in std_logic; -- Horizontal Sync.
VSYNCH_OUT : in std_logic; -- Veritcal Sync.
VVBLNK_OUTn : in std_logic; -- Vertical blanking.
--
VMB_HBLNKn : out std_logic; -- Horizontal Blanking from the Colour Card CN! connector.
VMB_SYNCH : out std_logic; -- Vertical sync from the Colour Card CN! connector.
VMB_V_HBLNKn : out std_logic; -- combined vertical/horizontal sync from the Colour Card CN! connector.
VMB_VIDEO : out std_logic; -- Video (74LS165 output combined with GATE) from the Colour Card CN! connector.
VMB_LOAD : out std_logic -- shift register load signal from the Colour Card CN! connector.
-- Reserved.
--TBA : in std_logic_vector(1 downto 0) -- Reserved signals.
);
end entity;
architecture rtl of VideoInterface is
-- Clock generation wires.
signal CLOCK_48 : std_logic; -- 16MHz used for the Video main frequency.
signal CLK24Mi : std_logic; -- 24MHz used for internal clocking.
signal CLK16Mi : std_logic; -- 16MHz used for internal clocking.
signal CLK4_8Mi : std_logic; -- 4.8MHz used for the CPU main frequency in custom mode.
signal CLK4Mi : std_logic; -- 4MHz used for the CPU main frequency in MZ80B mode.
signal CLK3_54Mi : std_logic; -- 3.54MHz used for the CPU main frequency in MZ700 mode.
signal CLK2Mi : std_logic; -- 2MHz used for the CPU main frequency.
signal CLK1Mi : std_logic; -- 1MHz used for video timing.
signal CLK31500i : std_logic; -- 8253 Clock base frequency used for RTC,
signal ENASERCLK : std_logic; -- Enable serializer clock.
signal S_IORQn : std_logic; -- Serialiser signal - IORQn
signal S_VIDEO_RDn : std_logic; -- Serialiser signal - Video FPGA RDn
signal S_VIDEO_WRn : std_logic; -- Serialiser signal - Video FPGA WRn
signal INBUF : std_logic_vector(11 downto 0);
signal INCOUNT : integer range 0 to 3;
signal VA : std_logic_vector(15 downto 0);
-- CPLD configuration signals.
signal MODE_CPLD_MZ80K : std_logic;
signal MODE_CPLD_MZ80C : std_logic;
signal MODE_CPLD_MZ1200 : std_logic;
signal MODE_CPLD_MZ80A : std_logic;
signal MODE_CPLD_MZ700 : std_logic;
signal MODE_CPLD_MZ800 : std_logic;
signal MODE_CPLD_MZ80B : std_logic;
signal MODE_CPLD_MZ2000 : std_logic;
signal MODE_CPLD_SWITCH : std_logic;
signal MODE_CPLD_MB_VIDEOn : std_logic; -- Mainboard video, 0 = enabled, 1 = disabled.
signal CPLD_CFG_DATA : std_logic_vector(7 downto 0); -- CPLD Configuration register.
-- IO Decode signals.
signal CS_IO_6XXn : std_logic; -- IO decode for the 0x60-0x6f region used by the CPLD.
signal CS_IO_EXXn : std_logic; -- Chip select for block E0:EF
signal CS_IO_FXXn : std_logic; -- Chip select for block F0:FF
signal CS_CPLD_CFGn : std_logic; -- Select to set the CPLD configuration register.
signal CS_FB_VMn : std_logic; -- Chip Select for the Video Mode register.
signal CS_FB_PAGEn : std_logic; -- Chip Select for the Page select register.
signal CS_80B_PIOn : std_logic; -- Chip select for MZ80B PIO when in MZ80B mode.
signal CS_LAST_LEVEL : std_logic_vector(4 downto 0); -- Register to store the previous chip select level for edge detection.
signal CS_DXXXn : std_logic; -- Chip select range for the VRAM/ARAM.
signal CS_EXXXn : std_logic; -- Chip select range for the memory mapped I/O.
signal CS_DVRAMn : std_logic; -- Chip select for the Video RAM.
signal CS_DARAMn : std_logic; -- Chip select for the Attribute RAM.
-- Video module signal mirrors.
signal MODE_VIDEO_MZ80A : std_logic := '1'; -- The machine is running in MZ80A mode.
signal MODE_VIDEO_MZ700 : std_logic := '0'; -- The machine is running in MZ700 mode.
signal MODE_VIDEO_MZ800 : std_logic := '0'; -- The machine is running in MZ800 mode.
signal MODE_VIDEO_MZ80B : std_logic := '0'; -- The machine is running in MZ80B mode.
signal MODE_VIDEO_MZ80K : std_logic := '0'; -- The machine is running in MZ80K mode.
signal MODE_VIDEO_MZ80C : std_logic := '0'; -- The machine is running in MZ80C mode.
signal MODE_VIDEO_MZ1200 : std_logic := '0'; -- The machine is running in MZ1200 mode.
signal MODE_VIDEO_MZ2000 : std_logic := '0'; -- The machine is running in MZ2000 mode.
signal GRAM_PAGE_ENABLE : std_logic; -- Graphics mode page enable.
signal GRAM_MZ80B_ENABLE : std_logic; -- MZ80B Graphics memory enabled flag.
signal MZ80B_VRAM_HI_ADDR : std_logic; -- Video RAM located at D000:FFFF when high.
signal MZ80B_VRAM_LO_ADDR : std_logic; -- Video RAM located at 5000:7FFF when high.
function to_std_logic(L: boolean) return std_logic is
begin
if L then
return('1');
else
return('0');
end if;
end function to_std_logic;
begin
-- A tranZPUter signal serializer. Signals required by the Video Module but not accessible physically (without hardware hacks) are captured and serialised by the tranZPUter
-- as a set of x 4 blocks, clocked by the video interace CPLD, As the mainboard can not run faster than 4MHz, a 24MHz serialiser clock should be sufficient to bring the
-- signals across but can be increased as necessary.
-- Reset synchronises the Video Module CPLD with the tranZPUter CPLD and the signals are sent during valid mainboard accesses. During tranZPUter accesses, both
-- S_VIDEO_RDn and S_VIDEO_WRn are sent as 0, an invalid state, to indicate the signals are not valid.
--
SIGNALSERIALIZER: process(RESETn, CLK16Mi, ENASERCLK)
variable RCV_CYCLE : integer range 0 to 1;
begin
-- Each reset the FPGA and CPLD are in sync, set the signals to the starting level ready to commence serialization.
if RESETn = '0' then
ENASERCLK <= '0';
RCV_CYCLE := 0;
INCOUNT <= 1;
INBUF <= "000000000000";
VA(15 downto 11) <= (others => '0');
S_IORQn <= '1';
S_VIDEO_RDn <= '1';
S_VIDEO_WRn <= '1';
elsif falling_edge(CLK16Mi) then
case RCV_CYCLE is
-- Cycle starts by enabling the clock which the tranZPUter sees the rising edge and captures the 16 signals and places the
-- first block of 4 onto the mux-bus.
when 0 =>
ENASERCLK <= '1';
RCV_CYCLE := 1;
-- Each clock period, a block of signals are placed on the bus with sufficient time for the signals to settle and to capture them.
when 1 =>
if INCOUNT > 0 then
INBUF(3 downto 0) <= INDATA; --INBUF(7 downto 4);
--INBUF(7 downto 4) <= INDATA;
INCOUNT <= INCOUNT - 1;
else
-- If S_VIDEO_WRn and S_VIDEO_RDn are both zero it indicates an invalid data set so dont act on it.
--
if INDATA(3 downto 1) /= "000" then
VA(15 downto 11) <= INDATA(0) & INBUF(3 downto 0);
S_VIDEO_RDn <= INDATA(1);
S_VIDEO_WRn <= INDATA(2);
S_IORQn <= INDATA(3);
else
VA(15 downto 11) <= (others => '0');
S_VIDEO_RDn <= '1';
S_VIDEO_WRn <= '1';
S_IORQn <= '1';
end if;
INCOUNT <= 1;
end if;
RCV_CYCLE := 1;
end case;
end if;
-- Enable the clock directly onto the bus clock line when data required.
if ENASERCLK = '1' then
OUTCLK <= CLK16Mi;
else
OUTCLK <= '0';
end if;
end process;
-- Signals originating on the mainboard or the FPGA are brougnt into the clock domain of the CPLD, which is also the clock domain of the mainboard
-- as the CPLD provides the mainboard clocks.
--
VIDEOSIGNALS: process(RESETn, CLOCK_50)
begin
if RESETn = '0' then
SRVIDEO_OUT <= '0';
HBLNK_OUTn <= '0';
HSY_OUT <= '0';
SYNCH_OUT <= '0';
VBLNK_OUTn <= '0';
VMB_HBLNKn <= '0';
VMB_LOAD <= '0';
VMB_SYNCH <= '0';
VMB_V_HBLNKn <= '0';
VMB_VIDEO <= '0';
elsif rising_edge(CLOCK_50) then
SRVIDEO_OUT <= VSRVIDEO_OUT;
HBLNK_OUTn <= VHBLNK_OUTn;
HSY_OUT <= VHSY_OUT;
SYNCH_OUT <= VSYNCH_OUT;
VBLNK_OUTn <= VVBLNK_OUTn;
VMB_HBLNKn <= MB_HBLNKn;
VMB_LOAD <= MB_LOAD;
VMB_SYNCH <= MB_SYNCH;
VMB_V_HBLNKn <= MB_V_HBLNKn;
VMB_VIDEO <= MB_VIDEO;
end if;
end process;
-- The main crystal runs at 50MHz but most of the system board signals are in binary 2 values (except for MZ700 mode). We thus create a 48MHz
-- clock by skipping 2 out of 50 clock periods, 1 on each level, to create the desired clock.
--
CLOCK48MHZ: process(RESETn, CLOCK_50)
variable counter48Mi : unsigned(6 downto 0); -- Binary divider to create 48Mi clock.
begin
if RESETn = '0' then
counter48Mi := (others => '0');
elsif rising_edge(CLOCK_50) then
counter48Mi := counter48Mi + 1;
if counter48Mi = 50 then
counter48Mi := (others => '0');
end if;
end if;
if counter48Mi /= 25 and counter48Mi /= 49 then
CLOCK_48 <= CLOCK_50;
else
CLOCK_48 <= '1';
end if;
end process;
-- The 48MHz clock is used to create the base system clocks, 16MHz being the original machine base clock along with 4, 2 and 1MHz.
-- This logic was originally performed by the MB14298 Gate Array on the mainboard.
--
SYSCLOCKS: process(RESETn, CLOCK_48, CLK24Mi, CLK4_8Mi, CLK4Mi, CLK3_54Mi, CLK2Mi, CLK1Mi, CLK31500i, CPLD_CFG_DATA)
variable counter24Mi : unsigned(1 downto 0); -- Binary divider to create 24Mi clock.
variable counter16Mi : unsigned(1 downto 0); -- Binary divider to create 16Mi clock.
variable counter4_8Mi : unsigned(2 downto 0); -- Binary divider to create 4_8Mi clock.
variable counter4Mi : unsigned(3 downto 0); -- Binary divider to create 4Mi clock.
variable counter2Mi : unsigned(3 downto 0); -- Binary divider to create 2Mi clock.
variable counter1Mi : unsigned(4 downto 0); -- Binary divider to create 1Mi clock.
variable counter31500i : unsigned(10 downto 0); -- Binary divider to create 31500i clock.
begin
if RESETn = '0' then
counter24Mi := (others => '0');
counter16Mi := (others => '0');
counter4_8Mi := (others => '0');
counter4Mi := (others => '0');
counter2Mi := (others => '0');
counter1Mi := (others => '0');
counter31500i := (others => '0');
CLK24Mi <= '0';
CLK16Mi <= '0';
CLK4_8Mi <= '0';
CLK4Mi <= '0';
CLK2Mi <= '0';
CLK1Mi <= '0';
CLK31500i <= '0';
elsif rising_edge(CLOCK_48) then
counter24Mi := counter24Mi + 1;
counter16Mi := counter16Mi + 1;
counter4_8Mi := counter4_8Mi + 1;
counter4Mi := counter4Mi + 1;
counter2Mi := counter2Mi + 1;
counter1Mi := counter1Mi + 1;
counter31500i := counter31500i + 1;
-- 24000000Hz
if counter24Mi = 1 then
CLK24Mi <= not CLK24Mi;
counter24Mi := (others => '0');
end if;
-- 16000000Hz
if counter16Mi = 2 or counter16Mi = 3 then
CLK16Mi <= not CLK16Mi;
if counter16Mi = 3 then
counter16Mi := (others => '0');
end if;
end if;
-- 4800000Hz
if counter4_8Mi = 5 then
CLK4_8Mi <= not CLK4_8Mi;
counter4_8Mi := (others => '0');
end if;
-- 4000000Hz
if counter4Mi = 6 then
CLK4Mi <= not CLK4Mi;
counter4Mi := (others => '0');
end if;
-- 2000000Hz
if counter2Mi = 12 then
CLK2Mi <= not CLK2Mi;
counter2Mi := (others => '0');
end if;
-- 1000000Hz
if counter1Mi = 24 then
CLK1Mi <= not CLK1Mi;
counter1Mi := (others => '0');
end if;
-- 31500Hz
if counter31500i = 761 or counter31500i = 1523 then
CLK31500i <= not CLK31500i;
if counter31500i = 1523 then
counter31500i := (others => '0');
end if;
end if;
end if;
-- Setup board speeds according to mode.
--
CLK_31_5K_OUT <= CLK31500i;
CLK_1MHZ_OUT <= CLK1Mi;
case to_integer(unsigned(CPLD_CFG_DATA(6 downto 4))) is
when MODE_FREQ_MZ80A =>
CLK_2MHZ_OUT <= CLK2Mi;
when MODE_FREQ_MZ80B =>
CLK_2MHZ_OUT <= CLK4Mi;
when MODE_FREQ_MZ700 =>
CLK_2MHZ_OUT <= CLK3_54Mi;
when MODE_FREQ_CUSTOM =>
CLK_2MHZ_OUT <= CLK4_8Mi;
when others =>
CLK_2MHZ_OUT <= CLK2Mi;
end case;
end process;
-- Process to subdivide the main 50MHz clock to obtain the MZ700 frequencies.
--
MZ700CLOCKS: process(RESETn, CLOCK_50, CLK3_54Mi)
variable counter3_54Mi : unsigned(4 downto 0); -- Binary divider to create the 3.54Mi clock.
begin
if RESETn = '0' then
counter3_54Mi := (others => '0');
CLK3_54Mi <= '0';
elsif rising_edge(CLOCK_50) then
counter3_54Mi := counter3_54Mi + 1;
-- 3540000Hz
if counter3_54Mi = 7 then
CLK3_54Mi <= not CLK3_54Mi;
counter3_54Mi := (others => '0');
end if;
end if;
end process;
-- Control Registers - This mirrors the Video Module control registers as we need to know when video memory is to be mapped into main memory.
--
-- IO Range for Graphics enhancements is set by the Video Mode registers at 0xF8->.
-- 0xF8=<val> sets the mode that of the Video Module. [2:0] - 000 (default) = MZ80A, 001 = MZ-700, 010 = MZ800, 011 = MZ80B, 100 = MZ80K, 101 = MZ80C, 110 = MZ1200, 111 = MZ2000.
-- 0xFD=<val> memory page register. [1:0] switches in 1 16Kb page (3 pages) of graphics ram to C000 - FFFF. Bits [1:0] = page, 00 = off, 01 = Red, 10 = Green, 11 = Blue.
--
CTRLREGISTERS: process( RESETn, CLK16Mi, GRAM_PAGE_ENABLE, MZ80B_VRAM_HI_ADDR, MZ80B_VRAM_LO_ADDR )
begin
-- Ensure default values at reset.
if RESETn = '0' then
MODE_VIDEO_MZ80A <= '0';
MODE_VIDEO_MZ700 <= '1';
MODE_VIDEO_MZ800 <= '0';
MODE_VIDEO_MZ80B <= '0';
MODE_VIDEO_MZ80K <= '0';
MODE_VIDEO_MZ80C <= '0';
MODE_VIDEO_MZ1200 <= '0';
MODE_VIDEO_MZ2000 <= '0';
GRAM_PAGE_ENABLE <= '0';
MZ80B_VRAM_HI_ADDR <= '0';
MZ80B_VRAM_LO_ADDR <= '0';
MODE_CPLD_SWITCH <= '0';
CPLD_CFG_DATA <= "00000011";
elsif rising_edge(CLK16Mi) then
-- Write to config register.
-- CPLD Configuration register.
--
-- The mode can be changed by a Z80 transaction write into the register and it is acted upon if the mode switches between differing values. The Z80 write is typically used
-- by host software such as RFS.
--
-- [2:0] - Mode/emulated machine.
-- 000 = MZ-80K
-- 001 = MZ-80C
-- 010 = MZ-1200
-- 011 = MZ-80A
-- 100 = MZ-700
-- 101 = MZ-800
-- 110 = MZ-80B
-- 111 = MZ-2000
-- [3] - Mainboard Video - 1 = Enable, 0 = Disable - This flag allows Z-80 transactions in the range D000:DFFF to be directed to the mainboard. When disabled all transactions
-- can only be seen by the FPGA video logic. The FPGA uses this flag to enable/disable it's functionality.
-- [6:4] = Mainboard/CPU clock.
-- 000 = Sharp MZ80A 2MHz System Clock.
-- 001 = Sharp MZ80B 4MHz System Clock.
-- 010 = Sharp MZ700 3.54MHz System Clock.
-- 011 -111 = Reserved, defaults to 2MHz System Clock.
--
if(CS_CPLD_CFGn = '0' and CS_LAST_LEVEL(0) = '1' and S_VIDEO_WRn = '0') then
-- Set the mode switch event flag if the mode changes.
if CPLD_CFG_DATA(2 downto 0) /= D(2 downto 0) then
MODE_CPLD_SWITCH <= '1';
end if;
-- Store the new value into the register, used for read operations.
CPLD_CFG_DATA <= D;
else
MODE_CPLD_SWITCH <= '0';
end if;
-- Setup the video mode.
if CS_FB_VMn = '0' and CS_LAST_LEVEL(1) = '1' and S_VIDEO_WRn = '0' then
MODE_VIDEO_MZ80K <= '0';
MODE_VIDEO_MZ80C <= '0';
MODE_VIDEO_MZ1200 <= '0';
MODE_VIDEO_MZ80A <= '0';
MODE_VIDEO_MZ700 <= '0';
MODE_VIDEO_MZ800 <= '0';
MODE_VIDEO_MZ80B <= '0';
MODE_VIDEO_MZ2000 <= '0';
-- Bits [2:0] define the machine compatibility.
--
case to_integer(unsigned(D(2 downto 0))) is
when MODE_MZ80K =>
MODE_VIDEO_MZ80K <= '1';
when MODE_MZ80C =>
MODE_VIDEO_MZ80C <= '1';
when MODE_MZ1200 =>
MODE_VIDEO_MZ1200 <= '1';
when MODE_MZ80A =>
MODE_VIDEO_MZ80A <= '1';
when MODE_MZ700 =>
MODE_VIDEO_MZ700 <= '1';
when MODE_MZ800 =>
MODE_VIDEO_MZ800 <= '1';
when MODE_MZ80B =>
MODE_VIDEO_MZ80B <= '1';
when MODE_MZ2000 =>
MODE_VIDEO_MZ2000 <= '1';
when others =>
end case;
end if;
-- memory page register. [0] switches in 16Kb page (1 of 3 pages) of graphics ram to C000 - FFFF. Bits [0] = page, 0 = Off, 1 = Enabled. This overrides all MZ700/MZ80B page switching functions. [7] 0 - normal, 1 - switches in CGROM for upload at D000:DFFF.
if CS_FB_PAGEn = '0' and CS_LAST_LEVEL(2) = '1' and S_VIDEO_WRn = '0' then
GRAM_PAGE_ENABLE <= D(0);
end if;
-- MZ80B Z80 PIO.
if CS_80B_PIOn = '0' and CS_LAST_LEVEL(3) = '1' and MODE_VIDEO_MZ80B = '1' and S_VIDEO_WRn = '0' then
-- Write to PIO A.
-- 7 = Assigns addresses $DOOO-$FFFF to V-RAM.
-- 6 = Assigns addresses $5000-$7FFF to V-RAM.
-- 5 = Changes screen to 80-character mode (L: 40-character mode).
if VA(1 downto 0) = "00" then
MZ80B_VRAM_HI_ADDR <= D(7);
MZ80B_VRAM_LO_ADDR <= D(6);
end if;
end if;
-- Remember the previous level so we can detect the edge transition. As the clock of this process is not necessarily running at the clock of the CPU
-- this step is important to guarantee transaction integrity.
CS_LAST_LEVEL <= '0' & CS_80B_PIOn & CS_FB_PAGEn & CS_FB_VMn & CS_CPLD_CFGn;
end if;
-- MZ80B Graphics RAM is enabled whenever one of the two control lines goes active.
GRAM_MZ80B_ENABLE <= MZ80B_VRAM_HI_ADDR or MZ80B_VRAM_LO_ADDR;
end process;
-- Voltage translation. The FPGA is max 3.3v tolerant (as are nearly all FPGA's) so the 5V signals from the mainboard would have to go through a diode clamp
-- or converter. Given the pricing of the MAX7000 series chips it is easier and cheaper to use a CPLD to perform the voltage translation as they are 5V tolerant
-- and the mainboard accepts 3.3V output voltages.
--
VADDR <= VA(15 downto 11) & A(10 downto 0);
-- Data bus is muxed between the Z80 data bus and VRAMD which is the gated data bus after the video buffers.
-- The write signal WRn from the motherboard is actually a gated Write with video memory or I/O select. The read signal RDn from the motherboard is a gated Read with video memory or I/O select.
-- The logic has been updated in the tranZPUter to combine the Video Select with Z80 RD/WR such that use of S_VIDEO_RDn = 0 for read and S_VIDEO_WRn = 0 for write works as intended for all memory/IO operations. To
-- differentiate between memory and access, I/O operations use S_IORQn = 0.
--
VDATA <= D when S_VIDEO_WRn = '0' -- All memory write data sent to FPGA in region C000:FFFF
else
(others => 'Z');
D <= VDATA when S_VIDEO_RDn = '0' and CS_EXXXn = '1' -- C000:FFFF or FPGA IO Registers via data bus.
else
(others => 'Z');
VRAMD <= (others => 'Z');
VA(10 downto 0) <= A(10 downto 0); -- Lower 11 address bits taken from address bus.
VZ80_IORQn <= S_IORQn;
VZ80_WRn <= S_VIDEO_WRn; -- Write based on Z80_WRn and Video FPGA select signal from tranZPUter.
VZ80_RDn <= S_VIDEO_RDn; -- Read signal based on Z80_RDn and Video FPGA select from tranZPUter.
VGTn <= GTn;
VCSn <= CSn;
VVRAM_CS_INn <= VRAM_CS_INn;
-- Standard access to VRAM/ARAM.
CS_DXXXn <= '0' when S_IORQn = '1' and VA(15 downto 12) = "1101"
else '1';
CS_DVRAMn <= '0' when S_IORQn = '1' and VA(15 downto 11) = "11010"
else '1';
CS_DARAMn <= '0' when S_IORQn = '1' and VA(15 downto 11) = "11011"
else '1';
CS_EXXXn <= '0' when S_IORQn = '1' and VA(15 downto 11) = "11100" and GRAM_PAGE_ENABLE = '0' and (MODE_VIDEO_MZ80B = '0' or (MODE_VIDEO_MZ80B = '1' and GRAM_MZ80B_ENABLE = '0')) -- Normal memory mapped I/O if Graphics Option not enabled.
else '1';
--
-- CPU / RAM signals and selects.
--
CS_IO_6XXn <= '0' when S_IORQn = '0' and VA(7 downto 4) = "0110"
else '1';
CS_IO_EXXn <= '0' when S_IORQn = '0' and VA(7 downto 4) = "1110"
else '1';
CS_IO_FXXn <= '0' when S_IORQn = '0' and VA(7 downto 4) = "1111"
else '1';
CS_CPLD_CFGn <= '0' when CS_IO_6XXn = '0' and VA(3 downto 0) = "1110" -- IO 6E
else '1';
-- 0xF8 set the video mode. [2:0] = mode, 000 = MZ80A, 001 = MZ-700, 010 = MZ-80B, 011 = MZ-800, 111 = Pixel graphics.
CS_FB_VMn <= '0' when CS_IO_FXXn = '0' and VA(3 downto 0) = "1000"
else '1';
-- 0xFD set the Video memory page in block C000:FFFF bit 0, set the CGROM upload access in bit 7.
CS_FB_PAGEn <= '0' when CS_IO_FXXn = '0' and VA(3 downto 0) = "1101"
else '1';
-- MZ80B/MZ2000 I/O Registers E0-EB,
CS_80B_PIOn <= '0' when CS_IO_EXXn = '0' and VA(3 downto 2) = "10" and MODE_VIDEO_MZ80B = '1'
else '1';
-- Set the mainboard video state, 0 = enabled, 1 = disabled.
MODE_CPLD_MB_VIDEOn <= CPLD_CFG_DATA(3);
-- Set CPLD mode flag according to value given in config 2:0
MODE_CPLD_MZ80K <= '1' when to_integer(unsigned(CPLD_CFG_DATA(2 downto 0))) = MODE_MZ80K
else '0';
MODE_CPLD_MZ80C <= '1' when to_integer(unsigned(CPLD_CFG_DATA(2 downto 0))) = MODE_MZ80C
else '0';
MODE_CPLD_MZ1200 <= '1' when to_integer(unsigned(CPLD_CFG_DATA(2 downto 0))) = MODE_MZ1200
else '0';
MODE_CPLD_MZ80A <= '1' when to_integer(unsigned(CPLD_CFG_DATA(2 downto 0))) = MODE_MZ80A
else '0';
MODE_CPLD_MZ700 <= '1' when to_integer(unsigned(CPLD_CFG_DATA(2 downto 0))) = MODE_MZ700
else '0';
MODE_CPLD_MZ800 <= '1' when to_integer(unsigned(CPLD_CFG_DATA(2 downto 0))) = MODE_MZ800
else '0';
MODE_CPLD_MZ80B <= '1' when to_integer(unsigned(CPLD_CFG_DATA(2 downto 0))) = MODE_MZ80B
else '0';
MODE_CPLD_MZ2000 <= '1' when to_integer(unsigned(CPLD_CFG_DATA(2 downto 0))) = MODE_MZ2000
else '0';
end architecture;

View File

@@ -0,0 +1,201 @@
---------------------------------------------------------------------------------------------------------
--
-- Name: VideoInterface_Toplevel.vhd
-- Created: June 2020
-- Author(s): Philip Smart
-- Description: MZ80A Video Module CPLD Top Level module.
--
-- This module contains the basic pin definition of the CPLD<->logic<-->FPGA needed in
-- the project.
--
-- Credits:
-- Copyright: (c) 2018-20 Philip Smart <philip.smart@net2net.org>
--
-- History: June 2020 - Initial creation.
-- Sep 2020 - First release.
--
---------------------------------------------------------------------------------------------------------
-- This source file 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 source file 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->.
---------------------------------------------------------------------------------------------------------
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.numeric_std.all;
use work.VideoInterface_pkg.all;
library altera;
use altera.altera_syn_attributes.all;
entity VideoInterfaceCPLD is
port (
-- Primary video clock.
CLOCK_50 : in std_logic; -- 50MHz base clock for system board, video timing and gate clocking.
-- Z80 Address and Data. Address is muxed with video addressing, not direct.
A : in std_logic_vector(10 downto 0); -- Z80 Address bus, multiplexed with video address. 13..11 come from the tranZPUter board.
D : inout std_logic_vector(7 downto 0); -- Z80 Data bus, from the Colour Card CN! connector.
-- Z80 Control signals.
WRn : in std_logic; -- Z80 Write signal from the Colour Card CN! connector.
RDn : in std_logic; -- Z80 Read signal from the Colour Card CN! connector.
RESETn : in std_logic; -- Z80 RESET signal from the tranZPUter board.
MB_RESETn : in std_logic; -- Z80 RESET signal from the tranZPUter board.
-- Video and Mainboard signals.
SRVIDEO_OUT : out std_logic; -- Shift Register 74LS165 Video Output onto mainboard.
CLK_31_5K_OUT : out std_logic; -- 31.5KHz time base for the 8253 on mainboard. Signal was from the MB14298.
CLK_1MHZ_OUT : out std_logic; -- 1MHZ video timing clock output to mainboard. Signal was from the MB14298.
CLK_2MHZ_OUT : out std_logic; -- 2MHZ main CPU clock output to mainboard. Signal was from the MB14298.
HBLNK_OUTn : out std_logic; -- Horizontal Blanking output. Signal was from the MB14298.
HSY_OUT : out std_logic; -- Horizontal sync output. Signal was from the MB14298.
SYNCH_OUT : out std_logic; -- Vertical sync output. Signal was from the MB14298.
VBLNK_OUTn : out std_logic; -- Vertical blanking output. Signal was from the MB14298.
MB_HBLNKn : in std_logic; -- Mainboard Horizontal Blanking from the Colour Card CN! connector.
MB_SYNCH : in std_logic; -- Mainboard Vertical sync from the Colour Card CN! connector.
MB_V_HBLNKn : in std_logic; -- Mainboard combined vertical/horizontal sync from the Colour Card CN! connector.
MB_VIDEO : in std_logic; -- Mainboard Video (74LS165 output combined with GATE) from the Colour Card CN! connector.
MB_LOAD : in std_logic; -- Mainboard shift register load signal from the Colour Card CN! connector.
VRAM_CS_INn : in std_logic; -- Chip Select for access to the Video RAM from the mainboard IC15 socket.
GTn : in std_logic; -- GATE signal from the Colour Card CN! connector.
CSn : in std_logic; -- Chip Select for the Video Attribute RAM from the Colour Card CN! connector.
OUTCLK : out std_logic; -- CPU signal serialiser clock.
INDATA : in std_logic_vector(3 downto 0); -- Incoming serialised CPU signals.
-- V[name] = Voltage translated signals which mirror the mainboard signals but at a lower voltage.
VADDR : out std_logic_vector(15 downto 0); -- Z80 Address bus, multiplexed with video address.
VDATA : inout std_logic_vector(7 downto 0); -- Z80 Data bus from mainboard Colour Card CD connector..
VRAMD : inout std_logic_vector(7 downto 0); -- Z80 Data bus from the VRAM chip, gated according to state signals.
--VMEM_CSn : out std_logic; -- Extended memory select to FPGA.
VZ80_IORQn : out std_logic; -- IORQn to FPGA.
VZ80_RDn : out std_logic; -- RDn to FPGA.
VZ80_WRn : out std_logic; -- WRn to FPGA.
VVRAM_CS_INn : out std_logic; -- Chip Select for access to the Video RAM from the mainboard IC15 socket.
VWAITn : in std_logic; -- WAIT signal from FPGA asserted during active frame display period.
VCSn : out std_logic; -- Video RAM Attribute Chip Select (CSn) to FPGA.
VGTn : out std_logic; -- Video Gate (GTn)
VRESETn : out std_logic; -- Reset to FPGA.
--
VSRVIDEO_OUT : in std_logic; -- Video out from 74LS165 on mainboard, pre-GATE.
VHBLNK_OUTn : in std_logic; -- Horizontal blanking.
VHSY_OUT : in std_logic; -- Horizontal Sync.
VSYNCH_OUT : in std_logic; -- Veritcal Sync.
VVBLNK_OUTn : in std_logic; -- Vertical blanking.
--
VMB_HBLNKn : out std_logic; -- Horizontal Blanking from the Colour Card CN! connector.
VMB_SYNCH : out std_logic; -- Vertical sync from the Colour Card CN! connector.
VMB_V_HBLNKn : out std_logic; -- combined vertical/horizontal sync from the Colour Card CN! connector.
VMB_VIDEO : out std_logic; -- Video (74LS165 output combined with GATE) from the Colour Card CN! connector.
VMB_LOAD : out std_logic -- shift register load signal from the Colour Card CN! connector.
-- Reserved.
--TBA : in std_logic_vector(1 downto 0) -- Reserved signals.
);
END entity;
architecture rtl of VideoInterfaceCPLD is
signal CPLDRESETn : std_logic;
signal RESET_COUNTER : unsigned(2 downto 0);
begin
myVirtualToplevel : entity work.VideoInterface
--generic map
--(
--)
port map
(
-- Primary video clock.
CLOCK_50 => CLOCK_50, -- 50MHz base clock for system board, video timing and gate clocking.
-- Z80 Address and Data. Address is muxed with video addressing, not direct.
A => A, -- Z80 Address bus, multiplexed with video address. 13..11 come from the tranZPUter board.
D => D, -- Z80 Data bus, from the Colour Card CN! connector.
-- Z80 Control signals.
WRn => WRn, -- Z80 Write signal from the Colour Card CN! connector.
RDn => RDn, -- Z80 Read signal from the Colour Card CN! connector.
RESETn => CPLDRESETn, -- Z80 RESET signal from the tranZPUter board.
-- IORQn => IORQn, -- Z80 IORQ signal from the tranZPUter board.
-- Video and Mainboard signals.
SRVIDEO_OUT => SRVIDEO_OUT, -- Shift Register 74LS165 Video Output onto mainboard.
CLK_31_5K_OUT => CLK_31_5K_OUT, -- 31.5KHz time base for the 8253 on mainboard. Signal was from the MB14298.
CLK_1MHZ_OUT => CLK_1MHZ_OUT, -- 1MHZ video timing clock output to mainboard. Signal was from the MB14298.
CLK_2MHZ_OUT => CLK_2MHZ_OUT, -- 2MHZ main CPU clock output to mainboard. Signal was from the MB14298.
HBLNK_OUTn => HBLNK_OUTn, -- Horizontal Blanking output. Signal was from the MB14298.
HSY_OUT => HSY_OUT, -- Horizontal sync output. Signal was from the MB14298.
SYNCH_OUT => SYNCH_OUT, -- Vertical sync output. Signal was from the MB14298.
VBLNK_OUTn => VBLNK_OUTn, -- Vertical blanking output. Signal was from the MB14298.
MB_HBLNKn => MB_HBLNKn, -- Mainboard Horizontal Blanking from the Colour Card CN! connector.
MB_SYNCH => MB_SYNCH, -- Mainboard Vertical sync from the Colour Card CN! connector.
MB_V_HBLNKn => MB_V_HBLNKn, -- Mainboard combined vertical/horizontal sync from the Colour Card CN! connector.
MB_VIDEO => MB_VIDEO, -- Mainboard Video (74LS165 output combined with GATE) from the Colour Card CN! connector.
MB_LOAD => MB_LOAD, -- Mainboard shift register load signal from the Colour Card CN! connector.
VRAM_CS_INn => VRAM_CS_INn, -- Chip Select for access to the Video RAM from the mainboard IC15 socket.
GTn => GTn, -- GATE signal from the Colour Card CN! connector.
CSn => CSn, -- Chip Select for the Video Attribute RAM from the Colour Card CN! connector.
-- MEM_CSn => MEM_CSn, -- Extended memory select for region 0xE000 - 0xFFFF from the tranZPUter board.
OUTCLK => OUTCLK, -- CPU signal serialiser clock.
INDATA => INDATA, -- Incoming serialised CPU signals.
-- V[name] = Voltage translated signals which mirror the mainboard signals but at a lower voltage.
VADDR => VADDR, -- Z80 Address bus, multiplexed with video address.
VDATA => VDATA, -- Z80 Data bus from mainboard Colour Card CD connector..
VRAMD => VRAMD, -- Z80 Data bus from the VRAM chip, gated according to state signals.
--VMEM_CSn => VMEM_CSn, -- Extended memory select to FPGA.
VZ80_IORQn => VZ80_IORQn, -- IORQn to FPGA.
VZ80_RDn => VZ80_RDn, -- RDn to FPGA.
VZ80_WRn => VZ80_WRn, -- WRn to FPGA.
VVRAM_CS_INn => VVRAM_CS_INn, -- Chip Select for access to the Video RAM from the mainboard IC15 socket.
VWAITn => VWAITn, -- WAIT signal from FPGA asserted during active frame display period.
VCSn => VCSn, -- Video RAM Attribute Chip Select (CSn) to FPGA.
VGTn => VGTn, -- Video Gate (GTn)
VSRVIDEO_OUT => VSRVIDEO_OUT, -- Video out from 74LS165 on mainboard, pre-GATE.
VHBLNK_OUTn => VHBLNK_OUTn, -- Horizontal blanking.
VHSY_OUT => VHSY_OUT, -- Horizontal Sync.
VSYNCH_OUT => VSYNCH_OUT, -- Veritcal Sync.
VVBLNK_OUTn => VVBLNK_OUTn, -- Vertical blanking.
VMB_HBLNKn => VMB_HBLNKn, -- Horizontal Blanking from the Colour Card CN! connector.
VMB_SYNCH => VMB_SYNCH, -- Vertical sync from the Colour Card CN! connector.
VMB_V_HBLNKn => VMB_V_HBLNKn, -- combined vertical/horizontal sync from the Colour Card CN! connector.
VMB_VIDEO => VMB_VIDEO, -- Video (74LS165 output combined with GATE) from the Colour Card CN! connector.
VMB_LOAD => VMB_LOAD -- shift register load signal from the Colour Card CN! connector.
-- Reserved.
--TBA => TBA -- Reserved signals.
);
-- Process to reset the CPLD based on a minimum number of clock cycles to tie in with the FPGA. We dont want the
-- CPU starting up until the FPGA is ready.
--
CPLDRESET: process(RESETn, MB_RESETn, CLOCK_50)
begin
if RESETn = '0' or MB_RESETn = '0' then
RESET_COUNTER <= (others => '1');
CPLDRESETn <= '0';
elsif rising_edge(CLOCK_50) then
if RESET_COUNTER /= 0 then
RESET_COUNTER <= RESET_COUNTER - 1;
else
CPLDRESETn <= '1';
end if;
end if;
end process;
-- Reset to FPGA uses the mainboard reset.
VRESETn <= RESETn;
end architecture;

191
CPLD/VideoInterface_pkg.vhd Normal file
View File

@@ -0,0 +1,191 @@
---------------------------------------------------------------------------------------------------------
--
-- Name: VideoInterface_pkg.vhd
-- Created: June 2020
-- Author(s): Philip Smart
-- Description: Sharp MZ80A Video Module v2.0 CPLD configuration file.
--
-- This module contains parameters for the CPLD in v2.0 of the Sharp MZ80A Video Module
-- project.
--
-- Credits:
-- Copyright: (c) 2018-20 Philip Smart <philip.smart@net2net.org>
--
-- History: June 2020 - Initial creation.
--
---------------------------------------------------------------------------------------------------------
-- This source file 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 source file 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->.
---------------------------------------------------------------------------------------------------------
library ieee;
library pkgs;
use ieee.std_logic_1164.all;
use ieee.numeric_std.all;
use ieee.math_real.all;
package VideoInterface_pkg is
------------------------------------------------------------
-- Constants
------------------------------------------------------------
-- Potential logic state constants.
constant YES : std_logic := '1';
constant NO : std_logic := '0';
constant HI : std_logic := '1';
constant LO : std_logic := '0';
constant ONE : std_logic := '1';
constant ZERO : std_logic := '0';
constant HIZ : std_logic := 'Z';
-- Target hardware modes.
constant MODE_MZ80K : integer := 0;
constant MODE_MZ80C : integer := 1;
constant MODE_MZ1200 : integer := 2;
constant MODE_MZ80A : integer := 3;
constant MODE_MZ700 : integer := 4;
constant MODE_MZ800 : integer := 5;
constant MODE_MZ80B : integer := 6;
constant MODE_MZ2000 : integer := 7;
-- Target Bus frequency modes.
constant MODE_FREQ_MZ80A : integer := 0;
constant MODE_FREQ_MZ80B : integer := 1;
constant MODE_FREQ_MZ700 : integer := 2;
constant MODE_FREQ_CUSTOM : integer := 7;
-- Memory management modes.
constant TZMM_ORIG : integer := 00; -- Original Sharp mode, no tranZPUter features are selected except the I/O control registers (default: 0x60-063).
constant TZMM_BOOT : integer := 01; -- Original mode but E800-EFFF is mapped to tranZPUter RAM so TZFS can be booted.
constant TZMM_TZFS : integer := 02; -- TZFS main memory configuration. all memory is in tranZPUter RAM, E800-FFFF is used by TZFS, SA1510 is at 0000-1000 and RAM is 1000-CFFF, 64K Block 0 selected.
constant TZMM_TZFS2 : integer := 03; -- TZFS main memory configuration. all memory is in tranZPUter RAM, E800-EFFF is used by TZFS, SA1510 is at 0000-1000 and RAM is 1000-CFFF, 64K Block 0 selected, F000-FFFF is in 64K Block 1.
constant TZMM_TZFS3 : integer := 04; -- TZFS main memory configuration. all memory is in tranZPUter RAM, E800-EFFF is used by TZFS, SA1510 is at 0000-1000 and RAM is 1000-CFFF, 64K Block 0 selected, F000-FFFF is in 64K Block 2.
constant TZMM_TZFS4 : integer := 05; -- TZFS main memory configuration. all memory is in tranZPUter RAM, E800-EFFF is used by TZFS, SA1510 is at 0000-1000 and RAM is 1000-CFFF, 64K Block 0 selected, F000-FFFF is in 64K Block 3.
constant TZMM_CPM : integer := 06; -- CPM main memory configuration, all memory on the tranZPUter board, 64K block 4 selected. Special case for F3C0:F3FF & F7C0:F7FF (floppy disk paging vectors) which resides on the mainboard.
constant TZMM_CPM2 : integer := 07; -- CPM main memory configuration, F000-FFFF are on the tranZPUter board in block 4, 0040-CFFF and E800-EFFF are in block 5, mainboard for D000-DFFF (video), E000-E800 (Memory control) selected.
-- Special case for 0000:003F (interrupt vectors) which resides in block 4, F3FE:F3FF & F7FE:F7FF (floppy disk paging vectors) which resides on the mainboard.
constant TZMM_COMPAT : integer := 08; -- Compatible monitor mode, monitor ROM on mainboard, RAM on tranZPUter in Block 0 1000-CFFF.
constant TZMM_MZ700_0 : integer := 10; -- MZ700 Mode - 0000:0FFF is on the tranZPUter board in block 6, 1000:CFFF is on the tranZPUter board in block 0, D000:FFFF is on the mainboard.
constant TZMM_MZ700_1 : integer := 11; -- MZ700 Mode - 0000:0FFF is on the tranZPUter board in block 0, 1000:CFFF is on the tranZPUter board in block 0, D000:FFFF is on the tranZPUter in block 6.
constant TZMM_MZ700_2 : integer := 12; -- MZ700 Mode - 0000:0FFF is on the tranZPUter board in block 6, 1000:CFFF is on the tranZPUter board in block 0, D000:FFFF is on the tranZPUter in block 6.
constant TZMM_MZ700_3 : integer := 13; -- MZ700 Mode - 0000:0FFF is on the tranZPUter board in block 0, 1000:CFFF is on the tranZPUter board in block 0, D000:FFFF is inaccessible.
constant TZMM_MZ700_4 : integer := 14; -- MZ700 Mode - 0000:0FFF is on the tranZPUter board in block 6, 1000:CFFF is on the tranZPUter board in block 0, D000:FFFF is inaccessible.
constant TZMM_TZPU0 : integer := 24; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 0 is selected.
constant TZMM_TZPU1 : integer := 25; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 1 is selected.
constant TZMM_TZPU2 : integer := 26; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 2 is selected.
constant TZMM_TZPU3 : integer := 27; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 3 is selected.
constant TZMM_TZPU4 : integer := 28; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 4 is selected.
constant TZMM_TZPU5 : integer := 29; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 5 is selected.
constant TZMM_TZPU6 : integer := 30; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 6 is selected.
constant TZMM_TZPU7 : integer := 31; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 7 is selected.
------------------------------------------------------------
-- Configurable parameters.
------------------------------------------------------------
-- Target hardware.
constant CPLD_HOST_HW : integer := MODE_MZ80A;
-- Target video hardware.
constant CPLD_HAS_FPGA_VIDEO : std_logic := '1';
-- Version of hdl.
constant CPLD_VERSION : integer := 1;
-- Clock source for the secondary clock. If a K64F is installed the enable it otherwise use the onboard oscillator.
--
constant USE_K64F_CTL_CLOCK : integer := 1;
------------------------------------------------------------
-- Function prototypes
------------------------------------------------------------
-- Find the maximum of two integers.
function IntMax(a : in integer; b : in integer) return integer;
-- Find the number of bits required to represent an integer.
function log2ceil(arg : positive) return natural;
-- Function to calculate the number of whole 'clock' cycles in a given time period, the period being in ns.
function clockTicks(period : in integer; clock : in integer) return integer;
-- Function to return the value of a bit as an integer for array indexing etc.
function bit_to_integer( s : std_logic ) return natural;
------------------------------------------------------------
-- Records
------------------------------------------------------------
------------------------------------------------------------
-- Components
------------------------------------------------------------
end VideoInterface_pkg;
------------------------------------------------------------
-- Function definitions.
------------------------------------------------------------
package body VideoInterface_pkg is
-- Find the maximum of two integers.
function IntMax(a : in integer; b : in integer) return integer is
begin
if a > b then
return a;
else
return b;
end if;
return a;
end function IntMax;
-- Find the number of bits required to represent an integer.
function log2ceil(arg : positive) return natural is
variable tmp : positive := 1;
variable log : natural := 0;
begin
if arg = 1 then
return 0;
end if;
while arg > tmp loop
tmp := tmp * 2;
log := log + 1;
end loop;
return log;
end function;
-- Function to calculate the number of whole 'clock' cycles in a given time period, the period being in ns.
function clockTicks(period : in integer; clock : in integer) return integer is
variable ticks : real;
variable fracTicks : real;
begin
ticks := (Real(period) * Real(clock)) / 1000000000.0;
fracTicks := ticks - CEIL(ticks);
if fracTicks > 0.0001 then
return Integer(CEIL(ticks + 1.0));
else
return Integer(CEIL(ticks));
end if;
end function;
-- Function to return the value of a bit as an integer for array indexing etc.
function bit_to_integer( s : std_logic ) return natural is
begin
if s = '1' then
return 1;
else
return 0;
end if;
end function;
end package body;

View File

@@ -0,0 +1,30 @@
# -------------------------------------------------------------------------- #
#
# Copyright (C) 1991-2013 Altera Corporation
# Your use of Altera Corporation's design tools, logic functions
# and other software and tools, and its AMPP partner logic
# functions, and any output files from any of the foregoing
# (including device programming or simulation files), and any
# associated documentation or information are expressly subject
# to the terms and conditions of the Altera Program License
# Subscription Agreement, Altera MegaCore Function License
# Agreement, or other applicable license agreement, including,
# without limitation, that your use is for the sole purpose of
# programming logic devices manufactured by Altera and sold by
# Altera or its authorized distributors. Please refer to the
# applicable agreement for further details.
#
# -------------------------------------------------------------------------- #
#
# Quartus II 64-Bit
# Version 13.0.1 Build 232 06/12/2013 Service Pack 1 SJ Web Edition
# Date created = 16:29:32 June 24, 2020
#
# -------------------------------------------------------------------------- #
QUARTUS_VERSION = "13.0"
DATE = "16:29:32 June 24, 2020"
# Revisions
PROJECT_REVISION = "VideoInterface"

View File

@@ -0,0 +1,217 @@
# -------------------------------------------------------------------------- #
#
# Copyright (C) 1991-2013 Altera Corporation
# Your use of Altera Corporation's design tools, logic functions
# and other software and tools, and its AMPP partner logic
# functions, and any output files from any of the foregoing
# (including device programming or simulation files), and any
# associated documentation or information are expressly subject
# to the terms and conditions of the Altera Program License
# Subscription Agreement, Altera MegaCore Function License
# Agreement, or other applicable license agreement, including,
# without limitation, that your use is for the sole purpose of
# programming logic devices manufactured by Altera and sold by
# Altera or its authorized distributors. Please refer to the
# applicable agreement for further details.
#
# -------------------------------------------------------------------------- #
#
# Quartus II 64-Bit
# Version 13.0.1 Build 232 06/12/2013 Service Pack 1 SJ Web Edition
# Date created = 16:29:32 June 24, 2020
#
# -------------------------------------------------------------------------- #
#
# Notes:
#
# 1) The default values for assignments are stored in the file:
# tranZPUterSW_assignment_defaults.qdf
# If this file doesn't exist, see file:
# assignment_defaults.qdf
#
# 2) Altera recommends that you do not modify this file. This
# file is updated automatically by the Quartus II software
# and any changes you make may be lost or overwritten.
#
# -------------------------------------------------------------------------- #
set_global_assignment -name FAMILY MAX7000AE
set_global_assignment -name DEVICE "EPM7512AETC144-12"
set_global_assignment -name TOP_LEVEL_ENTITY VideoInterfaceCPLD
set_global_assignment -name ORIGINAL_QUARTUS_VERSION "13.0 SP1"
set_global_assignment -name PROJECT_CREATION_TIME_DATE "16:29:32 JUNE 24, 2020"
set_global_assignment -name LAST_QUARTUS_VERSION "13.0 SP1"
set_global_assignment -name PROJECT_OUTPUT_DIRECTORY output_files
set_global_assignment -name ERROR_CHECK_FREQUENCY_DIVISOR "-1"
set_global_assignment -name EDA_DESIGN_ENTRY_SYNTHESIS_TOOL "<None>"
set_global_assignment -name EDA_INPUT_VCC_NAME VCC -section_id eda_design_synthesis
set_global_assignment -name EDA_INPUT_DATA_FORMAT EDIF -section_id eda_design_synthesis
set_global_assignment -name EDA_SIMULATION_TOOL "ModelSim-Altera (VHDL)"
set_global_assignment -name EDA_OUTPUT_DATA_FORMAT VHDL -section_id eda_simulation
set_global_assignment -name OPTIMIZE_HOLD_TIMING OFF
set_global_assignment -name OPTIMIZE_MULTI_CORNER_TIMING OFF
set_global_assignment -name FITTER_EFFORT "STANDARD FIT"
set_global_assignment -name MAX7000_DEVICE_IO_STANDARD LVTTL
# Global clocks.
# ==============
set_location_assignment PIN_125 -to CLOCK_50
# Z80 Address Bus
# ===============
#set_location_assignment PIN_90 -to A[13]
#set_location_assignment PIN_88 -to A[12]
#set_location_assignment PIN_87 -to A[11]
set_location_assignment PIN_98 -to A[10]
set_location_assignment PIN_101 -to A[9]
set_location_assignment PIN_103 -to A[8]
set_location_assignment PIN_106 -to A[7]
set_location_assignment PIN_108 -to A[6]
set_location_assignment PIN_110 -to A[5]
set_location_assignment PIN_112 -to A[4]
set_location_assignment PIN_114 -to A[3]
set_location_assignment PIN_117 -to A[2]
set_location_assignment PIN_119 -to A[1]
set_location_assignment PIN_121 -to A[0]
# Video Interface Address Bus
# ===========================
set_location_assignment PIN_69 -to VADDR[15]
set_location_assignment PIN_68 -to VADDR[14]
set_location_assignment PIN_42 -to VADDR[13]
set_location_assignment PIN_41 -to VADDR[12]
set_location_assignment PIN_40 -to VADDR[11]
set_location_assignment PIN_39 -to VADDR[10]
set_location_assignment PIN_38 -to VADDR[9]
set_location_assignment PIN_37 -to VADDR[8]
set_location_assignment PIN_36 -to VADDR[7]
set_location_assignment PIN_35 -to VADDR[6]
set_location_assignment PIN_34 -to VADDR[5]
set_location_assignment PIN_32 -to VADDR[4]
set_location_assignment PIN_31 -to VADDR[3]
set_location_assignment PIN_30 -to VADDR[2]
set_location_assignment PIN_29 -to VADDR[1]
set_location_assignment PIN_28 -to VADDR[0]
# Clock outputs.
# ==============
set_location_assignment PIN_7 -to CLK_1MHZ_OUT
set_location_assignment PIN_10 -to CLK_2MHZ_OUT
set_location_assignment PIN_9 -to CLK_31_5K_OUT
# Z80 control signals
# ===================
set_location_assignment PIN_92 -to CSn
set_location_assignment PIN_93 -to GTn
#set_location_assignment PIN_84 -to IORQn
#set_location_assignment PIN_83 -to MEM_CSn
set_location_assignment PIN_86 -to MB_RESETn
set_location_assignment PIN_127 -to RESETn
set_location_assignment PIN_91 -to RDn
set_location_assignment PIN_96 -to WRn
set_location_assignment PIN_16 -to VRAM_CS_INn
set_location_assignment PIN_90 -to INDATA[3]
set_location_assignment PIN_88 -to INDATA[2]
set_location_assignment PIN_87 -to INDATA[1]
set_location_assignment PIN_84 -to INDATA[0]
set_location_assignment PIN_83 -to OUTCLK
# Z80 Data Bus
# ============
set_location_assignment PIN_107 -to D[7]
set_location_assignment PIN_109 -to D[6]
set_location_assignment PIN_111 -to D[5]
set_location_assignment PIN_113 -to D[4]
set_location_assignment PIN_116 -to D[3]
set_location_assignment PIN_118 -to D[2]
set_location_assignment PIN_120 -to D[1]
set_location_assignment PIN_122 -to D[0]
# Video Data Bus
# ==============
set_location_assignment PIN_53 -to VDATA[7]
set_location_assignment PIN_54 -to VDATA[6]
set_location_assignment PIN_55 -to VDATA[5]
set_location_assignment PIN_56 -to VDATA[4]
set_location_assignment PIN_60 -to VDATA[3]
set_location_assignment PIN_61 -to VDATA[2]
set_location_assignment PIN_62 -to VDATA[1]
set_location_assignment PIN_63 -to VDATA[0]
# VRAM Data Bus
# =============
set_location_assignment PIN_18 -to VRAMD[7]
set_location_assignment PIN_19 -to VRAMD[6]
set_location_assignment PIN_21 -to VRAMD[5]
set_location_assignment PIN_22 -to VRAMD[4]
set_location_assignment PIN_23 -to VRAMD[3]
set_location_assignment PIN_14 -to VRAMD[2]
set_location_assignment PIN_12 -to VRAMD[1]
set_location_assignment PIN_11 -to VRAMD[0]
# Mainboard video signals on the CN1 connector.
# =============================================
set_location_assignment PIN_94 -to MB_HBLNKn
set_location_assignment PIN_100 -to MB_LOAD
set_location_assignment PIN_97 -to MB_SYNCH
set_location_assignment PIN_99 -to MB_V_HBLNKn
set_location_assignment PIN_102 -to MB_VIDEO
# Mainboard video signals on the CN1 connector passed to the FPGA.
# ================================================================
set_location_assignment PIN_75 -to VMB_HBLNKn
set_location_assignment PIN_74 -to VMB_LOAD
set_location_assignment PIN_72 -to VMB_SYNCH
set_location_assignment PIN_71 -to VMB_V_HBLNKn
set_location_assignment PIN_70 -to VMB_VIDEO
# Generated video signals.
# ========================
set_location_assignment PIN_1 -to HBLNK_OUTn
set_location_assignment PIN_2 -to HSY_OUT
set_location_assignment PIN_15 -to SRVIDEO_OUT
set_location_assignment PIN_8 -to SYNCH_OUT
set_location_assignment PIN_6 -to VBLNK_OUTn
# FPGA Generated video signals.
# =============================
set_location_assignment PIN_80 -to VHBLNK_OUTn
set_location_assignment PIN_79 -to VHSY_OUT
set_location_assignment PIN_81 -to VSRVIDEO_OUT
set_location_assignment PIN_78 -to VSYNCH_OUT
set_location_assignment PIN_77 -to VVBLNK_OUTn
# Video control signals.
# ======================
set_location_assignment PIN_46 -to VCSn
set_location_assignment PIN_47 -to VGTn
set_location_assignment PIN_44 -to VZ80_IORQn
#set_location_assignment PIN_43 -to VMEM_CSn
set_location_assignment PIN_67 -to VWAITn
set_location_assignment PIN_45 -to VZ80_RDn
set_location_assignment PIN_49 -to VRESETn
set_location_assignment PIN_27 -to VVRAM_CS_INn
set_location_assignment PIN_48 -to VZ80_WRn
# Reserved.
# =========
#set_location_assignment PIN_66 -to TBA[1]
#set_location_assignment PIN_65 -to TBA[0]
set_global_assignment -name VHDL_FILE ../VideoInterface_Toplevel.vhd
set_global_assignment -name VHDL_FILE ../VideoInterface_pkg.vhd
set_global_assignment -name VHDL_FILE ../VideoInterface.vhd
set_global_assignment -name SDC_FILE VideoInterface_constraints.sdc
set_global_assignment -name SYNTH_TIMING_DRIVEN_SYNTHESIS OFF
set_global_assignment -name MAX7000_OPTIMIZATION_TECHNIQUE AREA
set_global_assignment -name AUTO_RESOURCE_SHARING OFF
set_global_assignment -name PRE_MAPPING_RESYNTHESIS OFF
set_global_assignment -name USE_LOGICLOCK_CONSTRAINTS_IN_BALANCING OFF
set_global_assignment -name AUTO_LCELL_INSERTION OFF
set_global_assignment -name VHDL_INPUT_VERSION VHDL_2008
set_global_assignment -name VHDL_SHOW_LMF_MAPPING_MESSAGES OFF

View File

@@ -0,0 +1,59 @@
{ "" "" "" "Found combinational loop of 2 nodes" { } { } 0 332125 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Macrocell buffer inserted after node \"Z80_BUSACKn\"" { } { } 0 163076 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Found combinational loop of 5 nodes" { } { } 0 332125 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "TimeQuest Timing Analyzer does not support the analysis of latches as synchronous elements for the currently selected device family." { } { } 0 335095 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(127): object \"MODE_CPLD_MZ80K\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(157): object \"MODE_VIDEO_MZ80C\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(156): object \"MODE_VIDEO_MZ80K\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(154): object \"MODE_VIDEO_MZ800\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(153): object \"MODE_VIDEO_MZ700\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(158): object \"MODE_VIDEO_MZ1200\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(136): object \"MODE_CPLD_MB_VIDEOn\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(152): object \"MODE_VIDEO_MZ80A\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(134): object \"MODE_CPLD_MZ2000\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(133): object \"MODE_CPLD_MZ80B\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(132): object \"MODE_CPLD_MZ800\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(131): object \"MODE_CPLD_MZ700\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(130): object \"MODE_CPLD_MZ80A\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(129): object \"MODE_CPLD_MZ1200\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(135): object \"MODE_CPLD_SWITCH\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(128): object \"MODE_CPLD_MZ80C\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(160): object \"GRAM_PAGE_ENABLE\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(159): object \"MODE_VIDEO_MZ2000\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(161): object \"MZ80B_VRAM_HI_ADDR\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(162): object \"MZ80B_VRAM_LO_ADDR\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(150): object \"MODE_VIDEO_MZ80A\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(151): object \"MODE_VIDEO_MZ700\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(152): object \"MODE_VIDEO_MZ800\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(154): object \"MODE_VIDEO_MZ80K\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(155): object \"MODE_VIDEO_MZ80C\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(156): object \"MODE_VIDEO_MZ1200\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(154): object \"MODE_VIDEO_MZ80A\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(155): object \"MODE_VIDEO_MZ700\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(156): object \"MODE_VIDEO_MZ800\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(158): object \"MODE_VIDEO_MZ80K\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(159): object \"MODE_VIDEO_MZ80C\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(160): object \"MODE_VIDEO_MZ1200\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(161): object \"MODE_VIDEO_MZ2000\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(128): object \"MODE_CPLD_MZ80K\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(129): object \"MODE_CPLD_MZ80C\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(130): object \"MODE_CPLD_MZ1200\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(131): object \"MODE_CPLD_MZ80A\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(132): object \"MODE_CPLD_MZ700\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(133): object \"MODE_CPLD_MZ800\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(134): object \"MODE_CPLD_MZ80B\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(135): object \"MODE_CPLD_MZ2000\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(136): object \"MODE_CPLD_SWITCH\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(137): object \"MODE_CPLD_MB_VIDEOn\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(155): object \"MODE_VIDEO_MZ80A\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(156): object \"MODE_VIDEO_MZ700\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(157): object \"MODE_VIDEO_MZ800\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(159): object \"MODE_VIDEO_MZ80K\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(160): object \"MODE_VIDEO_MZ80C\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(161): object \"MODE_VIDEO_MZ1200\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(162): object \"MODE_VIDEO_MZ2000\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(149): object \"CS_DXXXn\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(151): object \"CS_DVRAMn\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "Verilog HDL or VHDL warning at VideoInterface.vhd(152): object \"CS_DARAMn\" assigned a value but never read" { } { } 0 10036 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "*" { } { } 0 10631 "" 0 0 "Quartus II" 0 -1 0 ""}
{ "" "" "" "*" { } { } 0 163076 "" 0 0 "Quartus II" 0 -1 0 ""}

View File

@@ -0,0 +1,232 @@
## Generated SDC file "VideoInterface.out.sdc"
## Copyright (C) 1991-2013 Altera Corporation
## Your use of Altera Corporation's design tools, logic functions
## and other software and tools, and its AMPP partner logic
## functions, and any output files from any of the foregoing
## (including device programming or simulation files), and any
## associated documentation or information are expressly subject
## to the terms and conditions of the Altera Program License
## Subscription Agreement, Altera MegaCore Function License
## Agreement, or other applicable license agreement, including,
## without limitation, that your use is for the sole purpose of
## programming logic devices manufactured by Altera and sold by
## Altera or its authorized distributors. Please refer to the
## applicable agreement for further details.
## VENDOR "Altera"
## PROGRAM "Quartus II"
## VERSION "Version 13.0.1 Build 232 06/12/2013 Service Pack 1 SJ Web Edition"
## DATE "Mon Aug 17 12:55:02 2020"
##
## DEVICE "EPM7512AETC144-12"
##
#**************************************************************
# Time Information
#**************************************************************
set_time_format -unit ns -decimal_places 3
#**************************************************************
# Create Clock
#**************************************************************
create_clock -name {CLOCK_50} -period 20.00 -waveform { 0.000 10.00 } [get_ports { CLOCK_50 }]
#**************************************************************
# Create Generated Clock
#**************************************************************
create_clock -name {VideoInterface:myVirtualToplevel|CLK16Mi} -period 62.5 [get_keepers {VideoInterface:myVirtualToplevel|CLK16Mi}]
create_clock -name {VideoInterface:myVirtualToplevel|CLK24Mi} -period 41.667 [get_keepers {VideoInterface:myVirtualToplevel|CLK24Mi}]
#**************************************************************
# Set Clock Latency
#**************************************************************
#**************************************************************
# Set Clock Uncertainty
#**************************************************************
#**************************************************************
# Set Input Delay
#**************************************************************
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {CLOCK_50}]
#set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[13]}]
#set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[12]}]
#set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[11]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[10]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[9]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[8]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[7]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[6]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[5]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[4]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[3]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[2]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[1]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {A[0]}]
#set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {IORQn}]
#set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {MEM_CSn}]
#set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {WRn}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {CSn}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {GTn}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {RESETn}]
#set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {RDn}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {INDATA[3]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {INDATA[2]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {INDATA[1]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {INDATA[0]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAM_CS_INn}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[7]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[6]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[5]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[4]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[3]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[2]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[1]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[0]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[7]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[6]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[5]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[4]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[3]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[2]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[1]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[0]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[7]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[6]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[5]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[4]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[3]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[2]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[1]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[0]}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {MB_RESETn}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {MB_HBLNKn}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {MB_LOAD}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {MB_SYNCH}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {MB_V_HBLNKn}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {MB_VIDEO}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VSRVIDEO_OUT}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VSYNCH_OUT}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VVBLNK_OUTn}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VHBLNK_OUTn}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VHSY_OUT}]
#**************************************************************
# Set Output Delay
#**************************************************************
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[7]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[6]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[5]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[4]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[3]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[2]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[1]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {D[0]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[15]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[14]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[13]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[12]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[11]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[10]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[9]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[8]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[7]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[6]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[5]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[4]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[3]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[2]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[1]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VADDR[0]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[7]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[6]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[5]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[4]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[3]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[2]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[1]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VDATA[0]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[7]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[6]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[5]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[4]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[3]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[2]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[1]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRAMD[0]}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {HBLNK_OUTn}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {HSY_OUT}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {SRVIDEO_OUT}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {SYNCH_OUT}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VBLNK_OUTn}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VCSn}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VGTn}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VZ80_IORQn}]
#set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VMEM_CSn}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VZ80_RDn}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VRESETn}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VVRAM_CS_INn}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VWAITn}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VZ80_WRn}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VMB_HBLNKn}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VMB_LOAD}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VMB_SYNCH}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VMB_V_HBLNKn}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VMB_VIDEO}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {CLK_1MHZ_OUT}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {CLK_2MHZ_OUT}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {CLK_31_5K_OUT}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {OUTCLK}]
#**************************************************************
# Set Clock Groups
#**************************************************************
#**************************************************************
# Set False Path
#**************************************************************
set_false_path -from [get_clocks {VideoInterface:myVirtualToplevel|CLK16Mi}] -to [get_clocks {CLOCK_50}]
#**************************************************************
# Set Multicycle Path
#**************************************************************
#**************************************************************
# Set Maximum Delay
#**************************************************************
#**************************************************************
# Set Minimum Delay
#**************************************************************
#**************************************************************
# Set Input Transition
#**************************************************************

2972
FPGA/VideoController.vhd Normal file

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,227 @@
---------------------------------------------------------------------------------------------------------
--
-- Name: VideoController_Toplevel.vhd
-- Created: June 2020
-- Author(s): Philip Smart
-- Description: MZ80A Video Module FPGA Top Level module.
--
-- This module contains the definition of the video controller used in v2.0 of the Sharp MZ80A
-- Video Module. The controller emulates the video logic of the Sharp MZ80A, MZ-700 and
-- MZ80B including pixel graphics.
--
-- Credits:
-- Copyright: (c) 2018-20 Philip Smart <philip.smart@net2net.org>
--
-- History: June 2020 - Initial creation.
--
---------------------------------------------------------------------------------------------------------
-- This source file 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 source file 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->.
---------------------------------------------------------------------------------------------------------
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.numeric_std.all;
use work.VideoController_pkg.all;
library altera;
use altera.altera_syn_attributes.all;
entity VideoControllerFPGA is
port (
-- Primary and video clocks.
CLOCK_50 : in std_logic; -- 50MHz base clock for video timing and gate clocking.
-- V[name] = Voltage translated signals which mirror the mainboard signals but at a lower voltage.
-- Addres Bus
VADDR : in std_logic_vector(15 downto 0); -- Z80 Address bus, multiplexed with video address.
-- Data Bus
VDATA : inout std_logic_vector(7 downto 0); -- Z80 Data bus from mainboard Colour Card CD connector..
-- Control signals.
VZ80_IORQn : in std_logic; -- IORQn to FPGA.
VZ80_RDn : in std_logic; -- RDn to FPGA.
VZ80_WRn : in std_logic; -- WRn to FPGA.
VWAITn : out std_logic; -- WAIT signal to CPU when accessing video RAM when busy.
-- VGA signals.
VGA_R : out std_logic_vector(3 downto 0); -- 16 level Red output.
VGA_G : out std_logic_vector(3 downto 0); -- 16 level Green output.
VGA_B : out std_logic_vector(3 downto 0); -- 16 level Blue output.
VGA_HS : out std_logic; -- Horizontal sync.
VGA_VS : out std_logic; -- Vertical sync.
-- Composite signals.
CSYNCn : out std_logic; -- Composite sync negative polarity.
CSYNC : out std_logic; -- Comnposite sync.
VSRVIDEO_OUT : out std_logic; -- Video out from 74LS165 on mainboard, pre-GATE.
VHBLNK_OUTn : out std_logic; -- Horizontal blanking.
VHSY_OUT : out std_logic; -- Horizontal Sync.
VSYNCH_OUT : out std_logic; -- Veritcal Sync.
VVBLNK_OUTn : out std_logic; -- Vertical blanking.
-- Reset.
VRESETn : in std_logic -- Reset to FPGA.
-- Reserved.
--TBA : in std_logic_vector(4 downto 0) -- Reserved signal paths to the CPLD.
);
END entity;
architecture rtl of VideoControllerFPGA is
signal SYS_CLK : std_logic;
signal IF_CLK : std_logic;
signal VIDCLK_8MHZ : std_logic;
signal VIDCLK_16MHZ : std_logic;
signal VIDCLK_25_175MHZ : std_logic;
signal VIDCLK_40MHZ : std_logic;
signal VIDCLK_65MHZ : std_logic;
signal VIDCLK_8_86719MHZ : std_logic;
signal VIDCLK_17_7344MHZ : std_logic;
signal VIDCLK_PSEUDO : std_logic;
signal PLL_LOCKED : std_logic;
signal PLL_LOCKED2 : std_logic;
signal PLL_LOCKED3 : std_logic;
signal PLL_LOCKED4 : std_logic;
signal RESETn : std_logic;
signal RESET_COUNTER : unsigned(5 downto 0);
begin
-- Instantiate a PLL to generate the system clock and base video clocks.
--
VCPLL1 : entity work.Video_Clock
port map
(
inclk0 => CLOCK_50,
areset => '0',
c0 => SYS_CLK,
c1 => IF_CLK,
c2 => VIDCLK_8MHZ,
c3 => VIDCLK_16MHZ,
c4 => VIDCLK_40MHZ,
locked => PLL_LOCKED
);
-- Instantiate a 2nd PLL to generate additional video clocks for VGA and Sharp MZ700 modes.
VCPLL2 : entity work.Video_Clock_II
port map
(
inclk0 => CLOCK_50,
areset => not VRESETn,
c0 => VIDCLK_65MHZ,
c1 => VIDCLK_25_175MHZ,
locked => PLL_LOCKED2
);
-- Instantiate a 3rd PLL to generate clock for pseudo monochrome generation on internal monitor.
VCPLL3 : entity work.Video_Clock_III
port map
(
inclk0 => CLOCK_50,
areset => not VRESETn,
c0 => VIDCLK_PSEUDO,
locked => PLL_LOCKED3
);
-- Instantiate a 4th PLL to generate clocks for MZ-700 video modes.
VCPLL4 : entity work.Video_Clock_IV
port map
(
inclk0 => CLOCK_50,
areset => not VRESETn,
c0 => VIDCLK_8_86719MHZ,
c1 => VIDCLK_17_7344MHZ,
locked => PLL_LOCKED4
);
-- Add the Serial Flash Loader megafunction to enable in-situ programming of the EPCS16 configuration memory.
--
SFL : entity work.sfl
port map
(
noe_in => '0'
);
vcToplevel : entity work.VideoController
--generic map
--(
--)
port map
(
-- Primary and video clocks.
SYS_CLK => SYS_CLK, -- 120MHz main FPGA clock.
IF_CLK => IF_CLK, -- 16MHz interface clock.
VIDCLK_8MHZ => VIDCLK_8MHZ, -- 2x 8MHz base clock for video timing and gate clocking.
VIDCLK_16MHZ => VIDCLK_16MHZ, -- 2x 16MHz base clock for video timing and gate clocking.
VIDCLK_65MHZ => VIDCLK_65MHZ, -- 2x 65MHz base clock for video timing and gate clocking.
VIDCLK_25_175MHZ => VIDCLK_25_175MHZ, -- 2x 25.175MHz base clock for video timing and gate clocking.
VIDCLK_40MHZ => VIDCLK_40MHZ, -- 2x 40MHz base clock for video timing and gate clocking.
VIDCLK_8_86719MHZ => VIDCLK_8_86719MHZ, -- 2x original MZ700 video clock.
VIDCLK_17_7344MHZ => VIDCLK_17_7344MHZ, -- 2x original MZ700 colour modulator clock.
VIDCLK_PSEUDO => VIDCLK_PSEUDO, -- Clock to create pixel slicing to generate pseudo monochrome.
-- V[name] = Voltage translated signals which mirror the mainboard signals but at a lower voltage.
-- Addres Bus
VADDR => VADDR, -- Z80 Address bus, multiplexed with video address.
-- Data Bus
VDATA => VDATA, -- Z80 Data bus from mainboard Colour Card CD connector..
-- Control signals.
VZ80_IORQn => VZ80_IORQn, -- IORQn to FPGA.
VZ80_RDn => VZ80_RDn, -- RDn to FPGA.
VZ80_WRn => VZ80_WRn, -- WRn to FPGA.
VWAITn => VWAITn, -- WAIT signal to CPU when accessing video RAM when busy.
-- VGA signals.
VGA_R => VGA_R, -- 16 level Red output.
VGA_G => VGA_G, -- 16 level Green output.
VGA_B => VGA_B, -- 16 level Blue output.
VGA_HS => VGA_HS, -- Horizontal sync.
VGA_VS => VGA_VS, -- Vertical sync.
-- Composite signals.
CSYNCn => CSYNCn, -- Composite sync negative polarity.
CSYNC => CSYNC, -- Comnposite sync.
VSRVIDEO_OUT => VSRVIDEO_OUT, -- Video out from 74LS165 on mainboard, pre-GATE.
VHBLNK_OUTn => VHBLNK_OUTn, -- Horizontal blanking.
VHSY_OUT => VHSY_OUT, -- Horizontal Sync.
VSYNCH_OUT => VSYNCH_OUT, -- Veritcal Sync.
VVBLNK_OUTn => VVBLNK_OUTn, -- Vertical blanking.
-- Reset.
VRESETn => RESETn -- Reset to FPGA.
-- Reserved.
--TBA => TBA -- Reserved signals.
);
-- Process to reset the FPGA based on the external RESET trigger, PLL's being locked
-- and a counter to set minimum width.
--
FPGARESET: process(VRESETn, CLOCK_50, PLL_LOCKED, PLL_LOCKED2, PLL_LOCKED3, PLL_LOCKED4)
begin
if VRESETn = '0' then
RESET_COUNTER <= (others => '1');
RESETn <= '0';
elsif PLL_LOCKED = '1' and PLL_LOCKED2 = '1' and PLL_LOCKED3 = '1' and PLL_LOCKED4 = '1' then
if rising_edge(CLOCK_50) then
if RESET_COUNTER /= 0 then
RESET_COUNTER <= RESET_COUNTER - 1;
else
RESETn <= '1';
end if;
end if;
end if;
end process;
end architecture;

View File

@@ -0,0 +1,209 @@
---------------------------------------------------------------------------------------------------------
--
-- Name: VideoController_pkg.vhd
-- Created: June 2020
-- Author(s): Philip Smart
-- Description: Sharp MZ80A Video Module v2.0 CPLD configuration file.
--
-- This module contains parameters for the CPLD in v2.0 of the Sharp MZ80A Video Module
-- project.
--
-- Credits:
-- Copyright: (c) 2018-20 Philip Smart <philip.smart@net2net.org>
--
-- History: June 2020 - Initial creation.
--
---------------------------------------------------------------------------------------------------------
-- This source file 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 source file 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->.
---------------------------------------------------------------------------------------------------------
library ieee;
library pkgs;
use ieee.std_logic_1164.all;
use ieee.numeric_std.all;
use ieee.math_real.all;
package VideoController_pkg is
------------------------------------------------------------
-- Constants
------------------------------------------------------------
-- Potential logic state constants.
constant YES : std_logic := '1';
constant NO : std_logic := '0';
constant HI : std_logic := '1';
constant LO : std_logic := '0';
constant ONE : std_logic := '1';
constant ZERO : std_logic := '0';
constant HIZ : std_logic := 'Z';
-- Target hardware modes.
constant MODE_MZ80K : integer := 0;
constant MODE_MZ80C : integer := 1;
constant MODE_MZ1200 : integer := 2;
constant MODE_MZ80A : integer := 3;
constant MODE_MZ700 : integer := 4;
constant MODE_MZ800 : integer := 5;
constant MODE_MZ80B : integer := 6;
constant MODE_MZ2000 : integer := 7;
-- Memory management modes.
constant TZMM_ORIG : integer := 00; -- Original Sharp mode, no tranZPUter features are selected except the I/O control registers (default: 0x60-063).
constant TZMM_BOOT : integer := 01; -- Original mode but E800-EFFF is mapped to tranZPUter RAM so TZFS can be booted.
constant TZMM_TZFS : integer := 02; -- TZFS main memory configuration. all memory is in tranZPUter RAM, E800-FFFF is used by TZFS, SA1510 is at 0000-1000 and RAM is 1000-CFFF, 64K Block 0 selected.
constant TZMM_TZFS2 : integer := 03; -- TZFS main memory configuration. all memory is in tranZPUter RAM, E800-EFFF is used by TZFS, SA1510 is at 0000-1000 and RAM is 1000-CFFF, 64K Block 0 selected, F000-FFFF is in 64K Block 1.
constant TZMM_TZFS3 : integer := 04; -- TZFS main memory configuration. all memory is in tranZPUter RAM, E800-EFFF is used by TZFS, SA1510 is at 0000-1000 and RAM is 1000-CFFF, 64K Block 0 selected, F000-FFFF is in 64K Block 2.
constant TZMM_TZFS4 : integer := 05; -- TZFS main memory configuration. all memory is in tranZPUter RAM, E800-EFFF is used by TZFS, SA1510 is at 0000-1000 and RAM is 1000-CFFF, 64K Block 0 selected, F000-FFFF is in 64K Block 3.
constant TZMM_CPM : integer := 06; -- CPM main memory configuration, all memory on the tranZPUter board, 64K block 4 selected. Special case for F3C0:F3FF & F7C0:F7FF (floppy disk paging vectors) which resides on the mainboard.
constant TZMM_CPM2 : integer := 07; -- CPM main memory configuration, F000-FFFF are on the tranZPUter board in block 4, 0040-CFFF and E800-EFFF are in block 5, mainboard for D000-DFFF (video), E000-E800 (Memory control) selected.
-- Special case for 0000:003F (interrupt vectors) which resides in block 4, F3FE:F3FF & F7FE:F7FF (floppy disk paging vectors) which resides on the mainboard.
constant TZMM_COMPAT : integer := 08; -- Compatiblilty monitor mode, monitor ROM on mainboard, RAM on tranZPUter in Block 0 1000-CFFF.
constant TZMM_MZ700_0 : integer := 10; -- MZ700 Mode - 0000:0FFF is on the tranZPUter board in block 6, 1000:CFFF is on the tranZPUter board in block 0, D000:FFFF is on the mainboard.
constant TZMM_MZ700_1 : integer := 11; -- MZ700 Mode - 0000:0FFF is on the tranZPUter board in block 0, 1000:CFFF is on the tranZPUter board in block 0, D000:FFFF is on the tranZPUter in block 6.
constant TZMM_MZ700_2 : integer := 12; -- MZ700 Mode - 0000:0FFF is on the tranZPUter board in block 6, 1000:CFFF is on the tranZPUter board in block 0, D000:FFFF is on the tranZPUter in block 6.
constant TZMM_MZ700_3 : integer := 13; -- MZ700 Mode - 0000:0FFF is on the tranZPUter board in block 0, 1000:CFFF is on the tranZPUter board in block 0, D000:FFFF is inaccessible.
constant TZMM_MZ700_4 : integer := 14; -- MZ700 Mode - 0000:0FFF is on the tranZPUter board in block 6, 1000:CFFF is on the tranZPUter board in block 0, D000:FFFF is inaccessible.
constant TZMM_TZPU0 : integer := 24; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 0 is selected.
constant TZMM_TZPU1 : integer := 25; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 1 is selected.
constant TZMM_TZPU2 : integer := 26; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 2 is selected.
constant TZMM_TZPU3 : integer := 27; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 3 is selected.
constant TZMM_TZPU4 : integer := 28; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 4 is selected.
constant TZMM_TZPU5 : integer := 29; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 5 is selected.
constant TZMM_TZPU6 : integer := 30; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 6 is selected.
constant TZMM_TZPU7 : integer := 31; -- Everything is in tranZPUter domain, no access to underlying Sharp mainboard unless memory management mode is switched. tranZPUter RAM 64K block 7 is selected.
------------------------------------------------------------
-- Configurable parameters.
------------------------------------------------------------
-- Target hardware.
constant CPLD_HOST_HW : integer := MODE_MZ80A;
-- Target video hardware.
constant CPLD_HAS_FPGA_VIDEO : std_logic := '1';
-- Version of hdl.
constant CPLD_VERSION : integer := 1;
-- Clock source for the secondary clock. If a K64F is installed the enable it otherwise use the onboard oscillator.
--
constant USE_K64F_CTL_CLOCK : integer := 1;
------------------------------------------------------------
-- Function prototypes
------------------------------------------------------------
-- Find the maximum of two integers.
function IntMax(a : in integer; b : in integer) return integer;
-- Find the number of bits required to represent an integer.
function log2ceil(arg : positive) return natural;
-- Function to calculate the number of whole 'clock' cycles in a given time period, the period being in ns.
function clockTicks(period : in integer; clock : in integer) return integer;
-- Function to reverse the order of the bits in a standard logic vector.
-- ie. 1010 becomes 0101
function reverse_vector(slv:std_logic_vector) return std_logic_vector;
-- Function to convert an integer (0 or 1) into std_logic.
--
function to_std_logic(i : in integer) return std_logic;
-- Function to return the value of a bit as an integer for array indexing etc.
function bit_to_integer( s : std_logic ) return natural;
------------------------------------------------------------
-- Records
------------------------------------------------------------
------------------------------------------------------------
-- Components
------------------------------------------------------------
end VideoController_pkg;
------------------------------------------------------------
-- Function definitions.
------------------------------------------------------------
package body VideoController_pkg is
-- Find the maximum of two integers.
function IntMax(a : in integer; b : in integer) return integer is
begin
if a > b then
return a;
else
return b;
end if;
return a;
end function IntMax;
-- Find the number of bits required to represent an integer.
function log2ceil(arg : positive) return natural is
variable tmp : positive := 1;
variable log : natural := 0;
begin
if arg = 1 then
return 0;
end if;
while arg > tmp loop
tmp := tmp * 2;
log := log + 1;
end loop;
return log;
end function;
-- Function to calculate the number of whole 'clock' cycles in a given time period, the period being in ns.
function clockTicks(period : in integer; clock : in integer) return integer is
variable ticks : real;
variable fracTicks : real;
begin
ticks := (Real(period) * Real(clock)) / 1000000000.0;
fracTicks := ticks - CEIL(ticks);
if fracTicks > 0.0001 then
return Integer(CEIL(ticks + 1.0));
else
return Integer(CEIL(ticks));
end if;
end function;
function reverse_vector(slv:std_logic_vector) return std_logic_vector is
variable target : std_logic_vector(slv'high downto slv'low);
begin
for idx in slv'high downto slv'low loop
target(idx) := slv(slv'low + (slv'high-idx));
end loop;
return target;
end reverse_vector;
function to_std_logic(i : in integer) return std_logic is
begin
if i = 0 then
return '0';
end if;
return '1';
end function;
-- Function to return the value of a bit as an integer for array indexing etc.
function bit_to_integer( s : std_logic ) return natural is
begin
if s = '1' then
return 1;
else
return 0;
end if;
end function;
end package body;

21
FPGA/build/SFL.cmp Normal file
View File

@@ -0,0 +1,21 @@
--Copyright (C) 1991-2013 Altera Corporation
--Your use of Altera Corporation's design tools, logic functions
--and other software and tools, and its AMPP partner logic
--functions, and any output files from any of the foregoing
--(including device programming or simulation files), and any
--associated documentation or information are expressly subject
--to the terms and conditions of the Altera Program License
--Subscription Agreement, Altera MegaCore Function License
--Agreement, or other applicable license agreement, including,
--without limitation, that your use is for the sole purpose of
--programming logic devices manufactured by Altera and sold by
--Altera or its authorized distributors. Please refer to the
--applicable agreement for further details.
component SFL
PORT
(
noe_in : IN STD_LOGIC
);
end component;

5
FPGA/build/SFL.qip Normal file
View File

@@ -0,0 +1,5 @@
set_global_assignment -name IP_TOOL_NAME "Serial Flash Loader"
set_global_assignment -name IP_TOOL_VERSION "13.1"
set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) "SFL.vhd"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "SFL_inst.vhd"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "SFL.cmp"]

102
FPGA/build/SFL.vhd Normal file
View File

@@ -0,0 +1,102 @@
-- megafunction wizard: %Serial Flash Loader%
-- GENERATION: STANDARD
-- VERSION: WM1.0
-- MODULE: altserial_flash_loader
-- ============================================================
-- File Name: SFL.vhd
-- Megafunction Name(s):
-- altserial_flash_loader
--
-- Simulation Library Files(s):
-- altera_mf
-- ============================================================
-- ************************************************************
-- THIS IS A WIZARD-GENERATED FILE. DO NOT EDIT THIS FILE!
--
-- 13.1.0 Build 162 10/23/2013 SJ Full Version
-- ************************************************************
--Copyright (C) 1991-2013 Altera Corporation
--Your use of Altera Corporation's design tools, logic functions
--and other software and tools, and its AMPP partner logic
--functions, and any output files from any of the foregoing
--(including device programming or simulation files), and any
--associated documentation or information are expressly subject
--to the terms and conditions of the Altera Program License
--Subscription Agreement, Altera MegaCore Function License
--Agreement, or other applicable license agreement, including,
--without limitation, that your use is for the sole purpose of
--programming logic devices manufactured by Altera and sold by
--Altera or its authorized distributors. Please refer to the
--applicable agreement for further details.
LIBRARY ieee;
USE ieee.std_logic_1164.all;
LIBRARY altera_mf;
USE altera_mf.all;
ENTITY SFL IS
PORT
(
noe_in : IN STD_LOGIC
);
END SFL;
ARCHITECTURE SYN OF sfl IS
COMPONENT altserial_flash_loader
GENERIC (
enable_quad_spi_support : NATURAL;
enable_shared_access : STRING;
enhanced_mode : NATURAL;
intended_device_family : STRING;
lpm_type : STRING
);
PORT (
noe : IN STD_LOGIC
);
END COMPONENT;
BEGIN
altserial_flash_loader_component : altserial_flash_loader
GENERIC MAP (
enable_quad_spi_support => 0,
enable_shared_access => "OFF",
enhanced_mode => 1,
intended_device_family => "Cyclone III",
lpm_type => "altserial_flash_loader"
)
PORT MAP (
noe => noe_in
);
END SYN;
-- ============================================================
-- CNX file retrieval info
-- ============================================================
-- Retrieval info: PRIVATE: INTENDED_DEVICE_FAMILY STRING "Cyclone III"
-- Retrieval info: LIBRARY: altera_mf altera_mf.altera_mf_components.all
-- Retrieval info: CONSTANT: ENABLE_QUAD_SPI_SUPPORT NUMERIC "0"
-- Retrieval info: CONSTANT: ENABLE_SHARED_ACCESS STRING "OFF"
-- Retrieval info: CONSTANT: ENHANCED_MODE NUMERIC "1"
-- Retrieval info: CONSTANT: INTENDED_DEVICE_FAMILY STRING "Cyclone III"
-- Retrieval info: USED_PORT: noe_in 0 0 0 0 INPUT NODEFVAL "noe_in"
-- Retrieval info: CONNECT: @noe 0 0 0 0 noe_in 0 0 0 0
-- Retrieval info: GEN_FILE: TYPE_NORMAL SFL.vhd TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL SFL.inc FALSE
-- Retrieval info: GEN_FILE: TYPE_NORMAL SFL.cmp TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL SFL.bsf FALSE
-- Retrieval info: GEN_FILE: TYPE_NORMAL SFL_inst.vhd TRUE
-- Retrieval info: LIB_FILE: altera_mf

3
FPGA/build/SFL_inst.vhd Normal file
View File

@@ -0,0 +1,3 @@
SFL_inst : SFL PORT MAP (
noe_in => noe_in_sig
);

View File

@@ -0,0 +1,30 @@
# -------------------------------------------------------------------------- #
#
# Copyright (C) 1991-2013 Altera Corporation
# Your use of Altera Corporation's design tools, logic functions
# and other software and tools, and its AMPP partner logic
# functions, and any output files from any of the foregoing
# (including device programming or simulation files), and any
# associated documentation or information are expressly subject
# to the terms and conditions of the Altera Program License
# Subscription Agreement, Altera MegaCore Function License
# Agreement, or other applicable license agreement, including,
# without limitation, that your use is for the sole purpose of
# programming logic devices manufactured by Altera and sold by
# Altera or its authorized distributors. Please refer to the
# applicable agreement for further details.
#
# -------------------------------------------------------------------------- #
#
# Quartus II 64-Bit
# Version 13.0.1 Build 232 06/12/2013 Service Pack 1 SJ Web Edition
# Date created = 16:29:32 June 24, 2020
#
# -------------------------------------------------------------------------- #
QUARTUS_VERSION = "13.0"
DATE = "16:29:32 June 24, 2020"
# Revisions
PROJECT_REVISION = "VideoController"

View File

@@ -0,0 +1,288 @@
# -------------------------------------------------------------------------- #
#
# Copyright (C) 1991-2013 Altera Corporation
# Your use of Altera Corporation's design tools, logic functions
# and other software and tools, and its AMPP partner logic
# functions, and any output files from any of the foregoing
# (including device programming or simulation files), and any
# associated documentation or information are expressly subject
# to the terms and conditions of the Altera Program License
# Subscription Agreement, Altera MegaCore Function License
# Agreement, or other applicable license agreement, including,
# without limitation, that your use is for the sole purpose of
# programming logic devices manufactured by Altera and sold by
# Altera or its authorized distributors. Please refer to the
# applicable agreement for further details.
#
# -------------------------------------------------------------------------- #
#
# Quartus II 64-Bit
# Version 13.0.1 Build 232 06/12/2013 Service Pack 1 SJ Web Edition
# Date created = 16:29:32 June 24, 2020
#
# -------------------------------------------------------------------------- #
#
# Notes:
#
# 1) The default values for assignments are stored in the file:
# tranZPUterSW_assignment_defaults.qdf
# If this file doesn't exist, see file:
# assignment_defaults.qdf
#
# 2) Altera recommends that you do not modify this file. This
# file is updated automatically by the Quartus II software
# and any changes you make may be lost or overwritten.
#
# -------------------------------------------------------------------------- #
set_global_assignment -name DEVICE EP3C25E144C8
set_global_assignment -name FAMILY "Cyclone III"
set_global_assignment -name TOP_LEVEL_ENTITY VideoControllerFPGA
set_global_assignment -name ORIGINAL_QUARTUS_VERSION "13.0 SP1"
set_global_assignment -name PROJECT_CREATION_TIME_DATE "16:29:32 JUNE 24, 2020"
set_global_assignment -name LAST_QUARTUS_VERSION 13.1
set_global_assignment -name PROJECT_OUTPUT_DIRECTORY output_files
set_global_assignment -name ERROR_CHECK_FREQUENCY_DIVISOR "-1"
set_global_assignment -name EDA_DESIGN_ENTRY_SYNTHESIS_TOOL "<None>"
set_global_assignment -name EDA_INPUT_VCC_NAME VDD -section_id eda_design_synthesis
set_global_assignment -name EDA_INPUT_DATA_FORMAT EDIF -section_id eda_design_synthesis
set_global_assignment -name EDA_SIMULATION_TOOL "ModelSim-Altera (VHDL)"
set_global_assignment -name EDA_OUTPUT_DATA_FORMAT VHDL -section_id eda_simulation
set_global_assignment -name OPTIMIZE_HOLD_TIMING OFF
set_global_assignment -name OPTIMIZE_MULTI_CORNER_TIMING OFF
set_global_assignment -name FITTER_EFFORT "STANDARD FIT"
set_global_assignment -name MAX7000_DEVICE_IO_STANDARD LVTTL
set_global_assignment -name PARTITION_NETLIST_TYPE SOURCE -section_id Top
set_global_assignment -name PARTITION_FITTER_PRESERVATION_LEVEL PLACEMENT_AND_ROUTING -section_id Top
set_global_assignment -name PARTITION_COLOR 16764057 -section_id Top
set_global_assignment -name MIN_CORE_JUNCTION_TEMP 0
set_global_assignment -name MAX_CORE_JUNCTION_TEMP 85
set_global_assignment -name TIMEQUEST_MULTICORNER_ANALYSIS ON
set_global_assignment -name FLOW_ENABLE_IO_ASSIGNMENT_ANALYSIS ON
set_global_assignment -name ENABLE_CONFIGURATION_PINS OFF
set_global_assignment -name ENABLE_NCE_PIN OFF
set_global_assignment -name ENABLE_BOOT_SEL_PIN OFF
set_global_assignment -name USE_CONFIGURATION_DEVICE OFF
set_global_assignment -name CRC_ERROR_OPEN_DRAIN OFF
set_global_assignment -name STRATIX_DEVICE_IO_STANDARD "3.3-V LVTTL"
set_global_assignment -name CYCLONEII_RESERVE_NCEO_AFTER_CONFIGURATION "USE AS REGULAR IO"
set_global_assignment -name RESERVE_DATA0_AFTER_CONFIGURATION "USE AS REGULAR IO"
set_global_assignment -name RESERVE_DATA1_AFTER_CONFIGURATION "USE AS REGULAR IO"
set_global_assignment -name RESERVE_FLASH_NCE_AFTER_CONFIGURATION "USE AS REGULAR IO"
set_global_assignment -name OUTPUT_IO_TIMING_NEAR_END_VMEAS "HALF VCCIO" -rise
set_global_assignment -name OUTPUT_IO_TIMING_NEAR_END_VMEAS "HALF VCCIO" -fall
set_global_assignment -name OUTPUT_IO_TIMING_FAR_END_VMEAS "HALF SIGNAL SWING" -rise
set_global_assignment -name OUTPUT_IO_TIMING_FAR_END_VMEAS "HALF SIGNAL SWING" -fall
set_global_assignment -name VHDL_INPUT_VERSION VHDL_2008
set_global_assignment -name VHDL_SHOW_LMF_MAPPING_MESSAGES OFF
# Clocks.
# =======
#set_location_assignment PIN_22 -to CLOCK_50
set_location_assignment PIN_129 -to CLOCK_50
# Video Interface Address Bus
# ===========================
set_location_assignment PIN_80 -to VADDR[15]
set_location_assignment PIN_83 -to VADDR[14]
set_location_assignment PIN_120 -to VADDR[13]
set_location_assignment PIN_121 -to VADDR[12]
set_location_assignment PIN_125 -to VADDR[11]
set_location_assignment PIN_132 -to VADDR[10]
set_location_assignment PIN_133 -to VADDR[9]
set_location_assignment PIN_135 -to VADDR[8]
set_location_assignment PIN_136 -to VADDR[7]
set_location_assignment PIN_137 -to VADDR[6]
set_location_assignment PIN_141 -to VADDR[5]
set_location_assignment PIN_142 -to VADDR[4]
set_location_assignment PIN_143 -to VADDR[3]
set_location_assignment PIN_144 -to VADDR[2]
set_location_assignment PIN_7 -to VADDR[1]
set_location_assignment PIN_4 -to VADDR[0]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[15]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[14]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[13]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[12]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[11]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[10]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[9]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[8]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[7]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[6]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[5]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[4]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[3]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[2]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[1]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VADDR[0]
# Video Data Bus
# ==============
set_location_assignment PIN_106 -to VDATA[7]
set_location_assignment PIN_105 -to VDATA[6]
set_location_assignment PIN_104 -to VDATA[5]
set_location_assignment PIN_103 -to VDATA[4]
set_location_assignment PIN_101 -to VDATA[3]
set_location_assignment PIN_100 -to VDATA[2]
set_location_assignment PIN_99 -to VDATA[1]
set_location_assignment PIN_98 -to VDATA[0]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VDATA[7]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VDATA[6]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VDATA[5]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VDATA[4]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VDATA[3]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VDATA[2]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VDATA[1]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VDATA[0]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VDATA[7]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VDATA[6]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VDATA[5]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VDATA[4]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VDATA[3]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VDATA[2]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VDATA[1]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VDATA[0]
# Video control signals.
# ======================
#set_location_assignment PIN_113 -to VCSn
#set_location_assignment PIN_112 -to VGTn
set_location_assignment PIN_115 -to VZ80_IORQn
#set_location_assignment PIN_119 -to VMEM_CSn
set_location_assignment PIN_114 -to VZ80_RDn
set_location_assignment PIN_110 -to VRESETn
#set_location_assignment PIN_28 -to VVRAM_CS_INn
set_location_assignment PIN_111 -to VZ80_WRn
set_location_assignment PIN_85 -to VWAITn
#set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VCSn
#set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGTn
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VZ80_IORQn
#set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VMEM_CSn
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VZ80_RDn
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VRESETn
#set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VVRAM_CS_INn
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VZ80_WRn
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VWAITn
# VGA/RGB signals.
# ================
set_location_assignment PIN_46 -to VGA_R[0]
set_location_assignment PIN_49 -to VGA_R[1]
set_location_assignment PIN_50 -to VGA_R[2]
set_location_assignment PIN_51 -to VGA_R[3]
set_location_assignment PIN_39 -to VGA_G[0]
set_location_assignment PIN_42 -to VGA_G[1]
set_location_assignment PIN_43 -to VGA_G[2]
set_location_assignment PIN_44 -to VGA_G[3]
set_location_assignment PIN_30 -to VGA_B[0]
set_location_assignment PIN_31 -to VGA_B[1]
set_location_assignment PIN_32 -to VGA_B[2]
set_location_assignment PIN_33 -to VGA_B[3]
set_location_assignment PIN_59 -to VGA_HS
set_location_assignment PIN_58 -to VGA_VS
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_R[0]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_R[1]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_R[2]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_R[3]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_G[0]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_G[1]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_G[2]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_G[3]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_B[0]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_B[1]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_B[2]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_B[3]
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_HS
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VGA_VS
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_R[0]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_R[1]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_R[2]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_R[3]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_G[0]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_G[1]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_G[2]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_G[3]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_B[0]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_B[1]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_B[2]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_B[3]
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_HS
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VGA_VS
# Composite video signals.
# ========================
set_location_assignment PIN_64 -to CSYNCn
set_location_assignment PIN_60 -to CSYNC
set_location_assignment PIN_65 -to VSRVIDEO_OUT
set_location_assignment PIN_66 -to VHBLNK_OUTn
set_location_assignment PIN_67 -to VHSY_OUT
set_location_assignment PIN_68 -to VSYNCH_OUT
set_location_assignment PIN_69 -to VVBLNK_OUTn
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to CSYNCn
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to CSYNC
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VSRVIDEO_OUT
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VHBLNK_OUTn
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VHSY_OUT
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VSYNCH_OUT
set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VVBLNK_OUTn
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to CSYNCn
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to CSYNC
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VSRVIDEO_OUT
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VHBLNK_OUTn
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VHSY_OUT
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VSYNCH_OUT
set_instance_assignment -name CURRENT_STRENGTH_NEW "MAXIMUM CURRENT" -to VVBLNK_OUTn
# Mainboard video signals on the CN1 connector passed to the FPGA.
# ================================================================
#set_location_assignment PIN_71 -to VMB_HBLNKn
#set_location_assignment PIN_72 -to VMB_LOAD
#set_location_assignment PIN_76 -to VMB_SYNCH
#set_location_assignment PIN_77 -to VMB_V_HBLNKn
#set_location_assignment PIN_79 -to VMB_VIDEO
#set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VMB_HBLNKn
#set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VMB_LOAD
#set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VMB_SYNCH
#set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VMB_V_HBLNKn
#set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to VMB_VIDEO
# Reserved.
# =========
#set_location_assignment PIN_86 -to TBA[1]
#set_location_assignment PIN_87 -to TBA[0]
#set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to TBA[1]
#set_instance_assignment -name IO_STANDARD "3.3-V LVTTL" -to TBA[0]
# Files in project.
# =================
set_global_assignment -name VHDL_FILE ../VideoController_Toplevel.vhd
#set_global_assignment -name QIP_FILE Clock_50to100.qip
set_global_assignment -name QIP_FILE SFL.qip
set_global_assignment -name QIP_FILE Video_Clock.qip
set_global_assignment -name QIP_FILE Video_Clock_II.qip
set_global_assignment -name QIP_FILE Video_Clock_III.qip
set_global_assignment -name QIP_FILE Video_Clock_IV.qip
set_global_assignment -name QIP_FILE vbuffer.qip
set_global_assignment -name VHDL_FILE ../VideoController_pkg.vhd
set_global_assignment -name VHDL_FILE ../VideoController.vhd
set_global_assignment -name VHDL_FILE ../devices/RAM/dpram.vhd
set_global_assignment -name SDC_FILE VideoController_constraints.sdc
set_instance_assignment -name PARTITION_HIERARCHY root_partition -to | -section_id Top

View File

@@ -0,0 +1,267 @@
## Generated SDC file "VideoController.out.sdc"
## Copyright (C) 1991-2013 Altera Corporation
## Your use of Altera Corporation's design tools, logic functions
## and other software and tools, and its AMPP partner logic
## functions, and any output files from any of the foregoing
## (including device programming or simulation files), and any
## associated documentation or information are expressly subject
## to the terms and conditions of the Altera Program License
## Subscription Agreement, Altera MegaCore Function License
## Agreement, or other applicable license agreement, including,
## without limitation, that your use is for the sole purpose of
## programming logic devices manufactured by Altera and sold by
## Altera or its authorized distributors. Please refer to the
## applicable agreement for further details.
## VENDOR "Altera"
## PROGRAM "Quartus II"
## VERSION "Version 13.1.0 Build 162 10/23/2013 SJ Full Version"
## DATE "Fri Jul 3 00:11:58 2020"
##
## DEVICE "EP3C25E144C8"
##
#**************************************************************
# Time Information
#**************************************************************
set_time_format -unit ns -decimal_places 3
#**************************************************************
# Create Clock
#**************************************************************
create_clock -name {altera_reserved_tck} -period 100.000 -waveform { 0.000 50.000 } [get_ports {altera_reserved_tck}]
create_clock -name {CLOCK_50} -period 20.000 -waveform { 0.000 10.000 } [get_ports {CLOCK_50}]
#**************************************************************
# Create Generated Clock
#**************************************************************
#derive_pll_clocks
create_generated_clock -name {SYS_CLK} -source [get_pins {VCPLL1|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 12 -divide_by 5 -master_clock {CLOCK_50} [get_pins {VCPLL1|altpll_component|auto_generated|pll1|clk[0]}]
create_generated_clock -name {IF_CLK} -source [get_pins {VCPLL1|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 8 -divide_by 25 -phase 180.000 -master_clock {CLOCK_50} [get_pins {VCPLL1|altpll_component|auto_generated|pll1|clk[1]}]
create_generated_clock -name {VIDCLK_8MHZ} -source [get_pins {VCPLL1|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 8 -divide_by 25 -master_clock {CLOCK_50} [get_pins {VCPLL1|altpll_component|auto_generated|pll1|clk[2]}]
create_generated_clock -name {VIDCLK_16MHZ} -source [get_pins {VCPLL1|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 16 -divide_by 25 -master_clock {CLOCK_50} [get_pins {VCPLL1|altpll_component|auto_generated|pll1|clk[3]}]
create_generated_clock -name {VIDCLK_40MHZ} -source [get_pins {VCPLL1|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 8 -divide_by 5 -master_clock {CLOCK_50} [get_pins {VCPLL1|altpll_component|auto_generated|pll1|clk[4]}]
create_generated_clock -name {VIDCLK_65MHZ} -source [get_pins {VCPLL2|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 13 -divide_by 5 -master_clock {CLOCK_50} [get_pins {VCPLL2|altpll_component|auto_generated|pll1|clk[0]}]
create_generated_clock -name {VIDCLK_25_175MHZ} -source [get_pins {VCPLL2|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 91 -divide_by 90 -master_clock {CLOCK_50} [get_pins {VCPLL2|altpll_component|auto_generated|pll1|clk[1]}]
create_generated_clock -name {VIDCLK_PSEUDO} -source [get_pins {VCPLL3|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 64 -divide_by 25 -master_clock {CLOCK_50} [get_pins {VCPLL3|altpll_component|auto_generated|pll1|clk[0]}]
create_generated_clock -name {VIDCLK_8_86719MHZ} -source [get_pins {VCPLL4|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 115 -divide_by 324 -master_clock {CLOCK_50} [get_pins {VCPLL4|altpll_component|auto_generated|pll1|clk[0]}]
create_generated_clock -name {VIDCLK_17_7344MHZ} -source [get_pins {VCPLL4|altpll_component|auto_generated|pll1|inclk[0]}] -duty_cycle 50.000 -multiply_by 115 -divide_by 162 -master_clock {CLOCK_50} [get_pins {VCPLL4|altpll_component|auto_generated|pll1|clk[1]}]
#**************************************************************
# Set Clock Latency
#**************************************************************
#**************************************************************
# Set Clock Uncertainty
#**************************************************************
derive_clock_uncertainty
#**************************************************************
# Set Input Delay
#**************************************************************
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {CLOCK_50}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VRESETn}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VZ80_WRn}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VZ80_RDn}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VZ80_IORQn}]
#set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {VMEM_CSn}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[15]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[14]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[13]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[12]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[11]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[10]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[9]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[8]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[7]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[6]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[5]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[4]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[3]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[2]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[1]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VADDR[0]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[0]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[1]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[2]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[3]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[4]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[5]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[6]}]
set_input_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VDATA[7]}]
#set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {TBA[3]}]
#set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {TBA[2]}]
#set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {TBA[1]}]
#set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {TBA[0]}]
# Required for the Serial Flash Loader.
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {altera_reserved_tck}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {altera_reserved_tdi}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {altera_reserved_tms}]
set_input_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {SFL:sfl|altserial_flash_loader_component|\GEN_ASMI_TYPE_1:asmi_inst~ALTERA_DATA0}]
#**************************************************************
# Set Output Delay
#**************************************************************
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[0]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[1]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[2]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[3]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[4]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[5]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[6]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VDATA[7]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 8.000 [get_ports {VWAITn}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_B[0]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_B[1]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_B[2]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_B[3]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_G[0]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_G[1]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_G[2]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_G[3]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_R[0]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_R[1]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_R[2]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_R[3]}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_VS}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VGA_HS}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {CSYNC}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {CSYNCn}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VSRVIDEO_OUT}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VHBLNK_OUTn}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VHSY_OUT}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VSYNCH_OUT}]
set_output_delay -add_delay -clock [get_clocks {SYS_CLK}] 1.000 [get_ports {VVBLNK_OUTn}]
# Required for the Serial Flash Loader.
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {SFL:sfl|altserial_flash_loader_component|\GEN_ASMI_TYPE_1:asmi_inst~ALTERA_DCLK}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {SFL:sfl|altserial_flash_loader_component|\GEN_ASMI_TYPE_1:asmi_inst~ALTERA_SCE}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {SFL:sfl|altserial_flash_loader_component|\GEN_ASMI_TYPE_1:asmi_inst~ALTERA_SDO}]
set_output_delay -add_delay -clock [get_clocks {CLOCK_50}] 1.000 [get_ports {altera_reserved_tdo}]
#**************************************************************
# Set Clock Groups
#**************************************************************
#**************************************************************
# Set False Path
#**************************************************************
# There is no relationship between the different video frequencies, only one is used at a time and they are switched through synchronised D-Type flip flops.
set_false_path -from [get_clocks {VIDCLK_8MHZ}] -to [get_clocks {CLOCK_50 VIDCLK_PSEUDO VIDCLK_16MHZ VIDCLK_40MHZ VIDCLK_65MHZ VIDCLK_25_175MHZ VIDCLK_8_86719MHZ VIDCLK_17_7344MHZ IF_CLK}]
set_false_path -from [get_clocks {VIDCLK_8_86719MHZ}] -to [get_clocks {CLOCK_50 VIDCLK_PSEUDO VIDCLK_8MHZ VIDCLK_16MHZ VIDCLK_40MHZ VIDCLK_65MHZ VIDCLK_25_175MHZ VIDCLK_17_7344MHZ IF_CLK}]
set_false_path -from [get_clocks {VIDCLK_16MHZ}] -to [get_clocks {CLOCK_50 VIDCLK_PSEUDO VIDCLK_8MHZ VIDCLK_40MHZ VIDCLK_65MHZ VIDCLK_25_175MHZ VIDCLK_8_86719MHZ VIDCLK_17_7344MHZ IF_CLK}]
set_false_path -from [get_clocks {VIDCLK_17_7344MHZ}] -to [get_clocks {CLOCK_50 VIDCLK_PSEUDO VIDCLK_8MHZ VIDCLK_16MHZ VIDCLK_40MHZ VIDCLK_65MHZ VIDCLK_25_175MHZ VIDCLK_8_86719MHZ IF_CLK}]
set_false_path -from [get_clocks {VIDCLK_25_175MHZ}] -to [get_clocks {CLOCK_50 VIDCLK_PSEUDO VIDCLK_8MHZ VIDCLK_16MHZ VIDCLK_40MHZ VIDCLK_65MHZ VIDCLK_8_86719MHZ VIDCLK_17_7344MHZ IF_CLK}]
set_false_path -from [get_clocks {VIDCLK_40MHZ}] -to [get_clocks {CLOCK_50 VIDCLK_PSEUDO VIDCLK_8MHZ VIDCLK_16MHZ VIDCLK_65MHZ VIDCLK_25_175MHZ VIDCLK_8_86719MHZ VIDCLK_17_7344MHZ IF_CLK}]
set_false_path -from [get_clocks {VIDCLK_65MHZ}] -to [get_clocks {CLOCK_50 VIDCLK_PSEUDO VIDCLK_8MHZ VIDCLK_16MHZ VIDCLK_40MHZ VIDCLK_65MHZ VIDCLK_25_175MHZ VIDCLK_8_86719MHZ VIDCLK_17_7344MHZ IF_CLK}]
set_false_path -from [get_clocks {VIDCLK_PSEUDO}] -to [get_clocks {CLOCK_50 VIDCLK_PSEUDO VIDCLK_8MHZ VIDCLK_16MHZ VIDCLK_40MHZ VIDCLK_65MHZ VIDCLK_25_175MHZ VIDCLK_8_86719MHZ VIDCLK_17_7344MHZ IF_CLK}]
# Z80 clock has no relationship to the video frequencies, it is used only for latching data asynchronous to the FPGA clocks.
set_false_path -from [get_clocks {IF_CLK}] -to [get_clocks {VIDCLK_8MHZ VIDCLK_16MHZ VIDCLK_40MHZ VIDCLK_25_175MHZ VIDCLK_65MHZ VIDCLK_8_86719MHZ VIDCLK_17_7344MHZ VIDCLK_PSEUDO}]
# The system clock has no real relationship with the video frequencies, rendering and display. The only place they meet is in the dual port BRAM.
set_false_path -from [get_clocks {SYS_CLK}] -to [get_clocks {CLOCK_50 VIDCLK_8MHZ VIDCLK_16MHZ VIDCLK_40MHZ VIDCLK_25_175MHZ VIDCLK_65MHZ VIDCLK_8_86719MHZ VIDCLK_17_7344MHZ VIDCLK_PSEUDO}]
# Clock 50MHZ, the input oscillator is only used for the PLL input and as I/O input/output latch which is detached from the video block
set_false_path -from [get_clocks {CLOCK_50}] -to [get_clocks {VIDCLK_8MHZ VIDCLK_16MHZ VIDCLK_40MHZ VIDCLK_25_175MHZ VIDCLK_65MHZ VIDCLK_8_86719MHZ VIDCLK_17_7344MHZ VIDCLK_PSEUDO}]
# The Z80 data, address and control lines do not go to the video block (except the parameter update which is not critical) so set it as a false path so as not to consider.
set_false_path -from [get_ports {VDATA[*]}] -to [get_clocks {VIDCLK_8MHZ VIDCLK_16MHZ VIDCLK_40MHZ VIDCLK_25_175MHZ VIDCLK_65MHZ VIDCLK_8_86719MHZ VIDCLK_17_7344MHZ}]
set_false_path -from [get_ports {VADDR[*]}] -to [get_registers {VideoController:vcToplevel|XFER_MAPPED_DATA[*]}]
set_false_path -from [get_ports {VZ80_WRn VZ80_RDn VZ80_IORQn}] -to [get_registers {VideoController:vcToplevel|XFER_MAPPED_DATA[*]}]
#**************************************************************
# Set Multicycle Path
#**************************************************************
set_multicycle_path -from [get_registers {VideoController:vcToplevel|DSP_PARAM_SEL[*]}] -to [get_ports {VDATA[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|DSP_PARAM_SEL[*]}] -to [get_ports {VDATA[*]}] -setup -start 2
set_multicycle_path -from [get_clocks {SYS_CLK}] -to [get_clocks {IF_CLK}] -hold -start 1
set_multicycle_path -from [get_clocks {SYS_CLK}] -to [get_clocks {IF_CLK}] -setup -start 2
set_multicycle_path -from [get_clocks {IF_CLK}] -to [get_clocks {SYS_CLK}] -hold -start 2
set_multicycle_path -from [get_clocks {IF_CLK}] -to [get_clocks {SYS_CLK}] -setup -start 3
# GPU control and run variables have at least 1 clock between them being setup and used.
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_X[*]}] -to [get_registers {VideoController:vcToplevel|GPU_START_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_X[*]}] -to [get_registers {VideoController:vcToplevel|GPU_START_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_X[*]}] -to [get_registers {VideoController:vcToplevel|GRAM_GPU_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_X[*]}] -to [get_registers {VideoController:vcToplevel|GRAM_GPU_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_Y[*]}] -to [get_registers {VideoController:vcToplevel|GPU_START_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_Y[*]}] -to [get_registers {VideoController:vcToplevel|GPU_START_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_Y[*]}] -to [get_registers {VideoController:vcToplevel|GRAM_GPU_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_Y[*]}] -to [get_registers {VideoController:vcToplevel|GRAM_GPU_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_X[*]}] -to [get_registers {VideoController:vcToplevel|\GPU:GPU_VAR_Y[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_X[*]}] -to [get_registers {VideoController:vcToplevel|\GPU:GPU_VAR_Y[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_X[*]}] -to [get_registers {VideoController:vcToplevel|GPU_STATE.*}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_X[*]}] -to [get_registers {VideoController:vcToplevel|GPU_STATE.*}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_X[*]}] -to [get_registers {VideoController:vcToplevel|VRAM_GPU_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_X[*]}] -to [get_registers {VideoController:vcToplevel|VRAM_GPU_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_Y[*]}] -to [get_registers {VideoController:vcToplevel|VRAM_GPU_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|GPU_START_ADDR[*]}] -to [get_registers {VideoController:vcToplevel|VRAM_GPU_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_COLUMNS[*]}] -to [get_registers {VideoController:vcToplevel|GPU_START_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_COLUMNS[*]}] -to [get_registers {VideoController:vcToplevel|VRAM_GPU_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|XFER_DST_ADDR[*]}] -to [get_registers {VideoController:vcToplevel|XFER_MAPPED_DATA[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|XFER_DST_ADDR[*]}] -to [get_registers {VideoController:vcToplevel|XFER_DST_ADDR[*]}] -setup -start 2
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_X[*]}] -to [get_registers {VideoController:vcToplevel|GPU_START_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_X[*]}] -to [get_registers {VideoController:vcToplevel|GPU_START_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_X[*]}] -to [get_registers {VideoController:vcToplevel|GRAM_GPU_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_X[*]}] -to [get_registers {VideoController:vcToplevel|GRAM_GPU_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_Y[*]}] -to [get_registers {VideoController:vcToplevel|GPU_START_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_Y[*]}] -to [get_registers {VideoController:vcToplevel|GPU_START_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_Y[*]}] -to [get_registers {VideoController:vcToplevel|GRAM_GPU_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_Y[*]}] -to [get_registers {VideoController:vcToplevel|GRAM_GPU_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_X[*]}] -to [get_registers {VideoController:vcToplevel|\GPU:GPU_VAR_Y[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_X[*]}] -to [get_registers {VideoController:vcToplevel|\GPU:GPU_VAR_Y[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_X[*]}] -to [get_registers {VideoController:vcToplevel|GPU_STATE.*}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_X[*]}] -to [get_registers {VideoController:vcToplevel|GPU_STATE.*}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_X[*]}] -to [get_registers {VideoController:vcToplevel|VRAM_GPU_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_END_X[*]}] -to [get_registers {VideoController:vcToplevel|VRAM_GPU_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_START_Y[*]}] -to [get_registers {VideoController:vcToplevel|VRAM_GPU_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|GPU_START_ADDR[*]}] -to [get_registers {VideoController:vcToplevel|VRAM_GPU_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_COLUMNS[*]}] -to [get_registers {VideoController:vcToplevel|GPU_START_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|\GPU:GPU_COLUMNS[*]}] -to [get_registers {VideoController:vcToplevel|VRAM_GPU_ADDR[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|XFER_DST_ADDR[*]}] -to [get_registers {VideoController:vcToplevel|XFER_MAPPED_DATA[*]}] -hold -start 1
set_multicycle_path -from [get_registers {VideoController:vcToplevel|XFER_DST_ADDR[*]}] -to [get_registers {VideoController:vcToplevel|XFER_DST_ADDR[*]}] -hold -start 1
#**************************************************************
# Set Maximum Delay
#**************************************************************
#**************************************************************
# Set Minimum Delay
#**************************************************************
#**************************************************************
# Set Input Transition
#**************************************************************

View File

@@ -0,0 +1,28 @@
--Copyright (C) 1991-2013 Altera Corporation
--Your use of Altera Corporation's design tools, logic functions
--and other software and tools, and its AMPP partner logic
--functions, and any output files from any of the foregoing
--(including device programming or simulation files), and any
--associated documentation or information are expressly subject
--to the terms and conditions of the Altera Program License
--Subscription Agreement, Altera MegaCore Function License
--Agreement, or other applicable license agreement, including,
--without limitation, that your use is for the sole purpose of
--programming logic devices manufactured by Altera and sold by
--Altera or its authorized distributors. Please refer to the
--applicable agreement for further details.
component Video_Clock
PORT
(
areset : IN STD_LOGIC := '0';
inclk0 : IN STD_LOGIC := '0';
c0 : OUT STD_LOGIC ;
c1 : OUT STD_LOGIC ;
c2 : OUT STD_LOGIC ;
c3 : OUT STD_LOGIC ;
c4 : OUT STD_LOGIC ;
locked : OUT STD_LOGIC
);
end component;

View File

@@ -0,0 +1,15 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE pinplan>
<pinplan intended_family="Cyclone III" variation_name="Video_Clock" megafunction_name="ALTPLL" specifies="all_ports">
<global>
<pin name="areset" direction="input" scope="external" />
<pin name="inclk0" direction="input" scope="external" source="clock" />
<pin name="c0" direction="output" scope="external" source="clock" />
<pin name="c1" direction="output" scope="external" source="clock" />
<pin name="c2" direction="output" scope="external" source="clock" />
<pin name="c3" direction="output" scope="external" source="clock" />
<pin name="c4" direction="output" scope="external" source="clock" />
<pin name="locked" direction="output" scope="external" />
</global>
</pinplan>

View File

@@ -0,0 +1,6 @@
set_global_assignment -name IP_TOOL_NAME "ALTPLL"
set_global_assignment -name IP_TOOL_VERSION "13.1"
set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) "Video_Clock.vhd"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "Video_Clock_inst.vhd"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "Video_Clock.cmp"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "Video_Clock.ppf"]

490
FPGA/build/Video_Clock.vhd Normal file
View File

@@ -0,0 +1,490 @@
-- megafunction wizard: %ALTPLL%
-- GENERATION: STANDARD
-- VERSION: WM1.0
-- MODULE: altpll
-- ============================================================
-- File Name: Video_Clock.vhd
-- Megafunction Name(s):
-- altpll
--
-- Simulation Library Files(s):
-- altera_mf
-- ============================================================
-- ************************************************************
-- THIS IS A WIZARD-GENERATED FILE. DO NOT EDIT THIS FILE!
--
-- 13.1.0 Build 162 10/23/2013 SJ Full Version
-- ************************************************************
--Copyright (C) 1991-2013 Altera Corporation
--Your use of Altera Corporation's design tools, logic functions
--and other software and tools, and its AMPP partner logic
--functions, and any output files from any of the foregoing
--(including device programming or simulation files), and any
--associated documentation or information are expressly subject
--to the terms and conditions of the Altera Program License
--Subscription Agreement, Altera MegaCore Function License
--Agreement, or other applicable license agreement, including,
--without limitation, that your use is for the sole purpose of
--programming logic devices manufactured by Altera and sold by
--Altera or its authorized distributors. Please refer to the
--applicable agreement for further details.
LIBRARY ieee;
USE ieee.std_logic_1164.all;
LIBRARY altera_mf;
USE altera_mf.all;
ENTITY Video_Clock IS
PORT
(
areset : IN STD_LOGIC := '0';
inclk0 : IN STD_LOGIC := '0';
c0 : OUT STD_LOGIC ;
c1 : OUT STD_LOGIC ;
c2 : OUT STD_LOGIC ;
c3 : OUT STD_LOGIC ;
c4 : OUT STD_LOGIC ;
locked : OUT STD_LOGIC
);
END Video_Clock;
ARCHITECTURE SYN OF video_clock IS
SIGNAL sub_wire0 : STD_LOGIC_VECTOR (4 DOWNTO 0);
SIGNAL sub_wire1 : STD_LOGIC ;
SIGNAL sub_wire2 : STD_LOGIC ;
SIGNAL sub_wire3 : STD_LOGIC ;
SIGNAL sub_wire4 : STD_LOGIC ;
SIGNAL sub_wire5 : STD_LOGIC ;
SIGNAL sub_wire6 : STD_LOGIC ;
SIGNAL sub_wire7 : STD_LOGIC ;
SIGNAL sub_wire8 : STD_LOGIC_VECTOR (1 DOWNTO 0);
SIGNAL sub_wire9_bv : BIT_VECTOR (0 DOWNTO 0);
SIGNAL sub_wire9 : STD_LOGIC_VECTOR (0 DOWNTO 0);
COMPONENT altpll
GENERIC (
bandwidth_type : STRING;
clk0_divide_by : NATURAL;
clk0_duty_cycle : NATURAL;
clk0_multiply_by : NATURAL;
clk0_phase_shift : STRING;
clk1_divide_by : NATURAL;
clk1_duty_cycle : NATURAL;
clk1_multiply_by : NATURAL;
clk1_phase_shift : STRING;
clk2_divide_by : NATURAL;
clk2_duty_cycle : NATURAL;
clk2_multiply_by : NATURAL;
clk2_phase_shift : STRING;
clk3_divide_by : NATURAL;
clk3_duty_cycle : NATURAL;
clk3_multiply_by : NATURAL;
clk3_phase_shift : STRING;
clk4_divide_by : NATURAL;
clk4_duty_cycle : NATURAL;
clk4_multiply_by : NATURAL;
clk4_phase_shift : STRING;
inclk0_input_frequency : NATURAL;
intended_device_family : STRING;
lpm_hint : STRING;
lpm_type : STRING;
operation_mode : STRING;
pll_type : STRING;
port_activeclock : STRING;
port_areset : STRING;
port_clkbad0 : STRING;
port_clkbad1 : STRING;
port_clkloss : STRING;
port_clkswitch : STRING;
port_configupdate : STRING;
port_fbin : STRING;
port_inclk0 : STRING;
port_inclk1 : STRING;
port_locked : STRING;
port_pfdena : STRING;
port_phasecounterselect : STRING;
port_phasedone : STRING;
port_phasestep : STRING;
port_phaseupdown : STRING;
port_pllena : STRING;
port_scanaclr : STRING;
port_scanclk : STRING;
port_scanclkena : STRING;
port_scandata : STRING;
port_scandataout : STRING;
port_scandone : STRING;
port_scanread : STRING;
port_scanwrite : STRING;
port_clk0 : STRING;
port_clk1 : STRING;
port_clk2 : STRING;
port_clk3 : STRING;
port_clk4 : STRING;
port_clk5 : STRING;
port_clkena0 : STRING;
port_clkena1 : STRING;
port_clkena2 : STRING;
port_clkena3 : STRING;
port_clkena4 : STRING;
port_clkena5 : STRING;
port_extclk0 : STRING;
port_extclk1 : STRING;
port_extclk2 : STRING;
port_extclk3 : STRING;
self_reset_on_loss_lock : STRING;
width_clock : NATURAL
);
PORT (
areset : IN STD_LOGIC ;
clk : OUT STD_LOGIC_VECTOR (4 DOWNTO 0);
inclk : IN STD_LOGIC_VECTOR (1 DOWNTO 0);
locked : OUT STD_LOGIC
);
END COMPONENT;
BEGIN
sub_wire9_bv(0 DOWNTO 0) <= "0";
sub_wire9 <= To_stdlogicvector(sub_wire9_bv);
sub_wire5 <= sub_wire0(3);
sub_wire4 <= sub_wire0(4);
sub_wire3 <= sub_wire0(2);
sub_wire2 <= sub_wire0(0);
sub_wire1 <= sub_wire0(1);
c1 <= sub_wire1;
c0 <= sub_wire2;
c2 <= sub_wire3;
c4 <= sub_wire4;
c3 <= sub_wire5;
locked <= sub_wire6;
sub_wire7 <= inclk0;
sub_wire8 <= sub_wire9(0 DOWNTO 0) & sub_wire7;
altpll_component : altpll
GENERIC MAP (
bandwidth_type => "LOW",
clk0_divide_by => 5,
clk0_duty_cycle => 50,
clk0_multiply_by => 12,
clk0_phase_shift => "0",
clk1_divide_by => 25,
clk1_duty_cycle => 50,
clk1_multiply_by => 8,
clk1_phase_shift => "31250",
clk2_divide_by => 25,
clk2_duty_cycle => 50,
clk2_multiply_by => 8,
clk2_phase_shift => "0",
clk3_divide_by => 25,
clk3_duty_cycle => 50,
clk3_multiply_by => 16,
clk3_phase_shift => "0",
clk4_divide_by => 5,
clk4_duty_cycle => 50,
clk4_multiply_by => 8,
clk4_phase_shift => "0",
inclk0_input_frequency => 20000,
intended_device_family => "Cyclone III",
lpm_hint => "CBX_MODULE_PREFIX=Video_Clock",
lpm_type => "altpll",
operation_mode => "NO_COMPENSATION",
pll_type => "AUTO",
port_activeclock => "PORT_UNUSED",
port_areset => "PORT_USED",
port_clkbad0 => "PORT_UNUSED",
port_clkbad1 => "PORT_UNUSED",
port_clkloss => "PORT_UNUSED",
port_clkswitch => "PORT_UNUSED",
port_configupdate => "PORT_UNUSED",
port_fbin => "PORT_UNUSED",
port_inclk0 => "PORT_USED",
port_inclk1 => "PORT_UNUSED",
port_locked => "PORT_USED",
port_pfdena => "PORT_UNUSED",
port_phasecounterselect => "PORT_UNUSED",
port_phasedone => "PORT_UNUSED",
port_phasestep => "PORT_UNUSED",
port_phaseupdown => "PORT_UNUSED",
port_pllena => "PORT_UNUSED",
port_scanaclr => "PORT_UNUSED",
port_scanclk => "PORT_UNUSED",
port_scanclkena => "PORT_UNUSED",
port_scandata => "PORT_UNUSED",
port_scandataout => "PORT_UNUSED",
port_scandone => "PORT_UNUSED",
port_scanread => "PORT_UNUSED",
port_scanwrite => "PORT_UNUSED",
port_clk0 => "PORT_USED",
port_clk1 => "PORT_USED",
port_clk2 => "PORT_USED",
port_clk3 => "PORT_USED",
port_clk4 => "PORT_USED",
port_clk5 => "PORT_UNUSED",
port_clkena0 => "PORT_UNUSED",
port_clkena1 => "PORT_UNUSED",
port_clkena2 => "PORT_UNUSED",
port_clkena3 => "PORT_UNUSED",
port_clkena4 => "PORT_UNUSED",
port_clkena5 => "PORT_UNUSED",
port_extclk0 => "PORT_UNUSED",
port_extclk1 => "PORT_UNUSED",
port_extclk2 => "PORT_UNUSED",
port_extclk3 => "PORT_UNUSED",
self_reset_on_loss_lock => "ON",
width_clock => 5
)
PORT MAP (
areset => areset,
inclk => sub_wire8,
clk => sub_wire0,
locked => sub_wire6
);
END SYN;
-- ============================================================
-- CNX file retrieval info
-- ============================================================
-- Retrieval info: PRIVATE: ACTIVECLK_CHECK STRING "0"
-- Retrieval info: PRIVATE: BANDWIDTH STRING "1.000"
-- Retrieval info: PRIVATE: BANDWIDTH_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: BANDWIDTH_FREQ_UNIT STRING "MHz"
-- Retrieval info: PRIVATE: BANDWIDTH_PRESET STRING "Low"
-- Retrieval info: PRIVATE: BANDWIDTH_USE_AUTO STRING "0"
-- Retrieval info: PRIVATE: BANDWIDTH_USE_PRESET STRING "1"
-- Retrieval info: PRIVATE: CLKBAD_SWITCHOVER_CHECK STRING "0"
-- Retrieval info: PRIVATE: CLKLOSS_CHECK STRING "0"
-- Retrieval info: PRIVATE: CLKSWITCH_CHECK STRING "0"
-- Retrieval info: PRIVATE: CNX_NO_COMPENSATE_RADIO STRING "1"
-- Retrieval info: PRIVATE: CREATE_CLKBAD_CHECK STRING "0"
-- Retrieval info: PRIVATE: CREATE_INCLK1_CHECK STRING "0"
-- Retrieval info: PRIVATE: CUR_DEDICATED_CLK STRING "c0"
-- Retrieval info: PRIVATE: CUR_FBIN_CLK STRING "c0"
-- Retrieval info: PRIVATE: DEVICE_SPEED_GRADE STRING "8"
-- Retrieval info: PRIVATE: DIV_FACTOR0 NUMERIC "1"
-- Retrieval info: PRIVATE: DIV_FACTOR1 NUMERIC "1"
-- Retrieval info: PRIVATE: DIV_FACTOR2 NUMERIC "1"
-- Retrieval info: PRIVATE: DIV_FACTOR3 NUMERIC "1"
-- Retrieval info: PRIVATE: DIV_FACTOR4 NUMERIC "1"
-- Retrieval info: PRIVATE: DUTY_CYCLE0 STRING "50.00000000"
-- Retrieval info: PRIVATE: DUTY_CYCLE1 STRING "50.00000000"
-- Retrieval info: PRIVATE: DUTY_CYCLE2 STRING "50.00000000"
-- Retrieval info: PRIVATE: DUTY_CYCLE3 STRING "50.00000000"
-- Retrieval info: PRIVATE: DUTY_CYCLE4 STRING "50.00000000"
-- Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE0 STRING "120.000000"
-- Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE1 STRING "16.000000"
-- Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE2 STRING "16.000000"
-- Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE3 STRING "32.000000"
-- Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE4 STRING "80.000000"
-- Retrieval info: PRIVATE: EXPLICIT_SWITCHOVER_COUNTER STRING "0"
-- Retrieval info: PRIVATE: EXT_FEEDBACK_RADIO STRING "0"
-- Retrieval info: PRIVATE: GLOCKED_COUNTER_EDIT_CHANGED STRING "1"
-- Retrieval info: PRIVATE: GLOCKED_FEATURE_ENABLED STRING "0"
-- Retrieval info: PRIVATE: GLOCKED_MODE_CHECK STRING "0"
-- Retrieval info: PRIVATE: GLOCK_COUNTER_EDIT NUMERIC "1048575"
-- Retrieval info: PRIVATE: HAS_MANUAL_SWITCHOVER STRING "1"
-- Retrieval info: PRIVATE: INCLK0_FREQ_EDIT STRING "50.000"
-- Retrieval info: PRIVATE: INCLK0_FREQ_UNIT_COMBO STRING "MHz"
-- Retrieval info: PRIVATE: INCLK1_FREQ_EDIT STRING "16.000"
-- Retrieval info: PRIVATE: INCLK1_FREQ_EDIT_CHANGED STRING "1"
-- Retrieval info: PRIVATE: INCLK1_FREQ_UNIT_CHANGED STRING "1"
-- Retrieval info: PRIVATE: INCLK1_FREQ_UNIT_COMBO STRING "MHz"
-- Retrieval info: PRIVATE: INTENDED_DEVICE_FAMILY STRING "Cyclone III"
-- Retrieval info: PRIVATE: INT_FEEDBACK__MODE_RADIO STRING "1"
-- Retrieval info: PRIVATE: LOCKED_OUTPUT_CHECK STRING "1"
-- Retrieval info: PRIVATE: LONG_SCAN_RADIO STRING "1"
-- Retrieval info: PRIVATE: LVDS_MODE_DATA_RATE STRING "Not Available"
-- Retrieval info: PRIVATE: LVDS_MODE_DATA_RATE_DIRTY NUMERIC "0"
-- Retrieval info: PRIVATE: LVDS_PHASE_SHIFT_UNIT0 STRING "deg"
-- Retrieval info: PRIVATE: LVDS_PHASE_SHIFT_UNIT1 STRING "deg"
-- Retrieval info: PRIVATE: LVDS_PHASE_SHIFT_UNIT2 STRING "ps"
-- Retrieval info: PRIVATE: LVDS_PHASE_SHIFT_UNIT3 STRING "ps"
-- Retrieval info: PRIVATE: LVDS_PHASE_SHIFT_UNIT4 STRING "ps"
-- Retrieval info: PRIVATE: MIG_DEVICE_SPEED_GRADE STRING "Any"
-- Retrieval info: PRIVATE: MIRROR_CLK0 STRING "0"
-- Retrieval info: PRIVATE: MIRROR_CLK1 STRING "0"
-- Retrieval info: PRIVATE: MIRROR_CLK2 STRING "0"
-- Retrieval info: PRIVATE: MIRROR_CLK3 STRING "0"
-- Retrieval info: PRIVATE: MIRROR_CLK4 STRING "0"
-- Retrieval info: PRIVATE: MULT_FACTOR0 NUMERIC "1"
-- Retrieval info: PRIVATE: MULT_FACTOR1 NUMERIC "1"
-- Retrieval info: PRIVATE: MULT_FACTOR2 NUMERIC "1"
-- Retrieval info: PRIVATE: MULT_FACTOR3 NUMERIC "1"
-- Retrieval info: PRIVATE: MULT_FACTOR4 NUMERIC "1"
-- Retrieval info: PRIVATE: NORMAL_MODE_RADIO STRING "0"
-- Retrieval info: PRIVATE: OUTPUT_FREQ0 STRING "120.00000000"
-- Retrieval info: PRIVATE: OUTPUT_FREQ1 STRING "16.00000000"
-- Retrieval info: PRIVATE: OUTPUT_FREQ2 STRING "16.00000000"
-- Retrieval info: PRIVATE: OUTPUT_FREQ3 STRING "32.00000000"
-- Retrieval info: PRIVATE: OUTPUT_FREQ4 STRING "80.00000000"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_MODE0 STRING "1"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_MODE1 STRING "1"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_MODE2 STRING "1"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_MODE3 STRING "1"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_MODE4 STRING "1"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_UNIT0 STRING "MHz"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_UNIT1 STRING "MHz"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_UNIT2 STRING "MHz"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_UNIT3 STRING "MHz"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_UNIT4 STRING "MHz"
-- Retrieval info: PRIVATE: PHASE_RECONFIG_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: PHASE_RECONFIG_INPUTS_CHECK STRING "0"
-- Retrieval info: PRIVATE: PHASE_SHIFT0 STRING "0.00000000"
-- Retrieval info: PRIVATE: PHASE_SHIFT1 STRING "180.00000000"
-- Retrieval info: PRIVATE: PHASE_SHIFT2 STRING "0.00000000"
-- Retrieval info: PRIVATE: PHASE_SHIFT3 STRING "0.00000000"
-- Retrieval info: PRIVATE: PHASE_SHIFT4 STRING "0.00000000"
-- Retrieval info: PRIVATE: PHASE_SHIFT_STEP_ENABLED_CHECK STRING "0"
-- Retrieval info: PRIVATE: PHASE_SHIFT_UNIT0 STRING "deg"
-- Retrieval info: PRIVATE: PHASE_SHIFT_UNIT1 STRING "deg"
-- Retrieval info: PRIVATE: PHASE_SHIFT_UNIT2 STRING "deg"
-- Retrieval info: PRIVATE: PHASE_SHIFT_UNIT3 STRING "ps"
-- Retrieval info: PRIVATE: PHASE_SHIFT_UNIT4 STRING "ps"
-- Retrieval info: PRIVATE: PLL_ADVANCED_PARAM_CHECK STRING "0"
-- Retrieval info: PRIVATE: PLL_ARESET_CHECK STRING "1"
-- Retrieval info: PRIVATE: PLL_AUTOPLL_CHECK NUMERIC "1"
-- Retrieval info: PRIVATE: PLL_ENHPLL_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PLL_FASTPLL_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PLL_FBMIMIC_CHECK STRING "0"
-- Retrieval info: PRIVATE: PLL_LVDS_PLL_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PLL_PFDENA_CHECK STRING "0"
-- Retrieval info: PRIVATE: PLL_TARGET_HARCOPY_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PRIMARY_CLK_COMBO STRING "inclk0"
-- Retrieval info: PRIVATE: RECONFIG_FILE STRING "Clock_Video.mif"
-- Retrieval info: PRIVATE: SACN_INPUTS_CHECK STRING "0"
-- Retrieval info: PRIVATE: SCAN_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: SELF_RESET_LOCK_LOSS STRING "1"
-- Retrieval info: PRIVATE: SHORT_SCAN_RADIO STRING "0"
-- Retrieval info: PRIVATE: SPREAD_FEATURE_ENABLED STRING "0"
-- Retrieval info: PRIVATE: SPREAD_FREQ STRING "50.000"
-- Retrieval info: PRIVATE: SPREAD_FREQ_UNIT STRING "KHz"
-- Retrieval info: PRIVATE: SPREAD_PERCENT STRING "0.500"
-- Retrieval info: PRIVATE: SPREAD_USE STRING "0"
-- Retrieval info: PRIVATE: SRC_SYNCH_COMP_RADIO STRING "0"
-- Retrieval info: PRIVATE: STICKY_CLK0 STRING "1"
-- Retrieval info: PRIVATE: STICKY_CLK1 STRING "1"
-- Retrieval info: PRIVATE: STICKY_CLK2 STRING "1"
-- Retrieval info: PRIVATE: STICKY_CLK3 STRING "1"
-- Retrieval info: PRIVATE: STICKY_CLK4 STRING "1"
-- Retrieval info: PRIVATE: SWITCHOVER_COUNT_EDIT NUMERIC "1"
-- Retrieval info: PRIVATE: SWITCHOVER_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: SYNTH_WRAPPER_GEN_POSTFIX STRING "0"
-- Retrieval info: PRIVATE: USE_CLK0 STRING "1"
-- Retrieval info: PRIVATE: USE_CLK1 STRING "1"
-- Retrieval info: PRIVATE: USE_CLK2 STRING "1"
-- Retrieval info: PRIVATE: USE_CLK3 STRING "1"
-- Retrieval info: PRIVATE: USE_CLK4 STRING "1"
-- Retrieval info: PRIVATE: USE_CLKENA0 STRING "0"
-- Retrieval info: PRIVATE: USE_CLKENA1 STRING "0"
-- Retrieval info: PRIVATE: USE_CLKENA2 STRING "0"
-- Retrieval info: PRIVATE: USE_CLKENA3 STRING "0"
-- Retrieval info: PRIVATE: USE_CLKENA4 STRING "0"
-- Retrieval info: PRIVATE: USE_MIL_SPEED_GRADE NUMERIC "0"
-- Retrieval info: PRIVATE: ZERO_DELAY_RADIO STRING "0"
-- Retrieval info: LIBRARY: altera_mf altera_mf.altera_mf_components.all
-- Retrieval info: CONSTANT: BANDWIDTH_TYPE STRING "LOW"
-- Retrieval info: CONSTANT: CLK0_DIVIDE_BY NUMERIC "5"
-- Retrieval info: CONSTANT: CLK0_DUTY_CYCLE NUMERIC "50"
-- Retrieval info: CONSTANT: CLK0_MULTIPLY_BY NUMERIC "12"
-- Retrieval info: CONSTANT: CLK0_PHASE_SHIFT STRING "0"
-- Retrieval info: CONSTANT: CLK1_DIVIDE_BY NUMERIC "25"
-- Retrieval info: CONSTANT: CLK1_DUTY_CYCLE NUMERIC "50"
-- Retrieval info: CONSTANT: CLK1_MULTIPLY_BY NUMERIC "8"
-- Retrieval info: CONSTANT: CLK1_PHASE_SHIFT STRING "31250"
-- Retrieval info: CONSTANT: CLK2_DIVIDE_BY NUMERIC "25"
-- Retrieval info: CONSTANT: CLK2_DUTY_CYCLE NUMERIC "50"
-- Retrieval info: CONSTANT: CLK2_MULTIPLY_BY NUMERIC "8"
-- Retrieval info: CONSTANT: CLK2_PHASE_SHIFT STRING "0"
-- Retrieval info: CONSTANT: CLK3_DIVIDE_BY NUMERIC "25"
-- Retrieval info: CONSTANT: CLK3_DUTY_CYCLE NUMERIC "50"
-- Retrieval info: CONSTANT: CLK3_MULTIPLY_BY NUMERIC "16"
-- Retrieval info: CONSTANT: CLK3_PHASE_SHIFT STRING "0"
-- Retrieval info: CONSTANT: CLK4_DIVIDE_BY NUMERIC "5"
-- Retrieval info: CONSTANT: CLK4_DUTY_CYCLE NUMERIC "50"
-- Retrieval info: CONSTANT: CLK4_MULTIPLY_BY NUMERIC "8"
-- Retrieval info: CONSTANT: CLK4_PHASE_SHIFT STRING "0"
-- Retrieval info: CONSTANT: INCLK0_INPUT_FREQUENCY NUMERIC "20000"
-- Retrieval info: CONSTANT: INTENDED_DEVICE_FAMILY STRING "Cyclone III"
-- Retrieval info: CONSTANT: LPM_TYPE STRING "altpll"
-- Retrieval info: CONSTANT: OPERATION_MODE STRING "NO_COMPENSATION"
-- Retrieval info: CONSTANT: PLL_TYPE STRING "AUTO"
-- Retrieval info: CONSTANT: PORT_ACTIVECLOCK STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_ARESET STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_CLKBAD0 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CLKBAD1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CLKLOSS STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CLKSWITCH STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CONFIGUPDATE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_FBIN STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_INCLK0 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_INCLK1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_LOCKED STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_PFDENA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASECOUNTERSELECT STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASEDONE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASESTEP STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASEUPDOWN STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PLLENA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANACLR STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANCLK STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANCLKENA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANDATA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANDATAOUT STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANDONE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANREAD STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANWRITE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk0 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_clk1 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_clk2 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_clk3 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_clk4 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_clk5 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena0 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena2 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena3 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena4 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena5 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk0 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk2 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk3 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: SELF_RESET_ON_LOSS_LOCK STRING "ON"
-- Retrieval info: CONSTANT: WIDTH_CLOCK NUMERIC "5"
-- Retrieval info: USED_PORT: @clk 0 0 5 0 OUTPUT_CLK_EXT VCC "@clk[4..0]"
-- Retrieval info: USED_PORT: @inclk 0 0 2 0 INPUT_CLK_EXT VCC "@inclk[1..0]"
-- Retrieval info: USED_PORT: areset 0 0 0 0 INPUT GND "areset"
-- Retrieval info: USED_PORT: c0 0 0 0 0 OUTPUT_CLK_EXT VCC "c0"
-- Retrieval info: USED_PORT: c1 0 0 0 0 OUTPUT_CLK_EXT VCC "c1"
-- Retrieval info: USED_PORT: c2 0 0 0 0 OUTPUT_CLK_EXT VCC "c2"
-- Retrieval info: USED_PORT: c3 0 0 0 0 OUTPUT_CLK_EXT VCC "c3"
-- Retrieval info: USED_PORT: c4 0 0 0 0 OUTPUT_CLK_EXT VCC "c4"
-- Retrieval info: USED_PORT: inclk0 0 0 0 0 INPUT_CLK_EXT GND "inclk0"
-- Retrieval info: USED_PORT: locked 0 0 0 0 OUTPUT GND "locked"
-- Retrieval info: CONNECT: @areset 0 0 0 0 areset 0 0 0 0
-- Retrieval info: CONNECT: @inclk 0 0 1 1 GND 0 0 0 0
-- Retrieval info: CONNECT: @inclk 0 0 1 0 inclk0 0 0 0 0
-- Retrieval info: CONNECT: c0 0 0 0 0 @clk 0 0 1 0
-- Retrieval info: CONNECT: c1 0 0 0 0 @clk 0 0 1 1
-- Retrieval info: CONNECT: c2 0 0 0 0 @clk 0 0 1 2
-- Retrieval info: CONNECT: c3 0 0 0 0 @clk 0 0 1 3
-- Retrieval info: CONNECT: c4 0 0 0 0 @clk 0 0 1 4
-- Retrieval info: CONNECT: locked 0 0 0 0 @locked 0 0 0 0
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock.vhd TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock.ppf TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock.inc FALSE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock.cmp TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock.bsf FALSE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_inst.vhd TRUE
-- Retrieval info: LIB_FILE: altera_mf
-- Retrieval info: CBX_MODULE_PREFIX: ON

View File

@@ -0,0 +1,25 @@
--Copyright (C) 1991-2013 Altera Corporation
--Your use of Altera Corporation's design tools, logic functions
--and other software and tools, and its AMPP partner logic
--functions, and any output files from any of the foregoing
--(including device programming or simulation files), and any
--associated documentation or information are expressly subject
--to the terms and conditions of the Altera Program License
--Subscription Agreement, Altera MegaCore Function License
--Agreement, or other applicable license agreement, including,
--without limitation, that your use is for the sole purpose of
--programming logic devices manufactured by Altera and sold by
--Altera or its authorized distributors. Please refer to the
--applicable agreement for further details.
component Video_Clock_II
PORT
(
areset : IN STD_LOGIC := '0';
inclk0 : IN STD_LOGIC := '0';
c0 : OUT STD_LOGIC ;
c1 : OUT STD_LOGIC ;
locked : OUT STD_LOGIC
);
end component;

View File

@@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE pinplan>
<pinplan intended_family="Cyclone III" variation_name="Video_Clock_II" megafunction_name="ALTPLL" specifies="all_ports">
<global>
<pin name="areset" direction="input" scope="external" />
<pin name="inclk0" direction="input" scope="external" source="clock" />
<pin name="c0" direction="output" scope="external" source="clock" />
<pin name="c1" direction="output" scope="external" source="clock" />
<pin name="locked" direction="output" scope="external" />
</global>
</pinplan>

View File

@@ -0,0 +1,6 @@
set_global_assignment -name IP_TOOL_NAME "ALTPLL"
set_global_assignment -name IP_TOOL_VERSION "13.1"
set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) "Video_Clock_II.vhd"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "Video_Clock_II_inst.vhd"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "Video_Clock_II.cmp"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "Video_Clock_II.ppf"]

View File

@@ -0,0 +1,394 @@
-- megafunction wizard: %ALTPLL%
-- GENERATION: STANDARD
-- VERSION: WM1.0
-- MODULE: altpll
-- ============================================================
-- File Name: Video_Clock_II.vhd
-- Megafunction Name(s):
-- altpll
--
-- Simulation Library Files(s):
-- altera_mf
-- ============================================================
-- ************************************************************
-- THIS IS A WIZARD-GENERATED FILE. DO NOT EDIT THIS FILE!
--
-- 13.1.0 Build 162 10/23/2013 SJ Full Version
-- ************************************************************
--Copyright (C) 1991-2013 Altera Corporation
--Your use of Altera Corporation's design tools, logic functions
--and other software and tools, and its AMPP partner logic
--functions, and any output files from any of the foregoing
--(including device programming or simulation files), and any
--associated documentation or information are expressly subject
--to the terms and conditions of the Altera Program License
--Subscription Agreement, Altera MegaCore Function License
--Agreement, or other applicable license agreement, including,
--without limitation, that your use is for the sole purpose of
--programming logic devices manufactured by Altera and sold by
--Altera or its authorized distributors. Please refer to the
--applicable agreement for further details.
LIBRARY ieee;
USE ieee.std_logic_1164.all;
LIBRARY altera_mf;
USE altera_mf.all;
ENTITY Video_Clock_II IS
PORT
(
areset : IN STD_LOGIC := '0';
inclk0 : IN STD_LOGIC := '0';
c0 : OUT STD_LOGIC ;
c1 : OUT STD_LOGIC ;
locked : OUT STD_LOGIC
);
END Video_Clock_II;
ARCHITECTURE SYN OF video_clock_ii IS
SIGNAL sub_wire0 : STD_LOGIC_VECTOR (4 DOWNTO 0);
SIGNAL sub_wire1 : STD_LOGIC ;
SIGNAL sub_wire2 : STD_LOGIC ;
SIGNAL sub_wire3 : STD_LOGIC ;
SIGNAL sub_wire4 : STD_LOGIC ;
SIGNAL sub_wire5 : STD_LOGIC_VECTOR (1 DOWNTO 0);
SIGNAL sub_wire6_bv : BIT_VECTOR (0 DOWNTO 0);
SIGNAL sub_wire6 : STD_LOGIC_VECTOR (0 DOWNTO 0);
COMPONENT altpll
GENERIC (
bandwidth_type : STRING;
clk0_divide_by : NATURAL;
clk0_duty_cycle : NATURAL;
clk0_multiply_by : NATURAL;
clk0_phase_shift : STRING;
clk1_divide_by : NATURAL;
clk1_duty_cycle : NATURAL;
clk1_multiply_by : NATURAL;
clk1_phase_shift : STRING;
inclk0_input_frequency : NATURAL;
intended_device_family : STRING;
lpm_hint : STRING;
lpm_type : STRING;
operation_mode : STRING;
pll_type : STRING;
port_activeclock : STRING;
port_areset : STRING;
port_clkbad0 : STRING;
port_clkbad1 : STRING;
port_clkloss : STRING;
port_clkswitch : STRING;
port_configupdate : STRING;
port_fbin : STRING;
port_inclk0 : STRING;
port_inclk1 : STRING;
port_locked : STRING;
port_pfdena : STRING;
port_phasecounterselect : STRING;
port_phasedone : STRING;
port_phasestep : STRING;
port_phaseupdown : STRING;
port_pllena : STRING;
port_scanaclr : STRING;
port_scanclk : STRING;
port_scanclkena : STRING;
port_scandata : STRING;
port_scandataout : STRING;
port_scandone : STRING;
port_scanread : STRING;
port_scanwrite : STRING;
port_clk0 : STRING;
port_clk1 : STRING;
port_clk2 : STRING;
port_clk3 : STRING;
port_clk4 : STRING;
port_clk5 : STRING;
port_clkena0 : STRING;
port_clkena1 : STRING;
port_clkena2 : STRING;
port_clkena3 : STRING;
port_clkena4 : STRING;
port_clkena5 : STRING;
port_extclk0 : STRING;
port_extclk1 : STRING;
port_extclk2 : STRING;
port_extclk3 : STRING;
self_reset_on_loss_lock : STRING;
width_clock : NATURAL
);
PORT (
areset : IN STD_LOGIC ;
clk : OUT STD_LOGIC_VECTOR (4 DOWNTO 0);
inclk : IN STD_LOGIC_VECTOR (1 DOWNTO 0);
locked : OUT STD_LOGIC
);
END COMPONENT;
BEGIN
sub_wire6_bv(0 DOWNTO 0) <= "0";
sub_wire6 <= To_stdlogicvector(sub_wire6_bv);
sub_wire3 <= sub_wire0(0);
sub_wire1 <= sub_wire0(1);
c1 <= sub_wire1;
locked <= sub_wire2;
c0 <= sub_wire3;
sub_wire4 <= inclk0;
sub_wire5 <= sub_wire6(0 DOWNTO 0) & sub_wire4;
altpll_component : altpll
GENERIC MAP (
bandwidth_type => "LOW",
clk0_divide_by => 5,
clk0_duty_cycle => 50,
clk0_multiply_by => 13,
clk0_phase_shift => "0",
clk1_divide_by => 5000,
clk1_duty_cycle => 50,
clk1_multiply_by => 5051,
clk1_phase_shift => "0",
inclk0_input_frequency => 20000,
intended_device_family => "Cyclone III",
lpm_hint => "CBX_MODULE_PREFIX=Video_Clock_II",
lpm_type => "altpll",
operation_mode => "NO_COMPENSATION",
pll_type => "AUTO",
port_activeclock => "PORT_UNUSED",
port_areset => "PORT_USED",
port_clkbad0 => "PORT_UNUSED",
port_clkbad1 => "PORT_UNUSED",
port_clkloss => "PORT_UNUSED",
port_clkswitch => "PORT_UNUSED",
port_configupdate => "PORT_UNUSED",
port_fbin => "PORT_UNUSED",
port_inclk0 => "PORT_USED",
port_inclk1 => "PORT_UNUSED",
port_locked => "PORT_USED",
port_pfdena => "PORT_UNUSED",
port_phasecounterselect => "PORT_UNUSED",
port_phasedone => "PORT_UNUSED",
port_phasestep => "PORT_UNUSED",
port_phaseupdown => "PORT_UNUSED",
port_pllena => "PORT_UNUSED",
port_scanaclr => "PORT_UNUSED",
port_scanclk => "PORT_UNUSED",
port_scanclkena => "PORT_UNUSED",
port_scandata => "PORT_UNUSED",
port_scandataout => "PORT_UNUSED",
port_scandone => "PORT_UNUSED",
port_scanread => "PORT_UNUSED",
port_scanwrite => "PORT_UNUSED",
port_clk0 => "PORT_USED",
port_clk1 => "PORT_USED",
port_clk2 => "PORT_UNUSED",
port_clk3 => "PORT_UNUSED",
port_clk4 => "PORT_UNUSED",
port_clk5 => "PORT_UNUSED",
port_clkena0 => "PORT_UNUSED",
port_clkena1 => "PORT_UNUSED",
port_clkena2 => "PORT_UNUSED",
port_clkena3 => "PORT_UNUSED",
port_clkena4 => "PORT_UNUSED",
port_clkena5 => "PORT_UNUSED",
port_extclk0 => "PORT_UNUSED",
port_extclk1 => "PORT_UNUSED",
port_extclk2 => "PORT_UNUSED",
port_extclk3 => "PORT_UNUSED",
self_reset_on_loss_lock => "ON",
width_clock => 5
)
PORT MAP (
areset => areset,
inclk => sub_wire5,
clk => sub_wire0,
locked => sub_wire2
);
END SYN;
-- ============================================================
-- CNX file retrieval info
-- ============================================================
-- Retrieval info: PRIVATE: ACTIVECLK_CHECK STRING "0"
-- Retrieval info: PRIVATE: BANDWIDTH STRING "1.000"
-- Retrieval info: PRIVATE: BANDWIDTH_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: BANDWIDTH_FREQ_UNIT STRING "MHz"
-- Retrieval info: PRIVATE: BANDWIDTH_PRESET STRING "Low"
-- Retrieval info: PRIVATE: BANDWIDTH_USE_AUTO STRING "0"
-- Retrieval info: PRIVATE: BANDWIDTH_USE_PRESET STRING "1"
-- Retrieval info: PRIVATE: CLKBAD_SWITCHOVER_CHECK STRING "0"
-- Retrieval info: PRIVATE: CLKLOSS_CHECK STRING "0"
-- Retrieval info: PRIVATE: CLKSWITCH_CHECK STRING "0"
-- Retrieval info: PRIVATE: CNX_NO_COMPENSATE_RADIO STRING "1"
-- Retrieval info: PRIVATE: CREATE_CLKBAD_CHECK STRING "0"
-- Retrieval info: PRIVATE: CREATE_INCLK1_CHECK STRING "0"
-- Retrieval info: PRIVATE: CUR_DEDICATED_CLK STRING "c0"
-- Retrieval info: PRIVATE: CUR_FBIN_CLK STRING "c0"
-- Retrieval info: PRIVATE: DEVICE_SPEED_GRADE STRING "8"
-- Retrieval info: PRIVATE: DIV_FACTOR0 NUMERIC "1"
-- Retrieval info: PRIVATE: DIV_FACTOR1 NUMERIC "1"
-- Retrieval info: PRIVATE: DUTY_CYCLE0 STRING "50.00000000"
-- Retrieval info: PRIVATE: DUTY_CYCLE1 STRING "50.00000000"
-- Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE0 STRING "130.000000"
-- Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE1 STRING "50.509998"
-- Retrieval info: PRIVATE: EXPLICIT_SWITCHOVER_COUNTER STRING "0"
-- Retrieval info: PRIVATE: EXT_FEEDBACK_RADIO STRING "0"
-- Retrieval info: PRIVATE: GLOCKED_COUNTER_EDIT_CHANGED STRING "1"
-- Retrieval info: PRIVATE: GLOCKED_FEATURE_ENABLED STRING "0"
-- Retrieval info: PRIVATE: GLOCKED_MODE_CHECK STRING "0"
-- Retrieval info: PRIVATE: GLOCK_COUNTER_EDIT NUMERIC "1048575"
-- Retrieval info: PRIVATE: HAS_MANUAL_SWITCHOVER STRING "1"
-- Retrieval info: PRIVATE: INCLK0_FREQ_EDIT STRING "50.000"
-- Retrieval info: PRIVATE: INCLK0_FREQ_UNIT_COMBO STRING "MHz"
-- Retrieval info: PRIVATE: INCLK1_FREQ_EDIT STRING "100.000"
-- Retrieval info: PRIVATE: INCLK1_FREQ_EDIT_CHANGED STRING "1"
-- Retrieval info: PRIVATE: INCLK1_FREQ_UNIT_CHANGED STRING "1"
-- Retrieval info: PRIVATE: INCLK1_FREQ_UNIT_COMBO STRING "MHz"
-- Retrieval info: PRIVATE: INTENDED_DEVICE_FAMILY STRING "Cyclone III"
-- Retrieval info: PRIVATE: INT_FEEDBACK__MODE_RADIO STRING "1"
-- Retrieval info: PRIVATE: LOCKED_OUTPUT_CHECK STRING "1"
-- Retrieval info: PRIVATE: LONG_SCAN_RADIO STRING "1"
-- Retrieval info: PRIVATE: LVDS_MODE_DATA_RATE STRING "Not Available"
-- Retrieval info: PRIVATE: LVDS_MODE_DATA_RATE_DIRTY NUMERIC "0"
-- Retrieval info: PRIVATE: LVDS_PHASE_SHIFT_UNIT0 STRING "deg"
-- Retrieval info: PRIVATE: LVDS_PHASE_SHIFT_UNIT1 STRING "ps"
-- Retrieval info: PRIVATE: MIG_DEVICE_SPEED_GRADE STRING "Any"
-- Retrieval info: PRIVATE: MIRROR_CLK0 STRING "0"
-- Retrieval info: PRIVATE: MIRROR_CLK1 STRING "0"
-- Retrieval info: PRIVATE: MULT_FACTOR0 NUMERIC "1"
-- Retrieval info: PRIVATE: MULT_FACTOR1 NUMERIC "1"
-- Retrieval info: PRIVATE: NORMAL_MODE_RADIO STRING "0"
-- Retrieval info: PRIVATE: OUTPUT_FREQ0 STRING "130.00000000"
-- Retrieval info: PRIVATE: OUTPUT_FREQ1 STRING "50.51000000"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_MODE0 STRING "1"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_MODE1 STRING "1"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_UNIT0 STRING "MHz"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_UNIT1 STRING "MHz"
-- Retrieval info: PRIVATE: PHASE_RECONFIG_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: PHASE_RECONFIG_INPUTS_CHECK STRING "0"
-- Retrieval info: PRIVATE: PHASE_SHIFT0 STRING "0.00000000"
-- Retrieval info: PRIVATE: PHASE_SHIFT1 STRING "0.00000000"
-- Retrieval info: PRIVATE: PHASE_SHIFT_STEP_ENABLED_CHECK STRING "0"
-- Retrieval info: PRIVATE: PHASE_SHIFT_UNIT0 STRING "deg"
-- Retrieval info: PRIVATE: PHASE_SHIFT_UNIT1 STRING "ps"
-- Retrieval info: PRIVATE: PLL_ADVANCED_PARAM_CHECK STRING "0"
-- Retrieval info: PRIVATE: PLL_ARESET_CHECK STRING "1"
-- Retrieval info: PRIVATE: PLL_AUTOPLL_CHECK NUMERIC "1"
-- Retrieval info: PRIVATE: PLL_ENHPLL_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PLL_FASTPLL_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PLL_FBMIMIC_CHECK STRING "0"
-- Retrieval info: PRIVATE: PLL_LVDS_PLL_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PLL_PFDENA_CHECK STRING "0"
-- Retrieval info: PRIVATE: PLL_TARGET_HARCOPY_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PRIMARY_CLK_COMBO STRING "inclk0"
-- Retrieval info: PRIVATE: RECONFIG_FILE STRING "Video_Clock_II.mif"
-- Retrieval info: PRIVATE: SACN_INPUTS_CHECK STRING "0"
-- Retrieval info: PRIVATE: SCAN_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: SELF_RESET_LOCK_LOSS STRING "1"
-- Retrieval info: PRIVATE: SHORT_SCAN_RADIO STRING "0"
-- Retrieval info: PRIVATE: SPREAD_FEATURE_ENABLED STRING "0"
-- Retrieval info: PRIVATE: SPREAD_FREQ STRING "50.000"
-- Retrieval info: PRIVATE: SPREAD_FREQ_UNIT STRING "KHz"
-- Retrieval info: PRIVATE: SPREAD_PERCENT STRING "0.500"
-- Retrieval info: PRIVATE: SPREAD_USE STRING "0"
-- Retrieval info: PRIVATE: SRC_SYNCH_COMP_RADIO STRING "0"
-- Retrieval info: PRIVATE: STICKY_CLK0 STRING "1"
-- Retrieval info: PRIVATE: STICKY_CLK1 STRING "1"
-- Retrieval info: PRIVATE: SWITCHOVER_COUNT_EDIT NUMERIC "1"
-- Retrieval info: PRIVATE: SWITCHOVER_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: SYNTH_WRAPPER_GEN_POSTFIX STRING "0"
-- Retrieval info: PRIVATE: USE_CLK0 STRING "1"
-- Retrieval info: PRIVATE: USE_CLK1 STRING "1"
-- Retrieval info: PRIVATE: USE_CLKENA0 STRING "0"
-- Retrieval info: PRIVATE: USE_CLKENA1 STRING "0"
-- Retrieval info: PRIVATE: USE_MIL_SPEED_GRADE NUMERIC "0"
-- Retrieval info: PRIVATE: ZERO_DELAY_RADIO STRING "0"
-- Retrieval info: LIBRARY: altera_mf altera_mf.altera_mf_components.all
-- Retrieval info: CONSTANT: BANDWIDTH_TYPE STRING "LOW"
-- Retrieval info: CONSTANT: CLK0_DIVIDE_BY NUMERIC "5"
-- Retrieval info: CONSTANT: CLK0_DUTY_CYCLE NUMERIC "50"
-- Retrieval info: CONSTANT: CLK0_MULTIPLY_BY NUMERIC "13"
-- Retrieval info: CONSTANT: CLK0_PHASE_SHIFT STRING "0"
-- Retrieval info: CONSTANT: CLK1_DIVIDE_BY NUMERIC "5000"
-- Retrieval info: CONSTANT: CLK1_DUTY_CYCLE NUMERIC "50"
-- Retrieval info: CONSTANT: CLK1_MULTIPLY_BY NUMERIC "5051"
-- Retrieval info: CONSTANT: CLK1_PHASE_SHIFT STRING "0"
-- Retrieval info: CONSTANT: INCLK0_INPUT_FREQUENCY NUMERIC "20000"
-- Retrieval info: CONSTANT: INTENDED_DEVICE_FAMILY STRING "Cyclone III"
-- Retrieval info: CONSTANT: LPM_TYPE STRING "altpll"
-- Retrieval info: CONSTANT: OPERATION_MODE STRING "NO_COMPENSATION"
-- Retrieval info: CONSTANT: PLL_TYPE STRING "AUTO"
-- Retrieval info: CONSTANT: PORT_ACTIVECLOCK STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_ARESET STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_CLKBAD0 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CLKBAD1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CLKLOSS STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CLKSWITCH STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CONFIGUPDATE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_FBIN STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_INCLK0 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_INCLK1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_LOCKED STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_PFDENA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASECOUNTERSELECT STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASEDONE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASESTEP STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASEUPDOWN STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PLLENA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANACLR STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANCLK STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANCLKENA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANDATA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANDATAOUT STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANDONE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANREAD STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANWRITE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk0 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_clk1 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_clk2 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk3 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk4 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk5 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena0 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena2 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena3 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena4 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena5 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk0 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk2 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk3 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: SELF_RESET_ON_LOSS_LOCK STRING "ON"
-- Retrieval info: CONSTANT: WIDTH_CLOCK NUMERIC "5"
-- Retrieval info: USED_PORT: @clk 0 0 5 0 OUTPUT_CLK_EXT VCC "@clk[4..0]"
-- Retrieval info: USED_PORT: @inclk 0 0 2 0 INPUT_CLK_EXT VCC "@inclk[1..0]"
-- Retrieval info: USED_PORT: areset 0 0 0 0 INPUT GND "areset"
-- Retrieval info: USED_PORT: c0 0 0 0 0 OUTPUT_CLK_EXT VCC "c0"
-- Retrieval info: USED_PORT: c1 0 0 0 0 OUTPUT_CLK_EXT VCC "c1"
-- Retrieval info: USED_PORT: inclk0 0 0 0 0 INPUT_CLK_EXT GND "inclk0"
-- Retrieval info: USED_PORT: locked 0 0 0 0 OUTPUT GND "locked"
-- Retrieval info: CONNECT: @areset 0 0 0 0 areset 0 0 0 0
-- Retrieval info: CONNECT: @inclk 0 0 1 1 GND 0 0 0 0
-- Retrieval info: CONNECT: @inclk 0 0 1 0 inclk0 0 0 0 0
-- Retrieval info: CONNECT: c0 0 0 0 0 @clk 0 0 1 0
-- Retrieval info: CONNECT: c1 0 0 0 0 @clk 0 0 1 1
-- Retrieval info: CONNECT: locked 0 0 0 0 @locked 0 0 0 0
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_II.vhd TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_II.ppf TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_II.inc FALSE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_II.cmp TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_II.bsf FALSE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_II_inst.vhd TRUE
-- Retrieval info: LIB_FILE: altera_mf
-- Retrieval info: CBX_MODULE_PREFIX: ON

View File

@@ -0,0 +1,24 @@
--Copyright (C) 1991-2013 Altera Corporation
--Your use of Altera Corporation's design tools, logic functions
--and other software and tools, and its AMPP partner logic
--functions, and any output files from any of the foregoing
--(including device programming or simulation files), and any
--associated documentation or information are expressly subject
--to the terms and conditions of the Altera Program License
--Subscription Agreement, Altera MegaCore Function License
--Agreement, or other applicable license agreement, including,
--without limitation, that your use is for the sole purpose of
--programming logic devices manufactured by Altera and sold by
--Altera or its authorized distributors. Please refer to the
--applicable agreement for further details.
component Video_Clock_III
PORT
(
areset : IN STD_LOGIC := '0';
inclk0 : IN STD_LOGIC := '0';
c0 : OUT STD_LOGIC ;
locked : OUT STD_LOGIC
);
end component;

View File

@@ -0,0 +1,11 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE pinplan>
<pinplan intended_family="Cyclone III" variation_name="Video_Clock_III" megafunction_name="ALTPLL" specifies="all_ports">
<global>
<pin name="areset" direction="input" scope="external" />
<pin name="inclk0" direction="input" scope="external" source="clock" />
<pin name="c0" direction="output" scope="external" source="clock" />
<pin name="locked" direction="output" scope="external" />
</global>
</pinplan>

View File

@@ -0,0 +1,6 @@
set_global_assignment -name IP_TOOL_NAME "ALTPLL"
set_global_assignment -name IP_TOOL_VERSION "13.1"
set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) "Video_Clock_III.vhd"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "Video_Clock_III_inst.vhd"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "Video_Clock_III.cmp"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "Video_Clock_III.ppf"]

View File

@@ -0,0 +1,365 @@
-- megafunction wizard: %ALTPLL%
-- GENERATION: STANDARD
-- VERSION: WM1.0
-- MODULE: altpll
-- ============================================================
-- File Name: Video_Clock_III.vhd
-- Megafunction Name(s):
-- altpll
--
-- Simulation Library Files(s):
-- altera_mf
-- ============================================================
-- ************************************************************
-- THIS IS A WIZARD-GENERATED FILE. DO NOT EDIT THIS FILE!
--
-- 13.1.0 Build 162 10/23/2013 SJ Full Version
-- ************************************************************
--Copyright (C) 1991-2013 Altera Corporation
--Your use of Altera Corporation's design tools, logic functions
--and other software and tools, and its AMPP partner logic
--functions, and any output files from any of the foregoing
--(including device programming or simulation files), and any
--associated documentation or information are expressly subject
--to the terms and conditions of the Altera Program License
--Subscription Agreement, Altera MegaCore Function License
--Agreement, or other applicable license agreement, including,
--without limitation, that your use is for the sole purpose of
--programming logic devices manufactured by Altera and sold by
--Altera or its authorized distributors. Please refer to the
--applicable agreement for further details.
LIBRARY ieee;
USE ieee.std_logic_1164.all;
LIBRARY altera_mf;
USE altera_mf.all;
ENTITY Video_Clock_III IS
PORT
(
areset : IN STD_LOGIC := '0';
inclk0 : IN STD_LOGIC := '0';
c0 : OUT STD_LOGIC ;
locked : OUT STD_LOGIC
);
END Video_Clock_III;
ARCHITECTURE SYN OF video_clock_iii IS
SIGNAL sub_wire0 : STD_LOGIC ;
SIGNAL sub_wire1 : STD_LOGIC_VECTOR (4 DOWNTO 0);
SIGNAL sub_wire2 : STD_LOGIC ;
SIGNAL sub_wire3 : STD_LOGIC ;
SIGNAL sub_wire4 : STD_LOGIC_VECTOR (1 DOWNTO 0);
SIGNAL sub_wire5_bv : BIT_VECTOR (0 DOWNTO 0);
SIGNAL sub_wire5 : STD_LOGIC_VECTOR (0 DOWNTO 0);
COMPONENT altpll
GENERIC (
bandwidth_type : STRING;
clk0_divide_by : NATURAL;
clk0_duty_cycle : NATURAL;
clk0_multiply_by : NATURAL;
clk0_phase_shift : STRING;
compensate_clock : STRING;
inclk0_input_frequency : NATURAL;
intended_device_family : STRING;
lpm_hint : STRING;
lpm_type : STRING;
operation_mode : STRING;
pll_type : STRING;
port_activeclock : STRING;
port_areset : STRING;
port_clkbad0 : STRING;
port_clkbad1 : STRING;
port_clkloss : STRING;
port_clkswitch : STRING;
port_configupdate : STRING;
port_fbin : STRING;
port_inclk0 : STRING;
port_inclk1 : STRING;
port_locked : STRING;
port_pfdena : STRING;
port_phasecounterselect : STRING;
port_phasedone : STRING;
port_phasestep : STRING;
port_phaseupdown : STRING;
port_pllena : STRING;
port_scanaclr : STRING;
port_scanclk : STRING;
port_scanclkena : STRING;
port_scandata : STRING;
port_scandataout : STRING;
port_scandone : STRING;
port_scanread : STRING;
port_scanwrite : STRING;
port_clk0 : STRING;
port_clk1 : STRING;
port_clk2 : STRING;
port_clk3 : STRING;
port_clk4 : STRING;
port_clk5 : STRING;
port_clkena0 : STRING;
port_clkena1 : STRING;
port_clkena2 : STRING;
port_clkena3 : STRING;
port_clkena4 : STRING;
port_clkena5 : STRING;
port_extclk0 : STRING;
port_extclk1 : STRING;
port_extclk2 : STRING;
port_extclk3 : STRING;
self_reset_on_loss_lock : STRING;
width_clock : NATURAL
);
PORT (
areset : IN STD_LOGIC ;
clk : OUT STD_LOGIC_VECTOR (4 DOWNTO 0);
inclk : IN STD_LOGIC_VECTOR (1 DOWNTO 0);
locked : OUT STD_LOGIC
);
END COMPONENT;
BEGIN
sub_wire5_bv(0 DOWNTO 0) <= "0";
sub_wire5 <= To_stdlogicvector(sub_wire5_bv);
locked <= sub_wire0;
sub_wire2 <= sub_wire1(0);
c0 <= sub_wire2;
sub_wire3 <= inclk0;
sub_wire4 <= sub_wire5(0 DOWNTO 0) & sub_wire3;
altpll_component : altpll
GENERIC MAP (
bandwidth_type => "LOW",
clk0_divide_by => 25,
clk0_duty_cycle => 50,
clk0_multiply_by => 64,
clk0_phase_shift => "0",
compensate_clock => "CLK0",
inclk0_input_frequency => 20000,
intended_device_family => "Cyclone III",
lpm_hint => "CBX_MODULE_PREFIX=Video_Clock_III",
lpm_type => "altpll",
operation_mode => "NORMAL",
pll_type => "AUTO",
port_activeclock => "PORT_UNUSED",
port_areset => "PORT_USED",
port_clkbad0 => "PORT_UNUSED",
port_clkbad1 => "PORT_UNUSED",
port_clkloss => "PORT_UNUSED",
port_clkswitch => "PORT_UNUSED",
port_configupdate => "PORT_UNUSED",
port_fbin => "PORT_UNUSED",
port_inclk0 => "PORT_USED",
port_inclk1 => "PORT_UNUSED",
port_locked => "PORT_USED",
port_pfdena => "PORT_UNUSED",
port_phasecounterselect => "PORT_UNUSED",
port_phasedone => "PORT_UNUSED",
port_phasestep => "PORT_UNUSED",
port_phaseupdown => "PORT_UNUSED",
port_pllena => "PORT_UNUSED",
port_scanaclr => "PORT_UNUSED",
port_scanclk => "PORT_UNUSED",
port_scanclkena => "PORT_UNUSED",
port_scandata => "PORT_UNUSED",
port_scandataout => "PORT_UNUSED",
port_scandone => "PORT_UNUSED",
port_scanread => "PORT_UNUSED",
port_scanwrite => "PORT_UNUSED",
port_clk0 => "PORT_USED",
port_clk1 => "PORT_UNUSED",
port_clk2 => "PORT_UNUSED",
port_clk3 => "PORT_UNUSED",
port_clk4 => "PORT_UNUSED",
port_clk5 => "PORT_UNUSED",
port_clkena0 => "PORT_UNUSED",
port_clkena1 => "PORT_UNUSED",
port_clkena2 => "PORT_UNUSED",
port_clkena3 => "PORT_UNUSED",
port_clkena4 => "PORT_UNUSED",
port_clkena5 => "PORT_UNUSED",
port_extclk0 => "PORT_UNUSED",
port_extclk1 => "PORT_UNUSED",
port_extclk2 => "PORT_UNUSED",
port_extclk3 => "PORT_UNUSED",
self_reset_on_loss_lock => "ON",
width_clock => 5
)
PORT MAP (
areset => areset,
inclk => sub_wire4,
locked => sub_wire0,
clk => sub_wire1
);
END SYN;
-- ============================================================
-- CNX file retrieval info
-- ============================================================
-- Retrieval info: PRIVATE: ACTIVECLK_CHECK STRING "0"
-- Retrieval info: PRIVATE: BANDWIDTH STRING "1.000"
-- Retrieval info: PRIVATE: BANDWIDTH_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: BANDWIDTH_FREQ_UNIT STRING "MHz"
-- Retrieval info: PRIVATE: BANDWIDTH_PRESET STRING "Low"
-- Retrieval info: PRIVATE: BANDWIDTH_USE_AUTO STRING "0"
-- Retrieval info: PRIVATE: BANDWIDTH_USE_PRESET STRING "1"
-- Retrieval info: PRIVATE: CLKBAD_SWITCHOVER_CHECK STRING "0"
-- Retrieval info: PRIVATE: CLKLOSS_CHECK STRING "0"
-- Retrieval info: PRIVATE: CLKSWITCH_CHECK STRING "0"
-- Retrieval info: PRIVATE: CNX_NO_COMPENSATE_RADIO STRING "0"
-- Retrieval info: PRIVATE: CREATE_CLKBAD_CHECK STRING "0"
-- Retrieval info: PRIVATE: CREATE_INCLK1_CHECK STRING "0"
-- Retrieval info: PRIVATE: CUR_DEDICATED_CLK STRING "c0"
-- Retrieval info: PRIVATE: CUR_FBIN_CLK STRING "c0"
-- Retrieval info: PRIVATE: DEVICE_SPEED_GRADE STRING "8"
-- Retrieval info: PRIVATE: DIV_FACTOR0 NUMERIC "1"
-- Retrieval info: PRIVATE: DUTY_CYCLE0 STRING "50.00000000"
-- Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE0 STRING "128.000000"
-- Retrieval info: PRIVATE: EXPLICIT_SWITCHOVER_COUNTER STRING "0"
-- Retrieval info: PRIVATE: EXT_FEEDBACK_RADIO STRING "0"
-- Retrieval info: PRIVATE: GLOCKED_COUNTER_EDIT_CHANGED STRING "1"
-- Retrieval info: PRIVATE: GLOCKED_FEATURE_ENABLED STRING "0"
-- Retrieval info: PRIVATE: GLOCKED_MODE_CHECK STRING "0"
-- Retrieval info: PRIVATE: GLOCK_COUNTER_EDIT NUMERIC "1048575"
-- Retrieval info: PRIVATE: HAS_MANUAL_SWITCHOVER STRING "1"
-- Retrieval info: PRIVATE: INCLK0_FREQ_EDIT STRING "50.000"
-- Retrieval info: PRIVATE: INCLK0_FREQ_UNIT_COMBO STRING "MHz"
-- Retrieval info: PRIVATE: INCLK1_FREQ_EDIT STRING "100.000"
-- Retrieval info: PRIVATE: INCLK1_FREQ_EDIT_CHANGED STRING "1"
-- Retrieval info: PRIVATE: INCLK1_FREQ_UNIT_CHANGED STRING "1"
-- Retrieval info: PRIVATE: INCLK1_FREQ_UNIT_COMBO STRING "MHz"
-- Retrieval info: PRIVATE: INTENDED_DEVICE_FAMILY STRING "Cyclone III"
-- Retrieval info: PRIVATE: INT_FEEDBACK__MODE_RADIO STRING "1"
-- Retrieval info: PRIVATE: LOCKED_OUTPUT_CHECK STRING "1"
-- Retrieval info: PRIVATE: LONG_SCAN_RADIO STRING "1"
-- Retrieval info: PRIVATE: LVDS_MODE_DATA_RATE STRING "Not Available"
-- Retrieval info: PRIVATE: LVDS_MODE_DATA_RATE_DIRTY NUMERIC "0"
-- Retrieval info: PRIVATE: LVDS_PHASE_SHIFT_UNIT0 STRING "deg"
-- Retrieval info: PRIVATE: MIG_DEVICE_SPEED_GRADE STRING "Any"
-- Retrieval info: PRIVATE: MIRROR_CLK0 STRING "0"
-- Retrieval info: PRIVATE: MULT_FACTOR0 NUMERIC "1"
-- Retrieval info: PRIVATE: NORMAL_MODE_RADIO STRING "1"
-- Retrieval info: PRIVATE: OUTPUT_FREQ0 STRING "128.00000000"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_MODE0 STRING "1"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_UNIT0 STRING "MHz"
-- Retrieval info: PRIVATE: PHASE_RECONFIG_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: PHASE_RECONFIG_INPUTS_CHECK STRING "0"
-- Retrieval info: PRIVATE: PHASE_SHIFT0 STRING "0.00000000"
-- Retrieval info: PRIVATE: PHASE_SHIFT_STEP_ENABLED_CHECK STRING "0"
-- Retrieval info: PRIVATE: PHASE_SHIFT_UNIT0 STRING "deg"
-- Retrieval info: PRIVATE: PLL_ADVANCED_PARAM_CHECK STRING "0"
-- Retrieval info: PRIVATE: PLL_ARESET_CHECK STRING "1"
-- Retrieval info: PRIVATE: PLL_AUTOPLL_CHECK NUMERIC "1"
-- Retrieval info: PRIVATE: PLL_ENHPLL_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PLL_FASTPLL_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PLL_FBMIMIC_CHECK STRING "0"
-- Retrieval info: PRIVATE: PLL_LVDS_PLL_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PLL_PFDENA_CHECK STRING "0"
-- Retrieval info: PRIVATE: PLL_TARGET_HARCOPY_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PRIMARY_CLK_COMBO STRING "inclk0"
-- Retrieval info: PRIVATE: RECONFIG_FILE STRING "Video_Clock_II.mif"
-- Retrieval info: PRIVATE: SACN_INPUTS_CHECK STRING "0"
-- Retrieval info: PRIVATE: SCAN_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: SELF_RESET_LOCK_LOSS STRING "1"
-- Retrieval info: PRIVATE: SHORT_SCAN_RADIO STRING "0"
-- Retrieval info: PRIVATE: SPREAD_FEATURE_ENABLED STRING "0"
-- Retrieval info: PRIVATE: SPREAD_FREQ STRING "50.000"
-- Retrieval info: PRIVATE: SPREAD_FREQ_UNIT STRING "KHz"
-- Retrieval info: PRIVATE: SPREAD_PERCENT STRING "0.500"
-- Retrieval info: PRIVATE: SPREAD_USE STRING "0"
-- Retrieval info: PRIVATE: SRC_SYNCH_COMP_RADIO STRING "0"
-- Retrieval info: PRIVATE: STICKY_CLK0 STRING "1"
-- Retrieval info: PRIVATE: SWITCHOVER_COUNT_EDIT NUMERIC "1"
-- Retrieval info: PRIVATE: SWITCHOVER_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: SYNTH_WRAPPER_GEN_POSTFIX STRING "0"
-- Retrieval info: PRIVATE: USE_CLK0 STRING "1"
-- Retrieval info: PRIVATE: USE_CLKENA0 STRING "0"
-- Retrieval info: PRIVATE: USE_MIL_SPEED_GRADE NUMERIC "0"
-- Retrieval info: PRIVATE: ZERO_DELAY_RADIO STRING "0"
-- Retrieval info: LIBRARY: altera_mf altera_mf.altera_mf_components.all
-- Retrieval info: CONSTANT: BANDWIDTH_TYPE STRING "LOW"
-- Retrieval info: CONSTANT: CLK0_DIVIDE_BY NUMERIC "25"
-- Retrieval info: CONSTANT: CLK0_DUTY_CYCLE NUMERIC "50"
-- Retrieval info: CONSTANT: CLK0_MULTIPLY_BY NUMERIC "64"
-- Retrieval info: CONSTANT: CLK0_PHASE_SHIFT STRING "0"
-- Retrieval info: CONSTANT: COMPENSATE_CLOCK STRING "CLK0"
-- Retrieval info: CONSTANT: INCLK0_INPUT_FREQUENCY NUMERIC "20000"
-- Retrieval info: CONSTANT: INTENDED_DEVICE_FAMILY STRING "Cyclone III"
-- Retrieval info: CONSTANT: LPM_TYPE STRING "altpll"
-- Retrieval info: CONSTANT: OPERATION_MODE STRING "NORMAL"
-- Retrieval info: CONSTANT: PLL_TYPE STRING "AUTO"
-- Retrieval info: CONSTANT: PORT_ACTIVECLOCK STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_ARESET STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_CLKBAD0 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CLKBAD1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CLKLOSS STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CLKSWITCH STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CONFIGUPDATE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_FBIN STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_INCLK0 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_INCLK1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_LOCKED STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_PFDENA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASECOUNTERSELECT STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASEDONE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASESTEP STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASEUPDOWN STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PLLENA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANACLR STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANCLK STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANCLKENA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANDATA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANDATAOUT STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANDONE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANREAD STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANWRITE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk0 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_clk1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk2 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk3 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk4 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk5 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena0 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena2 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena3 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena4 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena5 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk0 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk2 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk3 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: SELF_RESET_ON_LOSS_LOCK STRING "ON"
-- Retrieval info: CONSTANT: WIDTH_CLOCK NUMERIC "5"
-- Retrieval info: USED_PORT: @clk 0 0 5 0 OUTPUT_CLK_EXT VCC "@clk[4..0]"
-- Retrieval info: USED_PORT: @inclk 0 0 2 0 INPUT_CLK_EXT VCC "@inclk[1..0]"
-- Retrieval info: USED_PORT: areset 0 0 0 0 INPUT GND "areset"
-- Retrieval info: USED_PORT: c0 0 0 0 0 OUTPUT_CLK_EXT VCC "c0"
-- Retrieval info: USED_PORT: inclk0 0 0 0 0 INPUT_CLK_EXT GND "inclk0"
-- Retrieval info: USED_PORT: locked 0 0 0 0 OUTPUT GND "locked"
-- Retrieval info: CONNECT: @areset 0 0 0 0 areset 0 0 0 0
-- Retrieval info: CONNECT: @inclk 0 0 1 1 GND 0 0 0 0
-- Retrieval info: CONNECT: @inclk 0 0 1 0 inclk0 0 0 0 0
-- Retrieval info: CONNECT: c0 0 0 0 0 @clk 0 0 1 0
-- Retrieval info: CONNECT: locked 0 0 0 0 @locked 0 0 0 0
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_III.vhd TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_III.ppf TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_III.inc FALSE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_III.cmp TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_III.bsf FALSE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_III_inst.vhd TRUE
-- Retrieval info: LIB_FILE: altera_mf
-- Retrieval info: CBX_MODULE_PREFIX: ON

View File

@@ -0,0 +1,6 @@
Video_Clock_III_inst : Video_Clock_III PORT MAP (
areset => areset_sig,
inclk0 => inclk0_sig,
c0 => c0_sig,
locked => locked_sig
);

View File

@@ -0,0 +1,7 @@
Video_Clock_II_inst : Video_Clock_II PORT MAP (
areset => areset_sig,
inclk0 => inclk0_sig,
c0 => c0_sig,
c1 => c1_sig,
locked => locked_sig
);

View File

@@ -0,0 +1,25 @@
--Copyright (C) 1991-2013 Altera Corporation
--Your use of Altera Corporation's design tools, logic functions
--and other software and tools, and its AMPP partner logic
--functions, and any output files from any of the foregoing
--(including device programming or simulation files), and any
--associated documentation or information are expressly subject
--to the terms and conditions of the Altera Program License
--Subscription Agreement, Altera MegaCore Function License
--Agreement, or other applicable license agreement, including,
--without limitation, that your use is for the sole purpose of
--programming logic devices manufactured by Altera and sold by
--Altera or its authorized distributors. Please refer to the
--applicable agreement for further details.
component Video_Clock_IV
PORT
(
areset : IN STD_LOGIC := '0';
inclk0 : IN STD_LOGIC := '0';
c0 : OUT STD_LOGIC ;
c1 : OUT STD_LOGIC ;
locked : OUT STD_LOGIC
);
end component;

View File

@@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE pinplan>
<pinplan intended_family="Cyclone III" variation_name="Video_Clock_IV" megafunction_name="ALTPLL" specifies="all_ports">
<global>
<pin name="areset" direction="input" scope="external" />
<pin name="inclk0" direction="input" scope="external" source="clock" />
<pin name="c0" direction="output" scope="external" source="clock" />
<pin name="c1" direction="output" scope="external" source="clock" />
<pin name="locked" direction="output" scope="external" />
</global>
</pinplan>

View File

@@ -0,0 +1,5 @@
set_global_assignment -name IP_TOOL_NAME "ALTPLL"
set_global_assignment -name IP_TOOL_VERSION "13.1"
set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) "Video_Clock_IV.vhd"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "Video_Clock_IV.cmp"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "Video_Clock_IV.ppf"]

View File

@@ -0,0 +1,397 @@
-- megafunction wizard: %ALTPLL%
-- GENERATION: STANDARD
-- VERSION: WM1.0
-- MODULE: altpll
-- ============================================================
-- File Name: Video_Clock_IV.vhd
-- Megafunction Name(s):
-- altpll
--
-- Simulation Library Files(s):
-- altera_mf
-- ============================================================
-- ************************************************************
-- THIS IS A WIZARD-GENERATED FILE. DO NOT EDIT THIS FILE!
--
-- 13.1.0 Build 162 10/23/2013 SJ Full Version
-- ************************************************************
--Copyright (C) 1991-2013 Altera Corporation
--Your use of Altera Corporation's design tools, logic functions
--and other software and tools, and its AMPP partner logic
--functions, and any output files from any of the foregoing
--(including device programming or simulation files), and any
--associated documentation or information are expressly subject
--to the terms and conditions of the Altera Program License
--Subscription Agreement, Altera MegaCore Function License
--Agreement, or other applicable license agreement, including,
--without limitation, that your use is for the sole purpose of
--programming logic devices manufactured by Altera and sold by
--Altera or its authorized distributors. Please refer to the
--applicable agreement for further details.
LIBRARY ieee;
USE ieee.std_logic_1164.all;
LIBRARY altera_mf;
USE altera_mf.all;
ENTITY Video_Clock_IV IS
PORT
(
areset : IN STD_LOGIC := '0';
inclk0 : IN STD_LOGIC := '0';
c0 : OUT STD_LOGIC ;
c1 : OUT STD_LOGIC ;
locked : OUT STD_LOGIC
);
END Video_Clock_IV;
ARCHITECTURE SYN OF video_clock_iv IS
SIGNAL sub_wire0 : STD_LOGIC_VECTOR (4 DOWNTO 0);
SIGNAL sub_wire1 : STD_LOGIC ;
SIGNAL sub_wire2 : STD_LOGIC ;
SIGNAL sub_wire3 : STD_LOGIC ;
SIGNAL sub_wire4 : STD_LOGIC ;
SIGNAL sub_wire5 : STD_LOGIC_VECTOR (1 DOWNTO 0);
SIGNAL sub_wire6_bv : BIT_VECTOR (0 DOWNTO 0);
SIGNAL sub_wire6 : STD_LOGIC_VECTOR (0 DOWNTO 0);
COMPONENT altpll
GENERIC (
bandwidth_type : STRING;
clk0_divide_by : NATURAL;
clk0_duty_cycle : NATURAL;
clk0_multiply_by : NATURAL;
clk0_phase_shift : STRING;
clk1_divide_by : NATURAL;
clk1_duty_cycle : NATURAL;
clk1_multiply_by : NATURAL;
clk1_phase_shift : STRING;
compensate_clock : STRING;
inclk0_input_frequency : NATURAL;
intended_device_family : STRING;
lpm_hint : STRING;
lpm_type : STRING;
operation_mode : STRING;
pll_type : STRING;
port_activeclock : STRING;
port_areset : STRING;
port_clkbad0 : STRING;
port_clkbad1 : STRING;
port_clkloss : STRING;
port_clkswitch : STRING;
port_configupdate : STRING;
port_fbin : STRING;
port_inclk0 : STRING;
port_inclk1 : STRING;
port_locked : STRING;
port_pfdena : STRING;
port_phasecounterselect : STRING;
port_phasedone : STRING;
port_phasestep : STRING;
port_phaseupdown : STRING;
port_pllena : STRING;
port_scanaclr : STRING;
port_scanclk : STRING;
port_scanclkena : STRING;
port_scandata : STRING;
port_scandataout : STRING;
port_scandone : STRING;
port_scanread : STRING;
port_scanwrite : STRING;
port_clk0 : STRING;
port_clk1 : STRING;
port_clk2 : STRING;
port_clk3 : STRING;
port_clk4 : STRING;
port_clk5 : STRING;
port_clkena0 : STRING;
port_clkena1 : STRING;
port_clkena2 : STRING;
port_clkena3 : STRING;
port_clkena4 : STRING;
port_clkena5 : STRING;
port_extclk0 : STRING;
port_extclk1 : STRING;
port_extclk2 : STRING;
port_extclk3 : STRING;
self_reset_on_loss_lock : STRING;
width_clock : NATURAL
);
PORT (
areset : IN STD_LOGIC ;
clk : OUT STD_LOGIC_VECTOR (4 DOWNTO 0);
inclk : IN STD_LOGIC_VECTOR (1 DOWNTO 0);
locked : OUT STD_LOGIC
);
END COMPONENT;
BEGIN
sub_wire6_bv(0 DOWNTO 0) <= "0";
sub_wire6 <= To_stdlogicvector(sub_wire6_bv);
sub_wire3 <= sub_wire0(0);
sub_wire1 <= sub_wire0(1);
c1 <= sub_wire1;
locked <= sub_wire2;
c0 <= sub_wire3;
sub_wire4 <= inclk0;
sub_wire5 <= sub_wire6(0 DOWNTO 0) & sub_wire4;
altpll_component : altpll
GENERIC MAP (
bandwidth_type => "LOW",
clk0_divide_by => 15625,
clk0_duty_cycle => 50,
clk0_multiply_by => 5542,
clk0_phase_shift => "0",
clk1_divide_by => 250000,
clk1_duty_cycle => 50,
clk1_multiply_by => 177343,
clk1_phase_shift => "0",
compensate_clock => "CLK0",
inclk0_input_frequency => 20000,
intended_device_family => "Cyclone III",
lpm_hint => "CBX_MODULE_PREFIX=Video_Clock_IV",
lpm_type => "altpll",
operation_mode => "NORMAL",
pll_type => "AUTO",
port_activeclock => "PORT_UNUSED",
port_areset => "PORT_USED",
port_clkbad0 => "PORT_UNUSED",
port_clkbad1 => "PORT_UNUSED",
port_clkloss => "PORT_UNUSED",
port_clkswitch => "PORT_UNUSED",
port_configupdate => "PORT_UNUSED",
port_fbin => "PORT_UNUSED",
port_inclk0 => "PORT_USED",
port_inclk1 => "PORT_UNUSED",
port_locked => "PORT_USED",
port_pfdena => "PORT_UNUSED",
port_phasecounterselect => "PORT_UNUSED",
port_phasedone => "PORT_UNUSED",
port_phasestep => "PORT_UNUSED",
port_phaseupdown => "PORT_UNUSED",
port_pllena => "PORT_UNUSED",
port_scanaclr => "PORT_UNUSED",
port_scanclk => "PORT_UNUSED",
port_scanclkena => "PORT_UNUSED",
port_scandata => "PORT_UNUSED",
port_scandataout => "PORT_UNUSED",
port_scandone => "PORT_UNUSED",
port_scanread => "PORT_UNUSED",
port_scanwrite => "PORT_UNUSED",
port_clk0 => "PORT_USED",
port_clk1 => "PORT_USED",
port_clk2 => "PORT_UNUSED",
port_clk3 => "PORT_UNUSED",
port_clk4 => "PORT_UNUSED",
port_clk5 => "PORT_UNUSED",
port_clkena0 => "PORT_UNUSED",
port_clkena1 => "PORT_UNUSED",
port_clkena2 => "PORT_UNUSED",
port_clkena3 => "PORT_UNUSED",
port_clkena4 => "PORT_UNUSED",
port_clkena5 => "PORT_UNUSED",
port_extclk0 => "PORT_UNUSED",
port_extclk1 => "PORT_UNUSED",
port_extclk2 => "PORT_UNUSED",
port_extclk3 => "PORT_UNUSED",
self_reset_on_loss_lock => "ON",
width_clock => 5
)
PORT MAP (
areset => areset,
inclk => sub_wire5,
clk => sub_wire0,
locked => sub_wire2
);
END SYN;
-- ============================================================
-- CNX file retrieval info
-- ============================================================
-- Retrieval info: PRIVATE: ACTIVECLK_CHECK STRING "0"
-- Retrieval info: PRIVATE: BANDWIDTH STRING "1.000"
-- Retrieval info: PRIVATE: BANDWIDTH_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: BANDWIDTH_FREQ_UNIT STRING "MHz"
-- Retrieval info: PRIVATE: BANDWIDTH_PRESET STRING "Low"
-- Retrieval info: PRIVATE: BANDWIDTH_USE_AUTO STRING "0"
-- Retrieval info: PRIVATE: BANDWIDTH_USE_PRESET STRING "1"
-- Retrieval info: PRIVATE: CLKBAD_SWITCHOVER_CHECK STRING "0"
-- Retrieval info: PRIVATE: CLKLOSS_CHECK STRING "0"
-- Retrieval info: PRIVATE: CLKSWITCH_CHECK STRING "0"
-- Retrieval info: PRIVATE: CNX_NO_COMPENSATE_RADIO STRING "0"
-- Retrieval info: PRIVATE: CREATE_CLKBAD_CHECK STRING "0"
-- Retrieval info: PRIVATE: CREATE_INCLK1_CHECK STRING "0"
-- Retrieval info: PRIVATE: CUR_DEDICATED_CLK STRING "c0"
-- Retrieval info: PRIVATE: CUR_FBIN_CLK STRING "c0"
-- Retrieval info: PRIVATE: DEVICE_SPEED_GRADE STRING "8"
-- Retrieval info: PRIVATE: DIV_FACTOR0 NUMERIC "1"
-- Retrieval info: PRIVATE: DIV_FACTOR1 NUMERIC "1"
-- Retrieval info: PRIVATE: DUTY_CYCLE0 STRING "50.00000000"
-- Retrieval info: PRIVATE: DUTY_CYCLE1 STRING "50.00000000"
-- Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE0 STRING "17.734400"
-- Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE1 STRING "35.468601"
-- Retrieval info: PRIVATE: EXPLICIT_SWITCHOVER_COUNTER STRING "0"
-- Retrieval info: PRIVATE: EXT_FEEDBACK_RADIO STRING "0"
-- Retrieval info: PRIVATE: GLOCKED_COUNTER_EDIT_CHANGED STRING "1"
-- Retrieval info: PRIVATE: GLOCKED_FEATURE_ENABLED STRING "0"
-- Retrieval info: PRIVATE: GLOCKED_MODE_CHECK STRING "0"
-- Retrieval info: PRIVATE: GLOCK_COUNTER_EDIT NUMERIC "1048575"
-- Retrieval info: PRIVATE: HAS_MANUAL_SWITCHOVER STRING "1"
-- Retrieval info: PRIVATE: INCLK0_FREQ_EDIT STRING "50.000"
-- Retrieval info: PRIVATE: INCLK0_FREQ_UNIT_COMBO STRING "MHz"
-- Retrieval info: PRIVATE: INCLK1_FREQ_EDIT STRING "100.000"
-- Retrieval info: PRIVATE: INCLK1_FREQ_EDIT_CHANGED STRING "1"
-- Retrieval info: PRIVATE: INCLK1_FREQ_UNIT_CHANGED STRING "1"
-- Retrieval info: PRIVATE: INCLK1_FREQ_UNIT_COMBO STRING "MHz"
-- Retrieval info: PRIVATE: INTENDED_DEVICE_FAMILY STRING "Cyclone III"
-- Retrieval info: PRIVATE: INT_FEEDBACK__MODE_RADIO STRING "1"
-- Retrieval info: PRIVATE: LOCKED_OUTPUT_CHECK STRING "1"
-- Retrieval info: PRIVATE: LONG_SCAN_RADIO STRING "1"
-- Retrieval info: PRIVATE: LVDS_MODE_DATA_RATE STRING "Not Available"
-- Retrieval info: PRIVATE: LVDS_MODE_DATA_RATE_DIRTY NUMERIC "0"
-- Retrieval info: PRIVATE: LVDS_PHASE_SHIFT_UNIT0 STRING "deg"
-- Retrieval info: PRIVATE: LVDS_PHASE_SHIFT_UNIT1 STRING "ps"
-- Retrieval info: PRIVATE: MIG_DEVICE_SPEED_GRADE STRING "Any"
-- Retrieval info: PRIVATE: MIRROR_CLK0 STRING "0"
-- Retrieval info: PRIVATE: MIRROR_CLK1 STRING "0"
-- Retrieval info: PRIVATE: MULT_FACTOR0 NUMERIC "1"
-- Retrieval info: PRIVATE: MULT_FACTOR1 NUMERIC "1"
-- Retrieval info: PRIVATE: NORMAL_MODE_RADIO STRING "1"
-- Retrieval info: PRIVATE: OUTPUT_FREQ0 STRING "17.73440000"
-- Retrieval info: PRIVATE: OUTPUT_FREQ1 STRING "35.46860000"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_MODE0 STRING "1"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_MODE1 STRING "1"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_UNIT0 STRING "MHz"
-- Retrieval info: PRIVATE: OUTPUT_FREQ_UNIT1 STRING "MHz"
-- Retrieval info: PRIVATE: PHASE_RECONFIG_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: PHASE_RECONFIG_INPUTS_CHECK STRING "0"
-- Retrieval info: PRIVATE: PHASE_SHIFT0 STRING "0.00000000"
-- Retrieval info: PRIVATE: PHASE_SHIFT1 STRING "0.00000000"
-- Retrieval info: PRIVATE: PHASE_SHIFT_STEP_ENABLED_CHECK STRING "0"
-- Retrieval info: PRIVATE: PHASE_SHIFT_UNIT0 STRING "deg"
-- Retrieval info: PRIVATE: PHASE_SHIFT_UNIT1 STRING "ps"
-- Retrieval info: PRIVATE: PLL_ADVANCED_PARAM_CHECK STRING "0"
-- Retrieval info: PRIVATE: PLL_ARESET_CHECK STRING "1"
-- Retrieval info: PRIVATE: PLL_AUTOPLL_CHECK NUMERIC "1"
-- Retrieval info: PRIVATE: PLL_ENHPLL_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PLL_FASTPLL_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PLL_FBMIMIC_CHECK STRING "0"
-- Retrieval info: PRIVATE: PLL_LVDS_PLL_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PLL_PFDENA_CHECK STRING "0"
-- Retrieval info: PRIVATE: PLL_TARGET_HARCOPY_CHECK NUMERIC "0"
-- Retrieval info: PRIVATE: PRIMARY_CLK_COMBO STRING "inclk0"
-- Retrieval info: PRIVATE: RECONFIG_FILE STRING "Video_Clock_II.mif"
-- Retrieval info: PRIVATE: SACN_INPUTS_CHECK STRING "0"
-- Retrieval info: PRIVATE: SCAN_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: SELF_RESET_LOCK_LOSS STRING "1"
-- Retrieval info: PRIVATE: SHORT_SCAN_RADIO STRING "0"
-- Retrieval info: PRIVATE: SPREAD_FEATURE_ENABLED STRING "0"
-- Retrieval info: PRIVATE: SPREAD_FREQ STRING "50.000"
-- Retrieval info: PRIVATE: SPREAD_FREQ_UNIT STRING "KHz"
-- Retrieval info: PRIVATE: SPREAD_PERCENT STRING "0.500"
-- Retrieval info: PRIVATE: SPREAD_USE STRING "0"
-- Retrieval info: PRIVATE: SRC_SYNCH_COMP_RADIO STRING "0"
-- Retrieval info: PRIVATE: STICKY_CLK0 STRING "1"
-- Retrieval info: PRIVATE: STICKY_CLK1 STRING "1"
-- Retrieval info: PRIVATE: SWITCHOVER_COUNT_EDIT NUMERIC "1"
-- Retrieval info: PRIVATE: SWITCHOVER_FEATURE_ENABLED STRING "1"
-- Retrieval info: PRIVATE: SYNTH_WRAPPER_GEN_POSTFIX STRING "0"
-- Retrieval info: PRIVATE: USE_CLK0 STRING "1"
-- Retrieval info: PRIVATE: USE_CLK1 STRING "1"
-- Retrieval info: PRIVATE: USE_CLKENA0 STRING "0"
-- Retrieval info: PRIVATE: USE_CLKENA1 STRING "0"
-- Retrieval info: PRIVATE: USE_MIL_SPEED_GRADE NUMERIC "0"
-- Retrieval info: PRIVATE: ZERO_DELAY_RADIO STRING "0"
-- Retrieval info: LIBRARY: altera_mf altera_mf.altera_mf_components.all
-- Retrieval info: CONSTANT: BANDWIDTH_TYPE STRING "LOW"
-- Retrieval info: CONSTANT: CLK0_DIVIDE_BY NUMERIC "15625"
-- Retrieval info: CONSTANT: CLK0_DUTY_CYCLE NUMERIC "50"
-- Retrieval info: CONSTANT: CLK0_MULTIPLY_BY NUMERIC "5542"
-- Retrieval info: CONSTANT: CLK0_PHASE_SHIFT STRING "0"
-- Retrieval info: CONSTANT: CLK1_DIVIDE_BY NUMERIC "250000"
-- Retrieval info: CONSTANT: CLK1_DUTY_CYCLE NUMERIC "50"
-- Retrieval info: CONSTANT: CLK1_MULTIPLY_BY NUMERIC "177343"
-- Retrieval info: CONSTANT: CLK1_PHASE_SHIFT STRING "0"
-- Retrieval info: CONSTANT: COMPENSATE_CLOCK STRING "CLK0"
-- Retrieval info: CONSTANT: INCLK0_INPUT_FREQUENCY NUMERIC "20000"
-- Retrieval info: CONSTANT: INTENDED_DEVICE_FAMILY STRING "Cyclone III"
-- Retrieval info: CONSTANT: LPM_TYPE STRING "altpll"
-- Retrieval info: CONSTANT: OPERATION_MODE STRING "NORMAL"
-- Retrieval info: CONSTANT: PLL_TYPE STRING "AUTO"
-- Retrieval info: CONSTANT: PORT_ACTIVECLOCK STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_ARESET STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_CLKBAD0 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CLKBAD1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CLKLOSS STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CLKSWITCH STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_CONFIGUPDATE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_FBIN STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_INCLK0 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_INCLK1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_LOCKED STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_PFDENA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASECOUNTERSELECT STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASEDONE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASESTEP STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PHASEUPDOWN STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_PLLENA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANACLR STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANCLK STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANCLKENA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANDATA STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANDATAOUT STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANDONE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANREAD STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_SCANWRITE STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk0 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_clk1 STRING "PORT_USED"
-- Retrieval info: CONSTANT: PORT_clk2 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk3 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk4 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clk5 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena0 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena2 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena3 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena4 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_clkena5 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk0 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk1 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk2 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: PORT_extclk3 STRING "PORT_UNUSED"
-- Retrieval info: CONSTANT: SELF_RESET_ON_LOSS_LOCK STRING "ON"
-- Retrieval info: CONSTANT: WIDTH_CLOCK NUMERIC "5"
-- Retrieval info: USED_PORT: @clk 0 0 5 0 OUTPUT_CLK_EXT VCC "@clk[4..0]"
-- Retrieval info: USED_PORT: @inclk 0 0 2 0 INPUT_CLK_EXT VCC "@inclk[1..0]"
-- Retrieval info: USED_PORT: areset 0 0 0 0 INPUT GND "areset"
-- Retrieval info: USED_PORT: c0 0 0 0 0 OUTPUT_CLK_EXT VCC "c0"
-- Retrieval info: USED_PORT: c1 0 0 0 0 OUTPUT_CLK_EXT VCC "c1"
-- Retrieval info: USED_PORT: inclk0 0 0 0 0 INPUT_CLK_EXT GND "inclk0"
-- Retrieval info: USED_PORT: locked 0 0 0 0 OUTPUT GND "locked"
-- Retrieval info: CONNECT: @areset 0 0 0 0 areset 0 0 0 0
-- Retrieval info: CONNECT: @inclk 0 0 1 1 GND 0 0 0 0
-- Retrieval info: CONNECT: @inclk 0 0 1 0 inclk0 0 0 0 0
-- Retrieval info: CONNECT: c0 0 0 0 0 @clk 0 0 1 0
-- Retrieval info: CONNECT: c1 0 0 0 0 @clk 0 0 1 1
-- Retrieval info: CONNECT: locked 0 0 0 0 @locked 0 0 0 0
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_IV.vhd TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_IV.ppf TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_IV.inc FALSE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_IV.cmp TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_IV.bsf FALSE
-- Retrieval info: GEN_FILE: TYPE_NORMAL Video_Clock_IV_inst.vhd FALSE
-- Retrieval info: LIB_FILE: altera_mf
-- Retrieval info: CBX_MODULE_PREFIX: ON

View File

@@ -0,0 +1,10 @@
Video_Clock_inst : Video_Clock PORT MAP (
areset => areset_sig,
inclk0 => inclk0_sig,
c0 => c0_sig,
c1 => c1_sig,
c2 => c2_sig,
c3 => c3_sig,
c4 => c4_sig,
locked => locked_sig
);

29
FPGA/build/vbuffer.cmp Normal file
View File

@@ -0,0 +1,29 @@
--Copyright (C) 1991-2013 Altera Corporation
--Your use of Altera Corporation's design tools, logic functions
--and other software and tools, and its AMPP partner logic
--functions, and any output files from any of the foregoing
--(including device programming or simulation files), and any
--associated documentation or information are expressly subject
--to the terms and conditions of the Altera Program License
--Subscription Agreement, Altera MegaCore Function License
--Agreement, or other applicable license agreement, including,
--without limitation, that your use is for the sole purpose of
--programming logic devices manufactured by Altera and sold by
--Altera or its authorized distributors. Please refer to the
--applicable agreement for further details.
component vbuffer
PORT
(
aclr : IN STD_LOGIC := '0';
data : IN STD_LOGIC_VECTOR (7 DOWNTO 0);
rdclk : IN STD_LOGIC ;
rdreq : IN STD_LOGIC ;
wrclk : IN STD_LOGIC ;
wrreq : IN STD_LOGIC ;
q : OUT STD_LOGIC_VECTOR (7 DOWNTO 0);
rdempty : OUT STD_LOGIC ;
wrfull : OUT STD_LOGIC
);
end component;

5
FPGA/build/vbuffer.qip Normal file
View File

@@ -0,0 +1,5 @@
set_global_assignment -name IP_TOOL_NAME "FIFO"
set_global_assignment -name IP_TOOL_VERSION "13.1"
set_global_assignment -name VHDL_FILE [file join $::quartus(qip_path) "vbuffer.vhd"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "vbuffer_inst.vhd"]
set_global_assignment -name MISC_FILE [file join $::quartus(qip_path) "vbuffer.cmp"]

204
FPGA/build/vbuffer.vhd Normal file
View File

@@ -0,0 +1,204 @@
-- megafunction wizard: %FIFO%
-- GENERATION: STANDARD
-- VERSION: WM1.0
-- MODULE: dcfifo
-- ============================================================
-- File Name: vbuffer.vhd
-- Megafunction Name(s):
-- dcfifo
--
-- Simulation Library Files(s):
-- altera_mf
-- ============================================================
-- ************************************************************
-- THIS IS A WIZARD-GENERATED FILE. DO NOT EDIT THIS FILE!
--
-- 13.1.0 Build 162 10/23/2013 SJ Full Version
-- ************************************************************
--Copyright (C) 1991-2013 Altera Corporation
--Your use of Altera Corporation's design tools, logic functions
--and other software and tools, and its AMPP partner logic
--functions, and any output files from any of the foregoing
--(including device programming or simulation files), and any
--associated documentation or information are expressly subject
--to the terms and conditions of the Altera Program License
--Subscription Agreement, Altera MegaCore Function License
--Agreement, or other applicable license agreement, including,
--without limitation, that your use is for the sole purpose of
--programming logic devices manufactured by Altera and sold by
--Altera or its authorized distributors. Please refer to the
--applicable agreement for further details.
LIBRARY ieee;
USE ieee.std_logic_1164.all;
LIBRARY altera_mf;
USE altera_mf.all;
ENTITY vbuffer IS
PORT
(
aclr : IN STD_LOGIC := '0';
data : IN STD_LOGIC_VECTOR (7 DOWNTO 0);
rdclk : IN STD_LOGIC ;
rdreq : IN STD_LOGIC ;
wrclk : IN STD_LOGIC ;
wrreq : IN STD_LOGIC ;
q : OUT STD_LOGIC_VECTOR (7 DOWNTO 0);
rdempty : OUT STD_LOGIC ;
wrfull : OUT STD_LOGIC
);
END vbuffer;
ARCHITECTURE SYN OF vbuffer IS
SIGNAL sub_wire0 : STD_LOGIC ;
SIGNAL sub_wire1 : STD_LOGIC_VECTOR (7 DOWNTO 0);
SIGNAL sub_wire2 : STD_LOGIC ;
COMPONENT dcfifo
GENERIC (
intended_device_family : STRING;
lpm_numwords : NATURAL;
lpm_showahead : STRING;
lpm_type : STRING;
lpm_width : NATURAL;
lpm_widthu : NATURAL;
overflow_checking : STRING;
rdsync_delaypipe : NATURAL;
read_aclr_synch : STRING;
underflow_checking : STRING;
use_eab : STRING;
write_aclr_synch : STRING;
wrsync_delaypipe : NATURAL
);
PORT (
rdclk : IN STD_LOGIC ;
wrfull : OUT STD_LOGIC ;
q : OUT STD_LOGIC_VECTOR (7 DOWNTO 0);
rdempty : OUT STD_LOGIC ;
wrclk : IN STD_LOGIC ;
wrreq : IN STD_LOGIC ;
aclr : IN STD_LOGIC ;
data : IN STD_LOGIC_VECTOR (7 DOWNTO 0);
rdreq : IN STD_LOGIC
);
END COMPONENT;
BEGIN
wrfull <= sub_wire0;
q <= sub_wire1(7 DOWNTO 0);
rdempty <= sub_wire2;
dcfifo_component : dcfifo
GENERIC MAP (
intended_device_family => "Cyclone III",
lpm_numwords => 8192,
lpm_showahead => "ON",
lpm_type => "dcfifo",
lpm_width => 8,
lpm_widthu => 13,
overflow_checking => "OFF",
rdsync_delaypipe => 3,
read_aclr_synch => "OFF",
underflow_checking => "OFF",
use_eab => "ON",
write_aclr_synch => "OFF",
wrsync_delaypipe => 3
)
PORT MAP (
rdclk => rdclk,
wrclk => wrclk,
wrreq => wrreq,
aclr => aclr,
data => data,
rdreq => rdreq,
wrfull => sub_wire0,
q => sub_wire1,
rdempty => sub_wire2
);
END SYN;
-- ============================================================
-- CNX file retrieval info
-- ============================================================
-- Retrieval info: PRIVATE: AlmostEmpty NUMERIC "0"
-- Retrieval info: PRIVATE: AlmostEmptyThr NUMERIC "-1"
-- Retrieval info: PRIVATE: AlmostFull NUMERIC "0"
-- Retrieval info: PRIVATE: AlmostFullThr NUMERIC "-1"
-- Retrieval info: PRIVATE: CLOCKS_ARE_SYNCHRONIZED NUMERIC "0"
-- Retrieval info: PRIVATE: Clock NUMERIC "4"
-- Retrieval info: PRIVATE: Depth NUMERIC "4096"
-- Retrieval info: PRIVATE: Empty NUMERIC "1"
-- Retrieval info: PRIVATE: Full NUMERIC "1"
-- Retrieval info: PRIVATE: INTENDED_DEVICE_FAMILY STRING "Cyclone III"
-- Retrieval info: PRIVATE: LE_BasedFIFO NUMERIC "0"
-- Retrieval info: PRIVATE: LegacyRREQ NUMERIC "0"
-- Retrieval info: PRIVATE: MAX_DEPTH_BY_9 NUMERIC "0"
-- Retrieval info: PRIVATE: OVERFLOW_CHECKING NUMERIC "1"
-- Retrieval info: PRIVATE: Optimize NUMERIC "2"
-- Retrieval info: PRIVATE: RAM_BLOCK_TYPE NUMERIC "0"
-- Retrieval info: PRIVATE: SYNTH_WRAPPER_GEN_POSTFIX STRING "0"
-- Retrieval info: PRIVATE: UNDERFLOW_CHECKING NUMERIC "1"
-- Retrieval info: PRIVATE: UsedW NUMERIC "1"
-- Retrieval info: PRIVATE: Width NUMERIC "8"
-- Retrieval info: PRIVATE: dc_aclr NUMERIC "1"
-- Retrieval info: PRIVATE: diff_widths NUMERIC "0"
-- Retrieval info: PRIVATE: msb_usedw NUMERIC "0"
-- Retrieval info: PRIVATE: output_width NUMERIC "8"
-- Retrieval info: PRIVATE: rsEmpty NUMERIC "1"
-- Retrieval info: PRIVATE: rsFull NUMERIC "0"
-- Retrieval info: PRIVATE: rsUsedW NUMERIC "0"
-- Retrieval info: PRIVATE: sc_aclr NUMERIC "0"
-- Retrieval info: PRIVATE: sc_sclr NUMERIC "0"
-- Retrieval info: PRIVATE: wsEmpty NUMERIC "0"
-- Retrieval info: PRIVATE: wsFull NUMERIC "1"
-- Retrieval info: PRIVATE: wsUsedW NUMERIC "0"
-- Retrieval info: LIBRARY: altera_mf altera_mf.altera_mf_components.all
-- Retrieval info: CONSTANT: INTENDED_DEVICE_FAMILY STRING "Cyclone III"
-- Retrieval info: CONSTANT: LPM_NUMWORDS NUMERIC "4096"
-- Retrieval info: CONSTANT: LPM_SHOWAHEAD STRING "ON"
-- Retrieval info: CONSTANT: LPM_TYPE STRING "dcfifo"
-- Retrieval info: CONSTANT: LPM_WIDTH NUMERIC "8"
-- Retrieval info: CONSTANT: LPM_WIDTHU NUMERIC "12"
-- Retrieval info: CONSTANT: OVERFLOW_CHECKING STRING "OFF"
-- Retrieval info: CONSTANT: RDSYNC_DELAYPIPE NUMERIC "5"
-- Retrieval info: CONSTANT: READ_ACLR_SYNCH STRING "OFF"
-- Retrieval info: CONSTANT: UNDERFLOW_CHECKING STRING "OFF"
-- Retrieval info: CONSTANT: USE_EAB STRING "ON"
-- Retrieval info: CONSTANT: WRITE_ACLR_SYNCH STRING "OFF"
-- Retrieval info: CONSTANT: WRSYNC_DELAYPIPE NUMERIC "5"
-- Retrieval info: USED_PORT: aclr 0 0 0 0 INPUT GND "aclr"
-- Retrieval info: USED_PORT: data 0 0 8 0 INPUT NODEFVAL "data[7..0]"
-- Retrieval info: USED_PORT: q 0 0 8 0 OUTPUT NODEFVAL "q[7..0]"
-- Retrieval info: USED_PORT: rdclk 0 0 0 0 INPUT NODEFVAL "rdclk"
-- Retrieval info: USED_PORT: rdempty 0 0 0 0 OUTPUT NODEFVAL "rdempty"
-- Retrieval info: USED_PORT: rdreq 0 0 0 0 INPUT NODEFVAL "rdreq"
-- Retrieval info: USED_PORT: wrclk 0 0 0 0 INPUT NODEFVAL "wrclk"
-- Retrieval info: USED_PORT: wrfull 0 0 0 0 OUTPUT NODEFVAL "wrfull"
-- Retrieval info: USED_PORT: wrreq 0 0 0 0 INPUT NODEFVAL "wrreq"
-- Retrieval info: CONNECT: @aclr 0 0 0 0 aclr 0 0 0 0
-- Retrieval info: CONNECT: @data 0 0 8 0 data 0 0 8 0
-- Retrieval info: CONNECT: @rdclk 0 0 0 0 rdclk 0 0 0 0
-- Retrieval info: CONNECT: @rdreq 0 0 0 0 rdreq 0 0 0 0
-- Retrieval info: CONNECT: @wrclk 0 0 0 0 wrclk 0 0 0 0
-- Retrieval info: CONNECT: @wrreq 0 0 0 0 wrreq 0 0 0 0
-- Retrieval info: CONNECT: q 0 0 8 0 @q 0 0 8 0
-- Retrieval info: CONNECT: rdempty 0 0 0 0 @rdempty 0 0 0 0
-- Retrieval info: CONNECT: wrfull 0 0 0 0 @wrfull 0 0 0 0
-- Retrieval info: GEN_FILE: TYPE_NORMAL vbuffer.vhd TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL vbuffer.inc FALSE
-- Retrieval info: GEN_FILE: TYPE_NORMAL vbuffer.cmp TRUE
-- Retrieval info: GEN_FILE: TYPE_NORMAL vbuffer.bsf FALSE
-- Retrieval info: GEN_FILE: TYPE_NORMAL vbuffer_inst.vhd TRUE
-- Retrieval info: LIB_FILE: altera_mf

View File

@@ -0,0 +1,11 @@
vbuffer_inst : vbuffer PORT MAP (
aclr => aclr_sig,
data => data_sig,
rdclk => rdclk_sig,
rdreq => rdreq_sig,
wrclk => wrclk_sig,
wrreq => wrreq_sig,
q => q_sig,
rdempty => rdempty_sig,
wrfull => wrfull_sig
);

View File

@@ -0,0 +1,173 @@
#########################################################################################################
##
## Name: Dockerfile.13.0.1
## Created: June 2020
## Author(s): Philip Smart
## Description: A Docker build script to create an Ubuntu 16.04 OS with Quartus Prime 13.0.1
##
## Credits:
## Copyright: (c) 2019 Philip Smart <philip.smart@net2net.org>
##
## History: August 2019 - Initial module written.
## June 2020 - Need to use a CPLD MAX series device which is only supported in
## Quartus 13.
##
#########################################################################################################
## This source file 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 source file 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/>.
#########################################################################################################
# Ubuntu 16.04 as the base.
FROM ubuntu:xenial
# Maintainer!
MAINTAINER Philip Smart <philip.smart@net2net.org>
# Set build time environment variables.
ENV DEBIAN_FRONTEND=noninteractive
# Set constants for the build, more simpler to adjust these than the script if you want to change Quartus version.
# Uncomment one of the QUARTUS= arguments below depending on wether your using the LITE or STANDARD version of Quartus.
ARG TARGET_DOWNLOAD_DIR=/tmp/
ARG INSTALLATION_DIR=/opt/altera
ARG ALTERA_DOWNLOAD_SITE=http://download.altera.com/akdlm/software/acdsinst
ARG QUARTUS_VERSION_INSTALLER=/13.0sp1/232/ib_installers/
#ARG QUARTUS_VERSION_UPDATE=/13.0.1/232/update/
#ARG QUARTUS=QuartusSetup-13.0.1.232.run
ARG QUARTUS=QuartusSetupWeb-13.0.1.232.run
#ARG QUARTUS_UPDATE=QuartusSetup-13.0.1.232.run
ARG QUARTUS_PROGRAMMER=QuartusProgrammerSetup-13.0.1.232.run
ARG QUARTUS_HELP=QuartusHelpSetup-13.0.1.232.run
ARG QUARTUS_LINUX_SUPPORT_BIN=linux-socfpga-13.02-RC10-bin.tar.gz
ARG QUARTUS_LINUX_SUPPORT_SRC=linux-socfpga-13.02-RC10-src.bsx
ARG QUARTUS_DEVICE_FILES="arria_web-13.0.1.232.qdz cyclonev-13.0.1.232.qdz cyclone_web-13.0.1.232.qdz cyclone-13.0.1.232.qdz max-13.0.1.232.qdz"
# Base Ubuntu install, add necessary packages for Quartus, command line editting and web-browser.
RUN dpkg --add-architecture i386
RUN apt-get update
RUN apt-get install --no-install-recommends -y \
ca-certificates \
libstdc++6:i386 \
libc6:i386 \
libx11-dev:i386 \
libxext-dev:i386 \
libxau-dev:i386 \
libxdmcp-dev:i386 \
libfreetype6:i386 \
libxtst6:i386 \
libxi6:i386 \
fontconfig:i386 \
expat:i386 \
lib32ncurses5-dev \
libc6:i386 \
libcrypto++9v5 \
libfontconfig1 \
libglib2.0-0 \
libncurses5:i386 \
libsm6 \
libsm6:i386 \
libssl-dev \
libstdc++6:i386 \
libxext6:i386 \
libxft2:i386 \
libxrender1 \
libzmq3-dev \
libxext6:i386 \
libxrender-dev:i386 \
locales \
make \
openjdk-8-jdk \
pkg-config \
unixodbc-dev \
wget \
xauth \
xvfb \
net-tools \
x11-apps \
aptitude \
vim \
sudo \
firefox
# Setup environment defaults.
RUN echo "en_US.UTF-8 UTF-8" >> /etc/locale.gen && locale-gen
ENV LANG en_US.UTF-8
ENV LANGUAGE en_US:en
ENV LC_ALL en_US.UTF-8
ENV EXEC_DIR ${INSTALLATION_DIR}
#
# UNCOMMENT PRODUCTION OR DEVELOPMENT ACCORDING TO REQUIREMENTS.
#
# PRODUCTION CYCLE, fetch files from Altera as needed.
RUN echo "Fetching ${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS}"
RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS}
#RUN echo "Fetching ${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_UPDATE}"
#RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_UPDATE}/${QUARTUS_UPDATE}
RUN echo "Fetching ${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_PROGRAMMER}"
RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_PROGRAMMER}
RUN echo "Fetching ${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_HELP}"
RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_HELP}
RUN echo "Fetching ${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_LINUX_SUPPORT_BIN}"
RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_LINUX_SUPPORT_BIN}
RUN echo "Fetching ${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_LINUX_SUPPORT_SRC}"
RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_LINUX_SUPPORT_SRC}
RUN for DEVICE_FILE in ${QUARTUS_DEVICE_FILES}; \
do \
echo "Fetching ${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${DEVICE_FILE}"; \
wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${DEVICE_FILE}; \
done
# DEVELOPMENT CYCLE, quartus files cached locally.
#COPY ./files/13.0/*.qdz ${TARGET_DOWNLOAD_DIR}
#COPY ./files/13.0/*.run ${TARGET_DOWNLOAD_DIR}
# Install Quartus.
RUN chmod +x ${TARGET_DOWNLOAD_DIR}${QUARTUS}
#RUN chmod +x ${TARGET_DOWNLOAD_DIR}${QUARTUS_UPDATE}
RUN chmod +x ${TARGET_DOWNLOAD_DIR}${QUARTUS_PROGRAMMER}
RUN chmod +x ${TARGET_DOWNLOAD_DIR}${QUARTUS_HELP}
RUN ${TARGET_DOWNLOAD_DIR}${QUARTUS} --mode unattended --installdir ${INSTALLATION_DIR}/ #--accept_eula 1
#RUN ${TARGET_DOWNLOAD_DIR}${QUARTUS_UPDATE} --mode unattended --installdir ${INSTALLATION_DIR}/ #--accept_eula 1
RUN ${TARGET_DOWNLOAD_DIR}${QUARTUS_PROGRAMMER} --mode unattended --installdir ${INSTALLATION_DIR}/ #--accept_eula 1
RUN ${TARGET_DOWNLOAD_DIR}${QUARTUS_HELP} --mode unattended --installdir ${INSTALLATION_DIR}/ #--accept_eula 1
# Copy the license file, this would be a dummy for the Lite version or a genuine one for the Standard version coded to the host
# MAC Address.
COPY ./files/license.dat ${INSTALLATION_DIR}/
# Copy quartus config files to enable the license.
COPY ./files/quartus2.* /root/.altera.quartus/
COPY ./files/quartus_web_rules_file.txt /root/.altera.quartus/
# Copy the Arrow USB Blaster and setup the udev rules to detect and mount USB-Blaster I and II devices.
COPY ./files/libjtag_hw_arrow.so ${INSTALLATION_DIR}/quartus/linux64/
COPY ./files/70-usb.rules /etc/udev/rules.d/
# Setup necessary environment variables.
RUN echo "export PATH=\$PATH:${INSTALLATION_DIR}/quartus/bin:${INSTALLATION_DIR}/qprogrammer/bin" >> /root/.bashrc
RUN echo "export LM_LICENSE_FILE=${INSTALLATION_DIR}/license.dat" >> /root/.bashrc
# Clean up, removing unnecessary installation files.
RUN rm -rf ${TARGET_DOWNLOAD_DIR}/* ${INSTALLATION_DIR}/uninstall ${INSTALLATION_DIR}/logs/*
# Add the current user into the image.
ARG user_uid
ARG user_gid
ARG user_name
RUN groupadd -g $user_uid $user_name
RUN adduser --uid $user_uid --gid $user_gid --disabled-password --gecos $user_name --home /home/$user_name $user_name
# Start Quartus
CMD ${EXEC_DIR}/quartus/bin/quartus --64bit

View File

@@ -0,0 +1,168 @@
#########################################################################################################
##
## Name: Dockerfile.13.1.1
## Created: June 2020
## Author(s): Philip Smart
## Description: A Docker build script to create an Ubuntu 16.04 OS with Quartus Prime 13.1
##
## Credits:
## Copyright: (c) 2019 Philip Smart <philip.smart@net2net.org>
##
## History: August 2019 - Initial module written.
## June 2020 - Need to use a CPLD MAX series device which is only supported in
## Quartus 13.
##
#########################################################################################################
## This source file 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 source file 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/>.
#########################################################################################################
# Ubuntu 16.04 as the base.
FROM ubuntu:xenial
# Maintainer!
MAINTAINER Philip Smart <philip.smart@net2net.org>
# Set build time environment variables.
ENV DEBIAN_FRONTEND=noninteractive
# Set constants for the build, more simpler to adjust these than the script if you want to change Quartus version.
# Uncomment one of the QUARTUS= arguments below depending on wether your using the LITE or STANDARD version of Quartus.
ARG TARGET_DOWNLOAD_DIR=/tmp/
ARG INSTALLATION_DIR=/opt/altera
ARG ALTERA_DOWNLOAD_SITE=http://download.altera.com/akdlm/software/acdsinst
ARG QUARTUS_VERSION_INSTALLER=/13.1/162/ib_installers/
ARG QUARTUS_VERSION_UPDATE=/13.1.0/162/update/
ARG QUARTUS=QuartusSetup-13.1.0.162.run
#ARG QUARTUS=QuartusLiteSetup-13.1.0.162.run
ARG QUARTUS_UPDATE=QuartusSetup-13.1.0.162.run
ARG QUARTUS_PROGRAMMER=QuartusProgrammerSetup-13.1.0.162.run
ARG QUARTUS_HELP=QuartusHelpSetup-13.1.0.162.run
ARG QUARTUS_DEVICE_FILES="arria-13.1.0.162 arriav-13.1.0.162 arriavgz-13.1.0.162 arria_web-13.1.0.162 cyclone-13.1.0.162 cyclonev-13.1.0.162 cyclone_web-13.1.0.162 max-13.1.0.162 max-17.1.0.590 max_web-13.1.0.162 stratixv-13.1.0.162"
# Base Ubuntu install, add necessary packages for Quartus, command line editting and web-browser.
RUN dpkg --add-architecture i386
RUN apt-get update
RUN apt-get install --no-install-recommends -y \
ca-certificates \
libstdc++6:i386 \
libc6:i386 \
libx11-dev:i386 \
libxext-dev:i386 \
libxau-dev:i386 \
libxdmcp-dev:i386 \
libfreetype6:i386 \
libxtst6:i386 \
libxi6:i386 \
fontconfig:i386 \
expat:i386 \
lib32ncurses5-dev \
libc6:i386 \
libcrypto++9v5 \
libfontconfig1 \
libglib2.0-0 \
libncurses5:i386 \
libsm6 \
libsm6:i386 \
libssl-dev \
libstdc++6:i386 \
libxext6:i386 \
libxft2:i386 \
libxrender1 \
libzmq3-dev \
libxext6:i386 \
libxrender-dev:i386 \
locales \
make \
openjdk-8-jdk \
pkg-config \
unixodbc-dev \
wget \
xauth \
xvfb \
net-tools \
x11-apps \
aptitude \
vim \
sudo \
firefox
# Setup environment defaults.
RUN echo "en_US.UTF-8 UTF-8" >> /etc/locale.gen && locale-gen
ENV LANG en_US.UTF-8
ENV LANGUAGE en_US:en
ENV LC_ALL en_US.UTF-8
ENV EXEC_DIR ${INSTALLATION_DIR}
#
# UNCOMMENT PRODUCTION OR DEVELOPMENT ACCORDING TO REQUIREMENTS.
#
# PRODUCTION CYCLE, fetch files from Altera as needed.
RUN echo "Fetching ${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS}"
RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS}
#RUN echo "Fetching ${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_UPDATE}"
#RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_UPDATE}/${QUARTUS_UPDATE}
RUN echo "Fetching ${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_PROGRAMMER}"
RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_PROGRAMMER}
RUN echo "Fetching ${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_HELP}"
RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_HELP}
RUN for DEVICE_FILE in ${QUARTUS_DEVICE_FILES}; \
do \
echo "Fetching ${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${DEVICE_FILE}"; \
wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${DEVICE_FILE}; \
done
# DEVELOPMENT CYCLE, quartus files cached locally.
#COPY ./files/13.1/*.qdz ${TARGET_DOWNLOAD_DIR}
#COPY ./files/13.1/*.run ${TARGET_DOWNLOAD_DIR}
# Install Quartus.
RUN chmod +x ${TARGET_DOWNLOAD_DIR}${QUARTUS}
#RUN chmod +x ${TARGET_DOWNLOAD_DIR}${QUARTUS_UPDATE}
RUN chmod +x ${TARGET_DOWNLOAD_DIR}${QUARTUS_PROGRAMMER}
RUN chmod +x ${TARGET_DOWNLOAD_DIR}${QUARTUS_HELP}
RUN ${TARGET_DOWNLOAD_DIR}${QUARTUS} --mode unattended --installdir ${INSTALLATION_DIR}/ #--accept_eula 1
#RUN ${TARGET_DOWNLOAD_DIR}${QUARTUS_UPDATE} --mode unattended --installdir ${INSTALLATION_DIR}/ #--accept_eula 1
RUN ${TARGET_DOWNLOAD_DIR}${QUARTUS_PROGRAMMER} --mode unattended --installdir ${INSTALLATION_DIR}/ #--accept_eula 1
RUN ${TARGET_DOWNLOAD_DIR}${QUARTUS_HELP} --mode unattended --installdir ${INSTALLATION_DIR}/ #--accept_eula 1
# Copy the license file, this would be a dummy for the Lite version or a genuine one for the Standard version coded to the host
# MAC Address.
COPY ./files/license.dat ${INSTALLATION_DIR}/
# Copy quartus config files to enable the license.
COPY ./files/quartus2.* /root/.altera.quartus/
COPY ./files/quartus_web_rules_file.txt /root/.altera.quartus/
# Copy the Arrow USB Blaster and setup the udev rules to detect and mount USB-Blaster I and II devices.
COPY ./files/libjtag_hw_arrow.so ${INSTALLATION_DIR}/quartus/linux64/
COPY ./files/70-usb.rules /etc/udev/rules.d/
# Setup necessary environment variables.
RUN echo "export PATH=\$PATH:${INSTALLATION_DIR}/quartus/bin:${INSTALLATION_DIR}/qprogrammer/bin" >> /root/.bashrc
RUN echo "export LM_LICENSE_FILE=${INSTALLATION_DIR}/license.dat" >> /root/.bashrc
# Clean up, removing unnecessary installation files.
RUN rm -rf ${TARGET_DOWNLOAD_DIR}/* ${INSTALLATION_DIR}/uninstall ${INSTALLATION_DIR}/logs/*
# Add the current user into the image.
ARG user_uid
ARG user_gid
ARG user_name
RUN groupadd -g $user_uid $user_name
RUN adduser --uid $user_uid --gid $user_gid --disabled-password --gecos $user_name --home /home/$user_name $user_name
# Start Quartus
CMD ${EXEC_DIR}/quartus/bin/quartus --64bit

View File

@@ -0,0 +1,167 @@
#########################################################################################################
##
## Name: Dockerfile.17.1.1
## Created: August 2019
## Author(s): Philip Smart
## Description: A Docker build script to create an Ubuntu 16.04 OS with Quartus Prime 17.1.1
##
## Credits:
## Copyright: (c) 2019 Philip Smart <philip.smart@net2net.org>
##
## History: August 2019 - Initial module written.
##
#########################################################################################################
## This source file 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 source file 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/>.
#########################################################################################################
# Ubuntu 16.04 as the base.
FROM ubuntu:xenial
# Maintainer!
MAINTAINER Philip Smart <philip.smart@net2net.org>
# Set build time environment variables.
ENV DEBIAN_FRONTEND=noninteractive
# Set constants for the build, more simpler to adjust these than the script if you want to change Quartus version.
# Uncomment one of the QUARTUS= arguments below depending on wether your using the LITE or STANDARD version of Quartus.
ARG TARGET_DOWNLOAD_DIR=/tmp/
ARG INSTALLATION_DIR=/opt/altera
ARG ALTERA_DOWNLOAD_SITE=http://download.altera.com/akdlm/software/acdsinst
ARG QUARTUS_VERSION_INSTALLER=/17.1std/590/ib_installers/
ARG QUARTUS_VERSION_UPDATE=/17.1std.1/593/update/
ARG QUARTUS=QuartusSetup-17.1.0.590-linux.run
#ARG QUARTUS=QuartusLiteSetup-17.1.0.590-linux.run
ARG QUARTUS_UPDATE=QuartusSetup-17.1.1.593-linux.run
ARG QUARTUS_PROGRAMMER=QuartusProgrammerSetup-17.1.0.590-linux.run
ARG QUARTUS_HELP=QuartusHelpSetup-17.1.0.590-linux.run
ARG QUARTUS_DEVICE_FILES="arria_lite-17.1.0.590.qdz cyclone10lp-17.1.0.590.qdz cyclone-17.1.0.590.qdz cyclonev-17.1.0.590.qdz max10-17.1.0.590.qdz max-17.1.0.590.qdz"
# Base Ubuntu install, add necessary packages for Quartus, command line editting and web-browser.
RUN dpkg --add-architecture i386
RUN apt-get update
RUN apt-get install --no-install-recommends -y \
ca-certificates \
libstdc++6:i386 \
libc6:i386 \
libx11-dev:i386 \
libxext-dev:i386 \
libxau-dev:i386 \
libxdmcp-dev:i386 \
libfreetype6:i386 \
libxtst6:i386 \
libxi6:i386 \
fontconfig:i386 \
expat:i386 \
lib32ncurses5-dev \
libc6:i386 \
libcrypto++9v5 \
libfontconfig1 \
libglib2.0-0 \
libncurses5:i386 \
libsm6 \
libsm6:i386 \
libssl-dev \
libstdc++6:i386 \
libxext6:i386 \
libxft2:i386 \
libxrender1 \
libzmq3-dev \
libxext6:i386 \
libxrender-dev:i386 \
locales \
make \
openjdk-8-jdk \
pkg-config \
unixodbc-dev \
wget \
xauth \
xvfb \
net-tools \
x11-apps \
aptitude \
vim \
sudo \
firefox
# Setup environment defaults.
RUN echo "en_US.UTF-8 UTF-8" >> /etc/locale.gen && locale-gen
ENV LANG en_US.UTF-8
ENV LANGUAGE en_US:en
ENV LC_ALL en_US.UTF-8
ENV EXEC_DIR ${INSTALLATION_DIR}
#
# UNCOMMENT PRODUCTION OR DEVELOPMENT ACCORDING TO REQUIREMENTS.
#
# PRODUCTION CYCLE, fetch files from Altera as needed.
#RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS}
#RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_UPDATE}/${QUARTUS_UPDATE}
#RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_PROGRAMMER}
#RUN wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${QUARTUS_HELP}
#RUN for DEVICE_FILE in ${QUARTUS_DEVICE_FILES}; \
# do \
# echo "Fetching ${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${DEVICE_FILE}"; \
# wget -q --directory-prefix=${TARGET_DOWNLOAD_DIR} ${ALTERA_DOWNLOAD_SITE}/${QUARTUS_VERSION_INSTALLER}/${DEVICE_FILE}; \
# done
# DEVELOPMENT CYCLE, quartus files cached locally.
COPY ./files/17.1/*.qdz ${TARGET_DOWNLOAD_DIR}
COPY ./files/17.1/*.run ${TARGET_DOWNLOAD_DIR}
# Install Quartus.
RUN chmod +x ${TARGET_DOWNLOAD_DIR}${QUARTUS}
RUN chmod +x ${TARGET_DOWNLOAD_DIR}${QUARTUS_UPDATE}
RUN chmod +x ${TARGET_DOWNLOAD_DIR}${QUARTUS_PROGRAMMER}
RUN chmod +x ${TARGET_DOWNLOAD_DIR}${QUARTUS_HELP}
RUN ${TARGET_DOWNLOAD_DIR}${QUARTUS} --mode unattended --installdir ${INSTALLATION_DIR}/ --accept_eula 1
RUN ${TARGET_DOWNLOAD_DIR}${QUARTUS_UPDATE} --mode unattended --installdir ${INSTALLATION_DIR}/ --accept_eula 1
RUN ${TARGET_DOWNLOAD_DIR}${QUARTUS_PROGRAMMER} --mode unattended --installdir ${INSTALLATION_DIR}/ --accept_eula 1
RUN ${TARGET_DOWNLOAD_DIR}${QUARTUS_HELP} --mode unattended --installdir ${INSTALLATION_DIR}/ --accept_eula 1
# Copy the license file, this would be a dummy for the Lite version or a genuine one for the Standard version coded to the host
# MAC Address.
COPY ./files/license.dat ${INSTALLATION_DIR}/
# Copy quartus config files to enable the license.
COPY ./files/quartus2.* /root/.altera.quartus/
COPY ./files/quartus_web_rules_file.txt /root/.altera.quartus/
# Copy the Arrow USB Blaster and setup the udev rules to detect and mount USB-Blaster I and II devices.
COPY ./files/libjtag_hw_arrow.so ${INSTALLATION_DIR}/quartus/linux64/
COPY ./files/70-usb.rules /etc/udev/rules.d/
# Local upgrades.
COPY local/17.1/license.dat ${INSTALLATION_DIR}/
COPY local/17.1/libsys_cpt.so ${INSTALLATION_DIR}/quartus/linux64/
COPY local/17.1/libgcl_afcq.so ${INSTALLATION_DIR}/quartus/linux64/
# Setup necessary environment variables.
RUN echo "export PATH=\$PATH:${INSTALLATION_DIR}/quartus/bin:${INSTALLATION_DIR}/qprogrammer/bin" >> /root/.bashrc
RUN echo "export LM_LICENSE_FILE=${INSTALLATION_DIR}/license.dat" >> /root/.bashrc
# Clean up, removing unnecessary installation files.
RUN rm -rf ${TARGET_DOWNLOAD_DIR}/* ${INSTALLATION_DIR}/uninstall ${INSTALLATION_DIR}/logs/*
#
# Add the current user into the image.
ARG user_uid
ARG user_gid
ARG user_name
RUN groupadd -g $user_uid $user_name
RUN adduser --uid $user_uid --gid $user_gid --disabled-password --gecos $user_name --home /home/$user_name $user_name
# Start Quartus
CMD ${EXEC_DIR}/quartus/bin/quartus --64bit

View File

@@ -0,0 +1,13 @@
===
# USB-Blaster
SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", ATTRS{idVendor}=="09fb", ATTRS{idProduct}=="6001", MODE="0666", SYMLINK+="usbblaster/%k"
SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", ATTRS{idVendor}=="09fb", ATTRS{idProduct}=="6002", MODE="0666", SYMLINK+="usbblaster/%k"
SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", ATTRS{idVendor}=="09fb", ATTRS{idProduct}=="6003", MODE="0666", SYMLINK+="usbblaster/%k"
# USB-Blaster II
SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", ATTRS{idVendor}=="09fb", ATTRS{idProduct}=="6010", MODE="0666", SYMLINK+="usbblaster2/%k"
SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", ATTRS{idVendor}=="09fb", ATTRS{idProduct}=="6810", MODE="0666", SYMLINK+="usbblaster2/%k"
===
# Arrow-USB-Blaster
SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", ATTRS{idVendor}=="0403", ATTRS{idProduct}=="6010", MODE="0666", SYMLINK+="usbblasterarrow/%k"

Binary file not shown.

View File

@@ -0,0 +1 @@
# Place your license in this file.

View File

@@ -0,0 +1,4 @@
[General 17.1]
LICENSE_FILE = /opt/altera/license.dat
WAIT_FOR_LICENSE = off

View File

@@ -0,0 +1,172 @@
[17.1]
Registry_version=27
Altera_Foundation_Class\quartusQuartus_Prime_17.1_Lite_EditionDialogGeometry=@ByteArray(\x1\xd9\xd0\xcb\0\x1\0\0\0\0\f\x17\0\0\x6\xb8\0\0\xe\xf5\0\0\a\xc8\0\0\f\x17\0\0\x6\xb8\0\0\xe\xf5\0\0\a\xc8\0\0\0\0\0\0)
Toolbar\Large_icons=true
Quartus_UI_Framework\startup_failed=No
Messages\id_column_in_quartus_12_1_and_later=true
General\Check_for_New_Info_Message_at_Startup=Yes
General\Confirm_Before_Connect_to_Internet=No
General\Current_Message_Release_Number=0
General\TalkForward_Message_URL=
General\quartusShow_welcome_screen=true
General\quartusClose_welcome_screen_after_project_load=true
General\Tooltip_enable=true
General\Tooltip_interval=5
General\Tooltip_hide_interval=1
Chip_Viewer\Tooltip_enable=true
Chip_Viewer\Tooltip_interval=5
Chip_Viewer\Tooltip_hide_interval=1
Logical_Floorplan\Tooltip_enable=true
Logical_Floorplan\Tooltip_interval=5
Logical_Floorplan\Tooltip_hide_interval=1
Atom_Property_Editor\Tooltip_enable=true
Atom_Property_Editor\Tooltip_interval=5
Atom_Property_Editor\Tooltip_hide_interval=1
RTL_Viewer\Tooltip_enable=true
RTL_Viewer\Tooltip_Interval=5
RTL_Viewer\Tooltip_Hide_Interval=1
State_Machine_Viewer\Tooltip_enable=true
State_Machine_Viewer\Tooltip_Interval=5
State_Machine_Viewer\Tooltip_Hide_Interval=1
Pin_Planner\Tooltip_enable=true
Pin_Planner\Tooltip_interval=5
Pin_Planner\Tooltip_hide_interval=1
Altera_Foundation_Class\quartusOptionsDialogGeometry="@ByteArray(\x1\xd9\xd0\xcb\0\x1\0\0\0\0\x3;\0\0\x1r\0\0\b\xb2\0\0\x4\x91\0\0\x3;\0\0\x1r\0\0\b\xb2\0\0\x4\x91\0\0\0\x2\0\0)"
Altera_Foundation_Class\quartusSelect_FileFileDialogGeometry=@ByteArray(\x1\xd9\xd0\xcb\0\x1\0\0\0\0\b\x8a\0\0\x1y\0\0\v\x4\0\0\x3/\0\0\b\x8a\0\0\x1y\0\0\v\x4\0\0\x3/\0\0\0\x2\0\0)
Quartus_UI_Framework\quartussld_bnlqmdiGeometry=@ByteArray(\x1\xd9\xd0\xcb\0\x1\0\0\0\0\x2p\0\0\0W\0\0\x6.\0\0\x2\xc4\0\0\x2p\0\0\0m\0\0\x6.\0\0\x2\xc4\0\0\0\x2\0\0)
Quartus_UI_Framework\quartussld_bnlqmdiState=@ByteArray(\0\0\0\xff\0\0\0\0\xfd\0\0\0\0\0\0\x3\xbf\0\0\x2\x1f\0\0\0\x4\0\0\0\x4\0\0\0\b\0\0\0\b\xfc\0\0\0\x4\0\0\0\0\0\0\0\x2\0\0\0&\0L\0\x65\0\x66\0t\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\x2\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x10\0\x46\0\x65\0\x65\0\x64\0\x62\0\x61\0\x63\0k\x2\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x1\0\0\0\x1\0\0\0(\0R\0i\0g\0h\0t\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\x2\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x2\0\0\0\x1\0\0\0$\0T\0o\0p\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\0\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x3\0\0\0\x1\0\0\0*\0\x42\0o\0t\0t\0o\0m\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\0\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0)
Quartus_UI_Framework\quartussld_atcqmdiGeometry=@ByteArray(\x1\xd9\xd0\xcb\0\x1\0\0\0\0\0\xf7\0\0\0Z\0\0\x4\x16\0\0\x2\xc7\0\0\0\xf7\0\0\0p\0\0\x4\x16\0\0\x2\xc7\0\0\0\x2\0\0)
Quartus_UI_Framework\quartussld_atcqmdiState=@ByteArray(\0\0\0\xff\0\0\0\0\xfd\0\0\0\0\0\0\x3 \0\0\x2\x1f\0\0\0\x4\0\0\0\x4\0\0\0\b\0\0\0\b\xfc\0\0\0\x4\0\0\0\0\0\0\0\x2\0\0\0&\0L\0\x65\0\x66\0t\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\x2\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x10\0\x46\0\x65\0\x65\0\x64\0\x62\0\x61\0\x63\0k\x2\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x1\0\0\0\x1\0\0\0(\0R\0i\0g\0h\0t\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\x2\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x2\0\0\0\x1\0\0\0$\0T\0o\0p\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\0\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x3\0\0\0\x1\0\0\0*\0\x42\0o\0t\0t\0o\0m\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\0\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0)
Altera_Foundation_Class\quartusOpen_ProjectFileDialogGeometry=@ByteArray(\x1\xd9\xd0\xcb\0\x1\0\0\0\0\x2\xc9\0\0\x1\r\0\0\x5\x43\0\0\x2\xc3\0\0\x2\xc9\0\0\x1\r\0\0\x5\x43\0\0\x2\xc3\0\0\0\x2\0\0)
Quartus_UI_Framework\quartusQuartus_Primedock_widget0=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget0Area=8
Quartus_UI_Framework\quartusQuartus_Primedock_widget0Floating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget0Pinned=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget0Minimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget0Closed=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget1=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget1Area=1
Quartus_UI_Framework\quartusQuartus_Primedock_widget1Floating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget1Pinned=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget1Minimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget1Closed=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget2=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget2Area=1
Quartus_UI_Framework\quartusQuartus_Primedock_widget2Floating=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget2Pinned=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget2Minimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget2Closed=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget3=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget3Area=8
Quartus_UI_Framework\quartusQuartus_Primedock_widget3Floating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget3Pinned=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget3Minimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget3Closed=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget4=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget4Area=1
Quartus_UI_Framework\quartusQuartus_Primedock_widget4Floating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget4Pinned=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget4Minimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget4Closed=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget5=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget5Area=1
Quartus_UI_Framework\quartusQuartus_Primedock_widget5Floating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget5Pinned=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget5Minimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget5Closed=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget6=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget6Area=8
Quartus_UI_Framework\quartusQuartus_Primedock_widget6Floating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget6Pinned=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget6Minimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget6Closed=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget7=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget7Area=8
Quartus_UI_Framework\quartusQuartus_Primedock_widget7Floating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget7Pinned=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget7Minimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget7Closed=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget8=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget8Area=8
Quartus_UI_Framework\quartusQuartus_Primedock_widget8Floating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget8Pinned=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget8Minimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget8Closed=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget11=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget11Area=2
Quartus_UI_Framework\quartusQuartus_Primedock_widget11Floating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget11Pinned=true
Quartus_UI_Framework\quartusQuartus_Primedock_widget11Minimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widget11Closed=false
Quartus_UI_Framework\current_project=
Quartus_UI_Framework\quartussys_sscqmdiState=@ByteArray(\0\0\0\xff\0\0\0\0\xfd\0\0\0\0\0\0\x2\xb3\0\0\x1\xfa\0\0\0\x4\0\0\0\x4\0\0\0\b\0\0\0\b\xfc\0\0\0\x4\0\0\0\0\0\0\0\x2\0\0\0&\0L\0\x65\0\x66\0t\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\x2\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x10\0\x46\0\x65\0\x65\0\x64\0\x62\0\x61\0\x63\0k\x2\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x1\0\0\0\x1\0\0\0(\0R\0i\0g\0h\0t\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\x2\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x2\0\0\0\x1\0\0\0$\0T\0o\0p\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\0\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x3\0\0\0\x1\0\0\0*\0\x42\0o\0t\0t\0o\0m\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\0\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0)
Quartus_UI_Framework\quartussys_qgqmainGeometry="@ByteArray(\x1\xd9\xd0\xcb\0\x1\0\0\0\0\x2\xb5\0\0\0\xe3\0\0\b,\0\0\x4\x18\0\0\x2\xb5\0\0\0\xf9\0\0\b,\0\0\x4\x18\0\0\0\x2\0\0)"
Quartus_UI_Framework\quartussys_qgqmainState=@ByteArray(\0\0\0\xff\0\0\0\0\xfd\0\0\0\x3\0\0\0\0\0\0\x1W\0\0\x2\x16\xfc\x2\0\0\0\x4\xfb\0\0\0\"\0P\0r\0o\0j\0\x65\0\x63\0t\0 \0N\0\x61\0v\0i\0g\0\x61\0t\0o\0r\x1\0\0\0O\0\0\x1/\0\0\0\x94\0\xff\xff\xff\xfb\0\0\0\n\0T\0\x61\0s\0k\0s\x1\0\0\x1\x84\0\0\0\xe1\0\0\0n\0\xff\xff\xff\xfb\0\0\0\x16\0N\0o\0\x64\0\x65\0 \0\x46\0i\0n\0\x64\0\x65\0r\x2\0\0\0\0\0\0\0\x10\0\0\x1+\0\0\x1'\xfb\0\0\0\f\0S\0t\0\x61\0t\0u\0s\0\0\0\0\0\xff\xff\xff\xff\0\0\0\x64\0\xff\xff\xff\0\0\0\x1\0\0\x1\x62\0\0\x2\x16\xfc\x2\0\0\0\x1\xfb\0\0\0\x14\0I\0P\0 \0\x43\0\x61\0t\0\x61\0l\0o\0g\x1\0\0\0O\0\0\x2\x16\0\0\0\xc8\0\xff\xff\xff\0\0\0\x3\0\0\x5x\0\0\0\x9d\xfc\x2\0\0\0\x5\xfb\0\0\0\x16\0T\0\x63\0l\0 \0\x43\0o\0n\0s\0o\0l\0\x65\0\0\0\0\0\xff\xff\xff\xff\0\0\0K\0\xff\xff\xff\xfb\0\0\0\x1c\0\x43\0h\0\x61\0n\0g\0\x65\0 \0M\0\x61\0n\0\x61\0g\0\x65\0r\0\0\0\0\0\xff\xff\xff\xff\0\0\0\x92\0\xff\xff\xff\xfb\0\0\0\x32\0L\0o\0g\0i\0\x63\0 \0L\0o\0\x63\0k\0 \0R\0\x65\0g\0i\0o\0n\0s\0 \0W\0i\0n\0\x64\0o\0w\0\0\0\0\0\xff\xff\xff\xff\0\0\0\x81\0\xff\xff\xff\xfb\0\0\0\x30\0\x44\0\x65\0s\0i\0g\0n\0 \0P\0\x61\0r\0t\0i\0t\0i\0o\0n\0s\0 \0W\0i\0n\0\x64\0o\0w\0\0\0\0\0\xff\xff\xff\xff\0\0\0\x81\0\xff\xff\xff\xfb\0\0\0\x10\0M\0\x65\0s\0s\0\x61\0g\0\x65\0s\x1\0\0\x2k\0\0\0\x9d\0\0\0\x9d\0\xff\xff\xff\0\0\x2\xb3\0\0\x2\x16\0\0\0\x4\0\0\0\x4\0\0\0\b\0\0\0\b\xfc\0\0\0\x5\0\0\0\0\0\0\0\x1\0\0\0&\0L\0\x65\0\x66\0t\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\x2\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x1\0\0\0\x1\0\0\0(\0R\0i\0g\0h\0t\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\x2\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x2\0\0\0\x4\0\0\0$\0T\0o\0p\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\0\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\b\0\x46\0i\0l\0\x65\x1\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x10\0S\0t\0\x61\0n\0\x64\0\x61\0r\0\x64\x1\0\0\x1\x81\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x10\0\x46\0\x65\0\x65\0\x64\0\x62\0\x61\0\x63\0k\x1\0\0\x4\xb5\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x2\0\0\0\x3\0\0\0\x1e\0U\0t\0i\0l\0i\0t\0y\0 \0W\0i\0n\0\x64\0o\0w\0s\0\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x18\0\x41\0p\0p\0l\0i\0\x63\0\x61\0t\0i\0o\0n\0s\0\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x14\0P\0r\0o\0\x63\0\x65\0s\0s\0i\0n\0g\0\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0\0\0\0\x3\0\0\0\x1\0\0\0*\0\x42\0o\0t\0t\0o\0m\0 \0\x42\0u\0t\0t\0o\0n\0 \0T\0o\0o\0l\0\x62\0\x61\0r\0\0\0\0\0\xff\xff\xff\xff\0\0\0\0\0\0\0\0)
Quartus_UI_Framework\quartusQuartus_Primedock_widgetProject_Navigator=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetProject_NavigatorArea=1
Quartus_UI_Framework\quartusQuartus_Primedock_widgetProject_NavigatorFloating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetProject_NavigatorPinned=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetProject_NavigatorMinimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetProject_NavigatorClosed=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetTasks=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetTasksArea=1
Quartus_UI_Framework\quartusQuartus_Primedock_widgetTasksFloating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetTasksPinned=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetTasksMinimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetTasksClosed=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetIP_Catalog=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetIP_CatalogArea=2
Quartus_UI_Framework\quartusQuartus_Primedock_widgetIP_CatalogFloating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetIP_CatalogPinned=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetIP_CatalogMinimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetIP_CatalogClosed=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetNode_Finder=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetNode_FinderArea=1
Quartus_UI_Framework\quartusQuartus_Primedock_widgetNode_FinderFloating=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetNode_FinderPinned=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetNode_FinderMinimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetNode_FinderClosed=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetTcl_Console=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetTcl_ConsoleArea=8
Quartus_UI_Framework\quartusQuartus_Primedock_widgetTcl_ConsoleFloating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetTcl_ConsolePinned=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetTcl_ConsoleMinimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetTcl_ConsoleClosed=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetStatus=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetStatusArea=1
Quartus_UI_Framework\quartusQuartus_Primedock_widgetStatusFloating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetStatusPinned=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetStatusMinimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetStatusClosed=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetChange_Manager=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetChange_ManagerArea=8
Quartus_UI_Framework\quartusQuartus_Primedock_widgetChange_ManagerFloating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetChange_ManagerPinned=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetChange_ManagerMinimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetChange_ManagerClosed=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetLogic_Lock_Regions_Window=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetLogic_Lock_Regions_WindowArea=8
Quartus_UI_Framework\quartusQuartus_Primedock_widgetLogic_Lock_Regions_WindowFloating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetLogic_Lock_Regions_WindowPinned=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetLogic_Lock_Regions_WindowMinimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetLogic_Lock_Regions_WindowClosed=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetDesign_Partitions_Window=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetDesign_Partitions_WindowArea=8
Quartus_UI_Framework\quartusQuartus_Primedock_widgetDesign_Partitions_WindowFloating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetDesign_Partitions_WindowPinned=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetDesign_Partitions_WindowMinimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetDesign_Partitions_WindowClosed=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetMessages=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetMessagesArea=8
Quartus_UI_Framework\quartusQuartus_Primedock_widgetMessagesFloating=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetMessagesPinned=true
Quartus_UI_Framework\quartusQuartus_Primedock_widgetMessagesMinimized=false
Quartus_UI_Framework\quartusQuartus_Primedock_widgetMessagesClosed=false
Quartus_UI_Framework\sys_sscqsingleton_attach_state=false
Quartus_UI_Framework\sys_qgqsingleton_attach_state=true
Task_Manager_Window\Task_Manager_File=tmwq_tasks_compile.tmf
Task_Manager_Window\Task_Manager_Expanded_Nodes=0
UNB\Filters\count=0
UNB\Filters\selection%20index=0
UNB\column_settings\node_found=23
Tcl_Toolbar\tcl_console_command_history=@Invalid()

View File

@@ -0,0 +1,69 @@
#!/bin/bash -x
#########################################################################################################
##
## Name: run_quartus.sh
## Created: August 2019
## Author(s): Philip Smart
## Description: A shell script to start the Quartus Prime Docker image.
##
## Credits:
## Copyright: (c) 2019 Philip Smart <philip.smart@net2net.org>
##
## History: August 2019 - Initial module written.
##
#########################################################################################################
## This source file 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 source file 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/>.
#########################################################################################################
# Configurable parameters. The MAC_ADDRESS is needed if you are using a licensed Quartus as it uses the hostid which is the mac address.
# Set a default for the X-Display if the environment hasnt set it.
#
MAC_ADDR="02:50:dd:72:03:01"
PROJECT_DIR_HOST=/srv/quartus
PROJECT_DIR_IMAGE=/srv/quartus
DISPLAY=${DISPLAY:-192.168.15.210:0}
VERSION=$1
if [ "${VERSION}" = "17.1.1" -o "X${VERSION}" = "X" ]; then
VERSION=17.1.1
elif [ "${VERSION}" != "13.0.1" -a "${VERSION}" != "13.1" ]; then
echo "Unknown QuartusII version:$1"
fi
# In order to get X-Forwarding from the container, we need to update the X Authorities and bind the authorisation file inside the virtual machine.
XSOCK=/tmp/.X11-unix
XAUTH=/tmp/.docker.xauth
NLIST=`xauth nlist $DISPLAY | sed -e 's/^..../ffff/'`
if [ "${NLIST}" != "" ]; then
echo ${NLIST} | xauth -f $XAUTH nmerge -
fi
chmod 777 $XAUTH
# Run the Ubuntu hosted Quartus Prime service.
docker run --rm \
--mac-address "${MAC_ADDR}" \
--env DISPLAY=${DISPLAY} \
--ipc=host \
--env XAUTHORITY=${XAUTH} \
--privileged \
--volume /dev:/dev \
--volume ${PROJECT_DIR_HOST}:${PROJECT_DIR_IMAGE} \
--volume ${XAUTH}:${XAUTH} \
--volume ${XSOCK}:${XSOCK} \
--volume /sys:/sys:ro \
--name quartus${VERSION} \
quartus-ii-${VERSION} &
# Bring up a terminal session for any local changes.
sleep 5
docker exec -it quartus${VERSION} bash

674
license.txt Normal file
View File

@@ -0,0 +1,674 @@
GNU GENERAL PUBLIC LICENSE
Version 3, 29 June 2007
Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
Everyone is permitted to copy and distribute verbatim copies
of this license document, but changing it is not allowed.
Preamble
The GNU General Public License is a free, copyleft license for
software and other kinds of works.
The licenses for most software and other practical works are designed
to take away your freedom to share and change the works. By contrast,
the GNU General Public License is intended to guarantee your freedom to
share and change all versions of a program--to make sure it remains free
software for all its users. We, the Free Software Foundation, use the
GNU General Public License for most of our software; it applies also to
any other work released this way by its authors. You can apply it to
your programs, too.
When we speak of free software, we are referring to freedom, not
price. Our General Public Licenses are designed to make sure that you
have the freedom to distribute copies of free software (and charge for
them if you wish), that you receive source code or can get it if you
want it, that you can change the software or use pieces of it in new
free programs, and that you know you can do these things.
To protect your rights, we need to prevent others from denying you
these rights or asking you to surrender the rights. Therefore, you have
certain responsibilities if you distribute copies of the software, or if
you modify it: responsibilities to respect the freedom of others.
For example, if you distribute copies of such a program, whether
gratis or for a fee, you must pass on to the recipients the same
freedoms that you received. You must make sure that they, too, receive
or can get the source code. And you must show them these terms so they
know their rights.
Developers that use the GNU GPL protect your rights with two steps:
(1) assert copyright on the software, and (2) offer you this License
giving you legal permission to copy, distribute and/or modify it.
For the developers' and authors' protection, the GPL clearly explains
that there is no warranty for this free software. For both users' and
authors' sake, the GPL requires that modified versions be marked as
changed, so that their problems will not be attributed erroneously to
authors of previous versions.
Some devices are designed to deny users access to install or run
modified versions of the software inside them, although the manufacturer
can do so. This is fundamentally incompatible with the aim of
protecting users' freedom to change the software. The systematic
pattern of such abuse occurs in the area of products for individuals to
use, which is precisely where it is most unacceptable. Therefore, we
have designed this version of the GPL to prohibit the practice for those
products. If such problems arise substantially in other domains, we
stand ready to extend this provision to those domains in future versions
of the GPL, as needed to protect the freedom of users.
Finally, every program is threatened constantly by software patents.
States should not allow patents to restrict development and use of
software on general-purpose computers, but in those that do, we wish to
avoid the special danger that patents applied to a free program could
make it effectively proprietary. To prevent this, the GPL assures that
patents cannot be used to render the program non-free.
The precise terms and conditions for copying, distribution and
modification follow.
TERMS AND CONDITIONS
0. Definitions.
"This License" refers to version 3 of the GNU General Public License.
"Copyright" also means copyright-like laws that apply to other kinds of
works, such as semiconductor masks.
"The Program" refers to any copyrightable work licensed under this
License. Each licensee is addressed as "you". "Licensees" and
"recipients" may be individuals or organizations.
To "modify" a work means to copy from or adapt all or part of the work
in a fashion requiring copyright permission, other than the making of an
exact copy. The resulting work is called a "modified version" of the
earlier work or a work "based on" the earlier work.
A "covered work" means either the unmodified Program or a work based
on the Program.
To "propagate" a work means to do anything with it that, without
permission, would make you directly or secondarily liable for
infringement under applicable copyright law, except executing it on a
computer or modifying a private copy. Propagation includes copying,
distribution (with or without modification), making available to the
public, and in some countries other activities as well.
To "convey" a work means any kind of propagation that enables other
parties to make or receive copies. Mere interaction with a user through
a computer network, with no transfer of a copy, is not conveying.
An interactive user interface displays "Appropriate Legal Notices"
to the extent that it includes a convenient and prominently visible
feature that (1) displays an appropriate copyright notice, and (2)
tells the user that there is no warranty for the work (except to the
extent that warranties are provided), that licensees may convey the
work under this License, and how to view a copy of this License. If
the interface presents a list of user commands or options, such as a
menu, a prominent item in the list meets this criterion.
1. Source Code.
The "source code" for a work means the preferred form of the work
for making modifications to it. "Object code" means any non-source
form of a work.
A "Standard Interface" means an interface that either is an official
standard defined by a recognized standards body, or, in the case of
interfaces specified for a particular programming language, one that
is widely used among developers working in that language.
The "System Libraries" of an executable work include anything, other
than the work as a whole, that (a) is included in the normal form of
packaging a Major Component, but which is not part of that Major
Component, and (b) serves only to enable use of the work with that
Major Component, or to implement a Standard Interface for which an
implementation is available to the public in source code form. A
"Major Component", in this context, means a major essential component
(kernel, window system, and so on) of the specific operating system
(if any) on which the executable work runs, or a compiler used to
produce the work, or an object code interpreter used to run it.
The "Corresponding Source" for a work in object code form means all
the source code needed to generate, install, and (for an executable
work) run the object code and to modify the work, including scripts to
control those activities. However, it does not include the work's
System Libraries, or general-purpose tools or generally available free
programs which are used unmodified in performing those activities but
which are not part of the work. For example, Corresponding Source
includes interface definition files associated with source files for
the work, and the source code for shared libraries and dynamically
linked subprograms that the work is specifically designed to require,
such as by intimate data communication or control flow between those
subprograms and other parts of the work.
The Corresponding Source need not include anything that users
can regenerate automatically from other parts of the Corresponding
Source.
The Corresponding Source for a work in source code form is that
same work.
2. Basic Permissions.
All rights granted under this License are granted for the term of
copyright on the Program, and are irrevocable provided the stated
conditions are met. This License explicitly affirms your unlimited
permission to run the unmodified Program. The output from running a
covered work is covered by this License only if the output, given its
content, constitutes a covered work. This License acknowledges your
rights of fair use or other equivalent, as provided by copyright law.
You may make, run and propagate covered works that you do not
convey, without conditions so long as your license otherwise remains
in force. You may convey covered works to others for the sole purpose
of having them make modifications exclusively for you, or provide you
with facilities for running those works, provided that you comply with
the terms of this License in conveying all material for which you do
not control copyright. Those thus making or running the covered works
for you must do so exclusively on your behalf, under your direction
and control, on terms that prohibit them from making any copies of
your copyrighted material outside their relationship with you.
Conveying under any other circumstances is permitted solely under
the conditions stated below. Sublicensing is not allowed; section 10
makes it unnecessary.
3. Protecting Users' Legal Rights From Anti-Circumvention Law.
No covered work shall be deemed part of an effective technological
measure under any applicable law fulfilling obligations under article
11 of the WIPO copyright treaty adopted on 20 December 1996, or
similar laws prohibiting or restricting circumvention of such
measures.
When you convey a covered work, you waive any legal power to forbid
circumvention of technological measures to the extent such circumvention
is effected by exercising rights under this License with respect to
the covered work, and you disclaim any intention to limit operation or
modification of the work as a means of enforcing, against the work's
users, your or third parties' legal rights to forbid circumvention of
technological measures.
4. Conveying Verbatim Copies.
You may convey verbatim copies of the Program's source code as you
receive it, in any medium, provided that you conspicuously and
appropriately publish on each copy an appropriate copyright notice;
keep intact all notices stating that this License and any
non-permissive terms added in accord with section 7 apply to the code;
keep intact all notices of the absence of any warranty; and give all
recipients a copy of this License along with the Program.
You may charge any price or no price for each copy that you convey,
and you may offer support or warranty protection for a fee.
5. Conveying Modified Source Versions.
You may convey a work based on the Program, or the modifications to
produce it from the Program, in the form of source code under the
terms of section 4, provided that you also meet all of these conditions:
a) The work must carry prominent notices stating that you modified
it, and giving a relevant date.
b) The work must carry prominent notices stating that it is
released under this License and any conditions added under section
7. This requirement modifies the requirement in section 4 to
"keep intact all notices".
c) You must license the entire work, as a whole, under this
License to anyone who comes into possession of a copy. This
License will therefore apply, along with any applicable section 7
additional terms, to the whole of the work, and all its parts,
regardless of how they are packaged. This License gives no
permission to license the work in any other way, but it does not
invalidate such permission if you have separately received it.
d) If the work has interactive user interfaces, each must display
Appropriate Legal Notices; however, if the Program has interactive
interfaces that do not display Appropriate Legal Notices, your
work need not make them do so.
A compilation of a covered work with other separate and independent
works, which are not by their nature extensions of the covered work,
and which are not combined with it such as to form a larger program,
in or on a volume of a storage or distribution medium, is called an
"aggregate" if the compilation and its resulting copyright are not
used to limit the access or legal rights of the compilation's users
beyond what the individual works permit. Inclusion of a covered work
in an aggregate does not cause this License to apply to the other
parts of the aggregate.
6. Conveying Non-Source Forms.
You may convey a covered work in object code form under the terms
of sections 4 and 5, provided that you also convey the
machine-readable Corresponding Source under the terms of this License,
in one of these ways:
a) Convey the object code in, or embodied in, a physical product
(including a physical distribution medium), accompanied by the
Corresponding Source fixed on a durable physical medium
customarily used for software interchange.
b) Convey the object code in, or embodied in, a physical product
(including a physical distribution medium), accompanied by a
written offer, valid for at least three years and valid for as
long as you offer spare parts or customer support for that product
model, to give anyone who possesses the object code either (1) a
copy of the Corresponding Source for all the software in the
product that is covered by this License, on a durable physical
medium customarily used for software interchange, for a price no
more than your reasonable cost of physically performing this
conveying of source, or (2) access to copy the
Corresponding Source from a network server at no charge.
c) Convey individual copies of the object code with a copy of the
written offer to provide the Corresponding Source. This
alternative is allowed only occasionally and noncommercially, and
only if you received the object code with such an offer, in accord
with subsection 6b.
d) Convey the object code by offering access from a designated
place (gratis or for a charge), and offer equivalent access to the
Corresponding Source in the same way through the same place at no
further charge. You need not require recipients to copy the
Corresponding Source along with the object code. If the place to
copy the object code is a network server, the Corresponding Source
may be on a different server (operated by you or a third party)
that supports equivalent copying facilities, provided you maintain
clear directions next to the object code saying where to find the
Corresponding Source. Regardless of what server hosts the
Corresponding Source, you remain obligated to ensure that it is
available for as long as needed to satisfy these requirements.
e) Convey the object code using peer-to-peer transmission, provided
you inform other peers where the object code and Corresponding
Source of the work are being offered to the general public at no
charge under subsection 6d.
A separable portion of the object code, whose source code is excluded
from the Corresponding Source as a System Library, need not be
included in conveying the object code work.
A "User Product" is either (1) a "consumer product", which means any
tangible personal property which is normally used for personal, family,
or household purposes, or (2) anything designed or sold for incorporation
into a dwelling. In determining whether a product is a consumer product,
doubtful cases shall be resolved in favor of coverage. For a particular
product received by a particular user, "normally used" refers to a
typical or common use of that class of product, regardless of the status
of the particular user or of the way in which the particular user
actually uses, or expects or is expected to use, the product. A product
is a consumer product regardless of whether the product has substantial
commercial, industrial or non-consumer uses, unless such uses represent
the only significant mode of use of the product.
"Installation Information" for a User Product means any methods,
procedures, authorization keys, or other information required to install
and execute modified versions of a covered work in that User Product from
a modified version of its Corresponding Source. The information must
suffice to ensure that the continued functioning of the modified object
code is in no case prevented or interfered with solely because
modification has been made.
If you convey an object code work under this section in, or with, or
specifically for use in, a User Product, and the conveying occurs as
part of a transaction in which the right of possession and use of the
User Product is transferred to the recipient in perpetuity or for a
fixed term (regardless of how the transaction is characterized), the
Corresponding Source conveyed under this section must be accompanied
by the Installation Information. But this requirement does not apply
if neither you nor any third party retains the ability to install
modified object code on the User Product (for example, the work has
been installed in ROM).
The requirement to provide Installation Information does not include a
requirement to continue to provide support service, warranty, or updates
for a work that has been modified or installed by the recipient, or for
the User Product in which it has been modified or installed. Access to a
network may be denied when the modification itself materially and
adversely affects the operation of the network or violates the rules and
protocols for communication across the network.
Corresponding Source conveyed, and Installation Information provided,
in accord with this section must be in a format that is publicly
documented (and with an implementation available to the public in
source code form), and must require no special password or key for
unpacking, reading or copying.
7. Additional Terms.
"Additional permissions" are terms that supplement the terms of this
License by making exceptions from one or more of its conditions.
Additional permissions that are applicable to the entire Program shall
be treated as though they were included in this License, to the extent
that they are valid under applicable law. If additional permissions
apply only to part of the Program, that part may be used separately
under those permissions, but the entire Program remains governed by
this License without regard to the additional permissions.
When you convey a copy of a covered work, you may at your option
remove any additional permissions from that copy, or from any part of
it. (Additional permissions may be written to require their own
removal in certain cases when you modify the work.) You may place
additional permissions on material, added by you to a covered work,
for which you have or can give appropriate copyright permission.
Notwithstanding any other provision of this License, for material you
add to a covered work, you may (if authorized by the copyright holders of
that material) supplement the terms of this License with terms:
a) Disclaiming warranty or limiting liability differently from the
terms of sections 15 and 16 of this License; or
b) Requiring preservation of specified reasonable legal notices or
author attributions in that material or in the Appropriate Legal
Notices displayed by works containing it; or
c) Prohibiting misrepresentation of the origin of that material, or
requiring that modified versions of such material be marked in
reasonable ways as different from the original version; or
d) Limiting the use for publicity purposes of names of licensors or
authors of the material; or
e) Declining to grant rights under trademark law for use of some
trade names, trademarks, or service marks; or
f) Requiring indemnification of licensors and authors of that
material by anyone who conveys the material (or modified versions of
it) with contractual assumptions of liability to the recipient, for
any liability that these contractual assumptions directly impose on
those licensors and authors.
All other non-permissive additional terms are considered "further
restrictions" within the meaning of section 10. If the Program as you
received it, or any part of it, contains a notice stating that it is
governed by this License along with a term that is a further
restriction, you may remove that term. If a license document contains
a further restriction but permits relicensing or conveying under this
License, you may add to a covered work material governed by the terms
of that license document, provided that the further restriction does
not survive such relicensing or conveying.
If you add terms to a covered work in accord with this section, you
must place, in the relevant source files, a statement of the
additional terms that apply to those files, or a notice indicating
where to find the applicable terms.
Additional terms, permissive or non-permissive, may be stated in the
form of a separately written license, or stated as exceptions;
the above requirements apply either way.
8. Termination.
You may not propagate or modify a covered work except as expressly
provided under this License. Any attempt otherwise to propagate or
modify it is void, and will automatically terminate your rights under
this License (including any patent licenses granted under the third
paragraph of section 11).
However, if you cease all violation of this License, then your
license from a particular copyright holder is reinstated (a)
provisionally, unless and until the copyright holder explicitly and
finally terminates your license, and (b) permanently, if the copyright
holder fails to notify you of the violation by some reasonable means
prior to 60 days after the cessation.
Moreover, your license from a particular copyright holder is
reinstated permanently if the copyright holder notifies you of the
violation by some reasonable means, this is the first time you have
received notice of violation of this License (for any work) from that
copyright holder, and you cure the violation prior to 30 days after
your receipt of the notice.
Termination of your rights under this section does not terminate the
licenses of parties who have received copies or rights from you under
this License. If your rights have been terminated and not permanently
reinstated, you do not qualify to receive new licenses for the same
material under section 10.
9. Acceptance Not Required for Having Copies.
You are not required to accept this License in order to receive or
run a copy of the Program. Ancillary propagation of a covered work
occurring solely as a consequence of using peer-to-peer transmission
to receive a copy likewise does not require acceptance. However,
nothing other than this License grants you permission to propagate or
modify any covered work. These actions infringe copyright if you do
not accept this License. Therefore, by modifying or propagating a
covered work, you indicate your acceptance of this License to do so.
10. Automatic Licensing of Downstream Recipients.
Each time you convey a covered work, the recipient automatically
receives a license from the original licensors, to run, modify and
propagate that work, subject to this License. You are not responsible
for enforcing compliance by third parties with this License.
An "entity transaction" is a transaction transferring control of an
organization, or substantially all assets of one, or subdividing an
organization, or merging organizations. If propagation of a covered
work results from an entity transaction, each party to that
transaction who receives a copy of the work also receives whatever
licenses to the work the party's predecessor in interest had or could
give under the previous paragraph, plus a right to possession of the
Corresponding Source of the work from the predecessor in interest, if
the predecessor has it or can get it with reasonable efforts.
You may not impose any further restrictions on the exercise of the
rights granted or affirmed under this License. For example, you may
not impose a license fee, royalty, or other charge for exercise of
rights granted under this License, and you may not initiate litigation
(including a cross-claim or counterclaim in a lawsuit) alleging that
any patent claim is infringed by making, using, selling, offering for
sale, or importing the Program or any portion of it.
11. Patents.
A "contributor" is a copyright holder who authorizes use under this
License of the Program or a work on which the Program is based. The
work thus licensed is called the contributor's "contributor version".
A contributor's "essential patent claims" are all patent claims
owned or controlled by the contributor, whether already acquired or
hereafter acquired, that would be infringed by some manner, permitted
by this License, of making, using, or selling its contributor version,
but do not include claims that would be infringed only as a
consequence of further modification of the contributor version. For
purposes of this definition, "control" includes the right to grant
patent sublicenses in a manner consistent with the requirements of
this License.
Each contributor grants you a non-exclusive, worldwide, royalty-free
patent license under the contributor's essential patent claims, to
make, use, sell, offer for sale, import and otherwise run, modify and
propagate the contents of its contributor version.
In the following three paragraphs, a "patent license" is any express
agreement or commitment, however denominated, not to enforce a patent
(such as an express permission to practice a patent or covenant not to
sue for patent infringement). To "grant" such a patent license to a
party means to make such an agreement or commitment not to enforce a
patent against the party.
If you convey a covered work, knowingly relying on a patent license,
and the Corresponding Source of the work is not available for anyone
to copy, free of charge and under the terms of this License, through a
publicly available network server or other readily accessible means,
then you must either (1) cause the Corresponding Source to be so
available, or (2) arrange to deprive yourself of the benefit of the
patent license for this particular work, or (3) arrange, in a manner
consistent with the requirements of this License, to extend the patent
license to downstream recipients. "Knowingly relying" means you have
actual knowledge that, but for the patent license, your conveying the
covered work in a country, or your recipient's use of the covered work
in a country, would infringe one or more identifiable patents in that
country that you have reason to believe are valid.
If, pursuant to or in connection with a single transaction or
arrangement, you convey, or propagate by procuring conveyance of, a
covered work, and grant a patent license to some of the parties
receiving the covered work authorizing them to use, propagate, modify
or convey a specific copy of the covered work, then the patent license
you grant is automatically extended to all recipients of the covered
work and works based on it.
A patent license is "discriminatory" if it does not include within
the scope of its coverage, prohibits the exercise of, or is
conditioned on the non-exercise of one or more of the rights that are
specifically granted under this License. You may not convey a covered
work if you are a party to an arrangement with a third party that is
in the business of distributing software, under which you make payment
to the third party based on the extent of your activity of conveying
the work, and under which the third party grants, to any of the
parties who would receive the covered work from you, a discriminatory
patent license (a) in connection with copies of the covered work
conveyed by you (or copies made from those copies), or (b) primarily
for and in connection with specific products or compilations that
contain the covered work, unless you entered into that arrangement,
or that patent license was granted, prior to 28 March 2007.
Nothing in this License shall be construed as excluding or limiting
any implied license or other defenses to infringement that may
otherwise be available to you under applicable patent law.
12. No Surrender of Others' Freedom.
If conditions are imposed on you (whether by court order, agreement or
otherwise) that contradict the conditions of this License, they do not
excuse you from the conditions of this License. If you cannot convey a
covered work so as to satisfy simultaneously your obligations under this
License and any other pertinent obligations, then as a consequence you may
not convey it at all. For example, if you agree to terms that obligate you
to collect a royalty for further conveying from those to whom you convey
the Program, the only way you could satisfy both those terms and this
License would be to refrain entirely from conveying the Program.
13. Use with the GNU Affero General Public License.
Notwithstanding any other provision of this License, you have
permission to link or combine any covered work with a work licensed
under version 3 of the GNU Affero General Public License into a single
combined work, and to convey the resulting work. The terms of this
License will continue to apply to the part which is the covered work,
but the special requirements of the GNU Affero General Public License,
section 13, concerning interaction through a network will apply to the
combination as such.
14. Revised Versions of this License.
The Free Software Foundation may publish revised and/or new versions of
the GNU General Public License from time to time. Such new versions will
be similar in spirit to the present version, but may differ in detail to
address new problems or concerns.
Each version is given a distinguishing version number. If the
Program specifies that a certain numbered version of the GNU General
Public License "or any later version" applies to it, you have the
option of following the terms and conditions either of that numbered
version or of any later version published by the Free Software
Foundation. If the Program does not specify a version number of the
GNU General Public License, you may choose any version ever published
by the Free Software Foundation.
If the Program specifies that a proxy can decide which future
versions of the GNU General Public License can be used, that proxy's
public statement of acceptance of a version permanently authorizes you
to choose that version for the Program.
Later license versions may give you additional or different
permissions. However, no additional obligations are imposed on any
author or copyright holder as a result of your choosing to follow a
later version.
15. Disclaimer of Warranty.
THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
16. Limitation of Liability.
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
SUCH DAMAGES.
17. Interpretation of Sections 15 and 16.
If the disclaimer of warranty and limitation of liability provided
above cannot be given local legal effect according to their terms,
reviewing courts shall apply local law that most closely approximates
an absolute waiver of all civil liability in connection with the
Program, unless a warranty or assumption of liability accompanies a
copy of the Program in return for a fee.
END OF TERMS AND CONDITIONS
How to Apply These Terms to Your New Programs
If you develop a new program, and you want it to be of the greatest
possible use to the public, the best way to achieve this is to make it
free software which everyone can redistribute and change under these terms.
To do so, attach the following notices to the program. It is safest
to attach them to the start of each source file to most effectively
state the exclusion of warranty; and each file should have at least
the "copyright" line and a pointer to where the full notice is found.
<one line to give the program's name and a brief idea of what it does.>
Copyright (C) <year> <name of author>
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 <https://www.gnu.org/licenses/>.
Also add information on how to contact you by electronic and paper mail.
If the program does terminal interaction, make it output a short
notice like this when it starts in an interactive mode:
<program> Copyright (C) <year> <name of author>
This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
This is free software, and you are welcome to redistribute it
under certain conditions; type `show c' for details.
The hypothetical commands `show w' and `show c' should show the appropriate
parts of the General Public License. Of course, your program's commands
might be different; for a GUI interface, you would use an "about box".
You should also get your employer (if you work as a programmer) or school,
if any, to sign a "copyright disclaimer" for the program, if necessary.
For more information on this, and how to apply and follow the GNU GPL, see
<https://www.gnu.org/licenses/>.
The GNU General Public License does not permit incorporating your program
into proprietary programs. If your program is a subroutine library, you
may consider it more useful to permit linking proprietary applications with
the library. If this is what you want to do, use the GNU Lesser General
Public License instead of this License. But first, please read
<https://www.gnu.org/licenses/why-not-lgpl.html>.

Binary file not shown.

View File

@@ -0,0 +1,14 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-05T10:41:52+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Glue,Bot*
G04 #@! TF.FilePolarity,Positive*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-05 10:41:52*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
G04 APERTURE END LIST*
M02*

View File

@@ -0,0 +1,255 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-05T10:41:52+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,User*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-05 10:41:52*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.050000*%
G04 APERTURE END LIST*
D10*
X115890000Y-77314000D02*
X115890000Y-80674000D01*
X117790000Y-77314000D02*
X115890000Y-77314000D01*
X117790000Y-80674000D02*
X117790000Y-77314000D01*
X115890000Y-80674000D02*
X117790000Y-80674000D01*
X119319000Y-77314000D02*
X119319000Y-80674000D01*
X121219000Y-77314000D02*
X119319000Y-77314000D01*
X121219000Y-80674000D02*
X121219000Y-77314000D01*
X119319000Y-80674000D02*
X121219000Y-80674000D01*
X122780000Y-72324000D02*
X126140000Y-72324000D01*
X122780000Y-70424000D02*
X122780000Y-72324000D01*
X126140000Y-70424000D02*
X122780000Y-70424000D01*
X126140000Y-72324000D02*
X126140000Y-70424000D01*
X113567000Y-77663000D02*
X110207000Y-77663000D01*
X113567000Y-79563000D02*
X113567000Y-77663000D01*
X110207000Y-79563000D02*
X113567000Y-79563000D01*
X110207000Y-77663000D02*
X110207000Y-79563000D01*
X122780000Y-75880000D02*
X126140000Y-75880000D01*
X122780000Y-73980000D02*
X122780000Y-75880000D01*
X126140000Y-73980000D02*
X122780000Y-73980000D01*
X126140000Y-75880000D02*
X126140000Y-73980000D01*
X114075000Y-72710000D02*
X110715000Y-72710000D01*
X114075000Y-74610000D02*
X114075000Y-72710000D01*
X110715000Y-74610000D02*
X114075000Y-74610000D01*
X110715000Y-72710000D02*
X110715000Y-74610000D01*
X112297000Y-67503000D02*
X108937000Y-67503000D01*
X112297000Y-69403000D02*
X112297000Y-67503000D01*
X108937000Y-69403000D02*
X112297000Y-69403000D01*
X108937000Y-67503000D02*
X108937000Y-69403000D01*
X80550000Y-64009000D02*
X80550000Y-67309000D01*
X82010000Y-64009000D02*
X80550000Y-64009000D01*
X82010000Y-67309000D02*
X82010000Y-64009000D01*
X80550000Y-67309000D02*
X82010000Y-67309000D01*
X83692000Y-60738000D02*
X80392000Y-60738000D01*
X83692000Y-62198000D02*
X83692000Y-60738000D01*
X80392000Y-62198000D02*
X83692000Y-62198000D01*
X80392000Y-60738000D02*
X80392000Y-62198000D01*
X82328000Y-64009000D02*
X82328000Y-67309000D01*
X83788000Y-64009000D02*
X82328000Y-64009000D01*
X83788000Y-67309000D02*
X83788000Y-64009000D01*
X82328000Y-67309000D02*
X83788000Y-67309000D01*
X87789000Y-64009000D02*
X87789000Y-67309000D01*
X89249000Y-64009000D02*
X87789000Y-64009000D01*
X89249000Y-67309000D02*
X89249000Y-64009000D01*
X87789000Y-67309000D02*
X89249000Y-67309000D01*
X83692000Y-57436000D02*
X80392000Y-57436000D01*
X83692000Y-58896000D02*
X83692000Y-57436000D01*
X80392000Y-58896000D02*
X83692000Y-58896000D01*
X80392000Y-57436000D02*
X80392000Y-58896000D01*
X92043000Y-57276000D02*
X92043000Y-53976000D01*
X90583000Y-57276000D02*
X92043000Y-57276000D01*
X90583000Y-53976000D02*
X90583000Y-57276000D01*
X92043000Y-53976000D02*
X90583000Y-53976000D01*
X93694000Y-57276000D02*
X93694000Y-53976000D01*
X92234000Y-57276000D02*
X93694000Y-57276000D01*
X92234000Y-53976000D02*
X92234000Y-57276000D01*
X93694000Y-53976000D02*
X92234000Y-53976000D01*
X90425000Y-59658000D02*
X93725000Y-59658000D01*
X90425000Y-58198000D02*
X90425000Y-59658000D01*
X93725000Y-58198000D02*
X90425000Y-58198000D01*
X93725000Y-59658000D02*
X93725000Y-58198000D01*
X86455000Y-57276000D02*
X86455000Y-53976000D01*
X84995000Y-57276000D02*
X86455000Y-57276000D01*
X84995000Y-53976000D02*
X84995000Y-57276000D01*
X86455000Y-53976000D02*
X84995000Y-53976000D01*
X89694000Y-64009000D02*
X89694000Y-67309000D01*
X91154000Y-64009000D02*
X89694000Y-64009000D01*
X91154000Y-67309000D02*
X91154000Y-64009000D01*
X89694000Y-67309000D02*
X91154000Y-67309000D01*
X90425000Y-63341000D02*
X93725000Y-63341000D01*
X90425000Y-61881000D02*
X90425000Y-63341000D01*
X93725000Y-61881000D02*
X90425000Y-61881000D01*
X93725000Y-63341000D02*
X93725000Y-61881000D01*
X83692000Y-54388000D02*
X80392000Y-54388000D01*
X83692000Y-55848000D02*
X83692000Y-54388000D01*
X80392000Y-55848000D02*
X83692000Y-55848000D01*
X80392000Y-54388000D02*
X80392000Y-55848000D01*
X115188000Y-76105000D02*
X111888000Y-76105000D01*
X115188000Y-77565000D02*
X115188000Y-76105000D01*
X111888000Y-77565000D02*
X115188000Y-77565000D01*
X111888000Y-76105000D02*
X111888000Y-77565000D01*
X120778000Y-67405000D02*
X124078000Y-67405000D01*
X120778000Y-65945000D02*
X120778000Y-67405000D01*
X124078000Y-65945000D02*
X120778000Y-65945000D01*
X124078000Y-67405000D02*
X124078000Y-65945000D01*
X120778000Y-69437000D02*
X124078000Y-69437000D01*
X120778000Y-67977000D02*
X120778000Y-69437000D01*
X124078000Y-67977000D02*
X120778000Y-67977000D01*
X124078000Y-69437000D02*
X124078000Y-67977000D01*
X114172000Y-70136000D02*
X110872000Y-70136000D01*
X114172000Y-71596000D02*
X114172000Y-70136000D01*
X110872000Y-71596000D02*
X114172000Y-71596000D01*
X110872000Y-70136000D02*
X110872000Y-71596000D01*
X118840000Y-65025000D02*
X117380000Y-65025000D01*
X117380000Y-65025000D02*
X117380000Y-68325000D01*
X117380000Y-68325000D02*
X118840000Y-68325000D01*
X118840000Y-68325000D02*
X118840000Y-65025000D01*
X114172000Y-65945000D02*
X110872000Y-65945000D01*
X114172000Y-67405000D02*
X114172000Y-65945000D01*
X110872000Y-67405000D02*
X114172000Y-67405000D01*
X110872000Y-65945000D02*
X110872000Y-67405000D01*
X120905000Y-77565000D02*
X124205000Y-77565000D01*
X120905000Y-76105000D02*
X120905000Y-77565000D01*
X124205000Y-76105000D02*
X120905000Y-76105000D01*
X124205000Y-77565000D02*
X124205000Y-76105000D01*
X111030000Y-55500000D02*
X111030000Y-58800000D01*
X112490000Y-55500000D02*
X111030000Y-55500000D01*
X112490000Y-58800000D02*
X112490000Y-55500000D01*
X111030000Y-58800000D02*
X112490000Y-58800000D01*
X110458000Y-89153000D02*
X110458000Y-85853000D01*
X108998000Y-89153000D02*
X110458000Y-89153000D01*
X108998000Y-85853000D02*
X108998000Y-89153000D01*
X110458000Y-85853000D02*
X108998000Y-85853000D01*
X126587000Y-89153000D02*
X126587000Y-85853000D01*
X125127000Y-89153000D02*
X126587000Y-89153000D01*
X125127000Y-85853000D02*
X125127000Y-89153000D01*
X126587000Y-85853000D02*
X125127000Y-85853000D01*
X121825000Y-55500000D02*
X121825000Y-58800000D01*
X123285000Y-55500000D02*
X121825000Y-55500000D01*
X123285000Y-58800000D02*
X123285000Y-55500000D01*
X121825000Y-58800000D02*
X123285000Y-58800000D01*
M02*

12272
pcb/v2_0/MZ80-80CLR-B_Cu.gbr Normal file

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,255 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-05T10:41:52+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,Fab,Bot*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-05 10:41:52*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.100000*%
G04 APERTURE END LIST*
D10*
X116240000Y-77994000D02*
X116240000Y-79994000D01*
X117440000Y-77994000D02*
X116240000Y-77994000D01*
X117440000Y-79994000D02*
X117440000Y-77994000D01*
X116240000Y-79994000D02*
X117440000Y-79994000D01*
X119669000Y-77994000D02*
X119669000Y-79994000D01*
X120869000Y-77994000D02*
X119669000Y-77994000D01*
X120869000Y-79994000D02*
X120869000Y-77994000D01*
X119669000Y-79994000D02*
X120869000Y-79994000D01*
X123460000Y-71974000D02*
X125460000Y-71974000D01*
X123460000Y-70774000D02*
X123460000Y-71974000D01*
X125460000Y-70774000D02*
X123460000Y-70774000D01*
X125460000Y-71974000D02*
X125460000Y-70774000D01*
X112887000Y-78013000D02*
X110887000Y-78013000D01*
X112887000Y-79213000D02*
X112887000Y-78013000D01*
X110887000Y-79213000D02*
X112887000Y-79213000D01*
X110887000Y-78013000D02*
X110887000Y-79213000D01*
X123460000Y-75530000D02*
X125460000Y-75530000D01*
X123460000Y-74330000D02*
X123460000Y-75530000D01*
X125460000Y-74330000D02*
X123460000Y-74330000D01*
X125460000Y-75530000D02*
X125460000Y-74330000D01*
X113395000Y-73060000D02*
X111395000Y-73060000D01*
X113395000Y-74260000D02*
X113395000Y-73060000D01*
X111395000Y-74260000D02*
X113395000Y-74260000D01*
X111395000Y-73060000D02*
X111395000Y-74260000D01*
X111617000Y-67853000D02*
X109617000Y-67853000D01*
X111617000Y-69053000D02*
X111617000Y-67853000D01*
X109617000Y-69053000D02*
X111617000Y-69053000D01*
X109617000Y-67853000D02*
X109617000Y-69053000D01*
X80880000Y-64859000D02*
X80880000Y-66459000D01*
X81680000Y-64859000D02*
X80880000Y-64859000D01*
X81680000Y-66459000D02*
X81680000Y-64859000D01*
X80880000Y-66459000D02*
X81680000Y-66459000D01*
X82842000Y-61068000D02*
X81242000Y-61068000D01*
X82842000Y-61868000D02*
X82842000Y-61068000D01*
X81242000Y-61868000D02*
X82842000Y-61868000D01*
X81242000Y-61068000D02*
X81242000Y-61868000D01*
X82658000Y-64859000D02*
X82658000Y-66459000D01*
X83458000Y-64859000D02*
X82658000Y-64859000D01*
X83458000Y-66459000D02*
X83458000Y-64859000D01*
X82658000Y-66459000D02*
X83458000Y-66459000D01*
X88119000Y-64859000D02*
X88119000Y-66459000D01*
X88919000Y-64859000D02*
X88119000Y-64859000D01*
X88919000Y-66459000D02*
X88919000Y-64859000D01*
X88119000Y-66459000D02*
X88919000Y-66459000D01*
X82842000Y-57766000D02*
X81242000Y-57766000D01*
X82842000Y-58566000D02*
X82842000Y-57766000D01*
X81242000Y-58566000D02*
X82842000Y-58566000D01*
X81242000Y-57766000D02*
X81242000Y-58566000D01*
X91713000Y-56426000D02*
X91713000Y-54826000D01*
X90913000Y-56426000D02*
X91713000Y-56426000D01*
X90913000Y-54826000D02*
X90913000Y-56426000D01*
X91713000Y-54826000D02*
X90913000Y-54826000D01*
X93364000Y-56426000D02*
X93364000Y-54826000D01*
X92564000Y-56426000D02*
X93364000Y-56426000D01*
X92564000Y-54826000D02*
X92564000Y-56426000D01*
X93364000Y-54826000D02*
X92564000Y-54826000D01*
X91275000Y-59328000D02*
X92875000Y-59328000D01*
X91275000Y-58528000D02*
X91275000Y-59328000D01*
X92875000Y-58528000D02*
X91275000Y-58528000D01*
X92875000Y-59328000D02*
X92875000Y-58528000D01*
X86125000Y-56426000D02*
X86125000Y-54826000D01*
X85325000Y-56426000D02*
X86125000Y-56426000D01*
X85325000Y-54826000D02*
X85325000Y-56426000D01*
X86125000Y-54826000D02*
X85325000Y-54826000D01*
X90024000Y-64859000D02*
X90024000Y-66459000D01*
X90824000Y-64859000D02*
X90024000Y-64859000D01*
X90824000Y-66459000D02*
X90824000Y-64859000D01*
X90024000Y-66459000D02*
X90824000Y-66459000D01*
X91275000Y-63011000D02*
X92875000Y-63011000D01*
X91275000Y-62211000D02*
X91275000Y-63011000D01*
X92875000Y-62211000D02*
X91275000Y-62211000D01*
X92875000Y-63011000D02*
X92875000Y-62211000D01*
X82842000Y-54718000D02*
X81242000Y-54718000D01*
X82842000Y-55518000D02*
X82842000Y-54718000D01*
X81242000Y-55518000D02*
X82842000Y-55518000D01*
X81242000Y-54718000D02*
X81242000Y-55518000D01*
X114338000Y-76435000D02*
X112738000Y-76435000D01*
X114338000Y-77235000D02*
X114338000Y-76435000D01*
X112738000Y-77235000D02*
X114338000Y-77235000D01*
X112738000Y-76435000D02*
X112738000Y-77235000D01*
X121628000Y-67075000D02*
X123228000Y-67075000D01*
X121628000Y-66275000D02*
X121628000Y-67075000D01*
X123228000Y-66275000D02*
X121628000Y-66275000D01*
X123228000Y-67075000D02*
X123228000Y-66275000D01*
X121628000Y-69107000D02*
X123228000Y-69107000D01*
X121628000Y-68307000D02*
X121628000Y-69107000D01*
X123228000Y-68307000D02*
X121628000Y-68307000D01*
X123228000Y-69107000D02*
X123228000Y-68307000D01*
X113322000Y-70466000D02*
X111722000Y-70466000D01*
X113322000Y-71266000D02*
X113322000Y-70466000D01*
X111722000Y-71266000D02*
X113322000Y-71266000D01*
X111722000Y-70466000D02*
X111722000Y-71266000D01*
X118510000Y-65875000D02*
X117710000Y-65875000D01*
X117710000Y-65875000D02*
X117710000Y-67475000D01*
X117710000Y-67475000D02*
X118510000Y-67475000D01*
X118510000Y-67475000D02*
X118510000Y-65875000D01*
X113322000Y-66275000D02*
X111722000Y-66275000D01*
X113322000Y-67075000D02*
X113322000Y-66275000D01*
X111722000Y-67075000D02*
X113322000Y-67075000D01*
X111722000Y-66275000D02*
X111722000Y-67075000D01*
X121755000Y-77235000D02*
X123355000Y-77235000D01*
X121755000Y-76435000D02*
X121755000Y-77235000D01*
X123355000Y-76435000D02*
X121755000Y-76435000D01*
X123355000Y-77235000D02*
X123355000Y-76435000D01*
X111360000Y-56350000D02*
X111360000Y-57950000D01*
X112160000Y-56350000D02*
X111360000Y-56350000D01*
X112160000Y-57950000D02*
X112160000Y-56350000D01*
X111360000Y-57950000D02*
X112160000Y-57950000D01*
X110128000Y-88303000D02*
X110128000Y-86703000D01*
X109328000Y-88303000D02*
X110128000Y-88303000D01*
X109328000Y-86703000D02*
X109328000Y-88303000D01*
X110128000Y-86703000D02*
X109328000Y-86703000D01*
X126257000Y-88303000D02*
X126257000Y-86703000D01*
X125457000Y-88303000D02*
X126257000Y-88303000D01*
X125457000Y-86703000D02*
X125457000Y-88303000D01*
X126257000Y-86703000D02*
X125457000Y-86703000D01*
X122155000Y-56350000D02*
X122155000Y-57950000D01*
X122955000Y-56350000D02*
X122155000Y-56350000D01*
X122955000Y-57950000D02*
X122955000Y-56350000D01*
X122155000Y-57950000D02*
X122955000Y-57950000D01*
M02*

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,13 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-05T10:41:52+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,Comment*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-05 10:41:52*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
G04 APERTURE END LIST*
M02*

View File

@@ -0,0 +1,13 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-05T10:41:52+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Drawing*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-05 10:41:52*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
G04 APERTURE END LIST*
M02*

View File

@@ -0,0 +1,13 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-05T10:41:52+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,ECO1*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-05 10:41:52*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
G04 APERTURE END LIST*
M02*

View File

@@ -0,0 +1,13 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-05T10:41:52+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,ECO2*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-05 10:41:52*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
G04 APERTURE END LIST*
M02*

View File

@@ -0,0 +1,27 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-05T10:41:52+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Profile,NP*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-05 10:41:52*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.100000*%
G04 APERTURE END LIST*
D10*
X133985000Y-62230000D02*
X142000000Y-62230000D01*
X133985000Y-33000000D02*
X133985000Y-62230000D01*
X133985000Y-33000000D02*
X70485000Y-33000000D01*
X142000000Y-133000000D02*
X142000000Y-62230000D01*
X70485000Y-133000000D02*
X142000000Y-133000000D01*
X70485000Y-33000000D02*
X70485000Y-133000000D01*
M02*

View File

@@ -0,0 +1,55 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-05T10:41:52+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Glue,Top*
G04 #@! TF.FilePolarity,Positive*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-05 10:41:52*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.100000*%
%ADD11C,0.083333*%
%ADD12C,0.116667*%
G04 APERTURE END LIST*
D10*
X117471000Y-88392000D02*
G75*
G03X117471000Y-88392000I-250000J0D01*
G01*
D11*
X117429333Y-88392000D02*
G75*
G03X117429333Y-88392000I-208333J0D01*
G01*
X117354333Y-88392000D02*
G75*
G03X117354333Y-88392000I-133333J0D01*
G01*
D12*
X117279333Y-88392000D02*
G75*
G03X117279333Y-88392000I-58333J0D01*
G01*
D10*
X74672000Y-72898000D02*
G75*
G03X74672000Y-72898000I-250000J0D01*
G01*
D11*
X74630333Y-72898000D02*
G75*
G03X74630333Y-72898000I-208333J0D01*
G01*
X74555333Y-72898000D02*
G75*
G03X74555333Y-72898000I-133333J0D01*
G01*
D12*
X74480333Y-72898000D02*
G75*
G03X74480333Y-72898000I-58333J0D01*
G01*
M02*

View File

@@ -0,0 +1,503 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-05T10:41:52+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,User*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-05 10:41:52*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.050000*%
G04 APERTURE END LIST*
D10*
X118647000Y-131923000D02*
X118647000Y-121823000D01*
X125447000Y-131923000D02*
X125447000Y-121823000D01*
X118647000Y-131923000D02*
X125447000Y-131923000D01*
X125447000Y-121823000D02*
X118647000Y-121823000D01*
X128298000Y-97233000D02*
X131798000Y-97233000D01*
X128298000Y-100633000D02*
X128298000Y-97233000D01*
X131798000Y-100633000D02*
X128298000Y-100633000D01*
X131798000Y-97233000D02*
X131798000Y-100633000D01*
X105948000Y-72014500D02*
X105948000Y-81164500D01*
X105948000Y-81164500D02*
X107348000Y-81164500D01*
X107348000Y-81164500D02*
X107348000Y-82264500D01*
X107348000Y-82264500D02*
X108448000Y-82264500D01*
X108448000Y-82264500D02*
X108448000Y-83664500D01*
X108448000Y-83664500D02*
X117598000Y-83664500D01*
X105948000Y-72014500D02*
X105948000Y-62864500D01*
X105948000Y-62864500D02*
X107348000Y-62864500D01*
X107348000Y-62864500D02*
X107348000Y-61764500D01*
X107348000Y-61764500D02*
X108448000Y-61764500D01*
X108448000Y-61764500D02*
X108448000Y-60364500D01*
X108448000Y-60364500D02*
X117598000Y-60364500D01*
X129248000Y-72014500D02*
X129248000Y-81164500D01*
X129248000Y-81164500D02*
X127848000Y-81164500D01*
X127848000Y-81164500D02*
X127848000Y-82264500D01*
X127848000Y-82264500D02*
X126748000Y-82264500D01*
X126748000Y-82264500D02*
X126748000Y-83664500D01*
X126748000Y-83664500D02*
X117598000Y-83664500D01*
X129248000Y-72014500D02*
X129248000Y-62864500D01*
X129248000Y-62864500D02*
X127848000Y-62864500D01*
X127848000Y-62864500D02*
X127848000Y-61764500D01*
X127848000Y-61764500D02*
X126748000Y-61764500D01*
X126748000Y-61764500D02*
X126748000Y-60364500D01*
X126748000Y-60364500D02*
X117598000Y-60364500D01*
X132550000Y-45742000D02*
X106150000Y-45742000D01*
X132550000Y-42192000D02*
X132550000Y-45742000D01*
X106150000Y-42192000D02*
X132550000Y-42192000D01*
X106150000Y-45742000D02*
X106150000Y-42192000D01*
X76201000Y-102648000D02*
X79501000Y-102648000D01*
X76201000Y-104108000D02*
X76201000Y-102648000D01*
X79501000Y-104108000D02*
X76201000Y-104108000D01*
X79501000Y-102648000D02*
X79501000Y-104108000D01*
X74251000Y-100412000D02*
X81451000Y-100412000D01*
X81451000Y-100412000D02*
X81451000Y-91612000D01*
X81451000Y-91612000D02*
X74251000Y-91612000D01*
X74251000Y-91612000D02*
X74251000Y-100412000D01*
X96780000Y-49056000D02*
X87630000Y-49056000D01*
X96780000Y-50456000D02*
X96780000Y-49056000D01*
X97880000Y-50456000D02*
X96780000Y-50456000D01*
X97880000Y-51556000D02*
X97880000Y-50456000D01*
X99280000Y-51556000D02*
X97880000Y-51556000D01*
X99280000Y-60706000D02*
X99280000Y-51556000D01*
X96780000Y-72356000D02*
X87630000Y-72356000D01*
X96780000Y-70956000D02*
X96780000Y-72356000D01*
X97880000Y-70956000D02*
X96780000Y-70956000D01*
X97880000Y-69856000D02*
X97880000Y-70956000D01*
X99280000Y-69856000D02*
X97880000Y-69856000D01*
X99280000Y-60706000D02*
X99280000Y-69856000D01*
X78480000Y-49056000D02*
X87630000Y-49056000D01*
X78480000Y-50456000D02*
X78480000Y-49056000D01*
X77380000Y-50456000D02*
X78480000Y-50456000D01*
X77380000Y-51556000D02*
X77380000Y-50456000D01*
X75980000Y-51556000D02*
X77380000Y-51556000D01*
X75980000Y-60706000D02*
X75980000Y-51556000D01*
X78480000Y-72356000D02*
X87630000Y-72356000D01*
X78480000Y-70956000D02*
X78480000Y-72356000D01*
X77380000Y-70956000D02*
X78480000Y-70956000D01*
X77380000Y-69856000D02*
X77380000Y-70956000D01*
X75980000Y-69856000D02*
X77380000Y-69856000D01*
X75980000Y-60706000D02*
X75980000Y-69856000D01*
X115221000Y-86692000D02*
X115221000Y-90092000D01*
X115221000Y-90092000D02*
X119221000Y-90092000D01*
X119221000Y-90092000D02*
X119221000Y-86692000D01*
X119221000Y-86692000D02*
X115221000Y-86692000D01*
X72422000Y-71198000D02*
X72422000Y-74598000D01*
X72422000Y-74598000D02*
X76422000Y-74598000D01*
X76422000Y-74598000D02*
X76422000Y-71198000D01*
X76422000Y-71198000D02*
X72422000Y-71198000D01*
X110076000Y-95233000D02*
X110076000Y-102633000D01*
X115476000Y-95233000D02*
X110076000Y-95233000D01*
X115476000Y-102633000D02*
X115476000Y-95233000D01*
X110076000Y-102633000D02*
X115476000Y-102633000D01*
X122113000Y-104720000D02*
X122113000Y-101020000D01*
X124013000Y-104720000D02*
X122113000Y-104720000D01*
X124013000Y-101020000D02*
X124013000Y-104720000D01*
X122113000Y-101020000D02*
X124013000Y-101020000D01*
X124013000Y-97083000D02*
X124013000Y-100783000D01*
X122113000Y-97083000D02*
X124013000Y-97083000D01*
X122113000Y-100783000D02*
X122113000Y-97083000D01*
X124013000Y-100783000D02*
X122113000Y-100783000D01*
X126177000Y-100783000D02*
X126177000Y-97083000D01*
X128077000Y-100783000D02*
X126177000Y-100783000D01*
X128077000Y-97083000D02*
X128077000Y-100783000D01*
X126177000Y-97083000D02*
X128077000Y-97083000D01*
X121981000Y-97083000D02*
X121981000Y-100783000D01*
X120081000Y-97083000D02*
X121981000Y-97083000D01*
X120081000Y-100783000D02*
X120081000Y-97083000D01*
X121981000Y-100783000D02*
X120081000Y-100783000D01*
X126045000Y-97083000D02*
X126045000Y-100783000D01*
X124145000Y-97083000D02*
X126045000Y-97083000D01*
X124145000Y-100783000D02*
X124145000Y-97083000D01*
X126045000Y-100783000D02*
X124145000Y-100783000D01*
X135951000Y-97083000D02*
X135951000Y-100783000D01*
X134051000Y-97083000D02*
X135951000Y-97083000D01*
X134051000Y-100783000D02*
X134051000Y-97083000D01*
X135951000Y-100783000D02*
X134051000Y-100783000D01*
X137983000Y-97083000D02*
X137983000Y-100783000D01*
X136083000Y-97083000D02*
X137983000Y-97083000D01*
X136083000Y-100783000D02*
X136083000Y-97083000D01*
X137983000Y-100783000D02*
X136083000Y-100783000D01*
X133919000Y-97083000D02*
X133919000Y-100783000D01*
X132019000Y-97083000D02*
X133919000Y-97083000D01*
X132019000Y-100783000D02*
X132019000Y-97083000D01*
X133919000Y-100783000D02*
X132019000Y-100783000D01*
X133405000Y-67757000D02*
X137105000Y-67757000D01*
X133405000Y-69657000D02*
X133405000Y-67757000D01*
X137105000Y-69657000D02*
X133405000Y-69657000D01*
X137105000Y-67757000D02*
X137105000Y-69657000D01*
X133405000Y-65725000D02*
X137105000Y-65725000D01*
X133405000Y-67625000D02*
X133405000Y-65725000D01*
X137105000Y-67625000D02*
X133405000Y-67625000D01*
X137105000Y-65725000D02*
X137105000Y-67625000D01*
X133405000Y-84013000D02*
X137105000Y-84013000D01*
X133405000Y-85913000D02*
X133405000Y-84013000D01*
X137105000Y-85913000D02*
X133405000Y-85913000D01*
X137105000Y-84013000D02*
X137105000Y-85913000D01*
X133405000Y-81981000D02*
X137105000Y-81981000D01*
X133405000Y-83881000D02*
X133405000Y-81981000D01*
X137105000Y-83881000D02*
X133405000Y-83881000D01*
X137105000Y-81981000D02*
X137105000Y-83881000D01*
X133405000Y-79949000D02*
X137105000Y-79949000D01*
X133405000Y-81849000D02*
X133405000Y-79949000D01*
X137105000Y-81849000D02*
X133405000Y-81849000D01*
X137105000Y-79949000D02*
X137105000Y-81849000D01*
X133405000Y-77917000D02*
X137105000Y-77917000D01*
X133405000Y-79817000D02*
X133405000Y-77917000D01*
X137105000Y-79817000D02*
X133405000Y-79817000D01*
X137105000Y-77917000D02*
X137105000Y-79817000D01*
X133405000Y-75885000D02*
X137105000Y-75885000D01*
X133405000Y-77785000D02*
X133405000Y-75885000D01*
X137105000Y-77785000D02*
X133405000Y-77785000D01*
X137105000Y-75885000D02*
X137105000Y-77785000D01*
X133405000Y-73853000D02*
X137105000Y-73853000D01*
X133405000Y-75753000D02*
X133405000Y-73853000D01*
X137105000Y-75753000D02*
X133405000Y-75753000D01*
X137105000Y-73853000D02*
X137105000Y-75753000D01*
X133405000Y-71821000D02*
X137105000Y-71821000D01*
X133405000Y-73721000D02*
X133405000Y-71821000D01*
X137105000Y-73721000D02*
X133405000Y-73721000D01*
X137105000Y-71821000D02*
X137105000Y-73721000D01*
X133405000Y-69789000D02*
X137105000Y-69789000D01*
X133405000Y-71689000D02*
X133405000Y-69789000D01*
X137105000Y-71689000D02*
X133405000Y-71689000D01*
X137105000Y-69789000D02*
X137105000Y-71689000D01*
X128833000Y-88077000D02*
X132533000Y-88077000D01*
X128833000Y-89977000D02*
X128833000Y-88077000D01*
X132533000Y-89977000D02*
X128833000Y-89977000D01*
X132533000Y-88077000D02*
X132533000Y-89977000D01*
X128833000Y-86045000D02*
X132533000Y-86045000D01*
X128833000Y-87945000D02*
X128833000Y-86045000D01*
X132533000Y-87945000D02*
X128833000Y-87945000D01*
X132533000Y-86045000D02*
X132533000Y-87945000D01*
X133405000Y-88077000D02*
X137105000Y-88077000D01*
X133405000Y-89977000D02*
X133405000Y-88077000D01*
X137105000Y-89977000D02*
X133405000Y-89977000D01*
X137105000Y-88077000D02*
X137105000Y-89977000D01*
X133405000Y-86045000D02*
X137105000Y-86045000D01*
X133405000Y-87945000D02*
X133405000Y-86045000D01*
X137105000Y-87945000D02*
X133405000Y-87945000D01*
X137105000Y-86045000D02*
X137105000Y-87945000D01*
X98099000Y-50226000D02*
X98099000Y-48326000D01*
X98099000Y-48326000D02*
X101799000Y-48326000D01*
X101799000Y-48326000D02*
X101799000Y-50226000D01*
X101799000Y-50226000D02*
X98099000Y-50226000D01*
X118679000Y-51888000D02*
X116779000Y-51888000D01*
X116779000Y-51888000D02*
X116779000Y-48188000D01*
X116779000Y-48188000D02*
X118679000Y-48188000D01*
X118679000Y-48188000D02*
X118679000Y-51888000D01*
X103577000Y-63434000D02*
X99877000Y-63434000D01*
X103577000Y-61534000D02*
X103577000Y-63434000D01*
X99877000Y-61534000D02*
X103577000Y-61534000D01*
X99877000Y-63434000D02*
X99877000Y-61534000D01*
X119949000Y-97083000D02*
X119949000Y-100783000D01*
X118049000Y-97083000D02*
X119949000Y-97083000D01*
X118049000Y-100783000D02*
X118049000Y-97083000D01*
X119949000Y-100783000D02*
X118049000Y-100783000D01*
X117917000Y-97083000D02*
X117917000Y-100783000D01*
X116017000Y-97083000D02*
X117917000Y-97083000D01*
X116017000Y-100783000D02*
X116017000Y-97083000D01*
X117917000Y-100783000D02*
X116017000Y-100783000D01*
X129564000Y-40997000D02*
X132564000Y-40997000D01*
X129564000Y-33997000D02*
X129564000Y-40997000D01*
X132564000Y-33997000D02*
X129564000Y-33997000D01*
X132564000Y-40997000D02*
X132564000Y-33997000D01*
X118850000Y-53235000D02*
X118850000Y-47135000D01*
X118850000Y-47135000D02*
X132550000Y-47135000D01*
X132550000Y-47135000D02*
X132550000Y-53235000D01*
X132550000Y-53235000D02*
X118850000Y-53235000D01*
X74644000Y-121032000D02*
X74644000Y-124332000D01*
X73184000Y-121032000D02*
X74644000Y-121032000D01*
X73184000Y-124332000D02*
X73184000Y-121032000D01*
X74644000Y-124332000D02*
X73184000Y-124332000D01*
X115442000Y-104235000D02*
X112142000Y-104235000D01*
X115442000Y-102775000D02*
X115442000Y-104235000D01*
X112142000Y-102775000D02*
X115442000Y-102775000D01*
X112142000Y-104235000D02*
X112142000Y-102775000D01*
X113570000Y-86742000D02*
X115030000Y-86742000D01*
X115030000Y-86742000D02*
X115030000Y-90042000D01*
X115030000Y-90042000D02*
X113570000Y-90042000D01*
X113570000Y-90042000D02*
X113570000Y-86742000D01*
X70771000Y-71248000D02*
X72231000Y-71248000D01*
X72231000Y-71248000D02*
X72231000Y-74548000D01*
X72231000Y-74548000D02*
X70771000Y-74548000D01*
X70771000Y-74548000D02*
X70771000Y-71248000D01*
X92031000Y-100539000D02*
X99231000Y-100539000D01*
X99231000Y-100539000D02*
X99231000Y-91739000D01*
X99231000Y-91739000D02*
X92031000Y-91739000D01*
X92031000Y-91739000D02*
X92031000Y-100539000D01*
X83268000Y-100539000D02*
X90468000Y-100539000D01*
X90468000Y-100539000D02*
X90468000Y-91739000D01*
X90468000Y-91739000D02*
X83268000Y-91739000D01*
X83268000Y-91739000D02*
X83268000Y-100539000D01*
X127363000Y-40535000D02*
X83163000Y-40535000D01*
X127363000Y-34435000D02*
X127363000Y-40535000D01*
X83163000Y-34435000D02*
X127363000Y-34435000D01*
X83163000Y-40535000D02*
X83163000Y-34435000D01*
X114800000Y-53362000D02*
X106150000Y-53362000D01*
X114800000Y-47262000D02*
X114800000Y-53362000D01*
X106150000Y-47262000D02*
X114800000Y-47262000D01*
X106150000Y-53362000D02*
X106150000Y-47262000D01*
X93092000Y-100743000D02*
X96392000Y-100743000D01*
X93092000Y-102203000D02*
X93092000Y-100743000D01*
X96392000Y-102203000D02*
X93092000Y-102203000D01*
X96392000Y-100743000D02*
X96392000Y-102203000D01*
X72518000Y-89821000D02*
X75818000Y-89821000D01*
X72518000Y-91281000D02*
X72518000Y-89821000D01*
X75818000Y-91281000D02*
X72518000Y-91281000D01*
X75818000Y-89821000D02*
X75818000Y-91281000D01*
X84075000Y-100616000D02*
X87375000Y-100616000D01*
X84075000Y-102076000D02*
X84075000Y-100616000D01*
X87375000Y-102076000D02*
X84075000Y-102076000D01*
X87375000Y-100616000D02*
X87375000Y-102076000D01*
X76201000Y-100997000D02*
X79501000Y-100997000D01*
X76201000Y-102457000D02*
X76201000Y-100997000D01*
X79501000Y-102457000D02*
X76201000Y-102457000D01*
X79501000Y-100997000D02*
X79501000Y-102457000D01*
M02*

45550
pcb/v2_0/MZ80-80CLR-F_Cu.gbr Normal file

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,642 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-05T10:41:52+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,Fab,Top*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-05 10:41:52*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.100000*%
%ADD11C,0.150000*%
G04 APERTURE END LIST*
D10*
X123797714Y-126873000D02*
G75*
G03X123797714Y-126873000I-1750714J0D01*
G01*
X119047000Y-123873000D02*
X119047000Y-129873000D01*
X125047000Y-123873000D02*
X119047000Y-123873000D01*
X125047000Y-129873000D02*
X125047000Y-123873000D01*
X119047000Y-129873000D02*
X125047000Y-129873000D01*
X128528000Y-98233000D02*
X128528000Y-99633000D01*
X131568000Y-99633000D02*
X128528000Y-99633000D01*
X130998000Y-98233000D02*
X131568000Y-98783000D01*
X131568000Y-98783000D02*
X131568000Y-99633000D01*
X130998000Y-98233000D02*
X128548000Y-98233000D01*
X107598000Y-81014500D02*
X107598000Y-62014500D01*
X107598000Y-62014500D02*
X127598000Y-62014500D01*
X127598000Y-62014500D02*
X127598000Y-82014500D01*
X127598000Y-82014500D02*
X108598000Y-82014500D01*
X108598000Y-82014500D02*
X107598000Y-81014500D01*
X132080000Y-45212000D02*
X106680000Y-45212000D01*
X132080000Y-42672000D02*
X132080000Y-45212000D01*
X107315000Y-42672000D02*
X132080000Y-42672000D01*
X106680000Y-43307000D02*
X107315000Y-42672000D01*
X106680000Y-45212000D02*
X106680000Y-43307000D01*
X77051000Y-102978000D02*
X78651000Y-102978000D01*
X77051000Y-103778000D02*
X77051000Y-102978000D01*
X78651000Y-103778000D02*
X77051000Y-103778000D01*
X78651000Y-102978000D02*
X78651000Y-103778000D01*
X74501000Y-94162000D02*
X81201000Y-94162000D01*
X81201000Y-97862000D02*
X81201000Y-94162000D01*
X74501000Y-96862000D02*
X74501000Y-94162000D01*
X75501000Y-97862000D02*
X81201000Y-97862000D01*
X75501000Y-97862000D02*
X74501000Y-96862000D01*
X76210000Y-130015000D02*
X75210000Y-129015000D01*
X78630000Y-70706000D02*
X77630000Y-69706000D01*
X97630000Y-70706000D02*
X78630000Y-70706000D01*
X97630000Y-50706000D02*
X97630000Y-70706000D01*
X77630000Y-50706000D02*
X97630000Y-50706000D01*
X77630000Y-69706000D02*
X77630000Y-50706000D01*
X115721000Y-87142000D02*
X118721000Y-87142000D01*
X118721000Y-87142000D02*
X118821000Y-87242000D01*
X118821000Y-87242000D02*
X118821000Y-89542000D01*
X118821000Y-89542000D02*
X118721000Y-89642000D01*
X118721000Y-89642000D02*
X115721000Y-89642000D01*
X115721000Y-89642000D02*
X115621000Y-89542000D01*
X115621000Y-89542000D02*
X115621000Y-87242000D01*
X115621000Y-87242000D02*
X115721000Y-87142000D01*
X115621000Y-88642000D02*
X116621000Y-89642000D01*
X72922000Y-71648000D02*
X75922000Y-71648000D01*
X75922000Y-71648000D02*
X76022000Y-71748000D01*
X76022000Y-71748000D02*
X76022000Y-74048000D01*
X76022000Y-74048000D02*
X75922000Y-74148000D01*
X75922000Y-74148000D02*
X72922000Y-74148000D01*
X72922000Y-74148000D02*
X72822000Y-74048000D01*
X72822000Y-74048000D02*
X72822000Y-71748000D01*
X72822000Y-71748000D02*
X72922000Y-71648000D01*
X72822000Y-73148000D02*
X73822000Y-74148000D01*
X111301000Y-100883000D02*
X110326000Y-99908000D01*
X115226000Y-100883000D02*
X111301000Y-100883000D01*
X115226000Y-96983000D02*
X115226000Y-100883000D01*
X110326000Y-96983000D02*
X115226000Y-96983000D01*
X110326000Y-99908000D02*
X110326000Y-96983000D01*
X122463000Y-103870000D02*
X122463000Y-101870000D01*
X123663000Y-103870000D02*
X122463000Y-103870000D01*
X123663000Y-101870000D02*
X123663000Y-103870000D01*
X122463000Y-101870000D02*
X123663000Y-101870000D01*
X123663000Y-97933000D02*
X123663000Y-99933000D01*
X122463000Y-97933000D02*
X123663000Y-97933000D01*
X122463000Y-99933000D02*
X122463000Y-97933000D01*
X123663000Y-99933000D02*
X122463000Y-99933000D01*
X126527000Y-99933000D02*
X126527000Y-97933000D01*
X127727000Y-99933000D02*
X126527000Y-99933000D01*
X127727000Y-97933000D02*
X127727000Y-99933000D01*
X126527000Y-97933000D02*
X127727000Y-97933000D01*
X121631000Y-97933000D02*
X121631000Y-99933000D01*
X120431000Y-97933000D02*
X121631000Y-97933000D01*
X120431000Y-99933000D02*
X120431000Y-97933000D01*
X121631000Y-99933000D02*
X120431000Y-99933000D01*
X125695000Y-97933000D02*
X125695000Y-99933000D01*
X124495000Y-97933000D02*
X125695000Y-97933000D01*
X124495000Y-99933000D02*
X124495000Y-97933000D01*
X125695000Y-99933000D02*
X124495000Y-99933000D01*
X135601000Y-97933000D02*
X135601000Y-99933000D01*
X134401000Y-97933000D02*
X135601000Y-97933000D01*
X134401000Y-99933000D02*
X134401000Y-97933000D01*
X135601000Y-99933000D02*
X134401000Y-99933000D01*
X137633000Y-97933000D02*
X137633000Y-99933000D01*
X136433000Y-97933000D02*
X137633000Y-97933000D01*
X136433000Y-99933000D02*
X136433000Y-97933000D01*
X137633000Y-99933000D02*
X136433000Y-99933000D01*
X133569000Y-97933000D02*
X133569000Y-99933000D01*
X132369000Y-97933000D02*
X133569000Y-97933000D01*
X132369000Y-99933000D02*
X132369000Y-97933000D01*
X133569000Y-99933000D02*
X132369000Y-99933000D01*
X134255000Y-68107000D02*
X136255000Y-68107000D01*
X134255000Y-69307000D02*
X134255000Y-68107000D01*
X136255000Y-69307000D02*
X134255000Y-69307000D01*
X136255000Y-68107000D02*
X136255000Y-69307000D01*
X134255000Y-66075000D02*
X136255000Y-66075000D01*
X134255000Y-67275000D02*
X134255000Y-66075000D01*
X136255000Y-67275000D02*
X134255000Y-67275000D01*
X136255000Y-66075000D02*
X136255000Y-67275000D01*
X134255000Y-84363000D02*
X136255000Y-84363000D01*
X134255000Y-85563000D02*
X134255000Y-84363000D01*
X136255000Y-85563000D02*
X134255000Y-85563000D01*
X136255000Y-84363000D02*
X136255000Y-85563000D01*
X134255000Y-82331000D02*
X136255000Y-82331000D01*
X134255000Y-83531000D02*
X134255000Y-82331000D01*
X136255000Y-83531000D02*
X134255000Y-83531000D01*
X136255000Y-82331000D02*
X136255000Y-83531000D01*
X134255000Y-80299000D02*
X136255000Y-80299000D01*
X134255000Y-81499000D02*
X134255000Y-80299000D01*
X136255000Y-81499000D02*
X134255000Y-81499000D01*
X136255000Y-80299000D02*
X136255000Y-81499000D01*
X134255000Y-78267000D02*
X136255000Y-78267000D01*
X134255000Y-79467000D02*
X134255000Y-78267000D01*
X136255000Y-79467000D02*
X134255000Y-79467000D01*
X136255000Y-78267000D02*
X136255000Y-79467000D01*
X134255000Y-76235000D02*
X136255000Y-76235000D01*
X134255000Y-77435000D02*
X134255000Y-76235000D01*
X136255000Y-77435000D02*
X134255000Y-77435000D01*
X136255000Y-76235000D02*
X136255000Y-77435000D01*
X134255000Y-74203000D02*
X136255000Y-74203000D01*
X134255000Y-75403000D02*
X134255000Y-74203000D01*
X136255000Y-75403000D02*
X134255000Y-75403000D01*
X136255000Y-74203000D02*
X136255000Y-75403000D01*
X134255000Y-72171000D02*
X136255000Y-72171000D01*
X134255000Y-73371000D02*
X134255000Y-72171000D01*
X136255000Y-73371000D02*
X134255000Y-73371000D01*
X136255000Y-72171000D02*
X136255000Y-73371000D01*
X134255000Y-70139000D02*
X136255000Y-70139000D01*
X134255000Y-71339000D02*
X134255000Y-70139000D01*
X136255000Y-71339000D02*
X134255000Y-71339000D01*
X136255000Y-70139000D02*
X136255000Y-71339000D01*
X129683000Y-88427000D02*
X131683000Y-88427000D01*
X129683000Y-89627000D02*
X129683000Y-88427000D01*
X131683000Y-89627000D02*
X129683000Y-89627000D01*
X131683000Y-88427000D02*
X131683000Y-89627000D01*
X129683000Y-86395000D02*
X131683000Y-86395000D01*
X129683000Y-87595000D02*
X129683000Y-86395000D01*
X131683000Y-87595000D02*
X129683000Y-87595000D01*
X131683000Y-86395000D02*
X131683000Y-87595000D01*
X134255000Y-88427000D02*
X136255000Y-88427000D01*
X134255000Y-89627000D02*
X134255000Y-88427000D01*
X136255000Y-89627000D02*
X134255000Y-89627000D01*
X136255000Y-88427000D02*
X136255000Y-89627000D01*
X134255000Y-86395000D02*
X136255000Y-86395000D01*
X134255000Y-87595000D02*
X134255000Y-86395000D01*
X136255000Y-87595000D02*
X134255000Y-87595000D01*
X136255000Y-86395000D02*
X136255000Y-87595000D01*
X98949000Y-49876000D02*
X98949000Y-48676000D01*
X98949000Y-48676000D02*
X100949000Y-48676000D01*
X100949000Y-48676000D02*
X100949000Y-49876000D01*
X100949000Y-49876000D02*
X98949000Y-49876000D01*
X118329000Y-51038000D02*
X117129000Y-51038000D01*
X117129000Y-51038000D02*
X117129000Y-49038000D01*
X117129000Y-49038000D02*
X118329000Y-49038000D01*
X118329000Y-49038000D02*
X118329000Y-51038000D01*
X102727000Y-63084000D02*
X100727000Y-63084000D01*
X102727000Y-61884000D02*
X102727000Y-63084000D01*
X100727000Y-61884000D02*
X102727000Y-61884000D01*
X100727000Y-63084000D02*
X100727000Y-61884000D01*
X119599000Y-97933000D02*
X119599000Y-99933000D01*
X118399000Y-97933000D02*
X119599000Y-97933000D01*
X118399000Y-99933000D02*
X118399000Y-97933000D01*
X119599000Y-99933000D02*
X118399000Y-99933000D01*
X117567000Y-97933000D02*
X117567000Y-99933000D01*
X116367000Y-97933000D02*
X117567000Y-97933000D01*
X116367000Y-99933000D02*
X116367000Y-97933000D01*
X117567000Y-99933000D02*
X116367000Y-99933000D01*
X132064000Y-39997000D02*
X131564000Y-40497000D01*
X132064000Y-34497000D02*
X132064000Y-39997000D01*
X130064000Y-34497000D02*
X132064000Y-34497000D01*
X130064000Y-40497000D02*
X130064000Y-34497000D01*
X131564000Y-40497000D02*
X130064000Y-40497000D01*
X119380000Y-52705000D02*
X119380000Y-48625000D01*
X119380000Y-48625000D02*
X120380000Y-47625000D01*
X120380000Y-47625000D02*
X132080000Y-47625000D01*
X132080000Y-47625000D02*
X132080000Y-52705000D01*
X132080000Y-52705000D02*
X119380000Y-52705000D01*
X74314000Y-121882000D02*
X74314000Y-123482000D01*
X73514000Y-121882000D02*
X74314000Y-121882000D01*
X73514000Y-123482000D02*
X73514000Y-121882000D01*
X74314000Y-123482000D02*
X73514000Y-123482000D01*
X114592000Y-103905000D02*
X112992000Y-103905000D01*
X114592000Y-103105000D02*
X114592000Y-103905000D01*
X112992000Y-103105000D02*
X114592000Y-103105000D01*
X112992000Y-103905000D02*
X112992000Y-103105000D01*
X113900000Y-87592000D02*
X114700000Y-87592000D01*
X114700000Y-87592000D02*
X114700000Y-89192000D01*
X114700000Y-89192000D02*
X113900000Y-89192000D01*
X113900000Y-89192000D02*
X113900000Y-87592000D01*
X71101000Y-72098000D02*
X71901000Y-72098000D01*
X71901000Y-72098000D02*
X71901000Y-73698000D01*
X71901000Y-73698000D02*
X71101000Y-73698000D01*
X71101000Y-73698000D02*
X71101000Y-72098000D01*
X92281000Y-94289000D02*
X98981000Y-94289000D01*
X98981000Y-97989000D02*
X98981000Y-94289000D01*
X92281000Y-96989000D02*
X92281000Y-94289000D01*
X93281000Y-97989000D02*
X98981000Y-97989000D01*
X93281000Y-97989000D02*
X92281000Y-96989000D01*
X83518000Y-94289000D02*
X90218000Y-94289000D01*
X90218000Y-97989000D02*
X90218000Y-94289000D01*
X83518000Y-96989000D02*
X83518000Y-94289000D01*
X84518000Y-97989000D02*
X90218000Y-97989000D01*
X84518000Y-97989000D02*
X83518000Y-96989000D01*
X126873000Y-40005000D02*
X83693000Y-40005000D01*
X126873000Y-34925000D02*
X126873000Y-40005000D01*
X84693000Y-34925000D02*
X126873000Y-34925000D01*
X83693000Y-35925000D02*
X84693000Y-34925000D01*
X83693000Y-40005000D02*
X83693000Y-35925000D01*
X114300000Y-52832000D02*
X106680000Y-52832000D01*
X114300000Y-47752000D02*
X114300000Y-52832000D01*
X107680000Y-47752000D02*
X114300000Y-47752000D01*
X106680000Y-48752000D02*
X107680000Y-47752000D01*
X106680000Y-52832000D02*
X106680000Y-48752000D01*
X93942000Y-101073000D02*
X95542000Y-101073000D01*
X93942000Y-101873000D02*
X93942000Y-101073000D01*
X95542000Y-101873000D02*
X93942000Y-101873000D01*
X95542000Y-101073000D02*
X95542000Y-101873000D01*
X73368000Y-90151000D02*
X74968000Y-90151000D01*
X73368000Y-90951000D02*
X73368000Y-90151000D01*
X74968000Y-90951000D02*
X73368000Y-90951000D01*
X74968000Y-90151000D02*
X74968000Y-90951000D01*
X84925000Y-100946000D02*
X86525000Y-100946000D01*
X84925000Y-101746000D02*
X84925000Y-100946000D01*
X86525000Y-101746000D02*
X84925000Y-101746000D01*
X86525000Y-100946000D02*
X86525000Y-101746000D01*
X77051000Y-101327000D02*
X78651000Y-101327000D01*
X77051000Y-102127000D02*
X77051000Y-101327000D01*
X78651000Y-102127000D02*
X77051000Y-102127000D01*
X78651000Y-101327000D02*
X78651000Y-102127000D01*
D11*
X118401761Y-128206333D02*
X118449380Y-128063476D01*
X118449380Y-127825380D01*
X118401761Y-127730142D01*
X118354142Y-127682523D01*
X118258904Y-127634904D01*
X118163666Y-127634904D01*
X118068428Y-127682523D01*
X118020809Y-127730142D01*
X117973190Y-127825380D01*
X117925571Y-128015857D01*
X117877952Y-128111095D01*
X117830333Y-128158714D01*
X117735095Y-128206333D01*
X117639857Y-128206333D01*
X117544619Y-128158714D01*
X117497000Y-128111095D01*
X117449380Y-128015857D01*
X117449380Y-127777761D01*
X117497000Y-127634904D01*
X117449380Y-127301571D02*
X118449380Y-127063476D01*
X117735095Y-126873000D01*
X118449380Y-126682523D01*
X117449380Y-126444428D01*
X118449380Y-125539666D02*
X118449380Y-126111095D01*
X118449380Y-125825380D02*
X117449380Y-125825380D01*
X117592238Y-125920619D01*
X117687476Y-126015857D01*
X117735095Y-126111095D01*
X117050380Y-72776404D02*
X117859904Y-72776404D01*
X117955142Y-72728785D01*
X118002761Y-72681166D01*
X118050380Y-72585928D01*
X118050380Y-72395452D01*
X118002761Y-72300214D01*
X117955142Y-72252595D01*
X117859904Y-72204976D01*
X117050380Y-72204976D01*
X117050380Y-71824023D02*
X117050380Y-71204976D01*
X117431333Y-71538309D01*
X117431333Y-71395452D01*
X117478952Y-71300214D01*
X117526571Y-71252595D01*
X117621809Y-71204976D01*
X117859904Y-71204976D01*
X117955142Y-71252595D01*
X118002761Y-71300214D01*
X118050380Y-71395452D01*
X118050380Y-71681166D01*
X118002761Y-71776404D01*
X117955142Y-71824023D01*
X119046666Y-43394380D02*
X119046666Y-44108666D01*
X118999047Y-44251523D01*
X118903809Y-44346761D01*
X118760952Y-44394380D01*
X118665714Y-44394380D01*
X119951428Y-43727714D02*
X119951428Y-44394380D01*
X119713333Y-43346761D02*
X119475238Y-44061047D01*
X120094285Y-44061047D01*
X87082380Y-61467904D02*
X87891904Y-61467904D01*
X87987142Y-61420285D01*
X88034761Y-61372666D01*
X88082380Y-61277428D01*
X88082380Y-61086952D01*
X88034761Y-60991714D01*
X87987142Y-60944095D01*
X87891904Y-60896476D01*
X87082380Y-60896476D01*
X87082380Y-59944095D02*
X87082380Y-60420285D01*
X87558571Y-60467904D01*
X87510952Y-60420285D01*
X87463333Y-60325047D01*
X87463333Y-60086952D01*
X87510952Y-59991714D01*
X87558571Y-59944095D01*
X87653809Y-59896476D01*
X87891904Y-59896476D01*
X87987142Y-59944095D01*
X88034761Y-59991714D01*
X88082380Y-60086952D01*
X88082380Y-60325047D01*
X88034761Y-60420285D01*
X87987142Y-60467904D01*
X130516380Y-38330333D02*
X131230666Y-38330333D01*
X131373523Y-38377952D01*
X131468761Y-38473190D01*
X131516380Y-38616047D01*
X131516380Y-38711285D01*
X131516380Y-37854142D02*
X130516380Y-37854142D01*
X130516380Y-37473190D01*
X130564000Y-37377952D01*
X130611619Y-37330333D01*
X130706857Y-37282714D01*
X130849714Y-37282714D01*
X130944952Y-37330333D01*
X130992571Y-37377952D01*
X131040190Y-37473190D01*
X131040190Y-37854142D01*
X131516380Y-36330333D02*
X131516380Y-36901761D01*
X131516380Y-36616047D02*
X130516380Y-36616047D01*
X130659238Y-36711285D01*
X130754476Y-36806523D01*
X130802095Y-36901761D01*
X125396666Y-49617380D02*
X125396666Y-50331666D01*
X125349047Y-50474523D01*
X125253809Y-50569761D01*
X125110952Y-50617380D01*
X125015714Y-50617380D01*
X125777619Y-49617380D02*
X126396666Y-49617380D01*
X126063333Y-49998333D01*
X126206190Y-49998333D01*
X126301428Y-50045952D01*
X126349047Y-50093571D01*
X126396666Y-50188809D01*
X126396666Y-50426904D01*
X126349047Y-50522142D01*
X126301428Y-50569761D01*
X126206190Y-50617380D01*
X125920476Y-50617380D01*
X125825238Y-50569761D01*
X125777619Y-50522142D01*
X104949666Y-36917380D02*
X104949666Y-37631666D01*
X104902047Y-37774523D01*
X104806809Y-37869761D01*
X104663952Y-37917380D01*
X104568714Y-37917380D01*
X105378238Y-37012619D02*
X105425857Y-36965000D01*
X105521095Y-36917380D01*
X105759190Y-36917380D01*
X105854428Y-36965000D01*
X105902047Y-37012619D01*
X105949666Y-37107857D01*
X105949666Y-37203095D01*
X105902047Y-37345952D01*
X105330619Y-37917380D01*
X105949666Y-37917380D01*
X110156666Y-49744380D02*
X110156666Y-50458666D01*
X110109047Y-50601523D01*
X110013809Y-50696761D01*
X109870952Y-50744380D01*
X109775714Y-50744380D01*
X111156666Y-50744380D02*
X110585238Y-50744380D01*
X110870952Y-50744380D02*
X110870952Y-49744380D01*
X110775714Y-49887238D01*
X110680476Y-49982476D01*
X110585238Y-50030095D01*
M02*

16209
pcb/v2_0/MZ80-80CLR-F_Mask.gbr Normal file

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,13 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-05T10:41:52+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,User*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-05 10:41:52*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
G04 APERTURE END LIST*
M02*

View File

@@ -0,0 +1,109 @@
%FSLAX45Y45*%
G04 Gerber Fmt 4.5, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-05 10:41:57*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.100000*%
%ADD11C,0.200000*%
%ADD12C,0.300000*%
G04 APERTURE END LIST*
D10*
X13398500Y-6223000D02*
X14200000Y-6223000D01*
X13398500Y-3300000D02*
X13398500Y-6223000D01*
X13398500Y-3300000D02*
X7048500Y-3300000D01*
X14200000Y-13300000D02*
X14200000Y-6223000D01*
X7048500Y-13300000D02*
X14200000Y-13300000D01*
X7048500Y-3300000D02*
X7048500Y-13300000D01*
D11*
D12*
X7329928Y-13770714D02*
X7329928Y-13470714D01*
X7401357Y-13470714D01*
X7444214Y-13485000D01*
X7472786Y-13513571D01*
X7487071Y-13542143D01*
X7501357Y-13599286D01*
X7501357Y-13642143D01*
X7487071Y-13699286D01*
X7472786Y-13727857D01*
X7444214Y-13756429D01*
X7401357Y-13770714D01*
X7329928Y-13770714D01*
X7629928Y-13770714D02*
X7629928Y-13570714D01*
X7629928Y-13627857D02*
X7644214Y-13599286D01*
X7658500Y-13585000D01*
X7687071Y-13570714D01*
X7715643Y-13570714D01*
X7815643Y-13770714D02*
X7815643Y-13570714D01*
X7815643Y-13470714D02*
X7801357Y-13485000D01*
X7815643Y-13499286D01*
X7829928Y-13485000D01*
X7815643Y-13470714D01*
X7815643Y-13499286D01*
X8001357Y-13770714D02*
X7972786Y-13756429D01*
X7958500Y-13727857D01*
X7958500Y-13470714D01*
X8158500Y-13770714D02*
X8129928Y-13756429D01*
X8115643Y-13727857D01*
X8115643Y-13470714D01*
X8501357Y-13770714D02*
X8501357Y-13470714D01*
X8601357Y-13685000D01*
X8701357Y-13470714D01*
X8701357Y-13770714D01*
X8972786Y-13770714D02*
X8972786Y-13613571D01*
X8958500Y-13585000D01*
X8929928Y-13570714D01*
X8872786Y-13570714D01*
X8844214Y-13585000D01*
X8972786Y-13756429D02*
X8944214Y-13770714D01*
X8872786Y-13770714D01*
X8844214Y-13756429D01*
X8829928Y-13727857D01*
X8829928Y-13699286D01*
X8844214Y-13670714D01*
X8872786Y-13656429D01*
X8944214Y-13656429D01*
X8972786Y-13642143D01*
X9115643Y-13570714D02*
X9115643Y-13870714D01*
X9115643Y-13585000D02*
X9144214Y-13570714D01*
X9201357Y-13570714D01*
X9229928Y-13585000D01*
X9244214Y-13599286D01*
X9258500Y-13627857D01*
X9258500Y-13713571D01*
X9244214Y-13742143D01*
X9229928Y-13756429D01*
X9201357Y-13770714D01*
X9144214Y-13770714D01*
X9115643Y-13756429D01*
X9387071Y-13742143D02*
X9401357Y-13756429D01*
X9387071Y-13770714D01*
X9372786Y-13756429D01*
X9387071Y-13742143D01*
X9387071Y-13770714D01*
X9387071Y-13585000D02*
X9401357Y-13599286D01*
X9387071Y-13613571D01*
X9372786Y-13599286D01*
X9387071Y-13585000D01*
X9387071Y-13613571D01*
M02*

View File

@@ -0,0 +1,13 @@
M48
; DRILL file {KiCad (5.1.2-1)-1} date Sunday, 05 July 2020 at 10:41:56
; FORMAT={-:-/ absolute / metric / decimal}
; #@! TF.CreationDate,2020-07-05T10:41:56+01:00
; #@! TF.GenerationSoftware,Kicad,Pcbnew,(5.1.2-1)-1
; #@! TF.FileFunction,NonPlated,1,2,NPTH
FMAT,2
METRIC
%
G90
G05
T0
M30

File diff suppressed because it is too large Load Diff

332
pcb/v2_0/MZ80-80CLR-PTH.drl Normal file
View File

@@ -0,0 +1,332 @@
M48
; DRILL file {KiCad (5.1.2-1)-1} date Sunday, 05 July 2020 at 10:41:56
; FORMAT={-:-/ absolute / metric / decimal}
; #@! TF.CreationDate,2020-07-05T10:41:56+01:00
; #@! TF.GenerationSoftware,Kicad,Pcbnew,(5.1.2-1)-1
; #@! TF.FileFunction,Plated,1,2,PTH
FMAT,2
METRIC
T1C0.400
T2C0.800
T3C1.000
%
G90
G05
T1
X72.473Y-89.525
X73.184Y-82.593
X73.406Y-70.739
X74.395Y-87.061
X74.907Y-47.195
X75.09Y-95.503
X75.442Y-78.494
X75.622Y-54.395
X75.626Y-56.03
X75.743Y-45.248
X75.936Y-88.804
X75.949Y-87.612
X75.95Y-81.597
X76.327Y-91.059
X76.968Y-47.491
X77.47Y-91.059
X77.851Y-97.536
X78.317Y-55.714
X78.319Y-56.826
X78.613Y-69.469
X78.613Y-91.059
X79.354Y-53.956
X79.629Y-91.059
X80.01Y-55.118
X80.01Y-58.293
X80.01Y-61.468
X80.088Y-53.26
X80.151Y-97.546
X80.852Y-105.503
X81.153Y-63.754
X82.514Y-69.661
X82.931Y-59.69
X82.942Y-97.601
X82.942Y-101.274
X84.074Y-55.245
X84.074Y-64.897
X84.127Y-56.353
X84.38Y-51.39
X85.217Y-91.059
X85.725Y-53.594
X86.233Y-91.059
X86.868Y-97.536
X87.081Y-73.834
X87.249Y-91.059
X87.503Y-64.77
X87.88Y-51.396
X88.392Y-91.059
X89.386Y-59.731
X89.63Y-52.075
X89.703Y-111.762
X90.297Y-56.515
X90.379Y-72.723
X90.424Y-67.564
X90.795Y-46.339
X91.186Y-57.912
X91.186Y-59.944
X91.186Y-61.595
X91.313Y-53.594
X91.567Y-64.897
X91.824Y-98.935
X91.824Y-101.346
X91.918Y-73.313
X92.146Y-83.545
X92.38Y-70.017
X92.49Y-48.702
X92.723Y-68.186
X92.964Y-53.594
X93.372Y-47.321
X93.535Y-69.608
X93.98Y-56.515
X93.98Y-62.611
X94.107Y-58.928
X95.005Y-54.028
X95.631Y-91.186
X95.631Y-97.536
X96.542Y-69.447
X96.567Y-47.992
X96.673Y-83.544
X98.501Y-46.914
X98.868Y-95.94
X99.167Y-100.752
X99.361Y-85.172
X99.659Y-47.247
X100.639Y-79.909
X100.639Y-84.054
X100.898Y-99.205
X101.372Y-58.956
X101.469Y-81.295
X101.469Y-85.855
X101.526Y-91.843
X101.526Y-96.941
X101.72Y-98.087
X102.151Y-49.745
X102.169Y-83.891
X103.338Y-50.842
X103.365Y-83.895
X103.935Y-61.98
X104.651Y-46.818
X104.72Y-51.265
X105.676Y-89.861
X106.546Y-91.857
X106.638Y-45.803
X106.787Y-93.495
X106.917Y-100.377
X107.085Y-56.229
X108.21Y-92.044
X108.23Y-91.024
X108.343Y-46.156
X108.585Y-67.564
X108.585Y-88.392
X108.712Y-69.342
X109.347Y-59.817
X109.494Y-100.031
X109.728Y-78.232
X109.728Y-79.375
X109.927Y-84.123
X110.109Y-73.66
X110.49Y-75.057
X110.617Y-66.675
X110.617Y-70.866
X110.709Y-65.079
X110.754Y-84.685
X111.125Y-76.419
X111.506Y-99.992
X111.633Y-69.596
X112.259Y-98.058
X112.299Y-64.612
X112.458Y-68.39
X112.666Y-99.671
X113.03Y-89.662
X113.411Y-65.659
X114.006Y-84.127
X114.413Y-54.313
X114.702Y-52.858
X114.808Y-59.817
X114.808Y-79.883
X114.934Y-81.199
X115.364Y-95.082
X115.413Y-84.599
X115.443Y-67.691
X115.522Y-99.958
X115.697Y-80.518
X115.803Y-97.085
X116.097Y-85.6
X116.332Y-63.5
X116.832Y-42.543
X116.986Y-52.74
X117.585Y-85.635
X118.603Y-85.099
X118.648Y-93.21
X118.811Y-53.607
X119.253Y-65.659
X119.761Y-88.519
X120.79Y-85.198
X121.031Y-65.659
X121.412Y-67.691
X121.468Y-86.002
X121.539Y-80.391
X121.617Y-84.077
X121.666Y-69.85
X121.666Y-74.93
X121.92Y-65.659
X122.381Y-64.596
X122.428Y-63.5
X122.555Y-77.851
X122.664Y-84.154
X123.063Y-80.01
X123.589Y-65.804
X123.922Y-86.494
X124.133Y-96.868
X124.218Y-57.708
X124.333Y-66.675
X124.333Y-68.707
X124.46Y-76.835
X125.299Y-78.536
X125.349Y-59.817
X126.111Y-84.201
X126.229Y-57.076
X126.492Y-81.153
X126.619Y-68.326
X126.619Y-71.374
X126.619Y-75.946
X126.619Y-78.994
X127.411Y-52.918
X128.264Y-86.58
X128.469Y-54.708
X128.595Y-92.897
X128.918Y-61.778
X129.404Y-57.376
X129.683Y-47.756
X130.414Y-57.341
X130.981Y-47.416
X131.57Y-52.908
X137.464Y-78.994
T2
X131.064Y-35.497
X131.064Y-37.497
X131.064Y-39.497
X76.48Y-115.03
X76.48Y-130.27
X79.02Y-115.03
X79.02Y-130.27
X81.56Y-115.03
X81.56Y-130.27
X84.1Y-115.03
X84.1Y-130.27
X86.64Y-115.03
X86.64Y-130.27
X89.18Y-115.03
X89.18Y-130.27
X91.72Y-115.03
X91.72Y-130.27
X94.26Y-115.03
X94.26Y-130.27
X96.8Y-115.03
X96.8Y-130.27
X99.34Y-115.03
X99.34Y-130.27
X101.88Y-115.03
X101.88Y-130.27
X104.42Y-115.03
X104.42Y-130.27
X106.96Y-115.03
X106.96Y-130.27
X109.5Y-115.03
X109.5Y-130.27
X110.1Y-91.61
X110.1Y-106.85
X112.64Y-91.61
X112.64Y-106.85
X115.18Y-91.61
X115.18Y-106.85
X117.72Y-91.61
X117.72Y-106.85
X120.26Y-91.61
X120.26Y-106.85
X122.8Y-91.61
X122.8Y-106.85
X125.34Y-91.61
X125.34Y-106.85
X127.88Y-91.61
X127.88Y-106.85
X130.42Y-91.61
X130.42Y-106.85
X132.96Y-91.61
X132.96Y-106.85
X135.5Y-91.61
X135.5Y-106.85
X138.04Y-91.61
X138.04Y-106.85
X75.184Y-77.089
X75.184Y-84.709
X92.964Y-77.089
X92.964Y-84.709
T3
X84.963Y-36.195
X84.963Y-38.735
X87.503Y-36.195
X87.503Y-38.735
X90.043Y-36.195
X90.043Y-38.735
X92.583Y-36.195
X92.583Y-38.735
X95.123Y-36.195
X95.123Y-38.735
X97.663Y-36.195
X97.663Y-38.735
X100.203Y-36.195
X100.203Y-38.735
X102.743Y-36.195
X102.743Y-38.735
X105.283Y-36.195
X105.283Y-38.735
X107.823Y-36.195
X107.823Y-38.735
X110.363Y-36.195
X110.363Y-38.735
X112.903Y-36.195
X112.903Y-38.735
X115.443Y-36.195
X115.443Y-38.735
X117.983Y-36.195
X117.983Y-38.735
X120.523Y-36.195
X120.523Y-38.735
X123.063Y-36.195
X123.063Y-38.735
X125.603Y-36.195
X125.603Y-38.735
X107.95Y-49.022
X107.95Y-51.562
X110.49Y-49.022
X110.49Y-51.562
X113.03Y-49.022
X113.03Y-51.562
X120.65Y-48.895
X120.65Y-51.435
X123.19Y-48.895
X123.19Y-51.435
X125.73Y-48.895
X125.73Y-51.435
X128.27Y-48.895
X128.27Y-51.435
X130.81Y-48.895
X130.81Y-51.435
X107.95Y-43.942
X110.49Y-43.942
X113.03Y-43.942
X115.57Y-43.942
X118.11Y-43.942
X120.65Y-43.942
X123.19Y-43.942
X125.73Y-43.942
X128.27Y-43.942
X130.81Y-43.942
T0
M30

Binary file not shown.

View File

@@ -0,0 +1,14 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-07T12:37:09+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Glue,Bot*
G04 #@! TF.FilePolarity,Positive*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-07 12:37:09*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
G04 APERTURE END LIST*
M02*

View File

@@ -0,0 +1,263 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-07T12:37:09+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,User*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-07 12:37:09*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.050000*%
G04 APERTURE END LIST*
D10*
X113096000Y-77314000D02*
X113096000Y-80674000D01*
X114996000Y-77314000D02*
X113096000Y-77314000D01*
X114996000Y-80674000D02*
X114996000Y-77314000D01*
X113096000Y-80674000D02*
X114996000Y-80674000D01*
X116525000Y-77314000D02*
X116525000Y-80674000D01*
X118425000Y-77314000D02*
X116525000Y-77314000D01*
X118425000Y-80674000D02*
X118425000Y-77314000D01*
X116525000Y-80674000D02*
X118425000Y-80674000D01*
X119986000Y-72324000D02*
X123346000Y-72324000D01*
X119986000Y-70424000D02*
X119986000Y-72324000D01*
X123346000Y-70424000D02*
X119986000Y-70424000D01*
X123346000Y-72324000D02*
X123346000Y-70424000D01*
X110773000Y-77663000D02*
X107413000Y-77663000D01*
X110773000Y-79563000D02*
X110773000Y-77663000D01*
X107413000Y-79563000D02*
X110773000Y-79563000D01*
X107413000Y-77663000D02*
X107413000Y-79563000D01*
X119986000Y-75880000D02*
X123346000Y-75880000D01*
X119986000Y-73980000D02*
X119986000Y-75880000D01*
X123346000Y-73980000D02*
X119986000Y-73980000D01*
X123346000Y-75880000D02*
X123346000Y-73980000D01*
X111281000Y-72710000D02*
X107921000Y-72710000D01*
X111281000Y-74610000D02*
X111281000Y-72710000D01*
X107921000Y-74610000D02*
X111281000Y-74610000D01*
X107921000Y-72710000D02*
X107921000Y-74610000D01*
X109503000Y-67503000D02*
X106143000Y-67503000D01*
X109503000Y-69403000D02*
X109503000Y-67503000D01*
X106143000Y-69403000D02*
X109503000Y-69403000D01*
X106143000Y-67503000D02*
X106143000Y-69403000D01*
X114366000Y-61269000D02*
X114366000Y-64969000D01*
X116266000Y-61269000D02*
X114366000Y-61269000D01*
X116266000Y-64969000D02*
X116266000Y-61269000D01*
X114366000Y-64969000D02*
X116266000Y-64969000D01*
X80550000Y-64263000D02*
X80550000Y-67563000D01*
X82010000Y-64263000D02*
X80550000Y-64263000D01*
X82010000Y-67563000D02*
X82010000Y-64263000D01*
X80550000Y-67563000D02*
X82010000Y-67563000D01*
X83692000Y-60992000D02*
X80392000Y-60992000D01*
X83692000Y-62452000D02*
X83692000Y-60992000D01*
X80392000Y-62452000D02*
X83692000Y-62452000D01*
X80392000Y-60992000D02*
X80392000Y-62452000D01*
X82328000Y-64263000D02*
X82328000Y-67563000D01*
X83788000Y-64263000D02*
X82328000Y-64263000D01*
X83788000Y-67563000D02*
X83788000Y-64263000D01*
X82328000Y-67563000D02*
X83788000Y-67563000D01*
X87789000Y-64263000D02*
X87789000Y-67563000D01*
X89249000Y-64263000D02*
X87789000Y-64263000D01*
X89249000Y-67563000D02*
X89249000Y-64263000D01*
X87789000Y-67563000D02*
X89249000Y-67563000D01*
X83692000Y-57690000D02*
X80392000Y-57690000D01*
X83692000Y-59150000D02*
X83692000Y-57690000D01*
X80392000Y-59150000D02*
X83692000Y-59150000D01*
X80392000Y-57690000D02*
X80392000Y-59150000D01*
X92043000Y-57530000D02*
X92043000Y-54230000D01*
X90583000Y-57530000D02*
X92043000Y-57530000D01*
X90583000Y-54230000D02*
X90583000Y-57530000D01*
X92043000Y-54230000D02*
X90583000Y-54230000D01*
X93694000Y-57530000D02*
X93694000Y-54230000D01*
X92234000Y-57530000D02*
X93694000Y-57530000D01*
X92234000Y-54230000D02*
X92234000Y-57530000D01*
X93694000Y-54230000D02*
X92234000Y-54230000D01*
X90425000Y-59912000D02*
X93725000Y-59912000D01*
X90425000Y-58452000D02*
X90425000Y-59912000D01*
X93725000Y-58452000D02*
X90425000Y-58452000D01*
X93725000Y-59912000D02*
X93725000Y-58452000D01*
X86455000Y-57530000D02*
X86455000Y-54230000D01*
X84995000Y-57530000D02*
X86455000Y-57530000D01*
X84995000Y-54230000D02*
X84995000Y-57530000D01*
X86455000Y-54230000D02*
X84995000Y-54230000D01*
X89694000Y-64263000D02*
X89694000Y-67563000D01*
X91154000Y-64263000D02*
X89694000Y-64263000D01*
X91154000Y-67563000D02*
X91154000Y-64263000D01*
X89694000Y-67563000D02*
X91154000Y-67563000D01*
X90425000Y-63595000D02*
X93725000Y-63595000D01*
X90425000Y-62135000D02*
X90425000Y-63595000D01*
X93725000Y-62135000D02*
X90425000Y-62135000D01*
X93725000Y-63595000D02*
X93725000Y-62135000D01*
X83692000Y-54642000D02*
X80392000Y-54642000D01*
X83692000Y-56102000D02*
X83692000Y-54642000D01*
X80392000Y-56102000D02*
X83692000Y-56102000D01*
X80392000Y-54642000D02*
X80392000Y-56102000D01*
X112394000Y-76105000D02*
X109094000Y-76105000D01*
X112394000Y-77565000D02*
X112394000Y-76105000D01*
X109094000Y-77565000D02*
X112394000Y-77565000D01*
X109094000Y-76105000D02*
X109094000Y-77565000D01*
X117984000Y-67405000D02*
X121284000Y-67405000D01*
X117984000Y-65945000D02*
X117984000Y-67405000D01*
X121284000Y-65945000D02*
X117984000Y-65945000D01*
X121284000Y-67405000D02*
X121284000Y-65945000D01*
X117984000Y-69437000D02*
X121284000Y-69437000D01*
X117984000Y-67977000D02*
X117984000Y-69437000D01*
X121284000Y-67977000D02*
X117984000Y-67977000D01*
X121284000Y-69437000D02*
X121284000Y-67977000D01*
X111378000Y-70136000D02*
X108078000Y-70136000D01*
X111378000Y-71596000D02*
X111378000Y-70136000D01*
X108078000Y-71596000D02*
X111378000Y-71596000D01*
X108078000Y-70136000D02*
X108078000Y-71596000D01*
X116046000Y-65025000D02*
X114586000Y-65025000D01*
X114586000Y-65025000D02*
X114586000Y-68325000D01*
X114586000Y-68325000D02*
X116046000Y-68325000D01*
X116046000Y-68325000D02*
X116046000Y-65025000D01*
X111378000Y-65945000D02*
X108078000Y-65945000D01*
X111378000Y-67405000D02*
X111378000Y-65945000D01*
X108078000Y-67405000D02*
X111378000Y-67405000D01*
X108078000Y-65945000D02*
X108078000Y-67405000D01*
X118111000Y-77565000D02*
X121411000Y-77565000D01*
X118111000Y-76105000D02*
X118111000Y-77565000D01*
X121411000Y-76105000D02*
X118111000Y-76105000D01*
X121411000Y-77565000D02*
X121411000Y-76105000D01*
X108363000Y-56262000D02*
X108363000Y-59562000D01*
X109823000Y-56262000D02*
X108363000Y-56262000D01*
X109823000Y-59562000D02*
X109823000Y-56262000D01*
X108363000Y-59562000D02*
X109823000Y-59562000D01*
X107664000Y-89153000D02*
X107664000Y-85853000D01*
X106204000Y-89153000D02*
X107664000Y-89153000D01*
X106204000Y-85853000D02*
X106204000Y-89153000D01*
X107664000Y-85853000D02*
X106204000Y-85853000D01*
X122523000Y-88899000D02*
X122523000Y-85599000D01*
X121063000Y-88899000D02*
X122523000Y-88899000D01*
X121063000Y-85599000D02*
X121063000Y-88899000D01*
X122523000Y-85599000D02*
X121063000Y-85599000D01*
X121825000Y-56262000D02*
X121825000Y-59562000D01*
X123285000Y-56262000D02*
X121825000Y-56262000D01*
X123285000Y-59562000D02*
X123285000Y-56262000D01*
X121825000Y-59562000D02*
X123285000Y-59562000D01*
M02*

15590
pcb/v2_0a/MZ80-80CLR-B_Cu.gbr Normal file

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,263 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-07T12:37:09+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,Fab,Bot*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-07 12:37:09*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.100000*%
G04 APERTURE END LIST*
D10*
X113446000Y-77994000D02*
X113446000Y-79994000D01*
X114646000Y-77994000D02*
X113446000Y-77994000D01*
X114646000Y-79994000D02*
X114646000Y-77994000D01*
X113446000Y-79994000D02*
X114646000Y-79994000D01*
X116875000Y-77994000D02*
X116875000Y-79994000D01*
X118075000Y-77994000D02*
X116875000Y-77994000D01*
X118075000Y-79994000D02*
X118075000Y-77994000D01*
X116875000Y-79994000D02*
X118075000Y-79994000D01*
X120666000Y-71974000D02*
X122666000Y-71974000D01*
X120666000Y-70774000D02*
X120666000Y-71974000D01*
X122666000Y-70774000D02*
X120666000Y-70774000D01*
X122666000Y-71974000D02*
X122666000Y-70774000D01*
X110093000Y-78013000D02*
X108093000Y-78013000D01*
X110093000Y-79213000D02*
X110093000Y-78013000D01*
X108093000Y-79213000D02*
X110093000Y-79213000D01*
X108093000Y-78013000D02*
X108093000Y-79213000D01*
X120666000Y-75530000D02*
X122666000Y-75530000D01*
X120666000Y-74330000D02*
X120666000Y-75530000D01*
X122666000Y-74330000D02*
X120666000Y-74330000D01*
X122666000Y-75530000D02*
X122666000Y-74330000D01*
X110601000Y-73060000D02*
X108601000Y-73060000D01*
X110601000Y-74260000D02*
X110601000Y-73060000D01*
X108601000Y-74260000D02*
X110601000Y-74260000D01*
X108601000Y-73060000D02*
X108601000Y-74260000D01*
X108823000Y-67853000D02*
X106823000Y-67853000D01*
X108823000Y-69053000D02*
X108823000Y-67853000D01*
X106823000Y-69053000D02*
X108823000Y-69053000D01*
X106823000Y-67853000D02*
X106823000Y-69053000D01*
X114716000Y-62119000D02*
X114716000Y-64119000D01*
X115916000Y-62119000D02*
X114716000Y-62119000D01*
X115916000Y-64119000D02*
X115916000Y-62119000D01*
X114716000Y-64119000D02*
X115916000Y-64119000D01*
X80880000Y-65113000D02*
X80880000Y-66713000D01*
X81680000Y-65113000D02*
X80880000Y-65113000D01*
X81680000Y-66713000D02*
X81680000Y-65113000D01*
X80880000Y-66713000D02*
X81680000Y-66713000D01*
X82842000Y-61322000D02*
X81242000Y-61322000D01*
X82842000Y-62122000D02*
X82842000Y-61322000D01*
X81242000Y-62122000D02*
X82842000Y-62122000D01*
X81242000Y-61322000D02*
X81242000Y-62122000D01*
X82658000Y-65113000D02*
X82658000Y-66713000D01*
X83458000Y-65113000D02*
X82658000Y-65113000D01*
X83458000Y-66713000D02*
X83458000Y-65113000D01*
X82658000Y-66713000D02*
X83458000Y-66713000D01*
X88119000Y-65113000D02*
X88119000Y-66713000D01*
X88919000Y-65113000D02*
X88119000Y-65113000D01*
X88919000Y-66713000D02*
X88919000Y-65113000D01*
X88119000Y-66713000D02*
X88919000Y-66713000D01*
X82842000Y-58020000D02*
X81242000Y-58020000D01*
X82842000Y-58820000D02*
X82842000Y-58020000D01*
X81242000Y-58820000D02*
X82842000Y-58820000D01*
X81242000Y-58020000D02*
X81242000Y-58820000D01*
X91713000Y-56680000D02*
X91713000Y-55080000D01*
X90913000Y-56680000D02*
X91713000Y-56680000D01*
X90913000Y-55080000D02*
X90913000Y-56680000D01*
X91713000Y-55080000D02*
X90913000Y-55080000D01*
X93364000Y-56680000D02*
X93364000Y-55080000D01*
X92564000Y-56680000D02*
X93364000Y-56680000D01*
X92564000Y-55080000D02*
X92564000Y-56680000D01*
X93364000Y-55080000D02*
X92564000Y-55080000D01*
X91275000Y-59582000D02*
X92875000Y-59582000D01*
X91275000Y-58782000D02*
X91275000Y-59582000D01*
X92875000Y-58782000D02*
X91275000Y-58782000D01*
X92875000Y-59582000D02*
X92875000Y-58782000D01*
X86125000Y-56680000D02*
X86125000Y-55080000D01*
X85325000Y-56680000D02*
X86125000Y-56680000D01*
X85325000Y-55080000D02*
X85325000Y-56680000D01*
X86125000Y-55080000D02*
X85325000Y-55080000D01*
X90024000Y-65113000D02*
X90024000Y-66713000D01*
X90824000Y-65113000D02*
X90024000Y-65113000D01*
X90824000Y-66713000D02*
X90824000Y-65113000D01*
X90024000Y-66713000D02*
X90824000Y-66713000D01*
X91275000Y-63265000D02*
X92875000Y-63265000D01*
X91275000Y-62465000D02*
X91275000Y-63265000D01*
X92875000Y-62465000D02*
X91275000Y-62465000D01*
X92875000Y-63265000D02*
X92875000Y-62465000D01*
X82842000Y-54972000D02*
X81242000Y-54972000D01*
X82842000Y-55772000D02*
X82842000Y-54972000D01*
X81242000Y-55772000D02*
X82842000Y-55772000D01*
X81242000Y-54972000D02*
X81242000Y-55772000D01*
X111544000Y-76435000D02*
X109944000Y-76435000D01*
X111544000Y-77235000D02*
X111544000Y-76435000D01*
X109944000Y-77235000D02*
X111544000Y-77235000D01*
X109944000Y-76435000D02*
X109944000Y-77235000D01*
X118834000Y-67075000D02*
X120434000Y-67075000D01*
X118834000Y-66275000D02*
X118834000Y-67075000D01*
X120434000Y-66275000D02*
X118834000Y-66275000D01*
X120434000Y-67075000D02*
X120434000Y-66275000D01*
X118834000Y-69107000D02*
X120434000Y-69107000D01*
X118834000Y-68307000D02*
X118834000Y-69107000D01*
X120434000Y-68307000D02*
X118834000Y-68307000D01*
X120434000Y-69107000D02*
X120434000Y-68307000D01*
X110528000Y-70466000D02*
X108928000Y-70466000D01*
X110528000Y-71266000D02*
X110528000Y-70466000D01*
X108928000Y-71266000D02*
X110528000Y-71266000D01*
X108928000Y-70466000D02*
X108928000Y-71266000D01*
X115716000Y-65875000D02*
X114916000Y-65875000D01*
X114916000Y-65875000D02*
X114916000Y-67475000D01*
X114916000Y-67475000D02*
X115716000Y-67475000D01*
X115716000Y-67475000D02*
X115716000Y-65875000D01*
X110528000Y-66275000D02*
X108928000Y-66275000D01*
X110528000Y-67075000D02*
X110528000Y-66275000D01*
X108928000Y-67075000D02*
X110528000Y-67075000D01*
X108928000Y-66275000D02*
X108928000Y-67075000D01*
X118961000Y-77235000D02*
X120561000Y-77235000D01*
X118961000Y-76435000D02*
X118961000Y-77235000D01*
X120561000Y-76435000D02*
X118961000Y-76435000D01*
X120561000Y-77235000D02*
X120561000Y-76435000D01*
X108693000Y-57112000D02*
X108693000Y-58712000D01*
X109493000Y-57112000D02*
X108693000Y-57112000D01*
X109493000Y-58712000D02*
X109493000Y-57112000D01*
X108693000Y-58712000D02*
X109493000Y-58712000D01*
X107334000Y-88303000D02*
X107334000Y-86703000D01*
X106534000Y-88303000D02*
X107334000Y-88303000D01*
X106534000Y-86703000D02*
X106534000Y-88303000D01*
X107334000Y-86703000D02*
X106534000Y-86703000D01*
X122193000Y-88049000D02*
X122193000Y-86449000D01*
X121393000Y-88049000D02*
X122193000Y-88049000D01*
X121393000Y-86449000D02*
X121393000Y-88049000D01*
X122193000Y-86449000D02*
X121393000Y-86449000D01*
X122155000Y-57112000D02*
X122155000Y-58712000D01*
X122955000Y-57112000D02*
X122155000Y-57112000D01*
X122955000Y-58712000D02*
X122955000Y-57112000D01*
X122155000Y-58712000D02*
X122955000Y-58712000D01*
M02*

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,13 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-07T12:37:09+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,Comment*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-07 12:37:09*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
G04 APERTURE END LIST*
M02*

View File

@@ -0,0 +1,13 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-07T12:37:09+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Drawing*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-07 12:37:09*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
G04 APERTURE END LIST*
M02*

View File

@@ -0,0 +1,13 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-07T12:37:09+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,ECO1*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-07 12:37:09*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
G04 APERTURE END LIST*
M02*

View File

@@ -0,0 +1,13 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-07T12:37:09+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,ECO2*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-07 12:37:09*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
G04 APERTURE END LIST*
M02*

View File

@@ -0,0 +1,27 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-07T12:37:09+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Profile,NP*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-07 12:37:09*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.100000*%
G04 APERTURE END LIST*
D10*
X133985000Y-62230000D02*
X142000000Y-62230000D01*
X133985000Y-33000000D02*
X133985000Y-62230000D01*
X133985000Y-33000000D02*
X70485000Y-33000000D01*
X142000000Y-133000000D02*
X142000000Y-62230000D01*
X70485000Y-133000000D02*
X142000000Y-133000000D01*
X70485000Y-33000000D02*
X70485000Y-133000000D01*
M02*

View File

@@ -0,0 +1,55 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-07T12:37:09+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Glue,Top*
G04 #@! TF.FilePolarity,Positive*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-07 12:37:09*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.100000*%
%ADD11C,0.083333*%
%ADD12C,0.116667*%
G04 APERTURE END LIST*
D10*
X117979000Y-86868000D02*
G75*
G03X117979000Y-86868000I-250000J0D01*
G01*
D11*
X117937333Y-86868000D02*
G75*
G03X117937333Y-86868000I-208333J0D01*
G01*
X117862333Y-86868000D02*
G75*
G03X117862333Y-86868000I-133333J0D01*
G01*
D12*
X117787333Y-86868000D02*
G75*
G03X117787333Y-86868000I-58333J0D01*
G01*
D10*
X74037000Y-37592000D02*
G75*
G03X74037000Y-37592000I-250000J0D01*
G01*
D11*
X73995333Y-37592000D02*
G75*
G03X73995333Y-37592000I-208333J0D01*
G01*
X73920333Y-37592000D02*
G75*
G03X73920333Y-37592000I-133333J0D01*
G01*
D12*
X73845333Y-37592000D02*
G75*
G03X73845333Y-37592000I-58333J0D01*
G01*
M02*

View File

@@ -0,0 +1,495 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-07T12:37:09+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,User*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-07 12:37:09*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.050000*%
G04 APERTURE END LIST*
D10*
X118647000Y-131923000D02*
X118647000Y-121823000D01*
X125447000Y-131923000D02*
X125447000Y-121823000D01*
X118647000Y-131923000D02*
X125447000Y-131923000D01*
X125447000Y-121823000D02*
X118647000Y-121823000D01*
X128044000Y-97487000D02*
X131544000Y-97487000D01*
X128044000Y-100887000D02*
X128044000Y-97487000D01*
X131544000Y-100887000D02*
X128044000Y-100887000D01*
X131544000Y-97487000D02*
X131544000Y-100887000D01*
X106150000Y-42142000D02*
X106150000Y-45742000D01*
X132600000Y-42142000D02*
X106150000Y-42142000D01*
X132600000Y-45742000D02*
X132600000Y-42142000D01*
X106150000Y-45742000D02*
X132600000Y-45742000D01*
X118850000Y-47339000D02*
X118850000Y-53489000D01*
X132600000Y-47339000D02*
X118850000Y-47339000D01*
X132600000Y-53489000D02*
X132600000Y-47339000D01*
X118850000Y-53489000D02*
X132600000Y-53489000D01*
X83163000Y-34385000D02*
X83163000Y-40535000D01*
X127413000Y-34385000D02*
X83163000Y-34385000D01*
X127413000Y-40535000D02*
X127413000Y-34385000D01*
X83163000Y-40535000D02*
X127413000Y-40535000D01*
X106150000Y-47339000D02*
X106150000Y-53489000D01*
X114800000Y-47339000D02*
X106150000Y-47339000D01*
X114800000Y-53489000D02*
X114800000Y-47339000D01*
X106150000Y-53489000D02*
X114800000Y-53489000D01*
X103154000Y-72014500D02*
X103154000Y-81164500D01*
X103154000Y-81164500D02*
X104554000Y-81164500D01*
X104554000Y-81164500D02*
X104554000Y-82264500D01*
X104554000Y-82264500D02*
X105654000Y-82264500D01*
X105654000Y-82264500D02*
X105654000Y-83664500D01*
X105654000Y-83664500D02*
X114804000Y-83664500D01*
X103154000Y-72014500D02*
X103154000Y-62864500D01*
X103154000Y-62864500D02*
X104554000Y-62864500D01*
X104554000Y-62864500D02*
X104554000Y-61764500D01*
X104554000Y-61764500D02*
X105654000Y-61764500D01*
X105654000Y-61764500D02*
X105654000Y-60364500D01*
X105654000Y-60364500D02*
X114804000Y-60364500D01*
X126454000Y-72014500D02*
X126454000Y-81164500D01*
X126454000Y-81164500D02*
X125054000Y-81164500D01*
X125054000Y-81164500D02*
X125054000Y-82264500D01*
X125054000Y-82264500D02*
X123954000Y-82264500D01*
X123954000Y-82264500D02*
X123954000Y-83664500D01*
X123954000Y-83664500D02*
X114804000Y-83664500D01*
X126454000Y-72014500D02*
X126454000Y-62864500D01*
X126454000Y-62864500D02*
X125054000Y-62864500D01*
X125054000Y-62864500D02*
X125054000Y-61764500D01*
X125054000Y-61764500D02*
X123954000Y-61764500D01*
X123954000Y-61764500D02*
X123954000Y-60364500D01*
X123954000Y-60364500D02*
X114804000Y-60364500D01*
X76201000Y-102648000D02*
X79501000Y-102648000D01*
X76201000Y-104108000D02*
X76201000Y-102648000D01*
X79501000Y-104108000D02*
X76201000Y-104108000D01*
X79501000Y-102648000D02*
X79501000Y-104108000D01*
X74251000Y-100412000D02*
X81451000Y-100412000D01*
X81451000Y-100412000D02*
X81451000Y-91612000D01*
X81451000Y-91612000D02*
X74251000Y-91612000D01*
X74251000Y-91612000D02*
X74251000Y-100412000D01*
X96780000Y-49310000D02*
X87630000Y-49310000D01*
X96780000Y-50710000D02*
X96780000Y-49310000D01*
X97880000Y-50710000D02*
X96780000Y-50710000D01*
X97880000Y-51810000D02*
X97880000Y-50710000D01*
X99280000Y-51810000D02*
X97880000Y-51810000D01*
X99280000Y-60960000D02*
X99280000Y-51810000D01*
X96780000Y-72610000D02*
X87630000Y-72610000D01*
X96780000Y-71210000D02*
X96780000Y-72610000D01*
X97880000Y-71210000D02*
X96780000Y-71210000D01*
X97880000Y-70110000D02*
X97880000Y-71210000D01*
X99280000Y-70110000D02*
X97880000Y-70110000D01*
X99280000Y-60960000D02*
X99280000Y-70110000D01*
X78480000Y-49310000D02*
X87630000Y-49310000D01*
X78480000Y-50710000D02*
X78480000Y-49310000D01*
X77380000Y-50710000D02*
X78480000Y-50710000D01*
X77380000Y-51810000D02*
X77380000Y-50710000D01*
X75980000Y-51810000D02*
X77380000Y-51810000D01*
X75980000Y-60960000D02*
X75980000Y-51810000D01*
X78480000Y-72610000D02*
X87630000Y-72610000D01*
X78480000Y-71210000D02*
X78480000Y-72610000D01*
X77380000Y-71210000D02*
X78480000Y-71210000D01*
X77380000Y-70110000D02*
X77380000Y-71210000D01*
X75980000Y-70110000D02*
X77380000Y-70110000D01*
X75980000Y-60960000D02*
X75980000Y-70110000D01*
X119429000Y-84868000D02*
X116029000Y-84868000D01*
X116029000Y-84868000D02*
X116029000Y-88868000D01*
X116029000Y-88868000D02*
X119429000Y-88868000D01*
X119429000Y-88868000D02*
X119429000Y-84868000D01*
X75487000Y-35592000D02*
X72087000Y-35592000D01*
X72087000Y-35592000D02*
X72087000Y-39592000D01*
X72087000Y-39592000D02*
X75487000Y-39592000D01*
X75487000Y-39592000D02*
X75487000Y-35592000D01*
X109822000Y-95106000D02*
X109822000Y-102506000D01*
X115222000Y-95106000D02*
X109822000Y-95106000D01*
X115222000Y-102506000D02*
X115222000Y-95106000D01*
X109822000Y-102506000D02*
X115222000Y-102506000D01*
X135691000Y-67376000D02*
X139391000Y-67376000D01*
X135691000Y-69276000D02*
X135691000Y-67376000D01*
X139391000Y-69276000D02*
X135691000Y-69276000D01*
X139391000Y-67376000D02*
X139391000Y-69276000D01*
X123632000Y-97337000D02*
X123632000Y-101037000D01*
X121732000Y-97337000D02*
X123632000Y-97337000D01*
X121732000Y-101037000D02*
X121732000Y-97337000D01*
X123632000Y-101037000D02*
X121732000Y-101037000D01*
X125796000Y-101037000D02*
X125796000Y-97337000D01*
X127696000Y-101037000D02*
X125796000Y-101037000D01*
X127696000Y-97337000D02*
X127696000Y-101037000D01*
X125796000Y-97337000D02*
X127696000Y-97337000D01*
X121600000Y-97337000D02*
X121600000Y-101037000D01*
X119700000Y-97337000D02*
X121600000Y-97337000D01*
X119700000Y-101037000D02*
X119700000Y-97337000D01*
X121600000Y-101037000D02*
X119700000Y-101037000D01*
X125664000Y-97337000D02*
X125664000Y-101037000D01*
X123764000Y-97337000D02*
X125664000Y-97337000D01*
X123764000Y-101037000D02*
X123764000Y-97337000D01*
X125664000Y-101037000D02*
X123764000Y-101037000D01*
X135824000Y-97337000D02*
X135824000Y-101037000D01*
X133924000Y-97337000D02*
X135824000Y-97337000D01*
X133924000Y-101037000D02*
X133924000Y-97337000D01*
X135824000Y-101037000D02*
X133924000Y-101037000D01*
X137856000Y-97337000D02*
X137856000Y-101037000D01*
X135956000Y-97337000D02*
X137856000Y-97337000D01*
X135956000Y-101037000D02*
X135956000Y-97337000D01*
X137856000Y-101037000D02*
X135956000Y-101037000D01*
X133792000Y-97337000D02*
X133792000Y-101037000D01*
X131892000Y-97337000D02*
X133792000Y-97337000D01*
X131892000Y-101037000D02*
X131892000Y-97337000D01*
X133792000Y-101037000D02*
X131892000Y-101037000D01*
X135691000Y-71440000D02*
X139391000Y-71440000D01*
X135691000Y-73340000D02*
X135691000Y-71440000D01*
X139391000Y-73340000D02*
X135691000Y-73340000D01*
X139391000Y-71440000D02*
X139391000Y-73340000D01*
X135691000Y-69408000D02*
X139391000Y-69408000D01*
X135691000Y-71308000D02*
X135691000Y-69408000D01*
X139391000Y-71308000D02*
X135691000Y-71308000D01*
X139391000Y-69408000D02*
X139391000Y-71308000D01*
X135691000Y-87696000D02*
X139391000Y-87696000D01*
X135691000Y-89596000D02*
X135691000Y-87696000D01*
X139391000Y-89596000D02*
X135691000Y-89596000D01*
X139391000Y-87696000D02*
X139391000Y-89596000D01*
X135691000Y-85664000D02*
X139391000Y-85664000D01*
X135691000Y-87564000D02*
X135691000Y-85664000D01*
X139391000Y-87564000D02*
X135691000Y-87564000D01*
X139391000Y-85664000D02*
X139391000Y-87564000D01*
X135691000Y-83632000D02*
X139391000Y-83632000D01*
X135691000Y-85532000D02*
X135691000Y-83632000D01*
X139391000Y-85532000D02*
X135691000Y-85532000D01*
X139391000Y-83632000D02*
X139391000Y-85532000D01*
X135691000Y-81600000D02*
X139391000Y-81600000D01*
X135691000Y-83500000D02*
X135691000Y-81600000D01*
X139391000Y-83500000D02*
X135691000Y-83500000D01*
X139391000Y-81600000D02*
X139391000Y-83500000D01*
X135691000Y-79568000D02*
X139391000Y-79568000D01*
X135691000Y-81468000D02*
X135691000Y-79568000D01*
X139391000Y-81468000D02*
X135691000Y-81468000D01*
X139391000Y-79568000D02*
X139391000Y-81468000D01*
X135691000Y-77536000D02*
X139391000Y-77536000D01*
X135691000Y-79436000D02*
X135691000Y-77536000D01*
X139391000Y-79436000D02*
X135691000Y-79436000D01*
X139391000Y-77536000D02*
X139391000Y-79436000D01*
X135691000Y-75504000D02*
X139391000Y-75504000D01*
X135691000Y-77404000D02*
X135691000Y-75504000D01*
X139391000Y-77404000D02*
X135691000Y-77404000D01*
X139391000Y-75504000D02*
X139391000Y-77404000D01*
X135691000Y-73472000D02*
X139391000Y-73472000D01*
X135691000Y-75372000D02*
X135691000Y-73472000D01*
X139391000Y-75372000D02*
X135691000Y-75372000D01*
X139391000Y-73472000D02*
X139391000Y-75372000D01*
X130738000Y-87696000D02*
X134438000Y-87696000D01*
X130738000Y-89596000D02*
X130738000Y-87696000D01*
X134438000Y-89596000D02*
X130738000Y-89596000D01*
X134438000Y-87696000D02*
X134438000Y-89596000D01*
X130738000Y-85664000D02*
X134438000Y-85664000D01*
X130738000Y-87564000D02*
X130738000Y-85664000D01*
X134438000Y-87564000D02*
X130738000Y-87564000D01*
X134438000Y-85664000D02*
X134438000Y-87564000D01*
X130738000Y-83632000D02*
X134438000Y-83632000D01*
X130738000Y-85532000D02*
X130738000Y-83632000D01*
X134438000Y-85532000D02*
X130738000Y-85532000D01*
X134438000Y-83632000D02*
X134438000Y-85532000D01*
X130738000Y-81600000D02*
X134438000Y-81600000D01*
X130738000Y-83500000D02*
X130738000Y-81600000D01*
X134438000Y-83500000D02*
X130738000Y-83500000D01*
X134438000Y-81600000D02*
X134438000Y-83500000D01*
X97591000Y-50353000D02*
X97591000Y-48453000D01*
X97591000Y-48453000D02*
X101291000Y-48453000D01*
X101291000Y-48453000D02*
X101291000Y-50353000D01*
X101291000Y-50353000D02*
X97591000Y-50353000D01*
X116779000Y-48569000D02*
X118679000Y-48569000D01*
X118679000Y-48569000D02*
X118679000Y-52269000D01*
X118679000Y-52269000D02*
X116779000Y-52269000D01*
X116779000Y-52269000D02*
X116779000Y-48569000D01*
X119568000Y-97328000D02*
X119568000Y-101028000D01*
X117668000Y-97328000D02*
X119568000Y-97328000D01*
X117668000Y-101028000D02*
X117668000Y-97328000D01*
X119568000Y-101028000D02*
X117668000Y-101028000D01*
X117536000Y-97337000D02*
X117536000Y-101037000D01*
X115636000Y-97337000D02*
X117536000Y-97337000D01*
X115636000Y-101037000D02*
X115636000Y-97337000D01*
X117536000Y-101037000D02*
X115636000Y-101037000D01*
X129564000Y-40997000D02*
X132564000Y-40997000D01*
X129564000Y-33997000D02*
X129564000Y-40997000D01*
X132564000Y-33997000D02*
X129564000Y-33997000D01*
X132564000Y-40997000D02*
X132564000Y-33997000D01*
X74644000Y-121032000D02*
X74644000Y-124332000D01*
X73184000Y-121032000D02*
X74644000Y-121032000D01*
X73184000Y-124332000D02*
X73184000Y-121032000D01*
X74644000Y-124332000D02*
X73184000Y-124332000D01*
X115188000Y-104108000D02*
X111888000Y-104108000D01*
X115188000Y-102648000D02*
X115188000Y-104108000D01*
X111888000Y-102648000D02*
X115188000Y-102648000D01*
X111888000Y-104108000D02*
X111888000Y-102648000D01*
X119539000Y-85599000D02*
X120999000Y-85599000D01*
X120999000Y-85599000D02*
X120999000Y-88899000D01*
X120999000Y-88899000D02*
X119539000Y-88899000D01*
X119539000Y-88899000D02*
X119539000Y-85599000D01*
X75437000Y-33941000D02*
X75437000Y-35401000D01*
X75437000Y-35401000D02*
X72137000Y-35401000D01*
X72137000Y-35401000D02*
X72137000Y-33941000D01*
X72137000Y-33941000D02*
X75437000Y-33941000D01*
X92031000Y-100539000D02*
X99231000Y-100539000D01*
X99231000Y-100539000D02*
X99231000Y-91739000D01*
X99231000Y-91739000D02*
X92031000Y-91739000D01*
X92031000Y-91739000D02*
X92031000Y-100539000D01*
X83268000Y-100539000D02*
X90468000Y-100539000D01*
X90468000Y-100539000D02*
X90468000Y-91739000D01*
X90468000Y-91739000D02*
X83268000Y-91739000D01*
X83268000Y-91739000D02*
X83268000Y-100539000D01*
X93092000Y-100743000D02*
X96392000Y-100743000D01*
X93092000Y-102203000D02*
X93092000Y-100743000D01*
X96392000Y-102203000D02*
X93092000Y-102203000D01*
X96392000Y-100743000D02*
X96392000Y-102203000D01*
X72518000Y-89821000D02*
X75818000Y-89821000D01*
X72518000Y-91281000D02*
X72518000Y-89821000D01*
X75818000Y-91281000D02*
X72518000Y-91281000D01*
X75818000Y-89821000D02*
X75818000Y-91281000D01*
X84075000Y-100616000D02*
X87375000Y-100616000D01*
X84075000Y-102076000D02*
X84075000Y-100616000D01*
X87375000Y-102076000D02*
X84075000Y-102076000D01*
X87375000Y-100616000D02*
X87375000Y-102076000D01*
X76201000Y-100997000D02*
X79501000Y-100997000D01*
X76201000Y-102457000D02*
X76201000Y-100997000D01*
X79501000Y-102457000D02*
X76201000Y-102457000D01*
X79501000Y-100997000D02*
X79501000Y-102457000D01*
M02*

48061
pcb/v2_0a/MZ80-80CLR-F_Cu.gbr Normal file

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,593 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-07T12:37:09+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,Fab,Top*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-07 12:37:09*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.100000*%
%ADD11C,0.150000*%
G04 APERTURE END LIST*
D10*
X123797714Y-126873000D02*
G75*
G03X123797714Y-126873000I-1750714J0D01*
G01*
X119047000Y-123873000D02*
X119047000Y-129873000D01*
X125047000Y-123873000D02*
X119047000Y-123873000D01*
X125047000Y-129873000D02*
X125047000Y-123873000D01*
X119047000Y-129873000D02*
X125047000Y-129873000D01*
X128274000Y-98487000D02*
X128274000Y-99887000D01*
X131314000Y-99887000D02*
X128274000Y-99887000D01*
X130744000Y-98487000D02*
X131314000Y-99037000D01*
X131314000Y-99037000D02*
X131314000Y-99887000D01*
X130744000Y-98487000D02*
X128294000Y-98487000D01*
X107315000Y-45212000D02*
X106680000Y-44577000D01*
X132080000Y-45212000D02*
X107315000Y-45212000D01*
X132080000Y-42672000D02*
X132080000Y-45212000D01*
X106680000Y-42672000D02*
X132080000Y-42672000D01*
X106680000Y-44577000D02*
X106680000Y-42672000D01*
X120650000Y-52959000D02*
X119380000Y-51689000D01*
X132080000Y-52959000D02*
X120650000Y-52959000D01*
X132080000Y-47879000D02*
X132080000Y-52959000D01*
X119380000Y-47879000D02*
X132080000Y-47879000D01*
X119380000Y-51689000D02*
X119380000Y-47879000D01*
X84963000Y-40005000D02*
X83693000Y-38735000D01*
X126873000Y-40005000D02*
X84963000Y-40005000D01*
X126873000Y-34925000D02*
X126873000Y-40005000D01*
X83693000Y-34925000D02*
X126873000Y-34925000D01*
X83693000Y-38735000D02*
X83693000Y-34925000D01*
X107950000Y-52959000D02*
X106680000Y-51689000D01*
X114300000Y-52959000D02*
X107950000Y-52959000D01*
X114300000Y-47879000D02*
X114300000Y-52959000D01*
X106680000Y-47879000D02*
X114300000Y-47879000D01*
X106680000Y-51689000D02*
X106680000Y-47879000D01*
X104804000Y-81014500D02*
X104804000Y-62014500D01*
X104804000Y-62014500D02*
X124804000Y-62014500D01*
X124804000Y-62014500D02*
X124804000Y-82014500D01*
X124804000Y-82014500D02*
X105804000Y-82014500D01*
X105804000Y-82014500D02*
X104804000Y-81014500D01*
X77051000Y-102978000D02*
X78651000Y-102978000D01*
X77051000Y-103778000D02*
X77051000Y-102978000D01*
X78651000Y-103778000D02*
X77051000Y-103778000D01*
X78651000Y-102978000D02*
X78651000Y-103778000D01*
X74501000Y-94162000D02*
X81201000Y-94162000D01*
X81201000Y-97862000D02*
X81201000Y-94162000D01*
X74501000Y-96862000D02*
X74501000Y-94162000D01*
X75501000Y-97862000D02*
X81201000Y-97862000D01*
X75501000Y-97862000D02*
X74501000Y-96862000D01*
X76210000Y-130015000D02*
X75210000Y-129015000D01*
X78630000Y-70960000D02*
X77630000Y-69960000D01*
X97630000Y-70960000D02*
X78630000Y-70960000D01*
X97630000Y-50960000D02*
X97630000Y-70960000D01*
X77630000Y-50960000D02*
X97630000Y-50960000D01*
X77630000Y-69960000D02*
X77630000Y-50960000D01*
X118979000Y-85368000D02*
X118979000Y-88368000D01*
X118979000Y-88368000D02*
X118879000Y-88468000D01*
X118879000Y-88468000D02*
X116579000Y-88468000D01*
X116579000Y-88468000D02*
X116479000Y-88368000D01*
X116479000Y-88368000D02*
X116479000Y-85368000D01*
X116479000Y-85368000D02*
X116579000Y-85268000D01*
X116579000Y-85268000D02*
X118879000Y-85268000D01*
X118879000Y-85268000D02*
X118979000Y-85368000D01*
X117479000Y-85268000D02*
X116479000Y-86268000D01*
X75037000Y-36092000D02*
X75037000Y-39092000D01*
X75037000Y-39092000D02*
X74937000Y-39192000D01*
X74937000Y-39192000D02*
X72637000Y-39192000D01*
X72637000Y-39192000D02*
X72537000Y-39092000D01*
X72537000Y-39092000D02*
X72537000Y-36092000D01*
X72537000Y-36092000D02*
X72637000Y-35992000D01*
X72637000Y-35992000D02*
X74937000Y-35992000D01*
X74937000Y-35992000D02*
X75037000Y-36092000D01*
X73537000Y-35992000D02*
X72537000Y-36992000D01*
X111047000Y-100756000D02*
X110072000Y-99781000D01*
X114972000Y-100756000D02*
X111047000Y-100756000D01*
X114972000Y-96856000D02*
X114972000Y-100756000D01*
X110072000Y-96856000D02*
X114972000Y-96856000D01*
X110072000Y-99781000D02*
X110072000Y-96856000D01*
X136541000Y-67726000D02*
X138541000Y-67726000D01*
X136541000Y-68926000D02*
X136541000Y-67726000D01*
X138541000Y-68926000D02*
X136541000Y-68926000D01*
X138541000Y-67726000D02*
X138541000Y-68926000D01*
X123282000Y-98187000D02*
X123282000Y-100187000D01*
X122082000Y-98187000D02*
X123282000Y-98187000D01*
X122082000Y-100187000D02*
X122082000Y-98187000D01*
X123282000Y-100187000D02*
X122082000Y-100187000D01*
X126146000Y-100187000D02*
X126146000Y-98187000D01*
X127346000Y-100187000D02*
X126146000Y-100187000D01*
X127346000Y-98187000D02*
X127346000Y-100187000D01*
X126146000Y-98187000D02*
X127346000Y-98187000D01*
X121250000Y-98187000D02*
X121250000Y-100187000D01*
X120050000Y-98187000D02*
X121250000Y-98187000D01*
X120050000Y-100187000D02*
X120050000Y-98187000D01*
X121250000Y-100187000D02*
X120050000Y-100187000D01*
X125314000Y-98187000D02*
X125314000Y-100187000D01*
X124114000Y-98187000D02*
X125314000Y-98187000D01*
X124114000Y-100187000D02*
X124114000Y-98187000D01*
X125314000Y-100187000D02*
X124114000Y-100187000D01*
X135474000Y-98187000D02*
X135474000Y-100187000D01*
X134274000Y-98187000D02*
X135474000Y-98187000D01*
X134274000Y-100187000D02*
X134274000Y-98187000D01*
X135474000Y-100187000D02*
X134274000Y-100187000D01*
X137506000Y-98187000D02*
X137506000Y-100187000D01*
X136306000Y-98187000D02*
X137506000Y-98187000D01*
X136306000Y-100187000D02*
X136306000Y-98187000D01*
X137506000Y-100187000D02*
X136306000Y-100187000D01*
X133442000Y-98187000D02*
X133442000Y-100187000D01*
X132242000Y-98187000D02*
X133442000Y-98187000D01*
X132242000Y-100187000D02*
X132242000Y-98187000D01*
X133442000Y-100187000D02*
X132242000Y-100187000D01*
X136541000Y-71790000D02*
X138541000Y-71790000D01*
X136541000Y-72990000D02*
X136541000Y-71790000D01*
X138541000Y-72990000D02*
X136541000Y-72990000D01*
X138541000Y-71790000D02*
X138541000Y-72990000D01*
X136541000Y-69758000D02*
X138541000Y-69758000D01*
X136541000Y-70958000D02*
X136541000Y-69758000D01*
X138541000Y-70958000D02*
X136541000Y-70958000D01*
X138541000Y-69758000D02*
X138541000Y-70958000D01*
X136541000Y-88046000D02*
X138541000Y-88046000D01*
X136541000Y-89246000D02*
X136541000Y-88046000D01*
X138541000Y-89246000D02*
X136541000Y-89246000D01*
X138541000Y-88046000D02*
X138541000Y-89246000D01*
X136541000Y-86014000D02*
X138541000Y-86014000D01*
X136541000Y-87214000D02*
X136541000Y-86014000D01*
X138541000Y-87214000D02*
X136541000Y-87214000D01*
X138541000Y-86014000D02*
X138541000Y-87214000D01*
X136541000Y-83982000D02*
X138541000Y-83982000D01*
X136541000Y-85182000D02*
X136541000Y-83982000D01*
X138541000Y-85182000D02*
X136541000Y-85182000D01*
X138541000Y-83982000D02*
X138541000Y-85182000D01*
X136541000Y-81950000D02*
X138541000Y-81950000D01*
X136541000Y-83150000D02*
X136541000Y-81950000D01*
X138541000Y-83150000D02*
X136541000Y-83150000D01*
X138541000Y-81950000D02*
X138541000Y-83150000D01*
X136541000Y-79918000D02*
X138541000Y-79918000D01*
X136541000Y-81118000D02*
X136541000Y-79918000D01*
X138541000Y-81118000D02*
X136541000Y-81118000D01*
X138541000Y-79918000D02*
X138541000Y-81118000D01*
X136541000Y-77886000D02*
X138541000Y-77886000D01*
X136541000Y-79086000D02*
X136541000Y-77886000D01*
X138541000Y-79086000D02*
X136541000Y-79086000D01*
X138541000Y-77886000D02*
X138541000Y-79086000D01*
X136541000Y-75854000D02*
X138541000Y-75854000D01*
X136541000Y-77054000D02*
X136541000Y-75854000D01*
X138541000Y-77054000D02*
X136541000Y-77054000D01*
X138541000Y-75854000D02*
X138541000Y-77054000D01*
X136541000Y-73822000D02*
X138541000Y-73822000D01*
X136541000Y-75022000D02*
X136541000Y-73822000D01*
X138541000Y-75022000D02*
X136541000Y-75022000D01*
X138541000Y-73822000D02*
X138541000Y-75022000D01*
X131588000Y-88046000D02*
X133588000Y-88046000D01*
X131588000Y-89246000D02*
X131588000Y-88046000D01*
X133588000Y-89246000D02*
X131588000Y-89246000D01*
X133588000Y-88046000D02*
X133588000Y-89246000D01*
X131588000Y-86014000D02*
X133588000Y-86014000D01*
X131588000Y-87214000D02*
X131588000Y-86014000D01*
X133588000Y-87214000D02*
X131588000Y-87214000D01*
X133588000Y-86014000D02*
X133588000Y-87214000D01*
X131588000Y-83982000D02*
X133588000Y-83982000D01*
X131588000Y-85182000D02*
X131588000Y-83982000D01*
X133588000Y-85182000D02*
X131588000Y-85182000D01*
X133588000Y-83982000D02*
X133588000Y-85182000D01*
X131588000Y-81950000D02*
X133588000Y-81950000D01*
X131588000Y-83150000D02*
X131588000Y-81950000D01*
X133588000Y-83150000D02*
X131588000Y-83150000D01*
X133588000Y-81950000D02*
X133588000Y-83150000D01*
X98441000Y-50003000D02*
X98441000Y-48803000D01*
X98441000Y-48803000D02*
X100441000Y-48803000D01*
X100441000Y-48803000D02*
X100441000Y-50003000D01*
X100441000Y-50003000D02*
X98441000Y-50003000D01*
X117129000Y-49419000D02*
X118329000Y-49419000D01*
X118329000Y-49419000D02*
X118329000Y-51419000D01*
X118329000Y-51419000D02*
X117129000Y-51419000D01*
X117129000Y-51419000D02*
X117129000Y-49419000D01*
X119218000Y-98178000D02*
X119218000Y-100178000D01*
X118018000Y-98178000D02*
X119218000Y-98178000D01*
X118018000Y-100178000D02*
X118018000Y-98178000D01*
X119218000Y-100178000D02*
X118018000Y-100178000D01*
X117186000Y-98187000D02*
X117186000Y-100187000D01*
X115986000Y-98187000D02*
X117186000Y-98187000D01*
X115986000Y-100187000D02*
X115986000Y-98187000D01*
X117186000Y-100187000D02*
X115986000Y-100187000D01*
X132064000Y-39997000D02*
X131564000Y-40497000D01*
X132064000Y-34497000D02*
X132064000Y-39997000D01*
X130064000Y-34497000D02*
X132064000Y-34497000D01*
X130064000Y-40497000D02*
X130064000Y-34497000D01*
X131564000Y-40497000D02*
X130064000Y-40497000D01*
X74314000Y-121882000D02*
X74314000Y-123482000D01*
X73514000Y-121882000D02*
X74314000Y-121882000D01*
X73514000Y-123482000D02*
X73514000Y-121882000D01*
X74314000Y-123482000D02*
X73514000Y-123482000D01*
X114338000Y-103778000D02*
X112738000Y-103778000D01*
X114338000Y-102978000D02*
X114338000Y-103778000D01*
X112738000Y-102978000D02*
X114338000Y-102978000D01*
X112738000Y-103778000D02*
X112738000Y-102978000D01*
X119869000Y-86449000D02*
X120669000Y-86449000D01*
X120669000Y-86449000D02*
X120669000Y-88049000D01*
X120669000Y-88049000D02*
X119869000Y-88049000D01*
X119869000Y-88049000D02*
X119869000Y-86449000D01*
X74587000Y-34271000D02*
X74587000Y-35071000D01*
X74587000Y-35071000D02*
X72987000Y-35071000D01*
X72987000Y-35071000D02*
X72987000Y-34271000D01*
X72987000Y-34271000D02*
X74587000Y-34271000D01*
X92281000Y-94289000D02*
X98981000Y-94289000D01*
X98981000Y-97989000D02*
X98981000Y-94289000D01*
X92281000Y-96989000D02*
X92281000Y-94289000D01*
X93281000Y-97989000D02*
X98981000Y-97989000D01*
X93281000Y-97989000D02*
X92281000Y-96989000D01*
X83518000Y-94289000D02*
X90218000Y-94289000D01*
X90218000Y-97989000D02*
X90218000Y-94289000D01*
X83518000Y-96989000D02*
X83518000Y-94289000D01*
X84518000Y-97989000D02*
X90218000Y-97989000D01*
X84518000Y-97989000D02*
X83518000Y-96989000D01*
X93942000Y-101073000D02*
X95542000Y-101073000D01*
X93942000Y-101873000D02*
X93942000Y-101073000D01*
X95542000Y-101873000D02*
X93942000Y-101873000D01*
X95542000Y-101073000D02*
X95542000Y-101873000D01*
X73368000Y-90151000D02*
X74968000Y-90151000D01*
X73368000Y-90951000D02*
X73368000Y-90151000D01*
X74968000Y-90951000D02*
X73368000Y-90951000D01*
X74968000Y-90151000D02*
X74968000Y-90951000D01*
X84925000Y-100946000D02*
X86525000Y-100946000D01*
X84925000Y-101746000D02*
X84925000Y-100946000D01*
X86525000Y-101746000D02*
X84925000Y-101746000D01*
X86525000Y-100946000D02*
X86525000Y-101746000D01*
X77051000Y-101327000D02*
X78651000Y-101327000D01*
X77051000Y-102127000D02*
X77051000Y-101327000D01*
X78651000Y-102127000D02*
X77051000Y-102127000D01*
X78651000Y-101327000D02*
X78651000Y-102127000D01*
D11*
X118401761Y-128206333D02*
X118449380Y-128063476D01*
X118449380Y-127825380D01*
X118401761Y-127730142D01*
X118354142Y-127682523D01*
X118258904Y-127634904D01*
X118163666Y-127634904D01*
X118068428Y-127682523D01*
X118020809Y-127730142D01*
X117973190Y-127825380D01*
X117925571Y-128015857D01*
X117877952Y-128111095D01*
X117830333Y-128158714D01*
X117735095Y-128206333D01*
X117639857Y-128206333D01*
X117544619Y-128158714D01*
X117497000Y-128111095D01*
X117449380Y-128015857D01*
X117449380Y-127777761D01*
X117497000Y-127634904D01*
X117449380Y-127301571D02*
X118449380Y-127063476D01*
X117735095Y-126873000D01*
X118449380Y-126682523D01*
X117449380Y-126444428D01*
X118449380Y-125539666D02*
X118449380Y-126111095D01*
X118449380Y-125825380D02*
X117449380Y-125825380D01*
X117592238Y-125920619D01*
X117687476Y-126015857D01*
X117735095Y-126111095D01*
X125396666Y-49871380D02*
X125396666Y-50585666D01*
X125349047Y-50728523D01*
X125253809Y-50823761D01*
X125110952Y-50871380D01*
X125015714Y-50871380D01*
X125777619Y-49871380D02*
X126396666Y-49871380D01*
X126063333Y-50252333D01*
X126206190Y-50252333D01*
X126301428Y-50299952D01*
X126349047Y-50347571D01*
X126396666Y-50442809D01*
X126396666Y-50680904D01*
X126349047Y-50776142D01*
X126301428Y-50823761D01*
X126206190Y-50871380D01*
X125920476Y-50871380D01*
X125825238Y-50823761D01*
X125777619Y-50776142D01*
X114256380Y-72776404D02*
X115065904Y-72776404D01*
X115161142Y-72728785D01*
X115208761Y-72681166D01*
X115256380Y-72585928D01*
X115256380Y-72395452D01*
X115208761Y-72300214D01*
X115161142Y-72252595D01*
X115065904Y-72204976D01*
X114256380Y-72204976D01*
X114256380Y-71824023D02*
X114256380Y-71204976D01*
X114637333Y-71538309D01*
X114637333Y-71395452D01*
X114684952Y-71300214D01*
X114732571Y-71252595D01*
X114827809Y-71204976D01*
X115065904Y-71204976D01*
X115161142Y-71252595D01*
X115208761Y-71300214D01*
X115256380Y-71395452D01*
X115256380Y-71681166D01*
X115208761Y-71776404D01*
X115161142Y-71824023D01*
X87082380Y-61721904D02*
X87891904Y-61721904D01*
X87987142Y-61674285D01*
X88034761Y-61626666D01*
X88082380Y-61531428D01*
X88082380Y-61340952D01*
X88034761Y-61245714D01*
X87987142Y-61198095D01*
X87891904Y-61150476D01*
X87082380Y-61150476D01*
X87082380Y-60198095D02*
X87082380Y-60674285D01*
X87558571Y-60721904D01*
X87510952Y-60674285D01*
X87463333Y-60579047D01*
X87463333Y-60340952D01*
X87510952Y-60245714D01*
X87558571Y-60198095D01*
X87653809Y-60150476D01*
X87891904Y-60150476D01*
X87987142Y-60198095D01*
X88034761Y-60245714D01*
X88082380Y-60340952D01*
X88082380Y-60579047D01*
X88034761Y-60674285D01*
X87987142Y-60721904D01*
X130516380Y-38330333D02*
X131230666Y-38330333D01*
X131373523Y-38377952D01*
X131468761Y-38473190D01*
X131516380Y-38616047D01*
X131516380Y-38711285D01*
X131516380Y-37854142D02*
X130516380Y-37854142D01*
X130516380Y-37473190D01*
X130564000Y-37377952D01*
X130611619Y-37330333D01*
X130706857Y-37282714D01*
X130849714Y-37282714D01*
X130944952Y-37330333D01*
X130992571Y-37377952D01*
X131040190Y-37473190D01*
X131040190Y-37854142D01*
X131516380Y-36330333D02*
X131516380Y-36901761D01*
X131516380Y-36616047D02*
X130516380Y-36616047D01*
X130659238Y-36711285D01*
X130754476Y-36806523D01*
X130802095Y-36901761D01*
M02*

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,13 @@
G04 #@! TF.GenerationSoftware,KiCad,Pcbnew,(5.1.2-1)-1*
G04 #@! TF.CreationDate,2020-07-07T12:37:09+01:00*
G04 #@! TF.ProjectId,MZ80-80CLR,4d5a3830-2d38-4304-934c-522e6b696361,rev?*
G04 #@! TF.SameCoordinates,Original*
G04 #@! TF.FileFunction,Other,User*
%FSLAX46Y46*%
G04 Gerber Fmt 4.6, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-07 12:37:09*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
G04 APERTURE END LIST*
M02*

View File

@@ -0,0 +1,109 @@
%FSLAX45Y45*%
G04 Gerber Fmt 4.5, Leading zero omitted, Abs format (unit mm)*
G04 Created by KiCad (PCBNEW (5.1.2-1)-1) date 2020-07-07 12:36:55*
%MOMM*%
%LPD*%
G04 APERTURE LIST*
%ADD10C,0.100000*%
%ADD11C,0.200000*%
%ADD12C,0.300000*%
G04 APERTURE END LIST*
D10*
X13398500Y-6223000D02*
X14200000Y-6223000D01*
X13398500Y-3300000D02*
X13398500Y-6223000D01*
X13398500Y-3300000D02*
X7048500Y-3300000D01*
X14200000Y-13300000D02*
X14200000Y-6223000D01*
X7048500Y-13300000D02*
X14200000Y-13300000D01*
X7048500Y-3300000D02*
X7048500Y-13300000D01*
D11*
D12*
X7329928Y-13770714D02*
X7329928Y-13470714D01*
X7401357Y-13470714D01*
X7444214Y-13485000D01*
X7472786Y-13513571D01*
X7487071Y-13542143D01*
X7501357Y-13599286D01*
X7501357Y-13642143D01*
X7487071Y-13699286D01*
X7472786Y-13727857D01*
X7444214Y-13756429D01*
X7401357Y-13770714D01*
X7329928Y-13770714D01*
X7629928Y-13770714D02*
X7629928Y-13570714D01*
X7629928Y-13627857D02*
X7644214Y-13599286D01*
X7658500Y-13585000D01*
X7687071Y-13570714D01*
X7715643Y-13570714D01*
X7815643Y-13770714D02*
X7815643Y-13570714D01*
X7815643Y-13470714D02*
X7801357Y-13485000D01*
X7815643Y-13499286D01*
X7829928Y-13485000D01*
X7815643Y-13470714D01*
X7815643Y-13499286D01*
X8001357Y-13770714D02*
X7972786Y-13756429D01*
X7958500Y-13727857D01*
X7958500Y-13470714D01*
X8158500Y-13770714D02*
X8129928Y-13756429D01*
X8115643Y-13727857D01*
X8115643Y-13470714D01*
X8501357Y-13770714D02*
X8501357Y-13470714D01*
X8601357Y-13685000D01*
X8701357Y-13470714D01*
X8701357Y-13770714D01*
X8972786Y-13770714D02*
X8972786Y-13613571D01*
X8958500Y-13585000D01*
X8929928Y-13570714D01*
X8872786Y-13570714D01*
X8844214Y-13585000D01*
X8972786Y-13756429D02*
X8944214Y-13770714D01*
X8872786Y-13770714D01*
X8844214Y-13756429D01*
X8829928Y-13727857D01*
X8829928Y-13699286D01*
X8844214Y-13670714D01*
X8872786Y-13656429D01*
X8944214Y-13656429D01*
X8972786Y-13642143D01*
X9115643Y-13570714D02*
X9115643Y-13870714D01*
X9115643Y-13585000D02*
X9144214Y-13570714D01*
X9201357Y-13570714D01*
X9229928Y-13585000D01*
X9244214Y-13599286D01*
X9258500Y-13627857D01*
X9258500Y-13713571D01*
X9244214Y-13742143D01*
X9229928Y-13756429D01*
X9201357Y-13770714D01*
X9144214Y-13770714D01*
X9115643Y-13756429D01*
X9387071Y-13742143D02*
X9401357Y-13756429D01*
X9387071Y-13770714D01*
X9372786Y-13756429D01*
X9387071Y-13742143D01*
X9387071Y-13770714D01*
X9387071Y-13585000D02*
X9401357Y-13599286D01*
X9387071Y-13613571D01*
X9372786Y-13599286D01*
X9387071Y-13585000D01*
X9387071Y-13613571D01*
M02*

View File

@@ -0,0 +1,13 @@
M48
; DRILL file {KiCad (5.1.2-1)-1} date Tuesday, 07 July 2020 at 12:36:56
; FORMAT={-:-/ absolute / metric / decimal}
; #@! TF.CreationDate,2020-07-07T12:36:56+01:00
; #@! TF.GenerationSoftware,Kicad,Pcbnew,(5.1.2-1)-1
; #@! TF.FileFunction,NonPlated,1,2,NPTH
FMAT,2
METRIC
%
G90
G05
T0
M30

Some files were not shown because too many files have changed in this diff Show More