亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? t65_alu.vhd

?? VHDL source codes of a 65xx compatible cpu core. Version 302.
?? VHD
字號:
-- ****
-- T65(b) core. In an effort to merge and maintain bug fixes ....
--
--
-- Ver 300 Bugfixes by ehenciak added
-- MikeJ March 2005
-- Latest version from www.fpgaarcade.com (original www.opencores.org)
--
-- ****
--
-- 6502 compatible microprocessor core
--
-- Version : 0245
--
-- Copyright (c) 2002 Daniel Wallner (jesus@opencores.org)
--
-- All rights reserved
--
-- Redistribution and use in source and synthezised forms, with or without
-- modification, are permitted provided that the following conditions are met:
--
-- Redistributions of source code must retain the above copyright notice,
-- this list of conditions and the following disclaimer.
--
-- Redistributions in synthesized form must reproduce the above copyright
-- notice, this list of conditions and the following disclaimer in the
-- documentation and/or other materials provided with the distribution.
--
-- Neither the name of the author nor the names of other contributors may
-- be used to endorse or promote products derived from this software without
-- specific prior written permission.
--
-- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
-- AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
-- THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
-- PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE
-- LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
-- CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
-- SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
-- INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
-- CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
-- ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
-- POSSIBILITY OF SUCH DAMAGE.
--
-- Please report bugs to the author, but before you do so, please
-- make sure that this is not a derivative work and that
-- you have the latest version of this file.
--
-- The latest version of this file can be found at:
--      http://www.opencores.org/cvsweb.shtml/t65/
--
-- Limitations :
--
-- File history :
--
--      0245 : First version
--

library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.numeric_std.all;
use work.T65_Pack.all;

entity T65_ALU is
	port(
		Mode    : in std_logic_vector(1 downto 0);      -- "00" => 6502, "01" => 65C02, "10" => 65816
		Op      : in std_logic_vector(3 downto 0);
		BusA    : in std_logic_vector(7 downto 0);
		BusB    : in std_logic_vector(7 downto 0);
		P_In    : in std_logic_vector(7 downto 0);
		P_Out   : out std_logic_vector(7 downto 0);
		Q       : out std_logic_vector(7 downto 0)
	);
end T65_ALU;

architecture rtl of T65_ALU is

	-- AddSub variables (temporary signals)
	signal      ADC_Z           : std_logic;
	signal      ADC_C           : std_logic;
	signal      ADC_V           : std_logic;
	signal      ADC_N           : std_logic;
	signal      ADC_Q           : std_logic_vector(7 downto 0);
	signal      SBC_Z           : std_logic;
	signal      SBC_C           : std_logic;
	signal      SBC_V           : std_logic;
	signal      SBC_N           : std_logic;
	signal      SBC_Q           : std_logic_vector(7 downto 0);

begin

	process (P_In, BusA, BusB)
		variable AL : unsigned(6 downto 0);
		variable AH : unsigned(6 downto 0);
		variable C : std_logic;
	begin
		AL := resize(unsigned(BusA(3 downto 0) & P_In(Flag_C)), 7) + resize(unsigned(BusB(3 downto 0) & "1"), 7);
		AH := resize(unsigned(BusA(7 downto 4) & AL(5)), 7) + resize(unsigned(BusB(7 downto 4) & "1"), 7);

-- pragma translate_off
			if is_x(std_logic_vector(AL)) then AL := "0000000"; end if;
			if is_x(std_logic_vector(AH)) then AH := "0000000"; end if;
-- pragma translate_on

		if AL(4 downto 1) = 0 and AH(4 downto 1) = 0 then
			ADC_Z <= '1';
		else
			ADC_Z <= '0';
		end if;

		if AL(5 downto 1) > 9 and P_In(Flag_D) = '1' then
			AL(6 downto 1) := AL(6 downto 1) + 6;
		end if;

		C := AL(6) or AL(5);
		AH := resize(unsigned(BusA(7 downto 4) & C), 7) + resize(unsigned(BusB(7 downto 4) & "1"), 7);

		ADC_N <= AH(4);
		ADC_V <= (AH(4) xor BusA(7)) and not (BusA(7) xor BusB(7));

-- pragma translate_off
			if is_x(std_logic_vector(AH)) then AH := "0000000"; end if;
-- pragma translate_on

		if AH(5 downto 1) > 9 and P_In(Flag_D) = '1' then
			AH(6 downto 1) := AH(6 downto 1) + 6;
		end if;

		ADC_C <= AH(6) or AH(5);

		ADC_Q <= std_logic_vector(AH(4 downto 1) & AL(4 downto 1));
	end process;

	process (Op, P_In, BusA, BusB)
		variable AL : unsigned(6 downto 0);
		variable AH : unsigned(5 downto 0);
		variable C : std_logic;
	begin
		C := P_In(Flag_C) or not Op(0);
		AL := resize(unsigned(BusA(3 downto 0) & C), 7) - resize(unsigned(BusB(3 downto 0) & "1"), 6);
		AH := resize(unsigned(BusA(7 downto 4) & "0"), 6) - resize(unsigned(BusB(7 downto 4) & AL(5)), 6);

-- pragma translate_off
			if is_x(std_logic_vector(AL)) then AL := "0000000"; end if;
			if is_x(std_logic_vector(AH)) then AH := "000000"; end if;
-- pragma translate_on

		if AL(4 downto 1) = 0 and AH(4 downto 1) = 0 then
			SBC_Z <= '1';
		else
			SBC_Z <= '0';
		end if;

		SBC_C <= not AH(5);
		SBC_V <= (AH(4) xor BusA(7)) and (BusA(7) xor BusB(7));
		SBC_N <= AH(4);

		if P_In(Flag_D) = '1' then
			if AL(5) = '1' then
				AL(5 downto 1) := AL(5 downto 1) - 6;
			end if;
			AH := resize(unsigned(BusA(7 downto 4) & "0"), 6) - resize(unsigned(BusB(7 downto 4) & AL(6)), 6);
			if AH(5) = '1' then
				AH(5 downto 1) := AH(5 downto 1) - 6;
			end if;
		end if;

		SBC_Q <= std_logic_vector(AH(4 downto 1) & AL(4 downto 1));
	end process;

	process (Op, P_In, BusA, BusB,
			ADC_Z, ADC_C, ADC_V, ADC_N, ADC_Q,
			SBC_Z, SBC_C, SBC_V, SBC_N, SBC_Q)
		variable Q_t : std_logic_vector(7 downto 0);
	begin
		-- ORA, AND, EOR, ADC, NOP, LD, CMP, SBC
		-- ASL, ROL, LSR, ROR, BIT, LD, DEC, INC
		P_Out <= P_In;
		Q_t := BusA;
		case Op(3 downto 0) is
		when "0000" =>
			-- ORA
			Q_t := BusA or BusB;
		when "0001" =>
			-- AND
			Q_t := BusA and BusB;
		when "0010" =>
			-- EOR
			Q_t := BusA xor BusB;
		when "0011" =>
			-- ADC
			P_Out(Flag_V) <= ADC_V;
			P_Out(Flag_C) <= ADC_C;
			Q_t := ADC_Q;
		when "0101" | "1101" =>
			-- LDA
		when "0110" =>
			-- CMP
			P_Out(Flag_C) <= SBC_C;
		when "0111" =>
			-- SBC
			P_Out(Flag_V) <= SBC_V;
			P_Out(Flag_C) <= SBC_C;
			Q_t := SBC_Q;
		when "1000" =>
			-- ASL
			Q_t := BusA(6 downto 0) & "0";
			P_Out(Flag_C) <= BusA(7);
		when "1001" =>
			-- ROL
			Q_t := BusA(6 downto 0) & P_In(Flag_C);
			P_Out(Flag_C) <= BusA(7);
		when "1010" =>
			-- LSR
			Q_t := "0" & BusA(7 downto 1);
			P_Out(Flag_C) <= BusA(0);
		when "1011" =>
			-- ROR
			Q_t := P_In(Flag_C) & BusA(7 downto 1);
			P_Out(Flag_C) <= BusA(0);
		when "1100" =>
			-- BIT
			P_Out(Flag_V) <= BusB(6);
		when "1110" =>
			-- DEC
			Q_t := std_logic_vector(unsigned(BusA) - 1);
		when "1111" =>
			-- INC
			Q_t := std_logic_vector(unsigned(BusA) + 1);
		when others =>
		end case;

		case Op(3 downto 0) is
		when "0011" =>
			P_Out(Flag_N) <= ADC_N;
			P_Out(Flag_Z) <= ADC_Z;
		when "0110" | "0111" =>
			P_Out(Flag_N) <= SBC_N;
			P_Out(Flag_Z) <= SBC_Z;
		when "0100" =>
		when "1100" =>
			P_Out(Flag_N) <= BusB(7);
			if (BusA and BusB) = "00000000" then
				P_Out(Flag_Z) <= '1';
			else
				P_Out(Flag_Z) <= '0';
			end if;
		when others =>
			P_Out(Flag_N) <= Q_t(7);
			if Q_t = "00000000" then
				P_Out(Flag_Z) <= '1';
			else
				P_Out(Flag_Z) <= '0';
			end if;
		end case;

		Q <= Q_t;
	end process;

end;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本中文一区二区三区| 91蝌蚪porny| 一道本成人在线| 日韩欧美一二三区| 一区二区免费视频| 国产永久精品大片wwwapp| 欧美午夜精品理论片a级按摩| 国产欧美一区二区精品性色超碰| 亚洲午夜免费视频| 99riav久久精品riav| 精品久久久久99| 日韩国产一区二| 日本乱人伦一区| 国产精品久久三区| 国产一区在线不卡| 日韩免费在线观看| 五月激情丁香一区二区三区| 色综合久久中文综合久久97 | 免费在线观看视频一区| 北条麻妃国产九九精品视频| 久久久久久久久99精品| 蜜桃在线一区二区三区| 欧美美女bb生活片| 亚洲成人tv网| 欧美久久久久中文字幕| 一区二区三区高清不卡| 91在线视频网址| 亚洲麻豆国产自偷在线| 波多野洁衣一区| 自拍偷在线精品自拍偷无码专区| 国产成人精品影视| 亚洲福利一区二区| 欧美性受极品xxxx喷水| 亚洲国产精品一区二区尤物区| 91免费在线视频观看| 亚洲精品伦理在线| 91福利精品视频| 亚洲第一av色| 欧美一区二区三区免费观看视频| 日韩电影在线看| 精品捆绑美女sm三区| 日韩欧美国产小视频| 精品国产伦一区二区三区观看方式| 成人蜜臀av电影| 欧美日韩国产综合久久| 亚洲国产成人av好男人在线观看| 欧美在线不卡视频| 午夜精品福利一区二区三区av | 精品日韩一区二区三区免费视频| 久久99国产精品免费| 久久久777精品电影网影网| 国产精品12区| 亚洲欧洲综合另类| 欧美日本一区二区三区四区| 蜜臀va亚洲va欧美va天堂| 久久亚洲精品小早川怜子| 成人高清视频在线| 亚洲一线二线三线久久久| 91精品国产综合久久香蕉麻豆| 韩国精品久久久| 国产精品三级视频| 欧美日韩国产一级| 国产乱淫av一区二区三区 | 久久午夜电影网| 成人手机在线视频| 午夜视频在线观看一区| 精品嫩草影院久久| 色婷婷久久久亚洲一区二区三区 | 日韩不卡一二三区| 久久久久久久综合日本| 色综合天天性综合| 另类成人小视频在线| 成人欧美一区二区三区黑人麻豆 | 日韩精品中文字幕一区二区三区 | 中文字幕精品三区| 欧美三级资源在线| 国产成人在线观看| 婷婷综合另类小说色区| 中文字幕高清不卡| 欧美一区二区久久久| av在线综合网| 激情欧美日韩一区二区| 亚洲午夜免费电影| 中文幕一区二区三区久久蜜桃| 欧美日韩国产大片| 97久久久精品综合88久久| 热久久免费视频| 亚洲影视在线播放| 国产精品乱码久久久久久| 日韩一区二区不卡| 欧美视频日韩视频在线观看| 国产a区久久久| 久久99精品网久久| 国产精品1区2区| 久久99最新地址| 欧美成人欧美edvon| 色婷婷av一区二区三区软件| 精品一区二区久久| 全部av―极品视觉盛宴亚洲| 亚洲综合免费观看高清完整版在线| 精品成人免费观看| 91.xcao| 色综合亚洲欧洲| 成人va在线观看| 国产精品亚洲午夜一区二区三区 | 久久精品国产久精国产爱| 亚洲一区二区在线观看视频| 中文字幕中文字幕中文字幕亚洲无线| 精品国产自在久精品国产| 欧美精品九九99久久| 欧美日韩日本视频| 91网站在线观看视频| 欧美日韩免费观看一区三区| 国产精品久久一卡二卡| 欧美日韩一区小说| 欧美三级三级三级| 欧美在线一区二区| 欧美日韩精品一区视频| 欧美日韩国产区一| 91精品午夜视频| 日韩一本二本av| 精品成人一区二区三区四区| 337p粉嫩大胆噜噜噜噜噜91av | 精品av综合导航| 精品国产免费人成电影在线观看四季 | 一本大道久久a久久精品综合 | 色噜噜狠狠色综合中国 | 国产精品一级黄| 国产aⅴ综合色| eeuss鲁片一区二区三区在线观看| 666欧美在线视频| 成人动漫一区二区三区| 成人va在线观看| 91黄色在线观看| 欧美日韩激情在线| 日韩免费性生活视频播放| 久久综合一区二区| 国产精品福利影院| 亚洲高清在线视频| 久久精品国内一区二区三区| 国产精品中文有码| 色偷偷久久人人79超碰人人澡| 在线观看国产精品网站| 日韩欧美区一区二| 成人欧美一区二区三区视频网页| 亚洲综合视频在线观看| 毛片av一区二区| 99re热这里只有精品免费视频| 欧美三区在线观看| 国产性做久久久久久| 亚洲一二三专区| 久久av老司机精品网站导航| 99久久精品免费看| 88在线观看91蜜桃国自产| 国产人久久人人人人爽| 一区二区三区日韩欧美| 久久精品国产色蜜蜜麻豆| aa级大片欧美| 精品国产乱码91久久久久久网站| 亚洲欧美一区二区视频| 麻豆精品国产传媒mv男同| hitomi一区二区三区精品| 欧美福利视频一区| 中文字幕 久热精品 视频在线| 亚洲3atv精品一区二区三区| 国产激情偷乱视频一区二区三区| 在线欧美日韩国产| 国产婷婷一区二区| 99久久精品久久久久久清纯| 欧美日韩国产一级片| 国产精品素人一区二区| 麻豆久久久久久| 在线观看一区日韩| 国产精品蜜臀在线观看| 麻豆国产欧美日韩综合精品二区| 在线看国产一区二区| 欧美国产日韩精品免费观看| 免费视频最近日韩| 欧美性videosxxxxx| 中文字幕一区二区5566日韩| 国产一区二区影院| 日韩一区二区三区免费观看| 亚洲成人精品一区| 91免费观看视频在线| 亚洲国产成人一区二区三区| 激情欧美一区二区| 日韩一级高清毛片| 青青青爽久久午夜综合久久午夜| 91官网在线观看| 亚洲美腿欧美偷拍| 91丝袜美女网| 国产精品久久久99| 丁香激情综合国产| 欧美国产精品专区| 国产馆精品极品| 日本一区二区三区电影| 国产精品自拍三区| 国产亚洲va综合人人澡精品| 国产一区二区三区高清播放| 2020国产精品久久精品美国|