找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3760|回復(fù): 0
收起左側(cè)

基于FPGA的紅外遙控和LCD顯示框架 附源程序

[復(fù)制鏈接]
ID:771317 發(fā)表于 2020-6-6 18:08 | 顯示全部樓層 |閱讀模式
一個基于FPGA的紅外遙控和LCD顯示框架,支持紅外遙控輸入并在LCD上顯示對應(yīng)的內(nèi)容,可通過修改代碼實現(xiàn)紅外遙控計算器等高級應(yīng)用。
已在臺灣友晶科技的DE2-115開發(fā)板上測試可用,該開發(fā)板的核心FPGA芯片型號為Intel/Altera的Cyclone IV4CE115F29,開發(fā)平臺為Quartus II/Quartus Prime。若要在其他開發(fā)板上使用,可通過修改相應(yīng)配置管腳來實現(xiàn)。
其頂層文件的代碼如下:
  1. module irda_top(
  2.                 input clk,
  3.                 input rst,
  4.                 input key_clear,
  5.                 input iIRDA,
  6.                 output rw,
  7.                 output rs,
  8.                 output en,
  9.                 output [7:0] data_out,
  10.                 output lcd_on,
  11.                 output lcd_bg
  12. );

  13. wire [9:0] data_in;
  14. lcd_1602 lcd_1602_m0(
  15.                 .clk(clk),
  16.                 .rst(rst),
  17.                 .data_in(data_in),
  18.                 .ir_arri(irinf_trig),
  19.                 .key_clear(key_clear),
  20.                 .rw(rw),
  21.                 .rs(rs),
  22.                 .en(en),
  23.                 .next_data(next_data),
  24.                 .data_out(data_out),
  25.                 .lcd_on(lcd_on),
  26.                 .lcd_bg(lcd_bg)
  27. );

  28. wire[31:0] ir_data;
  29. wire ir_arri;
  30. wire [7:0] inf_data;
  31. wire answer_flag;
  32. wire irinf_trig;
  33. wire [127:0] answer;
  34. IR_RECEIVE ir_m0(
  35.                 .iCLK(clk),         //clk 50MHz
  36.                 .iRST_n(rst),       //reset                                       
  37.                 .iIRDA(iIRDA),        //IR code input
  38.                 .oDATA_READY(ir_arri),  //data ready
  39.                 .oDATA(ir_data)         //decode data output
  40.                 );
  41.                
  42. lcd_inf lcd_inf_m0(
  43.                 .clk(clk),
  44.                 .rst(rst),
  45.                 .ir_arri(irinf_trig),
  46.                 .key_clear(key_clear),
  47.                 .trig(next_data),
  48.                 .answer_flag(answer_flag),
  49.                 .inf_data(inf_data),
  50.                 .answer(answer),
  51.                 .data(data_in)
  52. );

  53. data_trans data_trans_m0(
  54.                 .clk(clk),
  55.                 .rst(rst),
  56.                 .trig(ir_arri),
  57.                 .raw_data(ir_data),
  58.                 .final_data(inf_data),
  59.                 .answer_out(answer_flag),
  60.                 .ir_infready(irinf_trig),
  61.                 .answer(answer)
  62. );

  63. endmodule
復(fù)制代碼
綜合后的RTL圖如下:

RTL圖

RTL圖


全部資料51hei下載地址:
irda_lcd_version_2.7z (13.58 MB, 下載次數(shù): 22)





評分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表