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

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

?? pack8051.vhd

?? 一個8051的VHDL代碼
?? VHD
字號:
-------------------------------------------------------------------------------- Model        :   8051 Behavioral Model,--                  Supporting Package of Procedures ---- File         :   pack8051.vhd---- Author       :   Michael Mayer,--                  Department of Electrical Engineering--                  University of Missouri - Rolla---- Inspired By  :   Sundar Subbarayan--                  UC Riverside CS 122a (lab 3)--                  Professor: Dr.Frank Vahid--                  17th January 1996---- Date Started :   September 15, 1997---- Limitations  :   ---- Revisions    :---- REV    DATE     Description-- -----  --------   _____________________________________-- 2.0    11/04/97   Initial implementation of types for--                   memory, functions or, and, xor, not--                   and procedure load_program ---- 2.1    11/12/97   Changed memory to lo and hi mem's---- 2.2    11/13/97   Added type for states for machine cycles----------------------------------------------------------------------------------LIBRARY ieee;USE ieee.std_logic_1164.ALL;USE ieee.std_logic_arith.ALL;USE std.textio.ALL;PACKAGE pack8051 IS   SUBTYPE bvec       IS UNSIGNED(7 DOWNTO 0);   SUBTYPE wvec       IS UNSIGNED(15 DOWNTO 0);   SUBTYPE smallint   IS INTEGER RANGE 0 TO 255;   TYPE program_mem_T IS ARRAY(0 TO 65535) OF bvec;    TYPE data_lomem_T  IS ARRAY(0 TO 127)   OF bvec;   TYPE data_himem_T  IS ARRAY(128 TO 255) OF bvec;   -- The following type is used to declare if direct or indirect memory   -- access is being used and, hence, which segment of upper memory   -- is to be used.   TYPE    access_type IS (direct, indirect);   -- The following type is used to break up the machine cycle   -- into 6 states, with 2 pulses for each state   TYPE machine_cycle_states IS (init, s1p1, s1p2, s2p1, s2p2, s3p1, s3p2,         s4p1, s4p2, s5p1, s5p2, s6p1, s6p2);   FUNCTION to_int(ch   : CHARACTER)  RETURN INTEGER;   FUNCTION "or"(l,r : unsigned)  RETURN unsigned;   FUNCTION "and"(l,r : unsigned) RETURN unsigned;   FUNCTION "xor"(l,r : unsigned) RETURN unsigned;   FUNCTION "not"(r : unsigned)   RETURN unsigned;   FUNCTION conv_signed_to_int(arg : bvec) RETURN INTEGER;    FUNCTION to_high_imped(arg : bvec) RETURN bvec;   FUNCTION inc(state : machine_cycle_states)        RETURN machine_cycle_states;   PROCEDURE load_program(       CONSTANT program_filename : IN string;       VARIABLE pmem             : OUT program_mem_T  -- the program memory   );END pack8051;PACKAGE BODY pack8051 IS   ------------------------------------------------------------------------   -- to_int   --   --	A function that converts a character to an integer (0-9,A-F)    ------------------------------------------------------------------------    FUNCTION to_int(         CONSTANT ch    : CHARACTER    ) RETURN INTEGER IS         VARIABLE result : INTEGER := 0;    BEGIN         CASE ch IS             WHEN '0' => result := 16#0#;             WHEN '1' => result := 16#1#;             WHEN '2' => result := 16#2#;             WHEN '3' => result := 16#3#;             WHEN '4' => result := 16#4#;             WHEN '5' => result := 16#5#;             WHEN '6' => result := 16#6#;             WHEN '7' => result := 16#7#;             WHEN '8' => result := 16#8#;             WHEN '9' => result := 16#9#;             WHEN 'A' => result := 16#A#;             WHEN 'B' => result := 16#B#;             WHEN 'C' => result := 16#C#;             WHEN 'D' => result := 16#D#;             WHEN 'E' => result := 16#E#;             WHEN 'F' => result := 16#F#;             WHEN OTHERS => result := 16#0#;         END CASE;         RETURN result;    END FUNCTION to_int;   ------------------------------------------------------------------------   FUNCTION "or"(l,r : unsigned) RETURN unsigned IS   BEGIN       RETURN unsigned(std_logic_vector(l) OR std_logic_vector(r));   END FUNCTION "or";   ------------------------------------------------------------------------   FUNCTION "and"(l,r : unsigned) RETURN unsigned IS   BEGIN       RETURN unsigned(std_logic_vector(l) AND std_logic_vector(r));   END FUNCTION "and";   ------------------------------------------------------------------------   FUNCTION "xor"(l,r : unsigned) RETURN unsigned IS   BEGIN       RETURN unsigned(std_logic_vector(l) XOR std_logic_vector(r));   END FUNCTION "xor";   ------------------------------------------------------------------------   FUNCTION "not"(r : unsigned) RETURN unsigned IS   BEGIN       RETURN unsigned(NOT std_logic_vector(r));   END FUNCTION "not";   ------------------------------------------------------------------------   FUNCTION conv_signed_to_int(arg : bvec) RETURN INTEGER IS       VARIABLE result : INTEGER;   BEGIN       IF arg(7) = '1' THEN -- convert to positive            result := -1 * conv_integer(NOT(arg) + 1);        ELSE           result := conv_integer(arg);        END IF;       RETURN result;   END FUNCTION conv_signed_to_int;   ------------------------------------------------------------------------   FUNCTION to_high_imped(arg : bvec) RETURN bvec IS        VARIABLE result : bvec;    BEGIN       FOR k in arg'RANGE LOOP           CASE arg(k) IS               WHEN '0' => result(k) := 'L';               WHEN '1' => result(k) := 'H';               WHEN 'L' => result(k) := 'L';               WHEN 'H' => result(k) := 'H';               WHEN OTHERS => result(k) := 'Z';           END CASE;       END LOOP;       RETURN(result);   END FUNCTION to_high_imped;              ------------------------------------------------------------------------   FUNCTION inc(state : machine_cycle_states)        RETURN machine_cycle_states IS       VARIABLE result : machine_cycle_states;   BEGIN       CASE state IS            WHEN init => result := s1p1;           WHEN s1p1 => result := s1p2;           WHEN s1p2 => result := s2p1;           WHEN s2p1 => result := s2p2;           WHEN s2p2 => result := s3p1;           WHEN s3p1 => result := s3p2;           WHEN s3p2 => result := s4p1;           WHEN s4p1 => result := s4p2;           WHEN s4p2 => result := s5p1;           WHEN s5p1 => result := s5p2;           WHEN s5p2 => result := s6p1;           WHEN s6p1 => result := s6p2;           WHEN s6p2 => result := s1p1;        END CASE;        RETURN result;    END FUNCTION inc;    PROCEDURE load_program(        CONSTANT program_filename : IN string;        VARIABLE pmem             : OUT program_mem_T  -- the program memory    ) IS        FILE     progfile       : TEXT OPEN read_mode IS program_filename;        VARIABLE L              : LINE;        VARIABLE ch             : CHARACTER;        VARIABLE rec_type       : CHARACTER;        VARIABLE sum            : INTEGER;        VARIABLE dig            : INTEGER;        VARIABLE data           : INTEGER;        VARIABLE numb_of_bytes  : INTEGER;        VARIABLE address        : INTEGER;        VARIABLE address_offset : INTEGER;        VARIABLE end_of_data    : BOOLEAN;        VARIABLE checksum       : INTEGER;        VARIABLE line_num       : INTEGER;    BEGIN        line_num := 0;        address_offset := 0;        end_of_data := FALSE;        WHILE NOT (endfile(progfile) OR end_of_data) LOOP            -- Reset the variables for the line            sum := 0;            address := 0;            line_num := line_num + 1;             readline(progfile, L);            -- Read in the : character            read(L, ch);            IF ch /= ':' THEN                NEXT;  -- go to next loop            END IF;            -- Read in the number of bytes            read(L, ch);  -- msb            dig := to_int(ch);            sum := sum + dig;            read(L, ch);  -- lsb            sum := sum + to_int(ch);            numb_of_bytes := dig*16 + to_int(ch);            -- Read in the address            FOR k IN 3 DOWNTO 0 LOOP                read(L, ch);                dig := to_int(ch);                sum := sum + dig;                address := address + dig * 16**k;            END LOOP;            -- Read in the record type            read(L,ch);            sum := sum + to_int(ch);            ASSERT ch = '0'                REPORT "Illegal Record Type - Bad Program File" &                       " on line " & INTEGER'IMAGE(line_num);            read(L,rec_type);            sum := sum + to_int(rec_type);            -- If it is a line of all zeros, then it is the end of data.            IF (numb_of_bytes = 0) AND (address = 0)THEN                end_of_data := TRUE;            -- If it is normal data, then read in all of the bytes to program_mem            ELSIF rec_type = '0' THEN  -- It has normal data                FOR byte_no IN 0 TO numb_of_bytes-1 LOOP                     read(L,ch);                     dig := to_int(ch);                     sum := sum + dig;                     read(L,ch);                      sum := sum + to_int(ch);                     data := dig*16 + to_int(ch);                     pmem(address_offset*16 + address + byte_no) :=                         conv_unsigned(data,8);                END LOOP;             -- If it is an end of file record, then set end_of_data true            ELSIF rec_type = '1' THEN -- it is an end of file record                end_of_data := TRUE;            ELSIF rec_type = '2' THEN                address_offset := 0;                FOR k IN 3 DOWNTO 0 LOOP                    read(L, ch);                    dig := to_int(ch);                    sum := sum + dig;                    address_offset := address_offset + dig*16**k;                END LOOP;            END IF;            -- get the checksum            read(L,ch);            dig := to_int(ch);            read(L,ch);            checksum := dig * 16 + to_int(ch);            --ASSERT (checksum + sum MOD 256) = 0;            --   REPORT "Checksum Error"& " on line " & INTEGER'IMAGE(line_num);        END LOOP;    END PROCEDURE load_program;           END pack8051;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久se精品一区二区| 一二三区精品福利视频| 欧美剧在线免费观看网站| 国产99精品视频| 丁香亚洲综合激情啪啪综合| 蜜臀av一级做a爰片久久| 日本网站在线观看一区二区三区 | 国产一区二区三区免费观看| 亚洲一区二区中文在线| 亚洲免费伊人电影| 亚洲狠狠丁香婷婷综合久久久| 国产精品乱人伦中文| 欧美国产日韩一二三区| 成人欧美一区二区三区黑人麻豆| 欧美国产乱子伦| 亚洲婷婷综合久久一本伊一区| 中文字幕在线播放不卡一区| 国产精品成人免费精品自在线观看| 18成人在线观看| 一区二区三区四区在线免费观看| 午夜伦理一区二区| 国产一区二区三区国产| 成人精品亚洲人成在线| 一本色道久久加勒比精品 | 欧美一级黄色大片| xf在线a精品一区二区视频网站| 国产亚洲欧美一级| 亚洲日本一区二区| 蜜臀久久久久久久| 国产xxx精品视频大全| 欧美性猛片aaaaaaa做受| 精品国产乱码久久久久久免费| 国产婷婷精品av在线| 夜色激情一区二区| 国产麻豆精品在线| 欧美日韩免费一区二区三区视频| 精品国产乱码久久久久久图片| 国产精品午夜在线| 久久精品国产亚洲高清剧情介绍| 国产成人av一区二区| 欧美视频一区二区三区在线观看| 日韩一区二区电影网| 中文文精品字幕一区二区| 亚洲欧美日韩国产综合在线 | 午夜a成v人精品| 国产精品白丝av| 色8久久精品久久久久久蜜| 欧美日韩成人综合在线一区二区| 精品福利在线导航| 亚洲大片在线观看| 大白屁股一区二区视频| 91精品国产综合久久精品性色| 国产精品国产精品国产专区不蜜 | 亚洲精品视频在线看| 久久精品国产久精国产| 99国产麻豆精品| 久久久精品黄色| 日韩二区在线观看| 99久久精品国产毛片| 久久综合久久综合亚洲| 午夜天堂影视香蕉久久| 成人激情午夜影院| 欧美激情资源网| 国产精品69毛片高清亚洲| 欧美一级日韩不卡播放免费| 亚洲精品免费看| 成人app在线观看| 久久久91精品国产一区二区精品| 亚洲国产成人porn| 欧美性三三影院| 有坂深雪av一区二区精品| 成人精品亚洲人成在线| 欧美韩日一区二区三区| 国产传媒久久文化传媒| 欧美电影免费观看高清完整版| 亚洲v精品v日韩v欧美v专区| 日本高清不卡视频| 亚洲在线成人精品| 欧美吻胸吃奶大尺度电影| 亚洲卡通动漫在线| 日本二三区不卡| 亚洲超碰97人人做人人爱| 精品视频色一区| 亚洲成人资源网| 欧美一区午夜视频在线观看| 日日夜夜精品视频免费| 欧美美女网站色| 日韩激情av在线| 日韩午夜av电影| 久久精品国内一区二区三区| 日韩精品一区二区三区在线 | 亚洲一二三专区| 色香色香欲天天天影视综合网| 亚洲精品高清在线| 色综合色狠狠综合色| 亚洲最新视频在线观看| 欧美亚洲动漫精品| 韩国av一区二区三区四区| 26uuu久久综合| heyzo一本久久综合| 亚洲免费观看高清完整版在线| 欧美亚洲一区二区三区四区| 亚洲成人自拍网| 久久久www成人免费无遮挡大片| 国产成a人亚洲| 亚洲va欧美va人人爽| 欧美va亚洲va在线观看蝴蝶网| 国模一区二区三区白浆| 日韩理论电影院| 日韩一级片在线观看| 极品少妇xxxx精品少妇偷拍| 国产精品久久久久久久岛一牛影视 | 亚洲精选视频免费看| 欧美又粗又大又爽| 国产高清精品在线| 亚洲国产中文字幕在线视频综合| 精品免费一区二区三区| 91啪九色porn原创视频在线观看| 三级欧美在线一区| 亚洲欧美色图小说| 日韩欧美一级精品久久| 懂色中文一区二区在线播放| 亚洲123区在线观看| 中文字幕欧美三区| 91麻豆精品久久久久蜜臀 | 午夜精品在线视频一区| 久久精品一级爱片| 欧美裸体bbwbbwbbw| 成人精品gif动图一区| 久久国产日韩欧美精品| 亚洲精品v日韩精品| 中文乱码免费一区二区 | 国产很黄免费观看久久| 丝袜a∨在线一区二区三区不卡| 国产精品久久久久四虎| 欧美sm美女调教| 91精品国产品国语在线不卡| 色综合色狠狠综合色| 成人免费毛片嘿嘿连载视频| 日韩不卡一区二区| 五月激情综合网| 亚洲综合成人网| 亚洲精品国久久99热| 国产日韩欧美精品在线| 精品88久久久久88久久久| 日韩午夜小视频| 91精品国产综合久久久蜜臀粉嫩| 欧美在线免费视屏| 色屁屁一区二区| 在线亚洲一区二区| 99热在这里有精品免费| caoporm超碰国产精品| 成人免费视频app| 99国产精品久久久久| 99天天综合性| 欧洲另类一二三四区| 欧美性猛交xxxxxx富婆| 欧美网站大全在线观看| 欧美二区乱c少妇| 91精品国产综合久久福利 | 国产亚洲精品超碰| 国产亚洲短视频| 国产精品传媒视频| 伊人性伊人情综合网| 亚洲国产一区二区视频| 亚洲123区在线观看| 麻豆精品国产91久久久久久| 韩国一区二区在线观看| 成人国产一区二区三区精品| 91在线无精精品入口| 欧洲精品视频在线观看| 欧美一级国产精品| 久久久久国色av免费看影院| 国产欧美一区二区三区在线老狼 | 91精品国产高清一区二区三区| 欧美一区二区三区日韩| 久久久久久9999| 亚洲视频狠狠干| 人人爽香蕉精品| 高清国产午夜精品久久久久久| 97精品国产露脸对白| 91精品国产黑色紧身裤美女| 久久久久久久久蜜桃| 亚洲日本在线看| 狠狠色丁香久久婷婷综| 99精品黄色片免费大全| 欧美精三区欧美精三区| 国产日产精品一区| 亚洲一区二三区| 成人永久aaa| 欧美日高清视频| 中文在线免费一区三区高中清不卡| 亚洲最大成人综合| 国产精品18久久久久久vr| 91精品福利视频| 国产偷国产偷亚洲高清人白洁| 玉足女爽爽91| 成人美女在线观看| 日韩欧美第一区| 亚洲第一福利一区|