Thiết kế và thi công mạch cảnh báo tốc độ và tính cước xe taxi

DẪN NHẬP I – ĐẶT VẤN ĐỀ Cùng với sự phát triển của xã hội, nhu cầu vật chất và tinh thần của con người ngày càng tăng. Nắm bắt được điều trên, trong vài năm gần đây để thỏa mãn nhu cầu đi lại ngày càng cao để giải quyết một số vấn đề xã hội như giảm bớt lượng xe hai bánh trên đường phố, tăng vẻ mỹ quan cho đô thị. Nhà nước đã đưa vào hoạt động loại hình Taxi. Đây là loại hình đưa đón khách tương đối mới mẽ đối với nước ta nhưng lại không xa lạ gì đối với các nước. Nó tỏ ra tiện dụng cho việc đi lại và phần nào giảm bớt được ô nhiễm môi trường, an toàn cho hành khách. Muốn như vậy, xe Taxi lưu hành phải trang bị những thiết bị an toàn cho hành khách lẫn người điều khiễn phương tiện. Ngoài những thiết bị như dây an toàn, thiết bị giảm xóc và chống va đập thì việc trang bị những thiết bị cảnh báo nhằm cung cấp thông tin về tình trạng hoạt động của xe cho người điều khiển là điều cần thiết. Bên cạnh vấn đề quan trọng là bảo đảm an toàn trong quá trình di chuyển thì việc tính cước trên xe Taxi phải đảm bảo tính chính xác và hợp lý nhằm tạo tâm thoải mái và dễ chịu cho hành khách. Xuất phát từ nhu cầu thực tế khách quan đó, cùng những kiến thức đã được trang bị trong trường, người thực hiện đã mạnh dạn thực hiện đề tài “THIẾT KẾ VÀ THI CÔNG MẠCH CẢNH BÁO TỐC ĐỘ VÀ TÍNH CƯỚC XE TAXI”. II- GIỚI HẠN ĐỀ TÀI: Với đề tài mang tính thực tiễn là “THIẾT KẾ VÀ THI CÔNG MẠCH CẢNH BÁO TỐC ĐỘ VÀ TÍNH CƯỚC XE TAXI” thì vấn đề thực hiện thiết kế và thi công một mạch hoàn chỉnh thật sự có thể ứng dụng rộng rãi là một điều mà người thực hiện mong muốn đạt được. Tuy nhiên do thời gian và kiến thức có hạn cùng những hạn chế khách quan khác ngoài ý muốn mà trong phạm vi đồ án người thực hiện không thể đề cập, đi sâu khảo sát bộ tính cước xe Taxi đang được sử dụng rộng rãi trên các xe Taxi ở nước ta. Dù vậy người thực hiện cũng đã cố gắng tìm hiểu các nguyên lý tính cước cũng như cảnh báo tốc độ xe ôtô để đề ra hướng giải quyết. Theo đó nội dung nghiên cứu chỉ tiến hành thực hiện các vấn đề sau: · Giới thiệu nguyên lý đo tốc độ, nguyên lý tính cước xe Taxi, nguyên lý cảnh báo tốc độ xe ôtô. · Thiết kế mạch phần cứng. · Thiết kế phần mềm. Về thi công, với yêu cầu của đề tài đặt ra là thiết kế và thi công một mạch điện gần sát với thực tế để phục vụ cho việc học tập và nghiên cứu. Trên cơ sở dựa trên khả năng kiến thức đã thu thập ở nhà trường, người thực hiện đã cố gắng tiến hành thi công một số mạch cơ bản đủ để mô phỏng việc cảnh báo tốc độ và tính cước xe Taxi. III-MỤC ĐÍCH NGHIÊN CỨU Việc vận dụng môn điện tử ứng dụng để giải quyết một vấn đề kỹ thuật là điều không còn gì mới mẽ nhưng tính mới mẽ của đề tài được thể hiện ở chỗ người thực hiện đã mạnh dạn đi nghiên cứu một lĩnh vực mới đang phát triển mạnh mẽ nhằm đáp ứng nhu cầu của xã hội đó là lĩnh vực trang bị điện tử cho xe ôtô. Đề tài được thực hiện trong phạm vi hẹp chưa thể ứng dụng được trong thực tiễn nhưng điều mà người thực hiện muốn hướng đến là thông qua việc thực hiện đồ án tốt nghiệp có điều kiện vận dụng lý thuyết đã học để giải quyết một vấn đề mang tính thực tiễn. Đồng thời trong một chừng mực nào đó tập đồ án có thể được xem như một tài liệu tham khảo, học tập cho sinh viên trong và ngoài ngành.

doc77 trang | Chia sẻ: banmai | Lượt xem: 1711 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Thiết kế và thi công mạch cảnh báo tốc độ và tính cước xe taxi, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
3MW (cuõng coù theå lôùn hôn tuøy loaïi IC) Toái thieåu khoaûng 1KW Vôùi nhöõng giôùi haïn treân thì taàn soá taïo neân khoâng quaù 1MHz Chöùc naêng moät soá chaân cuûa IC 555 Ngoõ vaøo Reset (chaân 4) coù theå duøng ñeå giöõ ngoõ ra cuûa IC555 ôû möùc thaáp hay ngöng xung ra khi ñaõ baét ñaàu. Muoán vaäy chæ caàn ñöa ngoõ Reset xuoáng mass. Neáu hai ngoõ naûy vaø Reset noái chung nhau maïch seõ naûy ôû caïnh leân thay vì ôû caïnh xuoáng. Bình thöôøng ta phaûi noái ngoõ Reset leân nguoàn Vcc ñeå traùnh nhieãu. +5v 4 3 555 2 5 1 Ra R2 Cb C R1 Hình B. 9: Sô ñoà maïch taïo xung IC555 coøn coù ngoõ vaøo ñieän theá ñieàu khieån (controlvoltage), bình thöông ta ñeå hôû ngoõ naøy nhöng ñeå taêng söï oån ñònh cuûa maïch ta duøng moät tuï (.01 ¸ .1mF) noái reõ giöõa ngoõ naøy vôùi mass. Maïch 555 taïo ra xung vuoâng nhôø söï naïp, xaõ lieân tuïc cuûa tuï C Theo ñoù ta coù: Thôøi gian tuï naïp T1 = 0.693(R1 + R2)C Thôøi gian tuï xaõ T2 = 0.693R2C Chu kyø cuûa daïng soùng vuoâng ra: T = T1 + T2 = 0.693(R1 + 2R2)C Taàn soá cuûa daïng soùng vuoâng ra: f = 1/T = 1.44/ (R1 + 2R2)C Tính toaùn vaø löïa choïn linh kieän: Do yeâu caàu thieát keá caàn taïo ra moät khoaûng taàn soá ñuû roäng ñeå ñeã ñieàu chænh vaø theo doõi khi hoaït ñoäng, neân taàn soá thieát keá cho maïch taïo xung laøm tín hieäu toác ñoä ñöôïc thöïc hieän trong khoaûng 10Hz < f <= 100Hz. ÔÛ taàn soá 100Hz ta coù: Taàn soá soùng vuoâng ra : f = 1/T = 1,44/(R1 + 2R2)C = 100Hz Choïn C = 1mF R1 = 5KW (Thöïc teá R1 = 5KW + 0) Suy ra : 2R2 = (1,44/ 100.C) – R1 = 9.4KW. Hay R2 = 4.7KW Ñeå coù daõy taàn soá thay ñoåi ñöôïc töø > 10Hz – 100Hz thì R1 ñöôïc choïn laø moät bieán trôû 100KW noái tieáp vôùi moätñieän trôû 5KW. Khi ñoù ta coù: R1 = R1 + R1 = 100 +5 = 105KW Vôùi C = 1mF vaø R2 4.7KW. f = 1/T = 1,44/(R1 + 2R2)C = 1,44/ (114,4.103.10-6) = 12.5Hz. Pc1 .01 1mF 4.7k 100K +5v Ra 8 4 7 3 6 555 2 5 1 5K Hình B. 10 : Sô ñoà maïch taïo tín hieäu toác ñoä Nhö vaäy vôùi nhöõng giaù trò ñaõ tính ñöôïc seõ cho ta chuoãi xung vuoâng coù taàn soá chænh ñònh ñöôïc töø 12.5Hz – 100Hz. Xung ra seõ ñöôïc ñöa ñeán Pc1 cuûa boä vi xöû lyù. VIII-THIEÁT KEÁ MAÏCH CAÛNH BAÙO: Maïch caûnh baùo toác ñoä ñöôïc thieát keá chung cho caùc xe oâtoâ ñeàu khoâng naèm ngoaøi muïc ñích baûo ñaûm an toaøn tính maïng cho ngöôøi söû duïng xe. Sô ñoà maïch: Maïch caûnh baùo söû duïng tín hieäu toác ñoä ñaõ xöû lyù ñeå ñöa veà boä so saùnh, so saùnh vôùi toác ñoä caøi ñaët roài ñöa tín hieäu ñoù ñeán loa caûnh baùo. * Hoaït ñoäng: Tín hieäu toác ñoä ñöôïc ñöa ñeán boä so saùnh goàm ba vi maïch 7485 ñaõ ñöôïc caøi ñaët saün caáp so saùnh. Khi tín hieäu ñaït ñeán toác ñoä 80km/h thì moät tín hieäu ñieän aùp ñöôïc xuaát ra ngoõ ra cuûa vi maïch 7485, nhôø caùc coång logic maø moät taàn soá ñöôïc löïa choïn laø 500Hz seõ xuaát ra loa laøm cho loa phaùt ra moät taàn soá aâm thanh laø 500Hz. Töông töï cho caùc tröôøng hôïp toác ñoä ñaït 100km/h vaø 120km/h thì taàn soá caûnh baùo töông öùng xuaát ra loa seõ laø 2KHz vaø 5KHz. Trong quaù trình hoaït ñoäng maïch seõ bò Reset ôû taàn soá 10Hz phaùt ra bôûi IC 5551. 2-Tính toaùn vaø löïa choïn linh kieän: - Caùc taàn soá caûnh baùo ñöôïc taïo bôûi caùc maïch ñònh giôø 555. Caùc maïch ñònh giôø 555 naøy seõ laàn löôït taïo ra caùc tín hieäu dao ñoäng ôû taàn soá: 10Hz, 500Hz, 2Hz, 5Hz. Töø taàn soá xaùc ñònh tröôùc, döïa vaøo coâng thöùc sau F = 1/T = 1.44/(R1 + 2R2)C Ta laàn löôït xaùc ñònh ñöôïc caùc giaù trò R vaø C cho ôû hình veõ B. 11 Vôùi: 5551: Taïo ra taàn soá 10Hz ñeå reset 3 maïch dao doäng caûnh baùo. 5552: Taïo ra taàn soá caûnh baùo 5KHz khi toác ñoä ³ 120Km/h 5553: Taïo ra taàn soá caûnh baùo 2KHz khi toác ñoä ³ 100Km/h 5554: T5o ra taàn soá caûnh baùo 500Hz khi toác ñoä ³ 80Km/h Caùc coång logic And, Nor, Not ñeå taïo neân maïch choïn tín hieäu xuaát ra loa caûnh baùo. Boä so saùnh duøng vi maïch 7485. Vieäc thieát keá maïch caûnh baùo treân tuy ñôn giaûn, linh kieän deã kieám treân thò tröôøng. Nhöng ñeå goïn nheï trong quaù trình thi coâng vaø ñeå taän duïng heát khaû naêng cuûa KIT.Z80 ta chæ söû duïng moät loa caûnh baùo gaén tröïc tieáp leân ngoõ ra cuûa KIT coøn tín hieäu ra ñieàu khieån loa seõ ñöôïc thieát keá bôûi phaàn meàm. Theo ñoù taàn soá ñöôïc ngöôøi thöïc hieän löïa choïn caøi ñaët laø ba caáp dao ñoäng: 200Hz. 400Hz, 600Hz. Ñaây laø daõy taàn soá maø tai ngöôøi coù theå phaân bieät roõ raøng. Toùm laïi: Ngöôøi thöïc hieän vöøa trình baøy coâng vieäc thieát keá toaøn boä heä thoáng, vôùi boä vi xöû lyù trung taâm laø CPU Z80. Boä vi xöû lyù naøy seõ giaûi quyeát nhöõng chöông trình ñöôïc naïp trong EPROM. Töø ñoù chi phoái toaøn boä hoaït ñoäng cuûa heä thoáng, thöïc hieän quaù trình xöû lyù tín hieäu toác ñoä vaøo töø maïch taïo xung roài xuaát ra boä hieån thò soá tieàn vaø soá quaõng ñöôøng ñaõ thöïc hieän ñoàng thôøi xöû lyù luoân caû quaù trænh caûnh baùo toác ñoä. Chöông trình ñöôïc naïp trong EPROM giuùp cho maïch thi coâng ñôn giaûn vaø ñaït ñôïc söï meàm deûo. Khi coù yeâu caàu caøi ñaët laïi soá tieàn vaø caáp caûnh baùo khaùc ta chæ vieäc thay ñoåi treân phaàn meàm tröôùc khi naïp vaøo EPROM. Vôùi yeâu caàu cuûa ñeà taøi thì vieäc thieát keá heä thoáng KITZ80 ñaõ toû ra öu ñieåm hôn heä thoáng maïch soá nhôø coù khaû naêng tính toaùn caùc giaù trò khoâng tuyeán tính ñoàng thôøi löu laïi ñöôïc keát quaû veà soá tieàn vaø quaõng ñöôøng maø heä thoáng ñaõ xöû lyù ñöôïc. Ñieàu naøy giuùp cho cô quan chuû quaûn deã quaûn lyù hoaït ñoäng cuûa ngöôøi söû duïng phöông tieän. C- THIEÁT KEÁ PHAÀN MEÀM Moät heä thoáng vi xöû lyù sau khi ñöôïc thieát keá phaàn cöùng muoán laøm vieäc ñöôïc thì phaûi coù phaàn meàm ñieàu khieån. Chöông trình phaàn meàm caøng chaët cheõ, linh hoaït thì heä thoáng hoaït ñoäng caøng chính xaùc. Laäp trình laø thöïc hieän moät chöông trình vôùi moät ngoân ngöõ naøo ñoù ñeå ñieàu khieån caùch xöû lyù döõ lieäu theo töøng yeâu caàu cuï theå cuûa vaán ñeà. Do ñoù, beân caïnh söï hieåu bieát veà cô cheá hoaït ñoäng cuûa maùy tính, ngöôøi laäp trình caàn phaûi naém vöõng caùch toå chöùc döõ lieäu vaø caùch xöû lyù coøn goïi laø giaûi thuaät. Hieän nay coù 2 phöông phaùp laäp trình thoâng duïng laø phöông phaùp laäp trình tuaàn töï vaø phöông phaùp laäp trình caáu truùc. Phöông phaùp laäp trình tuaàn töï : Phöông phaùp naøy CPU seõ ñoïc tuaàn töï caùc chæ thò chöông trình töø ñòa chæ thaáp ñeán ñòa chæ cao vaø thöïc hieän chuùng cho ñeán ñòa chæ cuoái cuøng. Öu ñieåm cuûa phöông phaùp naøy laø ngöôøi ñoïc raát deã theo doõi chöông trình vaø naém ñöôïc yù ñoà cuûa ngöôøi thöïc hieän. Tuy nhieân laïi coù nhöôïc ñieåm laø kích thöôùc chöông trình lôùn. Phöông phaùp laäp trình coù caáu truùc: Theo phöông phaùp naøy nhöõng ñoaïn thöôøng xuyeân laäp laïi trong chöông trình ngöôøi ta ñem chuùng ra khoûi chöông trình vaø ñaët chuùng nhö moät chöông trình con. khi thi haønh ñeán ñoaïn chöông trình naøy CPU seõ nhaûy ñeán ñòa chæ xaùc ñònh cuûa chöông trình ñoù ñeå thöïc hieän taùc vuï. Ñeå quaù trình laøm vieäc khoâng bò giaùn ñoaïn ta duøng leänh quay veà (RET) khi ñoù CPU seõ quay veà chöông trình chính. Phöông phaùp naøy toû ra hieäu quaû trong vieäc giaûm kích thöôùc chöông trình vaø thuaän tieän cho ngöôøi vieát vaø noù ñöôïc ngöôøi thöïc hieän söû duïng trong taäp ñoà aùn. LÖU ÑOÀ KHOÁI CHÖÔNG TRÌNH : Löu ñoà khoái laø moät böôùc khaùi quaùt hoùa quaù trình thöïc hieän cuûa moät chöông trình. Noù löôïc ñi nhöõng chi tieát ñeå laøm noåi baät noäi dung chính cuûa chöông trình. Qua ñoù noù theå hieän yù ñoà cuûa ngöôøi thieát keá. Chöông trình ñöôïc ngöôøi thöïc hieän xaây döïng baèng taäp leänh cuûa CPU Z80. Keát hôïp vôùi nhöõng soá lieäu ban ñaàu ñöïôc löïa choïn caøi ñaët laø: Soá tieàn cho km ñaàu laø 5.000ÑVN 200m tieáp theo laø 1000 ÑVN. Sau 28 km : 2800ÑVN/km. Taàn soá caûnh baùo Khi soá xung >80 xung/s: Taàn soá caûnh baùo ñöôïc thöïc hieän 600Hz. Khi soá xung >60 xung/s : Taàn soá caûnh baùo ñöôïc thöïc hieän 400Hz. Khi soá xung <60 xung/s: Taàn soá caûnh baùo ñöôïc thöïc hieän 200Hz. LÖU ÑOÀ KHOÁI LÖÔÏNG TRÌNH CHÍNH SATRT ÑAËT BIEÁN CÔØ KIEÅM TRA HEÄ THOÁNG S Ñ GOÏI CHÖÔNG TRÌNH BAÙO ÑOÄNG CHÖÔNG TRÌNH TÍNH S VAØ T COÙ BAÙO ÑOÄNG ? CHÖÔNG TRÌNH ÑO LÖU ÑOÀ KHOÁI CHÖÔNG TRÌNH ÑO t=1s t=1s Ñ S Ñ S Ñ Ñ S S Ñ S RET I = 1S ? I = 0 ? I = 1 ? START Ñeám = Ñeám + 1 Ñeám giôø Ñeám giôø Goïi chöông trình queùt phím Goïi chöông trình queùt phím LÖU ÑOÀ KHOÁI CHÖÔNG TRÌNH QUEÙT PHÍM RET Ñ S Ñ S PCO = O ? PCO = O ? START Goïi chöông trình Delay 1 Xaùc ñònh phím Gôûi döõ lieäu oo -> Port B Goïi chöông trình Delay 2 Gôûi döõ lieäu 00 -> port B CHÖÔNG TRÌNH DELAY 1.2 RET Cho saùng soá haøng traêm Cho saùng soá haøng chuïc Cho saùng soá ñôn vò START Cho saùng soá haøng ngaøn Gôûi tín hieäu baùo MODE CHÖÔNG TRÌNH XAÙC ÑÒNH PHÍM Ñ Ñ S S A RET CY = 0 RRC B B -> A A = 01 ? AND 01 A <- Port C A -> Port B B -> A B = F7H START Ñ S S Ñ S Ñ S Ñ A =FBH ? ? RET A = 0 A -> (MODE) A = A + 1 Löu tieàn Ñaët côø tính tieàn = 1 Ñaët côø tính tieàn = 0 A A = 02 ? A<- (MODE) A =FDH ? A =F7H ? CHÖÔNG TRÌNH TÍNH TOAÙN S VAØ T Ñ S RET Tieàn = tieàn + 1000 * A A # O ? START Quaõng ñöôøng - 1000 Div -> A 200 *-CHÖÔNG TRÌNH BAÙO ÑOÄNG S Ñ S Ñ RET START A <- DOH A <- EOH A -> PortC A <- BOH Ñeám >60? ? Ñeám > 80? CHÖÔNG TRÌNH z80 Org 0000h LD SP. 3FFFH LD A,81H OUT (03H), A LD A,00H LD (TIME),A LD(VMOD),A LD (TT),A LD (CK),A LD HL, 0000H LD (MON), HL LD (S), HL LD (ST), HL LD (SS), HL LD A, (TAB+8) OUT (PORTB), A LD A, OFEH LAB1: OUT (PORTA),A CALL DL2S RRC A CP OBFH JP Z, LAB1 LAB 2: CALL DO CALL ALM CALL CAL JP LAB2 DL2S : LD HL, 6000H DL2S1: DEC HL LD A,H CP 00H JP NZ, DL2S1 LD A,L CP 00H JP NZ, DL2S1 RET DO : IN A, (PORTC) AND 02H CP 02H JP NZ, LADOI CALL SCKEY LD A, (TIME) INC A LD (TIME),A CP OC8H RET Z JP DO LADOI1: IN A , (PORTC) AND 02H CP 00H JP NZ, LADOI2 CALL SCKEY LD A, (TIME) INC A LD (TIME),A CP OC8H RET Z JP LADOI LADOI 2: LD A, (CK) INC A LD (CK), A JP DO SCKEY : LD A,OOH OUT (PORTA),A IN A, (PORTC) AND 01H CP 01H JP NZ, SCK1 CALL DELEY1 RET SCK1: CALL DELAY2 LD A,OOH OUT (PORTA), A IN A, (PORTC) AND 01H CP 01H RET Z CALL XDP RET DELAY 1: LD A,(VMOD) CP OOH JP Z,DSP1 CP 01H JP Z, DSP2 CP 02H JP Z, DSP3 JP NZ, DSP4 DL10: LD B,O8H DL11: LD A, (HL) OUT (PORTB), A LD A,B OUT (PORTA),A CALL DL1ms INC HL RRC B JP C, DL11 LD A, (VMOD) OUT (PORTB), A LD A,20H OUT (PORTA), A CALL DL1ms RET DSP 1: LD HL, BUF 1 JP DL10 DSP2 : LD HL BUF2 JP DL10 DSP3 : LD HL, BUF 3 JP DL10 DSP4: LD HL, BUF4 JP DL10 DL1ms: LD A,63H MS1 : CP OOH RET Z NOP DEC A JP MS1 DELAY2: CALL DELAY 1 CALL DELAY 1 CALL DELAY 1 CALL DELAY 1 RET XDP : LD B, OF7H XDP2: LD A,B OUT (PORTB), A IN A, (PORTC) AND 01H CP 01H JP Z,XDP1 RRC B RET NC JP C, XDP2 XDP1: LD A,B CP OF7H CALL Z,RSTT CP OFBH CALL Z, SETTT CP OFDH CALL Z,LUU LD A, (VMOD) CP 03H JP Z, XDP3 INC A LD (VMOD), A RET RSTT LD A,OOH LD (TT), A RET SETTT: LD A,01H LD (TT), A LUU : LD BC , (MON) LD HL, (ST) ADD HL, BC LD (ST), HL LD BC, (S) LD HL, (SS) ADD HL, BC LD (SS), HL RET XDP3: LD A,00H LD (VMOD), A RET CAL: LD HL, (S) LD A, (CK) CALL HLADDA LD (S), HL LD BC, 03E8H SBC HL, BC CALL D200 LD A, (SM) CP OOH RET Z CALL A1000 LD B,H LD C,L LD HL, (MON) ADD HL,BC LD (MON), HL RET DECO : LD A, (VMOD) CP OOH JP Z, DECO1 CP 01H JP Z,DECO2 CP 02 JP Z,DECO3 LD HL, (SSKT) LD BC, BUF4 DECOO: CALL DI10 LD (BC),A CALL DI10 INC BC LD (BC), A CALL DI10 INC BC LD (BC), A INC BC LD (BC),A RET DECO1: LD HL, (MON) LD BC, BUF1 JP DECOO DECO2: LD HL, (ST) LD BC, BUF2 JP DECOO DECO 3 LD HL, (SS) LD BC, BUF3 JP DECOO DI10: PUSH BC LD BC, OOOOH D12 LD A,H CP OOH JP Z, DII INC BC LD A, 0AH CALL HLSUBA JP D12 HLSUBA : LD D, OOH LD E, 0AH SBC HL, DE RET DI1: LD A,L D14: LD L, OAH CP L JP C, D13 INC BC SUB L JP D14 D13 LD HL, TAB CALL HLADDA LD A, (HL) LD H,B LD L,C POP BC RET ALM : LD A, (CK) CP 80 H JP Z, ALM1 CP 60H JP Z, ALM2 LD A, OBOH ALM3: OUT (PORTC), A RET ALM1: LD A, OEOH JP ALM3 ALM2: LD A, ODOH JP ALM3 HLADDA: LD B, OOH LD C,A ADD HL, BC RET A1000: LD HL, 0000H LD B, 03H LD C, OE8H A1L1: CP OOH RET Z ADC HL, BC DEC A JP A1L1 D200 : LD D, OOH LD BC, OOC8H D22: LD A,H CP OOH JP Z, D21 D23: SBC HL, BC INC D LD A,D LD (SM), A JP D22 D21: LD A,L CP OC8H RET C JP D23 TAB: DEFB 3FH ; BANG TRA MA LED DEFB 06H DEFB 5BH DEFB 4FH DEFB 66H DEFB 6DH DEFB 7DH DEFB 07H DEFB 7FH DEFB 6FH ;………………………………; PORTA EQU OOH PORTB EQU O1H PORTC EQU O2H TIME EQU 2100H CK EQU 2101H TT EQU 2022H VMOD EQU 2103H SM EQU 2104H BUF 1 EQU 2000H BUF 2 EQU 2010H BUF 3 EQU 2020H BUF 4 EQU 2030H S EQU 2105H MON EQU 2107H ST EQU 2109H SS EQU 210BH SSKT EQU 210EH END. D- THI COÂNG HEÄ THOÁNG Boä tính cöôùc xe Taxi coù chöùc naêng thoâng baùo cho ngöôøi ñieàu khieån xe vaø haønh khaùch bieát keát quûa soá tieàn cuøng chieàu daøi quaõng ñöôøng di chuyeån neân maïch phaûi ñaûm baûo tính chính xaùc vaø lieân tuïc. Hôn nöõa phaàn hieån thò phaûi roõ raøng deã quan saùt deã kieåm tra. Sau khi ñaõ tính toaùn thieát keá treân cô sôû lyù thuyeát ôû phaàn chöông II, ñeå kieåm chöùng laïi ñoä tin caäy vaø hoaøn chænh cuûa baûn thieát keá, ngöôøi thöïc hieän tieán haønh thi coâng heä thoáng. I-THI COÂNG HEÄ THOÁNG : Trong thöïc teá thi coâng heä thoáng ñeå taïo ñieàu kieän deã daøng cho vieäc veõ maïch vaø laép raùp linh kieän, ngöôøi thöïc hieän ñaõ coá gaéng thu nhoû kích thöôùc toaøn boä maïch trong phaïm vi cho pheùp ñoàng thôøi döïa treân ñieàu kieän thôøi gian vaø khaû naêng kinh phí coù haïn maø chia chuùng ra thaønh 3 boä phaän chính vaø thi coâng nhöõng phaàn chính yeáu theo yeâu caàu ñaõ ñeà ra. Bo maïch chính laø maïch KIT Z-80 Bo maïch thieát keá bò ngoaïi vi bao goàm ñeøn hieån thò vaø baøn phím. Bo maïch thieát bò ngoaïi vi bao goàm ñeøn hieån thò vaø baøn phím. II-KIEÅM TRA VAØ ÑAÙNH GIAÙ HEÄ THOÁNG: Sau khi ñaõ hoaøn taát caùc coâng ñoaïn laép raùp, tieán haønh kieåm tra hoaït ñoäng cuûa maïch. Caáp ñieän cho maïch, môû coâng taéc POWER. Nhaán phím START ñeå cho maïch baét ñaàu vieäc tính tieàn Nhaán phím STOP ñeå thöû chaám döùt vieäc ñeám soá km chaïy khoâng khaùch. Thöû choïn caùc MODE. Ñieàu chænh nuùm “Tín hieäu toác ñoä” ñeå thay ñoåi vaän toác theo doõi söï thay ñoåi nhòp keâu cuûa loa caûnh baùo. * Ñaùnh giaù keát quaû: Vieäc ñaùnh giaù bao goàm ñaùnh giaù veà hình thöùc vaø khaû naêng hoaït ñoäng cuûa maïch. I-KEÁT LUAÄN: Qua 6 tuaàn laøm vieäc thaät söï nghieâm tuùc ngöôøi thöïc hieän ñaõ hoaøn thaønh taäp ñoà aùn ñuùng thôøi haïn vaø ñuùng yeâu caàu ñeà ra. Ñeà taøi ñaõ ñeà caäp ñeán moät vaán ñeà mang tính môùi meõ vaø thöïc tieãn khoâng nöõng ñoái vôùi xaõ hoäi maø coøn ñoái vôùi ngöôøi thöïc hieän. Baèng söï noã löïc tham khaûo nhieàu taøi lieäu khaùc nhau trong vaø ngoaøi nöôùc ngöôøi thöïc hieän ñaõ trình baøy moät caùch coù heä thoáng caùc vaán ñeà lieân quan ñeán vieäc caûnh baùo toác ñoä vaø tính cöôùc xe Taxi. Xeùt veà maët lyù thuyeát taäp ñoà aùn ñaõ trình baøy töông ñoái ñaày ñuû, nhöng do thôøi gian vaø kieán thöùc coù haïn cuõng nhö yeâu caàu nghieân cöùu cuûa ñoà aùn ñeà ra maø ngöôøi thöïc hieän khoâng theå trình baøy ñaày ñuû vieäc thieát keá – thi coâng hoaøn chænh boä caûnh baùo vaø tính cöôùc xe Taxi coù theå öùng duïng trong thöïc teá. Ñaây cuõng chính laø maët haïn cheá chuû yeáu cuûa taäp ñoà aùn. Theo ñoù taäp ñoà aùn ñaõ ñeà caäp ñeán caùc noäi dung sau : Giôùi thieäu nguyeân lyù ño toác ñoä, nguyeân lyù caûnh baùo toác ñoä vaø nguyeân lyù tính cöôùc xe Taxi. Thieát keá maïch phaàn cöùng. Thieát keá phaàn meàm Thi coâng heä thoáng. Sau khi hoaøn thaønh taäp ñoà aùn ngöôøi thöïc hieän ñaõ heä thoáng hoùa ñöôïc nhöõng kieán thöùc ñaõ hoïc, hình thaønh vaø phaùt trieån khaû naêng nhaän thöùc vaø giaûi quyeát vaán ñeà, ñoàng thôøi caûm thaáy töï tin hôn ñi tieáp vaøo con ñöôøng hoïc taäp vaø nghieân cöùu khoa hoïc. ÑEÀ NGHÒ: Thoâng qua quaù trình thöïc hieän ñeà taøi nghieân cöùu coù moät soá ñeà nghò sau: Do soá trang coù haïn neân caùc vaán ñeà ñöôïc trình baøy trong taäp ñoà aùn raát coâ ñoïng do ñoù ngöôøi nghieân cöùu muoán hieåu roõ theâm chi tieát caùc vaán ñeà caàn tham khaûo theâm phaàn phuï luïc vaø caùc taøi lieäu coù lieân quan ñöôïc ghi ôû sau taäp ñoà aùn. Vì thôøi gian coù haïn neân ngöôøi thöïc hieän chæ giaûi quyeát ñöôïc moät soá yeâu caàu cô baûn veà kyõ thuaät ñaõ ñöôïc ñeà ra. Nhö vaäy ñeà heä thoáng thieát keá ñöôïc trôû neân hoaøn chænh vaø mang tính thöïc tieãn cao thì caàn phaûi thöïc hieän theâm moät soá phaàn sau. Thieát keá toaøn boä nguoàn döï phoøng ñeå caáp cho maïch ñaëc bieät laø giuùp RAM löu giöõ döõ lieäu khi gaëp söï coá maát ñieän nguoàn. Ñieàu naøy giuùp cho cô quan quaûn lyù, quaûn lyù ñöôïc hoaït ñoäng cuûa nhaân vieân. Thieát keá vaø thi coâng moät maïch taïo tín hieäu toác ñoä hoaøn chænh hôn nhaèm giuùp thuaän tieän cho vieäc hoïc taäp vaø nghieân cöùu. Hôn nöõa ñeå ñeà taøi coù theå öùng duïng trong thöïc teá caàn phaûi coù söï keát hôïp nghieân cöùu vôùi nhoùm chuyeân ngaønh cô khí ñoâng löïc nhaèm thuaän tieän cho vieäc thieát keá – thi coâng vaø taêng tính khaû thi cuûa ñeà taøi. Cuoái cuøng em xin chaân thaønh caûm ôn thaày Leâ Thanh Ñaïo ñaõ tröïc tieáp höôùng daãn cuøng toaøn theå caùc thaày coâ giaùo trong khoa vaø caùc baïn ñoàng nghieäp ñaõ giuùp ñôõ em trong quaù trình thöïc hieän ñeà taøi. Ngöôøi thöïc hieän raát mong nhaän ñöôïc söï goùp yù nhieät thaønh töø phía caùc thaày coâ giaùo vaø caùc baïn Ngöôøi Thöïc Hieän Nguyeãn Ñöùc Lôïi PHUÏ LUÏC KHAÛO SAÙT CPU Z80 Z80 CPU laø ñôn vò xöû lyù trung taâm thöïc hieän moïi quyeát ñònh vaø phaân boá thôøi gian ñieàu khieån toaøn heä thoáng. Nhöõng ñaëc ñieåm chính yeáu cuûa CPU Z80. 8 bít taùc ñoäng song song 158 loaïi leänh caên baûn Coù 52 thanh ghi beân trong Coù tính naêng ngaét (interrupt). Coù theå noái tröïc tieáp vôùi RAM ñoäng maø haàu nhö khoâng caàn maïch phuï trôï beân ngoaøi. Toác ñoä cuûa leänh fetch laø 1.6ms Chæ caàn duøng moät nguoàn ñieän +5v duy nhaát. Taát caû caùc chaân xuaát tín hieäu ra vaø nhaäp tín hieäu vaøo ñeàu thuoäc loaïi TTL. Moâ taû toång quaùt : Ngöôøi ta phaân Z80 CPU laøm 3 khoái chính: Khoái thanh ghi : Laø nhöõng oâ nhôù naèm beân trong CPU vaø ñöôïc giôùi thieäu trong leänh baèng nhöõng kyù hieäu cuï theå. Döõ lieäu töø boä nhôù ñöôïc chuyeån vaøo löu tröõ taïm thôøi, trong quaù trình tính toaùn vaø xöû lyù. Khoái ALU (Arithmetic and Logic Unit): Khoái naøy thöïc hieän caùc pheùp toaùn luaän lyù vaø soá hoïc. Khoái giaûi maõ leänh vaø ñieàu khieån : Coù nhieäm vuï phaân tích maõ leänh vaø hình thaønh caùc thao taùc tieáp theo töông öùng vôùi leänh ñoù. Phaân tích khoái thanh ghi (Register set): Khoái thanh ghi cuûa CPU ñöôïc chia laø 3 nhoùm theo baûng sau: Nhoùm 1 : Bao goàm caùc boä thanh ghi 16bit ñöôïc gheùp noái tieáp töø 2 thanh ghi 8bit, moät boä chính vaø moät boä hoaùn ñoåi. Caû hai boä goàm coù: Thanh ghi tích luõy (Accumulator Register). Thanh ghi côø (Flag Register). Saùu thanh ghi ña duïng : B, C, D, E, H,L: coù theå duøng ñôn leû hoaëc gheùp thaønh 3 caëp BC, DE, HL. Söï chuyeån ñoåi döõ lieäu giöõa caùc boä gheùp noái cuûa caùc thanh ghi ñöôïc thöïc hieän baèng leänh chuyeån ñoåi (Exchange). Keát quaû ñöôïc ñaùp öùng nhanh vaø deã daøng ñoái vôùi caùc ngaét. Nhoùm 2 : Goàm 6 thanh ghi. Thanh ghi ngaét (Interrupt Register). Thanh ghi laøm töôi boä nhôù (register Memory Refresh). Con troû ngaên xeáp (Stack pointer). Thanh ghi ñeám chöông trình (program Counter). Thanh ghi chæ soá (Index Register) : Duøng cho pheùp ñònh vò chæ soá. Nhoùm 3 : Goàm2 Flip – flop ñeå ghi nhôù caùc traïng thaùi ngaét. Moâ taû caùc nhoùm chaân Z80 – CPU: Z80 CPU 1 40 2 39 3 38 4 37 5 36 6 35 7 34 8 33 9 32 10 31 11 30 12 29 13 28 14 27 15 26 16 25 17 24 18 23 19 22 20 21 D1 INT NMI HALT MREQ IORQ D7 D0 D2 A11 Vcc D6 D5 D3 D4 CK A15 A14 A13 A12 A10 A9 A8 A7 A6 A5 A4 A3 A2 A1 A0 GND RFSH MI RESET BUSRQ WAIT BUSAK WR RD HÌNH I.1 : Sô ñoà chaân cuûa CPU Z80 Caùc Bus ñòa chæ vaø döõ lieäu Bus ñòa chæ (Address Bus) A0 ¸A15 : Ngoõ ra ba traïng thaùi xuaát, taùc ñoäng ôû möùc cao, taïo thaønh tuyeán ñòa chæ 16 bit. Baèng caùch phoái hôïp giöõa caùc tính hieäu “1” vaø “0” ôû moãi chaân chuùng ta coù theå chæ ñònh ñöôïc ñòa chæ treân boä nhôù hay boä vaøo ra I/O khaùc. Bus döõ lieäu (Data Bus) D0 ¸ D7 : Ngoõ ra ba traïng thaùi xuaát nhaäp, taùc ñoäng ôû möùc cao, taïo thaønh tuyeán döõ lieäu 8 bit, treân ñoù döõ lieäu coù theå di chuyeån theo hai chieàu, nhaän vaø giao döõ lieäu giöõa CPU vaø boä nhôù hay vaøo ra I/O. Caùc ngoõ ñieàu khieån nhaäp: BUSREQ – Yeâu caàu Bus (Bus Request): Ngoõ vaøo, taùc ñoäng ôû möùc thaáp. Tín hieäu naøy coù öu tieân cao hôn so vôùi NMI (Non Maskable Interrupt), luoân ñöôïc ghi vaøo cuoái chu ky maùy hieän haønh. BUSREQ yeâu caàu CPU ñöa Bus döõ lieäu, Bus ñòa chæ vaø caùc tín hieäu ñieàu khieån MREQ, IORQ, RD vaø WR leân traïng thaùi toång trôû cao. INT – Yeâu caàu ngaét (Interrupt request) : Yeâu caàu ngaét ñöôïc taïo bôûi thieát bò I/O. Neáu Flip – flop cho pheùp ngaét ñang ôû traïng thaùi cho pheùp thì CPU seõ thi haønh ngaét vaøo cuoái leänh haønh. NMI – Ngaét khoâng che (Non Maskable Interrupt) : Ngoõ vaøo taùc ñoäng ôû möùc thaáp. NMI coù öu tieân cao hôn INT. NMI luoân ghi nhaän vaøo cuoái leänh hieän haønh, ñoäc laäp vôùi traïng thaùi Flip – flop cho pheùp ngaét vaø töï ñoäng baét buoäc CPU phaûi khôûi taïo laïi. WAIT – Ñôïi: Ngoõ vaøo taùc ñoäng ôû möùc thaáp. WAIT chæ ra ñôn vò nhôù hay I/O ñaõ ñöôïc chæ ñònh khoâng saün saøng ñeå trao ñoåi döõ lieäu. CPU tieáp tuïc ñöa vaøo traïng thaùi ñôïi tín hieäu naøy coøn taùc ñoäng. RESET – Ñaët laïi : Ngoõ vaøo taùc ñoäng ôû möùc thaáp. RESET khôûi ñoäng laïi CPU nhö sau : noù ñaët laïi Flip – flop cho pheùp ngaét, xoùa thanh ghi ñeám chöông trình, thanh ghi ngaét vaø thanh ghi phuïc hoài boä nhôù (Memory refresh register) vaø ñaët laïi cheá ñoä 0. Trong suoát thôøi gian ñaët laïi Data Bus vaø Address Bus ôû traïng thaùi toång trôû cao. c- Caùc ngoõ ñieàu khieån xuaát: M1 – Moät chu kyø maùy (Machine Cycle One) : Ngoõ ra taùc ñoäng ôû möùc thaáp. M1 cuøng vôùi MREQ chæ ra chu kyø maùy hieän haønh laø moät chu kyø laáy leänh. MREQ – yeâu caàu boä nhôù (Memory Request): Ngoõ ra 3 traïng thaùi taùc ñoäng ôû möùc thaáp. Khi CPU truy xuaát boä nhôù MREQ xuoáng möùc thaáp ñeå choïn vuøng nhôù ñoù. IORQ – yeâu caàu vaøo ra (In/Out Request): Ngoõ ra 3 traïng thaùi, taùc ñoäng ôû möùc thaáp. IORQ cuõng ñöôïc taïo ra ñoàng thôøi vôùi M1 khi CPU chaáp nhaän noù ñeå chæ ra raèng 1 vectô ñaùp öùng ngaét coù theå ñaët leân treân bus döõ lieäu. RD- Ñoïc (Read) : Ngoõ ra 3 traïng thaùi, taùc ñoäng ôû möùc thaáp. RD chæ ra raèng CPU muoán ñoïc döõ lieäu töø ngaên nhôù vaø töø thieát bò I/O ñaõ ñöôïc chæ ñònh. WR – vieát (write): Ngoõ ra 3 traïng thaùi, taùc ñoäng ôû möùc thaáp. WR chæ ra raèng treân bus döõ lieäu cuûa CPU coù caùc döõ lieäu seõ ñöôïc ghi vaøo ngaên nhôù hoaëc coång vaøo ra ñaõ ñöôïc chæ ñònh. RSSH - laøm töôi (Refresh) : Ngoõ ra 3 traïng thaùi, taùc ñoäng ôû möùc thaáp RSSH cuøng vôùi MREQ chæ ra raèng 7 bis giaûm cuûa bus ñòa chæ thuoäc thoáng chöùa ñòa chæ laøm töôi boä nhôù ñoäng (phuïc hoài Ram ñoäng). HALT – traïng thaùi döøng (Halt sate) : Ngoõ ra 3 traïng thaùi, taùc ñoäng ôû möùc thaáp. Tín hieäu 0 ôû chaân HALT chæ ra raèng CPU ñaõ thöïc hieän leänh ngöøng CPU . Luùc ñoù beân trong noäi boä CPU seõ xöû lyù leänh NOP (No Operration Instruction) coù nghóa laø khoâng laøm gì caû. Trong khoaûng thôøi gian ñoù quaù trình phuïc hoài boä nhôù ñöôïc tieán haønh. Khi coù tín hieäu 0 gôûi ñeán 1 trong 3 chaân RESET, INT, NMI cuûa CPU thì tình traïng HALT cuûa CPU seõ ñöôïc loaïi boû. BUSACK – chaáp thuaän bus (Bus Acknowledge) : Ngoõ ra taùc ñoäng ôû möùc thaáp. Tín hieäu naøy cho bieát thieát bò ñang yeâu caàu bus bieát raèng. CPU ñaõ chaáp nhaän nguoàn bus, nghóa laø bus ñòa chæ, bus döõ lieäu caùc tín hieäu ñieàu khieån MREQ , IONQ, RD vaø WR cuûa CPU ñöôïc ñöa vaøo traïng thaùi toång trôû cao. Toång quaùt veà quaù trình hoaït ñoäng caùc ngaét : Khi yeâu caàu ngaét NMI ñöôïc ghi nhaän CPU khoâng thöïc hieän leänh kieåu RESTART ôû ñòa chæ 0066H. Ñaàu ngaét UNT coù theå cho pheùp hoaëc caém baèng phaàn meàm (leänh EI cho pheùp ngaét, leänh DI caám ngaét). Ñoái vôùi INT, Z80-CPU coù theå ghi ngaét trong 3 cheá ñoä xaùc ñònh bôûi phaàn meàm : Leänh IMO laäp cheá ñoä ngaét 0, IM1 laäp cheá ñoä ngaét 1 vaø IM2 laäp cheá ñoä ngaét 2. Cheá ñoä ngaét 0 : Thieát bò ngoaïi vi yeâu caàu ngaét coù theå ñöa vaøo bus soá lieäu baát cöù leänh naøo khi Z80-CPU traû lôøi ngaét vaø Z80-CPU seõ thöïc hieän leänh ñoù. Thoâng thöôøng ngöôøi ta söû duïng leänh maø thöïc chaát laø leänh CALL, 1 byte vaøo trang 0 cuûa boä nhôù, hoaëc leänh CALL thoâng thöôøng 3byte ñeå goïi ñeán baát cöù vuøng naøo cuûa boä nhôù. Cheá ñoä ngaét 1: Coâng vieäc chuû yeáu laø goïi chöông trình con phuïc vuï ngaét taïi ñòa chæ 0038H, khi nhaän ngaét ôû cheá ñoä 1, Z80-CPU töï ñoäng taïo vaø thöïc hieän leänh RST7 maø khoâng caàn thieát bò ngoaïi vi cung caáp vectô ngaét töø ngoaøi vaøo bus soá lieäu. Cheá ñoä ngaét 2 : Laø cheá ñoä ngaét öu vieät ñaùng keå cuûa Z80-CPU so vôùi caùc hoï vi xöû lyù khaùc. Vôùi caùc vectô ngaét 1 byte do thieát bò ngoaïi vi cung caáp , Z80-CPU coù theå thöïc hieän goïi giaùn tieáp vôùi baát kyø vò trí naøo trong boä nhôù. Taäp leänh cuûa Z80-CPU: Vi xöû lyù Z80 coù taäp leänh raát phong phuù so vôùi caùc vi xöû lyù 8bit khaùc. Ñaëc bieät coù caùc leänh truyeàn khoái, taïo thao taùc dòch chuyeån moät khoái döõ lieäu trong boä nhôù hay giöõa boä nhôù vaø thieát bò vaøo/ra. Caùc leänh cuûa Z80 chia thaønh caùc loaïi: Leänh truyeàn döõ lieäu 8 bit. Leänh truyeàn döõ lieäu 16bit. Leänh trao ñoåi, truyeàn khoái, doø tìm. Leänh tính toaùn 8bit. Leänh tính toaùn 16bit. Leänh xeâ dòch döõ lieäu (shift). Caùc leänh nhaûy (Jump). Leänh naïp döõ lieäu vaøo töøng bit. Caùc leänh goïi chöông trình con, trôû veà vaø khôûi ñoäng. Leänh ñieàu khieån CPU. Leänh hoaùn chuyeån thanh ghi. Leänh xuaát nhaäp döõ lieäu. II KHAÛO SAÙT BOÄ XUAÁT NHAÄP SONG SONG (VI MAÏCH PPI 8255) 1-Giôùi thieäu Moät heä thoáng xöû lyù muoán ñöa döõ lieäu ra ñieàu khieån thieát bò beân ngoaøi hoaëc muoán nhaäp döõ lieäu töø ngoaøi vaøo ñeå xöû lyù thì khoâng theå trao ñoåi tröïc tieáp maø phaûi thoâng qua moät khaâu trung gian laø boä giao tieáp ngoaïi vi hay coøn goïi laø caûng xuaát nhaäp (I/O port). Nhôø coù boä giao tieáp naøy döõ lieäu truyeàn ñi ñeå ñieàu khieån hoaëc nhaän vaøo ñeå xöû lyù ñaõ môû roäng ñöôïc phaïm vi öùng duïng cuûa noù trong nhieàu lónh vöïc, ñaëc bieät laø trong töï ñoäng hoaù. Moät vaøi haõng saûn xuaát vi xöû lyù ñaõ cheá taïo saün caùc thieát bò LSI laøm cho vieäc thieát keá giao tieáp song song ñöôïc deã daøng. Moät trong nhöõng thieát bò giao tieáp song song ñieån hình laø maïch giao tieáp 8255 cuûa haõng Intel. 2-Caáu taïo cuûa vi maïch 8255 8255 giao tieáp ngoaïi vi song song laäp trình ñöôïc (PPI) 8255 laø moät linh kieän xuaát nhaäp song song laäp trình ñöôïc duøng ñeå giao tieáp vôùi caùc thieát bò ngoaïi vi tôùi Bus heä thoáng. Noù coù theå laäp trình ñöôïc ñeå truyeàn döõ lieäu döôùi nhöõng ñieàu kieän khaùc nhau, töø vaán ñeà vaøo ra I/O ñôn giaûn cho ñeán caùc ngaét vaøo ra I/O, noù raát linh hoaït, ña naêng veà kinh teá ( Khi nhieàu caûng vaøo ra ñöôïc yeâu caàu söû duïng) nhöng ñoâi khi cuõng phöùc taïp. 8255 laø moät linh kieän xuaát nhaäp ña naêng, coù theå söû duïng haàu heát vôùi caùc boä vi xöû lyù. Söû duïng maïch 8255 ñeå giao tieáp seõ laøm coâng vieäc thieát keá gheùp noái boä vi xöû lyù vôùi caùc thieát bò ngoaïi vi ñôn giaûn ñi nhieàu, ñoä meàm deûo cuûa thieát keá seõ taêng leân vaø linh phuï kieän seõ giaûm ñi. b-Caùc caáu truùc cuûa PPI 8255: 8255 hoaït ñoäng vôùi ba traïng thaùi (Mode) khaùc nhau. Chuùng coù theå duøng chöông trình ñeå choïn moät trong ba traïng thaùi naøy. Ba traïng thaùi hoaït ñoäng naøy ñöôïc goïi laø traïng thaùi 0, traïng thaùi 1, traïng thaùi 2. Chöùc naêng cuûa töøng traïng thaùi ñöôïc ñöôïc moâ taû trong hình sau: A B C I/O Hình II-1: Sô ñoà moâ taû caùc MODE hoaït ñoäng cuûa 8255 I/O PA7-PA0 CONTROL I/O PB7-PB0 C B A MODE 2 MODE 1 PA7-PA0 CONTROL OR I/O CONTROL OR I/O PB7-PB0 C B A PB7-PB0 PC3-PC0 PC7-PC4 PA7-PA0 MODE 0 I/O I/O I/O 8255 RD A0-A1 D7-D0 DATA BUS CONTROL BUS ADDRESS BUS BI-DIRECTIONAL Traïng thaùi 0: ÔÛ traïng thaùi naøy coù theå duøng toaøn boä 24bit (8bit x 3 caûng) cuûa caùc caûng A, B, C ñeå nhaäp hay xuaát döõ lieäu. Khi söû duïng caùc caûng naøy, caùc caûng A, B coù theå duøng 8 bit cuûa chuùng ñeå nhaäp hay xuaát döõ lieäu coøn 8bit cuûa caûng C thì ñöôïc chia thaønh 2 phaàn: 4 bis cao vaø 4 bis thaáp. Traïng thaùi 1: Traïng thaùi naøy ñöôïc chia thaønh 2 nhoùm : Nhoùm A (chuû yeáu laø caûng A) vaø nhoùm B (chuû yeáu laø caûng B). Ñoái vôùi moãi nhoùm duøng 4 bit cuûa caûng C ñieàu khieån. Traïng thaùi 2: Nhoùm A ñöôïc duøng nhö tuyeán 2 chieàu vaø duøng 5 bit cuûa caûng C ñieàu khieån. Coøn laïi 3bit cuûa caûng C vaø 8 bit caûng B coù theå duøng theo traïng thaùi 0 vaø traïng thaùi. 3-Sô ñoà chaân cuûa 8255: Hình II-2: Sô ñoà chaân cuûa 8255 PA4 PA5 PA6 PA7 WR RESET DO D1 D2 D3 D4 D5 D6 D7 Vcc PB7 PB6 PB5 PB4 PB3 PA3 PA2 PA1 PAO RD CS GND A1 A0 PC7 PC6 PC5 PC4 PC0 PC1 PC2 PC3 PBO PB1 PB2 8255 1 40 2 39 3 38 4 37 5 36 6 35 7 34 8 33 9 32 10 31 11 30 12 29 13 28 14 27 15 26 16 25 17 24 18 23 19 22 20 21 Boä gheùp noái song song ñieàu khieån theo chöông trình 8255 goàm coù: Thanh ghi ñieàu khieån: Ñaây laø thanh ghi 8bis noäi dung cuûa thanh ghi ñieàu khieån ñöôïc goïi laø töø ñieàu khieån. Töø ñieàu khieån ñöôïc duøng ñeå xaùc ñònh moät chöùc naêng vaøo/ra cho moãi caûng (khôû taïo caûng) thanh ghi naøy coù theå ñöôïc thaâm nhaäp ñeå ghi moät töø ñieàu khieån khi ñòa chæ Ao vaø A1 ñeàu ôû möùc logic 1. Caàn chuù yù raèng khoâng theå thaâm nhaäp vaøo thanh ghi naøy ñeå ñoïc döõ lieäu. Thanh ghi traïng thaùi : Caûng vaøo ra 8bit A, B, C trong ñoù 8 bit cuûa caûng C coù theå ñöôïc söû duïng nhö nhöõng bit rieâng (ôû cheá ñoä caøi ñaët bit hoaëc ñöôïc nhoùm thaønh 2 nhoùm ñoäc laäp baèng chöông trình: 4 bit cao (PC4…PC7) thuoäc nhoùm A vaø 4 bis thaáp (Pc0…PC3) thuoäc nhoùm B. Boä ñeám bus döõ lieäu laøm nhieäm vuï giao tieáp giöõa bus döõ lieäu ngoaøi vôùi thanh ghi ñieàu khieån, thanh ghi traïng thaùi hoaëc moät trong caùc caûng vaøo/ra, ngoaøi ra 8255 coøn coù caùc ñöôøng ñieàu khieån nhö sau: RD (read): Tín hieäu naøy cho pheùp hoaït ñoäng ñoïc döõ lieäu khi ñöôøng döõ lieäu naøy xuoáng möùc thaáp, CPU ñoïc döõ lieäu töø moät caûng ñaàu ra cuûa 8255. WR (write): Tín hieäu naøy cho pheùp hoaït ñoäng ghi döõ lieäu. Khi ñöôøng döõ lieäu naøy xuoáng möùc thaáp, CPU seõ xuaát ra moät caûng vaøo ra ñöôïc choïn hoaëc ra thanh ghi ñieàu khieån cuûa 8255. Reset: Ñöôøng tín hieäu naøy hoaït ñoäng tích cöïc ôû möùc cao. Khi chaân naøy ôû möùc cao, noäi dung trong thanh ghi ñieàu khieån ñöôïc xoùa vaø ñaët taát caû caùc caûng ôû kieåu vaøo. CS, A0, A1: Ñaây laø caùc tín hieäu ñöôïc choïn, CS ñöôïc noái vôùi boä giaûi maõ ñòa chæ; A0 vaø A1 ñöôïc noái ñeán caùc ñöôøng chæ A0 vaø A1 cuûa CPU, trong ñoù CS laø tín hieäu chính cho pheùp 8255 hoaït ñoäng vaø vieäc xaùc ñònh ñòa chæ cho 8255 döïa vaøo chaân tính hieäu naøy, coøn caùc tín hieäu A0 vaø A1 duøng ñeå choïn moät trong caùc caûng hoaëc thanh ghi ñieàu khieån. Toùm laïi vieäc choïn caûng vaø ñònh ñòa chæ cho 8255 ñöôïc toùm taét nhö sau: Traïng thaùi A1 A0 RD WR CS Moâ taû söï chuyeån ñoåi Ñoïc 0 0 1 0 1 0 0 0 0 1 1 1 0 0 0 Caûng A=> Bus döõ lieäu Caûng B=> Bus döõ lieäu Caûng C=> Bus döõ lieäu Ghi 0 0 1 1 0 1 0 1 1 1 1 1 0 0 0 0 0 0 0 0 Bus döõ lieäu=> Caûng A Bus döõ lieäu=> Caûng B Bus döõ lieäu=> Caûng C Bus döõ lieäu=> Thanh ghi ñieàu khieån neáu D7=1 Khoâng hoaït ñoäng x 1 x x 1 x x 0 1 x 1 1 1 0 0 Bus döõ lieäu ôû traïng thaùi trôû khaùng cao Ñieàu kieän khoâng chaáp nhaän Bus döõ lieäu ôû traïng thaùi trôû khaùng cao. x: khoâng quan taâm Baûng II.1 Baûng traïng thaùi cuûa 8255 c-Caùc cheá ñoä laøm vieäc cuûa 8255 Vi maïch tieáp song song laäp trình ñöôïc 8255 coù 2 cheá ñoä laøm vieäc khaùc nhau. Cheá ñoä caøi ñaët hoaëc xoùa bit(BSR: Bit Set/Reset) Cheá ñoä vaøo/ra (I/O mode) 8255 laøm vieäc ôû cheá ñoä naøo laø phuï thuoäc vaøo giaù trò cuûa bit D7 trong thanh ghi ñieàu khieån: Trong cheá ñoä I/O, vieäc xaùc ñònh cheá ñoä 0, hoaëc 1 cho nhoùm B hoaëc cheá ñoä 0,1,2 cho nhoùm A coøn phuï thuoäc giaù trò cuûa caùc bit D2, D5, D6 trong thanh ghi ñieàu khieån. Toùm laïi, vôùi 8255 vieäc choïn cheá ñoä naøy hay cheá ñoä kia laø phuï thuoäc vaøo ngöôøi laäp trình cho noù. Vôùi caùch choïn cheá ñoä laøm vieäc vaø chính xaùc, vi maïch 8255 coù theå ñaùp öùng moïi yeâu caàu gheùp noái raát tinh vi. Maët khaùc, neáu bieát taän duïng ñaëc tính cuûa moãi cheá ñoä thì ngöôøi thieát keá coù theå ñaït ñöôïc nhöõng keát quûa raát höõu hieäu. Sau ñaây laø nhöõng mieâu taû chi tieát veà ñaëc ñieåm cuûa moãi cheá ñoä laøm vieäc: Cheá ñoä BSR: Cheá ñoä BSR chæ lieân quan ñeán 8 bit ôû caûng C. Caùc bit naøy coù theå ñöôïc caøi ñaët hoaëc xoaù ñoäc laäp vôùi nhau baèng caùch ñöôïc ghi moät töø ñieàu khieån thích hôïp vaøo thanh ghi ñieàu khieån. Nhö phaàn trình baøy ôû treân, neáu D7=0 thì coù nhaän bieát töø ñieàu khieån BSR vaø noù khoâng laøm thay ñoåi töø ñieàu khieån ñaõ ñöôïc ghi vaøo tröôùc ñoù vôùi D7=1. Vì vaäy caùc hoaït ñoäng cuûa caùc caûng A vaø B khoâng bò aûnh höôûng ôû töø ñieàu khieån BSR. ÔÛ cheá ñoä BSR, caùc bit rieâng leõ ôû caûng C coù theå ñöôïc söû duïng vôùi öùng duïng nhö laø moät coâng taéc ñoùng môû. Nhôø tính chaát naøy, ôû cheá ñoä 1 hoaëc 2, duøng caùc bit cuûa caûng C ñeå laøm tín hieäu ñieàu khieån ngaét. Boä 8255 cho khaû naêng lôùn ñeå löïa choïn thöïc hieän gheùp noái vaøo/ra coù ngaét. Ñieàu ñoù laøm ñôn giaûn thieát keá veà phaàn cöùng. Töø ñieàu khieån khi ñöôïc vieát vaøo thanh ghi ñieàu khieån noù seõ ñaët hoaëc xoaù moät bit ôû moät thôøi ñieåm nhu baûng II.2 Choïn bit 000 001 010 011 100 101 110 111 Bit 0 Bit 1 Bit 2 Bit 3 Bit 4 Bit 5 Bit 6 Bit 7 Baûng II.2 : Töø ñieàu khieån laäp / xoaù bit 8255 Cheá ñoä I/O Hình II.3 moâ taû caáu truùc töø ñieàu khieån vaøo / ra Neáu bit D7=0, 8255 laøm vieäc ôû cheá ñoä caøi ñaët hoaëc xoaù bit Neáu bit D7=1, 8255 laøm vieäc ôû cheá ñoä vaøo/ ra. Trong cheá ñoä naøy, boä gheùp noái 8255 ñöôïc chia laøm 3 cheá ñoä cô baûn: Cheá ñoä 0 (mode 0): Moät caûng coù chöùc naêng nhö laø caûng vaøo/ra ñôn giaûn Cheá ñoä 1(mode 1): Goïi laø cheá ñoä vaøo / ra choát. Khi moät nhoùm ñang ôû cheá ñoä naøy thì caûng 8 bit cuûa noù (hoaëc caûng A hoaëc caûng B) ñöôïc duøng hoaëc laø nhaäp hoaëc laø xuaát vaø 3 chaân cuûa caûng C ñuôïc duøng cho caùc tín hieäu baét tay. Cheá ñoä 2 (mode 2) Cheá ñoä naøy chæ aùp duïng cho nhoùm A vaø ñöôïc goïi laø cheá ñoä nhaäp xuaát Bus hai chieàu. ÔÛ cheá ñoä naøy caûng A ñöôïc caøi ñaët ñeå truyeàn döõ lieäu hai chieàu baèng caùch söû duïng 5 chaân trong caùc chaân ôû caûng C laøm tín hieäu baét tay. Khi goõ vaøo Reset ôû möùc logic 1, 8255 bò Reset taát caû caùc caûng ñöôïc ñaët ôû cheá ñoä nhaäp(caû 24 ñöôøng cuûa 3 port ñeàu ôû traïng thaùi toång trôû cao). Sau khi Reset 8255 chôø nhaän töø ñieàu khieån ñeå ñöôïc khôûi ñoäng(caùc caûng ñöôïc duy trì ôû cheá ñoä nhaäp). Trong quaù trình thi haønh moät chöông trình cuûa heä thoáng baát kyø mode hoaït ñoäng naøo cuõng ñöôïc choïn baèng moät leänh ñôn giaûn neân 8255 coù theå phuïc vuï nhieàu loaïi ngoaïi vi khaùc nhau baèng caùc chöông trình con ñôn giaûn. Duø ôû mode naøo caûng A vaø B cuõng ñöôïc ñònh nghóa rieâng leû trong khi caûnng c ñöôïc chia laøm hai phaàn (moät nuõa cao vaø moät nöõa thaáp) theo yeâu caàu cuûa mode caûng A vaø B. Taát caû caùc thanh ghi xuaát bao goàm caùc flip-flop traïng thaùi ñeàu ñöôïc Reset khi thay ñoåi mode ôû cuøng moät thôøi ñieåm. Moãi nhoùm coù theå ñöôïc xaùc ñònh ôû caùc mode hoaït ñoäng khaùc nhau. Khaû naêng nhaäp/xoaù (set/reset) töøng bit Moãi bit cuûa caûng C ñeàu ñöôïc set/reset rieâng leû baèng leänh Out. Ñieàu naøy cho pheùp khaû naêng söû duïng caûng C ñeå ñieàu khieån vaø thoâng tin traïng thaùi ôû caûng A vaø B. Ñieàu khieån ngaét (Interrupt) Khi 8255 hoaït ñoäng ôû mode 1 hay mode 2, caùc tín hieäu ñieàu khieån coù khaû naêng yeâu caàu ngaét CPU. Caùc tín hieäu yeâu caàu ngaét phaùt sinh töø caûng C. Ngöôøi laäp trình coù theå cho pheùp hay caám moät ngoaïi vi ngaét CPU maø khoânng aûnh höôûng ñeán baát kyø moät ngoaïi naøo khaùc trong caáu truùc ngaét. Flip-flop INTE cuûa 8255 keát hôïp vôùi khaû naêng set/reset töøng bit cuûa caûng C seõ thöïc hieän nhieäm vuï naøy. Bit set-INTE set : cho pheùp ngaét. Bit reset-INTE reset: caám ngaét Taát caû caùc flip-flop che(mask flip-flop) ñeàu ñöôïc reset trong quaù trình choïn mode vaø reset 8255. Hoaït ñoäng cuûa caùc cheá ñoä (Modes) Cheá ñoä 0(mode 0) : Cheá ñoä xuaát nhaäp cô baûn 3 caûng A,B vaø C ñeàu laø caùc caûng xuaát nhaäp, khoâng coù tín hieäu baét tay döõ lieäu ñôn thuaàn ñöïôc ghi vaøo hoaëc ñoïc ra töø 8255 (ñoái vôùi töøng caûng rieâng leû) caûng C hoaït ñoäng nhö laø hai caûng 4 bit. Khi môùi reset taát caû caùc caûng ñeàu laø vaøo. Ñaëc ñieåm ôû moãi cheá ñoä naøy laø: Döõ lieäu ra ñöôïc choát Döõ lieäu vaøo khoâng ñöôïc choát Caùc caûng khoâng coù khaû naêng baét tay hoaëc ngaét Coù 16 khaû naêng xuaát nhaäp ñoái vôùi mode 0 (caên cöù vaøo caùc bit D0, D3, DZ4 cuûa töø ñieàu khieån). D7 D6 D5 D4 D3 D2 D1 D0 TÖØ ÑIEÀU KHIEÅN NHOÙM A Caûng C:PC4..PC7 1: VAØo 0: Ra Caûng A 1: VAØo 0: Ra Choïn cheá ñoä 00:Cheá ñoä 0 01: Cheá ñoä 1 1x : Cheá ñoä 2 NHOÙM B Caûng C:PC3..PC0 1: VAØo 0: Ra Caûng B 1: VAØo 0: Ra Choïn cheá ñoä 0:Cheá ñoä 0 1:Choïn cheá ñoä 1 HÌNH II.3 :töø ñieàu khieån cuûa 8255 D7=0: Choïn cheá ñoä I/O Cheá ñoä 1 (mode 1): Xuaát nhaäp coù ñieàu khieån: Hai caûng A vaø B coù chöùc naêng laø caûng vaøo ra 8bis chuùng coù theå ñöôïc caáu hình hoaëc laø caûng vaøo hoaëc laø caûng ra khi xuaát hoaëc nhaäp döõ lieäu ñeàu ñöôïc choát. Hay nöûa caûng c ñöôïc söû duïng ñeà ñieàu khieån thoâng tin traïng thaùi cho caûng A vaø caûng B. Nöûa cao söû duïng cho caûng A (nhoùm A), nöûa thaáp söû duïng cho caûng B (nhoùm B). Nhö vaäy moãi nhoùm goàm 1 caûng 8bis vaø 4 bis cuûa caûng C. Cheá ñoä vôùi caûng A (hoaëc B): Khôûi taïo laø vaøo : Trong cheá ñoä naøy, caûng A söû duïng 3 ñöôøng tín hieäu cao PC3, PC4 vaø PC5. Caûng B söû duïng 3 ñöôøng tín hieäu thaáp coøn laïi cuûa caûng C laø PC0 , PC1 vaø PC2. Caùc chöùc naêng cuûa tín hieäu naøy nhö sau: STB (Strobe Input) : Tín hieäu naøy hoaït ñoäng ôû möùc thaáp, noù ñöôïc taïo bôûi thieát bò ngoaïi vi ñeå thoâng baùo cho 8255 bieát byte soá lieäu nhaäp ñaõ saün saøng vaø 8255 ñaùp laïi tín hieäu STB baèng caùch taïo ra tín hieäu IBF, INTR. IBF : (Input Buffer Full) tín hieäu naøy laø moät söï baùo nhaän bôûi 8255 ñeå chæ thò raèng ngoõ vaøo choát ñaõ ñöôïc 1byte döõ lieäu. Tín hieäu naøy bò Reset khi CPU ñoïc döõ lieäu. INTR (Interrput request) : Ñaây laø tín hieäu coù theå ñöôïc söû duïng ñeå ngaét CPU, tín hieäu naøy ñöôïc taïo ra neáu STB = 1, IBF vaø INTE = 1, tín hieäu INTE bò xoùa bôûi caïnh sau cuûa tín hieäu RD. INTE (Interrput Enable) : Ñaây laø Flip-flop beân trong ñöôïc söû duïng ñeå cho pheùp hoaëc khoâng cho pheùp vieäc taïo ra tín hieäu INTR (töùc cho pheùp hoaëc khoâng cho pheùp yeâu caàu naøy). Hai Flip – flop INTEA vaø INTEB set /reset baèng caùch söû duïng cheá ñoä BSR, cuï theå laø Flip-flop INTEA ñöôïc ñieàu khieån bôûi PC4 vaø INTEB ñöôïc ñieàu khieån bôûi PC2. Toùm laïi : Quaù trình Cpu ñoïc döõ lieäu töø beân ngoaøi vaøo ôû cheá ñoä naøy nhö sau: Thieát bò vaøo ôû 8 bis soá lieäu ñeán A0… A7 (hoaëc B0 . . B7) roài phaùt sinh xung STR vôùi möùc tích cöïc thaáp ñeå naïp döõ lieäu vaøo maïch choát. Nhö vaäy laøm tín hieäu IBF coù möùc logic meàm. Boä vi xöû lyù ñoïc caûng C vaø kieåm tra tín hieäu IBF ñeå kieåm tra soá lieäu ñaõ saün saøng chöa. Neáu IBF = 1 boä vi xöû lyù ñoïc soá lieäu treân caûng A (hoaëc B) vaø xoùa côø IBF. Cheá ñoä 1 : Vôùi caûng A hoaëc B khôûi taïo laø ra: Khi caûng A vaø B ñöôïc khôûi taïo laø ra ôû töø ñieàu khieån thì chöùc naêng cuûa caùc chaân logic nhö sau : OBF (Output Buffer Full) tín hieäu ñieàu khieån naøy xuoáng thaáp CPU ghi döõ lieäu vaøo maïch choát ngoõ ra cuûa 8255. Tín hieäu naøy baùo cho tín hieäu ngoaïi vi ôû ngoõ ra laø döõ lieäu môùi ñang saün saøng ñoïc. Tín hieäu naøy leân cao 1 laàn nöõa sau khi 8255 nhaän ñöôïc tín hieäu ACK ngoaïi vi. OBF ñöôïc set bôûi caïnh leân cuûa xung WR töø CPU vaø bò reset bôûi ACK =0 do ngoaïi vi (töùc ôû möùc 0 tích cöïc). ACK (Acknowledge) : Ñaây laø tính hieäu vaøo töø ngoaïi vi, noù xuoáng möùc thaáp khi thieát bò ngoaïi vi nhaän ñöôïc döõ lieäu töø caùc caûng cuûa 8255. INTR (Interrupt Request) : Ñaây laø tín hieäu ra noù ñöôïc set bôûi caïnh leân cuûa tín hieäu ACK. Tín hieäu naøy leân 1 ôû ngoõ ra duøng yeâu caàu ngaét CPU, khi ngoaïi vò ñaõ nhaän döõ lieäu töø noù ñeå yeâu caàu byte döõ lieäu keá ñöôïc xuaát ra. Tín hieäu INTR ñöôïc set khi caáp tín hieäu OBF, ACK vaø INTE toaøn boä ôû möùc 1 vaø ñöôïc reset bôûi caïnh xuoáng cuûa tín hieäu WR. INTE (Interrupt Enable) ñaây laø moät Flip-flop beân trong ñöôïc duøng ñeå taïo tín hieäu INTR. Hai Flip-flop INTEA vaø INTEB ñöôïc ñieàu khieån bôûi caùc bis PC6, PC2 vaø ñöôïc nhaän bieát qua cheá ñoä BSR. Töông töï nhö caûng nhaäp PC4 vaø PC5 ñöôïc duøng nhö caûng vaøo ra. Toùm taét quaù trình CPU vieát döõ lieäu ra nhö sau; CPU ghi döõ lieäu ra caûng A (hoaëc B) laøm cho OBF ôõ möùc logic 0. Thieát bò kieåm tra OBF ñeå xaùc ñònh xem döõ lieäu ñaõ saün saøng chöa. Neáu ñaõ tieáp nhaän döõ lieäu, thieát bò ra traû lôøi baèng möùc 0 treân ñaàu vaøo ACK ñoàng thôøi xoùa côø OBS. Cheá ñoä 2 (mode 2) : Xuaát nhaäp döõ lieäu 2 chieàu baét tay: Cheá ñoä naøy ñöôïc söû duïng trong caùc öùng duïng nhö laø truyeàn döõ lieäu giöõa hai maùy vi tính hoaëc giao tieáp vôùi boä ñieàu khieån ñóa meàm. ÔÛ cheá ñoä naøy caûng A coù theå ñöôïc caáu hình nhö laø moät caûng hai chieàu vaø caûng B hoaëc laø ôû cheá ñoä 0 hoaëc laø ôû cheá ñoä 1. Caûng A söû duïng tín hieäu töø caûng C nhö laø caùc tín hieäu ñieàu khieån cho vieäc truyeàn döõ lieäu. Caùc ñöôøng naøy bao goàm OBF, ACK, INTR, STB, IBF. Vôùi : INTR : Möùc 1 ôû ngoõ ra naøy baùo cho CPU bieát yeâu caàu ngaét Hoaït ñoäng xuaát: OBF xuoáng möùc 0 ñeå baùo cho caùc thieát bò ngoaïi vi bieát CPU ñaõ ghi döõ lieäu ra caûng A ACK xuoáng möùc 0 ñeå baùo cho thieát bò ngoaïi vi cho pheùp boä ñeäm 3 traïng thaùi cuûa caûng A môû ñeå phaùt döõ lieäu INTE 1 (lieân quan vôùi OBF)ñöôïc kieåm soaùt bôûi set/reset cuûa PC Hoaït ñoäng nhaäp: STB: Möùc 0 ôû ngoõ vaøo naøy caøi döõ lieäu vaøo maïch, caøi ngoõ nhaäp. IBF : Möùc 1 thoâng baùo cho CPU bieát ñaõ naïp vaøo maïch caøi nhaäp. INTE 2 (lieân quan ñeán IBF)ñöôïc kieåm soaùt bôûi set/reset cuûa PC4. Ba ñöôøng tín hieäu coøn laïi PC0… PC2 coù theå ñöôïc söû duïng hoaëc laø nhö caùc ñöôøng vaøo ra ñôn giaûn hoaëc laø nhö caùc tín hieäu baét tay caûng B. Duøng caûng C ñieàu khieån caûng A,B. Trong mode 0, caûng C chuyeån soá lieäu töø 8255 ñeán ngoaïi vi hay töø ngoaïi vi ñeán 8255. Khi 8255 ñöôïc laäp trình ôû mode 1 hay mode 2, caûng C taïo ra hay nhaän veà caùc tín hieäu ñieàu khieån ngoaïi vi. Ñoïc noäi dung cuûa caûng C cho pheùp ngöôøi laäp trình kieåm tra vaø xaùc ñònh traïng thaùi cuûa thieát bò ngoaïi vi ñeå coù theå thay ñoåi chöông trình ñieàu khieån cho phuø hôïp. Caùc töø traïng thaùi caûng C töøng mode: Mode 1 : Nhaäp D7 D6 D5 D4 D3 D2 D1 D0 I/O I/O IBFA INTEA INTRA INTEB IBFB INTRB NHOÙM B NHOÙM A Mode 1 : Xuaát D7 D6 D5 D4 D3 D2 D1 D0 -OBF INTEA I/O I/O INTRA INTEB -OBF INTRB NHOÙM B NHOÙM A Mode 2 : D7 D6 D5 D4 D3 D2 D1 D0 OBFA INTE1 IBFA INTEØ INTRA NHOÙM B NHOÙM A HÌNH II.4 : Töø traïng thaùi caûng C III. KHAÛO SAÙT BOÄ NHÔÙ Boä nhôù coù theå thaûo chöông vaø xoaù ñöôïc EPROM 2764 EPROM 2764 laø boä nhôù chæ duøng moät nguoàn duy nhaát 5v, dung löôïng boä nhôù 65.536 bit vaø coù theå ñoïc xoùa deã daøng. Cuõng nhö caùc EPROM khaùc noù coù hai kieåu hoaït ñoäng laø : bình thöôøng vaø chôø (Standby). ÔÛ kieåu chôø maïch chæ tieâu taùn moät phaàn tö coâng suaát bình thöôøng, Thôøi gian truy xuaát laø 250ns vôùi toác ñoä löïa choïn vaøo khoaûng 200ns. Thôøi gian truy xuaát coù theå töông hôïp vôùi nhöõng vi xöû lyù hoaït ñoäng ôû toác ñoä cao. Moät öu ñieåm quan troïng cuûa 2764 laø kieåm soaùt rieâng leû caùc ngoõ ra. Sô ñoà chaân vaø caáu taïo 2764 ñöôïc cho ôû hình III.1 Ghi chuù : -OE ngoõ ra ñaûo cuûa OE Khoâng noái NC PGM Naïp chöông trình -CS Cho pheùp chip hoaït ñoäng Cho pheùp ra Döõ lieäu ra Ñòa chæ vaøo -OE D0-D7 A0-A12 Vcc PGM NC A8 A9 A11 OE A10 CS D7 D6 D2 Vpp A12 A7 A6 A5 A4 A3 A2 A1 A0 D0 D1 GND 2 7 10 12 14 1 3 4 5 6 8 9 11 13 28 26 25 24 23 21 20 18 16 27 22 19 17 15 D5 D4 D3 2 7 6 4 Sô ñoà khoái: D0-D7 -OE -OE/PGM LOGIC ÑIEÀU KHIEÅN ÑEÄM NGOÕ RA A12 GIAÛI MAÕ Y MAÏCH CUÛA Y HÌNH III.1: Sô ñoà chaân vaø caáu taïo cuûa EPROM 2764 A0 GIAÛI MAÕ X MA TRAÄN NHÔÙ 65.536BIT Baûng traïng thaùi hoaït ñoäng cuûa caùc chaân CHAÂN KIEÅU -CE (20) -OE (22) -PGM (27) VPP (1) VCC (28) D0 – D7 (11 – 13. 15 – 19) Ñoïc VIL VIL VCC VCC DOUT Chôø VIH VCC VCC Z cao Naïp chöông trình VIL VIL VPP VCC DIN Kieåm tra chöông trình VIL VIL VIH VPP VCC DOUT Caám naïp chöông trình VIH VPP VCC Z cao X coù theå laø VIL hoaëc VIH Baûng III.1: Baûng traïng thaùi cuûa 2764 Boä nhôø tónh SRAM 6264 : 6264 laø RAM tónh toác ñoä cao, dung löôïng boä nhôù 8192 word x 8bit Ñaëc tính 6264 : Söû duïng nguoàn 5V Thôøi gian truy xuaát nhanh, toái ña coù theå ñaït 150 ns Coâng suaát tieâu taùn ôû traïng thaùi chôø thaáp: 0.1mW Ngoõ vaøo / ra döõ lieäu chung, ngoõ ra ba traïng thaùi Ngoõ vaøo, ra töông hôïp vôùi hoï TTL Thôøi gian voøng vaø truy caäp nhö nhau. Chaân ra töông thích vôùi hoï EF ROM 64k Sô ñoà khoái tieâu chuaån 28 chaân * Baûng traïng thaùi: -WE -CS1 CS2 -OE Traïng thaùi Chaân D X H X X Khoâng choïn Z cao X X L X Z cao H L H H Khoâng xuaát Z cao H L H L Ñoïc D xuaát L L H H Ghi Dnhaäp L L H L Dnhaäp X : khoâng quan taâm Baûng III.2 Baûng traïng thaùi cuûa 2764. Sô ñoà chaân RAM 6264 Ghi chuù : -OE ngoõ ra ñaûo cuûa OE Khoâng noái NC -WE Cho pheùp ghi -CS1, CS2 Cho pheùp chip hoaït ñoäng Cho pheùp ra Döõ lieäu ra Ñòa chæ vaøo -OE D0-D7 A0-A12 Vcc WE CS A8 A9 A11 OE A10 CS1 D7 D6 D2 NC A12 A7 A6 A5 A4 A3 A2 A1 A0 D0 D1 GND 2 7 10 12 14 1 3 4 5 6 8 9 11 13 28 26 25 24 23 21 20 18 16 27 22 19 17 15 D5 D4 D3 6 2 6 4 D0-D7 Hình III.2 : Sô ñoà chaân cuûa SRAM 6264 IV KHAÛO SAÙT VI MAÏCH GIAÛI MAÕ ÑÒA CHÆ IC giaûi maõ thöôøng ñöôïc choïn cho maïch vi xöû lyù laø IC 74LS 138. Ñaây laø boä giaûi maõ ña hôïp giaûi 3 ñöôøng ra 8 ñöôøng. IC 74LS 138 goàm coù 8 ñöôøng ra töø Y0 -> Y7, 3 ñöôøng döõ lieäu vaøo laø A, B, C vaø 3 ñöôøng ñieàu khieån. Traïng thaùi hoaït ñoäng cuûa IC 74LS 138 phuï thuoäc vaøo ñieàu kieän cuûa ba chaân naøy trong ñoù hai chaân G2A vaø G2B taùc ñoäng ôû möùc thaáp (möùc 0) coøn G1 taùc ñoäng ôû möùc cao (möùc 1), IC 74LS 138 ñöôïc thieát keá ñeå hoaït ñoäng vôùi toác ñoä cao, noù thöôøng duøng cho caùc boä giaûi maõ ñòa chæ, boä nhôù vaø trong caùc heä thoáng truyeàn döõ lieäu. Sô ñoà chaân cuûa IC 74LS 138 : A B C G2A G2B G1 Y7 GND Vcc YO Y1 Y2 Y3 Y4 Y5 Y6 1 2 3 4 5 6 7 8 16 15 14 13 12 11 10 9 7 4 L S 138 HÌNH IV. 1 : Sô ñoà chaân cuûa IC 74 LS138 Baûng traïng thaùi cuaû IC74LS138 Ñieàu khieån Döõ lieäu vaøo Döõ lieäu ra G1 G2 C B A Y0 Y1 Y2 Y3 Y4 Y5 Y6 Y7 X 0 1 1 1 1 1 1 1 1 1 X 0 0 0 0 0 0 0 0 X X 0 0 0 0 1 1 1 1 X X 0 0 1 1 0 0 1 1 X X 0 1 0 1 0 1 0 1 1 1 0 1 1 1 1 1 1 1 1 1 1 0 1 1 1 1 1 1 1 1 1 1 0 1 1 1 1 1 1 1 1 1 1 0 1 1 1 1 1 1 1 1 1 1 0 1 1 1 1 1 1 1 1 1 1 0 1 1 1 1 1 1 1 1 1 1 0 1 1 1 1 1 1 1 1 1 1 0 X: Khoâng quan taâm Baûng IV.1 : baûng traïng thaùi cuûa IC 74LS138 TAØI LIEÄU THAM KHAÛO ----o0o---- ELECTRONIC DESIGN CIRCUITS AND SYSTEMS. Savant, Roden, Carpenter. 1991 – The Benjamin/Cummings Publishing Company, Jnc. MICROPROCESSOR AND IC FAMILIES. Walter H. Buchsbaum, ScD. 1993 – Tech Publication Pte Ltd. AUTOMOTIVE COMPUTER SYSTEMS AND CIRCUITS Edwardj. Ralbovsky Prenlice, Englewood Cliffs, New Gersey. TOYOTA COMPUTER CONTROLLED SYSTEMS 1992 – Toyota Motor Corporation. THIEÁT KEÁ & LAÉP RAÙP MAÙY VI TÍNH CPU Z-80. Taäp1: Thieát keá cô baûn. Hoàng Minh Nhaät, Huyønh Coâng Sanh. Nhaø Xuaát Baûn Giaùo Duïc – 1994. LAÄP TRÌNH CHO CAÙC HEÄ VI XÖÛ LYÙ 8080 – 80850 – Z80 Nhaø Xuaát Baûn Thoáng Keâ. GIAÙO TRÌNH MAÏCH SOÁ (TAÄP 2) Nguyeãn Höõu Phöông. Tröôøng ÑH, Toång Hôïp TP. HCM PHÖÔNG PHAÙP NGHIEÂN CÖÙU KHOA HOÏC Chaâu Kim Lang. Tröôøng ÑH.Sö Phaïm Kyõ Thuaät TP.HCM - 1989

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

  • docLUANVAN.DOC