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

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

?? rs232_syscon.v

?? 用VHDL語言實現的pic16f84
?? V
?? 第 1 頁 / 共 3 頁
字號:
          `DATA_BITS,   // data_bits
          `STOP_BITS,   // stop_bits
          `CLOCK_FACTOR // clock_factor
         )
         rs232_rx_block // instance name
         ( 
          .clk(clk_i),
          .rx_clk(serial_clk_16x),
          .reset(reset_i || (| rs232_rx_error)),
          .rxd(rs232_rxd_i),
          .read(rs232_tx_load),
          .data(rs232_rx_char),
          .data_ready(rs232_rx_data_ready),
          .error_over_run(rs232_rx_error[0]),
          .error_under_run(rs232_rx_error[1]),
          .error_all_low(rs232_rx_error[2])
         );

//`undef START_BITS 
//`undef DATA_BITS 
//`undef STOP_BITS 
//`undef CLOCK_FACTOR


//--------------------------------------------------------------------------
// Module code
//--------------------------------------------------------------------------

assign adr_o = master_bg_i?adr_ptr:master_adr_i;
assign we_o = master_bg_i?we_l:master_we_i;
assign stb_o = master_bg_i?stb_l:master_stb_i;


assign dat_io = (master_bg_i && we_l && stb_l)?
                   dat_sr:{`NIBBLE_SIZE*DAT_DIGITS_PP{1'bZ}};
                   
// Temporary
assign cyc_o = stb_o;  // Separate cyc_o is not yet supported!


// This is the adress offset counter
always @(posedge clk_i)
begin
  if (reset_i || reset_adr_offset) adr_offset <= 0;
  else if (incr_adr_offset) adr_offset <= adr_offset + 1;
end
// This forms the adress pointer which is used on the bus.
assign adr_ptr = adr_sr + adr_offset;


// This is the ROM for the ASCII characters to be transmitted.
always @(msg_pointer)
begin
  case (msg_pointer) // synthesis parallel_case
    5'b00000 : msg_char <= "0";    // Hexadecimal characters
    5'b00001 : msg_char <= "1";
    5'b00010 : msg_char <= "2";
    5'b00011 : msg_char <= "3";
    5'b00100 : msg_char <= "4";
    5'b00101 : msg_char <= "5";
    5'b00110 : msg_char <= "6";
    5'b00111 : msg_char <= "7";
    5'b01000 : msg_char <= "8";
    5'b01001 : msg_char <= "9";
    5'b01010 : msg_char <= "A";    // Address error indication
    5'b01011 : msg_char <= "B";
    5'b01100 : msg_char <= "C";    // Command error indication
    5'b01101 : msg_char <= "D";    // Data error indication
    5'b01110 : msg_char <= "E";
    5'b01111 : msg_char <= "F";
    5'b10000 : msg_char <= " ";    // Space
    5'b10001 : msg_char <= ":";    // Colon
    5'b10010 : msg_char <= " ";    // Space
    5'b10011 : msg_char <= "?";    // Parse error indication
    5'b10100 : msg_char <= "!";    // ack_i/err_i error indication
    5'b10101 : msg_char <= "O";    // "All is well" message
    5'b10110 : msg_char <= "K";
    5'b10111 : msg_char <= 8'h0d;  // Carriage return & line feed
    5'b11000 : msg_char <= 8'h0a;
    5'b11001 : msg_char <= "-";    // Command Prompt
    5'b11010 : msg_char <= ">";
    5'b11011 : msg_char <= " ";
    5'b11100 : msg_char <= "Q";    // Quantity error indication
    default  : msg_char <= "=";
  endcase
end

// This logic determines when to load a transmit character.
assign rs232_tx_load = rs232_echo?
  (rs232_rx_data_ready && rs232_tx_load_request):rs232_tx_load_request;

// This is the counter for incrementing, decrementing or resetting the 
// message pointer.
always @(posedge clk_i)
begin
  if (reset_i || reset_msg_offset) msg_offset <= 0;
  else if (incr_msg_offset) msg_offset <= msg_offset + 1;
end
assign msg_pointer = msg_offset + msg_base;



// This is the mux which selects whether to echo back the characters
// received (as during the entering of a command) or to send back response
// characters.
assign rs232_tx_char = (rs232_echo)?rs232_rx_char:msg_char;


// These assigments are for detecting whether the received rs232 character is
// anything of special interest.
assign rx_char_is_enter = (rs232_rx_char == 8'h0d);
assign rx_char_is_backspace = (rs232_rx_char == 8'h08);



// This is state machine m1.  It handles receiving the command line, including
// backspaces, and prints error/response messages.  It also parses and
// executes the commands.

// State register
always @(posedge clk_i)
begin : m1_state_register
  if (reset_i) m1_state <= m1_initial_state; // perform reset for rest of system
  else m1_state <= m1_next_state;
end

//         or rd_addr_field_done
//         or rd_data_field_done
//         or rd_line_done
//         or ack_i
//         or err_i

// State transition logic
always @(m1_state
         or rx_char_is_enter
         or rx_char_is_backspace
         or msg_offset
         or cmd_ptr
         or rs232_tx_load
         or char_is_whitespace
         or char_is_hex
         or char_is_enter
         or char_is_i
         or char_is_r
         or char_is_w
         or command
         or master_bg_i
         or watchdog_timer_done
         or err_i
         or ack_i
         or adr_offset
         or qty_sr
         or dat_sr
         or rd_adr_sr
         or rd_field_count
         or rd_digit_count
         )
begin : m1_state_logic

  // Default values for outputs.  The individual states can override these.
  msg_base <= 5'b0;
  reset_msg_offset <= 0;
  incr_msg_offset <= 0;
  rs232_echo <= 0;
  rst_o <= 0;
  we_l <= 0;
  stb_l <= 0;
  cmd_buffer_write <= 0;
  reset_cmd_ptr <= 0;
  incr_cmd_ptr <= 0;
  decr_cmd_ptr <= 0;
  master_br_o <= 0;
  cmd_r <= 0;
  cmd_w <= 0;
  cmd_i <= 0;
  shift_rd_adr <= 0;
  store_adr <= 0;          // enables storing hex chars in adr_sr (shift)
  store_dat <= 0;          // enables storing hex chars in dat_sr (shift)
  store_qty <= 0;          // enables storing hex chars in qty_sr (shift)
  reset_adr <= 0;
  reset_dat <= 0;
  reset_qty <= 0;
  init_qty <= 0;
  capture_dat <= 0;        // enables capturing bus data in dat_sr (load)
  incr_adr_offset <= 0;
  reset_adr_offset <= 0;
  reset_watchdog <= 0;
  incr_rd_field_count <= 0;
  incr_rd_digit_count <= 0;
  reset_rd_field_count <= 0;
  reset_rd_digit_count <= 0;

  case (m1_state) // synthesis parallel_case

    m1_initial_state :
      begin
        incr_msg_offset <= rs232_tx_load;
        if ((msg_offset == 15) && rs232_tx_load) begin
          m1_next_state <= m1_send_prompt;
          reset_msg_offset <= 1;
        end
        else m1_next_state <= m1_initial_state;
      end

    m1_send_ok :
      begin
        msg_base <= 5'b10101;     // Address of the OK message
        incr_msg_offset <= rs232_tx_load;
        if ((msg_offset == 1) && rs232_tx_load) begin
          m1_next_state <= m1_send_prompt;
          reset_msg_offset <= 1;
        end
        else m1_next_state <= m1_send_ok;
      end

    m1_send_prompt :
      begin
        msg_base <= 5'b10111;     // Address of the cr,lf,prompt message
        incr_msg_offset <= rs232_tx_load;
        if ((msg_offset == 4) && rs232_tx_load) begin
          m1_next_state <= m1_check_received_char;
          reset_cmd_ptr <= 1;
        end
        else m1_next_state <= m1_send_prompt;
      end

    // This state always leads to activating the parser...
    m1_send_crlf :
      begin
        msg_base <= 5'b10111;     // Address of the cr/lf message
        incr_msg_offset <= rs232_tx_load;
        if ((msg_offset == 1) && rs232_tx_load) begin
          m1_next_state <= m1_scan_command;
          reset_cmd_ptr <= 1;
        end
        else m1_next_state <= m1_send_crlf;
      end

    m1_check_received_char :
      begin
        rs232_echo <= 1;          // Allow echoing of characters
        if (rx_char_is_backspace && rs232_tx_load)
        begin
          m1_next_state <= m1_check_received_char;
          decr_cmd_ptr <= 1;     // This effectively eliminates the last char
        end
        else if (rx_char_is_enter && rs232_tx_load)
        begin
          m1_next_state <= m1_send_crlf;
          cmd_buffer_write <= 1;  // Store the enter as "marker" for parsing
          reset_msg_offset <= 1;
        end
        else if (rs232_tx_load && (cmd_ptr == CMD_BUFFER_SIZE_PP-1))
        begin
          m1_next_state <= m1_parse_error_indicator_crlf;
          reset_msg_offset <= 1;
          reset_cmd_ptr <= 1;
        end
        else if (rs232_tx_load)
        begin
          incr_cmd_ptr <= 1;
          cmd_buffer_write <= 1;
          m1_next_state <= m1_check_received_char;
        end
        else m1_next_state <= m1_check_received_char;
      end

    m1_bg_error_indicator :
      begin
        msg_base <= 5'b01011;    // Address of the B character
        incr_msg_offset <= rs232_tx_load;
        if ((msg_offset == 0) && rs232_tx_load) begin
          m1_next_state <= m1_ack_error_indicator;
          reset_msg_offset <= 1;
        end
        else m1_next_state <= m1_bg_error_indicator;
      end

    m1_ack_error_indicator :
      begin
        msg_base <= 5'b10100;    // Address of the ! error message
        incr_msg_offset <= rs232_tx_load;
        if ((msg_offset == 0) && rs232_tx_load) begin
          m1_next_state <= m1_send_prompt;
          reset_msg_offset <= 1;
        end
        else m1_next_state <= m1_ack_error_indicator;
      end

    // This state is used when the line is too long...
    m1_parse_error_indicator_crlf :
      begin
        msg_base <= 5'b10111;    // Address of the cr,lf message.
        incr_msg_offset <= rs232_tx_load;
        if ((msg_offset == 1) && rs232_tx_load) begin
          m1_next_state <= m1_parse_error_indicator;
          reset_msg_offset <= 1;
        end
        else m1_next_state <= m1_parse_error_indicator_crlf;
      end

    m1_parse_error_indicator :
      begin
        msg_base <= 5'b10011;    // Address of the ? message.
        incr_msg_offset <= rs232_tx_load;
        if ((msg_offset == 0) && rs232_tx_load) begin
          m1_next_state <= m1_send_prompt;
          reset_msg_offset <= 1;
        end
        else m1_next_state <= m1_parse_error_indicator;
      end

    m1_cmd_error_indicator :
      begin
        msg_base <= 5'b01100;    // Address of 'C'
        incr_msg_offset <= rs232_tx_load;
        if ((msg_offset == 0) && rs232_tx_load) begin
          m1_next_state <= m1_parse_error_indicator;
          reset_msg_offset <= 1;
        end
        else m1_next_state <= m1_cmd_error_indicator;
      end

    m1_adr_error_indicator :
      begin
        msg_base <= 5'b01010;    // Address of 'A'
        incr_msg_offset <= rs232_tx_load;
        if ((msg_offset == 0) && rs232_tx_load)
        begin
          m1_next_state <= m1_parse_error_indicator;
          reset_msg_offset <= 1;
        end
        else m1_next_state <= m1_adr_error_indicator;
      end

    m1_dat_error_indicator :
      begin
        msg_base <= 5'b01101;    // Address of 'D'
        incr_msg_offset <= rs232_tx_load;
        if ((msg_offset == 0) && rs232_tx_load)
        begin
          m1_next_state <= m1_parse_error_indicator;
          reset_msg_offset <= 1;
        end
        else m1_next_state <= m1_dat_error_indicator;
      end

    m1_qty_error_indicator :
      begin
        msg_base <= 5'b11100;    // Address of 'Q'
        incr_msg_offset <= rs232_tx_load;
        if ((msg_offset == 0) && rs232_tx_load)
        begin
          m1_next_state <= m1_parse_error_indicator;
          reset_msg_offset <= 1;
        end
        else m1_next_state <= m1_qty_error_indicator;
      end

    // The following states are for parsing and executing the command.

    // This state takes care of leading whitespace before the command
    m1_scan_command :
      begin
        rs232_echo <= 1;          // Don't send message characters
        reset_msg_offset <= 1;    // This one reset should cover all of the
                                  // parse/exec. states.  With rs232_echo
                                  // on, and no receive characters arrive,
                                  // then the msg_offset will remain reset.
                                  // This means the watchdog timer can take
                                  // a long time, if need be, during exec.
                                  // (NOTE: It might be better to disable
                                  //  the echoing of rx chars during these
                                  //  states.)
        init_qty <= 1;         // Set qty = 1 by default.  That can be
                               // overridden later, if the command has
                               // a different qty field.
        if (char_is_whitespace) begin
          m1_next_state <= m1_scan_command;
          incr_cmd_ptr <= 1;
        end
        else if (char_is_r) begin
          m1_next_state <= m1_scan_adr_whitespace;
          incr_cmd_ptr <= 1;
          cmd_r <= 1;
        end
        else if (char_is_w) begin

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩mp4| 日韩午夜在线观看| av一区二区三区四区| 国产精品亚洲专一区二区三区| 亚洲成在人线免费| 一区二区三区中文字幕在线观看| 亚洲欧美中日韩| 国产精品久久久久久久久免费丝袜| 欧美国产乱子伦| 国产精品久久久久久久久果冻传媒 | 亚洲国产激情av| 欧美激情中文字幕| 中文字幕av在线一区二区三区| 中文欧美字幕免费| 亚洲欧美色一区| 亚洲国产综合在线| 蜜臀久久久99精品久久久久久| 麻豆91在线播放| 国产东北露脸精品视频| 粉嫩av一区二区三区在线播放| www.66久久| 欧美性感一区二区三区| 9191久久久久久久久久久| 欧美一区二区观看视频| 精品国产乱码久久久久久久| 久久精品一区八戒影视| 中文字幕亚洲区| 亚洲电影一区二区| 免费在线欧美视频| 成人午夜在线免费| 欧美丝袜自拍制服另类| 日韩欧美成人午夜| 中文字幕欧美区| 亚洲综合视频在线观看| 久热成人在线视频| 成人黄色软件下载| 欧美日韩精品欧美日韩精品一综合| 69堂国产成人免费视频| 久久久久高清精品| 一区二区三区日韩精品| 蜜臂av日日欢夜夜爽一区| 国产成a人亚洲| 欧美人体做爰大胆视频| 久久精品一区二区三区不卡 | 一区二区三区四区不卡视频| 蜜臀91精品一区二区三区| 成人网在线播放| 欧美视频一区二| 久久精品视频免费观看| 亚洲综合免费观看高清完整版| 免费人成在线不卡| 成人av免费网站| 制服丝袜一区二区三区| 国产精品视频观看| 青青草国产精品亚洲专区无| 成人综合婷婷国产精品久久免费| 色婷婷av一区二区三区gif| 精品久久久久久久久久久久久久久久久| 国产日产欧美一区| 亚洲国产精品天堂| 久久精品亚洲一区二区三区浴池| 国产偷v国产偷v亚洲高清 | 在线观看视频一区二区| 91精品国产综合久久小美女| 国产福利精品导航| 亚洲国产精品一区二区www在线 | 欧美日韩大陆一区二区| 久久精品视频免费观看| 一区二区三区精品在线| 国产精品一区二区久激情瑜伽 | 欧美一区国产二区| 亚洲欧洲综合另类在线| 国产一区视频导航| 久久久久9999亚洲精品| 黄页视频在线91| 国产精品影视天天线| 色婷婷av一区二区| 久久亚洲综合av| 男人操女人的视频在线观看欧美 | 日韩国产精品久久久| 91美女片黄在线观看91美女| 精品福利一二区| 国产综合久久久久久久久久久久 | 成人高清在线视频| 日韩一区二区影院| 中文字幕亚洲在| 岛国精品在线观看| 日韩av成人高清| 色综合天天做天天爱| 亚洲一区欧美一区| 岛国av在线一区| 欧美日韩国产片| 亚洲综合色噜噜狠狠| 91玉足脚交白嫩脚丫在线播放| 国产精品区一区二区三区| 成人美女在线观看| 亚洲国产精品ⅴa在线观看| 亚欧色一区w666天堂| 欧美va日韩va| 不卡的av在线播放| 亚洲香蕉伊在人在线观| 欧美老女人在线| 麻豆freexxxx性91精品| 国产人妖乱国产精品人妖| 在线观看欧美精品| 国产麻豆91精品| 亚洲午夜一区二区三区| 99视频一区二区三区| 亚洲三级小视频| 成人一级片网址| 综合婷婷亚洲小说| 欧美日韩免费一区二区三区| 久久9热精品视频| 首页综合国产亚洲丝袜| 奇米在线7777在线精品| 777欧美精品| 免费欧美高清视频| 精品国产一区二区三区忘忧草 | 日韩精品专区在线影院重磅| 免费精品视频在线| 日韩精品自拍偷拍| 国产成人亚洲综合a∨猫咪| 日本一二三四高清不卡| 成人91在线观看| 亚洲激情五月婷婷| 欧美色图12p| 蜜臀av一区二区在线免费观看| 日韩精品一区二区三区swag| 狠狠色丁香久久婷婷综合丁香| 精品国产免费人成在线观看| 国产尤物一区二区| 国产精品麻豆久久久| 91美女福利视频| 丝袜亚洲另类欧美| 欧美成人欧美edvon| 国产99精品在线观看| 亚洲色图丝袜美腿| 777色狠狠一区二区三区| 国产精品综合二区| 亚洲男人的天堂一区二区| 精品视频123区在线观看| 毛片av一区二区| 国产精品国产三级国产普通话99| 欧美在线免费视屏| 老色鬼精品视频在线观看播放| 欧美激情中文不卡| 欧美三级乱人伦电影| 韩国v欧美v亚洲v日本v| 亚洲男人的天堂一区二区| 日韩欧美色综合网站| 亚洲成av人片在线观看无码| 欧美男同性恋视频网站| 亚洲日本一区二区| 在线免费观看日韩欧美| 国产色一区二区| 亚洲女子a中天字幕| 亚洲成人久久影院| 日韩国产高清影视| 视频一区欧美精品| 韩国理伦片一区二区三区在线播放| 成人黄色网址在线观看| 国产精品综合二区| 不卡一区在线观看| 亚洲一区二区在线播放相泽| 欧美亚洲国产怡红院影院| 麻豆精品精品国产自在97香蕉| 国产精品久久久久久久久晋中 | 久久久夜色精品亚洲| 色域天天综合网| 国产又粗又猛又爽又黄91精品| 亚洲线精品一区二区三区八戒| 国产欧美日韩精品一区| 日韩欧美中文字幕精品| 一本久久精品一区二区| 国产激情一区二区三区| 美国一区二区三区在线播放| 亚洲欧洲中文日韩久久av乱码| 精品国产乱码久久久久久免费| 欧美午夜精品理论片a级按摩| 国产91富婆露脸刺激对白| 日本视频免费一区| 亚洲五码中文字幕| 1024成人网色www| 久久久91精品国产一区二区精品 | 国产精品美女久久久久久久网站| 日韩一区二区三区四区| 在线影院国内精品| 不卡av免费在线观看| 国产乱码精品一区二区三| 日本成人超碰在线观看| 亚洲综合在线五月| 亚洲色图制服诱惑 | 一区二区国产视频| 中文字幕在线观看不卡视频| 精品入口麻豆88视频| 制服丝袜成人动漫| 欧美曰成人黄网| 在线免费不卡视频| 91老师国产黑色丝袜在线| 成人免费av资源|