Máy tính giao tính Teletype

Tài liệu Máy tính giao tính Teletype: ... Ebook Máy tính giao tính Teletype

doc73 trang | Chia sẻ: huyen82 | Lượt xem: 1493 | Lượt tải: 0download
Tóm tắt tài liệu Máy tính giao tính Teletype, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
LUAÄN VAÊN TOÁT NGHIEÄP ÑEÀ TAØI: MAÙY TÍNH GIAO TIEÁP TELETYPE BOÄ GIAÙO DUÏC VAØ ÑAØO TAÏO ÑAÏI HOÏC QUOÁC GIA TP HOÀ CHÍ MINH TRÖÔØNG ÑAÏI HOÏC SÖ PHAÏM KYÕ THUAÄT TP HOÀ CHÍ MINH KHOA ÑIEÄN - ÑIEÄN TÖÛ SVTH : PHAÏM HUØNG PHONG TRÖÔNG VIEÄT NAM LÔÙP : 95 KÑÑ GVHD : QUAÙCH THANH HAÛI THAØNH PHOÁ HOÀ CHÍ MINH 3 - 2000 Coäng Hoøa Xaõ Hoäi Chuû Nghóa Vieät Nam Ñoäc Laäp - Töï Do - Haïnh Phuùc BOÄ GIAÙO DUÏC VAØ ÑAØO TAÏO ÑAÏI HOÏC QUOÁC GIA THAØNH PHOÁ HOÀ CHÍ MINH TRÖÔØNG ÑAÏI HOÏC SÖ PHAÏM KYÕ THUAÄT KHOA ÑIEÄN BOÄ MOÂN ÑIEÄN TÖÛ NHIEÄM VUÏ LUAÄN VAÊN TOÁT NGHIEÄP Sinh vieân thöïc hieän : PHAÏM HUØNG PHONG -TRÖÔNG VIEÄT NAM Ngaønh : ÑIEÄN - ÑIEÄN TÖÛ Lôùp : 95 KÑÑ TEÂN ÑEÀ TAØI : MAÙY TÍNH GIAO TIEÁP TELETYPE 1. CAÙC SOÁ LIEÄU BAN ÑAÀU: 2. NOÄI DUNG THUYEÁT MINH TÍNH TOAÙN: 3. CAÙC BAÛN VEÕ : 4. GIAÙO VIEÂN HÖÔÙNG DAÃN : QUAÙCH THANH HAÛI 5. NGAØY GIAO NHIEÄM VUÏ : 13 -12 - 1999 6. NGAØY HOAØN THAØNH NHIEÄM VUÏ : 28 - 2 -2000 Thoâng qua boä moân Ngaøy.........thaùng........naêm....... Chuû nhieäm boä moân Giaùo vieân höôùng daãn NHAÄN XEÙT CUÛA GIAÙO VIEÂN HÖÔÙNG DAÃN NHAÄN XEÙT CUÛA GIAÙO VIEÂN PHAÛN BIEÄN LÔØI NOÙI ÑAÀU Thoâng tin lieân laïc laø moät vaán ñeà raát quan troïng trong giai ñoaïn hieän nay vaø cuõng ñang ñöôïc phaùt trieån moät caùch maïnh meõ. Hieän nay coù raát nhieàu hình thöùc thoâng tin lieân laïc nhö : voâ tuyeán, höõu tuyeán … Trong moãi hình thöùc laïi coù nhieàu daïng truyeàn nhö : truyeàn hình aûnh, truyeàn thoaïi, truyeàn maõ soá … Teletype laø moät trong nhöõng daïng truyeàn maõ soá ñöôïc phaùt trieån töø kieåu ñieän tín ngaøy xöa. Töø hai tín hieäu tích vaø te ñeå hieåu ñöôïc moät töø hay moät chöõ coù moät maõ rieâng bieät nhoùm caùc tín hieäu aáy laïi vôùi nhau. Sau ñoù vì löôïng thoâng tin ngaøy caøng nhieàu maø kieåu truyeàn tín hieäu coù toác ñoä quaù chaäm so vôùi nhu caàu ngöôøi ta môùi nghó ra vieäc truyeàn nhöõng choãi xung vôùi hai möùc: MARKING vaø SPACING trong moät khung töø goïi laø maõ BAUDOT. Nhöõng xung naøy ñöôïc truyeàn ñi vôùi taàn soá quy öôùc ñöôïc goïi laø toác ñoä BAURATE ñöôïc ñònh nghóa laø soá xung truyeàn ñi trong moät giaây. Ñaây chính laø phöông phaùp truyeàn cuûa Teletype. Maùy Teletype ñöôïc caûi tieán raát nhieàu töø loaïi Teletype ñaàu tieân baèng cô khí raát coàng keành, oàn aøo vaø khoù thao taùc ñeán nhöõng maùy Teletype goïn nheï, deã thao taùc. Vôùi söï buøng noå heä thoáng caùc maùy vi tính nhö hieän nay, chuùng em duøng maùy tính ñeå trao ñoåi döõ lieäu nhö maùy Teletype. Ñaây laø ñeà taøi ñeå chuùng em hoaøn thaønh luaän vaên toát nghieäp. Ñeà taøi neâu leân ñöôïc hình thöùc truyeàn soá lieäu giöõa hai maùy tính (giaû maùy Teletype), khoâng neâu baät heát öu dieåm cuûa maùy tính vì truyeàn theo daïng Teletype chæ truyeàn 5 bit kyù töï (trong khi ñoù maùy tính truyeàn ñöôïc toái ña tôùi 7 bit kyù töï). LÔØI CAÛM TAÏ Chuùng em xin chaân thaønh caûm ôn Ban Giaùm Hieäu vaø caùc thaày coâ Tröôøng Ñaïi Hoïc Sö Phaïm Kyõ Thuaät ñaõ chæ daãn chuùng em trong nhöõng thaùng naêm hoïc taäp taïi tröôøng. Trong quaù trình thöïc hieän taäp luaän vaên toát nghieäp chuùng em xin chaân thaønh caûm ôn thaày Quaùch Thanh Haûi, giaùo vieân höôùng daãn, caùc thaày coâ trong Khoa ñieän vaø caùc baïn trong vaø ngoaøi lôùp ñaõ ñoäng vieân giuùp ñôõ chuùng em hoaøn thaønh luaän vaên toát nghieäp. Tuy nhieân, do khaû naêng coøn haïn cheá vaø thôøi gian coù haïn, chaéc chaén trong taäp luaän vaên khoâng traùnh khoûi thieáu soùt, mong ñöôïc söï thoâng caûm vaø ñoùng goùp yù kieán cuûa quyù thaày coâ vaø caùc baïn ñeå taäp luaän vaên hoaøn chænh hôn. Chuùng em xin chaân thaønh caûm ôn. TP Hoà Chí Minh - Thaùng 2 naêm 2000 Nhoùm sinh vieân thöïc hieän Phaïm Huøng Phong Tröông Vieät Nam MUÏC LUÏC * PHAÀN GIÔÙI THIEÄU I.Töïa ñeà taøi II. Nhieäm vuï luaän vaên toát nghieäp III. Nhaän xeùt giaùo vieân höôùng daãn IV. Nhaän xeùt giaùo vieân phaûn bieän V. Lôøi caûm taï VI. Lôøi noùi ñaàu VII. Muïc luïc * PHAÀN NOÄI DUNG PHAÀN A : CÔ SÔÛ LYÙ THUYEÁT 1 CHÖÔNG DAÃN NHAÄP 1 I. Ñaët vaán ñeà 1 II. Muïc ñích nghieân cöùu 1 III. Caùch thöïc hieän 1 IV .Nhieäm vuï thöïc hieän 2 CHÖÔNG II : CAÙC KHAÙI NIEÄM LIEÂN QUAN ÑEÁN VIEÄC TRUYEÀN THOÂNG 3 I. Truyeàn thoâng tuaàn töï 3 II. Truyeàn thoâng ñoàng boä baát ñoàng boä 3 1. Truyeàn thoâng ñoàngboä 3 2. Truyeàn thoâng baát ñoàng boä 3 III. Caùc khaùi nieäm lieân quan ñeán vieäc truyeàn thoâng 4 1. Ñaàu caém vaø oå caém 4 2. Tín hieäu baét tay 4 3. DTE vaø DCE 5 4. Caùc thoâng soá cuûa trao ñoåi tin noái tieáp 5 5. Maïch trao ñoåi tin noái tieáp cuûa PC 5 6. Thuû tuïc trao ñoåi tin noái tieáp 7 IV. Chuaån giao tieáp RS_232C 8 1. Vaøi neùt cô baûn veà coång noái tieáp 8 2. Ñaëc ñieåm kyõ thuaät veà ñieän cuûa RS_232C 9 3. Caùc IC kích phaùt vaø thu cuûa RS_232C 10 CHÖÔNG III : NGUYEÂN LYÙ TRUYEÀN DÖÕ LIEÄU CUÛA TELETYPE 11 I. Giaûn ñoà xung 11 II. Khung kyù töï Teletype 11 III. Maõ kyù töï Teletype 12 IV. Tieâu chuaån giao tieáp maùy Teletype 13 1. Nguyeân lyù keát noái giöõa 2 maùy Teletype 13 2. Giao tieáp duøng doøng ñieän voøng 20mA 14 CHÖÔNG IV : KHOÁI GHEÙP NOÁI SONG SONG - NOÁI TIEÁP VAØ NOÁI TIEÁP - SONG SONG 15 I. Giôùi thieäu veà vieäc truyeàn thoâng tin noái tieáp cuûa PC 15 II. Nhieäm vuï cuûa khoái gheùp noái song song - noái tieáp vaø noái tieáp - song song 15 III. Sô ñoà khoái cuûa khoái gheùp noái 16 IV. Vi maïch trao ñoåi tin song song - noái tieáp KÑB 8251A 17 CHÖÔNG V : GIÔÙI THIEÄU VEÀ NGAÉT CUÛA PC 28 I. Caùc loaïi ngaét cuûa PC 28 1. Ngaét cöùng 28 2. Ngaét meàm 28 II. Thuû tuïc xöû lyù ngaét chöông trình 29 III. Giôùi thieäu veà caùch söû duïng IRQ4 30 IV. Söû duïng ngaét cuûa ROM-BIOS 31 PHAÀN B : THIEÁT KEÁ PHAÀN CÖÙNG 37 I. Sô ñoà khoái 37 II. Sô ñoà nguyeân lyù 38 III. Nguyeân lyù hoaït ñoäng cuûa maïch 39 IV. Tính toaùn caùc linh kieän cuûa maïch 39 PHAÀN C : XAÂY DÖÏNG PHAÀN MEÀM 41 I. Löu ñoà 41 II. Chöông trình PHAÀN D : HÖÔÙNG THI COÂNG I. Toång quaùt II. Toå chöùc maïch III. Caùc böôùc thi coâng IV. Baùo caùo keát quaû thi coâng * Keát luaän * Phuï luïc * Taøi lieäu tham khaûo PHAÀN A CÔ SÔÛ LYÙ THUYEÁT CHÖÔNG DAÃN NHAÄP I. Ñaët vaán ñeà: Thoâng tin lieân laïc luoân laø vaán ñeà ñöôïc quan taâm ñeán trong xaõ hoäi. Ngay töø thôøi xa xöa, con ngöôøi cuõng ñaõ bieát vaän duïng nhöõng gì coù saün nhö ngoïn löûa, aùm hieäu . . . ñeå truyeàn tin. Ngaøy nay, vieäc thu nhaäp thoâng tin ñaày ñuû vaø kòp thôøi laø ñieàu kieän tieân quyeát cho söï thaønh baïi cuûa taát caû caùc quyeát ñònh trong moïi lónh vöïc. Thoâng tin phaûi ñöôïc truyeàn nhanh choùng töø khaép moïi ñôn vò thu thaäp thoâng tin veà trung taâm, ñeå töø ñaây xöû lyù vaø phaûn hoài caùc chæ thò hoaït ñoäng cho caùc cô sôû. Maùy vi tính ngaøy caøng giöõ moät vai troø quan troïng trong caùc lónh vöïc khoa hoïc kyõ thuaät vaø cuoäc soáng haøng ngaøy. Caùc öùng duïng cuûa noù phuïc vuï cho con ngöôøi ngaøy ña daïng. Vieäc duøng maùy tính ñeå truyeàn soá lieäu laø heát söùc thuaän lôïi, vì ngoaøi vieäc thieát keá phaàn cöùng, ta coù theå thay ñoåi phaàn meàm moät caùch deã daøng vaø nhanh choùng. II. Muïc ñích nghieân cöùu: Quaù trình löïa choïn vaø thöïc hieän ñeà taøi naøy laø nhieäm vuï chuùng em hoaøn taát khoùa hoïc ñaïi hoïc. Ngoaøi ra, vieäc nghieân cöùu ñeà taøi naøy ñeå phaùt huy vieäc öùng duïng maùy tính trong lónh vöïc truyeàn thoâng, taïo ra nhöõng saûn phaåm, thieát bò coù tính tieán boä vaø hieäu quaû giuùp ích cho con ngöôøi. III. Caùch thöùc thöïc hieän: Ñeà taøi naøy ñöôïc thöïc hieän nhö sau: Tìm hieåu nguyeân lyù hoaït ñoäng, caùch thöùc truyeàn soá lieäu giöõa hai maùy Teletype. Vaän duïng kieán thöùc ñaõ ñöôïc hoïc veà caáu truùc maùy tính ñeå thieát keá maïch truyeàn soá lieäu giöõa hai maùy tính qua coång COM1. Tìm hieåu caùc thanh ghi trong UART deå vieát phaàn meàm thöïc hieän vieäc truyeàn soá lieäu. IV. Nhieäm vuï thöïc hieän: Nhieäm vuï chính thöïc hieän laø truyeàn soá lieäu theo phöông thöùc truyeàn baát ñoàng boä qua coång COM1 cuûa hai maùy tính. Ñoàng thôøi, naâng ñieän aùp cuûa ñöôøng truyeàn leân ± 60V ñeå thöïc hieän vieäc truyeàn ñi xa. Ñeà taøi chia thaønh chia thaønh 4 phaàn chính: Phaàn A : Ñeà caäp ñeán caùc cô sôû lyù thuyeát, caùc thuaät ngöõ ñöôïc söû duïng trong quaù trình truyeàn thoâng tuaàn töï. Phaàn B : Thieát keá maïch phaàn cöùng ñeå caùch ly giöõa hai maùy tính vaø naâng cao ñieän aùp ñöôøng truyeàn. Phaàn C : Vieát löu ñoà ñieàu khieån maùy tính truyeàn soá lieäu qua coång COM1. Phaàn D : Höôùng thi coâng. CHÖÔNG II : CAÙC KHAÙI NIEÄM LIEÂN QUAN ÑEÁN VIEÄC TRUYEÀN THOÂNG I. Truyeàn thoâng tuaàn töï: Haàu heát caùc maùy vi tính löu tröõ vaø thao taùc döõ lieäu cuûa chuùng theo caùch song song. Nghóa laø khi truyeàn 1 Byte thì caùc Bit ñi cuøng moät luùc treân caùc maïch daây song song. Soá caùc Bit gôûi ñi cuøng moät luùc thay ñoåi tuøy thuoäc vaøo moãi loaïi maùy tính khaùc nhau nhöng thöôøng laø 8 hoaëc boäi soá cuûa 8. Tuy nhieân ngoaøi vieäc trao ñoåi tin song song vôùi moät maùy tính khaùc (hoaëc moät thieát bò ngoaøi) coù daïng tin vaøo - ra song song, maùy tính coøn trao ñoåi tin noái tieáp vôùi maùy tính khaùc hoaëc thieát bò ngoaøi) coù daïng tin vaøo ra töøng bit moät. Boä giao tieáp töøng töï phaûi nhaän nhöõng Byte ôû daïng song vaø gôûi ñi caùc bit moät caùch rieâng bieät. Döõ lieäu treân ñöôøng truyeàn trong truyeàn thoâng töøng töï chæ ôû hai traïng thaùi laø Mark vaø Space töông öùng vôùi traïng thaùi ñieän theá aâm vaø ñieän theá döông. Baát kyø döõ lieäu truyeàn naøo, tröôùc tieân ñeàu phaûi chuyeån thaønh moät daõy thöù töï caùc Mark vaø Space (Mark töông öùng vôùi soá 1, Space töông öùng vôùi soá 0). II. Truyeàn thoâng ñoàng boä - baát ñoàng boä: 1. Truyeàn thoâng ñoàng boä: (Synchronous Communication) Quaù trình truyeàn vaø nhaän xaûy ra gaàn nhö ñoàng thôøi (coù söï treã do vaän toác truyeàn treân ñöôøng daây) theo töøng bit hay nhoùm bit do moät maùy phaùt xung nhòp taïo ra. Khi nhöõng kyù töï ñöôïc gôûi theo moât khoái ôû toác ñoä cuûa maùy, chuùng döôïc ñöa ra ngoaøi moät caùch ñeàu ñaën. Nhö vaäy seõ khoâng caàn thieát theâm vaøo cho moãi kyù töï truyeàn nhöõng Start bit vaø Stop bit. Bôûi vì moät khi kyø töï ñaàu tieân ñöôïc nhaän thì thieát bò nhaän coù theå tieân ñoaùn moät caùch chính xaùc khi naøo thì nhöõng kyù töï tieáp theo seõ ñeán. Noùi caùch khaùc, thieát bò nhaän coù theå töï ñoàng boä hoùa vôùi maùy truyeàn. Phöông thöùc truyeàn nhö treân goïi laø truyeàn thoâng ñoàng boä. Phöông phaùp naøy coù ñaëc ñieåm sau: - Nhanh : vì phaùt vaø nhaän haàu nhö töùc thôøi. - Khoâng tin caäy : deã maát tin. - Luoân ñoøi hoûi nguoàn phaùt vaø nguoàn nhaän phaûi saün saøng trao ñoåi tin . 2. Truyeàn thoâng baát ñoàng boä : (Asynchronous Communication) Vieäc phaùt vaø nhaän xaûy ra khoâng ñoàng thôøi, khoâng cuøng moät nhòp do hai maùy phaùt nhòp thôøi gian khaùc nhau ñieàu khieån, daïng tin phaùt vaø tin thu khoâng gioáng nhau. Khi döõ lieäu ñöôïc truyeàn bôûi ngöôøi söû duïng nhaäp töø baøn phím, caùc kyù töï nhaäp luoân luoân ñöôïc gôûi ñi vaø nhaän vaøo moät caùch baát ñoàng boä, bôûi vì ngöôøi söû duïng khoâng theå nhaán phím moät caùch lieân tuïc vaø ñeàu ñaën. Do ñoù, khi moät maùy tính nhaän nhöõng kyù töï, thì giöõa nhöõng kyù töï nhaän ñoù seõ coù nhöõng thôøi gian ngöng khaùc nhau. Ñieàu naøy seõ gaây cho maùy tính veäc khoâng theå bieát chính xaùc ñöôïc khi naøo thì moät kyù töï keá tieáp seõ ñöôïc goûi ñeán. Vì thieáu tính lieân tuïc nhö vaäy, cho neân caàn phaûi theâm vaøo nhöõng bít phuï tröôùc vaø sau kyù töï ñöôïc truyeàn. Nhöõng bit theâm vaøo naøy goïi laø Start bit, Stop bit. Phöông thöùc truyeàn nhö treân goïi laø truyeàn thoâng baát ñoàng boä. Quaù trình phaùt vaø nhaän ñöôïc dieãn ra nhö sau: - Nguoàn phaùt vaø nguoàn nhaän ñöa tín hieäu yeâu caàu trao ñoåi tin (hay saün saøng trao ñoåi tin). - Nguoàn nhaän hoaëc ngoàn phaùt ñöa tín hieäu xaùc nhaän (chaáp nhaän yeâu çaàu). - Nguoàn phaùt ñöa tin vaøo ñöôøng daây soá lieäu ñeå ghi vaøo thanh ghi soá lieäu ñeäm cuûa khoái gheùp noái. - Nguoàn nhaän nhaän soá lieäu töø khoái gheùp noái. Ñaëc ñieåm cuûa pheùp truyeàn naøy laø: - tin caäy (theo phöông thöùc hoûi ñaùp hay baét tay hoaëc hoäi thoaïi). - chaäm, toán thieát bò vì coù cô cheá hoûi ñaùp vaø boä ñeäm soá lieäu. III. Caùc khaùi nieäm lieân quan ñeán vieäc truyeàn thoâng: 1. Ñaàu caém vaø oå caém: (Plug And Socket) Coù moät vaøi kieåu khaùc nhau veà ñaàu caèm vaø oå caém cho nhöõng caùp keát noái vôùi thieát bò tuaàn töï. Boä keát noái D_ type 25 chaân vaø 9 chaân ñöôïc söû duïng roäng raõi nhaát, ñoâi khi ngöôøi ta coøn goïi laø DB_25 vaø DB_9. Nhöõng boä keát noái goàm coù nhöõng chaân (Pins) hoaëc nhöõng loå caém (Sockets). Boä keát noái vôùi nhöõng chaân caém (pins) laø nhöõng boä keát noái "ñöïc" (male). Boä keát noái vôùi nhöõng loå caém (Sockets) laø nhöõng boä keát noái "caùi" (Female). Treân moãi chaân caém hoaëc loã caém cuûa boä keát noái (Connector) ñeàu ñöôïc ñaùnh soá. 2. Tín hieäu baét tay: (Handshaking) Trong nhieàu tröôøng hôïp, thieát bò truyeàn caàn bieát raèng thieát bò nhaän coù saün saøng nhaän tin hay khoâng. Thí duï ta coù theå gôûi döõ lieäu töø maùy naøy sang maùy khaùc vaø maùy thöù hai khoâng theå xöû lyù döõ lieäu nhanh baèng vôùi toác ñoä nhaän döõ lieäu. Trong tröôøng hôïp naøy, thoâng tin phaûi ñöôïc gôûi ngöôïc töø thieát bò nhaän tôùi thieát bò truyeàn ñeå chæ ra raèng noù saün saøng hoaëc khoâng saün saøng nhaän. Thoâng tin naøy goïi laø doøng kieåm tra (Flow Control) hoaëc tín hieäu baét tay (Handshaking). Coù hai loaïi Handshaking laø Handshaking phaàn cöùng vaø handskaking phaàn meàm. Caû hai loaïi naøy ñeàu bao goàm nhöõng tín hieäu gôûi ngöôïc töø thieát bò nhaän ñeán thieát bò truyeàn. Vôùi Handshaking phaàn cöùng: thieát bò nhaän gôûi moät ñieän theá döông treân ñöôøng daây baét tay khi noù saün saøng nhaän döõ lieäu. Khi maùy truyeàn nhaän moät ñieän theá aâm, noù bieát raèng phaûi ngöøng vieäc gôûi döõ lieäu. Vôùi handshaking phaàn meàm, tín hieäu baét tay chöùa ñöïng nhöõng kyù töï ñaëc bieät ñöôïc truyeàn theo ñöôøng daây döõ lieäu thay vì treân ñöôøng daây baét tay. 3. DTE (Data Terminal Equipment) vaø DCE (Data Communication Equipment) DTE : laø thieát bò ñaàu cuoái ñöôïc hieåu töông töï nhö maùy tính. DCE : ñöôïc hieåu töông töï nhö Modem. Caùc chuaån ñeå phaân bieät DTE vaø DCE: - Thieát bò naøo söû duïng chaân soá 2 ñeå xuaát döõ lieäu thì döôïc hieåu nhö thieát bò DTE. - Thieát bò naøo söû duïng chaân soá 2 ñeå nhaän döõ lieäu thì ñöôïc hieåu nhö thieát bò DCE. Tuy nhieân hai caùch phaân bieät treân chæ laø töông ñoái. 4. Caùc thoâng soá cuûa trao ñoåi tin noái tieáp: - Khoaûng caùch trao ñoåi tin: khoaûng caùch giöõa nguoàn phaùt vaø nguoàn thu tin. Neáu ôû khoaûng caùch gaàn (döôùi 300m) söï thu vaø phaùt khoâng caàn modem Neáu ôû khoaûng caùch xa (lôùn hôn 300m) caàn Modem cho tin caäy. - Toác ñoä trao ñoåi thoâng tin: ñôn vò ñöôïc tính laø bit trong moät giaây (bit per second,bps) coøn goïi laø Baud. Thöôøng coù toác ñoä 600, 1200, 2400, 4800, 9600 paud (hay bps). Trao ñoåi tin khoâng ñoàng boä thöôøng coù toác ñoä chaäm (döôùi 4800 bps) coøn trao ñoåi tin ñoàng boä vaø lai coù theå ñaït tôùi treân 9600 bps. Hieän nay toác ñoä trao ñoåi tin soá ñaõ ñaït tôùi côõ Mbps (106 bps). - Chieàu trao ñoåi tin : trao ñoåi tin coù theå + Treân moät ñöôøng daây duy nhaát, coù theå coù hai chieàu ñi vaø veà giöõa hai nguoàn phaùt vaø thu tin. ÔÛ moät thôøi ñieåm chæ truyeàn theo moät chieàu (baùn song coâng) + Treân hai ñöôøng daây rieâng reõ TxD (phaùt hay truyeàn) vaø RxD (nhaän hay thu) vôùi caùc chieàu xaùc ñònh (ñôn coâng) vaø taïi moät thôøi ñieåm coù theå truyeàn ñoàng thôøi theo caû hai chieàu (song coâng). Tuøy maïch khueách ñaïi ñöôøng daây vaø soá ñöôøng daây noái (moät hoaëc hai ñöôøng) ta coù chieàu trao ñoåi tin khaùc nhau (ñôn coâng, baùn song coâng hay song coâng). 5. Maïch trao ñoåi tin noái tieáp cuûa maùy vi tính: Tuøy loái ra, caùch noái maïch vaø thieát bò ngoaøi ta coù caùc loaïi maïch trao ñoåi tin noái tieáp giöõa maùy vi tính vaø thieát bò ngoaøi khaùc nhau. a. Maïch khoâng caàn khoái gheùp noái: Ñoù laø söï trao ñoåi tin vôùi thieát bò ngoaøi noái tieáp vaø loái ra hay vaøo cuûa vi xöû lyù cuõng laø noái tieáp (hình 1). Coù hai loaïi loái vaøo ra cuûa vi xöû lyù laø: - Loái vaøo ra noái tieáp rieâng bieät (SID, SOD) nhö cuûa vi xöû lyù 8085. - Moät chaân loái vaøo ra song song cuûa vi xöû lyù ñöôïc duøng cho loái vaøo ra noái tieáp. Caû hai tröôøng hôïp treân ñeàu ñoøi hoûi nhieàu thôøi gian trao ñoåi tin cuûa vi xöû lyù. D Thanh ghi dòch Vi xöû lyù D1 CK ù Thieát bò ngoaøi song song , ra song song SOD,SID C Hình 1: b. Maïch caàn khoái gheùp noái song song noái tieáp (Hình 2): Ngöôøi ta duøng khoái gheùp noái song song noái tieáp ñeå bieán ñoåi tin song song cuûa vi xöû lyù (ñöa ra moät laàn) thaønh tín hieäu noái tieáp truyeàn cho thieát bò ngoaøi noái tieáp. Vi Xöû lyù KGN song song noái tieáp TBN (VXL) noái tieáp Hình 2 c. Maïch caàn khoái gheùp noái song song noái tieáp vaø noái tieáp song song (Hình 3): Ñaây laø tröôøng hôïp trao ñoåi tin giöõa vi xöû lyù vôùi thieát bò ngoaøi trao ñoåi tin song song. Tröôøng hôïp naøy xaûy ra khi maùy vi tính ñaët caùch xa thieát bò ngoaøi vaø khoâng theå thöïc hieän trao ñoåi tin song song ñöôïc vì toán nhieàu ñöôøng daây. Coù hai tröôøng hôïp: - Neáu khoaûng caùch giöõa maùy vi tính vaø thieát bò ngoaøi gaàn (döôùi 300m) khoâng caàn Modem. - Neáu khoaûng caùch giöõa maùy vi tính vaø thieát bò ngoaøi xa (treân 300m) caàn coù Modem ñeå ñieàu cheá tín hieäu soá thaønh aâm taàn (traùnh nhieãu) vaø tín hieäu aâm taàn ñieàu cheá thaønh tín hieäu soá. Vi Xöû lyù KGN song song noái tieáp TBN (VXL) song song KGN song song noái tieáp Hình 3 d. Maïch caàn khoái gheùp noái, Modem vaø khoái gheùp noái RS_232C (Hình 4): Ñaây laø tröôøng hôïp toång quaùt vaø thoâng duïng cuûa trao ñoåi tin giöõa maùy tính (song song) vôùi thieát bò ngoaøi (song song) ñaët ôû khoaûng caùch xa (caàn modem) vaø söû duïng chính ñöôøng daây ñieän thoaïi ñeå trao ñoåi tin (KGN RS_232C) bieán ñoåi möùc tín hieäu TTL thaønh möùc tín hieäu treân ñöôøng daây ñieän thoaïi (± 12 V). Vi Xöû Lyù KGN song song noái tieáp RS 232C Mo dem Mo dem KGN song song noái tieáp RS 232C TBN (VXL) song song Hình 4 6. Thuû tuïc tao ñoåi tin noái tieáp: Thuû tuïc trao ñoåi tin giöõa moät maùy vi tính vaø moät thieát bò nhaän tin song song (thieát bò ñaàu cuoái, maùy in song song, ñuïc baêng, ...) thoâng qua caùc khoái gheùp noái song song - noái tieáp vaø noái tieáp - song song vaø Modem (Hình 4) theo trình töï sau: a. Thuû tuïc phaùt tin TxD: - Thieát bò ñaàu cuoái (hay maùy vi tính) gôûi tín hieäu DTR (Data Terminal Ready - Söï saün saøng cuûa thieát bò ñaàu cuoái coù soá lieäu) möùc thaáp cho Modem baùo noù saün saøng. - Modem gôûi traû lôøi thieát bò ñaàu cuoái (TBÑC) baèng tín hieäu DSR (Data Set Ready) möùc thaáp. Thoâng thöôøng, modem ñöôïc ñoùng maïch nguoàn nuoâi bôûi DTR vaø baùo hieäu ñaõ ñoùng maïch bôûi DSR. - Neáu thieát bò ñaàu cuoái coù moät kyù töï (Character) saün saøng gôûi ñi, noù gôûi RTS (Request To Send - yeâu caàu gôûi) möùc thaáp cho Modem. - Modem gôûi tín hieäu CD (Carrier Detect - phaùt hieän soùng mang) cho TBÑC ñeå baùo raèng noù ñaõ lieân laïc ñöôïc vôùi maùy vi tính. - Khi Modem ñaõ hoaøn toaøn saün saøng phaùt soá lieäu leân ñöôøng daây, noù phaùt xung nhòp (Modem Clock) vaø tín hieäu CTR (Clear To Send) tôùi thieát bò ñaàu cuoái. - TBÑC gôûi caùc kyù töï soá lieäu (SUD) TxD cho Modem. - Khi thieát bò ñaàu cuoái gôûi xong soá lieäu, noù naâng möùc RTS leân cao baùo cho Modem laø ñaõ phaùt xong . - Modem traû lôøi thieát bò ñaàu cuoái baèng caùch keát thuùc tín hieäu CTS veà möùc cao, baùo ñaõ hoaøn thaønh vieäc truyeàn tin TxD. b. Thuû tuïc nhaän tin RxD: Khi moät thieát bò ñaàu cuoái nhaän tin noái tieáp töø ñöôøng daây, trình töï dieãn ra nhö sau: - TBÑC thu gôûi DTR möùc thaáp cho modem baùo saün saøng. - Modem thu giöõ traû lôøi bôûi DSR. - Modem thu nhaän tín hieäu CD töø ñöôøng daây vaø kích thích phaùt tín hieäu nhòp modem (Modem Clock) cho tín hieäu thu. - TBÑC phaùt tín hieäu RTS möùc thaáp cho modem bieát laø saün saøng thu. - Modem nhaän tín hieäu RTS vaø phaùt CTS möùc thaáp cho thieát bò ñaàu cuoái thu bieát modem saün saøng nhaän tin. - Modem nhaän tín hieäu TxD ñaõ ñieàu cheá ôû treân ñöôøng daây ñöa vaøo boä giaûi ñieàu cheá vaø truyeàn chuoãi tín hieäu RxD cho thieát bò ñaàu cuoái thu. - Khi thu xong, TBÑC thu naâng RTS leân cao baùo cho modem bieát vieäc thu moät lôøi tin ñaõ xong. - Modem thu naâng möùc CTS leân cao ñeå baùo ñaõ keát thuùc vieäc thu caùc tín hieäu RxD. IV. Chuaån giao tieáp RS_232C: 1. Vaøi neùt cô baûn veà coång noái tieáp: Coång noái tieáp RS_232C laø giao dieän phoå bieán roäng raõi nhaát. Ngöôøi duøng maùy tính PC coøn goïi caùc coång naøy laø COM1, COM2. Gioáng nhö coång maùy in, coång noái tieáp RS_232C cuõng ñöôïc söû duïng moät caùch raát thuaän tieän cho muïc ñích ño löôøng vaø ñieàu khieån . Chuaån RS_232C duøng vôùi toác ñoä truyeàn döõ lieäu laø 20 Kbps vôùi khoaûng caùch truyeàn lôùn nhaát gaàn 15 m. Ñaây laø moät daïng giao tieáp daïng TTL vaø boä kích ñöôøng daây khoâng caân baèng. Vieäc truyeàn döõ lieäu qua coång RS_232C ñöôïc tieán haønh theo caùch noái tieáp, nghóa laø caùc bit döõ lieäu ñöôïc gôûi ñi noái tieáp nhau treân moät ñöôøng daãn. Treân hình 5 laø söï boá trí chaân cuûa phích caém RS_232C ôû maùy tính PC. 14 13 1 25 Hình 5a : Boä noái 25 chaân (DB_25) 6 9 1 5 Hình 5b : Boä noái 9 chaân (DB_9) Trong ñoù : AA : Protective Ground (noái ñaát baûo veä) TxD : Transmitter Data (truyeàn döõ lieäu) RxD : Received Data (nhaän döõ lieäu) RTS :Request To Send (yeâu caàu gôûi) CTS : Clear To Send (xoùa vieäc gôûi) DSR : Data Set Ready (döõ lieäu saün saøng) SG : Signal Ground (noái ñaát) CD : Carrier Detect (doø soùng mang) ST : Select Stanty SCF : Secondary Recived Line Signal Det SCB : Secondary Clear To Send SBA : Secondary Transmitter Data DB : Transmitter Signal Element Timing SBB :Secondary Received Data DD : Received Signal Element Timing SCA : Secondary Request To Send DTR : Data Terminal Ready ( traïm ñaàu cuoái thieát bò saün saøng) CG : Signal Quality Detector RI : Ring Indicator ( boä chæ thò voøng) CH : Data Signal Rate Selector CI : Data Signal Rate Selector DA : Transmitter Signal Element Timing 2. Ñaëc ñieåm kyõ thuaät veà ñieän cuûa RS_232C: Möùc ñieän aùp logic cuûa RS_232C laø hai khoaûng ñieän aùp giöõa +15 V vaø -15 V. Caùc ñöôøng döõ lieäu söû duïng möùc logic aâm, logic 1 coù ñieän theá giöõa -5V vaø -15V, logic 0 coù ñieän theá giöõa +5V vaø +15V. Tuy nhieân caùc ñöôøng ñieàu khieån söû duïng möùc logic döông, giaù trò TRUE töø +5V ñeán +15V, giaù trò FALSE töø -5V ñeán -15V. ÔÛ chuaån giao tieáp naøy, giöõa ngoõ ra boä kích phaùt vaø ngoõ vaøo boä thu coù möùc nhieãu ñöôïc giôùi haïn laø 2V. Do vaäy ngöôõng lôùn nhaát cuûa ngoõ vaøo laø ±3V, traùi laïi möùc ±5V laø ngöôõng nhoû nhaát ñoái vôùi ngoõ ra. Ngoõ ra boä kích phaùt khi khoâng taûi coù ñieän aùp laø ±25V. Caùc ñaëc ñieåm veà ñieän khaùc bao goàm: - RL (ñieän trôû taûi) ñöôïc nhìn töø boä kích phaùt phaûi coù giaù trò giöõa 7KW vaø 3KW. - CL (ñieän dung taûi) ñöôïc nhìn töø boä kích phaùt khoâng ñöôïc vöôït quaù 2500 pF. - Ñeå ngaên caûn söï dao ñoäng quaù möùc, toác ñoä thay ñoåi cuûa ñieän aùp khoâng ñöôïc vöôït quaù 30 V/us. - Ñoái vôùi caùc ñöôøng ñieàu khieån, thôøi gian chuyeån cuûa tín hieäu khoâng ñöôïc vöôït quaù 1ms. Ñoái vôùi caùc ñöôøng döõ lieäu, thôøi gian chuyeån phaûi khoâng vöôït quaù 4% thôøi gian cuûa 1 bit hoaëc 1 ms. 3. Caùc IC kích phaùt vaø thu cuûa RS_232C: Nhôø tính phoå bieán cuûa giao tieáp RS_232C, ngöôøi ta ñaõ cheá taïo caùc IC kích phaùt vaø thu. Hai vi maïch nhö vaäy ñöôïc Motorola saûn xuaát laø IC kích phaùt MC1488 vaø IC thu 1489 coù daïng voû vuoâng. Hình 6 cho thaáy 1port RS_232C ñöôïc keát noái vôùi ACIA 6850 söû duïng MC1488 vaø MC1489. Moãi IC kích phaùt 1488 nhaän moät tín hieäu möùc TTL vaø chuyeån thaønh tín hieäu ôû ngoõ ra töông thích vôùi möùc ñieän aùp cuûa RS_232C, IC thu 1489 phaùt hieän caùc möùc vaøo cuûa RS_232C vaø chuyeån thaønh caùc ngoõ ra coù möùc TTL. CS0 CS1 CS2 RS D0 - D7 R/W IRQ SELACIA A0 DATA BUS R/W IRQ F2 +12V -12V 1488 +12V -12V 1488 Rx/Tx CLK TxCLK RxCLK TxD RxD CD RTS CTS +5V +5V Enable TTL LEVEL RS_232C LEVEL (±12V) RS_232C TxD RxD CD CTS RTS 1489 1489 1489 CHÖÔNG III : NGUYEÂN LYÙ TRUYEÀN DÖÕ LIEÄU CUÛA TELETYPE I. Giaûn ñoà xung cuûa Teletype: Teletype truyeàn döõ lieäu kieåu xung. Tröôùc ñaây ngöôøi ta truyeàn vôùi daïng xung MARK öùng vôùi ñieän aùp döông vaø xung SPACE öùng vôùi ñieän aùp aâm hoaëc 0V (vôùi caùc ñôøi maùy Teletype baèng cô khí). Tuy nhieân, sau naøy khi maùy Teletype ñieän töû ra ñôøi ngöôøi ta chuyeån sang truyeàn theo möùc logic, öùng vôùi möùc logic 1 (ñieân aùp aâm) laø xung MARKING, vaø möùc 0 (ñieän aùp döông) laø xung SPACING. Moâ taû nhö sau: Logic 0 +60V -60V 0V (SPACE) Logic1 (MARK) II. Khung kyù töï cuûa Teletype: Moät Frame cuûa Teletype ñöôïc quy öôùc nhö sau: - 1 bit Start (SPACE) - 5 bit kyù töï (SPACE hoaëc MARK) - 1,5 bit Stop (MARK) Moâ taû nhö sau: Logic 1 (MARK) Logic 0 -60V 0V +60V Start 5 bit kyù töï Stop (SPACE) III. Maõ kyù töï Teletype: Caùc bit kyù töï 4 3 2 1 0 LETTER FIGURE 0 0 0 0 0 BLANK BLANK (SP) 0 0 0 0 1 E 3 0 0 0 1 0 LF LF 0 0 0 1 1 A _ 0 0 1 0 0 SPACE SPACE 0 0 1 0 1 S BELL 0 0 1 1 0 I 8 0 0 1 1 1 U 7 0 1 0 0 0 CR CR 0 1 0 0 1 D $ 0 1 0 1 0 R 4 0 1 0 1 1 J ' 0 1 1 0 0 N ' 0 1 1 0 1 F ! 0 1 1 1 0 C : 0 1 1 1 1 K ( 1 0 0 0 0 T 5 1 0 0 0 1 Z " 1 0 0 1 0 L ) 1 0 0 1 1 W 2 1 0 1 0 0 H # 1 0 1 0 1 Y 6 1 0 1 1 0 P 0 1 0 1 1 1 Q 1 1 1 0 0 0 O 9 1 1 0 0 1 B ? 1 1 0 1 0 G & 1 1 0 1 1 FIGURE FIGURE 1 1 1 0 0 M . 1 1 1 0 1 X / 1 1 1 1 0 V ; 1 1 1 1 1 LETTER LETTER Hai kyù töï LETTER vaø FIGURE duøng ñeå chuyeån ñoåi boä chöõ cuûa Teletype töø maët chöõ sang maët soá (daáu). IV. Tieâu chaån giao tieáp maùy Teletype: 1. Nguyeân lyù keát noái giöõa hai maùy Teletype: Caùc ñöôøng tín hieäu cuûa maùy Teletype goàm coù nhö sau: - Moät ñöôøng vaøo laø ñöôøng thu Rx. - Moät ñöôøng ra laø ñöôøng phaùt Tx. - Moät ñöôøng mass. Khi môû maùy, ñöôøng phaùt seõ töø möùc logic 0 (+60V) seõ ñöôïc naâng leân möùc logic 1 (-60V). Toång ñaøi viba hoaëc maùy Teletype ñoái phöông khi nhaän ñöôïc tín hieäu naøy (ñöôøng thu cuûa maùy ñoái phöông ñöôïc Set leân möùc logic 1) thì seõ gôûi traû tín hieäu traû lôøi cuõng baèng caùch Set ñöôøng phaùt cuûa maùy hoï leân möùc logic 1. Ñöôøng thu cuûa maùy ta seõ nhaän ñöôïc möùc logic 1. Luùc naøy coi nhö hai maùy ñaõ ñöôïc baét tay vaø baét ñaàu truyeàn soá lieäu cho nhau. Tröôøng hôïp maùy ta khoâng nhaän ñöôïc tín hieäu traû lôøi töùc laø coù söï coá ñöôøng daây hoaëc vì maùy ñoái phöông khoâng môû maùy. Ñöôøng phaùt cuûa maùy ta seõ töï ñoäng traû veà möùc logic 0 (+60V) vaø thoâng baùo hôû maïch. Nhö vaäy ta coù theå phaân tích maïch keát noái vôùi maùy Teletype nhö hình 7 : - Khi khoâng baét tay: E2 ñöôïc noái vôùi nguoàn -60V ® Q2 khoâng daãn ® Q3 cuõng khoâng daãn. coøn Q1 ñöôïc daãn baõo hoøa. do ñoù, nguoàn +60 V qua R2 ® D3 (Led D3 saùng baùo hôû maïch) ® R1 ñeán ñöôøng daây thu cuûa maùy ñoái phöông ( Nhö vaäy ñöôøng daây thu cuûa maùy ñoái phöôngñang ôû möùc logic 0). - Töông töï ñöôøng daây phaùt cuûa maùy ñoái phöông cuõng ôû möùc logic 0, neân ñöôøng daây thu cuûa maùy ta cuõng ôû möùc logic 0, cöïc B cuûa Q4 ñöôïc ñaët vaøo moät ñieän aùp döông neân Q4 taét ® ñieän aùp ôû M2 laø -60V (D4 saùng). - Khi caàn goïi, ta cho E2 noái ñaát Q2 daãn ® Q3 daãn ® Q1 taét. Do ñoù töø Relay cuûa maùy ñoái phöông moät doøng ñieän töø mass qua D2 ® Q3 ® veà nguoàn -60V. Luùc naøy, ñoái phöông seõ traû lôøi baèng caùch gôûi ñeán ñöôøng daây thu cuûa ta möùc logic 1 (doøng-20mA). Do ñoù, Q4 daãn vaø M2 coi nhö noái ñaát (D2 saùng). Nhaän ñöôïc tín hieäu naøy töùc laø ñöôøng daây ñaõ ñöôïc keát noái vaø saün saøng truyeàn soá lieäu. +60V Ñeán Rx cuûa maùy Teletype - 60V Töø Tx cuûa maùy Teletype Ground M2 E2 R4 R2 DZ Q1 D2 R8 R5 R1 Q2 R3 D3 Q3 R9 R6 R10 R8 R7 Q4 R25 D5 D4 Hình 7 : 2. Giao tieáp duøng doøng ñieän voøng 20 mA: Giao tieáp duøng voøng ñieän voøng 20mA söû duïng moät doøng ñieän voøng 2 daây ñôn giaûn ñeå truyeàn döõ lieäu noái tieáp. Logic 1 bieåu thò baèng doøng ñieän voøng I = 20mA vaø logic 0 bieåu thò baèng doøng I = 4 mA. CHÖÔNG IV: KHOÁI GHEÙP NOÁI SONG SONG - NOÁI TIEÁP VAØ NOÁI TIEÁP - SONG SONG I. Giôùi thieäu veà vieäc truyeàn thoâng tin noái tieáp cuûa maùy vi tính: Nhö ñaõ giôùi thieäu ôû phaàn tröôùc, tín hieäu Teletype laø tín hieäu noái tieáp. Do ñoù, ñeå giao tieáp vôùi maùy vi tính thì phaûi qua heä thoáng phoái hôïp noái tieáp cuûa maùy vi tính. Bôûi vì trong maùy tính chæ söû duïng maõ ASCII ñeå nhaän bieát caùc kyù töï vaø CPU laøm vieäc treân caùc thanh ghi duøng 8 hoaëc 16 bit döõ lieäu ® CPU laøm vieäc vôùi caùc Chíp laø song song. Ñeå thu phaùt noái tieáp töø caùc thieát bò song song, chuùng ta phaûi bieán ñoåi tin song song thaønh noái tieáp vaø noái tieáp thaønh song song vaø cheá taïo moät khoái gheùp noái coù ñoàng thôøi 2 chöùc naêng treân ñeå trao ñoåi tin thu, phaùt giöõa moät thieát bò song song vôùi ñöôøng daây noái tieáp. Boä phoái gheùp noái tieáp trong maùy vi tính cho pheùp nhaän moät tín hieäu töø beân ngoaøi vaøo vaø bieán ñoåi thaønh song song ñeå ñöa vaøo CPU hoaëc ngöôïc laïi nhaän döõ lieäu song song töø CPU bieán ñoåi thaønh tín hieäu noái tieáp gôûi ra ngoaøi. Sau ñaây, chuùng em xin giôùi thieäu sô löôïc veà boä phoái gheùp noái tieáp - song song trong maùy vi tính IBM PC_AT (vì chæ caàn phaàn noái tieáp neân khoâng giôùi thieäu phaàn song song cuûa noù). Phaàn noái tieáp cuûa boä phoái gheùp noái tieáp trong maùy vi tính AT ñöôïc chöông trình hoùa moät caùch ñaày ñuû ñeå trôï giuùp cho vieäc lieân laïc thoâng tin dò boä. Boä phoái gheùp naøy seõ töï ñoäng theâm hoaëc laáy ra nhöõng bit Start, Stop vaø caùc bit chaün leû. Noù coù moät chöông trình ñaëc bieät taïo ra maõ BAUD_RATE cho pheùp vaän haønh töø 50 ® 9600 bps. Noù cho pheù._.p thieát laäp 1 Frame vôùi 5, 6, 7 hoaëc 8 bit kyù töï vôùi 1; 1,5 hoaëc 2 bit Stop. Noù coù moät heä thoáng ngaét öu tieân duøng ñeå ñieàu khieån phaùt, thu, baùo loãi, traïng thaùi ñöôøng daây. . . II. Nhieäm vuï cuûa khoái gheùp noái song song - noái tieáp vaø noái tieáp song song khoâng ñoàng boä: Khoái gheùp noái coù nhieäm vuï sau: (Hình 9) - Thu tin song song töø maùy vi tính, thieát bò ñaàu cuoái ñeå bieán thaønh tin noái tieáp ñeå truyeàn treân ñöôøng daây TxD. - Thu tin noái tieáp töø ñöôøng daây RxD ñeå bieán thaønh tin song song cho maùy vi tính, thieát bò ñaàu cuoái. - Cheøn vaø loaïi tröø caùc bit khung Start, Stop cuûa khung tin. - Ñieàu khieån Modem vôùi caùc tín hieäu hoäi thoaïi (phaùt cho modem DTR, RTS vaø nhaän DSR, CTS töø modem) - Ñieàu khieån caùc cheá ñoä ñoàng boä, khoâng ñoàng boä, soá bit tin, soá bit Stop. . Ñieàu khieån naïp/ dòch Thanh ghi dòch Thanh ghi dòch Ñieàu khieån dòch/ñoïc Phaùt hieän bit Sart (1) Stop (6) Start Naïp Nhòp truyeàn Soá lieäu vaøo song song Nhòp nhaän Soá lieäu ra song song Ñoïïc Hình 9 III. Sô ñoà khoái cuûa khoái gheùp noái: Sô ñoà khoái cuûa khoái gheùp noái song song - noái tieáp vaø noái tieáp - song song nhö hình 10, goàm: - Caùc thanh ghi dòch noái tieáp song song ñeå bieán ñoåi song song - noái tieáp vaø noái tieáp - song song. - Caùc thanh ghi ñeäm song song vaøo vaø ra. - Thanh ghi ñieàu khieån, ñònh cheá ñoä, soá löôïng bit tin, soá löôïng bit Stop. - Thanh ghi traïng thaùi ñeå ñoïc caùc traïng thaùi cuûa modem vaø cuûa khoái gheùp noái. - Boä ñieàu khieån modem. Logic ñieàu khieån Thanh ghi ñieàu khieån Thanh ghi traïng thaùi Ñeäm soá lieäu vaøo Ñieàu khieån Modem Giaûi maõ ñòa chæ Thanh ghi dòch noái tieáp - song song Thanh ghi dòch song song - noái tieáp Ñeäm soá lieäu ra D0 - D7 INTR WR RD CS A0 Modem RxD TxD TxC RxC Hình 10 : IV. Vi maïch trao ñoåi tin song song - noái tieáp khoâng ñoàng boä 8251A: 8251A laø moät USART coù khaû naêng thöïc hieän Protocol ñoàng boä hoaëc baát ñoàng boä. ÔÛ ñaây ta chæ söû duïng ñeå truyeàn baát ñoàng boä. Haõng Intel moâ taû 8251A nhö sau :8251A ñöôïc thieát keá ñeå truyeàn döõ lieäu vôùi hoï mP cuûa Intel. USART nhaän caùc kyù töï döõ lieäu töø mP ôû daïng song song, sau ñoù ñoåi chuùng thaønh daïng döõ lieäu noái tieáp ñeå phaùt ñi. Ñoàng thôøi 8251A coù theå thu doøng döõ lieäu noái tieáp vaø ñoåi chuùng thaønh caùc kyù töï döõ lieäu song song gôûi ñeán mP. USART seõ baùo cho mP khi naøo coù theå nhaän 1 kyù töï môùi töø mP ñeå phaùt hoaëc khi naøo ñaõ thu ñöôïc moät kyù töï ñeå cho mP ñoïc. 1. Sô ñoà chaân vaø sô ñoà khoái cuûa 8251A: Sô ñoà chaân vaø sô ñoà khoái cuûa USART 8251A nhö hình 11 a, b vaø caùc thanh ghi nhö hình 11c. 8251A ñöôïc cheá taïo baèng kyõ thuaät NMOS vaø coù 28 chaân, toác ñoä truyeàn döõ lieäu leân tôùi 64 Kpbs. Khaùc vôùi 6402, ôû 8251A taát caû döõ lieäu ñeán vaø töø mP ñeàu ñi qua Bus döõ lieäu (Data Bus) noái vôùi caùc chaân D7 - D0. 1 28 14 15 D2 D3 RxD GND D5 D4 D6 D7 TxC WR C/D CS RD RxRDY D1 D0 Vcc RxC RTS DTR DSR Reset CLK TxD CTS TxEMPTY Syndet/BR TxRDY 8251A Hình 11a Traïng thaùi Soá lieäu thu Soá lieäu phaùt vaø leänh Logic ñieàu khieån vaø logic ghi Bieán ñoåi song song noái tieáp Ñieàu khieån phaùt Ñieàu khieån modem Ñieàu khieån thu Bieán ñoåi noái tieáp song song D0 - D7 TxD TxRDY TxE TxC TxRDY Syndet/Brk RxC RxD Reset CLK C/D RD WR CS DTR DSR RTS CTS Hình 11b : Thanh ghi leänh Thanh ghi truyeàn Thanh ghi nhaän Thanh ghi ñeäm truyeàn Thanh ghi ñeäm nhaän Thanh ghi traïng thaùi Thanh ghi cheá ñoä CS RD WR C/D D0 D1 D2 D3 D4 D5 D6 D7 CLK RST RxRDY TxRDY TxEMPTY Vcc GND DSR DTR CTS RST Syn/brk TxC RxC TxD RxD Hình 11c : Trong ñoù: CS : Chip Select - choïn vi maïch RD : Read - ñoïc WR : Write - ghi C/D : Control/Data - ñieàu khieån/soá lieäu CLK : Clock - Nhòp D0 - D7 : Data bus I/O - Bus döõ lieäu vaøo/ra TxC : Transmit Clock - Nhòp truyeàn RxC : Receiver Clock - Nhòp nhaän RST : Reset - Xoùa DTR : Data Terminal Ready - Soá lieäu cuûa TBÑC saün saøng DSR : Data Set Ready - Boä soá lieäu saün saøng RTS : Request To Send - yeâu caàu gôûi CTS : Clear To Send - Xoùa gôûi TxD : Transmit Data - Soá lieäu truyeàn RxD : Receiver Data - Soá lieäu nhaän TxRDY : Transmit Ready - Saün saøng truyeàn RxRDY : Receiver Ready - Saün saøng nhaän TxEMTY : Transmit Register Emty - Thanh ghi truyeàn roãng Syn/BRK : Synch / Break Detect - Ñoàng boä / phaùt hieän ñöùc ñoaïn tin. a. Nhoùm tín hieäu gheùp noái vôùi vi xöû lyù goàm: - CS (chaân 11) noái vôùi boä giaûi maõ ñòa chæ (A1 - An) ñeå choïn hai thanh ghi (A0 ñieàu khieån traïng thaùi, A0 = 0 ñeäm soá lieäu). - C/D (chaân 12) noái vôùi ñöôøng daây ñòa chæ A0 ñeå choïn moät trong hai caëp thanh ghi treân. - WR (chaân 10) noái vôùi ñöôøng daây WR cuûa vi xöû lyù. - RD (chaân13) noái vôùi ñöôøng daây RD cuûa vi xöû lyù. - CLK (chaân 20) noái vôùi ñöôøng daây CLK cuûa vi xöû lyù. - Reset (chaân 21) noái vôùi ñöôøng daây Reset cuûa vi xöû lyù. - D0 - D7 (chaân 27, 28, 1, 2, 5, 6, 7, 8) noái vôùi caùc ñöôøng daây soá lieäu D0 - D7 cuûa vi xöû lyù. b. Nhoùm tín hieäu gheùp noái vôùi Modem: - DTR (chaân 24), RTS (chaân 23) - DSR (chaân22), CTS (chaân 17) c. Nhoùm tín hieäu gheùp noái vôùi ñöôøng daây truyeàn - nhaän vaø khoái gheùp noái: - TxEMPTY (chaân 18) thanh ghi ñeäm truyeàn roãng. - TxD (chaân 19) cho soá lieäu truyeàn. - RxD (chaân 3) cho soá lieäu nhaän. - TxRDY (chaân 15) baùo soá lieäu truyeàn saün saøng. - RxRDY (chaân 14) baùo soá lieäu nhaän saün saøng. - Syn/Break : chæ ñoàng boä/ ñöùt doøng tin. d. Nhoùm tín hieäu gheùp noái vôùi maùy phaùt xung nhòp: - TxC : nhòp truyeàn. - RxC : nhòp nhaän. 2. Khôûi ñoäng 8251A: Sau khi Chip 8251A ñöôïc Reset, moät Byte ñöôïc ghi vaøo thanh ghi choïn Mode ñeå choïn Protocol mong muoán. Coù theå Reset baèng caùch duøng chaân RST (Reset cöùng luùc baät nguoàn) hoaëc khi ghi bit D1 = 1 vaøo thanh ghi leänh (Reset meàm). Sau khi thieát laäp Mode hoaït ñoäng vieäc phaùt vaø thu ñöôïc ñieàu khieån baèng caùch ghi ñònh kyø töø ñieàu khieån leänh vaøo thanh ghi leänh bao goàm caùc böôùc sau: - Reset chip 8251A (baèng phaàn cöùng hoaëc phaàn meàm) - Ghi töø choïn Mode mong muoán vaøo thanh ghi Mode. - Ghi töø leänh mong muoán vaøo thanh ghi leänh. Phaùt moät kyù töï : Ñeå phaùt moät kyù töï, bit TxEN trong thanh ghi leänh phaûi ôû möùc logic 1 vaø chaân CTS phaûi ôû möùc 0: + Ñôïi cho ñeán khi chaân TxRDY ôû möùc cao hoaëc cho ñeán khi bit TxRDY trong thanh ghi traïng thaùi laø 1. + Ghi kyù töï caàn phaùt vaøo thanh ghi ñeäm phaùt. Thu moät kyù töï : Ñeå thu moät kyù töï vaø kieåm tra traïng traùi loãi cuûa kyù töï naøy, ta caàn thöïc hieän caùc böôùc sau : + Ñôïi cho ñeán khi chaân RxRDY ôû möùc cao hoaëc cho ñeán khi bit RxRDY trong thanh ghi traïng thaùi laø moät. + Ñoïc traïng thaùi loãi töø thanh ghi traïng thaùi (coù theå keát hôïp vôùi caùc böôùc tröôùc - khi ñoïc bit RxRDY). + Ñoïc kyù töï töø thanh ghi ñeäm thu. + Reset traïng thaùi loãi baèng caùch ghi bit ER = 1 trong thanh ghi leänh. Toác ñoä phaùt vaø thu ñöôïc quyeát ñònh bôûi taàn soá cuûa xung Clock ñöa vaøo chaân RxC/TxC chia theo heä soá (1, 16 hoaëc 64) ñaõ choïn trong töø choïn Mode. 3. Caùc thanh ghi cuûa chip 8251A : Cuõng nhö CPU, Chip UART chöùa ñöïng moät soá thanh ghi hoaëc boä nhôù trong, coù ba kieåu thanh ghi: - Nhöõng thanh ghi ñieàu khieån: Chuùng nhaän nhöõng leänh töø CPU vaø khoâng töï ñoäng thay ñoåi traïng thaùi. - Nhöõng thanh ghi traïng thaùi: Chuùng thoâng baùo ñeán CPU nhöõng gì xaûy ra trong UART. - Nhöõng thanh ghi ñeäm: Chuùng löu giöõ nhöõng kyù töï chuaån bò phaùt ñi hoaëc chôø xöû lyù. Caùch truy xuaát caùc thanh ghi phuï thuoäc vaøo caáu truùc cuûa maùy tính maø UART ñöôïc caøi ñaët. Trong tröôøng hôïp maùy IBM PC, nhöõng giaù trò ñöôïc ñaët vaøo beân trong caùc thanh ghi nghóa laø duøng leänh OUT töø chip CPU gôûi ñeán nhöõng ñòa chæ töông öùng cuûa caùc thanh ghi. töông töï, nhöõng thanh ghi ñöôïc truy xuaát theo caùch ñoïc nghóa laø duøng leänh IN vôùi caùc ñòa chæ töông öùng. a. Caùc thanh ghi ñieàu khieån: Coù 4 thanh ghi ñieàu khieån duøng ñeå nhaän leänh töø CPU: a1. Thanh ghi ñieàu khieån ñöôøng daây:) (Line Control Register) Thanh ghi naøy ñöôïc duøng ñeå SET caùc thoâng soá lieân laïc. Moãi bit cuûa thanh ghi naøy coù yù nghóa vaø ñöôïc moâ taû nhö sau: Bit YÙ nghóa 0 Hai bit naøy duøng ñeå xaùc ñònh chieàu daøi cuûa moät töø 1 2 Soá bit Stop 3 Cho pheùp kieåm tra chaún leû 4 Choïn kieåm tra chaún leû 5 Choïn bit chaún leû 6 Ngaét 7 Bit truy xuaát vaø choát soá lieäu Moâ taû : - Bit 0 vaø 1 : chæ chieàu daøi cuûa moät töø nhö sau : Bit 0 Bit 1 Soá kyù töï 0 0 5 0 1 6 1 0 7 1 1 8 - Bit 2 : Xaùc ñònh soá STOP bit. Neáu Bit 2 laø 0, moät Stop bit ñöôïc taïo ra. Neáu bit 2 laø 1, 2 Stop bit ñöôïc taïo ra tröø khi chieàu daøi kyù töï laø 5 (töùc laø bit 0 vaø bit 1 baèng 00), luùc naøy seõ taïo ra 1.5 Stop bit. - Bit 3, 4, 5 laø nhöõng bit löïa choïn söï kieåm tra chaün leû (trong ñoà aùn naøy khoâng söû duïng neân luoân ñöôïc Set baèng 0). - Bit 6 : laø bit taïo ra moät leänh ngaét, khi ñöôïc Set leân 1 noù seõ treo ngoõ ra OUT ôû möùc logic 0 (SPACING) cho tôùi khi ñöôïc SET trôû laïi baèng 0 (Bit naøy khoâng ñöôïc duøng neân luoân luoân ñöôïc Set baèng 0). - Bit 7 : laø bit duy nhaát vaø choát soá chia (DLAB : Division Latch Access Bit). noù phaûi ñöôïc SET leân 1 khi truy xuaát vieäc choát soá chia, töùc laø luùc caøi toác ñoä truyeàn theo BAUD_RATE. Khi SET trôû veà 0, noù seõ cho pheùp caùc thao taùc ñoïc hoaëc ghi töø vuøng ñeäm thu, vuøng ñeäm phaùt hoaëc thanh ghi cho pheùp ngaét. a2. Thanh ghi ñieàu khieån modem: (Modem Control Register) Thanh ghi naøy ñieàu khieån nhöõng tín hieäu baét tay gôùi ra ngoaøi töø UART. Moãi bit cuûa thanh ghi naøy ñöôïc moâ taû nhö sau : Bit Chöõ vieát taét Teân goïi 0 DTR Döõ lieäu traïm cuoái saün saøng 1 RTS Yeâu caàu gôûi 2 OUT1 Ngoõ ra 1 3 OUT2 Ngoõ ra 2 4 LOOP Kieåm tra cheá ñoä voøng laëp - Bit 0 : thöôøng duøng ñeå SET ngoõ ra DTR veà möùc logic 0, cho pheùp caùc thieát bò töø xa gôûi tín hieäu ñeán chuùng ta hoaëc khi noù ñöôïc SET trôû veà möùc logic 1 yeâu caàu thieát bò xa khoâng gôûi ñeán chuùng ta nöõa. Trong ñoà aùn naøy ta söû duïng Bit naøy ñeå gôûi ra maïch khi nhaän döôïc tín hieäu goïi keát noái töø ñoái phöông. Luùc ñoù, noù phaûi ñöôïc Set leân 1 ñeå xem nhö baét tay phaàn cöùng vôùi ñoái phöông. - Bit 1,2,3,4 : khoâng duøng neân luoân ñöôïc set baèng 0 - Bit 5,6,7 : luoân Set = 0 a3. Thanh ghi cho pheùp ngaét : (Interrupt Enable Register ) Taùm bit thanh ghi naøy cho pheùp 4 kieåu ñieàu khieån ngaét taùc ñoäng leân "chip ngaét" baèng ngoõ ra INTRPT. Khi RESET caùc bit töø 0 ñeán 3 cuûa thanh ghi naøy, ta coù theå boû kieåu ngaét heä thoáng cuûa noù. Khi SET caùc bit töø 0 ñeán 3, ta choïn kieåu ngaét cho pheùp. Bit Kieåu ngaét 0 Cho pheùp ngaét ñeå thu döõ lieäu 1 Cho pheùp ngaét baùo vuøng ñeäm phaùt roãng 2 Cho pheùp ngaét baùo traïng thaùi ñöôøng daây 3 Cho pheùp ngaét baùo traïng thaùi Modem 4 Baèng 0 5 Baèng 0 6 Baèng 0 7 Baèng 0 a4. Thanh ghi choát soá chia BAUD_RATE: BAUD_RATE ñöôïc caøi ñaët phuï thoäc vaøo 2 thanh ghi maø con soá cuûa chuùng phaûi ñöôïc chia bôûi xung nhòp 1.8432 MHz. Keát quaû cho ra taàn soá baèng 16 laàn BAUD_ RATE. Hai thanh ghi naøy mang 2 byte: 1 byte choát soá chia coù nghóa thaáp nhaát (LSB), vaø 1 byte choát soá chia coù nghóa cao nhaát (MSB). Nhöõng soá chia naøy duøng ñeå taïo ra nhöõng toác ñoä theo BAUD_RATE khaùc nhau. BAUD_RATE DECEMAL HEX MSB LSB 50 2304 900 9 00 100 1152 480 4 80 300 384 180 1 80 1200 96 60 0 60 2400 48 30 0 30 4800 24 18 0 18 9600 12 0C 0 0C Toác ñoä daõy BAUD_RATE trong baûng khoâng phaûi laø coá ñònh. Nhöõng giaù trò ôû khoaûng giöõa chuùng cuõng coù theå ñöôïc taïo ra baèng caùch choïn soá chia töông öùng. b. Caùc thanh ghi traïng thaùi: Coù 3 thanh ghi traïng thaùi töôøng trình ñeán CPU nhöõng gì ñang xaûy ra ôû nhöõng vuøng khaùc nhau cuûa UART. b1. Thanh ghi traïng thaùi ñöôøng daây: (Line Status Register) Taùm bit thanh ghi naøy töôøng trình ñeán CPU nhöõng thoâng tin traïng thaùi veà söï chuyeån bieán döõ lieäu. Bit Chuõ vieát taét Teân goïi 0 DR Data set ready 1 OE Overrun error 2 PE Parity error 3 FE Frame error 4 BI Break interrup 5 THRE Transmitter hold register empty 6 TSRE Tx shift register empty 7 = 0 - Bit 0 : Ñaây laø bit thoâng baùo döõ lieäu thu ñaõ saün saøng. Noù SET leân moät baát kyø khi naøo 1 kyù töï vöøa môùi ñöôïc nhaän vaø chuyeån vaøo beân trong thanh ghi vuøng ñeäm thu. Bit 0 coù theå Reset trôû veà 0 baèng vieäc ñoïc döõ lieäu thu töø thanh ghi ñeäm thu hoaëc ghi möùc 0 leân noù. - Bit 1 : Bit naøy thoâng baùo loãi traøn. Noù thoâng baùo laø döõ lieäu beân trong thanh ghi ñeäm thu chöa ñöôïc ñoïc tröôùc khi kyù töï keá tieáp ñöôïc ñeán, vì vaäy noù seõ phaù hoûng kyù töï tröôùc. - Bit 2 : laø bit baùo loãi cöïc tính, thoâng baùo ñaõ thu moät kyù töï khoâng ñuùng chaún (hoaëc leû) nhö ñaõ ñöôïc choïn trong Bit choïn löïa trong Bit choïn löïa chaún leû ôû thanh ghi ñieàu khieån ñöôøng daây. - Bit 3 : Laø bit baùo loãi Frame, noù thoâng baùo ñaõ thu moät kyù töï khoâng coù Stop bit. - Bit 4 : laø moät ngaét cuûa phaàn thu, noù ñöôïc Set leân 1 baát kyø khi naøo ngoõ vaøo thu döõ lieäu ôû möùc 0 laâu hôn thôøi gian chieàu daøi cuûa 1 töø. - Bit 5 : Bit naøy thoâng baùo thanh ghi ñeäm phaùt roãng. Noù baùo cho boä ñieàu khieån laø saün saøng nhaän moät kyù töï môùi ñeå phaùt ñi. Bit naøy Set leân möùc 1 khi 1 kyù töï nöõa môùi ñöôïc chuyeån töø thanh ghi löu giöõ phaàn phaùt. Noù ñöôïc Set trôû veà möùc 0 khi CPU naïp moät töø môùi vaøo thanh ghi löu giöõ phaàn phaùt. - Bit 6 : Bit naøy cuõng baùo phaàn ñeäm phaùt roãng. Noù ñöôïc Set leân 1 baát kyø khi naøo maø caû hai thanh ghi ñeäm phaùt vaø thanh ghi dòch chuyeån phaàn phaùt ñeàu roãng. Noù ñöôïc Reset trôû veà möùc 0 khi THR vaø TSR ñöôïc chöùa kyù töï döõ lieäu. - Bit 7 : khoâng duøng. b2 . Thanh ghi traïng thaùi Modem: (Modem Control Register) Thanh ghi naøy cho nhöõng thoâng tin veà traïng thaùi cuûa nhöõng ñöôøng baét tay. Moâ taû nhö sau: Bit Teân YÙ nghóa 0 Delta CTS CTS bò thay ñoåi traïng thaùi 1 Delta DSR DSR bò thay ñoåi traïng thaùi 2 TERI Ñöôøng daây ñoå chuoâng ñoåi töø ON leân OFF 3 Delta RLSD Tín hieäu taùch soùng bò thay ñoåi 4 CTS Ngoõ vaøo xoùa ñeå gôûi ôû möùc cao 5 DSR Ngoõ vaøo döõ lieäu saün saøng ôû möùc cao 6 RI Chæ thò chuoâng ôû möùc cao 7 RLSD Ñöôøng daây taùch soùng ôû möùc cao b3. Thanh ghi ñaëc tính ngaét: (Interrupt Identification Register) Thanh ghi naøy cung caáp thoâng tin veà traïng thaùi hieän haønh cuûa nhöõng ngaét ñöôïc phaùt ñi. Bit 0 Set leân 1 laø khoâng coù moät ngaét naøo gôûi ñi. Khi bit 0 ôû möùc 0, bit 1 vaø bit 2 chæ ra ngaét naøo ñaõ ñöôïc gôûi ñi theo baûng sau : Bit 2 1 0 Möùc öu tieân Kieåu ngaét Nguyeân nhaân ngaét Reset laïo ngaét 0 0 1 - 0 0 - 1 1 0 Cao nhaát Traïng thaùi ñöôøng daây thu - Loãi traøn - Loãi cöïc tính - Loãi khung - Break interrup Ñoïc thanh ghi traïng thaùi ñöôøng daây 1 0 0 Thöù hai Cho pheùp thu döõ lieäu Cho pheùp thu döõ lieäu Ñoïc thanh ghi ñeäm thu 0 1 0 Thöù ba Thanh ghi löu giöõ phaàn phaùt roãng Thanh ghi löu giöõ phaàn phaùt roãng Ñoïc IIR hoaëc ghi vaøo thanh ghi löu giöõ phaàn phaùt 0 0 0 Thöù tö Traïng thaùi Modem - CTS - DSR - RI Ñaõ nhaän tin Ñoïc thanh ghi traïng thaùi Modem c. Caùc thanh ghi ñeäm: Kieåu thanh ghi thöù 3 trong UART laø caùc thanh ghi ñeäm, coù hai thanh ghi ñeäm: Thanh ghi löu giöõ phaàn phaùt (Transmitter Holding Register) vaø thanh ghi ñeäm thu (Receiver Buffer Register). c1. Thanh ghi ñeäm thu: Thanh ghi naøy löu giöõ kyù töï sau cuøng vöøa môùi nhaän ñöôïc. Moãi laàn noù ñöôïc ñoïc, thanh ghi traïng thaùi ñöôøng daây seõ chæ thò vuøng ñeäm thu roãng cho tôùi khi nhaän ñöôïc moät kyù töï khaùc. Neáu kyù töï thöù hai nhaän ñöôïc tröôùc kyù töï thöù nhaát ñoïc xong, moãi loãi traøn seõ ñöôïc thoâng baùo. c2. Thanh ghi löu giöõ phaàn phaùt: Thanh ghi löu giöõ phaàn phaùt löu laïi kyù töï keá tieáp ñeå chuaån bò phaùt ñi. Kyù töï ñöôïc ñaët vaøo baèng chöông trình cuûa ngöôøi vieát. Thanh ghi traïng thaùi ñöôøng daây seõ thoâng baùo khi moät kyù töï vöøa ñöôïc phaùt ñi. Ñòa chæ cuûa caùc thanh ghi ñöôïc choïn nhö sau: Ñòa chæ Thanh ghi ñöôïc choïn XF8 Thanh ghi ñeäm phaùt XF8 Thanh ghi ñeäm thu XF8 Thanh ghi choát soá chia LSB XF9 Thanh ghichoát soá chia MSB XF9 Thanh ghi cho pheùp ngaét XFA Thanh ghi ñaëc tính ngaét XFB Thanh ghi ñieàu khieån ñöôøng daây XFC Thanh ghi ñieàu khieån modem XFD Thanh ghi traïng thaùi ñöôøng daây XFE Thanh ghi traïng thaùi modem Trong ñoù : Chöõ X duøng ñeå choïn coång COM1 hoaëc COM2. X = 3 duøng cho COM1, X = 2 duøng cho COM2. 4. Giao tieáp giöõa 8251A vôùi boä vi xöû lyù: Hình 12 trình baøy keát noái giao tieáp ñieån hình giöõa boä vi xöû lyù vôùi USART 8251A. CS C/D WR RD CLK RxRDY RTS D0 - D7 Data Bus Add Bus RST 6.5 RST CLK IN OUT Rx/Tx CLKS f = "d"*Baud TxC RxC TxD RxD SERIAL O/P SERIAL I/P CTS A7 A0 CPU 8251A Hình 12 Giao tieáp cuûa 8251A söû duïng ñaëc tính xuaát nhaäp boä tích luõy cuûa Intel 8085. Chaân RxRDY leân möùc cao High seõ gaây ra moät ngaét ñöa tôùi mP baùo cho CPU bieát ñaõ thu moät kyù töï. Chaân TxRDY khoâng ñöôïc duøng ñeå taïo ra ngaét CPU nhö treân. Trong tröôøng hôïp naøy mP phaûi hoûi voøng bit TxRDY cuûa thanh ghi traïng thaùi tröôùc khi moät kyù töï môùi ñeå phaùt. * Hoûi voøng (Polling) vaø söû duïng ngaét ñeå xuaát nhaäp: Caùc chöông trình xuaát nhaäp trong heä thoáng maùy tính thöôøng ñöôïc phaân loaïi nhö : hoûi voøng hoaëc ñieàu khieån ngaét. Hoûi voøng coù nghóa laø mP seõ ngöng caùc hoaït ñoäng khaùc moät caùch ñònh kyø vaø hoûi UART ñaõ nhaän döõ lieäu môùi chöa hoaëc saün saøng phaùt kyù töï keá tieáp chöa. Coâng vieäc naøy thöôøng ñoøi hoûi mP phaûi ñoïc thanh ghi traïng thaùi cuûa UART. Moät chöông trình ñieàu khieån ngaét bao haøm yù nghóa mP vaãn tieáp tuïc caùc hoaït ñoäng khaùc vaø chæ ngöng khi traû lôøi moät tín hieäu ngaét ñöôïc gôûi tôùi tö ø UART. Hoûi voøng ñeå quyeát ñònh traïng thaùi cuûa UART haïn cheá söï caàn thieát phaûi coù ngaét phaàn cöùng nhöng hieäu quaû söû duïng thôøi gian laøm vieäc cuûa mP seõ thaáp hôn. Cuõng vaäy, khi söû duïng hoûi voøng ñeå quyeát ñònh traïng thaùi thu phaûi heát söùc caån thaän ñeå ñaûm baûo raèng loãi traøn khoâng xaûy ra. Söï quyeát ñònh duøng caùc ngaét hoaëc hoûi voøng ñeå xuaát nhaäp ñeàu phaûi ñöôïc caân nhaéc chi töøng öùng duïng cuï theå, ñieàu naøy döïa vaøo caùc yeáu toá nhö ñoä phöùc taïp cuûa phaàn cöùng, phaàn meàm vaø caùc öu tieân cuûa nhieäm vuï heä thoáng. Toùm laïi: * Ñoái vôùi Teletype vì yeâu caàu truyeàn khoâng cao laém, hôn nöõa maùy Teletype khoâng theå naøo phaùt ñi hoaëc thu nhaän caùc Parity bit hoaëc kieåm tra caùc bit naøy ñöôïc, neân ta khoâng Set caùc bit parity. * Nhö ñaõ neâu ôû phaàn tröôùc, vì Teletype coù moät söï baét tay phaàn cöùng. Ñeå laøm coâng vieäc naøy ta choïn: - DSR (Data Set Ready): duøng ñeã nhaän bieát tín hieäu keát noái gôûi ñeán töø maùy Teletype töùc laø khi ñieän aùp ñöôøng thu cuûa maïch töø +60V (logic 0) chuyeån thaønh -60V (logic 1) thì DSR seõ chæ thò. - DTR (Data Terminal Ready): sau khi nhaän ñöôïc tín hieäu keát noái, duøng DTR ñeå xuaát ra ñöôøng phaùt cuûa maïch töø logic 0 ® logic 1 ñeå gôûi ñeán ñoái phöông hoaøn thaønh coâng vieäc baét tay phaàn cöùng. CHÖÔNG V : GIÔÙI THIEÄU VEÀ NGAÉT CUÛA MAÙY VI TÍNH I. Caùc loaïi ngaét cuûa moät maùy vi tính PC: Ngöôøi ta chia ngaét thaønh hai loaïi : Ngaét cöùng vaø ngaét meàm. 1. Ngaét cöùng : Coøn goïi laø ngaét ngoaøi vì do nguyeân nhaân beân ngoaøi. Vi xöû lyù coù caùc loái vaøo daønh cho ngaét ngoaøi. Khi coù tín hieäu vaøo caùc loái naøy, vi xöû lyù ñang thöïc hieän leänh cuûa chöông trình seõ bò döøng. * Ngaét NMI (Non Maskable Interrupt - Ngaét khoâng che ñöôïc) Khi coù ngaét naøy, vi xöû lyù döøng chöông trình sau leänh ñang thöïc hieän, thanh ghi chæ thò leänh vaø thanh ghi chæ thò Flag ñöôïc löu giöõ, hai bit IF (Interrup Flag) vaø TF (Trap Flag) bò xoùa veà 0 ñeå caám ngaét ngoaøi tieáp theo vaø khoâng coù baãy. Muoán cho pheùp hay khoâng cho pheùp ngaét naøy xaûy ra, chuùng ta duøng moät Trigô ñeå maéc loái vaøo ngaét tröôùc khi ñöa vaøo ngaét tröôùc khi ñöa vaøo loái vaøo ngaét NMI. * Ngaét INMR: - Ngaét naøy ñöôïc cho pheùp (ghi IF = 1) hay caám ngaét (IF = 0) vaøo thanh ghi Flag. - Ñöôïc xoùa veà 0 bôûi leänh CLI (Clear Interrup). - Ñöôïc xaùc laäp leân 1 bôûi leänh STI. - Thöôøng ñöôïc noái vôùi loái ra yeâu caàu ngaét cuûa vi maïch xöû lyù öu tieân ngaét (8214, 8159). * Ngaét Reset: Ñaây thöïc söï khoâng phaûi laø ngaét, chæ töông öùng vôùi vieäc treo chöông trình taïm thôøi. Kh i coù tín hieäu töø ngoaøi vaøo loái vaøo Reset hay coù leänh Reset cuûa chöông trình, taát caû caùc thanh ghi cuûa vi xöû lyù bò xoùa veà khoâng, tröø thanh ghi ñoaïn (CS) ñöôïc naïp ñòa chæ ñaàu tieân cuûa chöông trình töï kieåm tra Port. 2. Ngaét meàm: (Hay ngaét beân trong do leänh cuûa chöông trình) Do vi xöû lyù gaëp caùc leänh gaây ra ngaét hoaëc tình huoáng ñaëc bieät khi thöïc hieän leänh (ngaét logic vaø ngaét cuûa heä ñieàu haønh). - Ngaét do leänh : Ñoù laø ngaét khi thöïc hieän caùc leänh CALL, HLT, INT. - Ngaét logic hay caùc ngoaïi tröø : xaûy ra khi gaëp caùc tình huoáng ñaëc bieät sau : + Chia moät soá cho 0 (vectô 0). + Vöôït quaù noäi dung thanh ghi hay boä nhôù (vectô 4). + Thöïc hieän töøng böôùc (vectô 1). + Ñieåm döøng chöông trình do ngöôøi söû duïng ñònh huoáng (vectô 3). - Ngaét cuûa heä ñieàu haønh: Ñoù laø caùc ngaét do heä ñieàu haønh quy ñònh ñeå phuïc vuï trao ñoåi tin cuûa caùc thieát bò ngoaøi nhö INT 10, INT 16, INT 21 . . . II. Thuû tuïc xöû lyù ngaét cuûa chöông trình: Khi coù moät tín hieäu yeâu caàu ngaét chöông trình ñöa vaøo chaân yeâu caàu ngaét (INTR), quaù trình ngaét chöông trình ñöôïc dieãn ra nhö sau: - Löu giöõ tin veà traïng thaùi cuûa vi xöû lyù luùc coù tín hieäu yeâu caàu ngaét vaø nôi chöông trình chính bò giaùn ñoaïn. - Vi xöû lyù gôûi tín hieäu xaùc nhaän hay cho pheùp ngaét - INTA vaø ñoïc vectô ngaét. - Chuyeån sang chöông trình con phuïc vuï ngaét. - Trôû veà choå chöông trình chính bò ngaét vaø tieáp tuïc thöïc hieän chöông trình ñoù. 1. Löu giöõ tin veà choå bò ngaét chöông trình: ÔÛ cuoái moãi chöông trình leänh, VXL kieåm tra xem coù yeâu caàu ngaét naøo gôûi ñeán hay khoâng. Neáu coù yeâu caàu, VXL tieán haønh löu tröõ tin veà nôi bò ngaét chöông trình. quaù trình löu giöõ tin tieán haønh theo caùc böôùc sau: - Giaûm con troû ngaên xeáp. - Caám loái vaøo ngaét INTR baèng caùch xoùa bit IF ôû thanh ghi côø. - Xoùa bit côø baãy trong thanh ghi côø. - Giaûm SP ñi 2 vaø naïp noäi dung cuûa thanh ghi maïng leänh hieän haønh vaøo maûng nhôù ngaên xeáp coù ñòa chæ treân. - Giaûm SP ñi 2 vaø naïp noäi dung thanh ghi con troû leänh hieän haønh vaøo boä nhôù ngaên xeáp coù ñòa chæ treân. 2. Gôûi tín hieäu cho pheùp ngaét vaø ñoïc vec tô ngaét: Sau khi ñaõ löu tröõ tin veà vò trí bò ngaét cuûa chöông trình chính, VXL gôûi tín hieäu xaùc nhaän ngaét INTA (Interrup Acknowlege) cho khoái gheùp noái cuûa thieát bò ngoaøi. Tuøy caùch toå chöùc ngaét vaø taïo vectô ngaét, VXL söû duïng tín hieäu naøy ñeå ñoïc vectô ngaét töông öùng cuûa khoái gheùp noái vaøo thanh ghi chöùa A. VXL ñoïc noäi dung cuûa oâ nhôù coù ñòa chæ laø vectô ngaét ñeå bieát ñöôïc ñòa chæ ñaàu tieân cuûa chöông trình con phuïc vuï ngaét. 3. Thöïc hieän chöông trình con phuïc vuï ngaét: Ñoù laø chöông trình maø ñòa chæ cuûa leänh ñaàu tieân naèm trong oâ nhôù coù ñòa chæ laø vectô ngaét. Keát thuùc chöông trình con naøy, coù leänh trôû veà ñeå VXL tieáp tuïc thöïc hieän chöông trình chính. 4. Thöïc hieän chöông trình chính: Sau khi gaëp leänh trôû veà, VXL tieán haønh ñoïc vaø hoài phuïc caùc tin cuûa VXL luùc bò ngaét chöông trình ñaõ ghi nhôù ôû choå ngaét chöông trình. Quaù trình ñoïc ra naøy xaûy ra ngöôïc laïi vôùi quaù trình ghi vaøo vaø noäi dung: - Thanh ghi con troû leänh trôû veà ñoä dôøi cuûa ñòa chæ leänh tieáp theo cuûa chöông trình chính bò ngaét trong maûng nhôù leänh. - Thanh ghi maûng leänh veà ñòa chæ ñoaïn ñaàu tieân cuûa vuøng nhôù daønh cho chöông trình chính bò ngaét. - Thanh ghi Flag luùc bò ngaét chöông trình. III. Giôùi thieäu veà caùch söû duïng IRQ4: IRQ4 laø moät trong nhöõng ñöôøng ngaét cöùng cuûa maùy tính. Trong maùy IBM_PC coù 8 ñöôøng ngaét cöùng vaø maùy tíng IBM PC_AT coù 16 ñöôøng ngaét cöùng, ñöôïc moä taû nhö sau: IRQ Thieát bò NMI Ngaét khoâng che 0 Ngaét thôøi gian 1 Ngaét baøn phím 2 Döï tröõ 3 COM2 4 COM1 5 Ñóa cöùng 6 Ñóa meàm 7 LPT1 Nhöõng ñöôøng ngaét naøy khoâng noái ñöôïc tröïc tieáp tôùi chip CPU, nhöng ñöôïc thoâng qua chip xöû lyù ngaét laø PIC_8259A (Programmable Interrupt Controller). Trong maùy IBM PC_AT coù hai boä ñieàu khieån naøy. Noù coù nhöõng möùc öu tieân cho caùc nhaát ñeå traùnh trình traïng loän xoän xaûy ra khi nhieàu ngaét ñeán khoâng theo moät traät töï naøo caû. Caùc möùc öu tieân naøy trong maùy IBM PC ñöôïc chæ ñònh ôû cao nhaát laø IRQ0 vaø thaáp nhaát laø IRQ7. Neáu nhieàu thieát bò ñeàu yeâu caàu söï chuù yù baèng caùch naâng caùc ñöôøng ngaét cuûa noù leân, boä ñieàu khieån ngaét seõ coù nhieàu ngoõ vaøo ôû möùc cao thì noù seõ gôûi chuùng ñeán CPU vôùi traät töï cuûa möùc ñoä öu tieân. Trong PIC coù moät thanh ghi cho pheùp ngaét töø thieát bò gôûi ñeán. Maëc nhieân, IRQ4 vaø IRQ3 laø khoâng cho pheùp. Vì vaäy, neáu muoán duøng ngaét cho vieäc lieân laïc thoâng tin thì phaûi chæ thò cho PIC cho pheùp caùc ñöôøng ngaét töông öùng. Ñaây laø coâng vieäc ñoïc thanh ghi baèng leänh IN vôùi ñòa chæ coång laø 21H vaø Set Off bit töông öùng (bit 4 cho IRQ3 vaø bit 5 cho IRQ4) vaø OUT trôû laïi giaù trò ra Port 21H. Nhö vaäy thì PIC môùi coäng theâm caùc ngaét cuûa UART vaø cho noù gôûi ngaét tôùi. Khi PIC nhaän ñöôïc moät ngaét, neáu ngaét ñoù laø cho pheùp vaø khoâng coù moät ngaét naøo khaùc gôûi ñeán nöõa, noù seõ ñöa möùc ñieän aùp döông leân ñöôøng ngaét ñoù ñeán CPU. Khi ñoù CPU seõ coâng nhaän ngaét, nghóa laø traû moät tín hieäu veà PIC yeâu caàu PIC chæ thò xem ngaét naøo vöøa môùi xaûy ra. Luùc ñoù PIC seõ gôûi moät con soá (thoâng qua Data Bus) ñeán CPU (laø con soá IRQ + con soá 8). Noùi caùch khaùc, ñoái vôùi IRQ4 noù gôûi con soá 12 (OCh), ñoái vôùi IRQ3 noù gôûi con soá 11 (08h), luùc naøy CPU seõ thöïc hieän caùc phaàn muïc töông öùng laø caát ñòa chæ chöông trình hieän haønh vaøo vuøng Stack vaø thöïc hieän leänh Call Far ñeán boä nhôù ñöôïc troû bôûi vectô ngaét cuûa ngaét trong baûng vectô ngaét. Vì vaäy, vôùi ngaét IRQ4 gôûi tôùi vieäc CPU thöïc hieän cuõng gioáng nhö INT 0Ch cuûa phaàn meàm. Neáu baïn khoâng muoán CPU bò phaân chia khi coù nhieàu ngaét, bôûi vì noù can thieäp vaøo moät soá coâng vieäc xaáu laøm khoâng theå ngaét ñöôïc, ta coù theå chæ thò ñeán noù khoâng quan taâm ñeán caùi ngaét ñoù baèng leänh STI. Keát quaû cuûa leänh naøy laø chuyeåi ñoåi traïng thaùi côø IF trong CPU. Vieäc Set côø IF khoâng laøm thay ñoåi baát cöù caùi gì trong PIC maø noù vaãn gôûi moät tín hieäu ngaét ñöôøng daây ñeán CPU khi noù nhaän ñöôïc moät ngaét trong nhöõng ngaét ñöôøng daây. Ngaét ñöôøng daây seõ treo leân möùc cao vaø CPU coù theå nhaän ra ñöôïc nguyeân nhaân cuûa ngaét vaø thöïc hieän leänh STI moät laàn nöõa. Nhöõng ngaét khaùc gôûi ñeán khoâng nhaát thieát seõ maát ñi. Nhöõng thieát bò giöõ ñöôøng IRQ cuûa chuùng ôû möùc cao vaø PIC hieåu nhöõng thieát bò ñoù ñang caàn söï chuù yù. Noù seõ chaáp nhaän gôûi caùc ngaét trong thöù töï öu tieân cuûa chuùng. Caùc ngaét coù theå bò treo, nhö vaäy keát quaû laø maát thoâng tin töø khi thieát bò khoâng taïo ra ñöôïc ngaét thöù hai cho tôùi khi kyù töï thöù nhaát vöøa ñöôïc coâng nhaän. Coù hai lyù do taïi sao ngaét töø thieát bò khoâng ñöôïc CPU chuù yù ngay laäp töùc. Thöù nhaát laø noù bò xung ñoät vôùi caùc thieát bò khaùc coù möùc öu tieân cao hôn hoaëc coù nhöõng ngaét ñang bò treo. Tuy vaäy duøng phöông phaùp ngaét thöôøng nhanh hôn so vôùi phöông phaùp hoûi voøng. Trong chöông trình xöû lyù ngaét phaàn meàm phaûi traû lôøi ngaét ñeán PIC baèng caùch gôûi giaù trò 20h ra port 20h. Neáu vieäc naøy khoâng ñöôïc thöïc hieän PIC seõ khoâng gôûi theâm moät ngaét naøo nöõa ñeán CPU. IV. Söû duïng ngaét cuûa ROM_BIOS: ROM_BIOS cung caáp 4 haøm xöû lyù truyeàn thoâng tuaàn töï maø chuùng ta coù theå truy xuaát chuùng qua ngaét 14h. Ñeå söû duïng ngaét naøy, ta ñaëc giaù trò töø 0 - 3 trong thanh ghi AH ñeå xaùc ñònh haøm naøo seõ ñöôïc söû duïng vaø ñaët soá thöù töï coång caàn truy xuaát vaøo thanh ghi DX. Soá thöù töï coång = 0 : COM1 Soá thöù töï coång = 1 : COM2 ÔÛ möùc ñoä chöông trình, ta coù theå choïn moät khoái gheùp noái noái tieáp baèng caùch gaùn maõ töông öùng vaøo thanh ghi DX vôùi giaù trò: - 00h cho COM1 - 01h cho COM2 - 02h cho COM3 - 03h cho COM4 Caùc haøm cuûa ngaét 14h nhö sau: 1. Haøm soá 0 (Phuïc vuï 00h) Khôûi phaùt khoái gheùp noái noái tieáp, taïo tham soá cho coång noái tieáp: * Vaøo : AH = 0 AL = Tham soá truyeàn DX = Soá thöù töï coång noái tieáp * Ra : AX = Traïng thaùi ñöôøng daây truyeàn vaø Modem. Phuïc vuï 00h aán ñònh nhöõng thoâng soá khaùc nhau cuûa khoái gheùp noái noái tieáp cuõng nhö RS_232. Ñoù laø caùc thoâng soá: - Soá BAUD : Töùc toác ñoä trao ñoåi tin. - Tính chaün leû. - Soá bit döøng. - Kích thöôùc kyù töï hay soá bit tin noái tieáp. nhöõng thoâng soá naøy ñöôïc toå hôïp trong maõ 8 bit, ñöôïc ñaët vaøo thanh ghi AL, theo thöù töï caùc bit nhö hình sau : D6 D7 D4 D3 D5 D1 D0 D2 Baud Rate Parity Stop bit Word Length Giaù trò traû ra trong AX xem haøm soá 3: - D7, D6, D5 maõ cuûa vaän toác (tính baèng Baud). - D4, D3 ma._.

Các file đính kèm theo tài liệu này:

  • docDO32.DOC
  • docMACH.DOC