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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? smarti.v

?? 實(shí)現(xiàn)USB接口功能的VHDL和verilog完整源代碼
?? V
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
`include "smarti_params.v"
/********************************************************
 *       1. Filename : smarti.v
 *       2. Author   : Rha, haeyoung
 *       3. Key Feature : interface between USB and smart card.
 *       4. created date : 99/7/27
 *       5. modification history
 *            -1. remove reset condition
 *            -2. multipage write/read
 *            -3. data in & write command('h10) in one control tr
 *            -4. read/write unit : page  => dummy read/dummy wr 
 *            -5. remove wpb, ceb ==> gpio signal 99.12.8
 ********************************************************/

module smarti (
                mcclock, 
	        // from usb
                mcreset, 
                //mcreset_usb, 
                sm_enable, 
                sof, 
                sm64_enable, 
                disablebus, 
                cmdrdready, 
                statuswrready, 
                getdata, 
                getstatus, 
                getbusy, 
                datardready, 
                datawrready, 
                cmddata,
                datarddata,
                
	        // from smart card
                card_ready,
                smart_rd_data,

	        // to usb
                cmdrd, 
                statuswr, 
                statusdata, 
                datard, 
                datawr, 
                datawrdata, 

	        // to smart_card
                ale,
                //ceb,
                cle,
                reb,
                web,
                //wpb,
                out_enable,
                smart_wr_data
              );


  input              mcclock;
  input              mcreset; 
  input              sm_enable; 
  input              sm64_enable; 
  input              sof; 
  input              disablebus; 
  input              cmdrdready; 
  input              statuswrready; 
  input              getdata; 
  input              getstatus; 
  input              getbusy; 
  input              datardready; 
  input              datawrready; 
  input        [7:0] cmddata;
  input        [7:0] datarddata;
  input              card_ready;
  input        [7:0] smart_rd_data;

  output             cmdrd;
  output             statuswr; 
  output       [7:0] statusdata; 
  output             datard; 
  output             datawr;
  output       [7:0] datawrdata; 
  output             ale;
  //output             ceb;
  output             cle;
  output             reb;
  output             web;
  //output             wpb;
  output             out_enable;
  output       [7:0] smart_wr_data; 
  
  reg                getdata_d;
  reg                card_ready_d;
  reg                card_ok;
  reg                statusrd_done;
  reg                statusrd_d;
  reg                cmdrd;
  reg                statuswr;
  reg          [7:0] statusdata;
  reg          [6:0] sm_status;
  //reg          [7:0] sm_status;
  //reg          [7:0] busy_status;
  reg          [4:0] num_sof;
  reg                busy_timeout ;
  reg                datard;
  reg                datawr;
  reg          [7:0] datawrdata; 
  reg          [7:0] smart_wr_data; 
  reg                ale,cle,reb,web;
  //reg                ale,ceb,cle,reb,web;
  reg                new_page ;
  reg          [3:0] sm_state;
  reg          [3:0] nxt_sm_state;
  reg          [1:0] clk_cnt;
  reg          [1:0] st_cnt;
  reg          [4:0] err_cnt;
  reg                cmdrd_c;
  wire               datard_c;
  reg 		     reset_cnt;
  wire	             reset_cmd_num;
  reg 		     out_enable;
  reg          [9:0] num_sent;
  reg         [31:0] addr ;
  reg          [7:0] command;
  reg          [7:0] hidden_cmd0 ;
  reg          [7:0] hidden_cmd1 ;
  reg          [2:0] cmd_num;
  reg         [7:0] command_c;
  //wire         [7:0] command_c;
  wire               out_enable_c;
  wire               read_cmd;
  wire         [1:0] num_addr;
  wire               ale_c, cle_c,reb_c, web_c ;
  wire               statuswr_c ;
  //reg                interface_reset ;
  reg                sm64_en_d ;
  reg                escape_busy ;

  parameter [3:0] //synopsys enum state_info
    IDLE = 4'b0000,
    CMD  = 4'b0001,
    ADDR  = 4'b0010,
    RD_CMD  = 4'b0011,
    GET_STATUS  = 4'b0100,
    WR_STATUS  = 4'b0101,
    READ  = 4'b0110,
    WRITE  = 4'b0111,
    DUMMY_WR  = 4'b1001,
    WAIT_SM  = 4'b1011,
    DUMMY_RD  = 4'b1010,
    HIDDEN_CMD  = 4'b1000;

  parameter [7:0]
    DATA_IN = 8'h80,
    READ11 = 8'h00,
    READ12 = 8'h01,
    READ2  = 8'h50,
    READ_ID = 8'h90,
    RESET = 8'hff,
    PROGRAM  = 8'h10,
    ERASE_SETUP = 8'h60,
    ERASE = 8'hd0,
    READ_STATUS = 8'h70;

  parameter  num_send = 528; 

   /* // synopsys sync_set_reset "mcreset" */
  always @( posedge mcclock ) begin
    if ( mcreset ) begin
      cmdrd <= 0;
      statuswr <= 0;
      datard <=  0;
      datawr <=  0;
      reb <=  1;
      web <=  1;
      ale <=  0;
      cle <=  0;
      out_enable <= 0;
      escape_busy <= 0;
    end
    else if ( sm_enable )begin
      cmdrd <= cmdrd_c ;
      statuswr <= ( sm_state == WR_STATUS && clk_cnt == 1 ) ? 1:0;
      datard <=   ( ( sm_state == DUMMY_WR || sm_state == WRITE ) && 
                      clk_cnt == 'b0 && datardready ) ? 1 : 0 ;
      datawr <=  (( sm_state == READ || sm_state == DUMMY_RD ) && 
                    datawrready && clk_cnt =='b1) ? 1 : 0 ;
      escape_busy <= ( sm_state == RD_CMD ) ? 0 : 
                 (( !card_ready_d && num_sof[4:1] == 4'b1111 ) ? 1: escape_busy);
                 //(( sm_state == WAIT_SM && num_sof[4:1] == 4'b1111 ) ? 1: escape_busy);
      //reb <=  ( (sm_state == READ &&  clk_cnt =='b0 && datawrready && card_ready_d )||  12.28
      reb <=  ( (sm_state == READ &&  clk_cnt =='b0 && datawrready && card_ok )|| 
                (sm_state == GET_STATUS && clk_cnt =='b0 ) ||
                (sm_state == WR_STATUS && clk_cnt =='b0 && command == READ_ID ) ) ? 0 : 1; 
      web <= ((sm_state == CMD || sm_state == ADDR || sm_state == HIDDEN_CMD ||
                  sm_state == WRITE ) && clk_cnt ==1 )? 0 : 1 ;
      ale <=  ( sm_state == ADDR) ? 1 : 0 ;
      cle <=  ( (sm_state == CMD || sm_state == HIDDEN_CMD) && clk_cnt != 'b11 ) ? 1 : 0 ;
      //wpb <=  1;
      out_enable <=(( sm_state == CMD ||sm_state == ADDR||sm_state == WRITE || sm_state == HIDDEN_CMD )&&
                         ( clk_cnt == 'b10 || clk_cnt == 'b1 ) && !disablebus ) ? 1: 0;
    end
  end

  always @( posedge mcclock ) begin
    statusrd_d <= ( getbusy || getstatus ) && sm_enable;
    getdata_d <= getdata && sm_enable;
    card_ok <= card_ready || escape_busy ;
    card_ready_d <= card_ready ;
    sm64_en_d <= ( sm_enable  &&  sm64_enable ) ;
  end 

  always @( posedge mcclock ) begin
    if ( mcreset ) begin
      statusrd_done <= 1;
    end
    else begin
      statusrd_done <= ( (getbusy || getstatus)  && !statusrd_d ) ? 0 : 
                    (( sm_state == WR_STATUS && nxt_sm_state == IDLE && !statusrd_done ) ?
                     1:statusrd_done);
    end 
  end 
      
  always @( posedge mcclock ) begin
    if ( sm_state == WR_STATUS && clk_cnt == 'b01 && getstatus && command != READ_ID) begin
      statusdata <=  {escape_busy,sm_status} ;
    end 
    else if ( sm_state == WR_STATUS && clk_cnt == 'b01 && getstatus )
      statusdata <= smart_rd_data;
    else if ( sm_state == WR_STATUS && clk_cnt == 'b01 && getbusy)
      statusdata <= {7'h0,card_ready_d};
    else 
      statusdata <= statusdata;
    if ( sm_state == READ && clk_cnt == 'b01)
      datawrdata <= smart_rd_data;
    else
      datawrdata <= datawrdata;

    if ( sm_state == CMD && clk_cnt == 'b0)
      smart_wr_data <= command ;
    else if ( sm_state == HIDDEN_CMD && clk_cnt == 'b0 && st_cnt == 0 )
      smart_wr_data <= hidden_cmd0 ;
    else if ( sm_state == HIDDEN_CMD && clk_cnt == 'b0 && st_cnt == 1 )
      smart_wr_data <= hidden_cmd1 ;
    else if ( sm_state == ADDR && clk_cnt == 'b0 && st_cnt == 'b0 )
      smart_wr_data <= addr[7:0] ;
    else if ( sm_state == ADDR && clk_cnt == 'b0 && st_cnt == 'b1 )
      smart_wr_data <= addr[15:8];
    else if ( sm_state == ADDR && clk_cnt == 'b0 && st_cnt == 'b10 )
      smart_wr_data <= addr[23:16];
    else if ( sm_state == ADDR && clk_cnt == 'b0 && st_cnt == 'b11 )
      smart_wr_data <= addr[31:24];
    else if ( sm_state == WRITE  && clk_cnt == 'b1)  
      smart_wr_data <= datarddata;
    else
      smart_wr_data <= smart_wr_data;
  end

  always @( posedge mcclock ) begin
    if ( mcreset ) 
      cmd_num  <= 'h0;
    else  if (  sm_state == RD_CMD  )
      cmd_num <=  cmd_num + 1;
    else  if ( reset_cmd_num)
      cmd_num <=  'h0;
    /*else
      cmd_num <=  cmd_num;*/
  end 

  always @( posedge mcclock ) begin
    if ( mcreset ) 
      sm_status <= 0; 
    else if ( sm_state == RD_CMD )
      sm_status <= 0; 
    else if (  sm_state == GET_STATUS && clk_cnt == 'b01 )
      sm_status <= sm_status + smart_rd_data[0]; 
  end 

  always @( posedge mcclock ) begin
    if ( mcreset ) 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区二区三区四区| 不卡在线观看av| 91麻豆精品国产91久久久久久 | 精品一区二区三区av| 日韩一区二区在线观看视频 | 在线观看区一区二| 一区av在线播放| 欧美日韩国产片| 欧美aaaaaa午夜精品| 日本精品一区二区三区高清| 亚洲福利国产精品| 日韩欧美国产综合一区| 国产aⅴ综合色| 91精品午夜视频| 国内精品国产成人国产三级粉色| 北岛玲一区二区三区四区| 尤物视频一区二区| 日韩美一区二区三区| 成人在线视频首页| 一区二区三区高清不卡| 日韩欧美卡一卡二| 成人手机在线视频| 亚洲成人精品一区二区| 26uuu亚洲| 欧美在线高清视频| 国模套图日韩精品一区二区| 中文字幕一区免费在线观看| 国产成a人亚洲精| 亚洲精品成人a在线观看| 日韩亚洲欧美中文三级| 成人高清免费在线播放| 国产女主播一区| 国产成人小视频| 亚洲国产精品尤物yw在线观看| 91啪亚洲精品| 日本aⅴ精品一区二区三区| 国产精品传媒视频| aa级大片欧美| 日韩专区一卡二卡| 亚洲视频小说图片| 久久亚洲二区三区| 欧美日韩国产精品成人| 日韩精品免费专区| 国产精品久久久久久久久免费丝袜| 国产99久久精品| 五月天亚洲婷婷| 1024成人网色www| 欧美精品一区二区蜜臀亚洲| 久久精品国产77777蜜臀| 亚洲女性喷水在线观看一区| 在线观看不卡一区| 成人福利视频在线| 国产麻豆视频一区| 日韩中文字幕区一区有砖一区 | 亚洲人成亚洲人成在线观看图片 | 欧美猛男超大videosgay| 国产成人aaa| 亚洲女同一区二区| 久久精品一区八戒影视| 日韩欧美国产综合在线一区二区三区 | 亚洲日本在线a| 国产亚洲一本大道中文在线| 欧美一区二区二区| 欧美色网一区二区| 色婷婷一区二区| 波多野结衣在线一区| 国产伦理精品不卡| 韩国成人在线视频| 精品一区二区三区欧美| 免费成人在线观看视频| 蜜桃视频第一区免费观看| 久久综合九色综合97婷婷| av一区二区不卡| 成人一级黄色片| 国产精品白丝jk黑袜喷水| 亚洲同性gay激情无套| 欧美日韩一区中文字幕| 久久国产尿小便嘘嘘尿| 麻豆成人综合网| 美女视频免费一区| 日韩不卡一区二区三区 | 91麻豆精品国产自产在线观看一区| 老司机免费视频一区二区三区| 久久久久国产精品人| 337p日本欧洲亚洲大胆精品| 91麻豆123| 色综合久久88色综合天天免费| 麻豆国产精品一区二区三区| 亚洲天堂av老司机| 亚洲精品国产第一综合99久久| 日韩精品一区二区三区中文精品| 不卡的av在线| 色一区在线观看| 91久久奴性调教| 在线综合视频播放| 2020国产精品自拍| 91精品综合久久久久久| 色婷婷综合久色| 3751色影院一区二区三区| 91日韩精品一区| 欧美日韩夫妻久久| 精品免费视频.| 国产精品麻豆网站| 亚洲成a人片在线观看中文| 日韩av一区二区三区四区| 国产一区在线看| 99视频在线精品| 欧美日韩aaaaa| 欧美精品一区二区不卡| 亚洲毛片av在线| 蜜臀av国产精品久久久久| 国产一区二区免费在线| 99久久精品国产网站| 亚洲欧美影音先锋| 亚洲午夜成aⅴ人片| 奇米影视一区二区三区小说| 国产99精品国产| 欧美日韩亚洲综合一区| av网站免费线看精品| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 成人看片黄a免费看在线| 欧美性生活影院| 久久综合久久99| 曰韩精品一区二区| 韩国成人福利片在线播放| 久久精品国产澳门| 色综合色综合色综合| 69久久99精品久久久久婷婷| 国产调教视频一区| 日产国产欧美视频一区精品| 99国产一区二区三精品乱码| 日韩精品一区二区在线| 欧美大片一区二区三区| 亚洲乱码国产乱码精品精98午夜 | 久久国产日韩欧美精品| 91在线观看美女| 精品盗摄一区二区三区| 亚洲国产精品久久人人爱蜜臀 | 91精品午夜视频| 欧美一区二区三区四区在线观看| 欧美日韩另类一区| 91精品国产综合久久久蜜臀图片 | 国内精品免费**视频| 欧美日精品一区视频| 国产精品成人一区二区三区夜夜夜| 亚洲精选视频免费看| 国产精品一品二品| 日韩一级精品视频在线观看| 亚洲精品日韩综合观看成人91| 亚洲影院在线观看| 懂色av中文字幕一区二区三区| 国产69精品久久久久毛片| 99久久99久久精品免费观看| www精品美女久久久tv| 日韩一区精品视频| 国内不卡的二区三区中文字幕| 国产成人免费在线观看不卡| 欧美一区二区三区不卡| 亚洲午夜免费视频| 97久久超碰精品国产| 亚洲同性同志一二三专区| 成人午夜免费电影| 国产午夜精品福利| 国产高清亚洲一区| 欧美激情一二三区| 国产一区二区免费看| 久久久91精品国产一区二区精品 | 欧美高清视频在线高清观看mv色露露十八 | 岛国一区二区在线观看| 久久亚洲影视婷婷| 国产精品自拍一区| 国产偷国产偷亚洲高清人白洁| 亚洲乱码一区二区三区在线观看| 亚洲成a人片在线观看中文| 国产精品18久久久久| 久久综合久色欧美综合狠狠| 亚洲免费观看在线观看| 91啪在线观看| 亚洲国产精品欧美一二99| 国产风韵犹存在线视精品| 国产精品网曝门| 91啪亚洲精品| 日日欢夜夜爽一区| 日韩视频一区二区三区 | 久久精品72免费观看| 精品免费视频.| 成人高清免费在线播放| 亚洲精品日韩一| 国产夫妻精品视频| 日韩欧美一区二区在线视频| 久久不见久久见免费视频1| 国产午夜三级一区二区三| 成人av在线播放网站| 亚洲一区在线免费观看| 日韩久久久精品| 成人99免费视频| 亚洲第一激情av| 26uuu精品一区二区在线观看| 日韩电影网1区2区| 国产婷婷色一区二区三区|