Đề tài Giao tiếp bàn phím ma trận, LCD và PPI8255

MCS-51 là họ IC vi điều khiển do hãng Intel sản xuất. Các IC tiêu biểu cho họ là 8051 và 8031. Các sản phẩm MSC-51 thích hợp cho những ứng dụng điều khiển. Việc xử lý trên Byte và các toán số học ở cấu trúc dữ liệu nhỏ được thực hiện bằng nhiều chế độ truy xuất dữ liệu nhanh trên RAM nội. Chíp này có đặc điểm : 4 port , 8bit , có tốc độ, công suất thấp có lập trình được nhờ bộ nhớ Flash và dùng thuật ngữ lập trình 80C51 Được sử dụng để điều khiển công nghiệp hay tự động hoá AT89C51 cung cấp những đặc tính chuẩn như sau : 4 KB bộ nhớ chỉ đọc có thể xóa và lập trình nhanh (EPROM), 128 Byte RAM, 32 đường I/O, 2 TIMER/COUNTER 16 Bit, vecto ngắt có cấu trúc 2 mức ngắt, một Port nối tiếp bán song công, 1 mạch dao động tạo xung Clock và dao động ON-CHIP. Thêm vào đó, AT89C51 được thiết kế với logic tĩnh cho hoạt động đến mức không tần sốvà hỗ trợ hai phần mềm có thể lựa chọn những chế độ tiết kiện công suất, chế độ chờ (IDLE MODE) sẽ dừng CPU trong khi vẫn cho phép RAM, timer/counter, port nối tiếp và hệ thống ngắt tiếp tục hoạt động. Chế độ giảm công suất sẽ lưu nội dung RAM những sẽ treo bộ dao động làm khả năng hoạt động của tất cả những chức năng khác cho đến khi Reset hệ thống

docx29 trang | Chia sẻ: tuandn | Lượt xem: 3130 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Đề tài Giao tiếp bàn phím ma trận, LCD và PPI8255, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ĐẠI HỌC GIAO THÔNG VẬN TẢI THÀNH PHỐ HỒ CHÍ MINH KHOA ĐIỆN-ĐIỆN TỬ VIỄN THÔNG -----š›&š›----- BÁO CÁO Giao tiếp bàn phím ma trận, LCD và PPI8255 GVHD: Thầy Nguyễn Thanh Hiếu Danh sách nhóm 9: Nguyễn Thanh Duy Nguyễn Thị Các Linh Phan Thị Huỳnh Giao Phạm Văn Hiếu Bùi Văn Thời Nguyễn Ngọc Thương Nhận xét của Giáo Viên Hướng Dẫn & …………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………………… TP.HCM, ngày…. .Tháng 12 năm 2013 Giáo viên hướng dẫn Yêu cầu : Bàn phím ma trận nhận dữ liệu được nhập vào và xuất ra LCD Nội dung báo cáo A. PHẦN 1 Tìm hiểu về vi điều khiển 8051……………….4 Giới thiệu về PPI 8255………………………...7 Giới thiệu về bàn phím giao tiếp 4×4………...11 Giới thiệu về LCD………………………….…14 B. PHẦN 2 Sơ đồ nguyên lý………………………………21 Lưu đồ giải thuật……………………………...22 Viết chương trình cho vi điều khiển…………..23 Mạch mô phỏng protues PHẦN 1 Giới thiệu vi điều khiển 8501 GIỚI THIỆU HỌ MSC-51 MCS-51 là họ IC vi điều khiển do hãng Intel sản xuất. Các IC tiêu biểu cho họ là 8051 và 8031. Các sản phẩm MSC-51 thích hợp cho những ứng dụng điều khiển. Việc xử lý trên Byte và các toán số học ở cấu trúc dữ liệu nhỏ được thực hiện bằng nhiều chế độ truy xuất dữ liệu nhanh trên RAM nội. Chíp này có đặc điểm : 4 port , 8bit , có tốc độ, công suất thấp có lập trình được nhờ bộ nhớ Flash và dùng thuật ngữ lập trình 80C51 Được sử dụng để điều khiển công nghiệp hay tự động hoá AT89C51 cung cấp những đặc tính chuẩn như sau : 4 KB bộ nhớ chỉ đọc có thể xóa và lập trình nhanh (EPROM), 128 Byte RAM, 32 đường I/O, 2 TIMER/COUNTER 16 Bit, vecto ngắt có cấu trúc 2 mức ngắt, một Port nối tiếp bán song công, 1 mạch dao động tạo xung Clock và dao động ON-CHIP. Thêm vào đó, AT89C51 được thiết kế với logic tĩnh cho hoạt động đến mức không tần sốvà hỗ trợ hai phần mềm có thể lựa chọn những chế độ tiết kiện công suất, chế độ chờ (IDLE MODE) sẽ dừng CPU trong khi vẫn cho phép RAM, timer/counter, port nối tiếp và hệ thống ngắt tiếp tục hoạt động. Chế độ giảm công suất sẽ lưu nội dung RAM những sẽ treo bộ dao động làm khả năng hoạt động của tất cả những chức năng khác cho đến khi Reset hệ thống Bộ nhớ chương trình bên trong: 4 KB (ROM) Cấu trúc của 8051 Chức năng các chân của AT89C51 89C51 có tất cả 40 chân có chức năng như các đường xuất nhập. trong đó có 24 chân có tác dụng kép (có nghĩa 1 chân có 2 chức năng), mỗi đường có thể hoạt động như đường xuất nhập hoặc như đường điều khiển hoặc là thành phần của các bus dữ liệu và bus địa chỉ. Các port: 1/ Port 0 là port có hai chức năng ở các chân 32-39 của 89C51. trong các thiết kế cỡ nhỏ không dùng bộ nhớ mở rộng, nó có chức năng như các đường IO. Đối với các thiết kế cỡ lớn có bộ nhớ mở rộng, nó được kết hợp giữa bus địa chỉ và bus dữ liệu. 2/ Port 1 là port IO trên các chân 1-8 các chân được kí hiệu `p1.0, p1.1, p1.2, có thể dùng cho giao tiếp với các thiết bị ngoài nếu cần. port 1 không có chức năng khác, vì vậy chúng chỉ được dùng cho giao tiếp với các thiết bị bên ngoài. 3/ Port 2 là 1 port có tác dụng kép trên các chân 21-28 được dùng như các đường xuất nhập hoặc là byte cao của bus địa chỉ đối với các thiết bị dùng bộ nhớ mở rộng. 4/ Port 3 là port có tác dụng kép trên các chân 10-17 các chân, các chân của port này có nhiều chức năng, các công dụng chuyển đổi có liên hệ với các đặc tính đặc biệt của 89C51 như bảng sau  Các ngõ ra tín hiệu điều khiển: a/Ngõ tín hiệu PSEN: Psen là tín hiệu ngõ ra ở chân 29 có tác dụng cho phép đọc bộ nhớ chương trình mở rộng thường nói đến chân OE của Eprom cho phép đọc các byte mở rộng Psen ở mức thấp trong thời gian Microcontroller 8951 lấy lệnh. Các mã lệnh của chương trình đọc từ Eprom qua bus dữ liệu và được chốt từ thanh ghi bên trong 8951 để giải mã lệnh. Khi 8951 thi hành chương trình trong Rom nội Psen sẽ ở mức logic1. b/ Ngõ tín hiệu điều khiển ALE ALE (Address Latch Enable): cho phép chốt địa chỉ, chân số 30. - Chức năng: • Là tín hiệu cho phép chốt địa chỉ để thực hiện việc giải đa hợp cho bus địa chỉ byte thấp và bus dữ liệu đa hợp (AD0 – AD7). • Là tín hiệu xuất, tích cực mức cao. ALE = 0 →trong thời gian bus AD0 - AD7 đóng vai trò là bus D0 - D7. ALE = 1 →trong thời gian bus AD0 - AD7 đóng vai trò là bus A0 - A7. - Khi lập trình cho ROM trong chip thì chân ALE đóng vai trò là ngõ vào của xung lập trình. c/Chân EA\: - EA (External Access): truy xuất ngoài, chân số 31. - Chức năng: • Là tín hiệu cho phép truy xuất (sử dụng) bộ nhớ chương trình (ROM) ngoài. • Là tín hiệu nhập, tích cực mức thấp. EA\ = 0 →Chip 8051 sử dụng chương trình của ROM ngoài. EA\ = 1 →Chip 8051 sử dụng chương trình của ROM trong. - Khi lập trình cho ROM trong chip thì chân EA đóng vai trò là ngõ vào của điện áp lập trình d/Chân RST Ngõ vào RST ở chân 9 là ngõ vào reset của 89C51, khi ngõ vào tín hiệu này đưa lên cao ít nhất là 2 chu kỳ máy, các thanh ghi bên trong đươc nạp những giá trị thích hợp để khởi động hệ thống, khi cấp mạch điện tự động reset. GIỚI THIỆU VỀ PPI 8255 Giới thiệu về PPI8255 - PPI: programmable peripheral interface – giao tiếp ngoại vi lập trình được - Dùng 8255 để mở rộng I/O. từng port có thể lập trình là input hay output một cách linh hoạt bằng phần mềm (so sánh với việc thiết kế I/O port dùng 74LS244 và 74LS373 ở chương 1 → input hay output được thiết kế “cứng”,cố định). - Các chân: D0÷D7: bus dữ liệu 2 chiều PA0÷PA7: port A. PB0÷PB7: port B. PC0÷PC7: port C. /RD: Read. (Nối với /RD (P3.7) của 8051.) /WR: Write. (Nối với /WR của 8051.) RESET: khởi động lại 8255. (thường được nối với mạch reset của 8051 hoặc GND. /CS: chọn chíp.) A0, A1: địa chỉ port. (Nối với bus địa chỉ.) - hoạt động I/O cơ bản của 3 mode: o Mode 0: I/O đơn giản o Mode 1: I/O có bắt tay o Mode 2: bus 2 chiều Sơ đồ ghép nối PPI 8255 với IC 8051 Giao tiếp PPI8255 với LCD Giới thiệu về bàn phím giao tiếp 4×4. Có 2 cách xác định phím nhấn bằng phần cứng và phần mềm: Ở đây ta xác định mã các phím nhấn bằng phần mềm: - Khi nhấn phím thì hàng và cột tương ứng sẽ được nối với nhau. - Để xác định được phím nhấn ta quét bàn phím: ta thực hiện quét từng hàng, đầu tiên cho hàng 1 ở mức logic 0, các hàng và cột khác ở mức logic 1, ta đọc giá trị hàng và cột thông qua Port 1. - Nếu 1 phím nào đó được nhấn: hàng và cột tương ướng nối với nhau và ở mức logic 0, tuân theo quy tắc sau ta xác định mã phím: +Ta có số hàng là 4: đếm theo thứ tự: hi = 1(ứng với H4), 2( ứng với H3), 3(ứng với H2), 4(ứng với H1) ci = 0 (ứng với C1), 4(ứng với C2), 8(ứng với C3), 12(ứng với C4). Ta có thể thấy các cột hơn kém nhau 4 đơn vị Ma phimi = (4-hi)+ci - Ta thực hiện quét 4 lần, lần lượt 4 hàng - Thuật toán quét bàn phím như sau: Chương trình quét bàn phím được viết như sau: SCAN_KEY: MOV R1,#0FEH MOV R6,#4 SCAN: MOV P1,R1 MOV A,P1 ANL A,#0F0H CJNE A,#0F0H,GET_CODE XCH A,R1 RL A XCH A,R1 DJNZ R6,SCAN CLR F0 LJMP EXIT GET_CODE: PUSH ACC MOV A,#4 CLR C SUBB A,R6 MOV R5,A POP ACC SWAP A MOV R4,#4 LOOP2: RRC A JNC SET_FLAG XCH A,R5 ADD A,#4 XCH A,R5 DJNZ R4,LOOP2 SET_FLAG: SETB F0 MOV A,R5 EXIT: MOV R1,#00H MOV R6,#00H RET VI. Giao tiếp với LCD - Trong nhöõng naêm gaàn ñaây, LCD ñaõ ñöôïc söû duïng roäng raõi thay theá cho LED 7 ñoaïn hay caùc loaïi LED nhieàu ñoaïn khaùc. Ñoù laø do giaù thaønh ngaøy caøng giaûm cuûa caùc loaïi LCD; khaû naêng hieån thò ña daïng bao goàm caû chöõ soá, chöõ caùi vaø caû caùc kyù töï graphic; vieäc tích hôïp caùc boä ñieàu khieån LCD vaøo cuøng moät module, giuùp cho CPU khoûi phaûi ñieàu khieån lieân tuïc vieäc hieån thò döõ lieäu; vaø söï deã daøng trong vieäc laäp trình hieån thò treân LCD. Ñeå chuaån hoùa vieäc ñieàu khieån caùc loaïi LCD khaùc nhau, caùc haõng saûn xuaát LCD thöôøng söû duïng moät loaïi IC ñieàu khieån laø HD44780 cuûa haõng Hitachi. Ñieàu naøy giuùp cho vieäc ñieàu khieån LCD ñöôïc deã daøng vaø chuaån hoùa. Moâ taû caùc chaân cuûa LCD Chaân soá Teân Möùc logic Chöùc naêng 1 VSS GND GND 2 VDD +5V Cöïc + cuûa nguoàn 3 Vo 0 . . . +5 V Ñieàu khieån ñoä töông phaûn 4 RS H/L Choïn thanh ghi L: Thanh ghi leänh; H: Thanh ghi döõ lieäu 5 R/W H/L Ñoïc/Ghi L: Ñoïc; H: Ghi 6 E H/L Cho pheùp 7-14 DB0 - DB7 H/L Caùc bit döõ lieäu ƒ VSS, VDD: caùc chaân nguoàn vaø GND cuûa LCD ƒ Vo: chaân ñieàu khieån ñoä töông phaûn cuûa maøn hình hieån thò. RS (register select): Coù 2 thanh ghi raát quan troïng trong LCD laø thanh ghi leänh vaø thanh ghi döõ lieäu. Neáu RSôû möùc thaáp, thanh ghi leänh seõ ñöôïc choïn, cho pheùp ngöôøi söû duïng gôûi caùc meänh leänh ñeán LCD chaúng haïn nhö xoùa maøn hình hieån thò hoaëc chuyeån con troû veà ñaàu doøng, … Neáu RS ôû möùccao, thanh ghi döõ lieäu seõ ñöôïc choïn, cho pheùp ngöôøi söû duïng gôûi caùc döõ lieäu kyù töï ñeå hieån thò leân LCD. R/W (read/write): Cho pheùp ghi caùc leänh hay döõ lieäu kyù töï leân LCD hoaëc ñoïc caùc döõ lieäu kyù töï hay thoâng tin traïng thaùi töø caùc thanh ghi cuûa noù. E (enable): Duøng ñeå choát caùc leänh hay döõ lieäu giöõa module LCD vaø caùcñöôøng döõ lieäu cuûa noù. Khi ghi döõ lieäu ra maøn hình hieån thò LCD, döõ lieäu seõ ñöôïc choát khi coù xung caïnh xuoáng ôû chaân naøy. Xung naøy phaûi coù ñoä roäng toái thieåu laø 450ns. Tuy nhieân, khi ñoïc döõ lieäu ra töø LCD, sau khi coù xung caïnh leân ôû chaân naøy thì döõ lieäu ñoïc ñöôïc môùi laø döõ lieäu coù yù nghóa. DB0 – DB7: 8 ñöôøng bus döõ lieäu (töø D0 ñeán D7). Döõ lieäu coù theå ñöôïc chuyeån ñeán vaø laáy ra khoûi boä hieån thò LCD theo daïng moät byte 8 bit hay daïng hai nöûa byte 4 bit. Trong tröôøng hôïp sau chæ coù 4 ñöôøng döõ lieäu cao ñöôïc söû duïng (töø D4 ñeán D7). Cheá ñoä 4 bit naøy thuaän tieän khi söû duïng vi xöû lyù vì caàn coù ít ñöôøng I/O hôn. *Baûng kyù töï chuaån cuûa LCD (ROM CODE A00) - Chöông trình con kieåm tra traïng thaùi baän cuûa LCD WAIT_LCD: CLR E ; E = 0 ñeå taïo caïnh leân, baét ñaàu leänh LCD CLR RS ;choïn cheá ñoä gôûi leänh SETB RW ;choïn cheá ñoä ñoïc döõ lieäu MOV DATA,#0FFH ;choïn DATA laø input SETB E ;taïo caïnh leân MOV A,DATA ;ñoïc giaù trò traû veà JB ACC.7,WAIT_LCD ;neáu DB7 = 1, LCD vaãn baän CLR RW ;taét RW cho caùc leänh LCD keá RET Khôûi ñoäng LCD - Tröôùc khi coù theå söû duïng LCD thì ta phaûi khôûi ñoäng vaø ñaët caáu hình cho noù. - Toaøn boä maõ khôûi ñoäng nhö sau: INIT_LCD: SETB E ;E = 1 ñeå taïo caïnh xuoáng, baét ñaàu leänh LCD CLR RS ;choïn cheá ñoä gôûi leänh MOV DATA,#38H ;choïn bus 8 bit, font kyù töï 5x8, 2 haøng CLR E ;taïo caïnh xuoáng treân E LCALL WAIT_LCD ;chôø ñeán khi LCD heát baän SETB E ;E = 1 ñeå taïo caïnh xuoáng, baét ñaàu leänh CLR RS ;choïn cheá ñoä gôûi leänh MOV DATA,#0EH ;LCD on, cursor off CLR E ;taïo caïnh xuoáng treân E LCALL WAIT_LCD ;chôø ñeán khi LCD heát baän SETB E ;E = 1 ñeå taïo caïnh xuoáng, baét ñaàu leänh CLR RS ;choïn cheá ñoä gôûi leänh MOV DATA,#06H ;vò trí cursor töï ñoäng dòch sang phaûi khi coù CLR E ;taïo caïnh xuoáng treân E LCALL WAIT_LCD ;chôø ñeán khi LCD heát baän RET Xoùa maøn hình hieån thò LCD CLR_LCD: SETB E CLR RS MOV DATA,#01H CLR E LCALL WAIT_LCD RET Ghi ra maøn hình WRITE_TEXT: SETB E SETB RS MOV DATA,A CLR E LCALL WAIT_LCD RET Phần 2: thực hành Sơ đồ nguyên lý Lưu đồ giải thuật Start Chương trình Delay KKhai báo quét phím Thiết lập các lệnh khởi tạo cho LCD Khởi tạo các port của PPI 8255 Khởi tạo các port vào ra của 8051 Nhấn phím Chương trình cho phím Chương trình chính Xử lý dữ liệu Hiển thị lên LCD RESET END Chương trình cho LCD Giao tiếp PPI 8255 với LCD Giao tiếp PPI 8255 với 8051 Chương trình cho vi điều khiển-code asm ORG 0H RS EQU P1.0 RW EQU P1.1 E EQU P1.2 DB0 EQU P0.0 DB1 EQU P0.1 DB2 EQU P0.2 DB3 EQU P0.3 DB4 EQU P0.4 DB5 EQU P0.5 DB6 EQU P0.6 DB7 EQU P0.7 H1 EQU P2.0 H2 EQU P2.1 H3 EQU P2.2 H4 EQU P2.3 C1 EQU P2.4 C2 EQU P2.5 C3 EQU P2.6 C4 EQU P2.7 DATA_LCD EQU P0 MAIN: mov DPTR,#string1 MOV R3,#0H MOV R2,#0H ACALL CAUHINH_PPI8255 LCALL KHOITAO_LCD LCALL XUAT_CHUOI MOV R7,#30 LAP: ACALL DELAY DJNZ R7,LAP ACALL KHOITAO_LCD MOV R1,#0H LOOP: ACALL QUETPHIM SJMP LOOP CAUHINH_PPI8255: SETB P3.4 SETB P3.5 MOV DATA_LCD,#83H SETB P3.6 CLR P3.7 SETB P3.7 RET DELAY: MOV TMOD,#01H MOV TH0,#HIGH(-50000) MOV TL0,#LOW (-50000) SETB TR0 CLR TF0 JNB TF0,$ CLR TF0 CLR TR0 RET XUAT_CHUOI: MOV R0,#0H L1: MOV A,R0 MOVC A,@A+DPTR CJNE A,#0H,CONT_WRITE SJMP END_WRITE CONT_WRITE: CJNE R0,#0FH,TIEP MOV R2,#0C0H ACALL XUAT_LENH TIEP: INC R0 MOV R3,A ACALL XUAT_DATA SJMP L1 END_WRITE: RET KHOITAO_LCD: MOV R2,#38H ;BUS 8 BIT ,FONT 5X8 ,2 HANG ACALL XUAT_LENH MOV R2,#0EH ;LCD BAT CURSOR TAT ACALL XUAT_LENH MOV R2,#06H ; VI TRI CURSOR TU DONG DICH PHAI KHI CÓ KI TU CHUYEN VAO ACALL XUAT_LENH MOV R2,#80H ; CON TRO O VI TRI HANG TREN NGOAI CUNG BEN TRAI ACALL XUAT_LENH MOV R2,#01H ;XOA MAN HINH ACALL XUAT_LENH RET XUAT_LENH: SETB E CLR RS CLR RW CLR P3.4 CLR P3.5 MOV DATA_LCD,R2 SETB P3.6 CLR P3.7 SETB P3.7 CLR E LCALL DELAY RET XUAT_DATA: SETB E SETB RS CLR RW CLR P3.4 CLR P3.5 CJNE R1,#0FH,XUAT MOV R2,#0C0H ACALL XUAT_LENH XUAT: INC R1 MOV DATA_LCD,R3 SETB P3.6 CLR P3.7 SETB P3.7 CLR E LCALL DELAY RET CHONGRUNG: MOV R7,#2 LAP1: MOV R6,#250 LAP2: MOV R5,#250 DJNZ R5,$ DJNZ R6,LAP2 DJNZ R7,LAP1 RET QUETPHIM: LJMP QUET HIEN1: ACALL CHONGRUNG MOV R3,#31H ACALL XUAT_DATA SETB H1 LJMP THOAT HIEN2: ACALL CHONGRUNG MOV R3,#32H ACALL XUAT_DATA SETB H1 LJMP THOAT HIEN3: ACALL CHONGRUNG MOV R3,#33H ACALL XUAT_DATA SETB H1 LJMP THOAT CHU_A: ACALL CHONGRUNG MOV R3,#41H ACALL XUAT_DATA SETB H1 LJMP THOAT HIEN4: ACALL CHONGRUNG MOV R3,#34H ACALL XUAT_DATA SETB H2 LJMP THOAT HIEN5: ACALL CHONGRUNG MOV R3,#35H ACALL XUAT_DATA SETB H2 LJMP THOAT HIEN6: ACALL CHONGRUNG MOV R3,#36H ACALL XUAT_DATA SETB H2 LJMP THOAT CHU_B: ACALL CHONGRUNG MOV R3,#42H ACALL XUAT_DATA SETB H2 LJMP THOAT QUET: CLR H1 JNB C1,HIEN1 JNB C2,HIEN2 JNB C3,HIEN3 JNB C4,CHU_A SETB H1 CLR H2 JNB C1,HIEN4 JNB C2,HIEN5 JNB C3,HIEN6 JNB C4,CHU_B SETB H2 CLR H3 JNB C1,HIEN7 JNB C2,HIEN8 JNB C3,HIEN9 JNB C4,CHU_C SETB H3 CLR H4 JNB C1,HIEN_SAO JNB C2,HIEN0 JNB C3,HIEN_THANG JNB C4,T SETB H4 SJMP QUET HIEN7: ACALL CHONGRUNG MOV R3,#37H ACALL XUAT_DATA SETB H3 LJMP THOAT HIEN8: ACALL CHONGRUNG MOV R3,#38H ACALL XUAT_DATA SETB H3 LJMP THOAT HIEN9: ACALL CHONGRUNG MOV R3,#39H ACALL XUAT_DATA SETB H3 LJMP THOAT CHU_C: ACALL CHONGRUNG MOV R3,#43H ACALL XUAT_DATA SETB H3 LJMP THOAT HIEN_SAO: ACALL CHONGRUNG MOV R3,#2AH ACALL XUAT_DATA SETB H4 LJMP THOAT HIEN0: ACALL CHONGRUNG MOV R3,#30H ACALL XUAT_DATA SETB H4 LJMP THOAT HIEN_THANG: ACALL CHONGRUNG MOV R3,#23H ACALL XUAT_DATA SETB H4 LJMP THOAT CLEAR: ACALL CHONGRUNG ACALL KHOITAO_LCD MOV R1,#0H SETB H4 LJMP THOAT THOAT: RET STRING1: DB ' GROUP 9 !!! ' DB 0 EXIT: END ˜ END ™