BÁO CÁO ĐỒ ÁN, Vi điều khiển ATmega16
Trang 1BÁO CÁO ĐỒ ÁN
Giáo viên hướng dẫn : Hoàng Thế Phương.
Học Sinh : Hà Quốc Anh
Phần I Cơ sở lý thuyết
I Vi điều khiển ATmega16
ATmega16 là vi điều khiển 8 bit dựa trên kiến trúc RISC Với khả năng thực hiện mỗi lệnh trong vòng một chu kỳ xung clock, ATmega16 có thể đạt được tốc độ 1MIPS trên mỗi MHz
Ngoài ra ATmega16 có các đặc điểm sau: 16KB bộ nhớ Flash với khả năng đọc trong khi ghi, 512 byte bộ nhớ EEPROM, 1KB bộ nhớ SRAM, 32 thanh ghi chức năng chung, 32 đường vào ra chung, 3 bộ định thời/bộ đếm, ngắt nội và ngắt ngoại, USART, giao tiếp nối tiếp 2 dây, 8 kênh ADC 10 bit, ATmega 16 hỗ trợ đầy đủ các chương trình và công cụ phát triển hệ thống như: trình dịch C, macro assemblers, chương trình mô phỏng/sửa lỗi, …
Hình 1 Hình ảnh thực tế vi điều khiển Atmega16.
Trang 2Hình 2 Sơ đồ chân của ATmega16
1 Cấu trúc nhân
CPU của Atmega16 có chức năng bảo đảm sự hoạt động chính xác các chương trình Do
đó nó phải có khả năng truy cập bộ nhớ, thực hiện các quá trình tính toán, điều khiển các thiết bị ngoại vi và quản lý ngắt
- Cấu trúc tổng quát
AVR sử dụng cấu trúc Harvard, tách riêng bộ nhớ và các bus cho chương trình và dữ liệu Các lệnh được thực hiện chỉ trong một chu kỳ xung clock Bộ nhớ chương trình được lưu trong bộ nhớ Flash
Trang 3Hình 3 Cấu trúc tổng quát Atmega16
- ALU
ALU làm việc trực tiếp với các thanh ghi chức năng chung Các phép toán được thực hiện trong một chu kỳ xung clock Hoạt động của ALU được chia làm 3 loại: đại số, logic và theo bit
- Thanh ghi trạng thái
Đây là thanh ghi trạng thái có 8 bit lưu trữ trạng thái của ALU sau các phép tính số học
và logic
Hình 4 Thanh ghi trạng thái
Trong đó:
+ C: Carry Flag: cờ nhớ (Nếu phép toán có nhớ cờ sẽ được thiết lập)
+ Z: Zero Flag: Cờ zero (Nếu kết quả phép toán bằng 0)
+ N: Negative Flag: (Nếu kết quả của phép toán là âm)
+ V: Two’s complement overflow indicator (Cờ này được thiết lập khi tràn số bù 2)
Trang 4+ H: Half Carry Flag
+ T: Transfer bit used by BLD and BST instructions: (Được sử dụng làm nơi chung gian trong các lệnh BLD,BST)
+ I: Global Interrupt Enable/Disable Flag: (Đây là bit cho phép toàn cục ngắt Nếu bit này ở trạng thái logic 0 thì không có một ngắt nào được phục vụ.)
- Các thanh ghi chức năng chung
Hình 5: Các thanh ghi chức năng chung
- Con trỏ ngăn xếp (SP)
Là một thanh ghi 16 bit nhưng cũng có thể được xem như hai thanh ghi chức năng đặc biệt 8 bit Có địa chỉ trong các thanh ghi chức năng đặc biệt là $3E (trong bộ nhớ RAM là $5E)
và có nhiệm vụ trỏ tới vùng nhớ trong RAM chứa ngăn xếp
Hình 6: Thanh ghi con trỏ ngăn xếp
- Quản lý ngắt
Ngắt là một cơ chế cho phép thiết bị ngoại vi báo cho CPU biết về tình trạng sẵn sàng cho đổi dữ liệu của mình.Ví dụ: khi bộ truyền nhận UART nhận được một byte nó sẽ báo cho CPU biết thông qua cờ RXC, hoặc khi nó đã truyền được một byte thì cờ TX được thiết lập …
Trang 5Khi có tín hiệu báo ngắt CPU sẽ tạm dừng công việc đạng thực hiện lại và lưu vị trí đang thực hiên chương trình (con trỏ PC) vào ngăn xếp sau đó trỏ tới vector phuc vụ ngắt và thức hiện chương trình phục vụ ngắt đó chơ tới khi gặp lệnh RETI (return from interrup) thì CPU lại lấy
PC từ ngăn xếp ra và tiếp tục thực hiện chương trình mà trước khi có ngăt nó đang thực hiện
Trong trường hợp mà có nhiều ngắt yêu cầu cùng một lúc thì CPU sẽ lưu các cờ báo ngắt
đó lại và thực hiện lần lượt các ngắt theo mức ưu tiên Trong khi đang thực hiện ngắt mà xuất hiện ngắt mới thì sẽ xảy ra hai trường hợp Trường hợp ngắt này có mức ưu tiên cao hơn thì nó
sẽ được phục vụ Còn nó mà có mức ưu tiên thấp hơn thì nó sẽ bị bỏ qua
Bộ nhớ ngăn xếp là vùng bất kì trong SRAM từ địa chỉ 0x60 trở lên Để truy nhập vào SRAM thông thường thì ta dùng con trỏ X, Y, Z và để truy nhập vào SRAM theo kiểu ngăn xếp thì ta dùng con trỏ SP Con trỏ này là một thanh ghi 16 bit và được truy nhập như hai thanh ghi 8 bit chung có địa chỉ: SPL: 0x3D/0x5D(IO/SRAM) và SPH:0x3E/0x5E
Khi chương trình phục vụ ngắt hoặc chương trình con thì con trỏ PC được lưu vào ngăn xếp trong khi con trỏ ngăn xếp giảm hai vị trí.Và con trỏ ngăn xếp sẽ giảm 1 khi thực hiện lệnh PUSH Ngược lại khi thực hiện lệnh POP thì con trỏ ngăn xếp sẽ tăng 1 và khi thực hiện lệnh RET hoặc RETI thì con trỏ ngăn xếp sẽ tăng 2 Như vậy con trỏ ngăn xếp cần được chương trình đặt trước giá trị khởi tạo ngăn xếp trước khi một chương trình con được gọi hoặc các ngắt được cho phép phục vụ Và giá trị ngăn xếp ít nhất cũng phải lớn hơn 60H (0x60) vì 5FH trỏ lại là vùng các thanh ghi
2 Sơ đồ khối:
Hình 7: Sơ đồ khối
Trang 63 Ý nghĩa các chân
+ ChânVCC: Chân số 10 là VCC cấp điện áp nguồn cho Vi điều khiển Nguồn điện
cấp trong khoảng +5V ± 0,5
+ Chân GND: Chân số11 và chân số 31 nối GND(hay nối Mass) Khi thiết kế cần sử
dụng một mạch ổn áp để bảo vệ cho Vi điều khiển, cách đơn giản là sử dụng IC ổn áp 7805
+ Port A (PA): Port A gồm 8 chân (từ chân 33 đến 40) có chức năng: đầu vào cho
chuyển đổi ADC
+ Port B (PB): Port PB gồm 8 chân (từ chân 1 đến chân 8), ngoài có chức năng làm
các đường xuất/nhập thì còn có nhiều chức năng phụ khác
+ Port C (PC): Port C gồm 8 chân (từ chân 22 đến chân 29) : Nếu giao tiếp JTAG
được kích hoạt điện trở trên các PC5(TDI), PC3 (TMS) ,PC2 (TCK) sẽ được kích hoạt ngay cả khi khởi động lại (reset)
+ Port D (PD): Port D gồm 8 chân (từ chân 14 đến 21):chưc năng xuất nhập
+ Chân RESET(RST): Ngõ vào RST ở chân 9 là ngõ vào Reset dùng để thiết lập
trạng thái ban đầu cho vi điều khiển Hệ thống sẽ được thiết lập lại các giá trị ban đầu nếu ngõ này ở mức 1 tối thiểu 2 chu kì máy
+ Chân XTAL1 và XTAL2: Hai chân này có vị trí chân là 12 và 13 được sử dụng để
nhận nguồn xung clock từ bên ngoài để hoạt động, thường được ghép nối với thạch anh và các tụ
để tạo nguồn xung clock ổn định
+ Chân AVCC: Nguồn cấp cho cổng A và bộ chuyển đổi ADC , chân này nên được
nối với nguồn cấp VCC bên ngoài , ngay cả khi bộ chuyển đổi ADC không được sử dụng Nếu
bộ chuyển đổi ADC không được sử dụng , chân AVCC nên được nối với nguồn qua bộ lọc
+ Chân AREF: AREF là chân chuẩn analog cho bộ chuyển đổi ADC.
4 Bộ định thời
Bộ định thời (timer/counter) là một module định thời/đếm 8 bit, có các đặc điểm sau:
+ Bộ đếm một kênh
+ Xóa bộ định thời khi trong mode so sánh
+ PWM
+ Tạo tần số
+ Bộ đếm sự kiện ngoài
+ Bộ chia tần 10 bit
+ Nguồn ngắt tràn bộ đếm và so sánh
TCNT0 và OCR0 là các thanh ghi 8 bit Các tín hiệu yêu cầu ngắt đều nằm trong thanh ghi TIFR Các ngắt có thể được che bởi thanh ghi TIMSK
Bộ định thời có thể sử dụng xung clock nội thông qua bộ chia hoặc xung clock ngoài trên chân T0 Khối chọn xung clock điều khiển việc bộ định thời bộ đếm sẽ dùng nguồn xung nào để tăng giá trị của nó Ngõ ra của khối chọn xung clock được xem là xung clock của bộ định thời
Thanh ghi OCR0 luôn được so sánh với giá trị của bộ định thời/bộ đếm Kết quả so sánh
có thể được sử dụng để tạo ra PWM hoặc biến đổi tần số ngõ ra tại chân OC0
Phần chính của bộ định thời 8 bit là một đơn vị đếm song hướng có thể lập trình được Cấu trúc của nó như hình dưới đây:
Trang 7Hình 8 Sơ đồ đơn vị đếm
+ Count: tăng hay giảm TCNT0:1
+ Direction: lựa chọn giữa đếm lên và đếm xuống
+ Clear: xóa thanh ghi TCNT0
+ TOP: báo hiệu bộ định thời đẫ tăng đến giá trị lớn nhất
+ BOTTOM: báo hiệu bộ định thời đã giảm đến giá trị nhỏ nhất
Bộ so sánh 8 bit liên tục so sánh giá trị TCNT0 với giá trị thanh ghi so sánh ngõ ra (OCR0) Khi giá trị TCNT0 bằng với OCR0, bộ so sánh sẽ tạo một báo hiệu Báo hiệu này sẽ đặt giá trị cờ so sánh ngõ ra (OCF0) lên 1 vào chu kỳ xung clock tiếp theo Nếu được kích hoạt (OCIE0=1), cờ OCF0 sẽ tạo ra một ngắt so sánh ngõ ra và sẽ tự động được xóa khi ngắt được thực thi Cờ OCF0 cũng có thể được xóa bằng phần mềm
Hình 9 Sơ đồ đơn vị so sánh ngõ ra
Mô tả các thanh ghi
Thanh ghi điều khiển bộ định thời/bộ đếm TCCR0
Trang 8+ Bit 7 (FOC0): so sánh ngõ ra bắt buộc: bit này chỉ tích cực khi bit WGM00 chỉ
định chế độ làm việc không có PWM Khi đặt bit này lên 1, một báo hiệu so sánh bắt buộc xuất hiện tại đơn vị tạo dạng sóng
+ Bit 6 (WGM00) – bit 3 (WGM01): chế độ tạo dạng sóng: các bit này điều khiển
hoạt động của chân OC0 Nếu một hoặc cả hai bit COM01, COM00 được đặt lên 1, ngõ ra OC0
sẽ hoạt động
+ Bit 2 (CS02), bit 1 (CS01), bit 0 (CS00): chọn xung đồng hồ: ba bit này dùng để
lựa chọn nguồn xung cho bộ định thời/bộ đếm
Hình 10 Lựa chọn nguồn xung cho bộ định thời
Thanh ghi bộ định thời/bộ đếm
Thanh ghi bộ định thời/bộ đếm cho phép truy cập trực tiếp vào bộ đếm 8 bit
Thanh ghi so sánh ngõ ra – OCR0
Thanh ghi này chứa một giá trị 8 bit và liên tục được so sánh với giá trị của bộ đếm
Thanh ghi mặt nạ ngắt
Trang 9+ Bit 1 (OCIE0): cho phép ngắt báo hiệu so sánh
+ Bit 0 (TOIE0): cho phép ngắt tràn bộ đếm
Thanh ghi cờ ngắt bộ định thời
+ Bit 1 (OCF0): Cờ so sánh ngõ ra 0
+ Bit 0 (TOV0): Cờ tràn bộ đếm
Bit TOV0 được đặt lên 1 khi bộ đếm bị tràn và được xóa bởi phần cứng khi vector ngắt tương ứng được thực hiện Bit này cũng có thể được xóa bằng phần mềm
II Động cơ điện một chiều
1 Cấu tạo
Cấu tạo của động cơ điện gồm stator, rotor và hệ thống chổi than – vành góp
Stator bao gồm vỏ máy, cực từ chính, cực từ phụ, dây quấn phần cảm (dây quấn kích thích) gồm các bối dây đặt trong rãnh của lõi sắt Số lượng cực từ chính phụ thuộc tốc độ quay Đối với động cơ công suất nhỏ, người ta có thể kích từ bằng nam châm vĩnh cửu
Rotor (còn gọi là phần ứng) gồm các lá thép kỹ thuật điện ghép lại có rãnh để đặt các phần tử của dây quấn phần ứng Điện áp một chiều được đưa vào phần ứng qua hệ thống chổi than – vành góp Kết cấu của giá đỡ chổi than có khả năng điều chỉnh áp lực tiếp xúc và tự động duy trì áp lực tùy theo độ mòn của chổi than
Chổi than – vành góp có chức năng đưa điện áp một chiều vào cuộn dây phần ứng và đổi chiều dòng điện trong cuộn dây phần ứng Số lượng chổi than bằng số lượng cực từ (một nửa có cực tính dương và một nửa có cực tính âm)
2 Nguyên lý làm việc
Khi đặt lên dây quấn kích từ một điện áp kích từ Uk nào đó thì trong dây quấn kích từ sẽ xuất hiện dòng kích từ ik và do đó mạch từ của mách sẽ có từ thông Φ Tiếp đó đặt một giá trị điện áp U lên mạch phần ứng thì trong dây quấn phần ứng sẽ có một dòng điện I chạy qua Tương tác giữa dòng điện phần ứng và từ thông kích thích tạo thành moment điện từ Moment điện từ này kéo cho phần ứng quay quanh trục Giá trị của moment điện từ được tính bằng công thức:
2
p n
m I k I
a
Trong đó: p là số đôi cực của động cơ điện; n là số thanh dẫn phần ứng dưới một cực từ;
a là số mạch nhánh song song của dây quấn phần ứng; k là hệ số kết cấu của máy
Trang 10Cơ chế sinh lực quay của động cơ điện một chiều
Khi có một dòng điện chạy qua cuộn dây quấn xung quanh một lõi sắt non, cạnh phía bên cực dương sẽ bị tác động bởi một lực hướng lên, trong khi cạnh đối diện lại bị tác động bằng một lực hướng xuống theo nguyên lý bàn tay trái của Fleming Các lực này gây tác động quay lên cuộn dây, và làm cho rotor quay Để làm cho rotor quay liên tục và đúng chiều, một bộ cổ góp điện sẽ làm chuyển mạch dòng điện sau mỗi vị trí ứng với 1/2 chu kỳ Chỉ có vấn đề là khi mặt của cuộn dây song song với các đường sức từ trường Nghĩa là lực quay của động cơ bằng 0 khi cuộn dây lệch 900 so với phương ban đầu của nó, khi đó rotor sẽ quay theo quán tính
Trong các máy điện một chiều lớn, người ta có nhiều cuộn dây nối ra nhiều phiến góp khác nhau trên cổ góp Nhờ vậy dòng điện và lực quay được liên tục và hầu như không bị thay đổi theo các vị trí khác nhau của rotor
Phương trình cơ bản của động cơ 1 chiều:
u u
u
E K
V E R I
M K I
Với: Φ: Từ thông trên mỗi cực (Wb)
Iu: dòng điện phản ứng (A)
V: điện áp phản ứng (V)
Ru: điện trở phản ứng (Ω))
ω: tốc độ của động cơ (rad/s)
M: moment động cơ (N/m)
K: hằng số, phụ thuộc cấu trúc động cơ
3 Phân loại
- Động cơ một chiều kích từ bằng nam châm vĩnh cửu
- Động cơ một chiều kích từ độc lập (phần ứng và phần kích từ được cung cấp bởi hai nguồn riêng rẽ)
- Động cơ một chiều kích từ nối tiếp: cuộn dây kích thích được mắc nối tiếp với phần ứng
- Động cơ một chiều kích từ song song: cuộn dây kích thích được mắc song song với phần ứng
- Động cơ một chiều kích từ hỗn hợp: gồm có 2 cuộn dây kích thích, một cuộn mắc nối tiếp với phần ứng, cuộn còn lại mắc song song với phần ứng
(*) Mô phỏng mạch trên Proteus