Các lệnh luận lý ( Boolean Instruction):

Một phần của tài liệu khảo sát vi điều khiển 89c51 và thiết kế mạch đồng hồ (Trang 32 - 34)

III. KHẢO SÁT TẬP LỆNH CỦA VDK 8951:

5. Các lệnh luận lý ( Boolean Instruction):

SVTH:Võ Văn Nhiệm Trang 32

8951 chứa một bộ xử lí luận lý đầy đủ cho các hoạt động bit đơn, đây là một điểm mạnh của họ vi điều kiển MCS-51 mà các họ vi điều khiển khác không có. RAM nội chứa 128 bit đơn vị và các vùng nhớ các thanh ghi chức năng đặc biệt cấp lên đến 128 đơn vị khác. Tất cả các đường Port là bit định vị, mỗi đường có thể được xử lí như Port đơn vị riêng biệt. Cách truy xuất các bit này không chỉ các lệnh rẽ nhánh không, mà là một danh mục đầy đủ các lệnh MOVE, SET, CLEAR, COMPLEMENT, OR, AND.

Toàn bộ sự truy xuất của bit dùng sự định vị trực tiếp với những địa chỉ từ 00H - 7FH trong 128 vùng nhớ thấp và 80H - FFh ở các vùng thanh ghi chức năng đặc biệt.

Bit Carry C trong thanh ghi PSW\ của từ trạng thái chương trình và được dùng như một sự tích lũy đơn của bộ xử lí luận lý. Bit Carry cũng là bit định vị và có địa chỉ trực tiếp vì nó nằm trong PSW. Hai lệnh CLR C và CLR CY đều có cùng tác dụng là xóa bit cờ Carry nhưng lệnh này mất 1 byte còn lệnh sau mất 2 byte.

Hoạt động của các lệnh luận lý được tóm tắt như sau:

CLR C : Xóa cờ Carry xuống 0. Có ảnh hưởng cờ Carry. CLR BIT : Xóa bit xuống 0. Không ảnh hưởng cờ Carry. SETB C : Set cờ Carry lên 1. Có ảnh hưởng cờ Carry. SETB BIT : Set bit lên 1. Không ảnh hưởng cờ Carry. CLP C : Đảo bit cờ Carry. Có ảnh hưởng cờ Carry. CPL BIT : Đảo bit. Không ảnh hưởng cờ Carry.

ANL C, BIT : (C) (C) AND (BIT): Có ảnh hưởng cờ Carry.

ANL C, / BIT: (C) (C) AND NOT (BIT): Không ảnh hưởng cờ Carry. ORL C, BIT : (C) (C) OR (BIT): Tác động cờ Carry.

ORL C, / BIT : (C) (C) OR NOT (BIT): Tác động cờ Carry. MOV C, BIT : (C) (BIT) : Cờ Carry bị tác động.

SVTH:Võ Văn Nhiệm Trang 33

MOV BIT, C : (BIT) (C) : Không ảnh hưởng cờ Carry.

Một phần của tài liệu khảo sát vi điều khiển 89c51 và thiết kế mạch đồng hồ (Trang 32 - 34)

Tải bản đầy đủ (DOC)

(43 trang)
w