Uploaded by buiconghoc3010

tailieuxanh dkndo 5813

advertisement
BOÄ GIAÙO DUÏC VAØ ÑAØO TAÏO
TRÖÔØNG ÑAÏI HOÏC DAÂN LAÄP KYÕ THUAÄT COÂNG NGHEÄ
KHOA : ÑIEÄN TÖÛ – VIEÃN THOÂNG
ÑEÀ TAØI :
ÑOÀ AÙN MOÂN HOÏC
THIEÁT KEÁ-THI COÂNG MAÏCH ÑIEÀU KHIEÅN NHIEÄT ÑOÄ
Sinh vieân thöïc hieän : Nguyeãn Quang Hieáu.
Lôùp
: 97ÑT04
MSSV 97ÑT890
1
LÔØI NOÙI ÑAÀU
Kyõ thuaät vi söû lyù hieän nay raát phaùt trieån , noù ñöôïc öùng duïng vaøo raát nhieàu lónh
vöïc nhö saûn xuaát coâng nghieäp ,töï ñoäng hoaù vaø coøn nhieàu lónh vöïc khaùc nöõa . So vôùi kyõ
thuaätsoá thì kyõ thuaät vi söû lyù nhoû goïn hôn raát nhieàu do noù ñöôïc tích hôïp laïi vaø ñöôïc laäp
trình ñeå ñieàu khieån .
Vôùi tính öu vieät cuûa vi xöû lyù thì trong phaïm vi ñoà aùn nhoû naøy em chæ tieán haønh
vieäc duøng vi xöû lyù ñeå ño vaø ñieàu khieån nhieät ñoä , ñaây chæ laø moät öùng duïng nhoû cuûa vi
xöû lyù trong caùc öùng duïng cuûa noù .
Nhöõng kieán thöùc hoïc ñöôïc coäng theâm hieåu bieát töø caùc taøi lieäu tham khaûo , tuy
coù theå hoaøn thaønh cuoán ñoà aùn naøy nhöng khoâng theå traùnh khoûi nhieàu thieáu soùt mong
thaày giaùo khi xem cuoán ñoà aùn naøy coù theå thoâng caûm.
Ñeå hoaøn thaønh cuoán ñoà aùn naøy em ñaõ nhaän ñöôïc söï chæ baûo taän tình cuûa thaày
giaùo höôùng daãn vaø söï giuùp ñôõ nhieät tình cuûa baïn beø . Cuoái cuøng em xin caûm ôn thaày
höôùng daãn Phaïm Huøng Kim Khaùnh ,thaày giaùo moân vi xöû lyù vaø caùc thaày coâ giaùo ñaõ
daïy cho em nhöõng kieán thöùc cô baûn ñeå em coù theå hoaøn thaønh cuoán ñoà aùn naøy.
Sinh vieân thöïc hieän
Nguyeãn Quang Hieáu.
2
PHAÀN A : CÔ SÔÛ LYÙ THUYEÁT
Chöông 1:
GIÔÙI THIEÄU CHUNG VEÀ BOÄ VI ÑIEÀU KHIEÅN
I.GIÔÙI THIEÄU :
Boä vi ñieàu khieån vieát taét laø Micro-controller, laø maïch tích hôïp treân moät
chip coù theå laäp trình ñöôïc, duøng ñeå ñieàu khieån hoaït ñoäng cuûa moät heä thoáng.
Theo caùc taäp leänh cuûa ngöôøi laäp trình, boä vi ñieàu khieån tieán haønh ñoïc, löu tröõ
thoâng tin, xöû lyù thoâng tin, ño thôøi gian vaø tieán haønh ñoùng môû moät cô caáu naøo
ñoù.
Trong caùc thieáh bò ñieän vaø ñieän vaø ñieän töû daân duïng, caùc boä vi ñieàu khieån,
ñieàu khieån hoaït ñoäng cuûa TV, maùy giaët, ñaàu ñoïc laser, ñieän thoïai, loø vi-ba …
Trong heä thoáng saûn xuaát töï ñoäng, boä vi ñieàu khieån ñöôïc söû duïng trong Robot,
daây chuyeàn töï ñoäng. Caùc heä thoáng caøng “thoâng minh” thì vai troø cuûa heä vi ñieàu
khieån caøng quan troïng.
II.KHAÛO SAÙT BOÄ VI ÑIEÀU KHIEÅN 8051 VAØ 8031:
IC vi ñieàu khieån 8051/8031 thuoäc hoï MCS51 coù caùc ñaët ñieåm sau :
- 4kbyte ROM (ñöôïc laäp trình bôûi nhaø saûn xuaát chæ coù ôû 8051)
- 128 buùyt RAM
- 4port I/0 8bit
- Hai boä ñònh thôøi 16bit
- Giao tieáp noái tieáp
- 64KB khoâng gian boä nhôù chöông trình môû roäng
- 64 KB khoâng gian boä nhôù döõ lieäu môû roäng
- moät boä xöû lí luaän lí (thao taùc treân caùc bit ñôn)
- 210 bit ñöôïc ñòa chæ hoùa
- boä nhaân / chia 4µs
3
1.CAÁU TRUÙC BEÂN TRONG CUÛA 8051 / 8031 :
INT\*1
INT\*0
TIMER2
TIMER1
PORT noái tieàp
Ñieàu
khieån ngaét
Caùc ùthanh
ghi khaùc
128 byte
Ram
Rom
4K-8051
OK-8031
Timer1
Timer2
CPU
Taïo
dao
Ñieàu
khieån bus
EA\ RST PSEN ALE
I\O
P0 P1
Caùc port
P2
Port
noái tieáp
P3
TXD* RXD*
Hình 2.1 : Sô Ñoà Khoái 8051 / 8031
4
T1*
T2*
Phaàn chính cuûa vi ñieàu khieån 8051 / 8031 laø boä xöû lí trung taâm (CPU:
central processing unit ) bao goàm :
- Thanh ghi tích luõy A
- Thanh ghi tích luõy phuï B, duøng cho pheùp nhaân vaø pheùp chia
- Ñôn vò logic hoïc (ALU : Arithmetic Logical Unit )
- Töø traïng thaùi chöông trình (PSW : Prorgam Status Word)
- Boán baêng thanh ghi
- Con troû ngaên xeáp
- Ngoaøi ra coøn coù boä nhôù chöông trình, boä giaûi maõ leänh, boä ñieàu khieån
thôøi gian vaø logic.
Ñôn vò xöû lí trung taâm nhaän tröïc tieáp xung töø boä giao ñoäng, ngoaøi ra coøn
coù khaû naêng ñöa moät tín hieäu giöõ nhòp töø beân ngoaøi.
Chöông trình ñang chaïy coù theå cho döøng laïi nhôø moät khoái ñieàu khieån ngaét
ôû beân trong. Caùc nguoàn ngaét coù theå laø : caùc bieán coá ôû beân ngoaøi , söï traøn boä
ñeám ñònh thôøi hoaëc cuõng coù theå laø giao dieän noái tieáp.
Hai boä ñònh thôøi 16 bit hoaït ñoäng nhö moät boä ñeám.
Caùc coång (port0, port1, port2, port3 ). Söû duïng vaøo muïc ñích ñieàu khieån.
Ôû coång 3 coù theâm caùc ñöôøng daãn ñieàu khieån duøng ñeå trao ñoåi vôùi moät boä
nhôù beân ngoaøi, hoaëc ñeå ñaàu noái giao dieän noái tieáp, cuõng nhö caùc ñöôøng ngaét
daãn beân ngoaøi.
Giao dieän noái tieáp coù chöùa moät boä truyeàn vaø moät boä nhaän khoâng ñoàng boä,
laøm vieäc ñoäc laäp vôùi nhau. Toác ñoä truyeàn qu oång noái tieáp coù theå ñaët trong vaûy
roäng vaø ñöôïc aán ñònh baèng moät boä ñònh thôøi.
Trong vi ñieàu khieån 8051 / 8031 coù hai thaønh phaàn quan troïng khaùc ñoù laø
boä nhôù vaø caùc thanh ghi :
Boä nhôù goàm coù boä nhôù Ram vaø boä nhôù Rom (chæ coù ôû 8031) duøng ñeå löu
tröõ döõ lieäu vaø maõ leänh.
Caùc thanh ghi söû duïng ñeå löu tröõ thoâng tin trong quaù trình xöû lí. Khi CPU
laøm vieäc noù laøm thay ñoåi noäi dung cuû aùc thanh ghi.
5
2.CHÖÙC NAÊNG CAÙC CHAÂN VI ÑIEÀU KHIEÅN :
30p
40
19
XTAL1
12MHz
30p
18
29
30
31
9
RD\
WR\
T1
T0
INT1
INT0
TXD
RXD
Vcc
XTAL2
PSEN\
ALE
EA\
RET
17
16
15
14
13
12
11
10
Vss
Po.7
Po.6
Po.5
Po.4
Po.3
Po.2
Po.1
Po.0
P2.7
P2.6
P2.5
P2.4
P2.3
P2.2
P2.1
P2.0
P1.7
P1.6
P1.5
P1.4
P1.3
P1.2
P1.1
P1.0
32
33
34
35
36
37
38
39
8
7
6
5
4
3
2
1
28
27
26
25
24
23
22
21
AD7
AD6
AD5
AD4
AD3
AD2
AD1
AD0
A15
A14
A13
A12
A11
A10
A9
A8
20
Hình 2.2 : Sô Ñoà Chaân 8051
6
a.port0 : laø port coù 2 chöùc naêng ôû treân chaân töø 32 ñeán 39 trong caùc thieát keá
côõ nhoû
( khoâng duøng boä nhôù môû roäng ) coù hai chöùc naêng nhö caùc ñöôøng I/O. Ñoái vôùi
caùc thieát keá côõ lôùn ( vôùi boä nhôù môû roäng ) noù ñöôïc keát hôïp keânh giöõ a caùc
bus)
b.port1 : port1 laø moät port I/O treân caùc chaân 1-8. Caùc chaân ñöôïc kyù hieäu
P1.0, P1.1, P1.2 … coù theå duøng cho caùc thieát bò ngoaøi neáu caàn. Port1 khoâng coù
chöùc naêng khaùc, vì vaäy chuùng ta chæ ñöôïc duøng trong giao tieáp vôùi caùc thieát bò
ngoaøi.
c.port2 : port2 laø moät port coâng duïng keùp treân caùc chaân 21 – 28 ñöôïc duøng
nhö caùc ñöôøng xuaát nhaäp hoaëc laø byte cao cuûa bus ñòa chæ ñoái vôùi caùc thieát keá
duøng boä nhôù môû roäng.
d.Port3 : port3 laø moät port coâng duïng keùp treân caùc chaân 10 – 17. Caùc chaân
cuûa port naøy coù nhieàu chöùc naêng, caùc coâng duïng chuyeån ñoåi coù lieân heä vôùi caùc
ñaëc tín ñaëc bieät cuûa 8051 / 8031 nhö ôû baûng sau :
Bit
Teân
Chöùc naêng chuyeån ñoåi
P3.0
P3.1
P3.2
P3.3
P3.4
P3.5
P3.6
P3.7
RXD
TXD
INTO
INT1
TO
T1
WR
RD
Döõ lieäu nhaän cho port noái tieáp
Döõ lieäu phaùt cho port noái tieáp
Ngaét 0 beân ngoaøi
Ngaét 1 beân ngoaøi
Ngoõ vaøo cuûa timer/counter 0
Ngoõ vaøo cuûa timer/counter 1
Xung ghi boä nhôù döõ lieäu ngoaøi
Xung ñoïc boä nhôù döõ lieäu ngoaøi
Baûng 2.1 : Chöùc naêng cuûa caùc chaân treân port3
e.PSEN (Program Store Enable ) : 8051 / 8031 coù 4 tín hieäu ñieàu khieån
7
PSEN laø tín hieäu ra treân chaân 29. Noù laø tín hieäu ñieàu khieån ñeå cho pheùp
boä nhôù chöông trình môû roäng vaø thöôøng ñöôïc noái ñeán chaân OE (Output Enable)
cuûa moät EPROM ñeå cho pheùp ñoïc caùc bytes maõ leänh.
PSEN seõ ôû möùc thaáp trong thôøi gian laáy leänh. Caùc maõ nhò phaân cuûa
chöông trình ñöôïc ñoïc töø EPROM qua bus vaø ñöôïc choát vaøo thanh ghi leänh cuûa
8051 ñeå giaûi maõ leänh. Khi thi haønh chöông trình trong ROM noäi (8051) PSEN
seõ ôû möùc thuï ñoäng (möùc cao).
f.ALE (Address Latch Enable ) :
tín hieäu ra ALE treân chaân 30 töông hôïp vôùi caùc thieát bò laøm vieäc vôùi caùc
xöû lí 8585, 8088, 8086, 8051 duøng ALE moät caùch töông töï cho laøm vieäc giaûi caùc
keânh caùc bus ñòa chæ vaø döõ lieäu khi port 0 ñöôïc duøng trong cheá ñoä chuyeån ñoåi
cuûa noù : vöøa laø bus döõ lieäu vöøa laø buùyt thaáp cuûa ñòa chæ, ALE laø tín hieäu ñeå choát
ñòa chæ vaøo moät thanh ghi beân ngoaøi trong nöõa ñaàu cuûa chu kyø boä nhôù. Sau ñoù,
caùc ñöôøng port 0 duøng ñeå xuaát hoaëc nhaäp döõ lieäu trong nöõa sau chu kyø cuûa boä
nhôù.
Caùc xung tín hieäu ALE coù toác ñoä baèng 1/6 laàn taàn soá dao ñoäng treân chip
vaø coù theå ñöôïc duøng laø nguoàn xung nhòp cho caùc heä thoáng. Neáu xung treân 8051
laø 12MHz thì ALE coù taàn soá 2MHz. Chæ ngoaïi tröø khi thi haønh leänh MOVX,
moät xung ALE seõ bò maát. Chaân naøy cuõng ñöôïc laøm ngoõ vaøo cho xung laäp trình
cho EPROM trong 8051.
g.EA (External Access) :
Tín hieäu vaøo EA treân chaân 31 thöôøng ñöôïc maéc leân möùc cao (+5V) hoaëc
möùc thaáp (GND). Neáu ôû möùc cao, 8051 thi haønh chöông trình töø ROM noäi trong
khoaûng ñòa chæ thaáp (4K). Neáu ôû möùc thaáp, chöông trình chæ ñöôïc thi haønh töø
boä nhôù môû roäng. Khi duøng 8031, EA luoân ñöôïc noái möùc thaáp vì khoâng coù boä
nhôù chöông trình treân chip. Neáu EA ñöôïc noái möùc thaáp boä nhôù beân trong
chöông trình 8051 seõ bò caám vaø chöông trình thi haønh töø EPROM môû roäng.
Ngöôøi ta coøn duøng chaân EA laøm chaân caáp ñieän aùp 21V khi laäp trình cho
EPROM trong 8051.
h.SRT (Reset) :
Ngoõ vaøo RST treân chaân 9 laø ngoõ reset cuûa 8051. Khi tín hieäu naøy ñöôïc
ñöa leân muùc cao (trong ít nhaát 2 chu kyø maùy ), caùc thanh ghi trong 8051 ñöôïc
taûi nhöõng giaù trò thích hôïp ñeå khôûi ñoäng heä thoáng.
i.Caùc ngoõ vaøo boä dao ñoäng treân chip :
Nhö ñaõ thaáy trong caùc hình treân , 8051 coù moät boä dao ñoäng treân chip. Noù
thöôøng ñöôïc noái vôùi thaïch anh giöõa hai chaân 18 vaø 19. Caùc tuï giöõa cuõng caàn
thieát nhö ñaõ veõ. Taàn soá thaïch anh thoâng thöôøng laø 12MHz.
8
j.Caùc chaân nguoàn :
8051 vaän haønh vôùi nguoàn ñôn +5V. Vcc ñöôïc noái vaøo chaân 40 vaø Vss
(GND) ñöôïc noái vaøo chaân 20.
3_ Caùc thanh ghi ñaëc bieät :
a. Caùc thanh ghi port xuaát nhaäp:
Caùc port cuûa 8051/8031 bao goàm Port 0 ôû ñòa chæ 80H, Port 1 ôû ñòa chæ 90
H, Port 2 ôû ñòa chæ A0H vaø Port 3 ôû ñòa chæ B0H. Taát caû caùc Port ñeàu ñöôïc ñòa
chæ hoùa töøng bit. Ñieàu ñoù cung caáp moät khaû naêng giao tieáp thuaän lôïi.
b. Caùc thanh ghi timer:
8051/8031 chöùa 2 boä ñònh thôøi ñeám 16 bit ñöôïc duøng trong vieäc ñònh thôøi
hoaëc ñeám söï kieän. Timer 0 ôû ñòa chæ 8AH (TL0:byte thaáp) vaø 8CH (TH0:byte
cao).Timer 1 ôû ñòa chæ 8BH (TL1:byte thaáp) vaø 8DH (TH1: byte cao). vieäc vaän
haønh timer ñöôïc set bôûi thanh ghi Timer Mode (TMOD) ôû ñòa chæ 89H vaø thanh
ghi ñieàu khieån timer (TCON) ôû ñòa chæ 88H. Chæ coù TCON ñöôïc ñòa chæ hoùa
töøng bit.
c. Caùc thanh ghi port noái tieáp:
8051/8031 chöùc moät port noái tieáp treân chip daønh cho vieäc trao ñoåi thoâng
tin vôùi caùc thieát bò noái tieáp nhö maùy tính, modem hoaëc cho vieäc giao tieáp vôùi
caùc IC khaùc coù giao tieáp noái tieáp (coù boä chuyeån ñoåi A/D, caùc thanh ghi dòch..).
Moät thanh ghi goïi laø boä ñeäm döõ lieäu noái tieáp (SBUF) ôû ñòa chæ 99H sseõ giöõ caû
hai giöõ lieäu truyeàn vaø nhaän. Khi truyeàn döõ lieäu thì ghi leân SBUf, khi nhaän döõ
lieäu thì ñoïc SBUF. Caùc mode vaän haønh khaùc nhau ñöôïc laäp trình qua thanh ghi
ñieàu khieån port noái tieáp (SCON) (ñöôïc ñòa chæ hoùa töøng bit) ôû ñòa chæ 98H.
d. Caùc thanh ghi ngaét:
8051/8031 coù caáu truùc 5 nguoàn ngaét, 2 möùc öu tieân. Caùc ngaét bò caám sau
khi reset heä thoáng vaø seõ ñöôïc cho pheùp baèng vieäc ghi thanh ghi cho pheùp ngaét
(IE) ôû ñòa chæ 8AH. Caû hai thanh ghi ñöôïc ñòa chæ hoùa töøng bit.
e. Caùc thanh ghi ñieàu khieån coâng suaát:
Thanh ghi ñieàu khieån coâng suaát (PCON) ôû ñòa chæ 87H chöùa nhieàu bit ñieàu
khieån.
9
4/. Leänh reset.
8051/8031 ñöôïc reset baèng caùch giöõ chaân RST ôû möùc cao ít nhaát trong 2 chu
kyø maùy vaø traû noù veà muùc thaáp. RST coù theå ñöôïc kích khi caáp ñieän duøng moät
maïch R-C.
+5V
100
+5V
10UF
8,2K
Hình 2.9: Maïch reset heä thoáng.
Traïng thaùi cuûa taát caû caùc thanh ghi cuûa 8051/8031 sau khi reset heä thoáng
ñöôïc toùm taét trong baûng sau:
Thanh ghi
Ñeám chöông trình
Tích luõy
B
PSW
SP
DPTR
Port 0-3
IP
IE
Caùc thanh ghi ñònh thôøi
SCON
10
Noäi dung
0000H
00H
00H
00H
07H
0000H
FFH
XXX00000B
0XX00000B
00H
00H
SBUF
PCON(HMOS)
PCON(CMOS)
00H
0XXXXXXB
0XXX0000B
Baûng 2.3: Traïng thaùi caùc thanh ghi sau khi reset
Quan troïng nhaát trong caùc thanh ghi treân laø thanh ghi ñeám chöông trình, noù
ñöôïc ñaët laïi 0000H. Khi RST trôû laïi möùc thaáp, vieäc thi haønh chöông trình luoân
baét ñaàu ôû ñòa chæ ñaàu tieân trong boä nhôù trong chöông trình: ñòa chæ 0000H. Noäi
dung cuûa RAM treân chip khoâng bò thay ñoåi bôûi leänh reset.
5. Hoaït ñoäng cuûa boä ñònh thôøi (timer)
5.1 Giôùi thieäu.
Moät ñònh nghóa ñôn giaûn cuûa timer laø moät chuoãi caùc flip-flop chia ñoâi taàn soá
noái tieáp vôùi nhau, chuùng nhaän tín hieäu vaøo laøm nguoàn xung nhòp. Ngoõ ra cuûa
taàn soá cuoái laøm nguoàn xung nhòp cho flip-flop baùo traøn cuûa timer (flip-flop côø).
Giaù trò nhò phaân trong caùc flip-flop cuûa timer coù theå xem nhö soá ñeám soá xung
nhòp (hoaëc caùc söï kieän) töø khi khôûi ñoäng timer. Ví duï timer 16 bit seõ ñeám leân töø
0000H ñeán FFFFH. Côø baùo traøn seõ leân 1 khi soá ñeám traøn töø FFFFH ñeán 0000H.
8051/8031 coù 2 timer 16 bit, moãi timer coù boán caùch laøm vieäc. Ngöôøi ta söû duïng
caùc timer ñeå : a) ñònh khoaûng thôøi gian, b) ñeám söï kieän hoaëc c) taïo toác ñoä baud
cho port noái tieáp trong 8051/8031.
Trong caùc öùng duïng ñònh khoaûng thôøi gian, ngöôøi ta laäp trình timer ôû moät
khoaûng ñeàu ñaën vaø ñaët côø traøn timer. Côø ñöôïc duøng ñeå ñoàng boä hoùa chöông
trình ñeå thöïc hieän moät taùc ñoäng nhö kieåm tra traïng thaùi cuûa caùc cöûa ngoõ vaøo
hoaëc göûi caùc söï kieän ra caùc ngoõ ra. Caùc öùng duïng khaùc coù theå söû duïng vieäc taïo
xung nhòp ñeàu ñaën cuûa timer ñeå ño thôøi gian troâi qua giöõa hai söï kieän (ví duï :
ño ñoä roäng xung).
Ñeám söï kieän duøng ñeå xaùc ñònh soá laàn xaåy ra cuûa moät söï kieän. Moät “söï kieän”
laø baát cöù taùc ñoäng ngoaøi naøo coù theå cung caáp moät chuyeån traïng thaùi treân moät
chaân cuûa 8051/8031. Caùc timer cuõng coù theå cung caáp xung nhòp toác ñoä baud cho
port noái tieáp trong 8051/8031.
11
Truy xuaát timer cuûa 8051/8031 duøng 6 thanh ghi chöùc naêng ñaëc bieät cho
trong baûng sau:
SFR
MUÏC ÑÍCH
TCON
TMOD
TL0
TL1
TH0
TH1
Ñieàu khieån timer
Cheá ñoä timer
Byte thaáp cuûa timer 0
Byte thaáp cuûa timer 1
Byte cao cuûa timer 0
Byte cao cuûa timer 1
ÑÒA
CHÆ
88H
89H
8AH
8BH
8CH
8DH
Ñòa chæ hoùa töøng bit
Coù
Khoâng
Khoâng
Khoâng
Khoâng
Khoâng
Baûng 2.4: Thanh ghi chöùc naêng ñaëc bieät duøng timer.
5.2 Thanh ghi cheá ñoä timer (TMOD)
Thanh ghi TMOD chöùa hai nhoùm 4 bit duøng ñeå ñaët cheá ñoä laøm vieäc cho timer
0 vaø timer 1.
Bit
Teân
Timer
Moâ taû
7
GATE
1
Bit (Môû) coång, khi leân 1 timer chæ chaïy khi INT1
ôû möùc cao.
6
C/T
1
Bit choïn cheá ñoä counter/timer
1=boä ñeám söï kieän
0=boä ñònh khoaûng thôøi gian
5
M1
1
Bit 1 cuûa cheá ñoä(mode)
4
M0
1
Bit 0 cuûa cheá ñoä
00: cheá ñoä 0 : timer 13 bit
12
3
2
1
0
GATE
C/T
M1
M0
01: cheá ñoä 1 : timer 16 bit
10: cheá ñoä 2 : töï ñoäng naïp laïi 8255A bit
11: cheá ñoä 3 : taùch timer
Bit (môû) coång
Bit choïn counter/timer
Bit 1 cuûa cheá ñoä
Bit 0 cuûa cheá ñoä
0
0
0
0
Baûng 2.5: Toùm taét thanh ghi TMOD
5.3 Thanh ghi ñieàu khieån timer (TCON)
Thanh ghi TCON chöùa caùc bit traïng thaùi vaø caùc bit ñieàu khieån cho timer 0 vaø
timer 1.
Bit
TCON.7
Kyù hieäu
TF1 8FH
TCON.6
TR1
8EH
TCON.5
TF0
8DH
13
Ñòa chæ Moâ taû
Côø baùo traøn timer 1. Ñaët bôûi phaàn
cöùng khi traøn, ñöôïc xoùa bôûi phaàn
meàm hoaëc phaàn cöùng khi boä xöû lyù
chæ ñeán chöông trình phuïc vuï ngaét.
Bit ñieàu khieån timer 1 chaïy. Ñaët/xoùa
baèng phaàn meàm cho timer chaïy/ngöng.
Côø baùo traøn timer 0
TCON.4
TCON.3
TCON.2
TR0
IE1
IT1
8CH
8BH
8AH
TCON.1
TCON.0
IE0
IT0
89H
88H
Bit ñieàu khieån timer 0 chaïy
Côø caïnh ngaét 1 beân ngoaøi, ñaëc bôûi
Côø kieåu ngaét moät beân ngoaøi.
phaàn cöùng khi phaùt hieän moät caïnh
xuoáng ôû INT1, xoùa baèng phaàn meàm
hoaëc phaàn cöùng khi CPU chæ ñeán
chöông trình phuïc vuï ngaét.
Ñaët/xoùa baèng phaàn meàm ñeà ngaét
ngoaøi tích cöïc caïnh xuoáng/möùc thaáp
Côø caïnh ngaét 0 beân ngoaøi
Côø kieåu ngaét 0 beân ngoaøi
Baûng 2.6: Toùm taét thanh ghi TCON
5. 4 Caùc cheá ñoä timer.
a)
Cheá ñoä 0, cheá ñoä timer 13 bit.
Ñeå töông thích vôùi 8048 (coù tröùôùc 8051)
Ba bit cao cuûa TLX (TL0 vaø/hoaêc TL1) khoâng duøng
Xung nhòp
timer
meàm.
TLx
(5 bit)
THx
(8 bit)
TFx
Côø baùo traøn
b) Cheá ñoä 1- cheá ñoä timer 16 bit.
Hoaït ñoäng nhö timer 16 bit ñaày ñuû.
Côø baùo traøn laø bit TFx trong TCON coù theå ñoïc hoaëc ghi baèng phaàm
MSB cuûa giaù trò trong caùc thanh ghi timer laø bit 7 cuûa THx vaø LBS laø bit
0 cuûa TLx. Caùc thanh ghi timer (Tlx/THx) coù theå ñöôïc ñoïc hoaëc ghi baát cöù luùc
naøo baèng phaàm meàm.
Xung nhòp
timer
14
TLx
(5 bit)
THx
(8 bit)
TFx
Côø baùo traøn
c) Cheá ñoä 0- cheá ñoä töï ñoäng naïp laïi 8 bit.
TLx hoaït ñoäng nhö moät timer 8 bit, trong khi ñoù THx vaãn giöõ nguyeân giaù
trò ñöôïc naïp. Khi soá ñeám traøn töù FFH ñeán 00H, khoâng nhöõng côø timer ñöôïc set
maø giaù trò trong THx ñoàng thôøi ñöôïc naïp vaøo TLx. Vieäc ñeám tieáp tuïc töø giaù trò
naøy leân ñeán FFH xuoáng 00H vaø naïp laïi... cheá ñoä naøy raát thoâng duïng vì söï traøn
timer xaûy ra trong nhöõng khoaûng thôøi gian nhaát ñònh vaø tuaàn hoaøn moät khi ñaõ
khôûi ñoäng TMOD vaø THx.
Xung nhòp
timer
TLx
(8 bit)
TFx
Naïp laïi
Côû baùo traøn
THx
(8 bit)
d) Cheá ñoä 3- cheá ñoä taùch timer
Timer 0 taùch thaønh hai timer 8 bit (TL0 vaø TH0), TL0 coù côø baùo traøn laø
TF0 vaø TH0 coù côø baùo traøn laø TF1.
Timer 1 ngöng ôû cheá ñoä 3, nhöng coù theå ñöôïc khôûi ñoäng baèng caùch
chuyeån sang cheá ñoä khaùc. Giôùi haïn duy nhaát laø côø baùo traøn TF1 khoâng coøn bò
taùc ñoäng khi timer 1 bò traøn vì noù ñaõ ñöôïc noái tôùi TH0.
Khi timer 0 ôû cheá ñoä 3, coù theå cho timer 1 chaïy vaø ngöng baèng caùch chuyeån noù
ra ngoaøi vaø vaøo cheá ñoä 3. Noù vaãn coù theå ñöôïc söû duïng bôûi port noái tieáp nhö boä
taïo toác ñoä baund hoaëc noù coù theå ñöôïc söû duïng baèng baát cöù caùch naøo khoâng caàn
ngaét (vì noù khoâng coøn ñöôïc noái vôùi TF1).
Xung nhòp
Timer
TL1
TH1
Xung nhòp
Timer
TL0
TF0
15
TH0
TF1
Côø baùo traøn
I/12 Fosc
Côø baùo traøn
5.5 Nguoàn taïo xung nhòp.
Coù hai nguoàn taïo xung nhòp coù theå coù, ñöôï choïn baèng caùch ghi vaøo bit
C/T (counter/timer) trong TMOD khi khôûi ñoäng timer. Moät nguoàn taïo xung nhòp
duøng cho ñònh khoaûng thôøi gian, caùi khaùc cho ñeám söï kieän.
Crytal
T0 or T1
pin
On chip
Osillato
r
÷12
Timer
Clock
−
C/T
0=Up (Internal Timing)
1=Down (Event Counting)
Nguoàn xung taïo nhòp
- Ñònh khoaûng thôøi gian (interval timing)
Neáu C/T =0 hoaï t ñoäng timer lieân tuïc ñöôïc choïn vaø timer ñöôïc duøng cho
vieäc ñònh khoaûng thôøi gian. Luùc ñoù, timer laáy xung nhòp töø boä dao ñoäng treân
chip. Boä chia 12 ñöôïc theâm vaøo ñeå giaûm taàn soá xung nhòp ñeán giaù trò thích hôïp
cho phaàn lôùn caùc öùng duïng. Nhö vaäy thaïch anh 12 MHz seõ cho toác ñoä xung
nhòp timer 1 MHz. Boùa traøn timer xaûy ra sau moät soá (coá ñòng) xung nhòp, phuï
thuoäc vaøo giaù trò ban ñaàu ñöôïc naïp vaøo caùc thanh ghi timer TLx/THx.
- Ñeám söï kieän (Event counting)
- Neáu C/T=1, timer laáy xung nhòp töø nguoàn beân ngoaøi. Trong haàu heát caùc
öùng duïng nguoàn beân ngoaøi naøy cung caáp cho timer moät xung kh xaûy ra moät
“söï kieän “, timer duøng ñeám söï kieän ñöôïc xaùc ñònh baèng phaàn meàm baèng
caùch ñoïc caùc thanh ghi TLx/THx vì giaù trò 16 bit trong caùc thanh ghi naøy
taêng theâm 1 cho moãi söï kieän.
16
Nguoàn xung nhòp ngoaøi coù töø thay ñoåi chuù7c naêng cuûa caùc chaân port 3. Bit
4 cuûa port 3 (P3.4) duøng laøm ngoõ vaøo taïo xung nhòp beân trong timer 0 vaø ñöôïc
goïi laø “T0”. Vaø p3.5 hay “T1” laø ngoõ vaøo taïo xung nhòp cho timer 1.
5.6 Baét ñaàu döøng vaø ñieàu khieån caùc timer.
Phöông phaùp môùi ñôn giaûn nhaát ñeå baét ñaàu (cho chaïy) vaø döøng caùc timer
laø duøng caùc bit ñieàu khieån chaïy :TRx trong TCON, TRx bò xoùa sau khi reset heä
thoáng. Nhö vaäy, caùc timer theo maëc nhieân laø bò caám (bò döøng). TRx ñöôïc ñaët
leân 1 baèng phaàn meàm ñeå cho caùc timer chaïy.
Xung nhòp
Timer
TRx
Caùc thanh ghi timer
0=leân : timer döøng
1=xuoáng : timer chaïy
Cho chaïy vaø döøng timer
Vì TRx ôû trong thanh ghi TCON coù ñòa chæ bit, neân deã daøng cho vieäc ñieàu
khieån caùc timer trong chöông trình. Ví duï : cho timer 0 chaïy baèng leänh : SETB
TR0 vaø döøng baèng leänh SETB TR0
Trình bieân dòch seõ thöïc hieän vieäc chuyeån ñoåi kyù hieäu caàn thieát töø “TR0” sang
ñòa chæ bit ñuùng. SETB TR0 chính xaùc gioáng nhö SETB 8CH.
5.7 Khôûi ñoäng vaø truy xuaát caùc thanh ghi timer.
Thoâng thöôøng caùc thanh ghi ñöôïc khôûi ñoäng moät laàn ôû ñaàu chöông trình
ñeå ñaët cheá ñoä laøm vieäc cho ñuùng. Sau ñoù trong thaân chöông trình caùc timer
ñöôïc cho chaïy, döøng , caùc bit côø ñöôïc kieåm tra vaø xoùa, caùc thanh ghi timer ñöôïc
ñoïc vaø caïp nhaät... theo ñoøi hoûi cuûa caùc öùng duïng.
TMOD laø thanh ghi thöù nhaát ñöôïc khôûi ñoäng vì noù ñaët cheá ñoä hoaït ñoäng.
Ví duï caùc leänh sau khi khôûi ñoäng timer 1 nhö timer 16 bit (cheá ñoä 1) coù xung
nhòp töø boä dao ñoäng treân chíp cho vieäc ñòng khoaûng thôøi gian.
MOV TMOD,#00010000B
Leänh naøyy seõ ñaët M1=0 vaû M0=1 cho cheá ñoä 1, C/T=0 vaø GATE=0 cho
xung nhòp noäi vaø xoùa caùc bit cheá ñoä timer 0. Dó nhieân timer thaät söï khoâng baét
ñaàu ñònh thôøi cho ñeán khi bit ñieàu khieån chaïyy TR1 ñöôïc ñaët leân 1.
Neáu caàn soá ñeám ban ñaàu, caùc thanh ghi timer TL1/TH1 cuõng phaûi ñöôïc khôûi
ñoäng. Nhôù laïi laø caùc timer ñeám leân vaø ñaët côø baùo traøn khi coù söï truyeån tieáp.
FFFFH sang 0000H.
- Ñoïc timer ñang chaïy.
17
Trong moät soá öùng duïng caàn ñoïc giaù trò trong caùc thanh ghi timer ñang
chaïy. Vì phaûi ñoïc 2 thanh ghi timer “sai pha” coù theå xaåy ra neáu byte thaáp traøn
vaøo byte cao giöõa hai laàn ñoïc. Giaù trò coù theå ñoïc ñöôïc khoâng ñuùng. Giaûi phaùp laø
ñoïc byte cao tröôùc, keá ñoù ñoïc byte thaáp roài ñoïc byte cao laïi moät laàn nöõa. Neáu
byte cao ñaõ thay ñoåi thì laäp laïi caùc hoaït ñoäng ñoïc.
5.8 Caùc khoaûng ngaén vaø caùc khoaûng daøi.
Daõy caùc khoaûng thôøi gian coù theå ñònh thôøi laø bao nhieâu ? vaán ñeà naøy
ñöôïc khaûo saùt vôùi 8051/8031 hoaït ñoäng vôùi taàn soá 12MHz. nhö vaäy xung nhòp
cuûa caùc timer coù taàn soá laù 1 MHz.
Khoaûng thôøi gian ngaén nhaát coù theå coù bò giôùi haïn khoâng chæ bôûi taàn soá xung
nhòp cuûa timer maø coøn bôûi phaàn meàm. Do aûnh höôûng cuûa thôøi khoaûng thöïc hieän
moät leänh. Leäng ngaén nhaát 8051/8031 laø moät chu kyø maùy hay 1µs. Sau ñaây laø
baûng toùm taét caùc kyõ thuaät ñeå taïo nhöõng khoaûng thôøi gian coù chieàu daøi khaùc
nhau (vôùi giaû söû xung nhòp cho 8051/8031 coù taàn soá 12 MHz)
Khoaûng thôøi gian toái ña
Kyõ thuaät
≈10
- Baèng phaàn meàm
256
- Timer 8 bit vôùi töï ñoäng naïp laïi
65535
- Timer 16 bit
Khoâng giôùi haïn
- Timer 16 bit coäng vôùi caùc voøng
laäp phaàn meàm
Caùc kyõ thuaät ñeå laäp trình caùc khoaûng thôøi gian (FOSC=12 MHz)
6. Hoaït ñoäng port noái tieáp.
6.1. Giôùi thieäu.
8051/8031 coù moät port noái tieáp trong chip coù theå hoaït ñoäng ôû nhieàu cheá
ñoä khaùc treân moät daõy taàn soá roäng. Chöùc naêng chuû yeáu cuûa moät port noái tieáp laø
thöïc hieän chuyeån ñoåi song song sang noái tieáp vôùi döõ lieäu xuaát vaø chuyeån ñoài
noái tieáp sang song song vôùi döõ lieäu nhaäp.
Truy xuaát phaàn cöùng ñeán port noái tieáp qua caùc chaân TXD vaø RXD. Caùc
chaân naøy coù caùc chöùc naêng khaùc vôùi hai bit cuûa port 3. P3 ôû chaân 11 (TXD) vaø
P3.0 ôû chaân 10 (RXD).
Port noái tieáp cho hoaït ñoäng song coâng (full duplex : thu vaø phaùt ñoàng thôøi)
vaø ñeäm luùc thu (receiver buffering) cho pheùp moät kyù töï seõ ñöôïc thu vaø ñöôïc giöõ
trong khi kyù töï thöù hai ñöôïc nhaän. Neáu CPU ñoïc kyù töï thöù nhaát tröôùc khi kyù töï
thöù hai ñöôïc thu ñaày ñuû thì döõ lieäu seõ khoâng bò maát.
18
Hai thanh ghi chöùc naêng ñaëc bieät cho pheùp phaàn meàm truy xuaát ñeán port
noái tieáp laø : SBUF vaø SCON. Boä ñeám port noái tieáp (SBUF) ôû ñaïi chæ 99H thaät
söû laø hai boä ñeám. Vieát vaøo SBUF ñeå truy xuaát döõ lieäu thu ñöôïc. Ñaây laø hai
thanh ghi rieâng bieät thanh ghi chæ ghi ñeå phaùt vaø thanh ghi ñeå thu.
TXD (P3.1) RXD (P3.0)
CLK
Xung nhòp toác
Ñoä baud (thu)
SUBF
(Chæ ghi)
Q
D
CLK
Xung nhòp toác
Ñoä baud (thu)
Thanh ghi dòch
SBUF
(chæ ñoïc)
SBUF
(chæ ñoïc)
BUS noäi 8051/8031
Hình 2.9: Sô ñoà port noái tieáp.
Thanh ghi ñieàu khieån port noái tieáp (SCON) ôû ñòa chæ 98H laø thanh ghi coù
ñòa chæ bit chöùa caùc bit traïng thaùi vaø caùc bit ñieàu khieån. Caùc bit ñieàu khieån ñaët
cheá ñoä hoaït ñoäng cho port noái tieáp, vaø caùc bit traïng thaùi baùo caùo keát thuùc vieäc
phaùt hoaëc thu kyù töï. Caùc bit traïng thaùi coù theå ñöôïc kieåm tra baèng phaàn meàm
hoaëc coù theå ñöôïc laäp trình ñeå taïo ngaét.
Taàn soá laøm vieäc cuûa port noái tieáp coøn goïi laø toác ñoä baund coù theå coá ñònh
(laáy töø boä giao ñoäng cuûa chip). Neáu söû duïng toác ñoä baud thay ñoåi, timer 1 seõ
cung caáp xung nhòp toác ñoä baud vaø phaûi ñöôïc laäp trình.
6.2 Thanh ghi ñieàu khieån port noái tieáp.
Cheá ñoä hoaït ñoäng cuûa port noái tieáp ñöôïc ñaët baèng caùch ghi vaøo thanh ghi
cheá ñoä port noái tieáp (SCON) ôû ñòa chæ 98H. Sau ñaây caùc baûng toùm taét thanh ghi
SCON vaø caùc cheá ñoä cuûa port noái tieáp :
19
Bit
SCON.7
SCON.6
SCON.5
Kyù hieäu
SM0
SM1
SM2
Ñòa chæ
9FH
9EH
9DH
SCON.4
REN
9CH
SCON.3
TB8
9BH
SCON.2
SCON.1
RB8
TI
9AH
99H
SCON.0
RI
98H
Moâ taû
Bit 0 cuûa cheá ñoä port noái tieáp
Bit 1 cuûa cheá ñoä port noái tieáp
Bit 2 cuûa cheá ñoä 2 noái tieáp.
cho pheùp trueàn thoâng ñaõ xöû lyù
trong caùc cheá ñoä 2 vaø 3 ;RI seõ
khoâng bò taùc ñoäng neáu bit thöù
9 thu ñöôïc laø 0
Cho pheùp boä thu phaûi ñaët leân
1 ñeå thu (nhaän) caùc kyù töï
Bit 8 phaùt, bit thöù 9 ñöôïc phaùt
caùc cheá ñoä 2 vaø 3; ñöôïc ñaët
vaø xoùa baèng phaàn meàm
Bit 8 thu, bit thöù 9 thu ñöôïc
Côø ngaét phaùt. Ñaët leân 1 khi
keát thuùc phaùt kyù töï; ñöôïc xoùa
phaàn meàm
Côø ngaét thu. Ñaët leân 1 khi
Keát thuùc thu kyù töï; ñöôïc xoùa
Baèng phaàn meàm
Baûng 2.7:Toùm taét thanh ghi cheá ñoä port noái tieáp SCON.
SM0
0
0
1
Fosc/64)
1
SM1
0
1
0
Cheá ñoä
0
1
2
Moâ taû
Thanh ghi dòch
UART 8 bit
UART 9 bit
Toác ñoä baud
Coá ñònh (Fosc/12)
Thay ñoåi (ñaët baèng timer)
Coá ñònh (Fosc/12 hoaëc
1
3
UART 9 bit
Thay ñoåi (ñaët baèng timer)
Baûng 2.8: Caùc cheá ñoä port noái tieáp.
Tröôùc khi söû duïng port noái tieáp, phaûi khôûi ñoäng SCON cho ñuùng cheá ñoä.
Ví duï ,leänh sau:
20
MOV SCON,#01010010B
Khôûi ñoäng port noái tieáp cho cheá ñoä 1 (SM0/SM1=0/1), cho pheùp boä thu
(REN=1) vaø ñaët côø ngaét phaùt (TP=1) ñeå chæ boä phaùt saün saøng hoaït ñoäng.
6.3 Khôûi ñoäng vaø truy xuaát caùc thanh ghi coång noái tieáp.
a. Cho pheùp thu:
Bit cho pheùp boä thu (REN = Receiver Enable) trong SCON phaûi ñöôïc ñaët
leân 1 baèng phaàn meàm ñeå cho pheùp thu caùc kyù töï. Thoâng thöôøng thöïc hieän vieäc
naøy ôû ñaàu chöông trình khi khôûi ñoäng coång noái tieáp, timer...Coù theå thöïc hieän
vieäc naøy theo hai caùch. Leänh :
SETB REN
Seõ ñaët REN leân 1, hoaëc leänh :
MOV SCON,#xxx1xxxxB
Seõ ñaët REN 1 vaø ñaëc hoaëc xoùa ñi caùc bit khaùc treân SCON khi caàn (caùc x
phaûi laø 0 hoaëc 2 ñeå ñaëc cheá ñoä laøm vieäc).
b. Bit döõ lieäu thöù 9:
Bit döõ lieäu thöù 9 caàn phaùt trong caùc cheá ñoä 2 vaø 3, phaûi ñöôïc naïp vaøo
trong TB8 baèng phaàn meàm. Bit döõ lieäu thöù 9 thu ñöôïc ñaët ôû RBS. Phaàn meàm coù
theå caàn hoaëc khoâng caàn bit döõ lieäu thöù 9, phuï thuoäc vaøo caùc ñaëc tính kyõ thuaät
cuûa thieát bò noái tieáp söû duïng (bit döõ lieäu thöù 9 cuõng ñoùng vai moät troø quan troïng
trong truyeàn thoâng ña xöû lyù).
c. Theâm 1 bit parity:
Thöôøng söû duïng bit döõ lieäu thöù 9 ñeå theâm parity vaøo kyù töï. Nhö ñaõ xeùt ôû
caùc chöông tröôùc, pit P trong töø traïng thaùi chöông trình (PSW) ñöôïc ñaët leân 1
hoaëc bò xoùa bôûi chu kyø maùy ñeå thieát laäp kieåm tra chaün vôùi 8 bit trong thanh tích
luõy.
d. Caùc côø ngaét:
Hai côø ngaét thu vaø phaùt (RI vaø TI) trong SCON ñoùng moät vai troø quan
troïng truyeàn thoâng noái tieáp duøng 8051/8031. Caû hai bit ñöôïc ñaët leân 1 baèng
phaàn cöùng, nhöng phaûi ñöôïc xoùa baèng phaàn meàm.
6.4 . Toác ñoä baud port noái tieáp.
Nhö ñaõ noùi, toác ñoä baud coá ñònh ôû caùc cheá ñoä 0 vaø 2. Trong cheá ñoä 0 noù
luoân luoân laø taàn soá dao ñoäng treân chip ñöôïc chia cho 12 . Thoâng thöôøng thaïch
anh aán ñònh taàn soá dao ñoäng treân chip cuûa 8051/8031 nhöng cuõng coù theå söû
duïng nguoàn xung nhòp khaùc. Giaû söû vôùi taàn soá dao ñoäng danh ñònh laø 12 MHz,
tìm toác ñoä baud cheá ñoä 0 laø 1 MHz.
21
Dao ñoäng
treân chip
Xung nhòp
toác ñoä baud
÷12
a. Cheá ñoä 0
÷64
SMOD=0
Dao ñoäng
treân chip
÷32
Xung nhòp
toác ñoä baud
SMOD=1
b. Cheá ñoä 2
÷32
Dao ñoäng
treân chip
÷16
÷16
SMOD=0
SMOD=1
Xung nhòp
toác ñoä baud
c. Cheá ñoä 1 vaø 3.
Hình 2.10. Caùc nguoàn taïo xung nhòp cho port noái tieáp.
Maëc nhieân, sau khi reset heä thoáng, toác ñoä baud cheá ñoä laø 2 taàn soá boä dao
ñoäng chia cho 64. Toác ñoä baud cuõng aûnh höôûng bôûi 1 bit trong thanh ghi ñieàu
khieån nguoàn cung caáp (PCON). Bit 7 cuûa PCON laø bit SMOD. Ñaët bit sMOD
leân moät laøm gaáp ñoâi toác ñoä baud trong cheá ñoä 1,2 vaø 3. Trong cheá ñoä 2, toác ñoä
baud coù theå bò gaáp ñoâi töø giaù trò maëc nhieân cuûa 1/64 taàn soá dao ñoäng
(SMOD=0) ñeán 1/32 taàn soá dao ñoäng (SMOD=1)
Vì PCON khoâng ñöôïc ñònh ñòa chæ theo bit, neân ñeå ñaët bit SMOD leân 1
caàn phaûi theo caùc leänh sau:
MOV A,PCON laáy giaù trò hieän thôøi cuûa PCON
SETB ACC.7 ñaët bit 7 (SMOD) leân 1
MOV PCON,A ghi giaù trò ngöôïc veà PCON
Caùc toác ñoä baud trong caùc cheá ñoä 1 vaø 3 ñöôïc xaùc ñònh baèng toác ñoä traøn
cuûa timer 1. Vì timer hoaït ñoäng ôû taàn soá töông ñoái cao, traøn timer ñöôïc chia
22
theâm cho 32 (hay 16 neáu SMOD=1) tröôùc khi cung caáp xung nhòp toác ñoä baud
cho port noái tieáp.
7. Taäp leänh cuûa 8051/8031.
Taäp leänh 8051/8031 coù 255 leänh goàm 139 leänh 1 byte, 92 leänh 2 byte vaø
24 leänh 3 byte.
7.1/ Caùc nhoùm leänh cuûa 8051/8031.
Taäp leänh cuûa 8051/8031 ñöôïc chia thaønh 5 nhoùm:
- Soá hoïc.
- Luaän lyù.
- Chuyeån döõ lieäu.
- Chuyeån ñieàu khieån.
Caùc chi tieát thieát laäp leänh:
Rn
:Thanh ghi R0 ñeán R7 cuûa bank thanh ghi ñöôïc choïn.
Data
: 8 bit ñòa chæ vuøng döõ lieäu beân trong. Noù coù theå laø vuøng RAM döõ
lieäu trong (0-127) hoaëc caùc thanh ghi chöùc naêng ñaëc bieät.
@Ri
: 8 bit vuøng RAM döõ lieäu trong (0-125) ñöôïc ñaùnh giaù ñòa chæ giaùn
tieáp qua thanh ghi R0 hoaëc R1.
#data
: Haèng 8 bit chöùc trong caâu leänh.
#data 16
: Haèng 16 bit chöùa trong caâu leänh.
Addr16
: 16 bit ñòa chæ ñích ñöôïc duøng trong leänh LCALL vaø LJMP.
Addr11
: 11 bit ñòa chæ ñích ñöôïc duøng trong leänh LCALL vaø AJMP.
Rel
: Byte offset 8 bit coù daáu ñöôïc duøng trong leänh SJMP vaø nhöõng
leänh nhaûy coù ñieàu kieän.
Bit
: Bit ñöôïc ñònh ñòa chæ tröïc tieáp trong RAM döõ lieäu noäi hoaëc caùc
thanh ghi chöùc naêng ñaëc bieät.
a. Nhoùm leänh xöû lyù soá hoïc:
ADD A,Rn (1byte, 1 chu kyø maùy) : coäng noäi dung thanh ghi Rn vaøo thanh ghi
A.
ADD A,data
(2,1): Coäng tröïc tieáp 1 byte vaøo thanh ghi A.
ADD A,@Ri
(1,1): Coäng giaùn tieáp noäi dung RAM chöùa taïi ñòa chæ ñöôïc
khai baùo trong Ri vaøo thanh ghi A.
ADD A,#data
(2,1):Coäng döõ lieäu töùc thôøi vaøo A.
ADD A,Rn
(1,1): Coäng thanh ghi vaø côø nhôù vaøo A.
ADD A,data
(2,1): Coäng tröïc tieáp byte döõ lieäu vaø côø nhôù vaøo A.
ADDC A,@Ri
(1,1): Coäng giaùn tieáp noäi dung RAM vaø côø nhôù vaøo A.
ADDC A,#data
(2,1): Coäng döõ lieäu töùc thôøi vaø côø nhôù vaøo A.
SUBB A,Rn
(1,1): Tröø noäi dung thanh ghi A cho noäi dung thanh ghi Rn
vaø côø nhôù.
23
SUBB A,data
SUBB A,@Ri
SUBB A,#data
INC A
INC Rn
INC data
INC @Ri
DEC A
DEC Rn
DEC data
DEC @Ri
INC DPTR
MUL AB
DIV AB
DA A
(2,1): Tröø tröïc tieáp A cho moät soá vaø côø nhôù.
(1,1): Tröø giaùn tieáp A cho moät soá vaø côø nhôù.
(2,1): Tröø noäi dung A cho moät soá töùc thôøi vaø côø nhôù.
(1,1): Taêng noäi dung thanh ghi A leân 1.
(1,1): Taêng noäi dung thanh ghi Rn leân 1.
(2,1): Taêng döõ lieäu tröïc tieáp leân 1.
(1,1): Taêng giaùn tieáp noäi dung vuøng RAM leân 1.
(1,1): Giaûm noäi dung thanh ghi A xuoáng 1.
(1,1): Giaûm noäi dung thanh ghi Rn xuoáng 1.
(2,1): Giaûm döõ lieäu tröïc tieáp xuoáng 1
(1,1): Giaûm giaùn tieáp noäi dung vuøng RAM xuoáng 1.
(1,2): Taêng noäi dng con troû döõ lieäu leân 1.
(1,4): Nhaân noäi dung thanh ghi A vôùi noäi dung thanh ghi B.
(1,4): Chia noäi dung thanh ghi A cho noäi dung thanh ghi B.
(1,1,): hieäu chænh thaäp phaân thanh ghi A.
b. Nhoùm leänh luaän lyù:
ANL A,Rn
(1,1): AND noäi dung thanh ghi A vôùi noäi dung thanh ghi Rn.
ANL A,data
(2,1):AND noäi dung thanh ghi A vôùi döõ lieäu tröïc tieáp.
ANL A,@Ri
(1,1): AND noäi dung thanh ghi A vôùi döõ lieäu giaùn tieáp
trong RAM.
ANL A,#data
(2,1): AND noäi dung thanh ghi vôùi döõ lieäu töùc thôøi.
ANL data,A
(2,1): AND moät döõ lieäu tröïc tieáp vôùi A.
ANL data,#data
(3,2): AND moät döõ lieäu tröïc tieáp vôùi A moät döõ lieäu töùc thôøi.
ANL C,bit
(2,2):AND côø nhôù vôùi 1 bit tröïc tieáp.
ANL C,/bit
(2,2): AND côø nhôù vôùi buø 1 bit tröïc tieáp.
ORL A,Rn
(1,1): OR thanh ghi A vôùi thanh ghi Rn.
ORL A,data
(2,1): OR thanh ghi A vôùi moät döõ lieäu tröïc tieáp.
ORL A,@Ri
(1,1): OR thanh ghi A vôùi moät döõ lieäu giaùn tieáp.
ORL A,#data
(2,1):OR thanh ghi A vôùi moät döõ lieäu töùc thôøi.
ORL data,A
(2,1): OR moät döõ lieäu tröïc tieáp vôùi thanh ghi A.
ORL data,#data
(3,1):OR moät döõ lieäu tröïc tieáp vôùi moät döõ lieäu töùc thôøi.
ORL C,bit
(2,2): OR côø nhôù vôùi moät bit tröïc tieáp.
ORL C,/bit
(2,2): OR côø nhôù vôùi buø cuûa moät bit tröïc tieáp.
XRL A,Rn
(1,1): XOR thanh ghi A vôùi thanh ghi Rn.
XRL A,data
(2,1): XOR thanh ghi A vôùi moä döõ lieäu tröïc tieáp.
XRL A,@Ri
(1,1): XOR thanh ghi A vôùi moät döõ lieäu giaùn tieáp.
XRL A,#data
(2,1): XOR thanh ghi A vôùi moä döõ lieäu töùc thôøi.
24
XRL data,A
(2,1): XOR moät döõ lieäu tröïc tieáp vôùi thanh ghi A.
XRL dara,#data
(3,1): XOR moät döõ lieäu tröïc tieáp vôùi moät döõ lieäu töùc thôøi.
SETB C
(1,1): Ñaët côø nhôù.
SETB bit
(2,1): Ñaët moät bit tröïc tieáp.
CLR A
(1,1): Xoùa thanh ghi A.
CLR C
(1,1): Xoùa côø nhôù.
CPL A
(1,1): Buø noäi dung thanh ghi A.
CPL C
(1,1): Buø côø nhôù.
CPL bit
(2,1): Buø moät bit tröïc tieáp.
RL A
(1,1): Quay traùi noäi dung thanh ghi A.
RLC A
(1,1): Quay traùi noäi dung thanh ghi A qua côø nhôù.
RR A
(1,1): Quay phaûi noäi dung thanh ghi A.
RRC A
(1,1): Quay phaûi noäi dung thanh ghi A qua côø nhôù.
SWAP
(1,1): Quay traùi noäi dung thanh ghi A 1 nibble (1/2byte).
c. Nhoùm leänh chuyeån döõ lieäu:
MOV A,Rn
(1,1):Chuyeån noäi dung thanh ghi Rn vaøo thanh ghi A.
MOV A,data
(2,1): Chuyeån döõ lieäu tröïc tieáp vaøo thanh ghi A.
MOV A,@Ri
(1,1): Chuyeån döõ lieäu giaùn tieáp vaøo thanh ghi A.
MOV A,#data
(2,1): Chuyeån döõ lieäu töùc thôøi vaøo thanh ghi A.
MOV Rn,data
(2,2): Chuyeån döõ lieäu tröïc tieáp vaøo thanh ghi Rn.
MOV Rn,#data
(2,1): Chuyeån döõ lieäu töùc thôøi vaøo thanh ghi Rn.
MOV data,A
(2,1): Chuyeån noäi dung thanh ghi A vaøo moät döõ lieäu tröïc
tieáp.
MOV data,Rn
(2,2): Chuyeån noäi dung thanh ghi Rn vaøo moät döõ lieäu tröïc
tieáp.
MOV data,data
(3,2): Chuyeån moät döõ lieäu tröïc tieáp vaøo moät döõ lieäu tröïc
tieáp.
MOV data,@Ri
(2,2): Chuyeån moät döõ lieäu giaùn tieáp vaøo moät döõ lieäu giaùn
tieáp.
MOV data,#data (3,2): Chuyeån moät döõ lieäu töùc thôøi vaøo moät döõ lieäu tröïc
tieáp.
MOV @Ri,A
(1,1): Chuyeån noäi dung thanh ghi A vaøo moät döõ lieäu giaùn
tieáp.
MOV @Ri,data
(2,2): Chuyeån moät döõ lieäu tröïc tieáp vaøo moät döõ lieäu giaùn
tieáp.
MOV @Ri,#data (2,1): Chuyeån döõ lieäu töùc thôøi vaøo döõ lieäu giaùn tieáp.
MOV DPTR,#dataù6 (3,2): Chuyeån moät haèng 16 bit vaøo thanh ghi con troû döõ
lieäu.
25
MOV C,bit
(2,1): Chuyeån moät bit tröïc tieáp vaøo côø nhôù.
MOV bit,C
(2,2): Chuyeån côø nhôù vaøo moät bit tröïc tieáp.
MOV A,@A+DPTR (1,2): Chuyeån byte boä nhôù chöông trình coù ñòa chæ laø
@A+DPRT vaøo thanh ghi A.
MOVC A,@A+PC (1,2): Chuyeån byte boä nhôù chöông trình coù ñòa chæ laø
@A+PC vaøo thanh ghi A.
MOV A,@Ri
(1,2): Chuyeån döõ lieäu ngoaøi (8 bit ñòa chæ) vaøo thanh ghi A.
MOVX A,@DPTR (1,2): Chuyeån döõ lieäu ngoaøi (16 bit ñòa chæ) vaøo thanh ghi A.
MOVX @Ri,A
(1,2): Chuyeån noäi dung A ra döõ lieäu ngoaøi (8 bit ñòa chæ).
MOVX @DPTR,A (1,2): Chuyeån noäi dung A ra döõ lieäu beân ngoaøi (16 bit ñòa
chæ).
PUSH data (2,2) : Chuyeån döõ lieäu tröïc tieáp vaøo ngaên xeáp vaø taêng SP.
POP data (2,2)
: Chuyeån döõ lieäu tröïc tieáp vaøo ngaên xeáp vaø giaûm SP.
XCH A,Rn (1,1)
: Trao ñoåi döõ lieäu giöõa thanh ghi Rn v2 thanh ghi A.
XCH A,data (2,1) : Trao ñoåi giöõa thanh ghi A vaø moät döõ lieäu tröïc tieáp.
XCH A,@Ri (1,1) : Trao ñoåi giöõa thanh ghi A vaø moät döõ lieäu giaùn tieáp.
XCHD A,@R (1,1) : Trao ñoåi giöõa nibble thaáp (LSN) cuûa thanh ghi A vaø LSN
cuûa döõ lieäu giaùn tieáp.
d. Nhoùm leänh chuyeàn ñieàu khieån:
ACALL addr11
(2,2): Goïi chöông trình con duøng ñòa chì tuyeät ñoái.
LCALL addr16
(3,2): Goïi chöông trình con duøng ñòa chæ daøi.
RET
(1,2): Trôû veà töø leänh goïi chöông trình con.
RET1
(1,2): Trôû veà töø leänh goïi ngaét.
AJMP addr11
(2,2): Nhaûy tuyeät ñoái.
LJMP addr16
(3,2): Nhaûy daøi.
SJMP rel
(2,2):Nhaûy ngaén.
JMP @A+DPTR (1,2): Nhaûy giaùn tieáp töø con troû döõ lieäu.
JZ rel
(2,2): Nhaûy neáu A=0.
JNZ rel
(2,2): Nhaûy neáu A khoâng baèng 0.
JC rel
(2,2): Nhaûy neáu côø nhôù ñöôïc ñaët.
JNC rel
(2,2): Nhaûy neáu côø nhôù khoâng ñöôïc ñaët.
JB bit,rel
(3,2): Nhaûy töông ñoái neáu bit tröïc tieáp ñöôïc ñaët.
JNB bit,rel
(3,2):Nhaûy töông ñoái neáu bit tröïc tieáp khoâng ñöôïc ñaët.
JBC bit,rel
(3,2): Nhaûy töông ñoái neáu bit tröïc tieáp ñöôïc ñaët , roài xoùa
bit.
CJNE A,data,rel (3,2): So saùnh döõ lieäu tröïc tieáp vôùi A vaø nhaûy neáu khoâng
baèng.
26
CJNE A,#data,rel (3,2): So saùnh döõ lieäu töùc thôøi vôùi A vaø nhaûy neáu khoâng
baèng.
CJNE Rn,#data,rel (3,2): So saùnh döõ lieäu töùc thôøi vôùi noäi dung thanh ghi Rn vaø
nhaûy neáu khoâng baèng.
CJNE @Ri,#data,rel (3,2): So saùnh döõ lieäu töùc thôøi vôùi döõ lieäu giaùn tieáp vaø
nhaûy neáu khoâng baèng.
DJNZ Rn,rel
(2,2): Giaûn thanh ghi Rn vaø nhaûy neáu khoâng baèng.
DJNZ data,rel
(3,2): Giaûm döõ lieäu tröïc tieáp vaø nhaûy neáu khoâng baèng.
Chöông 2: ÑO NHIEÄT ÑOÄ
I. Heä Thoáng Ño Löôøng
1. Giôùi thieäu
Ñeå thöïc hieän pheùp ño cuûa moät ñaïi löôïng naøo ñoù thì tuyø thuoäc vaøo ñaëc
tính cuûa ñaïi löôïng caàn ño,ñieàu kieän ño,cuõng nhö ñoä chính xaùc theo yeâu caàu cuûa
moät pheùp ño maø ta coù theå thöïc hieän ño baèng nhieàu caùch khaùc nhau treân cô sôõ
cuûa caùc heä thoáng ño löôøng khaùc nhau.
Sô ñoà khoái cuûa moät heä thoáng ño löôøng toång quaùt
Chuyeån ñoåi
Maïch
ño
Chæ thò
_ Khoái chuyeån ñoåi: laøm nhieäm vuï nhaän tröïc tieáp caùc ñaïi löôïng vaät lyù ñaëc tröng
cho ñoái töôïng caàn ño bieán ñoåi caùc ñaïi löôïng thaønh caùc ñaïi löôïng vaät lyù thoáng
nhaát(doøng ñieän hay ñieän aùp) ñeå thuaän lôïi cho vieäc tính toaùn.
_ Maïch ño: coù nhieäm vuï tính toaùn bieán ñoåi tín hieäu nhaän ñöôïc töø boä
chuyeån ñoåi sao cho phuø hôïp vôùi yeâu caàu theå hieän keát quaû ño cuûa boä chæ thò.
_ Khoái chæ thò:laøm nhieäm vuï bieán ñoåi tín hieäu ñieän nhaän ñöôïc töø maïch ño
ñeå theå hieän keát quaû ño.
2. Heä thoáng ño löôøng soá
Heä thoáng ño löôøng soá ñöôïc nhoùm aùp duïng ñeå thöïc hieän luaän vaên naày vì
coù caùc öu ñieåm:caùc tín hieäu töông töï qua bieán ñoåi thaønh caùc tín hieäu soá coù caùc
xung roû raøng ôû traïng thaùi 0,1 seõ giôùi haïn ñöôïc nhieàu möùc tín hieäu gaây sai soá
.Maët khaùc ,heä thoáng naøy töông thích vôùi döõ lieäu cuûa maùy tính,qua giao tieáp vôùi
maùy tính öùng duïng roäng raõi trong kyõ thuaät.
27
a. Sô ñoà khoái
Ñaïi löôïng
Ñaïi löôïng
Caûm
bieán
Caûm
bieán
Cheá
bieán
Tín
hieäu ño
Cheá
bieán
Tín
hieäu ño
Doàn
keânh
töông
töï
ADC
Vi xöû
lyù
Hieånthò
Söû
dung
Ñieàu khieån choïn
Chöông
trình
Hình 5.1 Sô ñoà khoái cuûa heä thoáng ño löôøng soá
b. Nguyeân lyù hoaït ñoäng
Ñoái töôïng caàn ño laø ñaïi löôïng vaät lyù,döïa vaøo caùc ñaëc tính cuûa ñoái töôïng
caàn ño maø ta choïn moät loaïi caûm bieán phuø hôïp ñeå bieán ñoåi thoâng soá ñaïi löôïng
vaät lyù caàn ño thaønh ñaïi löôïng ñieän ,ñöa vaøo maïch cheá bieán tín hieäu(goàm:boä
caûm bieán,heä thoáng khueách ñaïi,xöû lyù tín hieäu).
Boä chuyeån ñoåi tín hieäu sang soá ADC(Analog Digital Converter) laøm nhieäm
vuï chuyeån ñoåi tín hieäu töông töï sang tín hieäu soá vaø keát noái vôùi vi xöû lyù.
Boä vi xöû lyù coù nhieäm vuï thöïc hieän nhöõng pheùp tính vaø xuaát ra nhöõng leänh
treân cô sôû trình töï nhöõng leänh chaáp haønh ñaõ thöïc hieän tröôùc ñoù.
Boä doàn keânh töông töï (multiplexers) vaø boä chuyeån ADC ñöôïc duøng chung taát
caû caùc keânh . Döõ lieäu nhaäp vaøo vi xöû lyù seõ coù tín hieäu choïn ñuùng keânh caàn xöû
lyù ñeâ ñöa vaøo boä chuyeån ñoåi ADC vaø ñoïc ñuùng giaù trò ñaëc tröng cuûa noù qua tính
toaùn ñeå coù keát quaû cuûa ñaïi löôïng caàn ño.
II.
Caùc Phöôg Phaùp Ño Nhieät Ñoä
Ño nhieät ñoä laø moät phöông thöùc ño löôøng khoâng ñieän,ño nhieät ñoä ñöôïc chia
thaønh nhieàu daõi:
+ Ño nhieät ñoä thaáp
+ Ño nhieät ñoä trung bình
+ Ño nhieät ñoä cao.
Vieäc ño nhieät ñoä ñöôïc tieán haønh nhôø caùc duïng cuï hoå trôï chuyeân bieät nhö:
+ Caëp nhieät ñieän
+ Nhieät keá ñieän keá kim loaïi
+ Nhieät ñieän trôû kim loaïi
28
+ Nhieät ñieän trôû baùn daãn
+ Caûm bieán thaïch anh.
Vieäc söû duïng caùc IC caûm bieán nhieät ñeå ño nhieät ñoä laø moät phöông phaùp
thoâng duïng ñöôïc nhoùm söû duïng trong taäp luaän vaên naày,neân ôû ñaây chæ giôùi thieäu
veà IC caûm bieán nhieät.
™ Nguyeân lyù hoaït ñoäng chung cuûa IC ño nhieät ñoä
IC ño nhieät ñoä laø moät maïch tích hôïp nhaän tín hieäu nhieät ñoä chuyeån thaønh
tín hieäu ñieän döôùi daïng doøng ñieän hay ñieän aùp.Döïa vaøo ñaëc tính raát nhaïy cuûa
caùc baùn daãn vôùi nhieät ñoä,taïo ra ñieän aùp hoaëc doøng ñieän,tæ leä thuaän vôùi nhieät ñoä
tuyeät ñoái.Ño tín hieäu ñieän ta bieát ñöôïc giaù trò cuûa nhieät ñoä caàn ño.Söï taùc ñoäng
cuûa nhieät ñoä taïo ra ñieän tích töï do vaø caùc loå troáng trong chaát baùn daãn . Baèng söï
phaù vôõ caùc phaân tö û, böùt caùc electron thaønh daïng töï do di chuyeån qua vuøng caáu
truùc maïng tinh theå taïo söï xuaát hieän caùc loã troáng . Laøm cho tæ leä ñieän töû töï do vaø
loå troáng taêng leân theo qui luaät haøm muõ vôùi nhieät ñoä .
™ Ñaëc tính cuûa moät soá IC ño nhieät ñoä thoâng duïng
+AÏD590
Ngoõ ra laø doøng ñieän.
Ñoä nhaïy 1A/0K.
Ñoä chính xaùc +40C.
Nguoàn cung caáp Vcc = 4 – 30V.
Phaïm vi söû duïng –55oc ñeán 150oc
+ LX5700
Ngoõ ra laø ñieän aùp.
Ñoä nhaïy –10mv/0K.
Phaïm vi söû duïng –550C – 1500C.
+ LM135,LM335
Ngoõ ra laø ñieän aùp.
Ñoä nhaïy 10mv/0C.
Sai soá cöïc ñaïi 1,50C khi nhieät ñoä lôùn hôn 1000C.
Phaïm vi söû duïng –550C – 1500C.
Chöông 3 : CHUYEÅN ÑOÅI TÖÔNG TÖÏ – SOÁ
I KHAÙI NIEÄM CHUNG
Ngaøy nay vieäc truyeàn ñaït tín hieäy cuõng nhö quaù trình ñieàu khieån vaø chæ
thò phaàn lôùn ñöôïc thöïc hieän theo phöông phaùp soá. Trong khi ñoù tín hieäu töï
nhieân coù daïng töông töï nhö:nhieät ñoä,aùp suaát ,cöôøng ñoä aùnh saùng,toác ñoä quay,tín
29
hieäu aâm thanh…Ñeå keát noái giöõa nguoàn tín hieäu töôïng töï vôùi caùc heä thoáng xöû lyù
soá ngöôøi ta duøng caùc maïch chuyeån ñoåi töông töï sang soá(ADC) nhaèm bieán ñoåi
tín hieäu töông töï sang soá hoaëc trong tröøông hôïp ngöôïc laïi caàn bieán ñoåi tín hieäu
soá sang töông töï thi duøng caùc maïch DAC (Digital Analog Converter).
II GIÔÙI THIEÄU VEÀ IC ADC0809
Boä ADC 0809 laø moät thieát bò CMOS tích hôïp vôùi moät boä chuyeån ñoåi töø
töông töï sang soá 8 bit, boä choïn 8 keânh vaø moät boâ logic ñieàu khieån töông thích.
Boä chuyeån ñoåi AD 8 bit naøy duøng phöông phaùp chuyeån ñoåi xaáp xæ tieáp. Boä
choïn keânh coù theå truy xuaát baát keành naøo trong caùc ngoõ vaøo töông töï moät caùnh
ñoäc laäp.
Thieát bò naøy loaïi tröø khaû naêng caàn thieát ñieàu chænh ñieåm 0 beân ngoaøi vaø
khaû naêng ñieàu chænh tæ soá laøm troøn ADC 0809 deã daøng giao tieáp vôùi caùc boä vi
xöû lyù.
1/ Sô ñoà chaân ADC 0809:
IN2 IN1 IN0
A
B
C
ALE 2-1 2-2
2-3
28
2-4
2-8 REF 2-6
15
ADC0809
1
IN3 IN4 IN5 IN6
14
IN7
START
EOC 2-5 OE
CLK VCC REF GND 2-7
* YÙ nghóa caùc chaân:
. IN0 ñeán IN7 : 8 ngoõ vaøo töông töï.
. A, B, C
: giaûi maõ choïn moät trong 8 ngoõ vaøo
-1
-8
. Z ñeán Z
: ngoõ ra song song 8 bit
. ALE
: cho pheùp choát ñòa chæ
. START
: xung baét ñaàu chuyeån ñoåi
. CLK : xung ñoàng hoà
. REF (+): ñieän theá tham chieáu (+)
. REF (-) : ñieän theá tham chieáu (-)
. VCC : nguoàn cung caáp
2/ Caùc ñaëc ñieåm cuûaADC 0809:
. Ñoä phaân giaûi 8 bit
30
. Toång sai soá chöa chænh ñònh ± ½ LSB; ± 1 LSB
. Thôøi gian chuyeån ñoåi: 100µs ôû taàn soá 640 kHz
. Nguoàn cung caáp + 5V
. Ñieän aùp ngoõ vaøo 0 – 5V
. Taàn soá xung clock 10kHz – 1280 kHz
. Nhieät ñoä hoaït ñoäng - 40oC ñeán 85oC
. Deã daøng giao tieáp vôùi vi xöû lyù hoaëc duøng rieâng
. Khoâng caàn ñieàu chænh zero hoaëc ñaày thang
3/ Nguyeân lyù hoaït ñoäng:
ADC 0809 coù 8 ngoõ vaøo töông töï, 8 ngoõ ra 8 bit coù theå choïn 1 trong 8 ngoõ
vaøo töông töï ñeå chuyeån ñoåi sang soá 8 bit.
Caùc ngoõ vaøo ñöôïc choïn baèng caùch giaûi maõ. Choïn 1 trong 8 ngoõ vaøo töông
töï ñöôïc thöïc hieän nhôø 3 chaân ADDA , ADDB , ADDC nhö baûng traïng thaùi sau:
A
0
0
0
0
1
1
1
1
B C
0 0
0 1
1 0
1 1
0 0
0 1
1 0
1 1
Ngoõ vaøo ñöôïc choïn
IN0
IN1
IN2
IN3
IN4
IN5
IN6
IN7
Sau khi kích xung start thì boä chuyeån ñoåi baét ñaàu hoaït ñoäng ôû caïnh xuoáng
cuûa xung start, ngoõ ra EOC seõ xuoáng möùc thaáp sau khoaûng 8 xung clock (tính töø
caïnh xuoáng cuûa xung start). Luùc naøy bit cô troïng soá lôùn nhaát (MSB) ñöôïc ñaët
leân möùc 1, taát caû caùc bit coøn laïi ôû möùc 0, ñoàng thôøi taïo ra ñieän theá coù giaù trò
Vref/2, ñieän theá naøy ñöôïc so saùnh vôùi ñieän theá vaøo in.
+ Neáu Vin > Vref/2 thì bit MSB vaãn ôû möùc 1.
+ Neáu Vin < Vref/2 thì bit MSB vaãn ôû möùc 0.
Töông töï nhö vaäy bit keá tieáp MSB ñöôïc ñaët leân 1 vaø taïo ra ñieän theá coù giaù trò
Vref/4 vaø cuõng so saùnh vôùi ñieän aùp ngoõ vaøo Vin. Quaù trình cöù tieáp tuïc nhö vaäy
cho ñeán khi xaùc ñònh ñöôïc bit cuoái cuøng. Khi ñoù chaân EOC leân möùc 1 baùo cho
bieát ñaõ keát thuùc chuyeån ñoåi.
Trong suoát quaù trình chuyeån ñoåi chaân OE ñöôïc ñaët ôû möùc 1, muoán ñoïc döõ lieäu
ra chaân OE xuoáng möùc 0.
31
Trong suoát quaù trình chuyeån ñoåi neáu coù 1 xung start taùc ñoäng thì ADC seõ ngöng
chuyeån ñoåi.
Maõ ra N cho moät ngoõ vaøo tuøy yù laø moät soá nguyeân.
N=
256.(VIN − Vref ( − ) )
Vref ( + ) − Vref ( − )
Trong ñoù Vin: ñieän aùp ngoõ vaøo heä so saùnh.
Vref(+): ñieän aùp taïi chaân REF(+).
Vref(-): ñieän aùp taïi chaân REF(-).
Neáu choïn Vref(-) = 0 thì N = 256.
-
Vin
Vref (+ )
Vref(+) = Vcc = 5V thì ñaày thang laø 256.
Giaù trò böôùc nhoû nhaát
1 LSB =
5
= 0,0196 V/byte
2 −1
8
Vaäy vôùi 256 böôùc Vin = 5V.
Aùp vaøo lôùn nhaát cuûa ADC 0809 laø 5V.
4/ Maïch taïo xung clock cho ADC 0809:
Söû duïng maïch dao
IK
ñoäng duøng caùc coång
not ñeå taïo dao ñoäng
cho ADC nhö sau:
Taàn soá dao ñoäng cuûa maïch laø f =
Vcc
IK
10K
1
560
3RC
Taàn soá dao ñoäng chuaån laø 600 kHz
Suy ra 640 =
1
3RC
Vôùi R töø 100Ω ñeán vaøi kΩ choïn R =1 kΩ ⇒ C = 500 PF.
*****************************************************
*****************************************************
PHAÀN B :
CHÖÔNG1
I . SÔ ÑOÀ KHOÁI :
32
THIEÁT KEÁ PHAÀN CÖÙNG
THIEÁT KEÁ TOÅNG QUAÙT
KHOÁI HIEÅN THÒ
BOÄ BIEÁN ÑOÅI ADC
CMU 8051
KHOÁI CAÛM BIEÁN
BAØN PHÍM
MAÏCH COÂNG SUAÁT
Heä hoaït ñoäng theo chöông trình ñaõ naïp treân ROM , qua söï ñieàu khieån cuaû MCU
8051 phaàn caûm bieán nhieät ñaët ôû nôi ta muoán ño ,noù seõ ñoï tín hieäu cuûa nhieät ñoä qua
möùc ñieän aùp tín hieäu analog ñöôïc chuyeån thaønh tín hieäu soá vaø giao tieáp vôùi heä thoáng
qua data bus.
Treân cô sôû chöông chình ñöôïc naïp treân ROM vaø tín hieäu nhaän ñöôïc , MCU cho
pheùp thieát bò ngoaïi vi hoaït ñoäng nhö : hieån thò giaù trò nhieät ñoä töông öùng ñieàu khieån
nhieät ñoä thích hôïp.
II .SÔ LÖÔÏC CHÖÙC NAÊNG CAÙC BOÄ PHAÄN :
_ Vi xöû lyù 8051 laø phaàn töû chính xöû caùc thoâng tin nhaäp vaøo vaø ñöa ra caùc quyeát
ñònh ñieài khieån.
_ Phím laø boä phaän giao tieáp ngoaïi vi , cho pheùp nhaäp caùc thoâng soá baèng tay.
_ Maïch hieån thò , hieån thò caùc giaù trò ñaët vaø giaù trò ño.
_ Maïch caûm bieán duøng ñeå khuyeách ñaò tín hieäu vaø buø nhieät.
_ Maïch coâng suaát duøng ñeå ñoùng môû nguoàn coâng suaát.
III . THIEÁT KEÁ CHI TIEÁT :
1 . Thieát keá phím :
Caùc phím thieát keá ñôn giaûn goàm coù 3 phím :
•
Phím taêng
•
Phím giaûm.
•
Phím chöùc naêng.
1VCC_CIRCLE
+V
R1
R2
4.7k 4.7k
R3
4.7k
P1.0
P1.1
P1.2
33
2 . Khoái maïch caûm bieán :
VCC
1
+V
-VCC
1
VR
1 5%
2
4+
U1
LM358
1
R3
R5
3
2
C1
1
3
-VCC
8 +VCC
2
3
-VCC
VCC1
1
+V
2 4+
3
LM335
2
1
4+
U3
LM358
IN0
1
8
U2A
LM358
R6
VCC
R4
1
8
1
VR1
1 5%
+VCC
3
C2
1
Tính toaùn vaø caân chænh :
LM335 laø caûm bieán nhieät ñoä coù theå hoaït ñoäng ñeán 1500C töông öùng vôùi
nhieät ñoä 00K , LM335 cho ra ñieän aùp 0V . Cöù taêng 10C ,ñieän aùp ra taêng 10mV.Nhö
vaäy vôùi 00C thì ñieän aùp laø 2.73V.
Xeùt maïch khuyeát ñaò tröø :
Goïi Vf1 = VOUT laø aùp ngoõ vaøo ñaoû cuaû U3 , VI2 = VOUT2 aùp ngoõ vaoø khoâng
ñaoûcuaû U3 . Aùp duïng phöông phaùp xeáp choàng cho töøng kích thích ngoõ vaoø ,ngaén
maïch ngoõ vaøo coøn laïi ta ñöôïc :
R5
V01 = Vi1
R3
⎛ R6 ⎞⎛ R5 ⎞
V02 = ⎜
⎟
⎟⎜1 +
R3 ⎠
⎝ R6 + R 4 ⎠⎝
R5
⎛ R6 ⎞⎛ R5 ⎞
V0 = V02 + V01 = V02 = ⎜
Vi1
⎟⎜1 +
⎟ Vi2 R3
R3 ⎠
⎝ R6 + R 4 ⎠⎝
Neáu R5 = R6 = R4 = R3 = 1
V0 = Vi2 – Vi1
Trong tröôøng hôïp naøy ta choïn R5 = R6 vaø R4 = R3 thì V0 ñöôïc vieát laïi nhö sau:
34
R5
R5
⎛ R6 ⎞⎛ R5 ⎞
V0 = ⎜
Vi1 = (
) (Vi2 – Vi1 ) =Av(Vi2 – Vi1)
⎟⎜1 +
⎟ Vi2 R3 ⎠
R3
R3
⎝ R6 + R 4 ⎠⎝
Suy ra ñieän aùp ngoõ ra seõ thay ñoåi Av*10mV khi nhieät ñoä thay ñoåi 10C .ñoä
phaân giaûi caàn laø 0.50C neân ñieän aùp thay ñoåi khi nhieät ñoä thay ñoåi 10C,phaûi baèng hai
laàn ñoä phaân giaûi cuûa AD0804 :
Av*10mV = 2*19.6mV
Ö Av= 3.92
Ö Choïn R5 = 39 K vaø R3 = 10K
Caân chænh :
Chænh VR1 sao cho VI cuûa U3 =2.73 + 0.01* t0C
Nhöng trong thöïc teá ñeå chính xaùc ,nhuùng LM335 vaøo nöôùc daù ñang tan
0
(0 C) . Chænh VR2 sao cho V2 cuûa U2 = 2.73V.
Thieát keá boä caûm bieán nhieät :
Taàm laøm vieäc trong heä thoáng maïch töø 0z1000C.
Ñeå ño nhieät ñoä chính xaùc phaûi coù caùc ñaàu ño ñaëc bieät. Ñaàu ño döôùi
daïng vi maïch LM335 laø moät ñaàu ño ñöôn giaûn vaø chính xaùc vôùi giaù thaønh laïi reû .
LM335 coù ñoä bieán thieân ñieän aùp theo nhieät ñoä laø 10mV/0K ,coù moät daõy ñoä chính xaùc
khaù cao vaø caûm bieán nhieät toát ôû nhieät ñoä 250C coù ñoä sai soá nhoû hôn 10C.vôùi taàm ño töø
nhieät ñoä 0z1000C, ngoõ ra cuûa caûm bieán naøy tuyeán tính.
•
•
•
•
•
Caùc tính chaát cuûa caûm bieán LM335 :
Chia ñoä tröïc teáp theo 0K
Ñoä chính xaùc ban ñaàu laø 10C
Trôû khaùng ñoäng < 1Ω
Taàm nhieät ñoä roäng .
Khoaûng ño 2000C
Taàm tuyeät ñoái lôùn nhaát :
Doøng ngöôïc 15mA
Doøng thuaän 10mA
Ñieän aùp hoaït ñoäng ngoõ ra ôû ñieàu kieän Tc=250C,IR =1nAtöông öùng
2.92z3.04V
Sai soá nhieät ôû 250C ôû ñieàu kieän Tmin<Tc<Tmax
<= > 1z20C
Ñieän aùp ngoõ ra hoaït ñoäng ôû ñieàu kieän 400µA<IR<5mA thì töông öùng töø
3z14mV.
Theo thoâng soá cuûa nhaø saûn xuaát IC LM335 coù ñoä bieán thieân ñieän aùp nhö sau:
V
00C (2730K ) aùp ra 2.73V
0
0
5 C (278 K ) aùp ra 2.78V
250C (2980K ) aùp ra 2.98V
3.73
VOUT
35
500C (3230K ) aùp ra 3.23V
1000C (3730K ) aùp ra 3.73V
3.23
2.98
2.78
2.73
+5V
Vout
LM335
273 278 298
323
373
VR
Nhö vaäy taàn bieán thieân ñieän aùp öùng vôùi nhieät ñoä töø 0z1000C laø 1V
Ñieän aùp ra töø boä caûm bieán LM335 theo coâng thöùc
VT (0K) = 2.73 =0.01T(0K) (mV)
Ñieän aùp ngoõ ra hoaït ñoäng ôû ñieàu kieän Tc =250C ,IR = 1mA
Maët khaùc : 400µA<IR<5mA
5V − 2.98V
< = > 400µA<
< 5mA
R2
<= > 1.8K <R2 < 22.5K
5V − 2.98V
maø R2 =
= 2.02 K
1mA
neân choïn R2 =2.2K vaø choïn moät bieán trôû VR2 =20K ñeå chænh tinh.
3 /Maïch hieån thò :
Tính giaù trò ñòeân trôû haïn doøng Rhd noái vôùi 74LS47 :
Moãi ñoaïn cuûa led caøn doøng khoaûng 10mA ñeå saùng , ñieän aùp rôi treân led khoaûng
Vled=2V . Nguoàng cung caáp Vcc = 5V. Caùc thoâng soá ngoõ ra cuûa IC7447 laø :
Vol = 0.4V, Iol = 40mA .
Giaû söû , ta muoán caùc led saùng vôùi moät doøng Iled =10mA vaäy :
Rhd= (Vcc – V LED – VOL)/ILED => RHD = (5V-1.8V –0.4V )/10mA Î RHD = 280Ω
thöïc teá khi thieát keá thöôøng cho moãi LED saùng vôùi doøng ILED töông öùng vôùi giaù trò
ñieän trôû haïn doøng laø: RHD =330Ω.
36
1
P0.
6
1
Q1
PNP
Rb
P0.
5
A101
5
Rb
1
A101
5
DISP1
P0.
P
00.
P0.
1
P0.
2
3
Rb
A101
5
DISP3
Gnd
Gnd
8
8
8
5
3
abcdefg.
U2
74LS47
A3
g
A2
f
A1
e
A0
d
c
b
a
test
RBI RBO
P0.
P
00.
P0.
1
P0.
2
3
5
3
abcdefg.
U1
74LS47
A3
g
A2
f
A1
e
A0
d
c
b
a
P0.
P
00.
P0.
1
P
20.
3
U3
74LS47
A3
g
A2
f
A1
e
A0
d
c
b
a
test
RBI RBO
test
RBI RBO
VCC
Tính giaù trò ñieän trôû RB noái vôùi A1015:
Xeùt ñieàu kieän ñeå transistor boaõ hoaø laø ;
I B >= βIC
Choïn β = 100 (A1015) taïi ngoõ ra cuûa IC8051 coù caùc thop6ng soá sau :
Iol = 3.2mA
Vol =0.45 V
Vaäy doøng IB naèm trong giôùi haïn sau :
Ic
Ic Ub
≤ Ib ≤ Iol hay
≤
≤ Iol
hfe
hfe Rb
Töø ñoù ta suy ra R:
Rb ≤
Ub Vcc − (Voh + Vγ ) 5V − (0.45 + 0.7 )V
=
= 1.203KΩ
=
Rb
Ib
0.0032
Choïn RB =1.2K Ω
Ω
37
4 – Maïch coâng suaát :
VCC
Q3
PNP
DISP2
Gnd
3
P0.
4
Q2
PNP
5
abcdefg.
Duøng coâng taéc ñieän töû ñeå ñoùng ngaét nguoàn ñieän cung caùp cho maïch ñieàu khieån
khi coù tín hieäu ngoõ vaøo P3.2 .Boä gheùp quang ñöôïc söû duïng vì söï caùch ly toát veà ñieän
giöõa maïch ñieàu khieån vaø maïch coâng suaát .
TAÛI
Nguyeân lyù laøm vieäc :
Tuyø theo ngoõ ra chaân P3.2 ôû möùc cao hay möùc thaáp maø transistor C828 ñoùng
hay môû cho pheùp doøng ñieän qua thoâng qua OPTO – TRIAC.
**********************************************************************
**********************************************************************
38
PHAÀNC :
CHÖÔNG1 :
THIEÁT KEÁ CHÖÔNG TRÌNH
GIAÛI THUAÄT CHÖÔNG TRÌNH
CHÖÔNG TRÌNH CHÍNH
Start
Naïp giaù tò ban ñaàu
P1.0 = 0 ?
P1.1= 0 ?
Taêng t0 ñaët
Y
N
Ktra t0 ñaët
< t0 max
Y
N
Taêng t0
Ktra t0 ñaët
>= t0 min
Y
Ñoïc ADC
Y
P1.2 =0 ?
Giaûm t0
Hieäu chænh
N
Hieån thò nhieät ñoä ño
39
Hieån thò nhieät ñoä ñaët
N
Giaûm t0
GIAÛI THUAÄT CHÖÔNG TRÌNH ÑOÅI SOÁ NHÒ PHAÂN RA BCD
Baét ñaàu
Chia soá caàn ñoåi cho 10
ñöôïc soá dö laø haøng ñôn vò.
Chia tieáp keát quaû cho
10 ñöôc soá chuc vaø traêm.
Caát keát quaû vaøo boä nhôù.
Thoaùt
40
GIAÛI THUAÄT XUAÁT LED
Baét ñaàu
Choïn döõ lieäu caàn hieån thò
Laáy maõ LED ñöa ra
LED choïn LED keá.
Thoaùt
41
GIAÛI THUAÄT CHÖÔNG TRÌNH ÑOÏC A/D
Baét ñaàu
Ñoïc döõ lieäu A/D
Chia soá ñoïc ñöôïc cho 2 ñeå
ñöôïc nhieät ñoä töông öùng
Ñoåi döõ lieäu ra soá BCD caát
vaøo RAM ôû caùc ñòa chæ
30H,31H,32H
Thoaùt
42
GIAÛI THUAÄT CHÖÔNH TRÌNH SO SAÙNH VAØ ÑIEÀU KHIEÅN
Baét ñaàu
Laáy nhieät ñoä ño tröø
nhieät ñoä ñaët
Ño < Ñaët
Caáp nguoàn cho phaàn
coâng suaát
Thoaùt
43
GIAÛI THUAÄT CHÖÔNG TRÌNH TAÊNG GIAÛM
Vaøo
Phím MOD coù nhaán
khoâng
YES
Taêng thoâng soá leân moät
ñôn vò
Giaûm thoâng soá
xuoáng moät ñôn vò
Phím taêng coù nhaán
khoâng ?
Phím giaûm coù nhaán
khoâng ?
Goïi chöông trình
hieån thò
44
NO
45
Download