Mạch nhỏ gọn, phù hợp với việc học tập nghiên cứu vềvi điều khiển và ứng
dụng của nó vào đời sống hằng ngày.
- Linh kiện phổbiến, dễdàng có thểthực hiện việc mô phỏng.
- Tiết kiệm nguồn điện bằng cách sửdụng nguồn máy tính, nguồn chuẩn 5v cho
mạch hoạt động.
- Thiết kếbằng phần mềm ORCAD thông dụng trong nghành điện tử.
25 trang |
Chia sẻ: lvcdongnoi | Lượt xem: 7998 | Lượt tải: 1
Bạn đang xem trước 20 trang tài liệu Đồ án Vi điều khiển: Thiết kế bộ đếm sản phẩm bằng cảm biến hồng ngoại gửi lên máy tính, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
1
ĐỒ ÁN MÔN HỌC VI ĐIỀU KHIỂN
Số: 10
STT Họ và tên sinh viên Lớp/Khóa Khoa
1 Nguyễn Đức Cường Điện tử 2_k2 Điện tử
2 Trương Đình Hà Điện tử 2_k2 Điện tử
Giáo viên hướng dẫn : Nguyễn Anh Dũng
............................................................................................................................
NỘI DUNG
1. Thiết kế bộ đếm sản phẩm bằng cảm biến hồng ngoại.
Yêu cầu:
- Mạch điện tử được thiết kế trên máy tính bằng phần mềm chuyên dụng.
- Số sản phẩm đếm được gửi lên máy tính và hiển thị bằng phần mềm tiện ích
Hyper Terminal.
- Số sản phẩm tối đa mà hệ thống có thể đếm được là một số thập phân bao gồm
12 chữ số.
2. Viết báo cáo về nội dung bài tập lớn.
Yêu cầu:
- Số trang: Từ 10 đến 20 trang giấy khổ A4.
- Nội dung báo cáo gồm 3 phần:
+ Phần 1: Cơ sở lý thuyết: Trình bày các cơ sở lý thuyết liên quan đến nội dung đồ án.
+ Phần 2: Nội dung: Trình bày trình tự và nội dung thiết kế.
+ Phần 3: Kết luận: Đánh giá các ưu, nhược điểm, tính thực tế của sản phẩm đã thiết kế
và hướng cải tiến, phát triển.
TT Tªn b¶n vÏ (nÕu cã) Khæ giÊy Sè l−îng
1 Sơ đồ mạch nguyên lý 1
2 Sơ đồ mạch in 1
PhÇn thuyÕt minh
- Đại diện nhóm vận hành và thuyết minh sản phẩm.
- 02 giảng viên chuyên môn chất vấn và chấm điểm từng sinh viên trong nhóm.
Thời gian tối đa (dành cho hỏi và trả lời): 10 phút/1 sinh viên.
Ngày giao đề : …………………………………. Ngày hoàn thành : ………………………………….
TRƯỞNG KHOA GIÁO VIÊN HƯỚNG DẪN
BỘ CÔNG THƯƠNG
TRƯỜNG ĐH CÔNG NGHIỆP HÀ NỘI
CỘNG HOÀ XÃ HỘI CHỦ NGHĨA VIỆT NAM
Độc lập - Tự do - Hạnh phúc
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
2
LỜI NÓI ĐẦU
Trong thời đại công nghệ phát triển mạnh mẽ, các thiết bị số đang có vai trò quan
trọng đối với công nghiệp và đời sống con người và đang dần chiếm ưu thế về số
lượng và chủng loại. Công nghệ số được ứng dụng trong nhiều lĩnh vực trong cộc
sống, chủ yếu làm các nhiêm vụ chính như : đo lường, điều khiển cơ cấu máy, truyền
thong giữa các thiết bị …tạo sự tiện dụng cho con người khi sử dụng các thiết bị điện
tử.
Với tính ưu việt của vi điều khiển đối với các hệ thống vừa và nhỏ thực hiện một
hoặc nhiều quá trình, trong đồ án này hệ thống vi điều khiển được dùng trong một lĩnh
vực thường gặp khi nói đến khi nhắc đến vi điều khiển : đếm sự kiện. Một trong
những ứng dụng của nó trong thực tế là phần đếm sản phẩm trong các dây truyền công
nghiệp ngày nay. Đồ án này có thể cải tiến thêm nhiều chức năng nữa cho phù hợp với
những dây truyền hiện đại và mục đích sử dụng của mạch như liên kết với cơ cấu để
có thể xếp đủ sản phẩm vào một thùng, hay đếm số thùng trong một lô hàng, nó cũng
có thể lưu lại dữ liệu của một ca làm việc tiện cho việc kiểm tra bảo mật…
Đồ án đã được thực hiện nhằm làm rõ hơn bản chất của vi điều khiển đối với việc
điều khiển một quá trình và bản chất cấu thành của một hệ thống vi điều khiển. Từ
kiến thức đã học đồng thời tham khảo thêm thông tin từ nhiều nguồn cùng với sự trợ
giúp của thầy cô và bạn bè, tuy vậy với vốn kiến thức có hạn không tránh khỏi những
thiếu sót khi thực hiện. Mong các thầy cô và mọi người góp ý cho đề tài này thêm
hoàn chỉnh.
Qua đây, xin cám ơn thầy giáo Nguyễn Anh Dũng đã giúp chúng em thực hiện
đồ án này.
Xin cảm ơn !
Nhóm sinh viên ĐT2K2
Dcn_105
Nguyễn Đức Cường – Trương Đình Hà
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
3
PHẦN I :
MẠCH ĐẾM SẢN PHẨM VÀ CÁC LINH KIỆN SỬ DỤNG
I. MẠCH ĐẾM SẢN PHẨM
Ngày nay, cùng với sự phát triển của khoa học kỹ thuật nói chung và kỹ thuật
điện tử nói riêng. Kỹ thuật số đóng vai trò quan trọng trong mọi lĩnh vựckhoa học kỹ thuật , quản
lý, công nghiệp hóa tự động hóa. Do đó chúng ta phải nắm bắt vận dụng nó một cách hiệu quả
nhằm góp phần vào sự phát triển của nền khoa học kỹ thuật thế giới nói chung và phát triển của
kỹ thuật điện tử nói chung.
Việc áp dụng lĩnh vực điện tử vào nghành sản xuất sản phẩm gia dụng trong nhà và các hệ
thống quản lý sản xuất đang được đưa vào ứng dụng rộng rãi hơn và phù hợp với chức năng cụ
thể của nó làm tăng năng suất làm việc cho dây truyền làm việc. Phù hợp với tiến trình công
nghiệp hóa hiện đại hóa nền công nghiệp nước ta.
Trong thực tế các nhà máy sản xuất lớn đã ứng dụng việc đếm sản phẩm trong khâu đóng gói
sản phẩm bằng các mạch điện tử làm tăng năng suất lao động và giảm chi phí nhân công, tự động
hóa dây truyền công nghiệp, chính xác hóa trong sản phẩm.
Mạch đếm sản phẩm mà chúng em được giao làm đồ án mô phỏng một hệ thống đếm sản phẩm
của dây truyền công nghiệp. Với đề tài này chúng em chọn mạch đếm sản phẩm dùng 89s52 một
trong những dòng vi xử lý mà chúng em đã được học trong môn vi điều khiển với những linh
kiện nhỏ gọn thực hiện viêc đếm sản phẩm. Linh kiện hồng ngoại được chọn trong mạch là thu
phát hồng ngoại tích hợp 2 trong 1 nhằm đảm bảo sự gọn nhẹ cho mạch mô phỏng. Phần giao
tiếp máy tính dùng Max232 để đồng bộ tín hiệu giữa mạch với máy tính (đồng bộ điện áp).
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
4
II. Giới thiệu linh kiện sử dụng.
1. Giới thiệu về 89s52.
89S52 là một vi điều khiển thông dụng giá rẻ và có nhiều tính năng hay,đặc biệt là có tích
hợp mạch nạp ISP trên chíp giúp người sử dụng có thể dễ dàng thực hiện các thí nghiệm với
chi phí thấp.
AT89S52 gồm các chức năng chính sau:
* CPU gồm:
- Thanh ghi tích lũy A;
- Thanh ghi tích lũy phụ B,dùng cho phép nhân và phép chia;
- Đơn vị logic học (ALU: Arithmetic Logical Unit);
- Thanh ghi từ trạng thái chương trình (PSW: Programe Status Word);
- Bốn băng thanh ghi;
- Con trỏ ngăn xếp.
* Bộ nhớ chương trình (bộ nhớ ROM) gồm 8kbyte Flash.
* Bộ nhớ dữ liệu (bộ nhớ RAM) gồm 256 byte.
* Bộ UART (Universal Ansynchronous Receiver and Transmitter) có chức năng truyền nhận
nối tiếp, AT89S52 có thể giao tiếp với cổng nối tiếp của máy tính thông qua bộ UART.
* 3 bộ Timer/Counter 16 bit thực hiện chức năng định thời và đếm sự kiện.
* WDM (Watch Dog Timer): WDM được dùng để phục hồi lại hoạt động của CPU khi nó bị
treo bởi nguyên nhân nào đó.
* Khối điều khiển ngắt với 2 nguồn ngắt ngoài và 4 nguồn ngắt trong.
* Bộ lập trình (ghi chương trình lên Flash ROM) cho phép người sử dụng có thể nạp chương
trình cho chíp mà không cần các bộ nạp chuyên dụng.
* Bộ chia tần số với hệ số chia la 12.
* 4 cổng xuất nhập với 32 chân.
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
5
Sơ đồ khối :
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
6
1.1. Port 0 (P0.0->P0.7)
Ngoài chức năng xuất nhập, Port 0 còn là bus đa hợp dữ liệu và địa chỉ,chức năng này sẽ
được sử dụng khi giao tiếp với các thiết bị ngoài có kiến trúc như các vi mạch nhớ.
1.2. Port 1 (P1.0->P1.7)
Chức năng duy nhất của Port 1 là chức năng xuất nhập dữ liệu cũng như các Port khác.
Port có thể xuất nhập dữ liệu theo bit hoặc theo byte. Có 3 chân P1.5,P1.6,P1.7 được dùng để
nạp ROM theo chuẩn ISP; hai chân P1.0,P1.1 được dùng cho bộ timer2.
1.3. Port 2 (P2.0->P2.7)
Ngoài chức năng là cổng xuất nhập còn là byte cao của bus địa chỉ khi sử dụng bộ nhớ
ngoài.
1.4.Port 3(P3.0->P3.7)
Mỗi chân trên Port 3 ngoài chức năng xuất nhập còn có một chức năng riêng cụ thể khác:
Bit Tên Chức năng
P3.0 RXD Dữ liệu nhận cho port nối tiếp
P3.1 TXD Dữ liệu truyền cho port nối tiếp
P3.2 INT0 Ngắt bên ngoài 0
P3.3 INT1 Ngắt bên ngoài 1
P3.4 T0 Ngõ vào của counter/timer 0
P3.5 T1 Ngõ vào của counter/timer 1
P3.6 /WR Xung ghi bộ nhớ dữ liệu ngoài
P3.7 /RD Xung đọc dữ liệu từ bộ nhớ ngoài hoặc thiết bị ngoại vi
1.5 Chân /PSEN (Program Store Enable)
Là chân điều khiển đọc chương trình ở bộ nhớ ngoài, nó được nối với chân /OE để cho
phép đọc các byte mã lệnh trên ROM ngoài. /PSEN sẽ ở mức thấp trong thời gian đọc mã
lệnh. Mã lệnh được đọc từ bộ nhớ ngoài qua bus dữ liệu (Port 0) , thanh ghi lệnh để được giải
mã.
Khi thực hiện chương trình trong ROM nội thì /PSEN ở mức cao.
1.6 Chân /ALE (Adress Latch Enable)
ALE là tín hiệu điều khiển chốt địa chỉ có tần số bằng 1/6 tần số dao động của vi điều
khiển. Tín hiêu ALE được dùng cho phép vi mạch chốt bên ngoài như 74373,74573, chốt
byte địa chỉ thấp ra khỏi bus đa hợp địa chỉ/ dữ liệu (Port 0).
1.7 Chân /EA (External access)
Tín hiệu /EA cho phép chọn bộ nhớ chương trình là bộ nhớ trong hay ngoài vi điều khiển.
Nếu /EA ở mức cao (đối với VCC ) thì vi điều khiển thi hành chương trình trong ROM nội.
Nếu /EA ở mức thấp (đối với GND) thì vi điều khiển thi hành chương trình từ bộ nhớ ngoài.
1.8 Chân /RST (Reset)
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
7
Ngõ vào /RST trên chân 9 là ngõ reset của 8051. Khi tín hiệu này ở mức cao (trong ít
nhất 2 chu kỳ máy) các thanh ghi trong bộ vi điều khiển được tải những giá trị thích hợp để
khởi động hệ thống.
1.9 Chân /XTAL1, /XTAL2
AT89S52 có một bộ dao động trên chíp,nó thường được nối với bộ dao động thạch anh
có tần số lớn nhất là 33 MHz, thông thường là 12MHz.
1.10 Chân /VCC và /GND
89S52 dùng nguồn một chiều có dải điện áp từ 4v đến 5.5v được cấp qua chân 40 và 20.
1.11 Bộ định thời/bộ đếm(timer/counter)
8051 có 2timer là timer0 và timer1.Các timer này đều là timer 16bit,giá trị đếm max do
đó bằng 65536(đếm từ 0 đến 65335).
Hai timer có nguyên lý hoạt động hoàn toàn giống nhau và độc lập.Sau khi cho phép
chạy,mỗi khi có thêm một xung tại đầu vào đếm,giá trị của timer sẽ tự động được tăng thêm
1đơn vị,cứ như vậy cho đến khi giá trị tăng lên vượt quá giá trị max mà thanh ghi đếm có thể
biểu diễn thì giá trị đếm lại được đưa về giá trị min(thông thường min=0).Điều này được hiểu
là tràn timer (overflow) và có thể gây ra ngắt nếu ngắt tràn timer được cho phép.
Việc cho timer chạy/dừng được thực hiện bởi các bit TR trong thanh ghi TCON 9 (đánh
địa chỉ đến từng bit).
7 6 5 4 3 2 1 0
Khi bit TRx =1,timer x sẽ đếm,ngược lại khi TRx =0,timer sẽ không đếm mặc dù vẫn có
xung đưa vào.Khi dừng không đếm,giá trị của timer được sẽ giữ nguyên.
Các bit TFx là các cờ báo tràn timer.khi sự tràn timer xảy ra,cờ sẽ được tự động đặt lên 1
và nếu ngắt tràn timer được cho phép,ngắt sẽ xảy ra.Khi CPU xử lý ngắt tràn timerx,cờ ngắt
TFx tương ứng sẽ tự động được xóa về 0.
Giá trị đếm 16bit của timer được lưu trong hai thanh ghi THx (byte cao) và TLx (byte
thấp).Hai thanh ghi này có thể ghi/đọc được bất kỳ lúc nào.Tuy nhiên nhà sản xuất khuyến
cáo rằng nên dừng timer (cho bit TRx=0) trước khi ghi/đọc các thanh ghi chứa giá trị đếm.
Các thanh ghi có thể hoạt động ở nhiều chế độ,được quy định bởi các bit trong thanh ghi
TMOD (không đánh địa chỉ đến từng bit).
7 6 5 4 3 2 1 0
TF1 TR1 TF0 TR0 IE1 IT1 IE0 IT0
GATE1 C/T1# M1 M0 GATE0 C/T0# M1 M0
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
8
Để xác định thời gian,người ta chọn nguồn xung nhịp (clock) đưa vào đếm trong timer là
xung nhịp bên trong (dành cho CPU).Nguồn xung nhịp này thường rất đều đặn (có tần số ổn
định),do đó từ số đếm của timer người ta có thể nhân với chu kỳ xung nhịp để tính thời gian
trôi qua.Timer lúc này được gọi chính xác với cái tên “timer” ,tức bộ định thời.
Để đếm các sự kiện bên ngoài,người ta chọn nguồn xung nhịp đưa vào đếm trong timer là
tín hiệu từ bên ngoài (đã được chuẩn đoán về dạng xung vuông 0V/5V).Các tín hiệu này sẽ
được nối với các bit cổng có dồn kênh thêm các tính năng T0/T1/T2.Khi có sự kiện bên
ngoài gây ra thay đổi mức xung ở đầu vào đếm,timer sẽ tự động tăng lên 1 đơn vị giống như
trường hợp đếm xung nhịp bên trong.Lúc này timer được gọi với cái tên chính xác
khác:”counter”,tức đếm (sự kiện).
Nhìn vào bảng mô tả thanh ghi TMOD bên trên,ta có thể nhận thấy có hai bộ 4bit giống
nhau (gồm GATEx,C/Tx,Mx0 và Mx1) dành cho hai timer 0 và 1.Ý nghĩa các bit là như
nhau đối với mỗi timer.
Bit GATEx quy định việc cho phép timer đếm (run timer).Nếu GATEx=0,timer x sẽ đếm
khi bit TRx bằng 1,dừng khi bit TRx = 0.Nếu GATEx =1,timer x sẽ chỉ đếm khi bit TRx=1
và tín hiệu tại chân INTx=1,dừng khi một trong hai điều kiện trên không còn thỏa
mãn.Thông thường người ta dùng timer với GATE =0,chỉ dùng timer với GATE =1 khi
muốn đo độ rộng xung vì lúc đó timer sẽ chỉ đếm thời gian khi xung đưa vào chân INTx ở
mức cao.
Bit C/Tx quy định nguồn clock đưa vào đếm trong timer .Nếu C/Tx=0,timer sẽ được cấu
hình là bộ định thời,nếu C/Tx=1,timer sẽ được cấu hình là bộ đếm sự kiện.
Bít Tên Timer Mô tả
7 GATE1 1 Bit mở cổng cho timer 1,khi được đặt bằng 1 thì timer 1
chạy khi chân INT1 ở mức cao.Nếu bit này được là 0 thì
hoạt động của timer 1 không bị ảnh hưởng bởi mức logic
trên chân INT1.
6 C/T1# 1 Bit chọn chế độ counter/timer của timer 1.
1=bộ đếm sự kiện.
0=bộ định khoảng thời gian
5 M1 1 Bit 1 chọn chế độ (mode) của timer 1
4 M0 1 Bit 0 chọn chế độ của timer 1.
00:chế độ 0 – timer 13bit
01:chế độ 1 – timer 16bit
10:chế độ 2 – 8bit tự động nạp lại
11:chế độ 3 – tách timer
3 GATE0 0 Bit mở cổng cho timer 0,khi được đặt bằng 1 timer 0 chỉ
hoạt động khi chân INT0 ở mức cao.
2 C/T0# 0 Bit chọn chế độ counter/timer của timer 0
1 M1 0 Bit 1 chọn chế độ của timer 0
0 M0 0 Bit 0 chọn chế độ của timer 0
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
9
Hai bit còn lại (Mx0 và Mx1) tạo ra tổ hợp 4 gía trị (00,01,10,11) ứng với 4 chế độ hoạt
động khác nhau của timer x.Trong 4 chế độ đó thường chỉ dùng chế độ timer/counter 16bit
(Mx1=0,Mx0=1) và chế độ Auto Reload 8bit timer/couter (Mx1=1,Mx0=0).
Trong chế độ timer/couter 16 bit, gia trị đếm (chứa trong 2 thanh ghi THx và TLx) tự
động được tăng lên 1 đơn vị mỗi lần nhận được thêm 1 xung nhịp. Khi giá trị đếm vượt quá
giá trị max = 65535 thì sẽ tràn về 0, cờ ngắt TFx được tự động đặt =1.
Chế độ này được dùng trong các ứng dụng đếm thời gian và đếm sự kiện.
Trong chế độ auto reload 8 bit giá trị đếm sẽ chỉ được chứa trong thanh ghi TRx, còn giá
trị của thanh ghi THx bằng một số n (0->255) do người lập trình đưa vào. Khi có thêm một
xung nhịp, giá trị đếm trong TLx đương nhiên cũng tăng lên 1 đơn vị như bình thường. Tuy
nhiên trong trường hợp này giá trị đếm lớn nhất = 255 chứ không phải = 65535 như trường
hợp trên vì timer/counter chỉ còn 8 bit. Do vậy sự kiện tràn lúc này xảy ra nhanh hơn, chỉ cần
vượt quá 255 là giá trị đếm sẽ tràn. Cờ ngắt TFx vẫn được đặt bằng 1 như trong trường hợp
tràn 16 bit. Điểm khác biệt là thay vì tràn về 0 giá trị THx sẽ được tự động nạp lại vào thanh
ghi TLx, do đó timer/counter sau khi tràn sẽ có giá trị bằng n và đếm từ giá trị n trở đi. Chế
độ này được dùng trong việc tạo Baud rate cho truyền thông qua cổng nối tiếp.
Để sử dụng timer của 8051,ta thực hiện theo các bước sau:
- Quy định chế độ hoạt động cho timer bằng cách tính toán và ghi giá trị cho các bit
trong thanh ghi TMOD.
- Ghi giá trị đếm khởi đầu mong muốn vào hai thanh ghi đếm THx và TLx. Đôi khi ta
không muốn timer/counter bắt đầu đếm từ 0 mà từ một giá trị nào đó để thời điểm
tràn gần hơn,hoặc chẵn hơn trong tính toán sau này.Ví dụ,nếu cho timer đếm từ
15535 thì sau 50000 xung nhịp (tức 50000 micro giây với thạch anh 12MHz) timer sẽ
tràn,và thời gian 1giây có thể dễ dàng tính ra khá chính xác =20 lần tràn của timer
(đương nhiên mỗi lần tràn lại phải nạp lại giá trị 15535).
- Đặt mức ưu tiên ngắt và cho phép ngắt tràn timer (nếu muốn).
- Dùng bit TRx trong thanh ghi TCON để cho timer chạy hay dừng theo ý muốn.
1.12 Cổng vào ra nối tiếp (Serial Port)
Cổng nối tiếp trong 8051 chủ yếu được dung trong các ứng dụng có yêu cầu
truyền thông với máy tính,hoặc một vi điều khiển khác.Liên quan đến cổng nối tiếp chủ
yếu có hai thanh ghi :SCON và SBUF.Ngoài ra một thanh ghi khác là thanh ghi PCON
(không đánh địa chỉ bit) có 7bit tên là SMOD quy định tốc độ truyền của cổng nối tiếp có
gấp đôi lên (SMOD = 1) hay không (SMOD = 0).
Dữ liệu được truyền nhận nối tiếp thông qua hai chân cổng P3.0 (RXD) và P3.1
(TXD).
Thanh ghi SBUF là thanh ghi 8bit chứa dữ liệu truyền hoặc nhận.Về thực chất có
hai thanh ghi dữ liệu khác nhau,một để chứa dữ liệu truyền đi,một để chứa dữ liệu nhận
được.Cả hai thanh ghi này đều có chung tên SBUF,tuy nhiên CPU hàon toàn phân biệt
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
10
được một cách dễ dàng.Khi ta muốn truyền dữ liệu đi,ta phải ghi vào thanh ghi SBUF (ví
dụ viết lệnh mov SBUF ,a) còn khi muốn đọc,kiểm tra dữ liệu nhận ta phải ghi vào thanh
ghi SBUF (ví dụ viết lệnh mov a,SBUF).CPU sẽ căn cứ vào việc thanh ghi SBUF nằm ở
vị trí toán hạng đích (toán hạng bên trái) hay toán hạng nguồn (toán hạng bên phải) để
quyết định sẽ truy nhập (đọc/ghi) thanh ghi SBUF nào.Người lập trình không cần phải
quan tâm xử lý vấn đề này.
Thanh ghi quy định chế độ hoạt động và điểu khiển cổng nối tiếp là thanh ghi
SCON (đánh địa chỉ bit).
Bit SM0,SM1,SM2 quy định chế độ hoạt động của cổng nối tiếp.Thông
thường để truyền thông giữa hai vi điều khiển hoặc giữa một vi điều khiển và một máy
tính,giá trị của bit SM2 được đặt bằng 0.Khi truyền thông theo kiểu mạng đa vi xử lý
(multiprocessor communication),SM2 được đặt bằng 1.Hai bit SM0 và SM1 thực sự là
các bit quy định chế độ hoạt động của cổng nối tiếp,chúng tạo ra 4 tổ hợp (00,01,10 và
11) ứng với 4 chế độ hoạt động mô tả trong bảng sau:
Chế độ 0: là chế độ truyền đồng bộ duy nhất .Chân RXD sẽ là tín hiệu truyền nhận dữ
liệu, chân TXD là tín hiệu xung nhịp.Bit LSB (bit 0) của dữ liệu được truyền đi trước
tiên.Tốc độ truyền cố định và bằng 1/12 giá trị thạch anh.
Chế độ 1: là chế độ truyền dị bộ 8bit.Dữ liệu 8bit được đóng khung bởi 1bit Star (=0) ở
đầu và bit Stop (=1) ở cuối trước khi dữ liệu được truyền đi.Tốc độ truyền có thể thay đổi
theo ý người lập trình.
Chế độ 2: là chế độ truyền dị bộ 9 bit.Dữ liệu truyền 9 bit được ghép thành bởi 8 bit trong
thanh ghi SBUF và bit RB8 (trường hợp nhận về) hoặc TB8 (trường hợp truyền đi) trong
thanh ghi SCON.Ngoài ra các bit Star và Stop vẫn được gắn bình ở đầu và ở cuối khung
truyền.Trong chế độ này,tốc độ truyền chỉ chọn 1 trong 2 mức :1/32 hoặc 1/64 giá trị của
thạch anh.
Chế độ 3: cũng là chế độ truyền dị bộ 9bit,khác với chế độ 2 ở chỗ tốc độ truyền có thể
thay đổi được theo ý người lập trình như chế độ 1.
Bit REN trong thanh ghi SCON là bit cho phép nhận dữ liệu.Dữ liệu chỉ được nhận qua
cổng nối tiếp khi bit này bằng 1.
Bit TB8 là bit dữ liệu thứ 9 trong trường hợp truyền đi 9bit (8 bit kia trong thanh ghi
SBUF).
SM0 SM1 SM2 REN TB8 RB8 TI RI
SM0 SM1 Chế độ Khung dữ liệu Baud rate
0 0 0 - đồng bộ 8bit SBUF Fosc/12
0 1 1 - dị bộ 8bit SBUF Thay đổi được
1 0 2 - dị bộ 8bit SBUF + RB8/TB8 Fosc/32 hoặc Fosc/64
1 1 3 - dị bộ 8bit SBUF + RB8/TB8 Thay đổi được
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
11
Bit RB8 là bit dữ liệu thứ 9 trong trường hợp nhận về 9bit (8 bit kia trong thanh ghi
SBUF).
Bit TI là cờ ngắt truyền,báo hiệu việc truyền 1khung dữ liệu đã hoàn tất.
Bit RI là cờ ngắt nhận,báo hiệu việc nhận 1khung dữ liệu đã hoàn tất.
Để tạo ra tốc độ truyền (Baud rate) của cổng nối tiếp trong 8051,phải dùng đến timer 1 ở
chế độ Auto Reload 8bit.Giá trị nạp lại chứa trong thanh ghi TH1 được tính toán theo
công thức sau (phụ thuộc vào Baud rate mong muốn và giá trị của thạch anh)
Tóm lại để sử dụng cổng nối tiếp của 8051,ta thực hiện theo các bước sau:
- Chọn chế độ cho cổng nối tiếp (đồng bộ/dị bộ,8bit/9bit…) từ đó chọn được giá trị cho
các bit trong thanh ghi SCON.Lưu ý xoá các bit TI và RI.
- Chọn tốc độ truyền mong muốn,từ đó tính ra giá trị của thanh ghi TH1.Cho timer 1
chạy ở chế độ Auto Reload 8bit (không dung ngắt tràn timer 1).
- Đặt mức ưu tiên ngắt và cho phép ngắt cổng nối tiếp nếu muốn.
- Bắt đầu truyền dữ liệu bằng một lệnh ghi dữ liệu muốn truyền vào thanh ghi
SBUF.Quá trình truyền kết thúc thì cờ TI tự động đặt lên 1.
- Khi một khung dữ liệu đã được nhận đầy đủ ,cờ RI sẽ tự động đặt lên và người lập
trình lúc này có thể dùng lệnh đọc thanh ghi SBUF để lấy dữ liệu nhận được ra xử lý.
1.13 Ngắt (interrupt)
8051 chỉ có một ssó lượng ít các nguồn ngắt (interrupt source),hoặc có thể gọi là nguyên
nhân ngắt.Mỗi ngắt sẽ có một vector ngắt riêng, đó là một địa chỉ cố định nằm trong bộ
nhớ chương trình.Khi ngắt xảy ra,CPU sẽ tự động nhảy đến thực hiện lệnh tại địa chỉ
này.Bảng tóm tắt các ngắt trong 8051 như sau:
STT Tên ngắt Mô tả Cờ ngắt Thanh ghi
chứa cờ
Vector ngắt
1 INT0 Ngắt ngoài 0 khi
có tín hiệu tích cực
thao kiểu đã chọn
ở chân P3.2 .
IE0 TCON 0x0003
2 Timer 0 Ngắt tràn timer 0
khi giá trị timer 0
tràn từ giá trị max
về min.
TF0 TCON 0x000B
3 INT1 Ngắt ngoài 1 khi
có tín hiệu tích cực
IE1 TCON 0x0013
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
12
thao kiểu đã chọn
ở chân P3.3.
4 Timer 1 Ngắt tràn timer 1
khi giá trị timer 1
tràn từ giá trị max
về min
TF1 TCON 0x001B
5 Serial
Port
Ngắt cổng nối tiếp
khi vi điều khiển
nhận hoặc truyền
xong 1byte bằng
cổng nối tiếp
TI,RI SCON 0x0023
Liên quan đến ngắt chủ yếu có 2 thanh ghi là thanh ghi cho phép ngắt IE và thanh ghi ưu
tiên ngắt IP.
- Thanh ghi cho phép ngắt IE (Interrupt Enable):
EA - ET2 ES ET1 EX1 ET0 EX0
Để cho phép một ngắt xảy ra,bit tương ứng với ngắt đó và bit EA phải được dặt
bằng 1.Thanh ghi IE là thanh ghi đánh địa chỉ từng bit,do đó có thể dùng các lệnh tác
động bit để tác động riêng rẽ lên từng bit mà không ảnh hưởng đến giá trị các bit khác.Cờ
ngắt hoạt động độc lập với việc cho phép ngắt, điều đó có nghĩa là cờ ngắt sẽ tự động đặt
lên bằng 1 khi có sự kiện ngắt xảy ra,bất kể sự kiện đó có được cho phép ngắt hay
không.Do vậy,trước khi cho phép một ngắt,ta nên xoá cờ của ngắt đó để đảm bảo sau khi
cho phép,các sự kiện gây ngắt trong quá khứ không thể gây ngắt nữa.
- Thanh ghi ưu tiên thứ tự ngắt IP (Interrupt Priority):
Các bit trong thanh ghi IP tương ứng với các ngắt đúng như trong thanh ghi IE
(bit PX0 dành cho ngắt ngoài 0,bit PT0 dành cho ngắt timer 0…)
Một điều dễ nhận thấy là một ngắt được đặt mức ưu tiên cao (bit tương ứng trong thanh
ghi IP bằng 1) thì sẽ không có ngắt nào xen vào quá trình xử lý nó được nữa.
Nói về mức ưu tiên ngắt,có thể dùng một ví dụ tổng quát sau,giả sử hai ngắt timer 0 và
ngắt cổng nối tiếp cùng được cho phép (các bit tương ứng và bit EA trong thanh ghi IE
được đặt bằng 1),bit PT0 =0,bit PS =1 thì:
- Nếu hai ngắt cùng xảy ra ,ngắt timer 0 sẽ được xử lý trước.
- Nếu ngắt cổng nối tiếp xảy ra trước và đang được xử lý thì ngắt timer 0 nếu có xảy ra
cũng không thể chen vào,làm dừng quá trình xử lý cổng nối tiếp được.
- Nếu ngắt timer 0 xảy ra trước và đang được xử lý ngắt mà ngắt cổng nối tiếp xảy ra
thì CPU sẽ phải dừng việc xử lý ngắt timer 0 lại,chuyển sang xử lý ngắt cổng nối
tiếp,xử lý xong mới quay lại xử lý tiếp ngắt timer 0.
- - PT2 PS PT1 PX1 PT0 PX0
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
13
Như đã biết,8051 có hai ngắt ngoài là INT0 và INT1.Ngắt ngoài được hiểu là ngắt được gây ra
bởi sự kiện mức logic 0 (mức điện áp thấp,gần 0V) hoặc sườn xuống (sự chuyển mức điện áp từ
mức cao về mức thấp) xảy ra ở chân ngắt tương ứng (P3.2 với ngắt ngoài 0 và P3.3 với ngắt
ngoài 1).Việc lựa chọn kiểu ngắt được thực hiện bằng bảng các bit IT (Interrupt type) nằm trong
thanh ghi TCON. Đây là thanh ghi điều khiển timer nhưng 4bit LSB được dung cho ngắt ngoài.
7 6 5 4 3 2 1 0
TF1 TR1 TF0 TR0 IE1 IT1 IE0 IT0
Khi bit ITx =1 thì ngắt ngoài tương ứng được chọn là kiểu ngắt theo sườn xuống,ngược
lại nếu bit ITx=0 thì ngắt ngoài tương ứng sẽ là kiểu ngắt theo mức thấp.Các bit IE là các bit cờ
ngắt ngoài,chỉ có tác dụng trong trường hợp kiểu ngắt được chọn là ngắt theo sườn xuống.
Khi kiểu ngắt theo sườn xuống được chọn thì ngắt sẽ xảy ra duy nhất 1lần khi có sườn
xuống của tín hiệu.Sau đó khi tín hiệu ở mức thấp,hoặc có sườn lên,hoặc ở mức cao thì cũng
không có ngắt xảy ra cho đến khi có sườn xuống tiếp theo.Cờ ngắt IE sẽ được dựng lên khi có
sườn xuống và tự động bị xoá khi CPU bắt đầu xử lý.
Khi kiểu ngắt theo mức thấp được chọn thì ngắt sẽ xảy ra bất cứ khi nào tín hiệu tại chân
ngắt ở mức thấp.Nếu khi xử lý xong ngắt mà tín hiệu vẫn ở mức thấp thì lại ngắt tiếp,cứ như vậy
cho đến khi xử lý xong ngắt n,tín hiệu đã lên mức cao rồi thì thôi,không ngắt nữa.Cờ IE trong
trường hợp này không có ý nghĩa gì cả.
Thông thường kiểu ngắt hay được chọn là ngắt theo sườn xuống.
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
14
2. Max 232
Khi giao tiếp với máy tính, bài toán đặt ra là tín hiệu của ic 89s52 không tương thích điện áp với
tín hiệu điện áp trong máy tính. để giải quyết vấn đề này ta dùng ic max232.
Cổng com trong máy tính có mức 0 ở 3 đến 12v còn mức 1 là -12 đến -3v. Tuy nhiên, đối với ic
89s52 mức 1 là 2.4 đến 5v, mức âm là 0 đến 0.45 v. Max232 chính là một ic biến đổi điện áp cho
chúng có thể giao tiếp với nhau.
Khi đặt đồng bộ hóa giữ máy tính với vi điều khiển về điện áp và tần số dao động thì chúng có
thể truyền dữ liệu cho nhau.
3. Thu phát hồng ngoại và mạch so sánh điện áp dùng LM393
- Mắt hồng ngoại gồm 1 led phát hồng ngoại và một transistor được kích mở bằng hồng ngoại từ
led phát. Khi đưa cấp nguồn cho led hồng ngoại sẽ có tín hiệu hồng ngoại đến chân B của
transistor thu làm transistor thông. Mức logic trên chân C (chân 3) là bằng 0. Nếu che khuất led
phát( sản phẩm đi qua) thì mức logic là 1 ở chân C (chân 3).
- LM393 là linh kiện dùng để so sánh điện áp. Nó là một OPAM làm việc như một bộ so sánh
điện áp, tạo điện áp chuẩn khi giao tiếp giữa mạch cảm biến với ic 89s52.
Khi cảm biến hộng ngoại bị che khuất (có sản phẩm đi qua) đầu ra của bộ khuếch đại thuật toán
chuyển mức từ 1 xuông 0 gây ngắt ngoài theo sườn âm ở chân INT0.
- Hoạt động :
+ Bình thường, khi không có vật chắn transistor luôn dẫn cực E và cực C của
transistor luôn thông với nhau.mức logic trên chân C (chân 3) cũng như trên chân
2 của OPAM là mức 0. Mức logic đầu vào 3 của OPAM luôn ở mức 2.5v mọi
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
15
lúc(vì qua cầu phân áp) cho nên đầu ra OPAM là ở mức cao. Không gây ngắt cho
chân INT0.
+ Khi có vật chắn,cực C của transistor thu có mức logic 1(bằng 5v) lớn hơn mức
logic ở chân 3 OPAM nên đầu ra OPAM có mức logic 0.Sự thay đổi mức từ 1
sang 0 làm ngắt ngoài ở chân INT0.
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
16
sơ đồ mạch hồng ngoại và bộ so sánh dùng OPAM Lm393
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
17
Phần II :
MẠCH ĐIỆN VÀ CHƯƠNG TRÌNH
I. MẠCH ĐỒ ÁN
1. Mạch nguyên lý :
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
18
2. Mạch in :
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
19
4. Hình ảnh đồ án :
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
20
II. CHƯƠNG TRÌNH ĐỒ ÁN
1. Lưu đồ khởi tạo chương trình :
Bắt đầu
Lựa chọn chế độ SCON
Đặt tần số baud rate (timer1 mode 2)
Cho phép ngắt nối tiếp và ngắt ngoài
Ưu tiên ngắt nối tiếp
Chờ ngắt ngoài INT0
Gửi kết quả
Thoát
Chọn kiểu ngắt sườn
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
21
2. Lưu đồ ngắt ngoài :
3. Lưu đồ truyền nối tiếp :
vào ngắt
tăng biến đếm
Biến đếm= biến đếm max ?
biến đếm = 0
Thoát
vào
thoát
Xóa cờ TI
nếu RI=1? Xóa cờ RI
nhận dữ liệu
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
22
4. Chương trình :
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Truong dai hoc cong nghiep ha noi //
// DH Dien Tu 2 - k2 //
// //
// chuong trinh thiet ke mach diem san pham bang hong ngoai gui ket qua len may tinh //
// //
// nhom sinh vien thuc hien : //
// NGUYEN DUC CUONG - TRUONG DINH HA //
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//======================================================
// khai bao thu vien
#include
#include
//======================================================
// khai bao hang so va hàm con
unsigned int count,i,j;
void delay(unsigned int);
//=====================================================
//chuong trinh chinh
void main ()
{
SCON = 0x52; // cong noi tiep hoat dong o che do 1
TMOD = 0x21; // timer1 hoat dong o che do 2-8 bit tu nap lai,timer 0
hoat dong che do 1,16 bit nap lai bang phan mem.
TH1=TL1 = -3; // tao toc do duong truyen cho cong noi tiep baud=9600
TR1 = 1 ; // de timer 1 bat dau hoat dong
IT0 = 1; // cho phep ngat suon am
IE = 0x91; // cho phep ngat toan bo va cho phep ngat port
noi tiep,cho phep ngat ngoai 0,
IP = 0x10; // uu tien ngat cong noi tiep
count=0; // ban dau so san pham la 0
putchar(0x0c);
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
23
puts(" ---------DAI HOC CONG NGHIEP HA NOI 11/2009--------- ");
puts(" ----DO AN VI DIEU KHIEN LOP DH DIEN TU2_K2---- ");
puts(" THIET KE DEM SAN PHAM BANG HONG NGOAI GUI KET
QUA LEN MAY TINH " );
puts(" THUC HIEN : NGUYEN DUC CUONG - TRUONG DINH HA ");
delay(5);
puts (" THIET BI SAN SANG ");
delay(2);
while(1)
{
putchar(0x0c);
printf("SO SAN PHAM DEM DUOC LA:%d\n", count);
delay(2);
}
}
//=============================================
// ham ngat ngoai 0
void ngatngoai0( ) interrupt 0
{
count++;
}
//=============================================
//ham delay(tre)
void delay(unsigned int n)
{
for(j=0;j<(n*10);j++)
{
TH0=-50000/256;
TL0=-50000%256;
TR0=1;
while(!TF0);
{
TF0=0;
TR0=0;
}
}
}
//=============================================
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
24
PHẦN III : KẾT LUẬN
Ưu nhược điểm, tính thực tế của sản phẩm và hướng cải tiến sản phẩm
I. Ưu nhược điểm của sản phẩm :
1. Ưu điểm :
- Mạch nhỏ gọn, phù hợp với việc học tập nghiên cứu về vi điều khiển và ứng
dụng của nó vào đời sống hằng ngày.
- Linh kiện phổ biến, dễ dàng có thể thực hiện việc mô phỏng.
- Tiết kiệm nguồn điện bằng cách sử dụng nguồn máy tính, nguồn chuẩn 5v cho
mạch hoạt động.
- Thiết kế bằng phần mềm ORCAD thông dụng trong nghành điện tử.
2. Nhược điểm :
- Mạch đồ án thực hiện mô phỏng hệ thống đếm sản phẩm nên dùng thu phát
hồng ngoại tích hợp làm khoảng thu phát ngắn, không phù hợp với việc đếm
sp thực tế.
II. Tính thực tế và hướng cải tiến sản phẩm :
1. Tính thực tế của sản phẩm :
- Thích hợp trong các phòng thí nghiệm, dạy và học vi điều khiển. Đó là một
dẫn chứng cụ thể cho việc sử dụng vi điều khiển áp dụng vào đời sống.
- Làm rõ bản chất của ngắt ngoài và ngắt nối tiếp trong vi điều khiển.
- Phát triển thêm ta có đc một hệ thống phù hợp với môi trường làm việc, nâng
cao năng suất lao động, tiết kiệm nhân công.
2. Hướng cải tiến sản phẩm :
Mạch có thể phát triển thêm nhiều chức năng để có thể thành một hệ thống cho dây
truyền công nghiệp.
- Dùng thu phát hông ngoại riêng biệt để có khoảng cách xa hơn.
- Với dung lượng bộ nhớ của AT89S52 chúng ta có thể lập trình thếm việc đếm
một số lượng sản phẩm hay thùng hàng vào một lô một cách chính xác.
- Việc giao tiếp của mạch với máy tính có thể dùng máy tính để điều khiển số
lượng sản phẩm cần đếm. Lưu lại tiến trình làm việc trong một ca làm việc
hay lưu lại lịch sử làm việc của từng ca làm việc trên máy tính.
- Quản lý xưởng chính xác mà không cần phải xuống tận nơi.
Với những cải tiến như trên, chúng ta có một hệ thống đế sản phẩm chính xác, tiện lợi mà giá
thành phù hợp với dây truyền vừa và nhỏ cũng như các hệ thống dây truyền lớn.
Ha noi university of industry ĐH ĐIỆN TỬ 2_K2
_________________________________________________________________
____________________________________________________________
Đồ án môn học vi điều khiển dcn105
25
TÀI LIỆU THAM KHẢO
1. Giáo trình : vi điều khiển, cấu trúc – lập trinh và ứng dụng
đại học công nghiệp hà nội.
2. Vi điều khiển 8051 _ tài liệu trung tâm etech
3. Tài liệu trên internet.
và nhiều nguồn thong tin từ thầy cô và bạn bè…