單片機與cpld綜合課程設(shè)計_第1頁
已閱讀1頁,還剩10頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、<p>  單片機與CPLD綜合課程設(shè)計</p><p>  學院 電子信息工程學院 </p><p>  專業(yè) 生物醫(yī)學工程 </p><p>  學號 </p><p>  姓名 </p><p&

2、gt;  日期 2014年1月4日 </p><p><b>  摘 要</b></p><p>  基于單片機與C P L D 設(shè)計了一個鍵值采集、顯示及與PC通信的綜合應(yīng)用系統(tǒng)。系統(tǒng)硬件由單片機、CPLD 及外圍電路組成,軟件采用C 語言和硬件描述語言VHDL 編程??蓪崿F(xiàn)上行鍵值采集、顯示,并將采集到的鍵值數(shù)據(jù)通過串口送給PC;下行PC發(fā)送數(shù)據(jù)

3、由系統(tǒng)接收,數(shù)碼管可以顯示接收到的數(shù)據(jù)。該系統(tǒng)工作可靠,在實際設(shè)計應(yīng)用中有一定的參考價值。</p><p><b>  引 言</b></p><p>  隨著電子、計算機技術(shù)的飛速發(fā)展,單片機與CPLD技術(shù)都得到了越來越廣泛的應(yīng)用。單片微型計算機(單片機)自問世以來,因其小巧靈活、成本低、控制能力強、易于產(chǎn)品化等優(yōu)勢,在各領(lǐng)域中得到廣泛的應(yīng)用;但純單片機系統(tǒng)也有弱點

4、:如低速、低可靠性等??删幊踢壿嬈骷﨏PLD含有數(shù)量眾多的可編程邏輯宏單元或邏輯塊,能夠任意組合,可以根據(jù)需要設(shè)計成功能各異的邏輯電路;并且可采用VHDL語言編程,加速了產(chǎn)品的開發(fā)過程,使邏輯電路的設(shè)計變得簡單、易于實現(xiàn);器件的現(xiàn)場可編程,大大地縮短了產(chǎn)品開發(fā)周期及方便更新?lián)Q代;但在信息處理、邏輯分析、決策判斷等方面CPLD 比不上單片機。因此,可以將單片機與CPLD器件結(jié)合,優(yōu)勢互補,組成軟硬件都可靈活編程的系統(tǒng),以適應(yīng)不斷改變的市場

5、需</p><p><b>  求。</b></p><p><b>  一、設(shè)計任務(wù)</b></p><p>  了解單片機與CPLD綜合實驗板及資源,實現(xiàn)如下功能:</p><p> ?、贆z測按鍵輸入:判斷按鍵鍵值,點亮相應(yīng)發(fā)光二極管,同時數(shù)碼管顯示鍵值,并通過串口將鍵值發(fā)給PC。</p&

6、gt;<p> ?、谟蒔C的串口向?qū)嶒灠灏l(fā)送1~9數(shù)據(jù),通過數(shù)碼管能將PC發(fā)送的數(shù)據(jù)正確顯示出來。</p><p><b>  二、相關(guān)知識介紹</b></p><p><b>  1.單片機技術(shù)</b></p><p>  P89C60X2 器件采用高性能的靜態(tài)80C51 設(shè)計,以先進的CMOS 工藝制造

7、 并包含非易失性Flash。程序存儲器可通過并行編程或在系 統(tǒng)編程(ISP)的方法進行編程。支持6 時鐘模式。</p><p>  P89C60X2 包含512 字節(jié)RAM ,64K字節(jié)Flash,32 個I/O 口,3 個16 位定時/計數(shù)器6 中斷源,4 中斷優(yōu)先級,嵌套的中斷結(jié)構(gòu),1 個增強型UART ,看門狗定時器以及片內(nèi)振蕩器和時鐘電路。</p><p>  此外器件的靜態(tài)設(shè)計使

8、其具有非常寬的頻率范圍甚至可低至零。具有兩個軟件可選的節(jié)電模式,空閑模式和掉電模式,空閑模式凍結(jié)CPU 的運行,但允許RAM 、定時器、串口和中斷系統(tǒng)繼續(xù)保持其功能,掉電模式保持RAM 的內(nèi)容,但凍結(jié)振蕩器,這樣使其它片內(nèi)功能都停止工作。由于是靜態(tài)設(shè)計,時鐘停止而不會使用戶數(shù)據(jù)丟失,操作可從時鐘停止點恢復運行。</p><p><b>  2.CPLD技術(shù)</b></p>&l

9、t;p>  EPM7128S: ALTERA的EPM7128S系列CPLD是基于第二代MAX結(jié)構(gòu)體系地高性能EEPROM結(jié)構(gòu)的CPLD。完全符合IEEE1149.1 JTAG邊界掃描標準,具有5V ISP的功能。具有最小5ns的引腳到引腳的邏輯時延,最高可175.4MHz的計數(shù)頻率。引腳可配置為開漏輸出。每個宏單元都有獨立的可編程電源控制,最多可以節(jié)省50%的功耗。宏單元內(nèi)的寄存器具有單獨的時鐘和復位等信號。支持多種電壓接口。實驗

10、板上使用的是一個PLCC84封裝的EPM7128S ,EPM7128S內(nèi)部有128個宏單元、8個邏輯陣列塊和2500個門電路。</p><p><b>  3.綜合實驗板介紹</b></p><p>  本綜合實驗板采用的是ATMEL公司的ATF1508AS芯片作為目標CPLD。 ATF1508AS 與Altera公司的EPM7128S芯片完全兼容,但是可以擦寫的次數(shù)

11、可以上萬次,方便同學們的練習。采用PHILIPS公司的最新的內(nèi)置ISP下載功能的64 KB大容量Flash存儲器和特大RAM的P89C60X2單片機做為目標單片機。</p><p><b>  三、設(shè)計工具簡介 </b></p><p><b>  1.keilC51</b></p><p>  Keil C51是美國Ke

12、il Software公司出品的51系列兼容單片機C語言軟件開發(fā)系統(tǒng),與匯編相比,C語言在功能上、結(jié)構(gòu)性、可讀性、可維護性上有明顯的優(yōu)勢,因而易學易用。Keil C51軟件提供豐富的庫函數(shù)和功能強大的集成開發(fā)調(diào)試工具。</p><p>  C51工具包的整體結(jié)構(gòu),如圖所示,其中uVision與Ishell分別是C51 for Windows和for Dos的集成開發(fā)環(huán)境(IDE),可以完成編輯、編譯、連接、調(diào)試、

13、仿真等整個開發(fā)流程。開發(fā)人員可用IDE本身或其它編輯器編輯C或匯編源文件。然后分別由C51及A51編譯器編譯生成目標文件(.OBJ)。目標文件可由LIB51創(chuàng)建生成庫文件,也可以與庫文件一起經(jīng)L51連接定位生成絕對目標文件(.ABS)。ABS文件由OH51轉(zhuǎn)換成標準的Hex文件,以供調(diào)試器dScope51或tScope51使用進行源代碼級調(diào)試,也可由仿真器使用直接對目標板進行調(diào)試,也可以直接寫入程序存貯器如EPROM中。</p&g

14、t;<p>  2.MaxplusII</p><p>  Max+plusⅡ是Altera公司上一代的PLD開發(fā)軟件,提供的FPGA/CPLD開發(fā)集成環(huán)境,Altera是世界上最大可編程邏輯器件的供應(yīng)商之一。Max+plusⅡ界面友好,使用便捷,被譽Max+plusⅡ是Altera公司上一代的PLD開發(fā)軟件,提供的FPGA/CPLD開發(fā)集成環(huán)境,Altera是世界上最大可編程邏輯器件的供應(yīng)商之一。

15、Max+plusⅡ界面友好,使用便捷,被譽為業(yè)界最易用易學的EDA軟件。在Max+plusⅡ上可以完成設(shè)計輸入、元件適配、時序仿真和功能仿真、編程下載整個流程,它提供了一種與結(jié)構(gòu)無關(guān)的設(shè)計環(huán)境,使設(shè)計者能方便地進行設(shè)計輸入、快速處理和器件編程。目前Altera已經(jīng)停止開發(fā)MaxplusII,而轉(zhuǎn)向QuartusII軟件平臺。</p><p><b>  四、設(shè)計過程</b></p>

16、;<p><b>  1.單片機軟件設(shè)計</b></p><p><b>  .過程</b></p><p><b>  .程序</b></p><p>  #include <reg51.h></p><p>  unsigned char a,ji

17、eshou;</p><p>  void send_char(unsigned char shuzi);</p><p>  void delay(unsigned int x);</p><p>  sbit P00=P0^0; //即定義P00為P0口的第1位,以便進行位操作。</p><p>  sbit P01=P0^1;&

18、lt;/p><p>  sbit P02=P0^2;</p><p>  sbit P03=P0^3;</p><p>  sbit p04=P0^4;</p><p>  sbit P05= P0^5;</p><p><b>  main()</b></p><p>  {

19、 p04=0; //蜂鳴器</p><p>  delay(100);</p><p><b>  P05=0;</b></p><p>  delay(100);</p><p><b>  P05=1;</b></p><p>  delay(150);<

20、/p><p><b>  P05=0;</b></p><p>  delay(100);</p><p><b>  P05=1;</b></p><p>  delay(150);</p><p><b>  P05=0;</b></p>

21、<p>  delay(100);</p><p><b>  P05=1;</b></p><p>  TMOD = 0x20; // 將定時/計數(shù)器1設(shè)置為工作方式2,用于產(chǎn)生波特率,定時器 1不相應(yīng)外部中斷,定時器1處于定時方式,定時器1定時方式為"8位自動充值定時"</p><p>  TH1= 0x

22、FD; //給定時/計數(shù)器1裝初值,確定定時時長. TL1=0xFD; // 波特率9600</p><p>  SCON = 0x50; // 01010000,串行口控制寄存器設(shè)置為工作方式1并允許中斷接收數(shù)據(jù)。</p><p&

23、gt;  PCON = 0x00; // 波特率不倍增 </p><p>  TR1 = 1; // 啟動定時器1</p><p>  IE = 0x0; // 禁止任何中斷</p><p><b>  a=0;</b>

24、</p><p><b>  while(1)</b></p><p><b>  {</b></p><p>  unsigned char n; //n;</p><p>  P2=0xff; n=P2; </p><p>  if(n!=0xff) /

25、/判斷鍵值</p><p><b>  {</b></p><p>  delay(20);</p><p>  if(n!=0xff)</p><p><b>  {</b></p><p>  switch(n) </p><

26、;p><b>  {</b></p><p>  case(0xfe):P03=0;P02=0;P01=0;P00=0;send_char(0x0);P05=0;delay(300);P05=1;delay(200);break;//0 case(0xfd):P03=0;P02=0;P01=0;P00=1;send_char(0x1);P05=0;de

27、lay(300);P05=1;delay(200);break;//1 case(0xfb):P03=0;P02=0;P01=1;P00=0;send_char(0x2);P05=0;delay(300);P05=1;delay(200);break;//2 case(0xf7):P03=0;P02=0;P01=1;P00=1;send_char(0x3);P05=0;d

28、elay(300);P05=1;delay(200);break;//3 case(0xef):P03=0;P02=1;P01=0;P00=0;send_char(0x4</p><p><b>  }</b></p><p><b>  }</b></p><p>  

29、} </p><p>  if(RI) // 是否有數(shù)據(jù)到來,由PC的串口向?qū)嶒灠灏l(fā)送1~9數(shù)據(jù) { </p><p><b>  RI = 0;</b></p><p>  jieshou = SBUF; // 暫存接收到的數(shù)據(jù)</p

30、><p>  switch(jieshou)</p><p>  { </p><p>  case(0x0):P03=0;P02=0;P01=0;P00=0;P05=0;delay(300);P05=1;break; case(0x1):P0

31、3=0;P02=0;P01=0;P00=1;P05=0;delay(300);P05=1;break; case(0x2):P03=0;P02=0;P01=1;P00=0;P05=0;delay(300);P05=1;break; case(0x3):P03=0;P02=0;P01=1;P00=1;P05=0;

32、delay(300);P05=1;break; case(0x4):P03=0;P02=1;P01=0;P00=0;P05=0;delay(300);P05=1;break; case(0x5):P03=0;</p><p><b>  }</b></p&g

33、t;<p><b>  }</b></p><p><b>  } </b></p><p><b>  } </b></p><p>  void send_char(unsigned char shuzi) //傳送一個字符,串口將鍵值發(fā)給PC</p><p>

34、;<b>  {</b></p><p>  SBUF = shuzi;</p><p>  while(!TI); // 等特數(shù)據(jù)傳送</p><p>  TI = 0; // 清除數(shù)據(jù)傳送標志</p><p><b>  

35、} </b></p><p>  void delay(unsigned int x)</p><p><b>  {</b></p><p>  unsigned char j;</p><p>  while(x--)</p><p><b>  {</b>&

36、lt;/p><p>  for (j=0;j<125;j++)</p><p><b>  {;}</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  2.cpld軟件設(shè)計</p>

37、<p><b>  .過程</b></p><p><b>  .程序</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  ENTITY li IS</p><p>

38、;<b>  PORT(</b></p><p>  A: IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  Y:Out STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  KEYIN:in STD_LOGIC_VECTOR(7 DOWNTO 0);</p>

39、;<p>  LEDOUT:OUT STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  KEYOUT:out STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  SPKIN:in STD_LOGIC;</p><p>  SPKOUT:OUT STD_LOGIC;</p><p

40、>  W4IN:in STD_LOGIC; --位選</p><p>  W4OUT:out STD_LOGIC); </p><p><b>  END li;</b></p><p>  ARCHITECTURE lili OF li IS</p><p>  SIGNAL TEMP

41、: STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  SIGNAL TEMP3: STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p><b>  BEGIN</b></p><p>  W4OUT<=W4IN; </p><p>  SPKOUT<=SPK

42、IN;</p><p>  PROCESS(A,KEYIN)</p><p>  VARIABLE COMB:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  VARIABLE COMB3:STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p><b>  BEGIN</b&g

43、t;</p><p>  COMB:=A(3)&A(2)&A(1)&A(0);</p><p>  COMB3:=KEYIN(7)&KEYIN(6)&KEYIN(5)&KEYIN(4)&KEYIN(3)&KEYIN(2)&KEYIN(1)&KEYIN(0);</p><p>  CASE

44、 COMB IS</p><p>  WHEN"0000"=>TEMP<="11000000"; --0</p><p>  WHEN"0001"=>TEMP<="11111001";</p><p>  WHEN"0010"=>TE

45、MP<="10100100";</p><p>  WHEN"0011"=>TEMP<="10110000";</p><p>  WHEN"0100"=>TEMP<="10011001";</p><p>  WHEN"010

46、1"=>TEMP<="10010010";</p><p>  WHEN"0110"=>TEMP<="10000010";</p><p>  WHEN"0111"=>TEMP<="11111000";</p><p> 

47、 WHEN"1000"=>TEMP<="10000000"; --8</p><p>  WHEN"1001"=>TEMP<="10010000"; --9</p><p>  WHEN OTHERS=>TEMP<="ZZZZZZZZ";</p&

48、gt;<p><b>  END CASE;</b></p><p>  CASE COMB3 IS</p><p>  WHEN"11111110"=>TEMP3<="11111110"; --采集的鍵值</p><p>  WHEN"11111101"

49、=>TEMP3<="11111101";</p><p>  WHEN"11111011"=>TEMP3<="11111011";</p><p>  WHEN"11110111"=>TEMP3<="11110111";</p><p&

50、gt;  WHEN"11101111"=>TEMP3<="11101111";</p><p>  WHEN"11011111"=>TEMP3<="11011111";</p><p>  WHEN"10111111"=>TEMP3<="1011

51、1111";</p><p>  WHEN"01111111"=>TEMP3<="01111111";</p><p>  WHEN OTHERS=>TEMP3<="ZZZZZZZZ";</p><p><b>  END CASE;</b></

52、p><p>  END PROCESS;</p><p>  Y(0)<=TEMP(0);</p><p>  Y(1)<=TEMP(1);</p><p>  Y(2)<=TEMP(2);</p><p>  Y(3)<=TEMP(3);</p><p>  Y(4)<

53、;=TEMP(4);</p><p>  Y(5)<=TEMP(5);</p><p>  Y(6)<=TEMP(6);</p><p>  Y(7)<=TEMP(7);</p><p>  --CPLD采集的鍵值數(shù)據(jù)通過keyout0~keyout7送給單片機的A8~A15輸入</p><p>  

54、KEYOUT(0)<=TEMP3(0); </p><p>  KEYOUT(1)<=TEMP3(1);</p><p>  KEYOUT(2)<=TEMP3(2);</p><p>  KEYOUT(3)<=TEMP3(3);</p><p>  KEYOUT(4)<=TEMP3(4);</p>

55、<p>  KEYOUT(5)<=TEMP3(5);</p><p>  KEYOUT(6)<=TEMP3(6);</p><p>  KEYOUT(7)<=TEMP3(7);</p><p>  LEDOUT(0)<=TEMP3(0);</p><p>  LEDOUT(1)<=TEMP3(1);&l

56、t;/p><p>  LEDOUT(2)<=TEMP3(2);</p><p>  LEDOUT(3)<=TEMP3(3);</p><p>  LEDOUT(4)<=TEMP3(4);</p><p>  LEDOUT(5)<=TEMP3(5);</p><p>  LEDOUT(6)<=T

57、EMP3(6);</p><p>  LEDOUT(7)<=TEMP3(7);</p><p>  END lili;.</p><p><b>  調(diào)試及結(jié)果</b></p><p>  本系統(tǒng)利用單片機與CPLD實現(xiàn)了鍵值采集及顯示,并將數(shù)據(jù)通過串口發(fā)向上位機PC;也可接收從上位機送來的數(shù)據(jù)并顯示接收的數(shù)據(jù)。在

58、設(shè)計中充分考慮了單片機與CPLD 的互補性。通過實驗證實系統(tǒng)工作穩(wěn)定,在實際的應(yīng)用中具有很好的參考價值。通過調(diào)試,系統(tǒng)實現(xiàn)了鍵值的采集和判斷,并且按下某個鍵時蜂鳴器會發(fā)聲,對應(yīng)的二極管發(fā)光,數(shù)碼管也顯示相應(yīng)的數(shù)字。</p><p><b>  六、心得、體會</b></p><p>  通過此次設(shè)計實驗,讓我看到了單片機與CPLD的實際應(yīng)用價值。讓我對單片機與CPLD

59、有了客觀的認識,并且增加了許多樂趣。</p><p><b>  總結(jié)</b></p><p>  本系統(tǒng)利用單片機與CPLD實現(xiàn)了鍵值的判斷,并點亮了相應(yīng)發(fā)光二極管,同時數(shù)碼管顯示鍵值,并將數(shù)據(jù)通過串口發(fā)向PC;也可接收從PC機送來的數(shù)據(jù)并顯示接收得數(shù)據(jù)。使單片機與CPLD得到了完美的結(jié)合。</p><p><b>  參考文獻&l

60、t;/b></p><p>  [1]畢立恒,劉玉賓. 一種實用單片機和 CPLD最小應(yīng)用系統(tǒng)的設(shè)計[J].自動化技術(shù)與應(yīng)用.2009,28(8):111-113</p><p>  [2]周立功,夏宇聞.單片機與CPLD 綜合應(yīng)用技術(shù)[M].北京:北京航空航天大學出版社.2004.</p><p>  [3] 彭 穎. 基于單片機和CPLD器件的綜合系統(tǒng)設(shè)計

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論