data:image/s3,"s3://crabby-images/8ea28/8ea282b7285902b007d8b365638b40856a39fa72" alt="第十三講微處理器接口芯片設(shè)計(jì)實(shí)例-可編程并行接口芯片設(shè)計(jì)實(shí)例課件_第1頁"
data:image/s3,"s3://crabby-images/08c0d/08c0d455efe9d909b256282f9a7d53c733bbdab8" alt="第十三講微處理器接口芯片設(shè)計(jì)實(shí)例-可編程并行接口芯片設(shè)計(jì)實(shí)例課件_第2頁"
data:image/s3,"s3://crabby-images/52d7c/52d7c0f1b4c206e80f7b69811ad81fa57ed0ef80" alt="第十三講微處理器接口芯片設(shè)計(jì)實(shí)例-可編程并行接口芯片設(shè)計(jì)實(shí)例課件_第3頁"
data:image/s3,"s3://crabby-images/33baa/33baa56969507ca9eb0ce22d0ec90f6b19770b61" alt="第十三講微處理器接口芯片設(shè)計(jì)實(shí)例-可編程并行接口芯片設(shè)計(jì)實(shí)例課件_第4頁"
data:image/s3,"s3://crabby-images/2b16a/2b16a811aba28c6a3c82fbe522ad34357364b020" alt="第十三講微處理器接口芯片設(shè)計(jì)實(shí)例-可編程并行接口芯片設(shè)計(jì)實(shí)例課件_第5頁"
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第十三講
微處理器接口芯片設(shè)計(jì)實(shí)例
--可編程并行接口芯片設(shè)計(jì)實(shí)例曲阜師范大學(xué)電氣信息與自動(dòng)化學(xué)院第十三講
微處理器接口芯片設(shè)計(jì)實(shí)例
--可編程并行接1本講主要內(nèi)容8255的引腳及內(nèi)部結(jié)構(gòu)8255的工作方式及其控制字8255的結(jié)構(gòu)設(shè)計(jì)8255芯片的VHDL語言描述8255芯片VHDL語言描述模塊仿真本講主要內(nèi)容8255的引腳及內(nèi)部結(jié)構(gòu)28255的引腳及內(nèi)部結(jié)構(gòu)外部引腳8255的引腳及內(nèi)部結(jié)構(gòu)外部引腳3內(nèi)部結(jié)構(gòu)內(nèi)部結(jié)構(gòu)4控制字控制字5第十三講微處理器接口芯片設(shè)計(jì)實(shí)例-可編程并行接口芯片設(shè)計(jì)實(shí)例課件6LIBRARYIEEE;USEIEEE.STD_1164.ALL;USEIEEE.STD_LOGIC_ARITH.ALL;USEIEEE.STD_LOGIC_UNSIGNED.ALL;ENTITYPPIIS使用庫(kù)LIBRARYIEEE;使用庫(kù)7PORT(RESET,RD,WR,CS,A0,A1:INSTD_LOGIC;PA:INOUTSTD_LOGIC_VECTOR(7DOWNTO0);PB:INOUTSTD_LOGIC_VECTOR(7DOWNTO0);PCL:INOUTTD_LOGIC_VECTOR(3DOWNTO0);PCH:INOUTSTD_LOGIC_VECTOR(3DOWNTO0);D:INOUTSTD_LOGIC_VECTOR(7DOWNTO0));ENDPPI;實(shí)體描述PORT(實(shí)體描述8構(gòu)造體描述ARCHITECTURERTLOFPPIISSIGNALINTERNAL_BUS_OUT:STD_ULOGIC_VECTOR(7DOWNTO0);SIGNALINTERNAL_BUS_IN:STD_ULOGIC_VECTOR(7DOWNTO0);SIGNALST,AD,FLAG:STD_ULOGIC_VECTOR(1DOWNTO0);SIGNALCTRREG:STD_ULOGIC_VECTOR(7DOWNTO0);SIGNALPA_LATCH,Pb_LATCH,Pc_LATCH:CTRREG:STD_ULOGIC_VECTOR(7DOWNTO0);構(gòu)造體描述ARCHITECTURERTLOFPPII9讀進(jìn)程BEGINPROCESS(RD,CS)Beginst<=cttreg(3)&cttreg(0);if(cs=‘0’andrd=‘0’)thenif(a0=‘0’anda1=‘0’andcttreg(4)=‘1’)theninternal_bus_in<=pa;elsif(a0=‘0’anda1=‘0’andcttreg(1)=‘1’)theninternal_bus_in<=pb;讀進(jìn)程BEGIN10elsif(a0=‘0’anda1=‘1’andst=“01”)theninternal_bus_in(3downto0)<=pcl(3downto0);elsif(a0=‘0’anda1=‘1’andst=“10”)theninternal_bus_in(7downto4)<=pch(3downto0);elsif(a0=‘0’anda1=‘1’andst=“11”andctrreg(7)=‘1’)theninternal_bus_in(3downto0)<=pcl(3downto0);internal_bus_in(7downto4)<=pch(3downto0);elsif(a0=‘0’anda1=‘1’andst=11process(cs,wr,reset)variablectrregF:std_ulogic;variablebctrreg_v:std_ulogic_vector(3downto0);beginif(cs='0'andwr='0')thenad<=a1&a0;ctrregF:=d(7);iternal_bus_out<=d;endif;process(cs,wr,reset)12if(reset='1')thenpa_latch<="00000000";pb_latch<="00000000";pc_latch<="00000000";ctrreg<="10011011"bctrreg_v:="0000";ctrregF:='0';if(reset='1')then13elsif(wr'eventandwr='1')thenif(ctrregF='1'andad="11"andcs='0')thenctrreg<=internal_bus_out;elsif(ctrreg(7)='1'andad="00"andcs='0')thenpa_latch<=internal_bus_out;elsif(ctrreg(7)='1'andad="01"andcs='0')thenpb_latch<=internal_bus_out;elsif(ctrreg(7)='1'andad="10"andcs='0')thenpc_latch<=internal_bus_out;elsif(wr'eventandwr='1')then14
elsif(ctrregF='0'andad="11"andcs='0')thenbctrreg:=internal_bus_out(3downto0);casebctrreg_viswhen"0000"=>pc_latch(0)<='0';when"0010"=>pc_latch(1)<='0';when"0100"=>pc_latch(2)<='0';when"0110"=>pc_latch(3)<='0';when"1000"=>pc_latch(4)<='0';when"1010"=>pc_latch(5)<='0';when"1100"=>pc_latch(6)<='0';when"1110"=>pc_latch(7)<='0';
elsif(ctrregF='0'andad="11"15when"0001"=>pc_latch(0)<='1';when"0011"=>pc_latch(1)<='1';when"0101"=>pc_latch(2)<='1';when"0111"=>pc_latch(3)<='1';when"1001"=>pc_latch(4)<='1';when"1011"=>pc_latch(5)<='1';when"1101"=>pc_latch(6)<='1';when"1111"=>pc_latch(7)<='1';whenothers=>flag<="11";endcase;when"0001"=>pc_latch(0)<='1';16endif;endif;endprocess;endif;17process(pa_latch)beginif(ctrreg(4)='0')thenpa<=pa_latch;elsepa<="ZZZZZZZZ";endif;endprocess;process(pa_latch)18process(pb_latch)beginif(ctrreg(1)='0')thenpb<=pb_latch;elsepa<="ZZZZZZZZ";endif;endprocess;process(pb_latch)19process(pc_latch)beginif(ctrreg(0)='0')thenpcl<=pc_latch(3downto0);elsepcl<="ZZZZ";endif;endprocess;process(pc_latch)20process(pc_latch)beginif(ctrreg(3)='0')thenpch<=pc_latch(7downto4);elsepch<="ZZZZ";endif;endprocess;endrtl;process(pc_latch)218255構(gòu)造體設(shè)計(jì)鎖存器Pa_latcha口輸出鎖存器Pb_latchb口輸出鎖存器Pcl_latchc口低4位輸出鎖存器Pch_latchc口高4位輸出鎖存器Ctrreg方式控制字寄存器Bctrreg選擇標(biāo)志寄存器三態(tài)緩沖器d、pa、pb、pc組合邏輯電路8255構(gòu)造體設(shè)計(jì)鎖存器22Endif;Elseinternal_bus_in<=“ZZZZZZZZ”;Endif;D<=internal_bus_in;Endprocess;讀進(jìn)程Endif;23Std_logic_1164定義了一個(gè)9值模型,每個(gè)值為邏輯電平(0、1與未知)與強(qiáng)度(強(qiáng)制、弱、高阻、未定和無關(guān))的組合,其中高阻、未定和無關(guān)只有一個(gè)電平值(未知)。其定義如下:
TypeStd_Ulogicis(
'U',--未定(Uninitialized)
'X',--強(qiáng)制未知(ForcingUnknown)
'0',--強(qiáng)制0(Forcing0)
'1',--強(qiáng)制1(Forcing1)
'Z',--高阻(HighImpedance)
'W',--弱未知(WeakUnknown)
'L',--弱0(Weak0)
'H',--弱1(Weak1)
'-'--無關(guān)(Don'tCare)
);Std_logic_1164定義了一個(gè)9值模型,每個(gè)值為邏輯24第十三講
微處理器接口芯片設(shè)計(jì)實(shí)例
--可編程并行接口芯片設(shè)計(jì)實(shí)例曲阜師范大學(xué)電氣信息與自動(dòng)化學(xué)院第十三講
微處理器接口芯片設(shè)計(jì)實(shí)例
--可編程并行接25本講主要內(nèi)容8255的引腳及內(nèi)部結(jié)構(gòu)8255的工作方式及其控制字8255的結(jié)構(gòu)設(shè)計(jì)8255芯片的VHDL語言描述8255芯片VHDL語言描述模塊仿真本講主要內(nèi)容8255的引腳及內(nèi)部結(jié)構(gòu)268255的引腳及內(nèi)部結(jié)構(gòu)外部引腳8255的引腳及內(nèi)部結(jié)構(gòu)外部引腳27內(nèi)部結(jié)構(gòu)內(nèi)部結(jié)構(gòu)28控制字控制字29第十三講微處理器接口芯片設(shè)計(jì)實(shí)例-可編程并行接口芯片設(shè)計(jì)實(shí)例課件30LIBRARYIEEE;USEIEEE.STD_1164.ALL;USEIEEE.STD_LOGIC_ARITH.ALL;USEIEEE.STD_LOGIC_UNSIGNED.ALL;ENTITYPPIIS使用庫(kù)LIBRARYIEEE;使用庫(kù)31PORT(RESET,RD,WR,CS,A0,A1:INSTD_LOGIC;PA:INOUTSTD_LOGIC_VECTOR(7DOWNTO0);PB:INOUTSTD_LOGIC_VECTOR(7DOWNTO0);PCL:INOUTTD_LOGIC_VECTOR(3DOWNTO0);PCH:INOUTSTD_LOGIC_VECTOR(3DOWNTO0);D:INOUTSTD_LOGIC_VECTOR(7DOWNTO0));ENDPPI;實(shí)體描述PORT(實(shí)體描述32構(gòu)造體描述ARCHITECTURERTLOFPPIISSIGNALINTERNAL_BUS_OUT:STD_ULOGIC_VECTOR(7DOWNTO0);SIGNALINTERNAL_BUS_IN:STD_ULOGIC_VECTOR(7DOWNTO0);SIGNALST,AD,FLAG:STD_ULOGIC_VECTOR(1DOWNTO0);SIGNALCTRREG:STD_ULOGIC_VECTOR(7DOWNTO0);SIGNALPA_LATCH,Pb_LATCH,Pc_LATCH:CTRREG:STD_ULOGIC_VECTOR(7DOWNTO0);構(gòu)造體描述ARCHITECTURERTLOFPPII33讀進(jìn)程BEGINPROCESS(RD,CS)Beginst<=cttreg(3)&cttreg(0);if(cs=‘0’andrd=‘0’)thenif(a0=‘0’anda1=‘0’andcttreg(4)=‘1’)theninternal_bus_in<=pa;elsif(a0=‘0’anda1=‘0’andcttreg(1)=‘1’)theninternal_bus_in<=pb;讀進(jìn)程BEGIN34elsif(a0=‘0’anda1=‘1’andst=“01”)theninternal_bus_in(3downto0)<=pcl(3downto0);elsif(a0=‘0’anda1=‘1’andst=“10”)theninternal_bus_in(7downto4)<=pch(3downto0);elsif(a0=‘0’anda1=‘1’andst=“11”andctrreg(7)=‘1’)theninternal_bus_in(3downto0)<=pcl(3downto0);internal_bus_in(7downto4)<=pch(3downto0);elsif(a0=‘0’anda1=‘1’andst=35process(cs,wr,reset)variablectrregF:std_ulogic;variablebctrreg_v:std_ulogic_vector(3downto0);beginif(cs='0'andwr='0')thenad<=a1&a0;ctrregF:=d(7);iternal_bus_out<=d;endif;process(cs,wr,reset)36if(reset='1')thenpa_latch<="00000000";pb_latch<="00000000";pc_latch<="00000000";ctrreg<="10011011"bctrreg_v:="0000";ctrregF:='0';if(reset='1')then37elsif(wr'eventandwr='1')thenif(ctrregF='1'andad="11"andcs='0')thenctrreg<=internal_bus_out;elsif(ctrreg(7)='1'andad="00"andcs='0')thenpa_latch<=internal_bus_out;elsif(ctrreg(7)='1'andad="01"andcs='0')thenpb_latch<=internal_bus_out;elsif(ctrreg(7)='1'andad="10"andcs='0')thenpc_latch<=internal_bus_out;elsif(wr'eventandwr='1')then38
elsif(ctrregF='0'andad="11"andcs='0')thenbctrreg:=internal_bus_out(3downto0);casebctrreg_viswhen"0000"=>pc_latch(0)<='0';when"0010"=>pc_latch(1)<='0';when"0100"=>pc_latch(2)<='0';when"0110"=>pc_latch(3)<='0';when"1000"=>pc_latch(4)<='0';when"1010"=>pc_latch(5)<='0';when"1100"=>pc_latch(6)<='0';when"1110"=>pc_latch(7)<='0';
elsif(ctrregF='0'andad="11"39when"0001"=>pc_latch(0)<='1';when"0011"=>pc_latch(1)<='1';when"0101"=>pc_latch(2)<='1';when"0111"=>pc_latch(3)<='1';when"1001"=>pc_latch(4)<='1';when"1011"=>pc_latch(5)<='1';when"1101"=>pc_latch(6)<='1';when"1111"=>pc_latch(7)<='1';whenothers=>flag<="11";endcase;when"0001"=>pc_latch(0)<='1';40endif;endif;endprocess;endif;41process(pa_latch)beginif(ctrreg(4)='0')thenpa<=pa_latch;elsepa<="ZZZZZZZZ";endif;endprocess;process(pa_latch)42process(pb_latch)beginif(ctrreg(1)='0')thenpb<=pb_latch;elsepa<="ZZZZZZZZ";endif;endprocess;process(pb_latch)43process(pc_latch)beginif(ctrreg(0)='0')thenpcl<=pc_latch(3downto0);els
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 產(chǎn)品度合同范例
- 單位租憑員工車輛合同范本
- 中糧銷售合同范本
- 化工散水出售合同范本
- seb采購(gòu)合同范本
- 華為銷售合同范本
- 農(nóng)業(yè)采購(gòu)合同范本格式
- 伐樹施工合同范本
- 代理業(yè)主房屋合同范本
- 寫作委托協(xié)議合同范本
- 初中數(shù)學(xué)新課程標(biāo)準(zhǔn)(2024年版)
- GB/T 19342-2024手動(dòng)牙刷一般要求和檢測(cè)方法
- 2024年山東鐵投集團(tuán)招聘筆試參考題庫(kù)含答案解析
- 8款-組織架構(gòu)圖(可編輯)
- 計(jì)價(jià)格(2002)10號(hào)文
- 青果巷歷史街區(qū)改造案例分析
- 樁身強(qiáng)度自動(dòng)驗(yàn)算表格Excel
- 《鋼鐵是怎樣煉成的》讀書報(bào)告
- 中學(xué)生班干部培訓(xùn)方案(共4頁)
- 凈土資糧——信愿行(11)第六講凈業(yè)三福變化氣質(zhì)
- 美的集團(tuán)公司分權(quán)手冊(cè)
評(píng)論
0/150
提交評(píng)論