Chương 7: Các lệnh di chuyển nội dung ô nhớ Các lệnh di chuyển thực hiện việc di chuyển hoặc sao chép số liệu từ vùng này sang vùng khác trong bộ nhớ. Trong LAD và STL lệnh dòch chuyển thực hiện việc di chuyển hay sao chép nội dung một byte, một từ đơn, hoặc một từ kép từ vùng này sang vùng khác trong bộ nhớ. Lệnh trao đổi nội dung vủa hai byte trong một từ đơn thực hiện việc chuyển nội dung của byte thấp sang byte cao và ngược lại chuyển nội dung của byte cao sang byte thấp của từ đó. ª MOV_B (LAD) Lệnh sao chép nội dung của byte IN sang byte OUT ª MOVB (STL) ª MOV_W (LAD) Lệnh sao chép nội dung của từ đơn IN sang OUT ª MOVW (STL) ª MOV_DW (LAD) Lệnh sao chép nội dung của từ kép IN sang OUT ª MOVD (STL) ª MOV_R (LAD) Lệnh sao chép một số thực từ IN (4byte) sang ª MOVR (STL) OUT (4byte) Cú pháp lệnh dòch chuyển như sau: LAD STL Toán hạng MOV_B — EN — IN OUT— MOVB IN OUT IN : VB, IB, QB, MB, SMB, AC, (byte) hằng số, *VD, *AC OUT: VB, IB, QB, MB, SMB, AC, (byte) *VD, *AC MOV_W — EN — IN OUT— MOVW IN OUT IN : VB, IB, QB, MB, SMB, AC, (từ đơn) hằng số, *VD, *AC OUT: VB, IB, QB, MB, SMB, AC, (từ đơn) *VD, *AC MOV_DW — EN — IN OUT— MOVD IN OUT IN : VB, IB, QB, MB, SMB, AC, (từ kép) hằng số, *VD, *AC OUT: VB, IB, QB, MB, SMB, AC, (từ kép) *VD, *AC MOV_R IN : VB, IB, QB, MB, SMB, AC, — EN — IN OUT— MOVR IN OUT (từ kép) hằng số, *VD, *AC OUT: VB, IB, QB, MB, SMB, AC, (từ kép) *VD, *AC a. Sử dụng bộ đếm tốc độ cao: Bộ đếm tốc độ cao được sử dụng để theo dõi và điều khiển các quá trình có tốc độ cao mà PLC không thể khống chế được do bò hạn chế về thời gian của vòng quét. Trong CPU 214 có ba bộ đếm tốc độ cao được đánh số lần lượt là: HSC0, HSC1 và HSC2. Nguyên tắc hoạt động của bộ đếm tốc độ cao cũng tương tự như các bộ đếm thông thường khác, tức là đếm theo sườn lên của tín hiệu đầu vào. Số đếm được sẽ được hệ thống ghi nhớ vào một ô nhớ đặc biệt kiểu từ kép và được gọi là giá trò đếm tức thời ký hiệu là CV. Khi giá trò đếm tức thời bằng giá trò đặt trước thì bộ đếm phát ra một tín hiệu báo ngắt. Giá trò đặt trước là một số nguyên 32 bit được lưu trong một ô nhớ kiểu từ kép, ký hiệu là PV. Chọn chế độ làm việc cho Bộ đếm tốc độ cao bằng lệnh HDFE và chỉ có thể kích bộ đếm sau khi đã khai báo chế độ làm việc bằng lệnh HSC. Nguyên lý làm việc của các bộ đếm tốc độ cao: o HSC0: Tần số đếm cực đại cho phép của HSC0 là 2 KHz. Bộ đếm HSC0 sử dụng một cổng vào là I0.0 và chỉ có một chế độ làm việc duy nhất là đếm tiến hoặc lùi số các sườn lên của tín hiệu đầu vào tại ngõ vào I0.0 HSC0 sử dụng từ kép SMD38 để lưu giá trò đếm tức thời CV, giá trò đặt trước PV được ghi vào từ kép SMD42 (cả hai giá trò PV và CV là những số nguyên 32 bit có dấu). Chiều đếm tiến/lùi của HSC0 được qui đònh bởi trạng thái của bit SM37.3 như sau:SM37.3 = 0 đếm lùi theo sườn lên của I0.0 = 1 đếm tiến theo sườn lên của I0.0 Các bước khai báo sử dụng HSC0 (nên thực hiện tại vòng quét đầu tiên): - Nạp giá trò điều khiển phù hợp cho SMB37. - Xác đònh chế độ làm việc cho bộ đếm bằng lệnh HDEF (do HSC0 có một chế độ làm việc nên lệnh xác đònh sẽ là: HDEF K0 K0) - Nạp giá trò tức thời ban đầu và giá trò đặt trước vào SMD38 và SMD42. - Khai báo sử dụng chế độ ngắt vào ra và kích tín hiệu báo ngắt HSC0 bằng lệnh ATCH. - Kích bộ đếm bằng lệnh HSC K0 o HSC1: tần số đếm cực đại tại ngõ vào là 7KHz HSC1 là một bộ đếm linh hoạt, sử dụng bốn đầu vào I0.6, I0.7, I1.0 và I1.1 với 12 chế độ làm việc khác nhau. HSC1 sử dụng từ kép SMD48 để lưu giá trò đếm tức thời CV, giá trò đặt trước PV được ghi vào từ kép SMD52 (cả hai giá trò PV và CV là những số nguyên 32 bit có dấu). Khác với HSC0, HSC1 có ba khả năng đếm: - Đếm tiến hoặc lùi theo sườn lên của I0.6 (chế độ 0, 1, 2, 3, 4, 5) - Đếm tiến theo sườn lên của I0.6 và lùi theo sườn lên của I0.7 (chế độ 6, 7, 8) - Đếm tiến hoặc lùi số lần lệch giá trò logic giữa hai cổng I0.6 và I0.7, tức là số làn phép tính logic XOR của I0.6 và I0.7 có kết quả là 1 (chế độ 6, 7, 8) Chiều đếm (tiến hay lùi) trong chế độ 0, 1, 2 được quy đònh bởi bit SM47.3 như sau: SM47.3 = 0 đếm lùi theo sườn lên của I0.6 = 1 đếm tiến theo sườn lên của I0.6 và trong chế độ 3, 4, 5 bởi đầu vào I0.7 như sau: I0.7 = 0 đếm lùi theo sườn lên của I0.6 = 1 đếm tiến theo sườn lên của I0.6 HSC1 có hai tần số đếm. Trong các chế độ 0÷8 tần số đếm bằng tần số thay đổi trạng thái tín hiệu đầu vào là 7KHz, riêng trong chế độ 9, 10, 11 tùy theo sự khai báo sử dụng mà tần số đếm có thể bằng hoặc có thể gấp 4 lần tần số biến thiên trạng thái kết quả phép tính XOR giữa I0.6 và I0.7. Do đó trong chế độ 9, 10, 11 tần số đếm cực đại cho phép của HSC1 sẽ là 28KHz. Cấu trúc byte SMB47 được gọi là byte điều khiển của HSC1 như sau SM47. 0 Kiểu reset cho tín hiệu xoá tại I0.0 (chế độ 1,2,4,5,7,8,10,11) SM47. 1 Kiểu kích cho tín hiệu khởi động tại I1.1 (chế độ 2,5,8,11) SM47. 2 Tần số đếm của HSC1 (chế độ 9,10,11) SM47. 3 Chiều đếm: 0 - đếm lùi, 1 - đếm tiến SM47. 4 Cho phép đổi chiều đếm: 0-không cho phép, 1-cho phép SM47. 5 Cho phép sửa đổi giá trò đặt trước: 0-không cho phép, 1-cho phép SM47. 6 Cho phép sửa đổi giá trò tức thời: 0-không cho phép, 1-cho phép SM47. 7 1-cho phép kích HSC1, 0-cho phép huỷ HSC1 . của I0.6 và lùi theo sườn lên của I0 .7 (chế độ 6, 7, 8) - Đếm tiến hoặc lùi số lần lệch giá trò logic giữa hai cổng I0.6 và I0 .7, tức là số làn phép tính logic XOR của I0.6 và I0 .7 có kết quả. trúc byte SMB 47 được gọi là byte điều khiển của HSC1 như sau SM 47. 0 Kiểu reset cho tín hiệu xoá tại I0.0 (chế độ 1,2,4,5 ,7, 8,10,11) SM 47. 1 Kiểu kích cho tín hiệu khởi động tại I1.1 (chế độ. đầu và giá trò đặt trước vào SMD38 và SMD42. - Khai báo sử dụng chế độ ngắt vào ra và kích tín hiệu báo ngắt HSC0 bằng lệnh ATCH. - Kích bộ đếm bằng lệnh HSC K0 o HSC1: tần số đếm cực đại tại