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
29 trang |
Chia sẻ: tuandn | Lượt xem: 3130 | Lượt tải: 1
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