Chương 3: Cấu trúc phần cứng hệ vi điều khiển

1. Nháy LED đơn nối với cổng P1.0 với 1 nhịp/1s 2. Sáng lần lượt các LED đơn nối với cổng P1 theo thứ tự P1.0 đến P1.7 rồi lặp lại, thời gian sáng /tắt là 1s 3. Sáng và lưu sáng các LED đơn nối với cổng P1 theo thứ tự từ P1.0 đến P1.7, thời gian sáng /tắt là 1s

pdf133 trang | Chia sẻ: phanlang | Lượt xem: 1917 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Chương 3: Cấu trúc phần cứng hệ vi điều khiển, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Chương 3: Cấu trúc phần cứng hệ vi điều khiển TS. Trần Văn Hưng Bộ môn: Kỹ thuật điện tử Nội dung 3.1 Các kiến trúc vi điều khiển 3.2 Khái quát họ vi điều khiển MCS51 3.3 Cấu trúc AT89C52 3.3.1 Các cổng vào ra (I/O port) 3.3.2 Các tín hiệu điều khiển 3.3.3 Tổ chức bộ nhớ 3.3.4 Giới thiệu tập lệnh 3.3.5 Timer – Mạch định thời 3.3.6 Serial Port – cổng nối tiếp 3.3.7 Interupt – Hoạt động ngắt 3.4 Phần cứng tối thiểu của họ MCS51 Nội dung 3.1 Các kiến trúc vi điều khiển 3.2 Khái quát họ vi điều khiển MCS51 3.3 Cấu trúc AT89C52 3.3.1 Các cổng vào ra (I/O port) 3.3.2 Các tín hiệu điều khiển 3.3.3 Tổ chức bộ nhớ 3.3.4 Giới thiệu tập lệnh 3.3.5 Timer – Mạch định thời 3.3.6 Serial Port – cổng nối tiếp 3.3.7 Interupt – Hoạt động ngắt 3.4 Phần cứng tối thiểu của họ MCS51 3.1 Các kiến trúc vi điều khiển Nội dung 3.1 Các kiến trúc vi điều khiển 3.2 Khái quát họ vi điều khiển MCS51 3.3 Cấu trúc AT89C52 3.3.1 Các cổng vào ra (I/O port) 3.3.2 Các tín hiệu điều khiển 3.3.3 Tổ chức bộ nhớ 3.3.4 Giới thiệu tập lệnh 3.3.5 Timer – Mạch định thời 3.3.6 Serial Port – cổng nối tiếp 3.3.7 Interupt – Hoạt động ngắt 3.4 Phần cứng tối thiểu của họ MCS51 3.2 Họ vi điều khiển MCS51 • 8051 là vi điều khiển đầu tiên của họ VĐK MCS51 được Intel sản xuất vào năm 1980. Một số tính năng cơ bản của họ MCS51 kinh điển: – CPU 8 bit được thiết kế tối ưu cho các ứng dụng điều khiển – Có khả năng xử l{ các bit logic – Không gian bộ nhớ chương trình 64KB – Không gian bộ nhớ dữ liệu 64KB – Tích hợp 4KB bộ nhớ chương trình, 128 byte RAM trên chip – có 32 đường vào ra 2 chiều có thể định địa chỉ đến từng bit – Tích hợp 2 timer 16 bit – Tích hợp UART song công (Universal Asynchronous Receiver Transmitter) – Cấu trúc ngắt với 6 nguồn/5 vector ở 2 mức khác nhau – Tích hợp mạch dao động trên chip. 8051 89C51 • 89C51 thuộc họ MCS51 • 4Kbyte EPROM (1000 chu kz ghi/xóa) • 128 byte RAM • 32 bit (4 cổng) I/O • 2 Timer/Counter 16bit • 6 nguồn ngắt So sánh bộ nhớ một số chip trong họ MCS51: Nội dung 3.1 Các kiến trúc vi điều khiển 3.2 Khái quát họ vi điều khiển MCS51 3.3 Cấu trúc AT89C52 3.3.1 Các cổng vào ra (I/O port) 3.3.2 Các tín hiệu điều khiển 3.3.3 Tổ chức bộ nhớ 3.3.4 Giới thiệu tập lệnh 3.3.5 Timer – Mạch định thời 3.3.6 Serial Port – cổng nối tiếp 3.3.7 Interupt – Hoạt động ngắt 3.4 Phần cứng tối thiểu của họ MCS51 3.3 AT89C52 Nội dung 3.1 Các kiến trúc vi điều khiển 3.2 Khái quát họ vi điều khiển MCS51 3.3 Cấu trúc AT89C52 3.3.1 Các cổng vào ra (I/O port) 3.3.2 Các tín hiệu điều khiển 3.3.3 Tổ chức bộ nhớ 3.3.4 Giới thiệu tập lệnh 3.3.5 Timer – Mạch định thời 3.3.6 Serial Port – cổng nối tiếp 3.3.7 Interupt – Hoạt động ngắt 3.4 Phần cứng tối thiểu của họ MCS51 3.3.1 Các cổng vào/ra (I/O port) (1/3) • Port 0: là port 8bit có 2 chức năng: – Là I/O đối với các thiết kế cỡ nhỏ (không dùng bộ nhớ mở rộng) – Là byte thấp của Add/Data bus khi thiết kế có sử dụng bộ nhớ mở rộng • Port 1: là I/O port 8bit • Port 2: là port 8bit có 2 chức năng: – Là I/O port đối với các thiết kế cỡ nhỏ (không dùng bộ nhớ mở rộng) – Là byte cao của add/data bus khi thiết kế có sử dụng bộ nhớ mở rộng • Port 3 (cổng 3): là port 8bit có nhiều chức năng: – Là I/O port – Có công dụng chuyển đổi có liên hệ với các tính năng đặc biệt của 89c52 3.3.1 Các cổng vào/ra (I/O port) (2/3) 3.3.1 Các cổng vào/ra (I/O port) (3/3) • Các chân của P0 không có điện trở treo (internal pull-up), ngoại trừ lúc làm việc như bus dữ liệu/địa chỉ bên ngoài; điện trở treo có thể được dùng với P0 tùy theo đặc tính của thiết bị phối ghép với cổng; • Port 0 with Pull-Up Resistors Port 3 Alternate Functions Nội dung 3.1 Các kiến trúc vi điều khiển 3.2 Khái quát họ vi điều khiển MCS51 3.3 Cấu trúc AT89C52 3.3.1 Các cổng vào ra (I/O port) 3.3.2 Các tín hiệu điều khiển 3.3.3 Tổ chức bộ nhớ 3.3.4 Giới thiệu tập lệnh 3.3.5 Timer – Mạch định thời 3.3.6 Serial Port – cổng nối tiếp 3.3.7 Interupt – Hoạt động ngắt 3.4 Phần cứng tối thiểu của họ MCS51 3.3.2 Các tín hiệu điều khiển (1/2) • PSEN (Program Store Enable): – Là tín hiệu để cho phép đọc bộ nhớ chương trình mở rộng (bộ nhớ ngoài); – Khi 89C51 đọc mã lệnh từ bộ nhớ chương trình mở rộng thì PSEN được tích cực (mức thấp) 2 lần trong mỗi chu kz máy; – Khi 89C51 thi hành chương trình trong ROM nội thì PSEN sẽ ở mức cao; • ALE/PROG (Program Store Enable) – ALE (Address Latch Enable) là tín hiệu chốt byte thấp của địa chỉ trong suốt quá trình truy xuất bộ nhớ ngoài; – Chân này cũng được làm ngõ vào xung lập trình (PROG) cho EPROM; – Ở chế độ hoạt động bình thường thì xung ALE có tốc độ bằng 1/6 tần số dao động trên chip và có thể được dùng làm nguồn xung nhịp cho các phần khác của hệ thống; 3.3.2 Các tín hiệu điều khiển (2/2) • EA (External Access): – Khi truy xuất ROM nội thì chân /EA phải nối nguồn 5V – Khi truy xuất ROM ngoài thì /EA nối với GND • RST (Reset): khi tín hiệu này được đưa lên cao trong ít nhất 2 chu kz máy thì sẽ khởi động lại hệ thống • XTAL1, XTAL2: là ngõ vào và ngõ ra của bộ dao động tạo xung nhịp • Nguồn nuôi: dùng nguồn +5V ở chân 40 và GND ở chân 20 Nội dung 3.1 Các kiến trúc vi điều khiển 3.2 Khái quát họ vi điều khiển MCS51 3.3 Cấu trúc AT89C52 3.3.1 Các cổng vào ra (I/O port) 3.3.2 Các tín hiệu điều khiển 3.3.3 Tổ chức bộ nhớ 3.3.4 Giới thiệu tập lệnh 3.3.5 Timer – Mạch định thời 3.3.6 Serial Port – cổng nối tiếp 3.3.7 Interupt – Hoạt động ngắt 3.4 Phần cứng tối thiểu của họ MCS51 3.3.3 Tổ chức bộ nhớ (1/5) • 89C51 có cả ROM nội và RAM nội, tuy nhiên co thể mở rộng thêm bằng các thiết bị nhớ bên ngoài • RAM nội gồm: – RAM lưu trữ đa dụng – RAM được địa chỉ hóa từng bit – Các bank thanh ghi – Các thanh ghi chức năng đặc biệt 3.3.3 Tổ chức bộ nhớ (2/5) • RAM đa dụng có địa chỉ 30-7FH • RAM được địa chỉ hóa từng bit có địa chỉ từ 20H- 2FH • Có 4 bank thanh ghi, mỗi bank có 8 thanh ghi từ R0 đến R7 3.3.3 Tổ chức bộ nhớ (3/5) 3.3.3 Tổ chức bộ nhớ (4/5) Thanh ghi PSW • Các bit RS0 và RS1 dùng để chọn bank thanh ghi tích cực, trạng thái mặc định thì các thanh ghi này ở bank 0 3.3.3 Tổ chức bộ nhớ (5/5) • Thanh ghi B: dùng cùng với thanh ghi A trong các phép toán nhân và chia • Con trỏ dữ liệu DPTR: – Dùng khi truy xuất bộ nhớ ngoài. – DPTR dùng để xác định địa chỉ của bộ nhớ ngoài cần truy xuất • Các thanh ghi port: – P0,P1,P2,P3; – Các thanh ghi này được địa chỉ hóa đến từng bit • Thanh ghi định thời gian: là các thanh ghi điều khiển hoạt động của timer Nội dung 3.1 Các kiến trúc vi điều khiển 3.2 Khái quát họ vi điều khiển MCS51 3.3 Cấu trúc AT89C52 3.3.1 Các cổng vào ra (I/O port) 3.3.2 Các tín hiệu điều khiển 3.3.3 Tổ chức bộ nhớ 3.3.4 Giới thiệu tập lệnh 3.3.5 Timer – Mạch định thời 3.3.6 Serial Port – cổng nối tiếp 3.3.7 Interupt – Hoạt động ngắt 3.4 Phần cứng tối thiểu của họ MCS51 3.3.4 Giới thiệu tập lệnh • Các cách đánh địa chỉ – Định địa chỉ thanh ghi – Định địa chỉ trực tiếp – Định địa chỉ gián tiếp thanh ghi – Định địa chỉ tức thời • Tập lệnh – Nhóm lệnh di chuyển dữ liệu – Nhóm lệnh số học và luận l{ – Nhóm lệnh điều khiển – Nhóm lệnh thực hiện trên bit Các cách đánh địa chỉ (1/2) • Đánh địa chỉ thanh ghi (Rn): – 98C51 có 8 thanh ghi làm việc được k{ hiệu từ R0-R7 – Trong định địa chỉ thanh ghi, mã lệnh luôn có 3 bit để chị thị một thanh ghi – Ví dụ: MOV A,R0 • Đánh địa chỉ trực tiếp (direct): – Lệnh hiện hành sẽ cung cấp địa chỉ tuyệt đối của ô nhớ sử dụng; – Lệnh có ít nhất 2byte, trong đó địa chỉ ô nhớ chiếm 1byte – Ví dụ: MOV A,40H Các cách đánh địa chỉ (2/2) • Định địa chỉ gián tiếp thanh ghi (@Ri): – Với i=0,1 – Ri hoạt động như một con trỏ thanh ghi, nội dung của Ri chỉ ra một ô nhớ trong RAM nội; – Mã lệnh có bit thấp nhất được dùng để xác định con trỏ thanh ghi nào được sử dụng – Ví dụ: MOV A,@R0 • Đinh địa chỉ tức thời (#data): – Với lệnh này thì data không phải là địa chỉ mà là dữ liệu thật, dữ liệu 8bit (hằng số) – Ví dụ: MOV A,#12 – Khi sử dụng con trỏ dữ liệu DPTR thì cần phải có dữ liệu 16bit (#data16); ví dụ MOV DPTR,#8000H Nhóm lệnh chuyển dữ liệu (1/3) • Cú pháp: MOV đích,nguồn • Chuyển dữ liệu trong không gian bộ nhớ nội, hướng chuyển dữ liệu từ nguồn đến đích • Ví dụ: – MOV A,Rn: chuyển nội dung thanh ghi Rn vào A – MOV A,@Ri: chuyển dữ liệu gián tiếp vào A – MOV A,direct: chuyển dữ liệu trực tiếp từ ô nhớ vào A – MOV A,#data: chuyển giá trị dữ liệu tức thời vào A – MOV Rn,A: chuyển nội dung thanh ghi A vào thanh ghi Rn – MOV Rn,#data: chuyển giá trị dữ liệu tức thời vào thanh ghi Rn – … Nhóm lệnh chuyển dữ liệu (2/3) • XCH A,Rn: hoán đổi dữ liệu giữa A và Rn • XCH A,direct: hoán đổi dữ liệu giữa A và ô nhớ trực tiếp • XCH A,@Ri: hoán đổi dữ liệu giữa A và ô nhớ gián tiếp • MOVX đích,nguồn – Chuyển dữ liệu giữa RAM nội và RAM bên ngoài – Hướng chuyển là từ nguồn đến đích – Địa chỉ của ngoại vi (ô nhớ ngoài) sẽ là nội dung của thanh ghi DPTR – Khi làm việc với bộ nhớ ngoài có dung lượng thấp (<256byte) thì chỉ cần 8bit địa chỉ thấp và ta sẽ sử dụng cách định địa chỉ gián tiếp thanh ghi @Ri để chứa địa chỉ 8bit này Nhóm lệnh chuyển dữ liệu (3/3) • MOVX @Ri,A: ghi dữ liệu từ A ra ô nhớ ngoài • MOVX A,@Ri: đọc dữ liệu từ ô nhớ ngoài vào A • MOVX @DPTR,A: ghi dữ liệu từ A ra ô nhớ ngoài • MOVX A,@DPTR: đọc dữ liệu từ ô nhớ ngoài về A • Ví dụ áp dụng:ở trạng thái ban đầu thanh ghi R1 chứa giá trị 40H, ô nhớ RAM nội ở địa chỉ 40H chứa giá trị FFH, sau khi thực thi lệnh các thanh ghi và ô nhớ sẽ có giá trị như thế nào ? – MOV A,R1 – MOV A,@R1 – MOV A,40H – MOV A,#40 Nội dung A là 40H, R1 là 40H, ô nhớ 40H là FFH Nội dung A là FFH, R1 là 40H, ô nhớ 40H là FFH Nội dung A là FFH, R1 là 40H, ô nhớ 40H là FFH Nội dung A là 40H, R1 là 40H, ô nhớ 40H là FFH Nhóm lệnh số học và luận l{ (1/2) • ADD, ADDC: lệnh cộng dữ liệu – Lệnh cộng dữ liệu sẽ lưu kết quả tính toán vào thanh ghi A – Lệnh cộng sẽ tác động đến cờ CY trong thanh ghi PSW – Lệnh ADDC sẽ cộng cả nội dung của cờ nhớ CY – Ví dụ: A chứa giá trị 12H, sau khi thực hiện lệnh ADD A,#36H thì giá trị của A là 48H và bit cờ CY=0 • SUBB: lệnh trừ dữ liệu – Lệnh trừ sẽ lưu kết quả tính toán vào thanh ghi A – Lệnh tác động đến cờ trong thanh ghi PSW – Để kết quả tính chính xác, trước khi dùng lệnh trừ ta nên xóa cờ CY – Ví dụ: lệnh SUBB A,R1: nội dung A – nội dung R1 – nội dung bit cờ CY, kết quả cất trở lại thanh ghi A Nhóm lệnh số học và luận l{ (2/2) • INC: lệnh tăng 1 đơn vị (không tác động đến CY) • DEC: giảm đi 1 đơn vị • MUL A,B: nhân nội dung A với nội dung B, byte thấp của kết quả cất vào A, byte cao của kết quả cất vào B • DIV A,B: chia nội dung của A cho nội dung B, phần nguyên kết quả cất vào A, phần dư cất vào B • Các lệnh luận l{: – ANL: lệnh AND – ORL: lệnh OR – XRL: lệnh XOR – RL A: quay trái thanh ghi A đi 1bit (RR A: quay phải 1 bit) – SWAP A: hoán đổi nội dung 4bit cao và 4 bit thấp của thanh ghi A (tương đương quay 4 lần) Nhóm lệnh thực hiện trên bit • CLR C: xóa cờ carry (CY) về 0 • CLR bit: xóa bit về 0 • SETB C, SETB bit: đặt bit cờ/bit lên 1 • CPL C, CPL bit: lấy bù bit cờ/ bit • … Nhóm các lệnh điều khiển • Lệnh gọi chương trình con: – ACALL: gọi ctc dùng địa chỉ tuyệt đối – LCALL: gọi ctc dùng địa chỉ dài • Lênh thoát: – RET: trở về CTC từ ctc – RETI: trở về CTC từ ctc phục vụ ngắt • Lệnh nhảy không điều kiện: – AJMP/LJMP/SJMP (lệnh nhảy tuyệt đối/dài/ngắn) • Lệnh nhảy có điều kiện – JZ/JNZ (nhảy nếu A=0/khác 0) – JC/JNC (nhảy nếu C=1/C=0) – JB bit/JNB bit: nhảy nếu bit =1/nếu bit=0 • NOP: lệnh k làm gì cả nhưng PC vẫn tăng lên 1 • …. Một số ví dụ áp dụng tập lệnh • VD1: Hãy cho biết các lệnh dưới đây thực hiện công việc gì ? Giá trị các thanh ghi và ô nhớ sau khi thực hiện xong lệnh: MOV R1,#25H MOV A,#50H MOV @R1,A • VD2: Viết chương trình thực hiện cổng logic sau: R1=25H; A=50H; (ô nhớ 25H)=50H MOV C,P1.4 ORL C,P1.5 CPL C MOV P1.7,C Một số ví dụ áp dụng tập lệnh a) Viết chương trình cho 8 Led sáng b) Viết chương trình cho 4 led sáng: D1-D4 c) Viết chương trình cho 4 led sáng: D5-D8 Một số ví dụ áp dụng tập lệnh a) Viết chương trình cho 8 Led sáng b) Viết chương trình cho 4 led sáng: D1-D4 c) Viết chương trình cho 4 led sáng: D5-D8 Nội dung 3.1 Các kiến trúc vi điều khiển 3.2 Khái quát họ vi điều khiển MCS51 3.3 Cấu trúc AT89C52 3.3.1 Các cổng vào ra (I/O port) 3.3.2 Các tín hiệu điều khiển 3.3.3 Tổ chức bộ nhớ 3.3.4 Giới thiệu tập lệnh 3.3.5 Timer – Mạch định thời 3.3.6 Serial Port – cổng nối tiếp 3.3.7 Interupt – Hoạt động ngắt 3.4 Phần cứng tối thiểu của họ MCS51 Giới thiệu Timer: • Timer là một chuỗi các Flip-Flop chia đôi tần số mắc nối tiếp với nhau, chúng nhận tín hiệu vào làm nguồn xung nhịp. Xung nhịp được đưa vào Flip-Flop thứ nhất để chia đôi tần số xung nhịp. Ngõ ra của Flip-Flop thứ nhất làm xung nhịp cho Flip-Flop thứ hai (cũng làm việc chia đôi tần số), và v.v. … • Vì mỗi tầng kế tiếp chia đôi cho nên timer có n tầng sẽ cho xung ra có tần số là tần số xung nhịp chia cho 2n. Ngõ ra của tầng cuối làm xung nhịp cho Flip-Flop báo tràn của timer (còn gọi là cờ timer TF – Timer Flag); • Giá trị nhị phân trong các Flip-Flop của timer có thể xem như số đếm xung nhịp (hoặc các sự kiện) từ khi timer bắt đầu chạy. Thí dụ timer 16bit sẽ đếm từ 0000H đến FFFFH, cờ báo tràn sẽ lên 1 khi số đếm tràn từ FFFFH đến 0000H. Vi dụ Timer 3 bit: Ứng dụng của Timer: • Sử dụng timer để: Định khoảng thời gian; Đếm sự kiện;Tạo tốc độ baud cho cổng nối tiếp có sẵn trong VĐK • Trong các ứng dụng định khoảng thời gian, thường lập trình cho timer tràn ở một khoảng đều đặn và đặt cờ tràn timer lên 1. cờ được dùng để đồng bộ hóa hoặc đo thời gian trôi qua giữa hai sự kiện (ví dụ đo độ rộng xung); • Đếm sự kiện được dùng để xác định số lần xảy ra của một sự kiện hơn là đo khoảng thời gian trôi qua giữa các sự kiện. Một “sự kiện” là bất cứ tác động bên ngoài nào có thể cung cấp một chuyển tiếp 1 sang 0 từ chân T0,T1,T2 (ở P3, P2) của 89c52 • Các timer cũng có thể cung cấp xung nhịp tốc độ baud cho cổng nối tiếp có sẵn trong VĐK Các thanh ghi chức năng đặc biệt (SFR) của timer Timer được truy cập khi sử dụng các thanh ghi chức năng đặc biệt: TMOD, TCON, TH0, TL0, TH1, TL1 Thanh ghi TMOD (Timer Mode Register) (1/2) • Thanh ghi TMOD dùng để xác định chế độ làm việc cho Timer 0 và Timer 1 • TMOD không được địa chỉ hóa từng bit • Nạp bằng phần mềm khi bắt đầu chương trình – Gate: bit mở cổng cho Timer: • Khi GATE=1: Timer/Counterx chỉ hoạt động khi chân INTx ở mức 1 (phần cứng) và bit TRx=1 (trong thanh ghi TCON) Thanh ghi TMOD (Timer Mode Register) (2/2) • Khi GATE=0: Timerx hoạt động khi bit TRx=1 (ghi chú: x=0,1; TRx: TR0 hoặc TR1; Timerx: Timer0 hoặc Timer1) – C/T: Bit chọn Timer hay Counter • C/T =1: chọn Counter (đếm sự kiện) • C/T = 0 chọn Timer (định khoảng thời gian) – M0,M1: các bit chọn chế độ Thanh ghi TMOD (Timer Mode Register) Ví dụ: TMOD = 0000 0001 (01H) chế độ 1 của bộ định thời Timer 0 được chọn TMOD = 0010 0000 (20H) chế độ 2 của bộ định thời Timer 1 được chọn TMOD = 0001 0010 (12H) chế độ 1 của bộ định thời Timer 1 và chế độ 2 của Timer 0 được chọn Thanh ghi TMOD (Timer Mode Register) Ví dụ: TMOD = 0000 0010 Bộ định thời là Timer0, chế độ 2, C/T = 0 dùng nguồn XTAL, GATE = 0 dùng phần mềm để khởi động và dừng bộ định thời. Thanh ghi điều khiển Timer (TCON- Timer Control Register) • Thanh ghi TCON chứa các bit trạng thái và điều khiển cho Timer 0 và Timer 1 • Được địa chỉ hóa đến từng bit • TFx: cờ báo tràn timer; cờ này được đặt bởi phần cứng khi tràn timer, được xóa bằng phần mềm VD: timer 16bit sẽ đếm lên từ 0000H đến FFFFH, tràn timer xảy ra khi số đếm tràn từ FFFFH sang 0000H • TRx: bit điều khiển timer chạy, được đặt/xóa bằng phần mềm để điều khiển timer chạy/dừng (TRx=1: cho phép Timer chạy; TRx=0: dừng Timer) Thanh ghi điều khiển Timer (TCON- Timer Control Register) Các chế độ làm việc của timer • AT89C52 có 3 timer, mỗi timer có 4 chế độ làm việc, bao gồm: – Chế độ 0 (mode 0): chế độ định thời 13bit – Chế độ 1 (mode 1): chế độ định thời 16bit – Chế độ 2 (mode 2): timer 8bit tự động nạp lại giá trị ban đầu – Chế độ 3 (mode 3): chế độ tách timer Chế độ 0 (mode 0): chế độ định thời 13bit • Chế độ Timer 13bit, tương thích 8048 • Trong chế độ này không sử dụng 3bit cao của thanh ghi TLx, chỉ sử dụng THx và 5bit thấp của TLx • Giá trị đếm được: 0 đến (213-1)Ttimer (từ 0 đến 8191Ttimer) Chế độ 1 (mode 1): chế độ định thời 16bit • Trong chế độ này sử dụng cả 2 thanh ghi THx và TLx • Cờ báo tràn là bit TFx trong thanh ghi TCON, được đọc hoặc ghi bằng phần mềm • Bit có trọng số cao (MSB) trong các thanh ghi timer là bit 7 của THx; Bit có trọng số thấp nhất (LSB) là bit 0 của TLx • Các thanh ghi timer có thể được đọc/ghi bất cứ lúc nào bằng phần mềm • Giá trị đếm được là từ 0 đến (216-1)Ttimer, nghĩa là từ 0 đến 65535Ttimer Lập trình trong chế độ 1 Để tạo ra một độ trễ thời gian dùng chế độ 1 của Timer: 1. Nạp giá trị TMOD cho thanh ghi báo độ định thời nào (Timer0 hay Timer1) được sử dụng và chế độ nào được chọn; 2. Nạp các thanh ghi TL và TH với các giá trị đếm ban đầu; 3. Khởi động bộ định thời 4. Duy trì kiểm tra cờ bộ định thời TF bằng một vòng lặp để xem nó được bật lên 1 không. Thoát vòng lặp khi TF được lên cao; 5. Dừng bộ định thời; 6. Xoá cờ TF cho vòng kế tiếp; 7. Quay trở lại bước 2 để nạp lại TL và TH. Lập trình trong chế độ 1 Công thức tính toán độ trễ sử dụng chế độ 1 (16 bit) của bộ định thời đối với tần số thạch anh XTAL = f (MHz): Tính theo số Hex Tính theo số thập phân (FFFF - YYXX + 1)*12/f (ms) trong đó YYXX là các giá trị khởi tạo của TH, TL tương ứng. Lưu ý rằng các giá trị YYXX là theo số Hex. Chuyển đổi các giá trị YYXX của TH, TL về số thập phân để nhận một số thập phân NNNNN sau đó lấy (65536 – NNNNN)*12/f (ms). Chế độ 2 (mode 2): timer 8bit tự động nạp lại giá trị ban đầu • Trong chế độ thanh ghi TLx hoạt động như một timer 8bit, trong khi đó thanh ghi THx vẫn giữ nguyên giá trị được nạp • Khi số đếm tràn từ FFH sang 00H thì cờ tràn timer được đặt lên 1 đồng thời giá trị trong THx được nạp lại vào TLx và chu trình đếm mới được bắt đầu • Chế độ này rất thông dụng vì sự tràn timer xảy ra trong những khoảng thời gian nhất định và tuần hoàn một khi đã khởi động bộ đếm • Giá trị đếm được là từ 0 đến (28-1)Ttimer, nghĩa là từ 0 đến 255Ttimer Chế độ 3 (mode 3): chế độ tách timer • Chế độ tách timer. Timer 0 được tách thành 2 timer 8bit: TH0 và TL0. Timer 1 dừng • TL0 có cờ báo tràn là TF0; TH0 có cờ báo tràn là TF1 Nguồn tạo xung nhịp cho Timer: Có 2 nguồn xung nhịp có thể được sử dụng và nó được chọn bằng bit C/T trong thanh ghi TMOD khi khởi động Timer; • Xung nhịp định khoảng thời gian: – Khi C/T=0: timer dùng để định khoảng thời gian – Nguồn xung nhịp được lấy từ bộ dao động trên chip đưa qua 1 bộ chia 12 để giảm đến tần số thích hợp cho phần lớn các ứng dụng. – ftimer=fOSC/12 • Xung nhịp đếm sự kiện: – Khi C/T=1: dùng timer đếm sự kiện – Xung nhịp được lấy từ nguồn bên ngoài thông qua ngõ T0 hoặc T1, nguồn bên ngoài sẽ cung cấp một xung khi xảy ra một sự kiện – Giá trị trong các thanh ghi timer (THx và TLx) sẽ tăng lên 1 khi có 1 sự kiện xảy ra. – Số sự kiện được xác định bằng phần mềm thông qua đọc các thanh ghi timer Nguồn tạo xung nhịp cho Timer: Tần số thạch anh Tần số bộ định thời Chu kỳ bộ định thời 20MHz 20MHz/12=1,6666MHz 1/1,6666MHz=0,6us 12MHz 12MHz/12=1MHz 1/1MHz=1us 11,0592MHz 11,0592MHz/12=0,9216MHz 1/0,9216MHz=1,085us Mặc dù các hệ thống 8051 có thể sử dụng tần số thạch anh từ 10 đến 40MHz, song ta chỉ tập trung vào tần số thạch anh 11,0592MHz. Lý do đằng sau một số lẻ như vậy là tốc độ baud đối với truyền thông nối tiếp của 8051. Tần số XTAL = 11,0592MHz cho phép hệ thống 8051 truyền thông với PC mà không có lỗi. Các bước cơ bản để khởi động Timer • Nạp giá trị bắt đầu cho thanh ghi TMOD: lựa chọn chế độ timer, cho bit Gate=0, C/T=0 • Nạp các giá trị thích hợp cho các thanh ghi THx và TLx • Cho timer chạy: SETB TRx (trong C: TRx=1) • Chờ cờ báo tràn: có 2 cách: – JNB TFx,$ – Wait: JNB TFx,Wait lenh JNB • Xóa cờ báo tràn: CLR TFx (trong C: TFx=0) • Dừng Timer: CLR TRx (trong C: TRx=0) Một số VD: Ví dụ 1: viết chương trình tạo trễ (delay) 100μs dùng Timer 0, biết rằng bộ dao động trên chip sử dụng thạch anh 12MHz • B1: tìm tần số dao động và chu kz xung nhịp của timer fOSC=12MHz Ftimer=fOSC/12=1MHz Ttimer=1/ftimer=1/10 6=1μs • B2: xác định các giá trị cần nạp cho các thanh ghi timer Có tdelay=100μs Mà Ttimer=1μs nên: tdelay=100Ttimer Do timer hoạt động như là một bộ đếm lên và khi bộ đếm tràn thì nó sẽ quay lại về giá trị 0, nên giá trị phải nạp cho các thanh ghi timer là -100 • B3: xác định giá trị cần nạp cho thanh ghi chế độ timer TMOD – Do Tdelay=100Ttimer ; giá trị này <255 nên có thể chọn timer ở chế độ 1(16bit) hay chế độ 2(8bit tự động nạp lại) Một số VD: • B4: Cho timer chạy • B5: chờ cờ báo tràn • B6: Xóa cờ báo tràn • B7: Dừng timer Chương trình hoàn chỉnh khi dùng timer 0 ở chế độ 2: MOV TMOD,#0000 0010B MOV TH0,#-100 SETB TR0 JNB TF0,$ CLR TF0 CLR TR0 END Một số VD: Chương trình dùng timer 0 chế độ 1: MOV TMOD,#0000 0001B MOV TH0,# high(-100); chuyển -100 sang mã nhị phân sau đó lấy 8bit cao của giá trị gán vàoTH0 MOV TL0,# low(-100); chuyển -100 sang mã nhị phân sau đó lấy 8bit thấp của giá trị gán vàoTL0 SETB TR0 JNB TF0,$ CLR TF0 CLR TR0 END Một số VD: VD2: viết chương trình tạo trễ 10ms dùng timer 1, tần số dao động trên chip là 12MHZ • B1: Ttimer=1 μs • B2: Các giá trị cần nạp cho các thanh ghi timer Tdelay=10ms vậy Tdelay=10000Ttimer • B3: các giá trị cần nạp cho thanh ghi TMOD Do Tdelay=10000Ttimer nên chọn timer ở chế độ 1 (16bit) Chương trình: MOV TMOD,#0001 0000B MOV TH1,#high(-10000) MOV TL1,#low(-10000) SETB TR1 JNB TF1,$ CLR TF1 CLR TR1 END Một số VD: VD3: Viết chương trình tạo sóng vuông 50% có tần số 10KHz ở ngõ ra P1.0, biết tần số dao động trên chip là 12MHz • Tần số xung 10KHz nên chu kz xung vuông là T=1/(10.103)=10-4s = 100μs • Xung vuông 50% nên: tH=tL=T/2=50μs Dùng Timer 1: MOV TMOD,#0000 0010B MOV TH0,# -50 SETB TR0 LOOP: JNB TF0,$ CLR TF0 CPL P1.0 SJMP LOOP END Một số VD: Cách 2: LOOP: SETB P1.0 ACALL Delay_50us CLR P1.0 ACALL Delay_50us SJMP LOOP Delay_50us: MOV TMOD,# 0000 0010B MOV TH0,# -50 SETB TR0 JNB TF0,$ CLR TF0 RET END Một số VD: • Tạo ra một sóng vuông với độ đầy xung 50% (cùng tỷ lệ giữa phần cao và phần thấp) trên chân P1.5. Bộ định thời Timer0 được dùng để tạo độ trễ thời gian: XTAL=11,0592MHz #include //khai báo thư viện cho VĐK 89x51 void delay(void); //khi báo nguyên mẫu hàm con tạo trễ main() { P1_5=1; //khởi tạo chân P1_5 ở mức cao while(1) //vòng lặp vô hạn { delay(); //chương trình con tạo trễ P1_5=~P1_5; //đảo tín hiệu chân P1_5 } } Một số VD: void delay(void) //định nghĩa hàm delay { TMOD=0x01; //chọn timer0, chế độ 1, 16Bit TL0=0xF2; //nạp giá trị cho TL0 TH0=0xFF; //nạp giá trị cho TH0 TR0=1; //khởi động timer0 while(!TF0){} //vòng lặp kiểm tra cờ TF0 TR0=0; //ngừng timer0 TF0=0; //xóa cờ TF0 } Một số VD: • Tính toán độ trễ tạo ra bởi bộ định thời ở chương trình trên với tần số XTAL=11,0592MHz: • Bộ định thời làm việc với tần số đồng hồ bằng 1/12 tần số XTAL, do vậy ta có 11,0592MHz/12=0,9216MHz là tần số của bộ định thời. Kết quả là mỗi nhịp xung đồng hồ có chu kỳ T=1/0,9216MHz=1,085us. Hay nói cách khác, bộ Timer0 tăng 01 đơn vị sau 1,085ms để tạo ra bộ trễ bằng số_đếm´1,085ms. • Số đếm bằng FFFFH - FFF2H = ODH (13 theo số thập phân). Tuy nhiên, ta phải cộng 1 vào 13 vì cần thêm một nhịp đồng hồ để nó quay từ FFFFH về 0000H và bật cờ TF. Do vậy, ta có 14 x1,085us = 15,19us cho nửa chu kỳ và cả chu kỳ là T = 2 x15,19us = 30,38us là thời gian trễ được tạo ra bởi bộ định thời. Phân tích ví dụ Các bước để tìm các giá trị của các thanh ghi TH và TL, XTAL = 11. 0592MHz 1. Chia thời gian trễ cần thiết cho 1.085ms 2. Thực hiện 65536 - n với n là giá trị thập phân nhận được từ bước 1. 3. Chuyển đổi kết quả ở bước 2 sang số Hex: ta có YYXX là giá trị Hexa ban đầu cần phải nạp vào các thanh ghi bộ định thời. 4. Đặt TL = XX và TH = YY. Một số VD: Ví dụ: Giả sử tần số XTAL = 11.0592MHz. Hãy tìm các giá trị cần được nạp vào các thanh ghi vào các thanh ghi TH và TL nếu ta muốn độ thời gian trễ là 5ms. • Để có được ta chia 5ms cho 1.085ms và nhận được số n = 4608 nhịp. Để nhận được giá trị cần được nạp vào TL và TH thì ta tiến hành lấy 65536 trừ đi 4608 bằng 60928. Ta đổi số này ra số hex thành EE00H. Do vậy, giá trị nạp vào TH là EE Và TL là 00. void delay(void) //định nghĩa hàm delay { TMOD=0x01; //chọn timer0 chế độ 1 16Bit TL0=0x00; //nạp giá trị cho TL0 TH0=0xEE; //nạp giá trị cho TH0 TR0=1; //khởi động timer0 while(!TF0){} //vòng lặp kiểm tra cờ TF0 TR0=0; //ngừng timer0 TF0=0; //xóa cờ TF0 } Chú {: • Lập trình chế độ 0: Chế độ 0 hoàn toàn giống chế độ 1 chỉ khác là bộ định thời 16 bit được thay bằng13 bit. Bộ đếm 13 bit có thể giữ các giá trị giữa 0000 đến 1FFFH • trong TH - TL. Do vậy khi bộ định thời đạt được giá trị cực đại của nó là 1FFFH thì nó sẽ quay trở về 0000và cờ TF được bật lên. • Lập trình ở chế độ 2: chế độ 2 là bộ định thời 8 bit. Tuy nhiên, nó lại có khả năng tự nạp, khi tự nạp lại thì giá trị ban đầu của TH được giữ nguyên, còn TL được nạp lại giá trị sao chép từ TH. Bài tập 1. Thiết kế cột đèn giao thông ở ngã tư dùng LED đơn và LED 7 thanh 2. Hiển thị số đếm từ 0 đến 9999 trên sơ đồ đã copy 3. Chuẩn bị: – Lập trình cho LCD – Lập trình cho LED ma trận – Lập trình cho ADC, RTC, … Nội dung 3.1 Các kiến trúc vi điều khiển 3.2 Khái quát họ vi điều khiển MCS51 3.3 Cấu trúc AT89C52 3.3.1 Các cổng vào ra (I/O port) 3.3.2 Các tín hiệu điều khiển 3.3.3 Tổ chức bộ nhớ 3.3.4 Giới thiệu tập lệnh 3.3.5 Timer – Mạch định thời 3.3.6 Serial Port – cổng nối tiếp 3.3.7 Interupt – Hoạt động ngắt 3.4 Phần cứng tối thiểu của họ MCS51 Truyền dữ liệu nối tiếp • Truyền dữ liệu khoảng cách xa • Tốc độ truyền dữ liệu thấp • Truyền dữ liệu nối tiếp đồng bộ – Dùng tìn hiệu clock riêng để đồng bộ hóa mạch thu và phát; – Thường dùng khung dữ liệu lớn hơn và nhanh hơn. • Truyền dữ liệu nối tiếp bất đồng bộ – Không cần tín hiệu clock riêng để đồng bộ hóa chuyển dữ liệu; – Dựa trên ký tự, mỗi ký tự được đóng khung bằng ‘start bit’ và ‘stop bit’ – Bên thu cần nhận dạng ‘start bit’ và ‘stop bit’ để nhận đúng ký tự dữ liệu Truyền dữ liệu đồng bộ và bất đồng bộ Đường truyền dữ liệu cơ bản Đường truyền điểm-điểm và điêm-đa điểm Cơ bản về đường truyền RS232 Giới thiệu cổng nối tiếp của MCS81 • 80c52 có 1 port nối tiếp hoạt động ở nhiều chế độ trên một dải tần số rộng; • Chức năng: chuyển dữ liệu từ song song sang nối tiếp đối với dữ liệu xuất và từ nối tiếp sang song song đối với dữ liệu nhập; • Port nối tiếp được truy xuất qua các chân TXD và RXD. Dữ liệu được thu (nhập) qua chân RXD (P3.0) và dữ liệu được phát (xuất) qua chân TXD (P3.1) • Tại mỗi thời điểm chỉ có 1 bit được thu hay phát. Để đồng bộ giữa thu và phát nối tiếp người ta sử dụng tốc độ baud • Port nối tiếp hoạt động song công và có đệm lúc thu cho phép 1 k{ tự được thu và được giữ trong khi k{ tự thứ 2 được nhận. Nếu CPU đọc k{ tự thứ nhất trước khi k{ tự thứ 2 được thu đầy đủ thì dữ liệu sẽ không bị mất; Giới thiệu cổng nối tiếp Hai thanh ghi DBUF và SCON dùng để truy xuất Port nối tiếp Các đặc tính của cổng nối tiếp MCS51 Thanh ghi đệm nối tiếp SBUF: • Thanh ghi SBUF đóng vai trò vừa là bộ đệm phát vừa là bộ đệm thu: – Dữ liệu phát đi sẽ được ghi vào SBUF và được phát qua ngõ TXD, trong trường hợp này nó là bộ đệm phát – Dữ liệu thu sẽ được nạp vào SBUF thông qua ngõ RXD và đọc thanh ghi này để truy xuất dữ liệu thu được, trong trường hợp này nó là bộ đệm thu – Port nối tiếp được dùng để cất các dữ liệu phát hoặc thu, khi dịch hết 8bit thì một dữ liệu được phát hoặc được nhận – Tốc độ baud của port nối tiếp có thể lấy từ bộ dao động trên chip hoặc sử dụng timer Thanh ghi điều khiển port nối tiếp SCON Các chế độ làm việc của cổng nối tiếp Mode 0: chế độ thanh ghi dịch • Dữ liệu nối tiếp được vào (thu) và ra (phát) qua ngõ RXD • Ngõ TXD là ngõ ra xung nhịp dịch, với 1 chu kz xung nhịp dịch thì 1 bit sẽ được phát hoặc thu • Dữ liệu được phát hoặc thu với bit đầu tiên là bit LSB • Xung nhip tốc độ baud cố định ở 1/12 tần số dao động trên chip • Việc phát k{ tự được khởi động bằng bất cứ lệnh nào ghi dữ liệu vào thanh ghi SBUF, trước khi phát phải kiểm tra bộ đệm phát đã rỗng • Chương trình con để phát 1 byte dữ liệu: Mode 0: chế độ thanh ghi dịch Mode 0: chế độ thanh ghi dịch Mode 1: UART 8bit tốc độ baud thay đổi được Mode 1: UART 8bit tốc độ baud thay đổi được Mode 1: UART 8bit tốc độ baud thay đổi được Mode 2: UART 9 bit có tốc độ baud cố định Mode 3: UART 9 bit có tốc độ baud thay đổi Khởi tạo và truy nhập các thanh ghi cổng nối tiếp Cho phép bộ thu – truyền dữ liệu nối tiếp Tốc độ baud cho cổng nối tiếp Sử dụng Timer1 làm xung nhịp tốc độ baud Tốc độ baud port nối tiếp • Tốc độ baud là số bit dữ liệu được truyền trong 1 sec, đơn vị tính là bit/giây (bps) • Để tạo tốc độ baud thì khởi động cho timer 1 tràn sau một khoảng thời gian tương ứng với tốc độ baud Ví dụ: tạo tốc độ baud 1200bps biết chip sử dụng thạch anh 12MHz Thạch anh 12MHz: Ttimer =1us Tốc độ tràn timer 1 là (giả sử bit SMOD trong thanh ghi PCON có giá trị =0) Ta có: fbaud=ftràn T1/32 Suy ra ftràn T1 = fbaudx32=1200x32=38400Hz Suy ra Ttràn T1=1/ftrànT1=1/38400Hz=26us TtrànT1=26Ttimer Như vậy giá trị cần nạp cho thanh ghi timer là -26 Tóm tắt tốc độ baud Ví dụ 1: Khởi tạo giá trị cho cổng nối tiếp Ví dụ 2 Ví dụ 3: Ví dụ 4 Ví dụ 5 Nội dung 3.1 Các kiến trúc vi điều khiển 3.2 Khái quát họ vi điều khiển MCS51 3.3 Cấu trúc AT89C52 3.3.1 Các cổng vào ra (I/O port) 3.3.2 Các tín hiệu điều khiển 3.3.3 Tổ chức bộ nhớ 3.3.4 Giới thiệu tập lệnh 3.3.5 Timer – Mạch định thời 3.3.6 Serial Port – cổng nối tiếp 3.3.7 Interupt – Hoạt động ngắt 3.4 Phần cứng tối thiểu của họ MCS51 Hoạt động ngắt Thực thi chương trình Cấu trúc ngắt trong 8051 Các nguồn ngắt Thanh ghi cho phép ngắt IE Thứ tự ưu tiên ngắt Xử lý ngắt Các vector ngắt Tổ chức bộ nhớ khi ngắt Khung chương trình dùng ngắt Chương trình phục vụ ngắt có kích thước nhỏ Chương trình phục vụ ngắt có kích thước lớn a.Ngắt timer Ví dụ tạo sóng vuông bằng ngắt timer Phân tích chương trình tạo sóng dùng timer Ví dụ: tạo 2 sóng vuông dùng ngắt Ví dụ: tạo 2 sóng vuông dùng ngắt Ví dụ về ngắt timer Ví dụ về ngắt timer b. Ngắt cổng nối tiếp c. Ngắt ngoài Nội dung 3.1 Các kiến trúc vi điều khiển 3.2 Khái quát họ vi điều khiển MCS51 3.3 Cấu trúc AT89C52 3.3.1 Các cổng vào ra (I/O port) 3.3.2 Các tín hiệu điều khiển 3.3.3 Tổ chức bộ nhớ 3.3.4 Giới thiệu tập lệnh 3.3.5 Timer – Mạch định thời 3.3.6 Serial Port – cổng nối tiếp 3.3.7 Interupt – Hoạt động ngắt 3.4 Phần cứng tối thiểu của họ MCS51 Phần cứng tối thiểu của họ MCS51 Bài tập 1. Sơ đồ đã cho: – Lập trình & mô phỏng: 8 led sáng lần lượt từ phải qua trái, sau đó lần lượt từ trái qua phải. 2. Thiết kế 1 ngã tư 4 cột đèn đk giao thông, lập trình và mô phỏng hoạt động của nút giao thông: xanh 10s, vàng 2s, đỏ 5s. return Bài tập 1. Nháy LED đơn nối với cổng P1.0 với 1 nhịp/1s 2. Sáng lần lượt các LED đơn nối với cổng P1 theo thứ tự P1.0 đến P1.7 rồi lặp lại, thời gian sáng/tắt là 1s 3. Sáng và lưu sáng các LED đơn nối với cổng P1 theo thứ tự từ P1.0 đến P1.7, thời gian sáng/tắt là 1s Tai lieu 1. Timer 2. Cong noi tiep 3. Ngat Bài tập lớn • 1 nhóm 3 người • Yêu cầu: – Làm mô phỏng (vẽ protus+lập trình chạy mô phỏng) – Làm mạch thực tế: chạy được – Viết Báo cáo: phần thiết kế mạch, phần mô phỏng, mạch thật

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

  • pdfchuong3_2611.pdf
Tài liệu liên quan