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

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

?? can_testbench.v

?? 基于FPGA的can 總線設(shè)計(jì)
?? V
?? 第 1 頁 / 共 4 頁
字號:
          send_bit(0);  // ID 
          send_bit(1);  // ID 
          send_bit(0);  // ID 
          send_bit(1);  // ID 5
          send_bit(1);  // RTR
          send_bit(0);  // r1
          send_bit(0);  // r0
          send_bit(0);  // DLC
          send_bit(1);  // DLC
          send_bit(0);  // DLC
          send_bit(1);  // DLC
          send_bit(1);  // CRC
          send_bit(0);  // CRC
          send_bit(0);  // CRC 4
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(0);  // CRC
          send_bit(1);  // CRC d
          send_bit(0);  // CRC
          send_bit(0);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC 3
          send_bit(1);  // CRC
          send_bit(0);  // CRC
          send_bit(0);  // CRC
          send_bit(1);  // CRC 9
          send_bit(1);  // CRC DELIM
          send_bit(0);  // ACK
          send_bit(1);  // ACK DELIM
          send_bit(1);  // EOF
          send_bit(1);  // EOF
          send_bit(1);  // EOF
          send_bit(1);  // EOF
          send_bit(1);  // EOF
          send_bit(1);  // EOF
          send_bit(1);  // EOF
          send_bit(1);  // INTER
          send_bit(1);  // INTER
          send_bit(1);  // INTER
        end // repeat


      end
    
    join



    read_receive_buffer;
    release_rx_buffer_command;

    read_receive_buffer;
    release_rx_buffer_command;
    read_receive_buffer;

    // Read irq register
    #1 read_register(8'd3);

    // Read error code capture register
    read_register(8'd12);

    // Read error capture code register
//    read_register(8'd12);

    #4000000;

  end
endtask   //  manual_frame_ext



task bus_off_test;    // Testbench sends a frame
  begin

    write_register(8'd10, 8'he8); // Writing ID[10:3] = 0xe8
    write_register(8'd11, 8'hb7); // Writing ID[2:0] = 0x5, rtr = 1, length = 7
    write_register(8'd12, 8'h00); // data byte 1
    write_register(8'd13, 8'h00); // data byte 2
    write_register(8'd14, 8'h00); // data byte 3
    write_register(8'd15, 8'h00); // data byte 4
    write_register(8'd16, 8'h00); // data byte 5
    write_register(8'd17, 8'h00); // data byte 6
    write_register(8'd18, 8'h00); // data byte 7
    write_register(8'd19, 8'h00); // data byte 8

    fork
      begin
        tx_request_command;
      end

      begin
        #2000;

        repeat (16)
        begin
          send_bit(0);  // SOF
          send_bit(1);  // ID
          send_bit(1);  // ID
          send_bit(1);  // ID
          send_bit(0);  // ID
          send_bit(1);  // ID
          send_bit(0);  // ID
          send_bit(0);  // ID
          send_bit(0);  // ID
          send_bit(1);  // ID
          send_bit(0);  // ID
          send_bit(1);  // ID
          send_bit(1);  // RTR
          send_bit(0);  // IDE
          send_bit(0);  // r0
          send_bit(0);  // DLC
          send_bit(1);  // DLC
          send_bit(1);  // DLC
          send_bit(1);  // DLC
          send_bit(1);  // CRC
          send_bit(0);  // CRC
          send_bit(0);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(0);  // CRC
          send_bit(1);  // CRC
          send_bit(0);  // CRC
          send_bit(0);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC DELIM
          send_bit(1);  // ACK            ack error
          send_bit(0);  // ERROR
          send_bit(0);  // ERROR
          send_bit(0);  // ERROR
          send_bit(0);  // ERROR
          send_bit(0);  // ERROR
          send_bit(0);  // ERROR
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // INTER
          send_bit(1);  // INTER
          send_bit(1);  // INTER
        end // repeat

        // Node is error passive now.

        // Read irq register (error interrupt should be cleared now.
        read_register(8'd3);

        repeat (20)
        
        begin
          send_bit(0);  // SOF
          send_bit(1);  // ID
          send_bit(1);  // ID
          send_bit(1);  // ID
          send_bit(0);  // ID
          send_bit(1);  // ID
          send_bit(0);  // ID
          send_bit(0);  // ID
          send_bit(0);  // ID
          send_bit(1);  // ID
          send_bit(0);  // ID
          send_bit(1);  // ID
          send_bit(1);  // RTR
          send_bit(0);  // IDE
          send_bit(0);  // r0
          send_bit(0);  // DLC
          send_bit(1);  // DLC
          send_bit(1);  // DLC
          send_bit(1);  // DLC
          send_bit(1);  // CRC
          send_bit(0);  // CRC
          send_bit(0);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(0);  // CRC
          send_bit(1);  // CRC
          send_bit(0);  // CRC
          send_bit(0);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC DELIM
          send_bit(1);  // ACK            ack error
          send_bit(0);  // ERROR
          send_bit(0);  // ERROR
          send_bit(0);  // ERROR
          send_bit(0);  // ERROR
          send_bit(0);  // ERROR
          send_bit(0);  // ERROR
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // ERROR DELIM
          send_bit(1);  // INTER
          send_bit(1);  // INTER
          send_bit(1);  // INTER
          send_bit(1);  // SUSPEND
          send_bit(1);  // SUSPEND
          send_bit(1);  // SUSPEND
          send_bit(1);  // SUSPEND
          send_bit(1);  // SUSPEND
          send_bit(1);  // SUSPEND
          send_bit(1);  // SUSPEND
          send_bit(1);  // SUSPEND
        end // repeat

        // Node is bus-off now


        // Read irq register (error interrupt should be cleared now.
        read_register(8'd3);



        #100000;

        // Switch-off reset mode
        write_register(8'd0, {7'h0, ~(`CAN_MODE_RESET)});

        repeat (64 * 11)
        begin
          send_bit(1);
        end // repeat

        // Read irq register (error interrupt should be cleared now.
        read_register(8'd3);

        repeat (64 * 11)
        begin
          send_bit(1);
        end // repeat



        // Read irq register (error interrupt should be cleared now.
        read_register(8'd3);

      end
     


    join



    fork
      begin
        tx_request_command;
      end

      begin
        #1100;

        send_bit(1);    // To spend some time before transmitter is ready.

        repeat (1)
        begin
          send_bit(0);  // SOF
          send_bit(1);  // ID
          send_bit(1);  // ID
          send_bit(1);  // ID
          send_bit(0);  // ID
          send_bit(1);  // ID
          send_bit(0);  // ID
          send_bit(0);  // ID
          send_bit(0);  // ID
          send_bit(1);  // ID
          send_bit(0);  // ID
          send_bit(1);  // ID
          send_bit(1);  // RTR
          send_bit(0);  // IDE
          send_bit(0);  // r0
          send_bit(0);  // DLC
          send_bit(1);  // DLC
          send_bit(1);  // DLC
          send_bit(1);  // DLC
          send_bit(1);  // CRC
          send_bit(0);  // CRC
          send_bit(0);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(0);  // CRC
          send_bit(1);  // CRC
          send_bit(0);  // CRC
          send_bit(0);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC
          send_bit(1);  // CRC DELIM
          send_bit(0);  // ACK
          send_bit(1);  // ACK DELIM
          send_bit(1);  // EOF
          send_bit(1);  // EOF
          send_bit(1);  // EOF
          send_bit(1);  // EOF
          send_bit(1);  // EOF
          send_bit(1);  // EOF
          send_bit(1);  // EOF
          send_bit(1);  // INTER
          send_bit(1);  // INTER
          send_bit(1);  // INTER
        end // repeat
      end

    join

    read_receive_buffer;
    release_rx_buffer_command;
    read_receive_buffer;
    release_rx_buffer_command;
    read_receive_buffer;

    #4000000;

    receive_frame(0, 0, {26'h00000e8, 3'h1}, 4'h1, 15'h30bb); // mode, rtr, id, length, crc

    #1000000;

  end
endtask   // bus_off_test



task send_frame_basic;    // CAN IP core sends frames
  begin

    write_register(8'd10, 8'hea); // Writing ID[10:3] = 0xea
    write_register(8'd11, 8'h28); // Writing ID[2:0] = 0x1, rtr = 0, length = 8
    write_register(8'd12, 8'h56); // data byte 1
    write_register(8'd13, 8'h78); // data byte 2
    write_register(8'd14, 8'h9a); // data byte 3
    write_register(8'd15, 8'hbc); // data byte 4
    write_register(8'd16, 8'hde); // data byte 5
    write_register(8'd17, 8'hf0); // data byte 6
    write_register(8'd18, 8'h0f); // data byte 7
    write_register(8'd19, 8'hed); // data byte 8


    // Enable irqs (basic mode)
    write_register(8'd0, 8'h1e);


  
    fork

      begin
        #1500;
        $display("\n\nStart receiving data from CAN bus");
        receive_frame(0, 0, {26'h00000e8, 3'h1}, 4'h1, 15'h30bb); // mode, rtr, id, length, crc
        receive_frame(0, 0, {26'h00000e8, 3'h1}, 4'h2, 15'h2da1); // mode, rtr, id, length, crc
        receive_frame(0, 0, {26'h00000ee, 3'h1}, 4'h0, 15'h6cea); // mode, rtr, id, length, crc
        receive_frame(0, 0, {26'h00000ee, 3'h1}, 4'h1, 15'h00c5); // mode, rtr, id, length, crc
        receive_frame(0, 0, {26'h00000ee, 3'h1}, 4'h2, 15'h7b4a); // mode, rtr, id, length, crc
      end

      begin
        tx_request_command;
      end

      begin
        // Transmitting acknowledge
        wait (can_testbench.i_can_top.i_can_bsp.tx_state & can_testbench.i_can_top.i_can_bsp.rx_ack);
        #1 rx = 0;
        wait (can_testbench.i_can_top.i_can_bsp.rx_ack_lim);
        #1 rx = 1;
      end


    join

    read_receive_buffer;
    release_rx_buffer_command;
    release_rx_buffer_command;
    read_receive_buffer;
    release_rx_buffer_command;
    read_receive_buffer;
    release_rx_buffer_command;
    read_receive_buffer;
    release_rx_buffer_command;
    read_receive_buffer;

    #200000;

    read_receive_buffer;

    // Read irq register
    read_register(8'd3);
    #1000;

  end
endtask   // send_frame_basic



task send_frame_extended;    // CAN IP core sends basic or extended frames in extended mode
  begin

    // Switch-on reset mode
    write_register(8'd0, {7'h0, (`CAN_MODE_RESET)});
    
    // Set Clock Divider register
    extended_mode = 1'b1;
    write_register(8'd31, {extended_mode, 7'h0});    // Setting the extended mode
 
    // Set Acceptance Code and Acceptance Mask registers
    write_register(8'd16, 8'ha6); // acceptance code 0
    write_register(8'd17, 8'hb0); // acceptance code 1
    write_register(8'd18, 8'h12); // acceptance code 2
    write_register(8'd19, 8'h30); // acceptance code 3
    write_register(8'd20, 8'h00); // acceptance mask 0
    write_register(8'd21, 8'h00); // acceptance mask 1
    write_register(8'd22, 8'h00); // acceptance mask 2
    write_register(8'd23, 8'h00); // acceptance mask 3

    // Switch-off reset mode
    write_register(8'd0, {7'h0, ~(`CAN_MODE_RESET)});

    // After exiting the reset mode sending bus free
    repeat (11) send_bit(1);


/*  Basic frame format
    // Writing TX frame information + identifier + data
    write_register(8'd16, 8'h45);   // Frame format = 0, Remote transmision request = 1, DLC = 5
    write_register(8'd17, 8'ha6);   // ID[28:21] = a6
    write_register(8'd18, 8'ha0);   // ID[20:18] = 5
    // write_register(8'd19, 8'h78); RTR does not send any data
    // write_register(8'd20, 8'h9a);
    // write_register(8'd21, 8'hbc);
    // write_register(8'd22, 8'hde);
    // write_register(8'd23, 8'hf0);
    // write_register(8'd24, 8'h0f);
    // write_register(8'd25, 8'hed);
    // write_register(8'd26, 8'hcb);
    // write_register(8'd27, 8'ha9);
    // write_register(8'd28, 8'h87);
*/

    // Extended frame format
    // Writing TX frame information + identifier + data
    write_register(8'd16, 8'hc5);   // Frame format = 1, Remote transmision request = 1, DLC = 5
    write_register(8'd17, 8'ha6);   // ID[28:21] = a6
    write_register(8'd18, 8'h00);   // ID[20:13] = 00
    write_register(8'd19, 8'h5a);   // ID[12:5]  = 5a
    write_register(8'd20, 8'ha8);   // ID[4:0]   = 15
    // write_register(8'd21, 8'h78); RTR does not send any data
    // write_register(8'd22, 8'h9a);
    // write_register(8'd23, 8'hbc);
    // write_register(8'd24, 8'hde);
    // write_register(8'd25, 8'hf0);
    // write_register(8'd26, 8'h0f);
    // write_register(8'd27, 8'hed);
    // write_register(8'd28, 8'hcb);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区欧美在线观看| 色婷婷国产精品久久包臀 | 亚洲综合精品自拍| 日韩一区欧美一区| 亚洲天堂av一区| 亚洲人123区| 亚洲自拍偷拍麻豆| 午夜欧美在线一二页| 一区二区三区**美女毛片| 亚洲精品国产a久久久久久 | 国产成人精品在线看| 高清在线成人网| 粉嫩嫩av羞羞动漫久久久| 成人激情av网| 色婷婷av一区| 欧美一区二区免费视频| 精品国产成人系列| 欧美国产日韩一二三区| 亚洲欧洲成人自拍| 亚洲成av人在线观看| 日韩精品久久理论片| 久久国产人妖系列| 丁香婷婷综合色啪| 一本久道中文字幕精品亚洲嫩| 在线观看不卡一区| 日韩一区二区不卡| 中文字幕欧美区| 夜夜精品视频一区二区| 日韩精品国产欧美| 国产成人丝袜美腿| 91精彩视频在线| 欧美成人a在线| 国产清纯在线一区二区www| 亚洲色大成网站www久久九九| 视频一区二区三区中文字幕| 极品少妇一区二区三区精品视频 | 欧美久久久久中文字幕| 精品少妇一区二区三区视频免付费 | 精品写真视频在线观看| 成人免费视频视频| 欧美高清视频一二三区 | 一本久久精品一区二区| 亚洲国产美女搞黄色| 久久草av在线| www.色精品| 欧美一级生活片| 久久久91精品国产一区二区三区| 亚洲精选视频免费看| 亚洲精品成a人| 精品一区二区三区不卡| 91在线国产观看| 精品不卡在线视频| 亚洲综合男人的天堂| 国产成人av电影在线播放| 在线观看日韩毛片| 国产亚洲成av人在线观看导航| 夜夜夜精品看看| 成人小视频在线观看| 9191成人精品久久| 中文字幕一区二区日韩精品绯色| 日本vs亚洲vs韩国一区三区| 成人在线综合网| 欧美成人猛片aaaaaaa| 亚洲一区二区三区视频在线| 国产成人自拍高清视频在线免费播放| 欧美日韩一区三区| 国产精品久久久久久户外露出| 男男gaygay亚洲| 欧美午夜精品久久久久久孕妇 | 日韩国产欧美一区二区三区| av资源网一区| 久久精品日产第一区二区三区高清版 | 亚洲成人午夜影院| 91影视在线播放| 国产清纯美女被跳蛋高潮一区二区久久w | 欧美亚洲一区二区在线观看| 久久夜色精品国产欧美乱极品| 五月激情六月综合| 色欧美88888久久久久久影院| 国产夜色精品一区二区av| 麻豆视频观看网址久久| 欧美日韩一区视频| 亚洲一区二区视频在线观看| 99久久亚洲一区二区三区青草 | 国产成人av电影在线| 日韩三级精品电影久久久| 亚洲成人自拍网| 欧美在线不卡一区| 一区二区三区四区不卡在线| 国产.欧美.日韩| 精品国产91乱码一区二区三区| 日韩精品乱码av一区二区| 欧美日韩国产影片| 天堂午夜影视日韩欧美一区二区| 99久久99精品久久久久久| 国产精品欧美一区喷水| 国产91精品免费| 欧美韩国日本不卡| 丁香六月久久综合狠狠色| 国产日产欧美一区| 国产一区视频导航| 国产日韩欧美一区二区三区综合| 韩国精品主播一区二区在线观看| 3d成人h动漫网站入口| 日韩精品一级中文字幕精品视频免费观看| 在线一区二区三区四区| 一区二区三区精品在线| 欧美综合天天夜夜久久| 亚洲国产三级在线| 欧美疯狂性受xxxxx喷水图片| 丝袜美腿一区二区三区| 7777女厕盗摄久久久| 日韩av午夜在线观看| 日韩欧美一区二区免费| 国产麻豆91精品| 国产精品每日更新在线播放网址| 91亚洲精品久久久蜜桃| 伊人性伊人情综合网| 精品视频一区二区三区免费| 三级一区在线视频先锋| 日韩欧美高清一区| 国产超碰在线一区| 亚洲精品久久久蜜桃| 欧美日韩精品一区二区三区四区 | 欧美日韩国产色站一区二区三区| 亚洲成人免费影院| 日韩一区二区免费电影| 久久99精品国产.久久久久| 久久久精品2019中文字幕之3| 懂色av一区二区三区免费观看| 成人欧美一区二区三区白人| 色综合 综合色| 日本美女一区二区三区视频| 久久精品人人做人人爽人人| 91丝袜美女网| 视频一区二区欧美| 国产亚洲精品福利| 91国产丝袜在线播放| 免费高清不卡av| 国产精品国模大尺度视频| 欧美女孩性生活视频| 国产精品一区二区三区99| 亚洲激情中文1区| 欧美成人三级在线| 色综合久久久久久久久久久| 免费xxxx性欧美18vr| 国产区在线观看成人精品| 欧美四级电影网| 国产传媒日韩欧美成人| 亚洲午夜免费电影| 国产日韩欧美麻豆| 欧美精品丝袜久久久中文字幕| 国产专区综合网| 一区二区三区产品免费精品久久75| 日韩欧美三级在线| 91福利在线观看| 国产在线视频精品一区| 亚洲影院在线观看| 国产性做久久久久久| 欧美日韩一区二区在线观看视频 | 不卡大黄网站免费看| 亚洲国产精品久久人人爱蜜臀| 精品国产麻豆免费人成网站| 色欧美日韩亚洲| 国产精品一区久久久久| 视频一区中文字幕国产| 国产精品福利在线播放| 日韩网站在线看片你懂的| 91网上在线视频| 国产91精品久久久久久久网曝门| 秋霞电影一区二区| 亚洲乱码中文字幕| 欧美国产禁国产网站cc| 欧美成人一区二区三区在线观看| 一本色道**综合亚洲精品蜜桃冫| 国产精一品亚洲二区在线视频| 五月天久久比比资源色| 中文字幕一区二区在线观看| 日韩欧美一区二区免费| 欧美性感一类影片在线播放| 不卡电影免费在线播放一区| 精品一区二区三区在线播放视频| 亚洲一区二区精品视频| 国产精品三级视频| 欧美大片在线观看一区| 欧美疯狂性受xxxxx喷水图片| 在线视频你懂得一区| 成人精品国产福利| 国产成人精品亚洲日本在线桃色| 美女脱光内衣内裤视频久久网站 | 国产一区二区三区在线观看精品| 日韩福利电影在线| 视频一区在线视频| 亚洲电影一区二区三区| 亚洲蜜臀av乱码久久精品蜜桃| 中文字幕av免费专区久久| 国产日韩欧美a| 亚洲国产精品成人综合| 国产亚洲欧美一级| 国产欧美一区二区精品秋霞影院|