# **MITSUBISHI** # type ACPU/QCPU-A (A Mode)(Fundamentals) **Programming Manual** # **SAFETY CAUTIONS** (You must read these cautions before using the product) In connection with the use of this product, in addition to carefully reading both this manual and the related manuals indicated in this manual, it is also essential to pay due attention to safety and handle the product correctly. The safety cautions given here apply to this product in isolation. For information on the safety of the PC system as a whole, refer to the CPU module User's Manual. Store this manual carefully in a place where it is accessible for reference whenever necessary, and forward a copy of the manual to the end user. # **REVISIONS** \*The manual number is given on the bottom left of the back cover. | Print Date | *Manual Number | Revision | |------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Feb., 1991 | IB (NA) 66249-A | First edition | | Sep., 1993 | IB (NA) 66249-B | Addition of models | | | | A1SCPU, A2UCPU(S1), A3UCPU, A4UCPU, A2ACPU(S1)-F, A3ACPU-F | | | | Correction | | | | CONTENTS, Section 1, 1.1, 2.1, 2.3.1, 2.4, 2.4.2, 2.4.3, 2.5, 2.6, 2.6.1, to 2.6.3, 3.1 to 3.6, 3.6.2, 3.6.3, 3.7, 3.7.1 to 3.7.4, 3.8, 3.8.2, 3.9 to 3.11, 3.11.2, 3.12, 3.13, 3.13.1, 3.13.2, 3.14 to 3.17, 4, 4.2, 4.2.2, 4.2.3, 4.3, 4.3.2, 4.4, 4.4.1, 5, 5.1, 5.1.1 to 5.1.3, 5.2, 5.2.1, 5.3, 5.3.1, 5.3.2, 5.3.4, 6, 6.1 to 6.8, 6.8.2, 6.8.3, 6.9 to 6.13, 6.13.1, 6.14 to 6.17, 7, 8 | | | | Addition | | | | Section 5.2.3, 6.18, 9 to 11 | | | | Deletion | | | | For BEGINNERS | | Sep., 1990 | IB (NA) 66249-C | Correction | | | | Section 3.11.2, 3.13.2, 4.2.2 | | Dec., 1990 | IB (NA) 66249-D | Chapter 9 added | | May., 1991 | IB (NA) 66249-E | Correction | | | | Section 3.6.3, 3.7.4, 3.13.1, 3.13.2, 4.4.1<br>A1SCPU added | | Feb., 1992 | IB (NA) 66249-F | Correction | | | | Section 3.16, 9.1, 9.6 | | Apr., 1992 | IB (NA) 66249-G | Correction | | | | Section 3.5, 5.3.4, Chapter 8, Section 9.6 | | Aug., 1992 | IB (NA) 66249-H | Correction | | | | Section 3.3 | | May., 1993 | IB (NA) 66249-I | Correction | | | | A2UCPU(S1), A3UCPU, A4UCPU, A52GCPU, A373CPU added Section 6.18, 9.7, 9.8, Chapter 10, 11 added | | Aug., 1994 | IB (NA) 66249-J | Correction | | | | Section 2.4.1, 2.4.2, Chapter 11 | | May., 1997 | IB (NA) 66249-K | Correction | | | | Section 3.1, 3.3, 3.4, 3.5, 3.6.2, 3.10, 3.11.2, 5.3.4, 10.4.1, IMPORTANT | | | | Addition | | | | Section 3.11.1, 5.3.4, 6.1, Chapter 11 | This manual does not imply guarantee or implementation right for industrial ownership or implementation of other rights. Mitsubishi Electric Corporation is not responsible for industrial ownership problems caused by use of the contents of this manual. | Print Date | *Manual Number | Dovision | |------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | · | | Revision | | Aug., 1998 | IB (NA) 66249-L | Addition of models | | : | · | A1SJCPU-S3, A1SCPUC24-R2, A2SCPU(S1),<br>A1SHCPU, A1SJHCPU, A2SHCPU(S1),<br>A2ASCPU(S1), A1FXCPU | | | | Addition | | | | Section 4.5, Appendix 1 | | | · | Correction | | | | CONTENTS, Section 1.1, 3.1, 4.3.1, Chapter 5, Section 6.9, 6.10, 6.11, 9.1, 9.3 to 9.12, 10.3 | | | | Deletion | | | | A2NCPU(P21/R21)-F, A2NCPU(P21/R21)-S1-F,<br>A3NCPU(P21/R21)-F, A3N Board | | Feb., 2000 | IB (NA) 66249-M | The manual name is changed into ACPU/QCPU-A(A<br>Mode) Programming Manual (Fundamentals).<br>[Old name: ACPU Programming Manual<br>(Fundamentals).] | | | • | Addition of models | | | | Q02CPU-A, Q02HCPU-A, Q06HCPU-A,<br>A2USHCPU-S1, A1SJHCPU-S8 | | Dec., 2000 | IB (NA) 66249-N | Correction | | | | Section 3.1, 3.6.2, Chapter 8 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | , | | | | | | | | , | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This manual does not imply guarantee or implementation right for industrial ownership or implementation of other rights. Mitsubishi Electric Corporation is not responsible for industrial ownership problems caused by use of the contents of this manual. # **CONTENTS** | 1. | GEN | ERAL D | ESCRIPTION | 1-1 | |----|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------| | | 1.1 | CPU Ty | ypes and Their Abbreviations Used in this Manual | 1 – 1 | | 2. | PRO | GRAMM | IING LANGUAGES AND OPERATIONS | 2-1~2-19 | | | 2.1 | Prograi | mming Languages | 2 – 1 | | | | 2.1.1 | Relay symbolic language (ladder mode) | 2 – 2 | | | | 2.1.2 | Logic symbolic language (list mode) | 2 – 4 | | | 2.2 | Operati | ion Processing of the PC CPU | 2-5 | | | 2.3 | Input a | nd Output Processings | 2 – 6 | | | | 2.3.1 | Direct mode | 2 – 6 | | | | 2.3.2 | Refresh mode | 2-7 | | | 2.4 | Respor | nse Lag | 2-8 | | | | 2.4.1 | In the direct mode | 2-8 | | | | 2.4.2 | In the refresh mode | 2-9 | | | | 2.4.3 | Response when direct and refresh modes are switched | 2 – 10 | | | 2.5 | Scan T | ime | | | | 2.6 | | ic Data Usable for Sequence Programs | | | | | 2.6.1 | Binary notation | 2 – 16 | | | | 2.6.2 | Hexadecimal | 2 – 18 | | | | 2.6.3 | BCD (Binary-coded decimal) | | | | | | , , , , , , , , , , , , , , , , , , , , | | | 3. | DEVI | CES | | 3-1~3-57 | | | | | | | | | 3.1 | List of [ | Devices | 3-1 | | | 3.1<br>3.2 | Input (> | K) and Output (Y) | 3-5 | | | | Input (> | | 3-5 | | | 3.2<br>3.3<br>3.4 | Input ()<br>Internal<br>Link Re | K) and Output (Y) | 3-5<br>3-8 | | | 3.2<br>3.3<br>3.4<br>3.5 | Input ()<br>Internal<br>Link Re<br>Annund | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) ciators (F) | 3-5<br>3-8<br>3-9<br>3-11 | | | 3.2<br>3.3<br>3.4 | Input (X<br>Internal<br>Link Re<br>Annund<br>Timers | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) ciators (F) (T) | 3-5<br>3-8<br>3-9<br>3-11 | | | 3.2<br>3.3<br>3.4<br>3.5 | Input ()<br>Internal<br>Link Re<br>Annund | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) ciators (F) (T) 100 ms timers, 10 ms timers, and 100 ms retentive timers | 3-5<br>3-8<br>3-9<br>3-11<br>3-15 | | | 3.2<br>3.3<br>3.4<br>3.5 | Input (X<br>Internal<br>Link Re<br>Annund<br>Timers | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) ciators (F) (T) | 3-5<br>3-8<br>3-9<br>3-11<br>3-15 | | | 3.2<br>3.3<br>3.4<br>3.5 | Input (><br>Internal<br>Link Re<br>Annund<br>Timers<br>3.6.1 | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) ciators (F) (T) 100 ms timers, 10 ms timers, and 100 ms retentive timers | 3-5<br>3-8<br>3-9<br>3-11<br>3-15<br>3-15 | | | 3.2<br>3.3<br>3.4<br>3.5 | Input (X<br>Internal<br>Link Re<br>Annund<br>Timers<br>3.6.1<br>3.6.2 | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) ciators (F) (T) 100 ms timers, 10 ms timers, and 100 ms retentive timers Processing and accuracy of timers. | 3-5<br>3-8<br>3-9<br>3-11<br>3-15<br>3-15<br>3-17 | | | 3.2<br>3.3<br>3.4<br>3.5 | Input (><br>Internal<br>Link Re<br>Annund<br>Timers<br>3.6.1<br>3.6.2<br>3.6.3<br>3.6.4 | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) ciators (F) (T) 100 ms timers, 10 ms timers, and 100 ms retentive timers Processing and accuracy of timers Extension timers | 3-53-83-93-113-153-153-173-21 | | | 3.2<br>3.3<br>3.4<br>3.5<br>3.6 | Input (><br>Internal<br>Link Re<br>Annund<br>Timers<br>3.6.1<br>3.6.2<br>3.6.3<br>3.6.4 | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) ciators (F) (T) 100 ms timers, 10 ms timers, and 100 ms retentive timers Processing and accuracy of timers Extension timers 1ms timer | 3-5 3-8 3-9 3-11 3-15 3-15 3-17 3-21 3-23 3-26 | | | 3.2<br>3.3<br>3.4<br>3.5<br>3.6 | Input (><br>Internal<br>Link Re<br>Annund<br>Timers<br>3.6.1<br>3.6.2<br>3.6.3<br>3.6.4<br>Counter | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) ciators (F) (T) 100 ms timers, 10 ms timers, and 100 ms retentive timers Processing and accuracy of timers Extension timers 1ms timer | 3-53-83-93-113-153-153-173-213-233-263-27 | | | 3.2<br>3.3<br>3.4<br>3.5<br>3.6 | Input (> Internal Link Re Annunc Timers 3.6.1 3.6.2 3.6.3 3.6.4 Counte 3.7.1 | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) ciators (F) (T) 100 ms timers, 10 ms timers, and 100 ms retentive timers Processing and accuracy of timers Extension timers 1ms timer ers (C) Count processing in direct mode | 3-5 3-8 3-9 3-11 3-15 3-15 3-17 3-21 3-23 3-23 3-26 3-27 | | | 3.2<br>3.3<br>3.4<br>3.5<br>3.6 | Input (X) Internal Link Re Annunc Timers 3.6.1 3.6.2 3.6.3 3.6.4 Counte 3.7.1 3.7.2 | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) Ciators (F) (T) 100 ms timers, 10 ms timers, and 100 ms retentive timers Processing and accuracy of timers Extension timers 1ms timer ers (C) Count processing in direct mode Count processing in refresh mode | 3-53-83-93-153-153-173-213-233-233-273-283-29 | | | 3.2<br>3.3<br>3.4<br>3.5<br>3.6 | Input (> Internal Link Re Annunc Timers 3.6.1 3.6.2 3.6.3 3.6.4 Counte 3.7.1 3.7.2 3.7.3 3.7.4 | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) ciators (F) (T) 100 ms timers, 10 ms timers, and 100 ms retentive timers Processing and accuracy of timers Extension timers 1ms timer ers (C) Count processing in direct mode Count processing in refresh mode Maximum counting speed | 3-5 3-8 3-9 3-11 3-15 3-15 3-17 3-21 3-23 3-26 3-27 3-28 3-28 3-29 | | | 3.2<br>3.3<br>3.4<br>3.5<br>3.6 | Input (> Internal Link Re Annunc Timers 3.6.1 3.6.2 3.6.3 3.6.4 Counte 3.7.1 3.7.2 3.7.3 3.7.4 | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) Ciators (F) (T) 100 ms timers, 10 ms timers, and 100 ms retentive timers Processing and accuracy of timers Extension timers 1ms timer ers (C) Count processing in direct mode Count processing in refresh mode Maximum counting speed Extension counters | 3-5 3-8 3-9 3-11 3-15 3-15 3-17 3-21 3-23 3-26 3-27 3-28 3-29 3-30 3-30 | | | 3.2<br>3.3<br>3.4<br>3.5<br>3.6 | Input (> Internal Link Re Annunc Timers 3.6.1 3.6.2 3.6.3 3.6.4 Counte 3.7.1 3.7.2 3.7.3 3.7.4 Interrupt | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) ciators (F) (T) 100 ms timers, 10 ms timers, and 100 ms retentive timers Processing and accuracy of timers Extension timers 1ms timer ers (C) Count processing in direct mode Count processing in refresh mode Maximum counting speed Extension counters of Counters (C) | 3-5 3-8 3-9 3-11 3-15 3-15 3-17 3-21 3-23 3-26 3-27 3-28 3-29 3-30 3-32 | | | 3.2<br>3.3<br>3.4<br>3.5<br>3.6 | Input (X) Internal Link Re Annund Timers 3.6.1 3.6.2 3.6.3 3.6.4 Counte 3.7.1 3.7.2 3.7.3 3.7.4 Interrup 3.8.1 3.8.2 | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) ciators (F) (T) 100 ms timers, 10 ms timers, and 100 ms retentive timers Processing and accuracy of timers Extension timers 1ms timer ers (C) Count processing in direct mode Count processing in refresh mode Maximum counting speed Extension counters of Counters (C) Counters for interrupt programs | 3-53-83-93-153-153-173-213-233-263-273-283-293-303-323-32 | | | 3.2<br>3.3<br>3.4<br>3.5<br>3.6<br>3.7 | Input (X) Internal Link Re Annunc Timers 3.6.1 3.6.2 3.6.3 3.6.4 Counte 3.7.1 3.7.2 3.7.3 3.7.4 Interrup 3.8.1 3.8.2 Data Re | K) and Output (Y) I Relays (M), Latch Relays (L), and Step Relays (S) elays (B) Ciators (F) (T) 100 ms timers, 10 ms timers, and 100 ms retentive timers Processing and accuracy of timers Extension timers 1ms timer ers (C) Count processing in direct mode Count processing in refresh mode Maximum counting speed Extension counters of Counters (C) Counters for interrupt programs Counters for counting the number of interrupts (Interrupt counters) | 3-5 3-8 3-9 3-11 3-15 3-15 3-17 3-21 3-21 3-26 3-27 3-28 3-29 3-30 3-30 3-32 3-34 3-37 | | | | 3.11.1 File registers | - 40 | |----|------|-------------------------------------------------------------------------------------------------------------------------------------------|------| | | | 3.11.2 Extension file registers | - 42 | | | 3.12 | Accumulators (A) | - 45 | | | 3.13 | Index Registers | | | | | 3.13.1 Index registers (Z, V) | | | | | 3.13.2 Index registers (Zn(Z, Z1 to Z6), Vn(V, V1 to V6)) | - 48 | | | 3.14 | Nesting (N) | - 50 | | | 3.15 | Pointers (P) | - 51 | | | 3.16 | Interrupt Pointers (I)3 - | - 52 | | | 3.17 | Special Relays and Special Registers | - 54 | | 4. | ALLC | DCATION OF I/O NUMBERS 4-1~4- | - 19 | | | 4.1 | I/O Numbers | _ 1 | | | 4.2 | I/O Number Allocation of the Building-block Type CPUs | | | | | 4.2.1 Basics of the I/O number allocation | | | | | 4.2.2 I/O allocation using peripheral devices | | | | | 4.2.3 Example of I/O number allocation | | | | 4.3 | I/O Allocation of the A0J2HCPU | | | | 7.0 | 4.3.1 Basics of I/O allocation | | | | | 4.3.2 Example of I/O number allocation | | | | 4.4 | I/O Allocation of the A2CCPU | | | | 7.7 | 4.4.1 Basics of I/O allocation | | | | 4.5 | I/O Number Assignment for A1FXCPU 4 - | | | | 4.0 | 4.5.1 I/O number assignment | | | 5. | PRO | GRAM STRUCTURE 5 – 1 ~ 5 - | - 24 | | ٥. | | | | | | 5.1 | Sequence Program5 | | | | | 5.1.1 Main routine program | | | | | 5.1.2 Subroutine program | | | | | 5.1.3 Interrupt programs | | | | 5.2 | Microcomputer Programs | | | | | 5.2.1 Utility program5 - | - 13 | | | | 5.2.2 User-created microcomputer program | | | | | 5.2.3 SFC program 5 - | - 13 | | | 5.3 | How to Use the Sub-Programs | - 15 | | | | 5.3.1 When the CHG instruction is executed at the leading edge of the input and the execution/non-execution result storage memory is used | 47 | | | | commonly with the main programs and the sub-programs | - 17 | | | | input and the execution/non-execution result storage memory is sued independently with the main programs and the sub-programs5 - | - 19 | | | | 5.3.3 When the CHG instruction is executed when the input is ON | | | | | and the execution/non- execution result storage memory is used independently with the main programs and the sub-programs 5 - | - 2C | | | | 5.3.4 Notes on write during run | | | | | 5.3.5 Notes on writing subprogram | | | 6. | FUN | CTIONS | 1 ~ 6 – 50 | |----|------|----------------------------------------------------------------------------------------------------------|------------| | | 6.1 | Constant Scan | 6-3 | | | 6.2 | Retaining Device Data (Latch Function) | | | | 6.3 | PC CPU RUN/STOP with a Peripheral Device (Remote RUN/STOP) | 6-7 | | | 6.4 | Stopping the Sequence Program Operation Retaining | | | | | the State of Outputs (PAUSE) | | | | 6.5 | Retaining Device Data when a Specific Condition is Established (Status Latch) | | | | 6.6 | Sampling Device Data at Constant Intervals (Sampling Trace) | 6 – 14 | | | 6.7 | Forced ON/OFF of the OUT Instruction with a | 0 47 | | | 6.8 | Peripheral Device in the RUN Stare (Offline Switch) | | | | 0.0 | Step Operation | | | | | | | | | | 6.8.2 Step operation (II) | | | | | 6.8.3 Precautions at step operation | | | | 6.9 | Clock Function | | | | 6.10 | I/O Module Replacement During Online | | | | 6.11 | Device Comments | | | | 6.12 | Watchdog Timer | | | | 6.13 | • | | | | | 6.13.1 Operation mode when an error occurs | | | | 6.14 | 0 1 ( ) | | | | 6.15 | Registration of the Entry Code | | | | 6.16 | Registration of the Print Title | 6 – 47 | | | 6.17 | Display Mode Setting of Annunciators (In case of the CPU module with the LED indicator of 16 characters) | 6 – 48 | | | 6.18 | ERROR LED Indication Priority Setting | | | 7. | MET | HOD OF DATA COMMUNICATION WITH SPECIAL-FUNCTION MODULE | 7-1 | | 8. | PAR | AMETER SETTING 8 - | -1~8-9 | | 9. | CON | FIGURATION OF USER MEMORY AREA 9 | 1 ~ 9 – 18 | | | 9.1 | A1CPU and A1NCPU | 9-2 | | | 9.2 | A2CPU(S1) and A2NCPU(S1) | 9-3 | | | 9.3 | A0J2HCPU, A2CCPU, A52GCPU, A1SCPU(S1), and A1SJCPU(S3) | 9 – 4 | | | 9.4 | A2SCPU(S1) | | | | 9.5 | A1SHCPU, A1SJHCPU(S8), and A2HCPU(S1) | 9-6 | | | 9.6 | A1FXCPU | 9-7 | | | 9.7 | A2ASCPU, A2ASCPU-S1, A2ASCPU-S30, and A2USHCPU-S1 | 9 – 8 | | | 9.8 | A3CPU, A3NCPU, A3VCPU, A73CPU, and A3HCPU | 9-9 | | | 9.9 | A3MCPU | 9 – 11 | | | 9.10 | A2ACPU(S1) and A3ACPU | 9 – 12 | | | 9.11 | A2UCPU(S1) and A3UCPU | 9 – 13 | | | 9.12 | | | | | 9.13 | Q02CPU-A, Q02HCPU-A and Q06HCPU-A | 9 – 18 | | 10. | | CONFIGURATION OF USER MEMORY AREA (WHEN AN SFC PROGRAM IS USED) | | | | | | | | |-----|-------|-----------------------------------------------------------------|-----------------|--|--|--|--|--|--| | | | SFC Program Memory Area | | | | | | | | | | 10.2 | A2NCPU(S1), and A3NCPU | 10 – 2 | | | | | | | | | 10.3 | A0J2HCPU, A2CCPU, A52GCPU, and A1SCPU | | | | | | | | | | 10.4 | AnACPU*, and AnUCPU | 10 – 3 | | | | | | | | | | 10.4.1 Allocation when extension comment capacity is not set | 10 – 4 | | | | | | | | | | 10.4.2 Allocation when extension comment capacity is set | 10 – 5 | | | | | | | | 11. | ALLC | OCATION OF THE MELSECNET/10 NETWORK PARAMETERS | 11 - 1 ~ 11 - 2 | | | | | | | | APF | PENDI | x | APP – 1 | | | | | | | | | APPE | ENDIX1 Differences between A3NCPU and A3N borad | APP – 1 | | | | | | | ## 1. GENERAL DESCRIPTION This manual describes the devices and the allocation procedures of input and output numbers which are required for creating programs for the MELSEC-A series programmable controllers. For the operations which pertain to the A6GPP, refer to the A-series basic course (for SW4GP-GPPAEE) (IB-66412) in the A-SERIES TRAINING MANUAL. # 1.1 CPU Types and Their Abbreviations Used in this Manual The CPU types and their abbreviations used in this manual are as given in the table below. Table 1.1 CPU Types and Their Abbreviations Used in this Manual | Abbre | viation | СРИ Туре | | | | | |--------|-----------|--------------------------------------------------------------|--|--|--|--| | | A1 | A1CPU(P21/R21) | | | | | | An | A2(-S1) | A2CPU(P21/R21), A2CPU(P21/R21)-S1 | | | | | | l | A3 | A3CPU(P21/R21) | | | | | | | A1N | A1NCPU(P21/R21) | | | | | | AnN | A2N(-S1) | A2NCPU(P21/R21), A2NCPU(P21/R21)-S1 | | | | | | | A3N | A3NCPU(P21/R21) | | | | | | A | ЗН | A3HCPU (P21/R21) | | | | | | AS | зм | A3MCPU(P21/R21) | | | | | | AS | 3V | A3VCPU(P21/R21) | | | | | | AnA | A2A(-S1) | A2ACPU(P21/R21), A2ACPU(P21/R21)-S1 | | | | | | ADA | АЗА | A3ACPU(P21/R21) | | | | | | A n C | A1S | A1SCPU(S1), A1SCPUC24-R2, A1SJCPU, A1SJCPU-S3 | | | | | | AnS | A2S | A2SCPU(S1) | | | | | | AnSH | A1SH | A1SHCPU, A1SJHCPU(S8) | | | | | | Ansn | A2SH | A2SHCPU(S1) | | | | | | Α0. | J2H | A0J2HCPU(P21/R21) | | | | | | A | 2C | A2CCPU(P21/R21), A2CCPUDC24, A2CCPUC24(-PRF),<br>A2CJCPU(S3) | | | | | | A. | 73 | A73CPU(P21/R21) | | | | | | A5 | 2G | A52GCPU(T21B) | | | | | | | A2U(-S1) | A2UCPU, A2UCPU-S1 | | | | | | AnU | A3U | A3UCPU | | | | | | | A4U | A4UCPU | | | | | | A2AS | A2AS(-S1) | A2ASCPU, A2ASCPU-S1, A2ASCPU-S30 | | | | | | AZAG | A2USH-S1 | A2USHCPU-S1 | | | | | | | Q02 | Q02CPU-A | | | | | | QCPU-A | Q02H | Q02HCPU-A | | | | | | | Q06H | Q06HCPU-A | | | | | | A1 | FX | A1FXCPU | | | | | ## POINT This manual does not apply to the A0J2CPU(P23/R23). For the instructions used with the A0J2CPU(P23/R23), refer to the A0J2CPU Programming Manual (IB-66057). #### 2. PROGRAMMING LANGUAGES AND OPERATIONS This chapter describes the programming languages and the method of expression of numeric values which are applied to the writing of sequence programs. #### 2.1 Programming Languages Two different methods, a graphic method and a dedicated instruction method, can be used for the programming of a PC CPU. - The graphic method uses the relay symbolic language.\*1 - The dedicated instruction method uses the logic symbolic language.\*2 These languages can be used to write a sequence program. The SFC language<sup>\*3</sup> (MELSAP II) as well as the relay symbolic language and the logic symbolic language can be used for programming. • For the SFC language (MELSAP II), refer to the MELSAP II Programming Manual (IB-66361). # REMARKS - \*1: When the A6GPP/A6PHP/A6HGP is used, set it to the "ladder mode". - \*2: When the A6GPP/A6PHP/A6HGP/A7PU is used, set it to the "list mode". - \*3: For the PC CPU types which can execute an SFC language, refer to the MELSAP II Programming Manual (IB-66361) Version B and later. # 2.1.1 Relay symbolic language (ladder mode) The relay symbolic language is based on the concept of relay control ladder operation and allows programming using expressions which are similar to relay sequence ladders. # (1) Ladder block A ladder block is the smallest unit of sequence program operation. Each block begins at the bus on the left side and ends at the bus on the right side. Fig. 2.1 Ladder Blocks #### (2) Operation processing Sequence program operation is executed repeatedly according to ladder blocks beginning with step 0 and finishing with the END instruction. In each ladder block, operation begins with the left bus and proceeds to the right and from top to bottom. Fig. 2.2 Order of Operation Processing ## 2.1.2 Logic symbolic language (list mode) The logic symbolic language uses dedicated instructions for writing contacts and coils (which are written in the relay symbolic language using symbols). # (1) Operation processing Sequence program operation is executed repeatedly beginning with step 0 and finishing with the END instruction. After the END instruction execution, processing is executed again beginning with step 0. Fig. 2.3 Order of Operation Processing #### 2.2 Operation Processing of the PC CPU The PC CPU employs a repetitive operation method using a stored program. #### (1) Stored program - (a) The sequence program for operation processing is stored in the internal memory of the CPU. - (b) The CPU performs operation processing by reading the stored program by each instruction, and it controls status of devices according to the operation results. #### (2) Repetitive operation method The repetitive operation method repeats execution of a series of operations. The PC CPU repeats the operation processing as shown below. - (a) The PC CPU executes the sequence program, stored in the internal memory, beginning with step 0 to the END instruction. - (b) After executing the END instruction, the PC CPU performs internal processings such as timer/counter update and self diagnosis, and then, returns to step 0 of the sequence program. Fig. 2.4 Operation Processing of the PC CPU # REMARK The series of steps from step 0 to the next step 0 or from an END instruction to the next END instruction is called a scan. The scan time of the PC CPU is calculated as a total of the processing time of the sequence program (step 0 to END) and the internal processing time of the PC CPU. #### 2.3 Input and Output Processings The input and output modules are controlled by either the direct mode or the refresh mode. The control mode is determined by the type of CPU used. #### 2.3.1 Direct mode The direct mode allows input signals to be received by the PC by each signal and used as input data. The operation results are output by each result to the output data memory and output modules. Fig. 2.5 Flow of Input/Output Data in the Direct Mode # REMARKS - \*1 The following operations turn ON/OFF the input (X) data memory. Test operation with a peripheral device Link refresh of the MELSECNET Writing data from a computer link module - \*2 The following operations turn ON/OFF the output (Y) data memory. Execution of the OUT instruction of the sequence program Test operation with a peripheral device Writing data from a computer link module #### 2.3.2 Refresh mode The refresh mode allows input signals to be stored in batch in the input data memory before execution of each scan. The data in the input data memory is used for execution of the sequence program operation. The operation results (Y) are output by each result to the output data memory. The data in the output data memory is output in batch to the output modules after execution of the END instruction. - Input refresh Input data is read (1) in batch from the input module before execution of step 0 and stored in the input (X) data memory. - Output refresh Data (2) in the output (Y) data memory is output in batch to the output module before execution of step 0. - When an input contact command is executed: Input data is read (3) from the input (X) data memory and used for execution of the sequence program. - When an output contact command is executed: Output data is read (4) from the output (Y) data memory and used for execution of the sequence program. - When an output OUT instruction is executed: The operation result (5) is stored in the output (Y) data memory. Fig. 2.6 Flow of Input/Output Data in the Refresh Mode # POINT To access a part of input/output module memory area as in the direct mode, use the SEG (partial refresh) instruction. Refer to the ACPU Programming Manual (Common Instructions) (IB-66250) for details. o - | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | | 0 | o | 0 | o | x | Χ. | х | x | 0 | х | 0 | | Remark | | | | | | | | 1 | | | | # 2.4 Response Lag This section describes the lag between a change in the input module and its resultant change in the output module in the cases of direct mode and refresh mode. #### 2.4.1 In the direct mode An output module change lags max. 1 scan behind the corresponding input module change as shown in Fig. 2.7. Fig. 2.7 Output Y Change to Corresponding Input X Change n o | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0,0 | 0 | x | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Remark | | | | | | | | | | | | #### 2.4.2 In the refresh mode An output module change lags max. 2 scans behind the corresponding input module change as shown in Fig. 2.8. The external contacts close immediately before the input refresh is made. X5 is switched on when the input refresh is mode. Y5E is switched on when the operation of step 56 is executed. The external load is switched on when the output refresh is mode after the [END] instruction is executed. The delay time (external contact change to external load change) is therefore 1 scan. The external contacts close immediately after the input refresh is made. X5 is switched on when the next input refresh is mode. Y5E is switched on when the operation of step 56 is executed. The external load is switched on when the output refresh is mode after the [END] instruction is executed. The delay time (external contact change to external load change) is therefore 2 scans. Fig. 2.8 Output Y Change to Corresponding Input X Change | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0.0 | 0 | x | 0 | 0 | x | x | х | х | 0 | x | 0 | | Remark | | | | | | | | | | | | ## 2.4.3 Response when direct and refresh modes are switched Some types of PC CPUs can handle input data in direct mode and output data in refresh mode, or vice versa. This section describes the flow of ON/OFF data from the input module to the output module when the I/O control mode is switched from direct mode to refresh mode, or vice versa. Figures 2.9 to 2.12 show ON/OFF timing of inputs and outputs when the program shown below is executed. Fig. 2.9 When Both Input and Output are in Direct Mode Fig. 2.10 When Input is in Direct Mode and Output is in Refresh Mode Fig. 2.11 When Input is in Refresh Mode and Output is in Direct Mode . 44 Fig. 2.12 When Both Input and Output are in Refresh Mode | Applicable<br>CPU | All Types of CPUs | | | | | | |-------------------|-------------------|--|--|--|--|--| | Remark | | | | | | | #### 2.5 Scan Time #### (1) Scan time Scan time refers to the period of time from the start of step 0 to the completion of the END instruction of a sequence program. Length of scan time differs between scans and is determined by the number of instructions executed within one time of scan. Fig. 2.13 Scan Time - (2) Storage of scan time data - (a) The PC stores scan times in special registers D9017 to 9019 in units of 10 ms. - 1) Data stored in D9017 to 9019 - D9017......Minimum value of scan time - D9018......Present value of scan time - D9019......Maximum value of Scan time - 2) Scan time accuracy Scan time accuracy is $\pm$ 10 ms. Hence, when the value in D9018 is 5, the actual scan time is between 40 and 60 ms. 3) D9017 to 9019 are not cleared and store the scan time if the WDT instruction is executed. # REMARKS - (1) In ladder monitor mode of the peripheral device, data of D9019 is displayed. - (2) The AnA and AnU stores present data of scan time (1 ms unit) in D9021. - (3) Scan time measurement may include errors when an interrupt program is used. Refer to Section 5.1.3 for details. **MELSEC-A** | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | # 2.6 Numeric Data Usable for Sequence Programs Alphanumeric data used by the PC CPUs is represented by 0 (OFF) and 1 (ON), in the most basic form as binary data. Other types of data such as hexadecimal data which represents binary data in units of 4 bits and BCD (binary-coded decimal) data are also usable. Table 2.1 shows the representation of numeric values by the BCD, binary, hexadecimal, and decimal notations. Table 2.1 Binary, Hexadecimal, BCD, and Decimal Notations | DEC<br>(Decimal) | HEX<br>(Hexadecimal) | BIN<br>(Binary) | BCD<br>(Binary-coded<br>Decimal) | |---------------------------------------------------|---------------------------------------------|--------------------------------------------------------------------------|----------------------------------------------------------------------------| | 0<br>1<br>2<br>3 | 0<br>1<br>2<br>3 | 0<br>1<br>10<br>11 | 0<br>1<br>10<br>11 | | 9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17 | 9<br>A<br>B<br>C<br>D<br>E<br>F<br>10<br>11 | 1001<br>1010<br>1011<br>1100<br>1101<br>1110<br>1111<br>1 0000<br>1 0001 | 1001<br>1 0000<br>1 0001<br>1 0010<br>1 0011<br>1 0100<br>1 0101<br>1 0110 | | 47 | 2F | 10 1111 | 100 0111 | (1) Input of numeric data from an external device to the PC CPU To input numeric values using a digital switch or other external device to the PC CPU, use BCD (binary-coded decimal) data which allows data to be set in the form of decimal data. Although the BCD data is binary-coded, it needs to be converted to binary data so that the PC CPU may execute correct operation. A BIN instruction is provided to convert the BCD input data into binary data used for the operations by the PC CPU. It is recommended to write a program which converts numeric data to binary data. By using this conversion program, numeric data can be input from an external device without considering the BIN data. Fig. 2.14 Data Input to the PC CPU (2) Output of numeric data from the PC CPU to an external device To read operation results of the PC CPU with an external device, use a digital display. The binary data used for operation by the PC CPU cannot be read correctly if it is output to a digital display directly. A BCD instruction is provided to convert the binary data into the BCD data. It is recommended to write a program which converts numeric data to BCD data. By using this program, a display in decimal notation is possible. Fig. 2.15 Data Output from the PC CPU | Applicable<br>CPU | All Types of CPUs | | | | |-------------------|-------------------|--|--|--| | Remark | | | | | #### 2.6.1 Binary notation #### (1) Binary Binary data is represented by 0 (OFF) and 1 (ON). Decimal notation uses the numerals 0 through 9. When counting beyond 9, a 1 is placed in the 10s column and a 0 is placed in the 1s column to make the number 10. In binary notation, the numerals 0 and 1 are used. A carry occurs after 1 and the number becomes 10 (decimal 2). Table 2.2 gives a comparison between binary and decimal notations. Table 2.2 Comparison between Binary and Decimal Notations | Decimal | Binary | | |---------|--------|---------| | 0 | 0000 | | | 1 | 0001 | Corry | | 2 | 0010 | Carry | | 3 | 0011 | | | 4 | 0100 | Carry | | 5 | 0101 | | | 6 | 0110 | | | 7 | 0111 | Carry | | 8 | 1000 | ← Carry | | 9 | 1001 | | | 10 | 1010 | | | 11 | 1011 | | ## (2) Representation of binary values (a) The PC CPU uses 16-bit registers (data registers, link registers, etc.) Each bit of a register is allocated with a 2<sup>n</sup> value. The most significant bit is used for the positive/negative judgment. - If the most significant bit is 0: Positive - If the most significant bit is 1: Negative Fig. 2.16 gives numeric expression used for the registers of the PC CPU. Fig. 2.16 Numeric Expression for Each Register of the PC CPU. # 2. PROGRAMMING LANGUAGES AND OPERATIONS MELSEC-A (b) Data usable with the PC CPU According to the numeric expression shown in Fig. 2.16, numeric values from —32768 to 32767 can be expressed. Therefore, values from —32768 to 32767 can be stored in the registers of the PC CPU. | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ## 2.6.2 Hexadecimal #### (1) Hexadecimal notation In hexadecimal notation, 4 binary bits are expressed in 1 digit. If 4 binary bits are used in binary notation, 16 different values from 0 to 15 can be represented. Since hexadecimal notation represents 0 to 15 in 1 digit, letters A to F are used to represent the numbers 10 to 15. Then, a carry occurs after F. Table 2.3 shows numeric representation by binary, hexadecimal, and decimal notations. Table 2.3 Numeric Representation by Binary, Hexadecimal and Decimal Notations | Decimal | Hexadecimal | Binary | |------------|-------------|---------| | 0 | O | . o | | . 1 | 1 | 1 | | 2 | 10 | 10 | | 2<br>3 | 11 | 11 | | | i i | | | : | : | | | • | | | | | | | | ġ | 9 | 1001 | | 10 | Α | 1010 | | 11 | В | 1011 | | 12 | Č | 1100 | | 13 | D | 1101 | | 14 | Ē | 1110 | | 15 | E<br>F | 1111 | | 16 | 10 | 1: 0000 | | 17 | 11 | 1 0001 | | l ï | | | | <b>I</b> i | : | | | | | | | 47 | ;<br>2F | 10 1111 | #### (2) Expression of hexadecimal values The PC CPU uses 16-bit registers (data registers, link registers, etc.) Data which can be stored in each register is within 0 to FFFF<sub>H</sub> range in hexadecimal notation. **MELSEC-A** | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | # 2.6.3 BCD (Binary-coded decimal) # (1) BCD notation BCD notation represents each decimal digit with 4 binary digits. Though it uses 4-bit representation like hexadecimal notation, it does not use letters A to F. Table 2.4 gives numeric representation by binary, BCD, and decimal notations. Table 2.4 Numeric Representation by Binary, BCD, and Decimal Notations | Decimal | Binary | BCD<br>(Binary-coded<br>Decimal) | |---------|--------|----------------------------------| | 0 | 0 | | | 1 | 1 | 1 | | 2 | 10 | 10 | | 3 | 11 | 11 | | 4 | 100 | 100 | | 5 | 101 | 101 | | 6 | 110 | 110 | | 7 | 111 | 111 | | 8 | 1000 | 1000 | | 9 | 1001 | 1001 | | 10 | 1010 | 1 0000 | | 11 | 1011 | 1 0001 | | 12 | 1100 | 1 0010 | ## (2) Expression of BCD values The PC CPU uses 16-bit registers (data registers, link registers, etc.) Data which can be stored in each register is within 0 to 9999 range in BCD notation. #### 3. DEVICES #### 3.1 List of Devices Table 3.1 shows the devices and their range of use which are usable with the PC CPU. The usable range for devices marked by an asterisk (\*) in Table 3.1 can be set or changed by setting parameters with a peripheral device. For the parameter set range refer to Section 8 "PARAMETER SETTING". Table 3.1 List of Devices | | Table 0.1 Figt of Bevices | | | | | | | | | | | |--------|------------------------------|--------------------------------------|--------------------------------------|---------------|---------------------|------------------------------|--------------------------------------|-----------------------------------------|--------------------------------|--------------------------------|--| | $\int$ | Device | A1S, A1SJ-S3 | A1SH,<br>A1SJH(S8) | A1S-S1, A2S | A2SH | A2S-S1 | A2SH-S1 | A0J2H | A2C<br>A52G | A1FX | | | | I/O device<br>points 1 | 256 points | 2048 points | 512 points | 2048 points | 1024 points | 2048 points | 336 points *4 | 512 points | 512 points | | | × | Input <sup>-2</sup> | X, Y0 | | X, Y0 | to 1FF | | to 3FF | X, Y0 to 1FF *4 | X, Y0 to 1FF | X, Y0 to F1 | | | 7 | Output *2 | (Total<br>Y point | | | l X and<br>ts: 512) | | IX and<br>ts:1024) | (Total X and<br>Y points: 336) | (Total X and<br>Y points: 512) | (Total X and<br>Y points: 224) | | | | Special relay | | | | | | | | | | | | ,<br>N | Internal<br>relay | | | M0 to 999 ( | 1000 points) | | | Setting can be changed using parameters | | | | | | Latch relay | | | L1000 to 2047 | | | M, L, S: 2048 pe<br>annot use step i | | | | | | | Step relay | | 0 point | | | | | | | | | | E | Link relay | | B0 to 3FF (1024 points) | | | | | | | | | | T | 100 ms timer | | | T0 to 199 | (200 points) | | | | | | | | | 10 ms timer | | | T200 to 255 | (256 points) | | | | e changed using | | | | * 7 | 100 ms<br>retentive<br>timer | | | 0 р | oint | | | (Total of timers: 256 points) | | | | | | 1ms timer | | | | | _ | | | | | | | | Counter | (Total of counters and interrupt cou | | | | | | | | | | | * 0 | Interrupt<br>counter *3 | | | | | | | • | | | | | | | | | For interru | ıpt programs (A2 | C and A52G car | nnot use interru | ot counters.) | | | | | | Data register | | | | D0 1 | o 1023 (1024 po | oints) | | | | | | | Special register | | D9000 to D9255 (256 points) | | | | | | | | | | ٧ | Link register | | W0 to 3FF (1024 points) | | | | | | | | | | * F | File register | | | | (Parame | 0 point<br>ter setting: 1 to | 4 k points) | | | | | | A | Accumulator | | | | | A0, A1 (2 points | 3) | | | | | | Z | | | | | | Z (1 point) | | | | | | | V | register | | | | | V (1 point) | | | | | | | N | Nesting | | | | | N0 to 7 (8 levels | 5) | | | | | | F | Pointer | | | | P0 | to 255 (256 poi | nts) | | | | | | ı | Interrupt<br>pointer | | 10 to 15,<br> 10 to 131 (32 points) | | | | | | | | | | K | Decimal | | | | K-32768 t | o 32767 (16-bit | instruction) | | | | | | Ľ | constant | | | | K-2147483648 t | o 2147483647 ( | 32-bit instruction | n) | | | | | F | Hexadecimal | | | | H0 to I | FFF (16-bit inst | truction) | | | | | | | constant | | | | H0 to FF | FFFFF (32-bit i | nstruction) | | | | | <sup>\*1:</sup> Indicates the number of points that can be specified by input/output (X, Y). Numbers which follow those allocated to I/O modules and special function modules may be allocated to remote I/O stations and MELSECNET/MINI-S3 in the data link system. (Counters and interrupt counters for an interrupt program are numbered consecutively.) Interrupt counters for counting the number of interrupts are fixed to C224 to C255. <sup>\*2:</sup> Indicates the I/O numbers and the number of I/O points that can actually control the I/O modules and special function modules. <sup>\*3:</sup> Interrupt counters for an interrupt program should be set in unit of 8 points in the range from C0 to C255. <sup>\*4:</sup> Can be expanded to 480 points if an extension base unit is used. Table 3.1 List of Devices | | - | | Table 0.1 List of Devices | | Q02, Q02H, | | | | | | |-------------|---|------------------------|--------------------------------------------------------|-------------------------------------------------|-----------------------------------------------------|--|--|--|--|--| | $\triangle$ | | Device | A2AS | A2AS(S1/S30), A2USH-S1 | Q06H | | | | | | | | | I/O device points *1 | 8192 points 8192 points | | | | | | | | | | Y | Input *2 Output *2 | X, Y0 to 1FF<br>(Total X and<br>Y points: 512) | X, Y0 to 3FF<br>(Total X and<br>Y points: 1024) | X, Y0 to 1FFF<br>(Total X and<br>Y points:<br>4096) | | | | | | | | | Special relay | M9000 to M9255 | (256 points) | | | | | | | | | м | Internal relay | M0 to 999 (1000 points)<br>M2048 to 8191 (6144 points) | g parameters | | | | | | | | | | Latch relay | L1000 to 2047 (1048 points) | (Total M, L, S: 8192 p | oints) | | | | | | | | | Step relay | 0 point | • | | | | | | | | | В | Link relay | B0 to 1FFF (81) | 92 points) | | | | | | | | | | 100 ms timer | T0 to 199 (200 points), T256 to 2047 (1848 points)*4 | · Setting can be changed usin | a narameters | | | | | | | | | 10 ms timer | T200 to 255 (256 points) | (Total of timers: 2048 | | | | | | | | | Т | 100 ms retentive timer | 0 point | | | | | | | | | | | 1ms timer | <u> </u> | | 0 point Usable with the ZHTIME instruction | | | | | | | | | Counter | | | | | | | | | | * | С | Interrupt counter *3 | 0 point | (Total of counters and interrupt points) | counters: 1024 | | | | | | | | | | For counting the num | ber of interrupts | | | | | | | | | D | Data register | D0 to 8191 (81 | 92 points) | | | | | | | | | | Special register | D9000 to D9255 | D9000 to D9255 (256 points) | | | | | | | | | W | Link register | W0 to 1FFF (8192 points) | | | | | | | | | | R | File register | 0 poin<br>(Parameter setting: | | | | | | | | | | Α | Accumulator | A0, A1 (2 p | oints) | | | | | | | | | Z | Index register | Z, Z1 to Z6 ( | | | | | | | | | | ٧ | | V, V1 to V6 ( | | • | | | | | | | | N | Nesting | N0 to 7 (8 I | | | | | | | | | | Р | Pointer | P0 to 255 (25 | <u> </u> | <u> </u> | | | | | | | | | Interrupt pointer | l0 to l31 (32 | | | | | | | | | | κ | Decimal constant | K-32768 to 32767 (16<br>K-2147483648 to 21474836 | | | | | | | | | | | | H0 to FFFF (16-bi | | | | | | | | | | Н | Hexadecimal constant | H0 to FFFFFFF (32 | | | | | | | | - \*1: Indicates the number of points that can be specified by input/output (X, Y). Numbers which follow those allocated to I/O modules and special function modules may be allocated to remote I/O stations and MELSECNET/MINI-S3 in the data link system. - \*2 : Indicates the I/O numbers and the number of I/O points that can actually control the I/O modules and special function modules. - \*3 : Interrupt counters for an interrupt program should be set in unit of 8 points in the range from C0 to C255. - (Counters and interrupt counters for an interrupt program are numbered consecutively.) Interrupt counters for counting the interrupt occurrences are fixed to C224 to C255. - \*4: Timers T256 to T2047 are called extended timers. To use extended timers, the number of points and the type of timers (100 ms timer, 10 ms timer, 100 ms retentive timer) to be used must be set for parameters and the setting of a setting value register is also necessary. - \*5 : Counters C256 to C1023 are called extended counters. To use extended counters, the number of points of counters must be set for parameters and the setting of a setting value register is also necessary. Table 3.1 List of Devices | | | Device | A1<br>A1N | A2<br>A2N | A2-S1<br>A2N-S1 | A3, A3N<br>A3V, A73 | A3H<br>A3M | | | | |---|---|------------------------|-----------------------------------------------|---------------------------------------------------|--------------------------------------------------|------------------------------------------------------------------------|-------------------------------------------------|--|--|--| | | | I/O device points *1 | 256 points | 512 points | 1024 points | 2048 points | 2048 points | | | | | | X | Input *2 Output *2 | X, Y0 to FF<br>(Total X and<br>Y points: 256) | X, Y0 to 1FF<br>(Total X and<br>Y points: 512) | X, Y0 to 3FF<br>(Total X and<br>Y points: 1024) | X, Y0 to 7FF<br>(Total X and<br>Y points: 2048) | X, Y0 to 7FF<br>(Total X and<br>Y points: 2048) | | | | | | | Special relay | | ints) | | | | | | | | | ١ | Internal relay | M | M0 to 999 (1000 points) Setting can be changed us | | | | | | | | ٠ | M | Latch relay | L10 | 00 to 2047 (1048 poi | parameters | | | | | | | | | Step relay | | 0 point | | (lotal M, L, S | : 2048 points) | | | | | | В | Link relay | | E | 0 to 3FF (1024 points | 3) | | | | | | | | 100 ms timer | 7 | TO to 199 (200 points | ) | Setting can be | changed using | | | | | * | Т | 10 ms timer | T2 | 200 to 255 (256 point | s) | paran | neters | | | | | | | 100 ms retentive timer | | 0 point | | (Total of times | rs: 256 points) | | | | | | | 1ms timer | | <del>_</del> | | | | | | | | | | Counter | ( | 00 to 255 (256 points | ) | Setting can be changed using | | | | | | | С | Interrupt counter *3 | 0 point | | | parameters<br>(Total of counters and interrup<br>counters: 256 points) | | | | | | | | monupi ocumei | | For interrupt programs | | | | | | | | | D | Data register | | D | 0 to 1023 (1024 point | s) | | | | | | | | Special register | D9000 to D9255 (256 points) | | | | | | | | | | W | Link register | | V | /0 to 3FF (1024 points | s) | | | | | | * | R | File register | (Param | 0 point<br>eter setting: 1 to 4 k | points) | | oint<br>g: 1 to 8 k points) | | | | | | Α | Accumulator | | | A0, A1 (2 points) | | | | | | | | Z | Index register | | | Z (1 point) | | | | | | | | ٧ | | | | V (1 point) | | | | | | | | N | Nesting | N0 to 7 (8 levels) | | | | | | | | | | Р | Pointer | | | P0 to 255 (256 points | ) | | | | | | | ı | Interrupt pointer | | | l0 to l31 (32 points) | | | | | | | | κ | Decimal constant | | | 3 to 32767 (16-bit inst<br>3 to 2147483647 (32-l | <del></del> | | | | | | | | | | | FFFF (16-bit instruc | | | | | | | | Н | Hexadecimal constant | | | • | | | | | | | | | | H0 to FFFFFFFF (32-bit instruction) | | | | | | | | - \*1 Indicates the number of points that can be specified by input/output (X, Y). Numbers which follow those allocated to I/O modules and special function modules may be allocated to remote I/O stations and MELSECNET/MINI-S3 in the data link system. - \*2 Indicates the I/O numbers and the number of I/O points that can actually control the I/O modules and special function modules. - \*3 Interrupt counters for an interrupt program should be set in unit of 8 points in the range from C0 to C255. - (Counters and interrupt counters for an interrupt program are numbered consecutively.) Interrupt counters for counting the interrupt occurrences are fixed to C224 to C255. Table 3.1 List of Devices | abla | | Device | A2A | A2A A2A-S1 A3A A2U A2U-S1 A3U A | | | | | | | |------|--------|------------------------|-----------------------------------------------------------------------------------------------------|-----------------------------------------------------|----------------------------------------------------|---------------------------------------------------|----------------------------------------------------|-----------------------------------------------------------|----------------------------------------------------|--| | | | I/O device points *1 | 512 points | 1024 points | 2048 points | | 8192 | points | | | | | X<br>Y | Input *2 Output *2 | X, Y0 to 1FF<br>(Total X and<br>Y points:<br>512) | X, Y0 to 3FF<br>(Total X and<br>Y points:<br>1024) | X, Y0 to 7FF<br>(Total X and<br>Y points:<br>2048) | X, Y0 to 1FF<br>(Total X and<br>Y points:<br>512) | X, Y0 to 3FF<br>(Total X and<br>Y points:<br>1024) | X, Y0 to 7FF<br>(Total X and<br>Y points:<br>2048) | X, Y0 to FFF<br>(Total X and<br>Y points:<br>4096) | | | | | Special relay | | M9000 to M9255 (256 points) | | | | | | | | | | Internal relay | M0 to 999 ( | M0 to 999 (1000 points) M2048 to 8191 (6144 points) | | | | | | | | * | М | Latch relay | L1000 to 2047 (1048 points) | | | | Setting can b-<br>Total) | e changed usir<br>M, L, S: 8192 ( | ig parameters<br>points) | | | | | Step relay | 0 point | | | | | , | | | | | В | Link relay | B0 to | o FFF (4096 po | ints) | | B0 to 1FFF | (8192 points) | | | | | | 100 ms timer | T0 to 199 ( | 200 points), T2 | 56 to 2047 (184 | 48 points)* <sup>4</sup> | . Cotting can b | e changed usin | a narametera | | | ٠ | Т | 10 ms timer | | T200 to 255 | (256 points) | | | of timers: 2048 | | | | | | 100 ms retentive timer | | 0 point | | | | | | | | | | 1ms timer | _ | | | | | | | | | | | Counter | C0 to 255 (256 points), C256 to 1023 (768 points) <sup>*5</sup> Setting can be changed using parame | | | | | | | | | * | С | Interrupt counter *3 | 0 point | | | | (Total of cou | Total of counters and interrupt counters:<br>1024 points) | | | | | | | | | For counting | g the number o | of interrupts | | | | | | D | Data register | D0 to | 6143 (6144 pc | <u> </u> | | D0 to 8191 (8192 points) | | | | | | | Special register | | | D9000 | to D9255 (256 | <del> </del> | | | | | | W | Link register | W0 t | o FFF (4096 pc | oints) | | W0 to 1FFF | (8192 points) | | | | * | R | File register | | 0 point<br>(Parameter setting: 1 to 8 k points) | | | | | | | | | Α | Accumulator | | | Į. | A0, A1 (2 points | 3) | | | | | | Z | Index register | | Z, Z1 to Z6 (7 points) | | | | | | | | | ٧ | madx register | V, V1 to V6 (7 points) | | | | | | | | | | N | Nesting | N0 to 7 (8 levels) | | | | | | | | | | Р | Pointer | P0 to 255 (256 points) | | | | | | | | | | 1 | Interrupt pointer | I0 to I31 (32 points) | | | | | | | | | | к | Decimal constant | | | | 32767 (16-bit | | | | | | | | | K-2147483648 to 2147483647 (32-bit instruction) | | | | | | | | | | Н | Hexadecimal constant | | H0 to FFFF (16-bit instruction) | | | | | · | | | | | | H0 to FFFFFFF (32-bit instruction) | | | | | | | | - \*1 Indicates the number of points that can be specified by input/output (X, Y). Numbers which follow those allocated to I/O modules and special function modules may be allocated to remote I/O stations and MELSECNET/MINI-S3 in the data link system. - \*2 Indicates the I/O numbers and the number of I/O points that can actually control the I/O modules and special function modules. - \*3 Interrupt counters for an interrupt program should be set in unit of 8 points in the range from C0 to C255. - (Counters and interrupt counters for an interrupt program are numbered consecutively.) Interrupt counters for counting the interrupt occurrences are fixed to C224 to C255. - \*4 Timers T256 to T2047 are called extended timers. To use extended timers, the number of points and the type of timers (100 ms timer, 10 ms timer, 100 ms retentive timer) to be used must be set for parameters and the setting of a setting value register is also necessary. - \*5 Counters C256 to C1023 are called extended counters. To use extended counters, the number of points of counters must be set for parameters and the setting of a setting value register is also necessary. | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | # 3.2 Input (X) and Output (Y) The input and output devices are used for data transaction between the PC CPU and external devices. The input devices hold ON/OFF data sent from external devices to the input module. Input data is used by the program as contact data (N/O and N/C contacts) and as the source data for basic and application instructions. The output devices are used to output operation results of the program from the output module to external devices. Fig. 3.1 Inputs (X) and Outputs (Y) # (1) Input X - (a) Inputs give commands and data from external devices (e.g. push buttons, select switches, limit switches, digital switches) to the PC. - (b) Regarding that one point of input incorporates a virtual relay Xn in the PC, the N/O contact and N/C contact of that Xn are used in the program. Fig. 3.2 Inputs (X) (c) There is no restriction on the number of N/O contacts and N/C contacts of Xn used in the program. Fig. 3.3 Used in the inputs (X) # (2) Output Y - (a) Outputs provide program control results to external devices (e.g. solenoids, magnetic switches, signal lamps, digital indicators). - (b) Outputs can be fetched to the outside as an equivalent to one N/O contact. - (c) There is no restriction on the number of N/O contacts and N/C contacts of Yn used in the program. Fig. 3.4 Outputs (Y) (d) The Y range which corresponds to the range to where the input modules are loaded and the range to where no module is loaded can be used for the internal relay M. The Y range used for the internal relay M cannot be latched. · - | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | # 3.3 Internal Relays (M), Latch Relays (L), and Step Relays (S) The internal relays, latch relays, and step relays are auxiliary relays used in the PC CPU. The number of contacts (N/O and N/C) used in the sequence program is not limited. The output (Y) devices are used to output operation results of the sequence program to external devices. Fig. 3.5 Internal Relays, Latch Relays, and Step Relays The number of internal relays, latch relays, and step relays is changed or set by parameters. (1) Internal relays M, step relays S Cannot be latched. Hence, all internal relays are switched off if the PC is switched on, reset or latch-cleared. - (2) Latch relay L - (a) Battery backed, i.e. operation results are retained if the PC is switched on or reset. - (b) Set the CPU to STOP, and latch-clear to switch off the latch relays from the external device. | Applicable<br>CPU | All Types of CPUs | | |-------------------|-------------------|--| | Remark | | | # 3.4 Link Relays (B) - (1) Internal relay for use in a data link system. When not using a data link, link relays can be used as internal relays. - (2) The ON/OFF data of the link relays used in a data link system can be read by switching them on/off as coils in the host (master, local station) and as contacts in other stations (master, local stations). Link relays thus allow ON/OFF data to be transferred between the master and local stations. Fig. 3.6 Link Relay in a Data Link System (3) The link range (range of link relays for use as coils in each station) must be set to the master station. Link relays outside the link range may be used as internal relays. Fig. 3.7 Assignment of Link Relays (4) There is no restriction on the number of N/O contacts and N/C contacts of link relay used in the program. Fig. 3.8 Processing of Link Relays # REMARK For detail of the data link system, refer to the MELSECNET, MELSECNET/B Data Link Reference Manual (IB-66350). | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ### 3.5 Annunciators (F) Annunciators are used with a fault detection program. If an annunciator is set, a special relay is turned ON, and the annunciator number is stored in a special register. (a) Special relay : M9009.....If an annunciator is set, M9009 is turned ON. (b) Special registers: D9009..... Stores the annunciator number which is set first. : D9124..... Stores the number of annunciators which are set. to D9132 ... ... Stores the annunciator numbers in order of setting. (D9125 and D9009 store the same annunciator number.) By using annunciators in a fault detection program, occurrence of fault and fault data (annunciator numbers) can be checked by monitoring M9009 and D9009. - (1) How to set annunciators - (a) Annunciators can be set using the OUT (OUT F[]]) instruction or the SET (SET F[]]) instruction. - The OUT instruction sets/resets annunciators according to ON/OFF of an input condition. The OUT instruction is executed every scan. If annunciators are reset by the OUT instruction, data of M9009, D9009, and D9124 to 9132 does not change. - 2) The SET instruction is executed at the leading edge (OFF to ON) of an input condition and sets annunciators. (If the input condition is turned OFF, annunciators are held in set status.) If a large number of annunciators are used, it is recommended to use the SET instruction instead of the OUT instruction to make the scan time short. - (b) When annunciators (F[7]) are set: - 1) Annunciator numbers (F[-]) are stored in order of setting in D9125 to 9132. When data of D9124 is 0, the first set annunciator number is stored also in D9009. The number of set annunciators stored in D9124 increases by one each time an annunciator is set. | SET SET SET<br>F50 F25 F99 | | | | | | | | | |----------------------------|---|----|----|----|---|--|--|--| | D9009 | 0 | 50 | 50 | 50 | | | | | | D9124 | 0 | 1 | 2 | 3 | | | | | | D9125 | 0 | 50 | 50 | 50 | | | | | | D9126 | 0 | 0 | 25 | 25 | | | | | | D9127 | 0 | 0 | 0 | 99 | | | | | | _ | | | | | ؎ | | | | - 2) Indication of annunciators varies with type of the CPU module as follows. - a) The CPU modules having an LED display on the front panel: The F number stored in D9009 is indicated on the LED display. - b) The CPU modules having an "ERROR" LED on the front panel: The "ERROR" LED flashes. (When it lights, it indicates an operation error.) - c) The A0J2H CPU module: The "RUN" LED flashes or lights according to the status of M9048, as follows. When M9048 is ON: The "RUN" LED flashes. When M9048 is OFF: The "RUN" LED remains lit. ### POINTS - (1) If an annunciator is set when any annunciator is already set, the F number being indicated on the LED display does not change. - (2) If the number of set F numbers has become larger than 8, data of D9124, and D9125 to 9132 does not change. However, data of the set F numbers is stored in the PC. - (2) How to reset annunciators - (a) Annunciators can be reset by the RST (RST F[]) instruction or the LEDR instruction. - 1) Use the RST (RST F[]) instruction to reset the set annunciator numbers. - 2) The LEDR instruction is used to reset the annunciator numbers stored in D9009 and D9125. Fig. 3.9 is the examples of programs used to reset annunciators by the LEDR instruction. Fig. 3.9 Programs to Reset Annunciators # **POINTS** - If annunciators are set by an instruction other than the OUT or SET instruction, they function as if they are internal relays. (Note that M9009 is not set, and annunciator numbers are not stored in D9009 and D9124 t D9132.) - (2) Even when the annunciator is reset by an OUT instruction, contents of M9009, D9009, and D9124 to D9132 do not change. When the annunciator is set by an OUT instruction, reset the annunciator as follows: - 1) Reset the annunciator by an OUT instruction. - 2) Execute RST instruction (RST F[]) /LEDR instructions. - (b) When annunciators are reset by the RST F[]] instruction: - 1) The F numbers of reset annunciators are erased from D9125 to 9132. And then, data stored in the special registers and the F numbers stored in the PC are shifted forward. If the annunciator of which F number is stored in D9125 is reset, the data shifted forward and newly stored to D9125 is stored also in D9009. The number of set annunciators, stored in D9124, decreases one. | SET SET SET RST RST<br>F50 F25 F99 F25 F50 | | | | | | | | | |--------------------------------------------|---|----|----|----|----|----|--|--| | D9009 | 0 | 50 | 50 | 50 | 50 | 99 | | | | D9124 | 0 | 1 | 2 | 3 | 2 | 1 | | | | D9125 | 0 | 50 | 50 | 50 | 50 | 99 | | | | D9126 | 0 | 0 | 25 | 25 | 99 | 0 | | | | D9127 | 0 | 0 | 0 | 99 | 0 | 0 | | | If the CPU module is provided with an LED display, the F number stored in D9125 is indicated on the display. The F number newly stored in D9125 after reset is indicated on the LED display. (Special registers) If data in D9124 has become 0 by resetting the F numbers, the "LED display" or the "ERROR" LED turns OFF. ### **POINT** To reset annunciators, the LEDR instruction or, if the CPU module is provided with an LED display, the "INDICATOR RESET" switch on the front panel may be used. | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ### 3.6 Timers (T) The PC CPU uses up count timers. An up count timer starts timing of the present value when its coil is turned ON. When the present value has become equal with its preset value (time out), the contact of the timer is turned ON. # 3.6.1 100 ms timers, 10 ms timers, and 100 ms retentive timers - (1) 100 ms and 10 ms timers - (a) Timing of the present value starts when the timer coil is turned ON. When the timer coil is turned OFF, the present value becomes 0 and the contact is turned OFF. Fig. 3.10 Timing Chart ## (2) 100 ms retentive timer (a) The 100 ms retentive timer measures the length of ON time of a timer coil. When a timer coil is turned ON, timing of the present value starts. When the coil is turned OFF, the present value and the ON/OFF status of the contact are retained. When the coil is turned ON again, timing starts with the retained present value. (b) Use the RST T[] instruction to clear the present value and to turn OFF the contact. Fig. 3.11 Timing Chart | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ### 3.6.2 Processing and accuracy of timers ### (1) Timer processing A timer coil turned ON/OFF by execution of the OUT T[] instruction. The present value is updated and the contact is turned ON/OFF after execution of the END instruction. - (a) When a timer coil is turned ON, the present value of the timer is updated after execution of the END instruction. When the timer has timed out, the contact of the timer is turned ON. - 1) When the timer coil is turned OFF, the 10 ms and 100 ms timers reset the present value to 0 and the contact is turned OFF after execution of the END instruction. - 2) The 100 ms timer retains the present value and the ON/OFF status of the contact when the timer coil is turned OFF. - (b) When a timer is reset by execution of the RST T[] instruction, the present value is reset to 0 and the contact is turned OFF. - (c) If the OUT T[] instruction is skipped by use of the CJ instruction after a timer coil is turned ON, the timer coil status is held ON. Then, the present value is updated without execution of the OUT T[] instruction and the contact is turned ON when the timer times out. Fig. 3.12 Timer Processing # POINT When the preset value is "0", it is regarded as infinite and the timer does not time out. - (2) Present value update timing and accuracy in direct mode - (a) Timer accuracy depends on the timer and scan time. | Timer Type | Scan Time T | Accuracy | |-----------------------------|-------------|------------------------------| | 10 ms | T < 10 ms | +2 scan time to -10 ms | | 10 ms | T ≥ 10 ms | +2 scan time to -1 scan time | | 100 ms,<br>100 ms retentive | T < 100 ms | +2 scan time to -100 ms | | 100 ms,<br>100 ms retentive | T ≥ 100 ms | +2 scan to -1 scan time | (b) The following example indicates the present value update timing and accuracy with a 10 ms timer used in the program of 10 ms or more scan time. Fig. 3.13 Timer Timing T203 time-out period includes the following errors: - \*1: 10 ms timer error (+1 scan time) - \*2: Error depending on timing of timer input continuity and location of the [OUT] T[] instruction in program (±1 scan time) Accuracy is therefore $^{+2}_{-1}$ scan time $^{+0.05}_{-0.025}$ seconds in Fig. 3.13). 3) Contact status is updated only after the [END] instruction is processed regardless of the timer coil status during any scan. - (3) Update timing and accuracy in refresh mode - (a) Timer accuracy depends on the timer and scan time. | Timer Type | Scan Time T | Accuracy | |-----------------------------|-------------|------------------------------| | 10 ms | T < 10 ms | +2 scan time to -10 ms | | 10 ms | T ≥ 10 ms | +2 scan time to -1 scan time | | 100 ms,<br>100 ms retentive | T < 100 ms | +2 scan time to -100 ms | | 100 ms,<br>100 ms retentive | T ≥ 100 ms | +2 scan to -1 scan time | (b) The following example indicates the present value update timing and accuracy by using a 10 ms timer in a program of 10 ms or more scan time. Fig. 3.14 Timer Timing T203 time-out period includes the following errors: - \*1: 10 ms timer error (+1 scan time) - \*2 : Error depending on timing of timer input continuity and location of the [OUT] T[] instruction in program (+1 scan time) Accuracy is therefore +2 scan time (+0.05 s in Fig. 2.7) (c) Contact status is updated only after the [END] instruction is processed, regardless of the timer coil status during any scan. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | VEA | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | | x | x | х | x | х | 0 | 0 | 0 | х | х | × | | Remark | | | | | | | | • | | | | #### 3.6.3 Extension timers The AnA, A2AS, or AnU is provided with 2048 timers from T0 to T2047. Timers T256 to T2047 are allocated to extension timers. Extension timers can be set as 100 ms, 10 ms, and 100 ms retentive timers. Setting values for the extension timers are set indirectly with data registers, link registers, and file registers. - (1) Setting of extension timers Use parameter setting to perform the following settings. - (a) Number of timers to be used Set the number of timers to 257 or over. Timers T256 and over are set for extension timers. The default value is 256. Up to 2048 can be set. - (b) Purpose of extension timers Set the extension timers for 100 ms, 10 ms, or 100 ms retentive timers. - (c) Set value devices (data registers, link registers, file registers) Set value devices are used to store set values for extension timers. The set value devices begin with a designated device number and are used through to the last device that corresponds to the last extension timer. (2) Programming of extension timers To use extension timers with a sequence program, use the [OUT] T[] instruction. (It is not necessary to key in setting value and devices for setting values.) When an [OUT] T[] instruction is entered, the set value device number which corresponds to the designated timer number is displayed on the screen. ## (3) Precautions - (a) To use extension timers, set the number of timers to 257 or over. The timer numbers which are not set in parameters cannot be written to the sequence program using contact commands or [OUT] T[]] instructions. The timer numbers which are not set in parameters can be used as data registers. - (b) To change the number of timers by parameter setting, do not set a number smaller than that designated by a contact command or an [OUT] T[] instruction. If a timer number designated by an [OUT] T[] instruction is larger than the last timer number designated by parameter setting, measuring of the present value and turning ON/OFF of contacts is disabled. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | VEA | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0.0 | x | × | x | х | х | х | × | 0 | х | х | х | | Remark | | | | | | | | | | | | #### 3.6.4 1ms timer With QCPU-A, a 1ms timer can be used in addition to the conventional high-speed timer (10ms) and low-speed timer (100ms). # (1) Usage Adding "ZHTIME", a 1ms timer setting instruction, in a program enables the use of a 1ms timer. (The ZHTIME instruction must be written in the main program.) The ZHTIME instruction is checked at startup and at switching from STOP to RUN. When this instruction exists in the main program, the 1ms timer can be used. If the ZHTIME instruction does not exist in the main program, only the 100ms/10ms timer can be used, and the 1ms timer is disabled. The number of occupied points is set as the total points of the 100ms timer, 10ms timer, retentive timer, and 1ms timer. The area for the 1ms timer is reserved following that of the retentive timer. Consequently, the constant specified with the ZHTIME instruction is designated as the device number following that of the retentive timer specified by parameters in the unit of 16 points. ### (2) Use example of the ZHTIME instruction The use example of the ZHTIME instruction is shown below. Example) When the timer in 1ms is set at T208 and later: # (3) Accuracy of 1ms timer The following table shows the accuracy of 1ms timer. | Timer type | Scan time | Accuracy | |------------|-----------|--------------------------------| | 1ms - | T < 1ms | + 2 scan time to - 1 ms | | | T ≥ 1ms | + 2 scan time to - 1 scan time | (4) Setting example The following are the setting examples with and without the expansion timer: (a) Setting example when the expansion timer is not used Number of occupied points: 256 (100ms timer: 120 points, 10ms timer: 40 points, retentive timer: 48 points, 1ms timer: 48 points) According to the setting above, the devices designated for the 100ms timer are T0 to T119, for the 10ms timer are T120 to T159, for the retentive timer are T160 to T207, and for the 1ms timer are T208 to T255. (b) Setting example when the expansion timer is used Number of occupied points: 512 (100ms timer: 240 points, 10ms timer: 80 points, retentive timer: 80 points, 1ms timer: 112 points) According to the setting above, the devices designated for the 100ms timer are T0 to T239, for the 10ms timer are T240 to T319, for the retentive timer are T320 to T399, and for the 1ms timer are T400 to T511. #### **POINTS** Note the following points to use the ZHTIME instruction. - (1) The ZHTIME instruction must be written in the main program. - (2) The ZHTIME instruction must be designated in the unit of 16 points. - (3) The number of occupied points designated in the timer setting by parameters should include those for the 1ms timer. - (4) When the range for the timer setting by parameters is between T256 and 2047, the initial device number to be used should be set at the item of the retentive timer between T256 and 2047. The 100ms timer should be used as the retentive timer. | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ### 3.7 Counters (C) The PC CPU uses up count counters. A up count counter counts out when the count value becomes equal with its preset value, and the contact of the counter is turned ON. ### (1) Count processing - (a) A counter coil is turned ON by execution of the [OUT] C[] instruction. The present value is updated and the contact is turned ON/OFF after execution of the [END] instruction. - (b) The counter counts the leading edges of pulses driving its coil and counts once only when the coil is switched from off to on. ## (2) Reset - (a) When the counter coil is switched on, the counter present value and contact status are updated after the [END] (FEND) instruction is executed. - (b) The count value is not cleared if the coil is switched off. Use the [RST] C[] instruction to clear the count value and update the contact status. Fig. 3.15 Count Ladder | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | | 0 | 0 | ٥ | 0 | х | х | х | x | 0 | х | 0 | | Remark | | | | | | | | | | | | # 3.7.1 Count processing in direct mode When input (X) signals are processed in direct mode, counting is executed at the leading edge of the input condition of the counter. Fig. 3.16 Counter Counting REMARK For the maximum counting speed of the counter, refer to Section 3.7.3. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | VEA | AnA | AnU<br>A2AS | QUPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | | 0 | x | 0 | 0 | 0 | o | o | 0 | 0 | 0 | 0 | | Remark | | | | | | | | | | | | # 3.7.2 Count processing in refresh mode When input (X) signals are processed in refresh mode, counting is executed at the leading edge of the input condition which is received at refresh. Fig. 3.17 Counter Counting REMARK For the maximum counting speed of the counter, refer to Section 3.7.3. | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | # 3.7.3 Maximum counting speed The maximum counting speed of counters is determined by the length of scan time. Counting is possible only when the ON/OFF switching time of the input condition is longer than scan time. Maximum counting speed (Cmax.) = $\frac{n}{100} \times \frac{1}{ts}$ (times/s) # REMARK where, n = duty (%) ts = interrupt signal interval (s) Duty is the ratio of the input signal's on time to off time as a percentage. If T1 $$\leq$$ T2 $n = \frac{T1}{T1 + T2} \times 100 [\%]$ If T1 > T2 n = $$\frac{T1}{T1 + T2} \times 100 [\%]$$ | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0.0 | x | x | x | ·x | х | 0 | 0 | 0 | х | х | x | | Remark | | | | | | | | | | • | | #### 3.7.4 Extension counters The AnA, A2AS, and AnU, QCPU-A is provided with 1024 counters from C0 to C1023. Counters C256 to C1023 are allocated to extension counters. Extension counters execute the same processings as those mentioned in Section 3.7. Setting values for the extension counters are set indirectly with data registers, link registers, and file registers. - (1) Setting of extension counters Use parameter setting to perform the following settings. - (a) Number of counters to be used - Set the number of counters to 257 or over. Counters C256 and over are set for extension counters. - 2) The default value is 256. Up to 1024 can be set. - (b) Set value devices (data registers, link registers, file registers) - Set value devices are used to store set values for extension counters. - The set value devices begin with a designated device number and are used through to the last device which corresponds to the last extension counter. (2) Programming of extension counters To use extension counters with a sequence program, use the [OUT] C[] instruction. (It is not necessary to key in setting values and devices for setting values.) When an [OUT] C[] instruction is entered, the set value device number which corresponds to the designated counter number is displayed on the screen. ### (3) Precautions (a) To use extension counters, set the number of counters to 257 or over. The counter numbers which are not set in parameters cannot be written to the sequence program using contact commands or [OUT] C[] instructions. The counter numbers which are not set in parameters can be used as data registers. (b) To change the number of counters by parameter setting, do not set a number smaller than that designated by a contact command or an [OUT] C[] instruction. If a counter number designated by an [OUT] C[] instruction is larger than the last counter number designated by parameter setting, measuring of the present value and turning ON/OFF of contacts is disabled. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | | 0 | 0 | 0 | x | x | х | х | × | 0 | х | 0 | | Remark | | | | | | | | · | | | | # 3.8 Interrupt Counters (C) The PC CPU can use two kinds of interrupt counters; those used within interrupt programs and those which count the number of interrupts. # 3.8.1 Counters for interrupt programs Counters used within interrupt programs are up count counters. An up count counter counts out when the count value becomes equal with its preset value, and then, the contact of the counter is turned ON. ### (1) Count processing - (a) A counter coil for an interrupt program is turned ON by execution of the [OUT] C[[]] instruction in an interrupt Program. The present value is updated and the contact is turned ON/OFF after execution of the IRET instruction. - (b) Counting is executed only when the input status of the [OUT] C instruction is turned from OFF to ON. If the input status remains ON (or OFF), counting will not be executed. #### (2) Reset (a) The counted value is not cleared when the coil is turned OFF. Use the [RST] C[] instruction to clear the counted value and to turn OFF the contact. (b) The present value and the contact of a counter is cleared when an [RST] instruction is executed to reset the counter. Fig. 3.18 Counting Method of Counter for Interruption (3) Maximum counting speed The maximum counting speed of the interrupt counter depends on the interrupt signal interval. Counting is only possible if the input condition is on for more than the interrupt signal interval. Maximum counting speed (Cmax.) = $$\frac{n}{100} \times \frac{1}{ti}$$ (times/s) # REMARK where, n = duty (%) ti = interrupt signal interval (s) Duty is the ratio of the input signal's on time to off time as a percentage. If T1 $$\leq$$ T2 n = $\frac{T1}{T1 + T2} \times 100 \, [\%]$ If T1 > T2 n = $\frac{T2}{T1 + T2} \times 100 \, [\%]$ | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0,0 | x | x | x | 0 | х | 0 | 0 | 0 | х | х | х | | Remark | | | | | | | | | | | | ### 3.8.2 Counters for counting the number of interrupts (Interrupt counters) The interrupt counters are used to count the number of occurrences of interrupt. # (1) Count processing (a) Counters C224 to C255 are used for the interrupt counters. When an interrupt occurs, the present value is updated and the contact is turned ON/OFF. The counter counts out when the number of interrupts becomes equal with its preset value, and then, the contact of the counter is turned ON. Contacts of the interrupt counters can be used freely in a sequence program. (b) The table below shows correspondence of interrupt pointers to interrupt counters. When an interrupt occurs at an interrupt pointer number, its corresponding counter executes counting. Refer to Section 3.16 for details of interrupt pointers. | Interrupt<br>Pointer | Interrupt<br>Counter | Interrupt<br>Pointer | interrupt<br>Counter | Interrupt<br>Pointer | Interrupt<br>Counter | Interrupt<br>Pointer | Interrupt<br>Counter | |----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------| | 10 | C224 | 18 | C232 | l16 | C240 | 124 | C248 | | 11 | C225 | 19 | C233 | l17 | C241 | 125 | C249 | | 12 | C226 | l10 | C234 | l18 | C242 | 126 | C250 | | 13 | C227 | l11 | C235 | l19 | C243 | 127 | C251 | | 14 | C228 | l12 | C236 | 120 | C244 | 128 | C252 | | 15 | C229 | l13 | C237 | l21 | C245 | 129 | C253 | | 16 | C230 | l14 | C238 | 122 | C246 | 130 | C254 | | 17 | C231 | l15 | C239 | 123 | C247 | l31 | C255 | - (2) Setting of the interrupt counters Perform the following settings to use counters C224 to C255 as interrupt counters. - 1) Set interrupt pointers in units of point by parameter setting. - 2) Insert the following program between the [FEND] instruction and the [END] instruction. 3) Interrupt should be kept enabled by executing the [EI] instruction at the program head. # (3) Precautions - (a) It is impossible to execute counting with an interrupt counter and an interrupt program using one interrupt pointer. An interrupt pointer set for an interrupt counter cannot be used to execute an interrupt program. - (b) If an interrupt occurs when any of the following processings is being executed count processing waits until the execution is completed. Count processing starts when the execution of each processing is completed. If the same interrupt occurs again when any processing is being executed, count processing is executed only once. - A sequence program instruction is being executed. - The interrupt-disable section in the [END] processing is being executed. (Timer/counter update, etc.) - An interrupt program is being executed. - (c) The maximum counting speed can be calculated using the longest processing time of the following: - Instruction with the longest processing time present in the program - END processing interrupt disable area ..... max. 2 ms - · Interrupt program processing time Max. counting speed = $$\frac{1}{\text{(max. processing time of the above)} + (500 \,\mu\text{s x number of interrupt counters)}}$$ (PPS) #### Example: The [End] processing time is 2 ms (0.002 s). If the max. instruction processing time is 0.3 ms a program is not written during run, there is no interrupt program, and two interrupt counters are used. Max. counting speed = $$\frac{1}{0.002 + 0.0005 \times 2} \approx 333 \text{ (PPS)}$$ Hence, the highest speed pulse train which may be reliably read by the A3HCPU, with the above conditions is 333 pulses/s. - (d) If a large number of interrupt counters are used, the processing time of the sequence program becomes long, and a "WDT ERROR" sometimes occurs. Decrease the number of interrupt counters or slow down the input pulse counting speed to avoid this error. - (e) The interrupt counters continue counting after count out. Use an [RST] C[] instruction before the [FEND] instruction in the sequence program to reset the counter. - (f) Counter value of the interrupt counters can be read by use of the [MOV] instruction in the sequence program. | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ## 3.9 Data Registers (D) (1) Data registers are used to store numeric data (-32768 to 32767 or 0000H to FFFFH) within the programmable controller. Each data register consists of 16 bits which is the unit of data read and write. Fig. 3.19 Structure of a Data Register (2) Use two data registers to handle 32-bit data. The data register number designated by the 32-bit instruction holds the lower 16 bits and the designated data register number + 1 holds the higher 16 bits. Fig. 3.20 Programming of Data Registers when the 32-bit Instruction is Used - (3) Data stored in a register by use of the program is retained till it is replaced by a new data. - (4) If additional data registers are required, the registers mentioned below can be used as data registers. - Unused timers (T) and counters (C) - File registers (R) within the range set by parameters. - · Link registers (W) not used for data link. - Index registers - Accumulators | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | # 3.10 Link Registers (W) (1) Link registers are used to store data for data link. Each link register consists of 16 bits which is the unit of data read and write. Fig. 3.21 Structure of a Link Register (2) Use two link registers to handle 32-bit data. The link register number designated by the 32-bit instruction holds the lower 16 bits and the designated link register number + 1 holds the higher 16 bits. Fig.3.22 Programming of Link Registers when the 32-bit Instruction is Used - (3) The data communication described below is possible by using link registers for data link. - (a) Data written to a station (master or local) can be read and used with other stations (local or master). Using link registers, data communication is enabled from the master station to all local stations, from a local station to the master station, and between local stations. Fig. 3.23 Use of Link Registers with a Data Link System (4) To use link registers for data link, it is necessary to set a link range (the range used for registers with each station) in the master station. The link register numbers not set within a link range can be used as data registers at each station. Fig. 3.24 Allocation of Link Registers # REMARKS - (1) For the data link system and link range setting, refer to the MELSECNET (II) Data Link System Reference Manual (IB-66263) and MELSECNET, MELSECNET/B Data Link System Reference Manual (IB-66350). - (2) To use link registers with remote I/O stations, use the RFRP/RTOP instructions at the master station. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----------|------------|------------|-----|-----|-------------|--------|-------|-------------|-----| | | ∆*1 | △*1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Remark | *1 : A1 aı | nd A1N a | re unusabl | θ. | | | | | | | | # 3.11 File Registers (R) ### 3.11.1 File registers (1) File registers are used in an extended area of data registers. The user memory area and sequencer CPU in the memory cassette is used for file registers. Fig. 3.25 File Register Area (2) Each file register consists of 16 bits which is the unit of data read and write. Fig. 3.26 Structure of a File Register (3) Use two file registers to handle a 32-bit data. The file register number designated by the 32-bit instruction holds the lower 16 bits and the designated file register number + 1 holds the higher 16 bits. Fig. 3.27 Programming of File Registers when the 32-bit Instruction is Used - (4) Clearing file register data - (a) Data stored in a file register is not cleared when the power supply is turned ON, or when the RESET switch is moved to "RESET" or "LATCH CLEAR". - (b) Use the FMOV(P) instruction and write "0" to clear a file register. Example To clear file registers R0 to R1023 (1K): Fig. 3.28 A Ladder to Clear File Registers (5) Note on setting the comment capacity File registers are set in the area before the comments. This means that if the comment capacity is changed, the location of the file registers changes and the stored data values will be incorrect. Before changing the comment capacity, write the file register data to a peripheral device, then write this data back to the CPU after the comment capacity has been changed. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | | x | x | × | x | х | 0 | 0 | 0 | х | х | x | | Remark | | | | | | | | | | | | #### 3.11.2 Extension file registers Extension file registers are for extended use of data registers and allocated automatically to vacant (unused) areas in the memory cassette. A total of 8192 points are set as 1 block. Up to 48 blocks can be used. The number of blocks varies with type of memory cassette to be used and capacity of vacant memory areas and the sequencer CPU. # **POINT** Extension file register can be used only when the memory capacity for registers is set with parameters. - (1) Allocation of extension file registers - (a) Extension file registers are allocated automatically to vacant areas in a memory cassette as shown below. Vacant areas are divided into units of 16 k bytes, and each area is attached with a block number. If capacity of a vacant area is less than 16 k bytes, such area cannot be used as an extension file register. (b) The block numbers usable for extension file registers among block number 1 to 8 can be obtained as follows based on the capacity of vacant areas. Capacity of vacant areas (k bytes)/16 = N (Truncation) Usable block numbers: 0 to N (c) The block numbers usable for extension file registers among block numbers 10 to 64 vary with type of memory cassette to be used. | A3NMCA-16 | 10, 11 | |------------|----------| | A3NMCA-24 | 10 to 12 | | A3NMCA-40 | 10 to 20 | | A3NMCA-56 | 10 to 28 | | A3AMCA-96 | 10 to 48 | | A4UMCA-128 | 10 to 64 | ## POINT When a value outside the usable block number range is designated when an A3NMCA-16, 24, 40, 56, A3AMCA-96, or A4UMCA-128 is used, the following will occur: | | Though No Error is Generated,<br>Read Out Value will be Indefinite. | "OPERATION ERROR" | |------------|---------------------------------------------------------------------|-------------------| | A3NMCA-16 | | 12 and after | | A3NMCA-24 | 13 to 28 | 29 and after | | A3NMCA-40 | 21 to 28 | 29 and after | | A3NMCA-56 | | 29 and after | | A3AMCA-96 | | 49 and after | | A4UMCA-128 | | 65 and after | (2) Use of extension file registers When data read/write is executed with extension file registers, use them as file registers (R). Set the device numbers of extension file register with R0 to R8191 similarly as file registers are set. Designate block numbers of extension file registers and file registers to be used. To use the file registers set with parameters, designate block No. 0. Block No. 0 is set when the PC CPU is powered on. # POINT The device number usable for data read/write among the extension file register block numbers 1 through 64 are within the range of the file registers (block No. 0) set with parameters. Example) If the file register area is set at 4 k with parameters: If index registers (Z, V) are used for index qualification of file register (R) device numbers, read/write can be done with all device numbers from 0 to 8191. - (3) Precautions on the use of extension file registers - (a) To use extension file registers, set the file register capacity with parameters. If the file register capacity is not set, extension file registers cannot be used. - (b) If sampling trace or status latch is executed when extension file registers are used, the file registers of which data is to be read are selected as follows. - At sampling trace: When a step number is designated: The file registers of the block numbers designated when the END instruction is executed. When sampling time is designated: File registers vary with timing of sampling. - At status latch: The file registers of the block numbers designated when the STATUS LATCH instruction is executed. - \*: To set block No. 2, use the "RSET" instruction. For details on the RSET instruction, refer to the Programming Manual (Dedicated Instructions) for the AnSHCPU/AnACPU/AnCCPU/QCPU-A (A Mode). | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | #### 3.12 Accumulators (A) (1) Accumulators are used to store the operation results of basic and application instructions. For the basic and application instructions of which operation results are stored in accumulators, refer to the list of instructions in the ACPU Programming Manual (Common Instructions) (IB-66250). (2) Each accumulator consists of 16 bits which is the unit of data read and write. Fig. 3.29 Structure of an Accumulator (3) Two accumulators (A0, A1) are provided. Use two accumulators to handle 32-bit data. Accumulator A0, when used with a 32-bit instruction, holds the lower 16 bits and A1 holds the higher 16 bits. Fig. 3.30 Programming of Accumulators when the 32-bit Instruction is Used | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | VEA | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0.0 | 0 | 0 | 0 | 0 | 0 | x | × | х | 0 | 0 | 0 | | Remark | | | | | | | | | | | | ### 3.13 Index Registers ### 3.13.1 Index registers (Z, V) (1) Index registers are used to designate indirectly the devices (X, Y, M, L, S, B, F, T, C, D, W, R, K, H, and P) which are used with basic and application instructions. This indirect designation of devices is disabled when those instructions which use bit devices (X, Y, M, L, S, B, F, T, and C) in units of each device for contacts, coils, etc. are used. Fig. 3.31 Example of Indirect Designation Using Index Register (2) Each index register consists of 16 bits which is the unit of data read and write. Fig. 3.32 Structure of an Index Register (3) Two index registers (Z, V) are provided. Index register Z, when used with a 32-bit instruction, holds the lower 16 bits and V holds the higher 16 bits. A 32-bit instruction cannot be used to designate V. Fig. 3.33 Programming of Index Registers when a 32-bit Instruction is Used ### POINT The CPU modules other than the AnA, A2AS, and AnU, QCPU-A do not save the index register data before the execution of an interrupt program. When index register data has been changed during an interrupt program execution and when the index register data needs to be changed back to the state before the interrupt program execution at the completion of the interrupt program execution (IRET execution), make a program as follows: | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|---------------------------------------|-----| | | x | x | x | х | x | 0 | 0 | 0 | x | х | х | | Remark | | | | | | | | | | · · · · · · · · · · · · · · · · · · · | | ## 3.13.2 Index registers (Zn(Z, Z1 to Z6), Vn(V, V1 to V6)) (1) index registers are used to designate indirectly the devices (X, Y, M, L, S, B, F, T, C, D, W, R, K, H, and P) which are used with basic and application instructions. This indirect designation of devices is enabled also when those instructions which use bit devices (X, Y, M, L, S, B, F, T, and C) in units of each device for contacts, coils, etc. are used. However, when devices T and C are used with OUT T[] or OUT C[], indirect designation by using index registers is impossible. Fig. 3.34 Example of Indirect Setting with Index Registers (2) Each index register consists of 16 bits which is the unit of data read and write. Fig. 3.35 Structure of an Index Register (a) Two kinds of index registers Zn and Vn are provided. When a 32-bit instruction is used, a Zn holds the lower 16 bits and a Vn holds the higher 16 bits. The following pairs of index registers are used with a 32-bit instruction. - 1) Z and V - 2) Z1 and V1 - 3) Z2 and V2 - 4) Z3 and V3 - 5) Z4 and V4 - 6) Z5 and V5 - 7) Z6 and V6 Since the Zn is regarded as the lower 16-bit device, the Vn cannot be used with a 32-bit instruction. Fig. 3.36 Programming of Index Registers when a 32-bit Instruction is Used #### **POINT** The AnA, A2AS, and AnU, QCPU-A modules save the index register data before the execution of an interrupt program. Saved index register data is restored after the interrupt program execution is completed (IRET execution). When index register data has been changed during an interrupt program execution, the index register data returns to that before the interrupt program execution at the completion of the interrupt program execution. | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ### 3.14 **Nesting (N)** - (1) Nesting devices are used with the master control instructions. - (2) The master control instructions are used to open and close the bus so that switching of ladders may be executed efficiently by the sequence program. Each master control sequence begins with an MC instruction and ends with an MCR instruction. (Refer to the ACPU Programming Manual (Common Instructions) (IB-66250) for details.) Fig. 3.37 Nesting of Master Control (3) When an MC instruction is OFF, the results of the operations from an MC to an MCR are as follows. | 100 ms and 10 ms timers | Count value becomes 0. Coil and contact are turned OFF. | |----------------------------------------------------------------------|-----------------------------------------------------------------------| | 100 ms retentive timers and counters | Coils are turned OFF. Count value and contacts retain present status. | | Devices used with an OUT instruction | All are turned OFF. | | Devices used with SET, RST, SFT, basic, and application instructions | Present status is retained. | | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | #### 3.15 Pointers (P) - (1) Pointers are used with the jump instructions (CJ, SCJ, JMP, CALL) in two different ways as follows. - (a) Designation of the destination of jump (CJ, SCJ, JMP) and the head of destination (label). - (b) Designation of the destination of subroutine call (CALL, CALLP) and the head of the subroutine program (label). - (2) A label number cannot be used at more than one place. If used, an error will occur. - (3) P255 always designates the END step. - (a) Use P255 with a CJ, SCJ, or JMP instruction to jump to the END step. - (b) P255 cannot be used as a label. - (c) P255 cannot be used with the devices for the CALL(P) instruction. Fig.3.38 Programming of Pointer with the Jump Instruction (4) When a CHK instruction is used in the sequence program, P254 should be used as the label of the CHK instruction. If a CHK instruction is not used, P254 can be used equally to P0 to P253. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0.0 | o | 0 | 0 | 0 | 0 | 0 | o | 0 | 0 | х | 0 | | Remark | | | | | | | | | | | | ### 3.16 Interrupt Pointers (I) (1) Interrupt pointers are used as the label at the head of each interrupt program. Each interrupt program begins with an interrupt pointer and ends with the IRET instruction. Fig. 3.39 Interrupt Pointer (2) Table 3.2 shows interrupt pointers classified by purpose of use. Table 3.2 Interrupt Pointers and Their Purpose of Use | , | Table 3.2 Interru | pt Pointer | sand In | eir Purpose of Use | | |----------------------|-------------------------------------|------------|----------------------|------------------------------------------|-------------| | Interrupt<br>Pointer | Interrupt Factor | | Interrupt<br>Pointer | Interrupt Factor | | | 10 | | 1st point | 116 | | 1st piece | | l1 | | 2nd point | 117 | | 2nd piece | | 12 | | 3rd point | 18 | (**) | 3rd piece | | 13 | | 4th point | 119 | (*1)<br>Interrupt factor by the sequence | 4th piece | | 14 | i | 5th point | 120 | start generator module | 5th piece | | 15 | | 6th point | 121 | | 6th piece | | 16 | Interrupt factor by the Al61 | 7th point | 122 | | 7th piece | | 17 | and A1SI61 process interrupt module | 8th point | 123 | | 8th piece | | 18 | | 9th point | 124 | | | | 19 | ļ | 10th point | 125 | | | | 110 | | 11th point | 126 | Unusable | | | 111 | | 12th point | 127 | | | | 112 | | 13th point | 128 | | | | 113 | | 14th point | 129 | Interrupt factor by 40 ms by an int | ernal timer | | 114 | | 15th point | 130 | Interrupt factor by 20 ms by an int | ernal timer | | 115 | | 16th point | 131 | Interrupt factor by 10 ms by an int | ernal timer | # REMARK - 1) \*1: The sequence start generator module is a special function module which can send an interrupt start signal to the PC CPU. (excluding the Al61, A1SI61) Pointers are allocated to the sequence start generator modules beginning with the one nearest to the PC CPU when the modules are installed to the base unit. - 2) Priority of the interrupt factors is provided as follows. (3) When any of I29 to 31 are used with the program, interrupt programs are executed at every preset interrupt time. Fig. 3.40 shows the example of execution of interrupt programs when I29 to 31 are used. Fig. 3.40 Execution of Interrupt Programs Using I29 to I31 ### 3.17 Special Relays and Special Registers Special relays and special registers are the internal relays and data registers which are allocated to specific purposes in the PC CPU. Special relays and special registers have the following purposes. | (1) | PC CPU operation status check The special relays and registers are used for the PC CPU operation status check as follows. | |-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | , | (a) Operation status check (RUN/STOP/PAUSE/STEP RUN) (b) Error check by self-diagnosis Section 6.13 (c) Momentary power failure check Table 3.1 (d) Battery voltage check (e) Operation error check Section 6.13 (f) Execution status of a fault detection program using annunciators Section 3.5 (g) Scan time check Section 2.5 | | (2) | Timing contact<br>Some of the special relays vary in function according to the purpose of<br>use in the sequence program. | | | (a) Normally ON/OFF flagsTable 3.1(b) RUN flagTable 3.1(c) Initial processing flag (ON for 1 scan)Table 3.1(d) Clock by every designated scanTable 3.1(e) Clock by every present timeTable 3.1 | | (3) | For commands to the PC CPU The special relays and registers are used also to give commands to the PC CPU by the sequence program or with peripheral devices. | | | (a) PAUSE enableSection 6.4(b) Clock data read/writeSection 6.9(c) Execution of constant scanSection 6.1(d) Execution of I/O module switchingSection 6.10 | # REMARKS - 1) Special relay and special register numbers are allocated as follows. - (a) Special relays . . . . . . . . M9000 to M9255 (e) Execution of error check (fuse blow, - (b) Special registers..... D9000 to D9255 - 2) For details of the special relays and registers which can be used with the PC CPU, refer to the ACPU Programming Manual (Common Instructions) (IB-66250). battery voltage, I/O module verify) . . . . . . Section 6.13 Special relays and registers used for confirming the operating status and timing contact of the PC CPU are as given in Table 3.1 below. Table 3.1 Applications of Special Relays and Registers | ltem | Special<br>Relay | Special<br>Register | Applications and Contents | |----------------------------------------|----------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Initial processing flag<br>(1 scan ON) | M9038 | | (1) M9038 relays turns ON for 1 scan when the PC CPU state switches from STOP (PAUSE) to RUN. Sequence program M9038 OFF Switching from STOP to RUN (2) By using M9038, a sequence program to be executed only once can be created without using a PLS instruction when the CPU state switches from STOP (PAUSE) to RUN. M9038 Initial processing program | | Clock at designated interval | M9030<br>to<br>M9034 | | (1) M9030 to M9034 relays switch ON and OFF at designated intervals when the CPU is in the RUN state. (They hold the ON or OFF state when the CPU is in the STOP state.) • M9030: 0.1 s clock • M9031: 0.2 s clock • M9032: 1 s clock • M9033: 2 s clock • M9034: 1 min clock (2) By using M9030 to M9034 relays, a program executed at designated intervals can be created and the time measurement can be done without using timers. • Program executed at 1 s intervals ON M9032 OFF ON M9034 CO CO (RST CO) CO M9034 OFF M9034 OFF M9034 OFF M9034 OFF M9034 OFF | Table 3.1 Applications of Special Relays and Registers (continued) | Item | Special<br>Relay | Special<br>Register | Applications and Contents | |--------------------------|----------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Clock by designated scan | M9020<br>to<br>M9024 | | (1) M9020 to M9024 relays switch ON and OFF by designated scans. Scans are designated with a DUTY instruction. [Sequence program] | | | | | DUTY n1 n2 M9020] M9020 to M9024 are designated. → OFF scan | | | | _ | <del>&gt;</del> ON scan<br>[Timing] | | | | | ON | | | | | OFF n2 scan n1 scan | | | | | <ul><li>(2) Timing starts with the OFF state when the power is turned ON or reset.</li><li>(3) By setting the n1 scan to 0, the clock can be terminated.</li></ul> | | Detection of instanta- | M9005 | D9005 | (1) M9005 relay is used for detecting the occurrence of instantaneous | | neous power failure | Wood | 23003 | power failure of 20 ms or less in the CPU. It remains ON when an instantaneous power failure is detected. When M9005 is ON, the sequence program operation continues. (2) When an instantaneous power failure is detected, D9005 (AC DOWN detection) data increases by 1. | | | | | 100 VAC | | | | | Instantaneous power failure voltage 20 ms | | | | | <b>★&gt;</b> | | | | | ON | | | | | M9005 OFF | | | | | M9005 0 1 | | | | | Number of occurrences of instaneous power failure | | | | | (3) This can be used for checking the stability of the power supply being used. | | Always OFF flag | M9037 | | <ul><li>(1) M9037 relay is always OFF when the power is ON.</li><li>(2) This can be used to disable execution temporarily for debugging, etc.</li></ul> | | Always ON flag | M9036 | | <ul><li>(1) M9036 relay is always ON when the power is ON.</li><li>(2) This can be used to create a program which is executed only once after the power is turned ON.</li></ul> | | | | | M9036<br> MOVP K4X0 D0 ] | Table 3.1 Applications of Special Relays and Registers (continued) ### 4. ALLOCATION OF I/O NUMBERS This section gives the input and output number allocation procedures for performing communications with the input/output modules and special function modules by using the building-block type CPU, A0J2H, A2CCPU, and A1FXCPU. The I/O number allocation for the A73 is the same as that for the building-block type CPUs. However, since the installation procedure for the main base unit is different from that for the building-block type CPU, refer to the following manuals. • A73 : A73CPU Reference Manual (IB-66233) Since the I/O number allocation for the A52G varies according to the operation mode (remote I/O mode, proximity I/O mode, composite mode), refer to the following manual: A52GCPU (T21B) Reference Manual (IB-66420) #### 4.1 I/O Numbers The input and output numbers are used with the sequence program for data input from the input modules and for data output to the output modules. The input and output numbers are expressed in three hexadecimal digits. Fig. 4.1 shows the example of the I/O numbers when all of the I/O modules are of the 16-point type. | | | X [0] [0] [0] | X [0] [1] [0] | X [0] [2] [0] | Y [0] [3] [0] | Y [0] [4] [0 | |--------------|---------------|--------------------|--------------------|---------------------|---------------------|---------------------| | Power supply | CPU<br>module | to | to | to<br>X2C | to | to | | module | | X [0] [0] [F] | X [0] [1] [F] | to<br>X [0] [2] [F] | Y [0] [3] [F] | Y [0] [4] [F] | | | | input<br>16 points | input<br>16 points | input<br>16 points | output<br>16 points | output<br>16 points | Fig. 4.1 Example of the I/O Numbers # REMARK When a peripheral device is used for programming, the I/O numbers can be input in two digits. | I/O number | | Input by a peripheral device | |------------|---------------|------------------------------| | X010 | $\rightarrow$ | X10 | | Y020 | $\rightarrow$ | Y20 | | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | VEA | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 5, 5 | 0 | 0 | x | 0 | 0 | 0 | 0 | 0 | х | х | x | | Remark | | | | | | | | | | | | ### 4.2 I/O Number Allocation of the Building-block Type CPUs This section gives the I/O number allocation procedure of the building-block type CPUs. #### 4.2.1 Basics of the I/O number allocation The I/O number allocation should be performed when the PC CPU is powered on or reset. Designate the I/O numbers, which are allocated as follows, with the sequence program. (1) The I/O numbers are allocated beginning with slot No. 0 of the main base unit (right next to the CPU module) to the right. Input modules are allocated with X[[[[[[]]]]]], and output modules are allocated with Y[[[[[[]]]]]] in consecutive numbers. (2) If extension base units are used, the allocation at the 1st extension base unit begins with the number which immediately follows the last number allocated to the main base unit. Allocation of extension base units should not follow the order of connection of extension cables but follow the order of stage number setting of extension base units. (3) Each module occupies the number of I/O numbers which is equal to the number of the I/O points of the module. For example, when a 32-point input module is loaded to slot No. 0 of the main base unit, 32 points of I/O numbers from X00 to X1F are occupied. (4) Each vacant slot to which no I/O module or special function module is loaded should be allocated with 16 points. (5) Each of the main and extension base units should be regarded to have 8 slots to which I/O numbers are allocated. For example, allocate the I/O numbers for 8 slots to a 5-slot main base unit. The I/O number allocation of the next (extension) base unit should begin with the number which immediately follows the last number allocated to the main base unit. (6) If setting of the extension stage numbers is not consecutive (stage numbers are skipped), the I/O numbers should be allocated considering that the I/O numbers obtained as "the number of skipped stages x 8 (slots) x 16 (points)" are already occupied. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | ΑЗV | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0.0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | х | x | х | | Remark | | | | | | | | | | | | #### 4.2.2 I/O allocation using peripheral devices The building-block type CPUs can control I/O modules and special function modules without the I/O allocation using peripheral devices. The I/O allocation using peripheral devices has the following features. - (1) Functions of the I/O allocation using peripheral devices - (a) When a 5-slot base unit is used, the number of I/O points to be allocated to additional 3 slots can be set at 0 points so that other I/O numbers may be efficiently used. - (b) The number of I/O points can be reserved to adopt modules other than the 16-point module to allow system expansion. - (c) Allocated I/O numbers are held unchanged when I/O modules or special function modules other than the 16-point module are removed for repair or replacement. - (2) Basics of the I/O allocation using peripheral devices - (a) The number of allocation points per slot of the main base unit or extension base unit is provided as follows. | | Number of Allocation Points | | | | | | | | | | | | | |-------------|-----------------------------|---------------|-------------------------|--|--|--|--|--|--|--|--|--|--| | Vacant Slot | Input Module | Output Module | Special Function Module | | | | | | | | | | | | 0 | | _ | <del></del> | | | | | | | | | | | | 16 | 16 | 16 | 16 | | | | | | | | | | | | 32 | 32 | 32 | 32 | | | | | | | | | | | | 48 | 48 | 48 | 48 | | | | | | | | | | | | 64 | 64 | 64 | 64 | | | | | | | | | | | - (b) The number of I/O points allocated to a specific slot by using a peripheral device is given priority over the number of I/O points occupied by a module to be loaded in the slot. - If the number of I/O points allocated to a slot using a peripheral device is smaller than that occupied by a module loaded to the slot, the number of I/O points usable with the module decreases. - For example, when a 32-points input module is loaded in a slot to which 16 points for the input module are allocated using a peripheral device, the latter 16 points occupied by the input module cannot be used. - 2) If the number of I/O points allocated to a slot is larger than that occupied by the I/O module loaded to the slot, the excessive points are set as dummy points. - 3) If a slot in which an I/O module is loaded is set as a vacant slot, the loaded module becomes unusable. - (c) The I/O allocation of the slots to which I/O allocation using a peripheral device has not been set is executed according to the number of points occupied by the modules loaded in the slots. ### (3) Precautions (a) The I/O allocation of a slot in which a special function module is loaded must correspond exactly to that of the loaded module. If there is any discrepancy between the I/O allocation of the slot and that of the loaded module, an error occurs. 1) A11VC.....Output: 16 points 2) Al61..... Special: 32 points 3) AG62.....Input: Number of setting points 4) 2-slot module.....Set with 16 vacant points and 32 special points as shown below. Also refer to the User's Manual for the special function module to be used. - (b) When the MELSECNET data link system is used, perform the I/O allocation as follows. - 1) If the I/O allocation is to be set at a master station, the master station and all the remote I/O station need I/O allocation. - 2) If the I/O allocation is to be set at a local station, only the local stations need I/O allocation. - 3) If the I/O allocation is to be set at a composite I/O module (such as A42XY), perform the I/O allocation for the output module. ### **POINT** The following restrictions are provided to the last slot of the 7th extension stage of the A3CPU module. - 1) If an input module is loaded, the Y addresses cannot be used for internal relays. - 2) If the I/O allocation using a peripheral device is set including some differences from that of the module to be loaded, do not load the module to the slot. If it is loaded, input and output will beincorrectly executed. - 3) If the X and Y addresses are transferred within a data link system, do not load a module to the slot. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0.0 | О | 0 | 0 | o | 0 | 0 | 0 | | х | х | x | | Remark | | | | | | | | | · | | | #### 4.2.3 Example of I/O number allocation The following are examples of I/O number allocation when a building-block type CPU is loaded with I/O modules and when a peripheral device is used for I/O allocation. (1) I/O allocation when I/O modules are loaded - (2) I/O allocation using a peripheral device - (a) Example of I/O allocation Fig. 4.2 Example of I/O Allocation Using a Peripheral Device . . ## (b) I/O numbers allocated by using a peripheral device # REMARKS - \*1 : Since only 16 points are allocated, the latter 16 input points are unusable. - \*2 : Since 32 points are allocated, points from 40 to 4F are set as dummy points. - \*3 : Since 16 points (S) for a vacant slot are allocated, these points cannot be used for output. - \*4 : Since 0 point (S) for a vacant slot is allocated, these 3 slots are not allocated with I/O points. - \*5 : Since 32 points (S) for a vacant slot are allocated, 32 vacant points are set. - \*6 : Since 48 points are allocated, points from E0 to EF are set as dummy points. ### 4. ALLOCATION OF I/O NUMBERS **MELSEC-A** | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0,0 | х | x | x | х | x | x | x | х | 0 | х | х | | Remark | | | | | | | | | | | | #### 4.3 I/O Allocation of the A0J2HCPU The A0J2HCPU can be connected with up to 8 I/O modules. The following describes the allocation of I/O numbers for the A0J2H system. #### 4.3.1 Basics of I/O allocation (1) I/O modules for the A0J2H (a) All the I/O modules for the A0J2H occupy 64 points per module. Inputs (X) and outputs (Y) are allocated as follows. 1) Inputs (X) First-half 32 points 2) Outputs (Y) Second-half 32 points (b) The I/O numbers are allocated in the order of I/O module numbers of the I/O modules for the A0J2H. The I/O module numbers do not need to be set in the order of connection of the I/O modules for the A0J2H. Use caution not to use duplicate I/O module numbers. The I/O module numbers can be set at 0 to 7. (c) The head I/O number of the I/O modules for the A0J2H is provided as follows. | Setting | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |--------------------|-----|-----|-----|-----|------|------|-------|-------| | Head input number | X00 | X40 | X80 | XC0 | X100 | X140 | X180 | X1 C0 | | Head output number | Y20 | Y60 | YA0 | YE0 | Y120 | Y160 | Y1 A0 | Y1E0 | 4 40 (d) The output numbers which correspond to allocated input numbers and unused numbers can be used for internal memory addresses. However, if an input-only module is used, the output numbers which correspond to allocated input numbers and unused numbers cannot be used for internal memory addresses. - (2) Special function modules for the A0J2H - (a) All the special function modules for the A0J2H occupy 64 points per module. The first-half 32 points are used for both input (X) and output (Y). However, the I/O numbers usable with the sequence program vary with each special function module. Refer to the User's Manual for respective special function module for usable I/O numbers and their purposes. - (b) The head I/O number of the special function modules for the A0J2 is provided according to the I/O module numbers as follows. | Setting | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |--------------------|-------------|-----|-----|-----|------|------|------|-------| | Head input number | X00 | X40 | X80 | XC0 | X100 | X140 | X180 | X1 C0 | | Head output number | <b>Y</b> 00 | Y40 | Y80 | YC0 | Y100 | Y140 | Y180 | Y1 C0 | - (c) The special function modules can use the second-half 32 points for internal relays. - Extension base unit - (a) If an extension base unit is used, slot 0 to 3 can be used. - (b) Slots 0 to 3 correspond to I/O module numbers 4 to 7. The I/O numbers of slot 0 always begin with X/Y100. - (c) Slot 1 occupies 64 points without regard to the number of I/O modules and vacant slots. - If 64-point I/O modules are not used (16- or 32-point modules are used), the following occurs. - When a 16-point module is used, the latter 48 points become unused. The A0J2H regards those 48 points as a wrap-around of the 16-point module. (I/O points are duplicated for every 16 addresses) For example, if either of addresses 110, 120, or 130 (see Fig. 4.2 below) is accessed, the A0J2H regards that address 100 is accessed. 2) When a 32-point module is used, the latter 32 points become unused. The A0J2H regards those 32 points as a wrap-around of the 32-point module. For example, if address 160 (see Fig. 4.2 below) is accessed, the A0J2H regards that address 140 is accessed. Fig. 4.2 I/O Allocation of Extension Base Unit #### POINT With an extension base unit, the A0J2H I/O modules and special function modules can be used up to 4 modules in total. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | VEA | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | | x | x | x | х | х | x | x | х | 0 | х | х | | Remark | | | | | | | | | | | | ### 4.3.2 Example of I/O number allocation The following figures show the examples of I/O allocation of the A0J2H. (1) Fig. 4.3 shows an example of I/O allocation when the A0J2H I/O modules and special function modules are used. Fig. 4.3 Example of I/O Allocation (1) (with the A0J2 I/O modules and special function modules) (2) Fig. 4.4 shows an example of I/O allocation when the A0J2H I/O modules and an extension base unit are used. Fig. 4.4 Example of I/O Allocation (2) (with an extension base unit) . . | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|-----------|-----------|------------|-----|-----|-------------|--------|---------------------------------------|-------------|-----| | | x | x | × | x | х | x | х | x | X | △*1 | x | | Remark | *1: Only t | he A2C is | applicabl | e. | | | | | · · · · · · · · · · · · · · · · · · · | • | | #### 4.4 I/O Allocation of the A2CCPU The A2CCPU controls communication with I/O modules and remote terminals by I/O numbers. The following describes the allocation of I/O numbers for the A2C system. #### 4.4.1 Basics of I/O allocation The I/O numbers are allocated with X/Y0 to X/Y1FF in the order of station numbers set with the station number setting switch on each module. Note that the I/O number allocation is not executed in the order of connection of the I/O modules and remote terminal modules. (1) Station number and I/O number allocation Each station is allocated with 8 points. Stations 1 through 64 can be set. Table 4.1 shows correspondence between station number setting and I/O number allocation. Table 4.1 Correspondence between Station Numbers and I/O Numbers | Station No. | I/O Number | Station No. | I/O Number | Station No. | I/O Number | Station No. | I/O Number | |-------------|-------------|-------------|-------------|-------------|---------------|-------------|---------------| | 1 | X/Y0 to 7 | 17 | X/Y80 to 87 | 33 | X/Y100 to 107 | 49 | X/Y180 to 187 | | 2 | X/Y8 to F | 18 | X/Y88 to 8F | 34 | X/Y108 to 10F | 50 | X/Y188 to 18F | | 3 | X/Y10 to 17 | 19 | X/Y90 to 97 | 35 | X/Y110 to 117 | 51 | X/Y190 to 197 | | 4 | X/Y18 to 1F | 20 | X/Y98 to 9F | 36 | X/Y118 to 11F | 52 | X/Y198 to 19F | | 5 | X/Y20 to 27 | 21 | X/YA0 to A7 | 37 | X/Y120 to 127 | 53 | X/Y1A0 to 1A7 | | 6 | X/Y28 to 2F | 22 | X/YA8 to AF | 38 | X/Y128 to 12F | 54 | X/Y1A8 to 1AF | | 7 | X/Y30 to 37 | 23 | X/YB0 to B7 | 39 | X/Y130 to 137 | 55 | X/Y1B0 to 1B7 | | 8 | X/Y38 to 3F | 24 | X/YB8 to BF | 40 | X/Y138 to 13F | 56 | X/Y1B8 to 1BF | | 9 | X/Y40 to 47 | 25 | X/YC0 to C7 | 41 | X/Y140 to 147 | 57 | X/Y1C0 to 1C7 | | 10 | X/Y48 to 4F | 26 | X/YC8 to CF | 42 | X/Y148 to 14F | 58 | X/Y1C8 to 1CF | | 11 | X/Y50 to 57 | 27 | X/YD0 to D7 | 43 | X/Y150 to 157 | 59 | X/Y1D0 to 1D7 | | 12 | X/Y58 to 5F | 28 | X/YD8 to DF | 44 | X/Y158 to 15F | 60 | X/Y1D8 to 1DF | | 13 | X/Y60 to 67 | 29 | X/YE0 to E7 | 45 | X/Y160 to 167 | 61 | X/Y1E0 to 1E7 | | 14 | X/Y68 to 6F | 30 | X/YE8 to EF | 46 | X/Y168 to 16F | 62 | X/Y1E8 to 1EF | | 15 | X/Y70 to 77 | 31 | X/YF0 to F7 | 47 | X/Y170 to 177 | 63 | X/Y1F0 to 1F7 | | 16 | X/Y78 to 7F | 32 | X/YF8 to FF | 48 | X/Y178 to 17F | 64 | X/Y1F8 to 1FF | - (2) Occupied points and station numbers - (a) When the number of I/O points of I/O modules and remote terminal modules is 8 or more, one module occupies several consecutive station numbers. - Those station numbers occupied by a module cannot be set to other modules. - (b) Set the station numbers of I/O modules and remote terminal modules so that the numbers may be consecutive. When modules which occupy 8 or more points per module are used, set the head station number of the station numbers occupied by the module as the station number of the module. Fig. 4.5 Example of Station Number Setting # REMARK For the I/O modules and remote terminal modules usable with the A2CCPU, refer to the A2CCPU (P21/R21), A2CCPU-DC24V, A2CCPUC24(-PRF), A2CJCPU(S3) User's Manual (IB-66545). | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | | x | x | 0 | х | х | x | х | х | х | х | х | | Remark | | | | | | | | | | | | #### 4.5 I/O Number Assignment for A1FXCPU This chapter describes I/O number assignment made to transfer data between the A1FXCPU and extension modules/extension blocks. "Inputs (X)" are used to import data from the extension modules/extension blocks to the A1FXCPU, and "outputs (Y)" are used to output data from the A1FXCPU to the extension modules/extension blocks. I/O numbers are addresses of the inputs/outputs built in the A1FXCPU and the extension modules/extension blocks. The number of input/output points that may be controlled by the A1FXCPU is 242 (built in A1FXCPU: 14 input points/4 output points, extension modules/extension blocks: 224 points). However, one special module or special block occupies 8 points. Hence, when special modules/special blocks are used, the number of points available for extension modules/extension blocks is found by: 224 points -8 x (number of special modules/special blocks) The A1FXCPU contains 14 input points and 4 output points and occupies X0 to XD as inputs and Y10 to Y13 as outputs. Therefore, extension modules/extension blocks use X/Y20 to X/YFF. ### 4.5.1 I/O number assignment When switched on or reset by the RUN/STOP switch, the A1FXCPU makes the following I/O number assignment. When writting a sequence program, specify the I/O numbers assigned in accordance with the following items. - (1) I/O number assignment - (a) I/O numbers are assigned to the extension module/extension block connected on the right-hand side of the A1FXCPU, starting with X/Y20. - Numbers $X \square \square \square$ are assigned to the inputs of extension modules/ extension blocks and $Y \square \square \square$ to their outputs. - (b) I/O numbers are assigned in hexadecimal. - (c) Inputs/outputs atart at X/Yn0.The I/O numbers of each module are indicated below. | Number of I/O Points of Extension<br>Module/Extension Block | I/O Numbers | | | | |-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 8 input points | Xn0 to Xn7 (Xn8 to XnF must not be used) | | | | | 8 output points | Yn0 to Yn7 (Yn8 to YnF are handled as internal relays)*1 | | | | | 4 input points, 4 output points | Xn0 to Xn3 (An4 to XnF must not be used) Y[n+1]0 to Y[n+1]3 (Y[n+1]4 to Y[n+1]F are handled as internal relays)*1 | | | | | 16 input points | Xn0 to XnF | | | | | 16 output points | Yn0 to YnF | | | | | 8 input points, 8 output points | Xn0 to Xn7 (Xn8 to XnF must not be used) Y[n+1]0 to Y[n+1]7 (Y[n+1]8 to Y[n+1]F are handled as internal relays) *1 | | | | | 16 input points, 16 output points | Xn0 to XnF, Y[n+1]0 to Y[n+1]7 | | | | | 24 input points, 24 output points | Xn0 to XnF, X[n+2]0 to X[n+2]7 (X[n+2]8 to X[n+2]F must not be used) Y[n+1]0 to Y[n+1]F, Y[n+3]0 to Y[n+3]7 (Y[n+3]8 to Y[n+3]F are handled as internal relays) | | | | <sup>\*1:</sup>Can be switched on/off in the sequence program but cannot be provided to the outside. For example, I/O numbers are as follows when an extension module/extension block is connected on the right-hand side of the A1FXCPU. I/O numbers in parentheses are occupied by each extension module/extension block. | | | 4 input points | | | |----------------------------|----------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------|------------------------------------------------------| | 8 input points | 8 output points | 4 output points | 16 input points | | | X20 to X27<br>(X20 to X2F) | Y20 to Y27<br>(Y20 to Y2F) | X20 to X23<br>(X20 to X2F)<br>Y30 to Y33<br>(Y30 to Y3F) | X20 to X2F<br>(X20 to X2F) | | | | L <sub>.</sub> | | | | | | 8 input points | 16 input points | 24 input points | | | 16 output points | 8 output points | 16 output points | 24 output points | <b>,</b> | | Y20 to Y2F<br>(Y20 to Y2F) | X20 to X27<br>(X20 to X2F)<br>Y30 to Y37<br>(Y30 to Y3F) | X20 to X2F<br>(X20 to X2F)<br>Y30 to Y3F<br>(Y30 to Y3F) | X20 to X2F<br>X20 to X47<br>Y30 to Y3F<br>Y50 to Y5F | X20 to X2F<br>X40 to X4F<br>Y30 to Y3F<br>Y50 to Y5F | (d) One special module/special block occupies 8 points but does not use I/O numbers. Hence, when special modules/special blocks are used, skip them over when setting the I/O numbers. # REMARKS The LED indication of the extension module/extension block is in octal. When using the A1FXCPU to control the extension module/extension block, read the octal of the LED indication as hexadecimal. When a 48-point extension module (24 input points, 24 output points) is connected next to the A1FXCPU. ### 5. PROGRAM STRUCTURE ## (1) Classification of programs Table 5.1 shows the classification of the programs usable with the PC CPU. Table 5.1 PC CPU Types and Programs o : Applicable, x : Not applicable, — : Not provided | | | N | lain Progran | n | | | 9 | Sub Program | 1 | | |------------------------------|-------------------------------------------|-------------------------------|--------------------|---------------------------------------------------|----------------|-------------------------------------------|-----------------------|--------------------|---------------------------------------------------|----------------| | | Sequence | Program Microcomputer Program | | Sequence Program | | Micro | Microcomputer Program | | | | | PC CPU<br>Type | Main<br>Routine/<br>Subroutine<br>Program | Interrupt<br>Program | Utility<br>Program | User-<br>Created<br>Micro-<br>computer<br>Program | SFC<br>Program | Main<br>Routine∕<br>Subroutine<br>Program | Interrupt<br>Program | Utility<br>Program | User-<br>Created<br>Micro-<br>computer<br>Program | SFC<br>Program | | A2C | | | | | | | | | | | | A52G | | | | | | | | | | | | A1S(S1) | | | | | | | | | | | | A1SJ-S3 | | | o | | | | | | | | | A1SJH(S8) | | | U | 0 | | | | | | | | A1SH | | | | | | | | | | | | A2S(S1) | | | | | ٥ | | | | | | | A2SH(S1) | | | | | | | | | | | | A1FX | | | | | | | | | | | | A2AS<br>(S1/S30)<br>A2USH-S1 | | | x | | | | | | <u> </u> | | | Q02, Q02H | | | ^ | | | | | | | | | Q06H | 0 | | | | | 0 | 0 | | | | | A0J2H | | 0 | | | | | | | | | | A1 | | | | | | | | | | | | A1N | | | 0 | 0 | _ | | | | | | | A2 | | | | | | _ | | | | | | A2N(S1) | | | | | | | | | | | | A2A(S1) | 1 | | v | | 0 | | | | | | | A2U(S1) | | • | х | _ | | | | | | | | A3 | | | | | | | | | | | | A73 | | | o | o | | | | | o | | | АЗН | | | | | | | | | | | | АЗМ | | | | | | 0 | 0 | _ | | | | A3N | | | | | o | | | | | | | АЗА | | | x | _ | | | | | | | | A3U | | | ^ | | | | | | | | | A4U | | | | | | | | | | | ### (2) Program capacity Program capacity is the capacity of memory in which main programs and sub-programs are stored. Program capacity varies with type of PC CPU. Use parameter setting to fix program capacity. (Refer to Chapter 8 for the default value and setting range of program capacity.) | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ### 5.1 Sequence Program A sequence program consists of a main routine program, a subroutine program, and interrupt programs, and runs with the PC CPU sequence instructions, basic instructions, and applied instructions. Sequence programs are classified into main routine programs, subroutine program, and interrupt programs. There is no restrictions on the order of creation of the subroutine program and interrupt programs. A subroutine program and interrupt programs can be contained in the sequence between an [FEND] instruction and an [END] instruction without dividing the program area into the subroutine program area and the interrupt program area. Fig. 5.1 Order of Creation of the Subroutine Program and Interrupt Programs ### POINT The subsequence program for the PC CPU for which a subprogram can be created has the same structure as the main sequence program. ### REMARK Refer to the ACPU Programming Manual (Common Instructions) (IB-66250) for the sequence instructions, basic instructions, and application instructions. | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ### 5.1.1 Main routine program The main routine program is stored in the head portion of the sequence program area and executed regularly in every scan. If the main program is not stored, the PC CPU cannot execute not only the main program but also other programs. Fig. 5.2 Execution of the Main Routine Program ### 5.1.2 Subroutine program The subroutine programs are executed when they are called by the main routine program with a CALL instruction. - (1) Purpose of the subroutine programs - (a) To execute a program for a specific processing more than once within one scan. - (b) To execute a program only when a specific condition is established. - (2) Structure of the subroutine programs - (a) The subroutine program must be created after the main routine program and after an FEND instruction and before an END instruction. - (b) Attach a P[] (pointer) to the head step of each subroutine program. One pointer number cannot be used twice in the main routine program or the subroutine programs. - (c) Enter the RET instruction in the last step of each subroutine program. Fig. 5.3 Structure of Subroutine Programs Exection of the subroutine programs Execution of the subroutine programs is controlled by turning ON/OFF the input of the CALL instruction. (a) When the input condition: Specified subroutine programs are is established executed. (b) When the input condition: The subroutine programs are not is not established executed, and the instruction right after the CALL instruction is executed. Execution of subroutine programs Fig. 5.4 Execution of the Subroutine Programs Nesting the subroutine programs Nesting in which a subroutine program is called by another subroutine program can be done up to 5 levels. Nesting of 6 or more levels is unusable. Fig. 5.5 Nesting of the Subroutine Programs | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | VEA | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0,0 | 0 | 0 | ٥ | o | 0 | 0 | 0 | 0 | 0 | x | 0 | | Remark | | | | | | | | | | | | #### 5.1.3 Interrupt programs Interrupt programs are executed only when interrupt factors occur. Each interrupt program can be created for each device number specified by interrupt points I0 to I31. - (1) Structure of the interrupt programs - (a) The interrupt programs must be created after the main routine program and after a FEND instruction and before a END instruction. - (b) Attach an I (interrupt pointer) to the head step of each interrupt program. - (c) Enter the IRET instruction in the last step of each interrupt program. - (2) Execution of the interrupt programs - (a) Use the El instruction to enable interrupt. - An interrupt program is not executed if an interrupt factor occurs before execution of an El instruction. The interrupt program which corresponds to an interrupt factor which occurs after execution of an El instruction is executed. - 2) An interrupt program is not executed if an interrupt factor occurs in the STOP state. The interrupt program which corresponds to an interrupt factor which occurs after execution of an El instruction in the RUN state is executed. Fig. 5.6 Execution of Interrupt Programs E 4 (b) When an interrupt factor occurs, the interrupt program specified by the interrupt pointer number that corresponds to the factor is executed. Interrupt programs are executed according to the following conditions. - 1) When multiple interrupts occur: - When multiple interrupt factors occur simultaneously, interrupt programs are executed according to the priority given to the interrupt pointer numbers. - When an interrupt program is being executed, the next priority interrupt program is executed when the currently executed interrupt program is finished. - 2) When an instruction which disables interrupt (DI) is being executed: - Interrupt is disabled when a FROM/TO instruction or a CHG instruction is being executed. - i) When an interrupt factor occurs when a FROM/TO instruction is being executed, the corresponding interrupt program is executed when read/write specified by the FROM/TO instruction execution is completed. - ii) When an interrupt factor occurs when a CHG instruction is being executed, the corresponding interrupt program is executed when the CHG instruction execution is completed. 3) When an instruction other than that mentioned above is being executed: Interrupt programs are executed when a sequence instruction, a basic instruction, or an applied instruction other than those mentioned above is being executed. When an interrupt factor occurs when the lower 16-bit data is being transmitted by a 32-bit data transmission (DMOV) instruction, the DMOV instruction execution is suspended when transmission of the lower 16-bit data is completed, and an interrupt program is executed. When the interrupt program exection is completed, the upper 16-bit data is transmitted by executing the DMOV instruction. Interrupt factor DMOV instruction execution DMOV instruction execution Interrupt factor DMOV instruction execution If data to be used with an interrupt program is stored by use of the main routine/subroutine program, use the EI and DI instructions so that an interrupt program may not be executed until the main or subroutine program completes execution of the data store operation. Fig. 5.7 Setting an Interrupt Program Execution Disable Section 4) Real-time interrupt Real-time interrupt specified by interrupt pointer numbers I29,I30, and I31 is executed in two different ways according to type of PC CPU as follows. An: When an interrupt factor occurs during link refresh, the interrupt program is executed after link refresh is completed. Other than An: When an interrupt factor occurs during link refresh, link refresh is suspended and the interrupt program is executed. Fig. 5.8 Timing of Real-time Interrupt #### 5) Interrupt during END processing - i) If an interrupt factor occurs during END processing of monitoring of other station in a data link system, the interrupt program is executed when monitoring of other stations is completed. - ii) If an interrupt factor occurs during the wait time of the END instruction in constant scan, the interrupt program that corresponds to the factor is executed. - (3) Restrictions on program creation - (a) Devices which are turned ON by the PLS instruction in an interrupt program remain ON until the same interrupt program is executed again. - (b) When an interrupt program is being executed, interrupt is disabled (DI). - Use caution not to execute an El or a DI instruction during execution of an interrupt program. - (c) If an interrupt factor occurs when the main program and the subprograms are being executed alternately, the interrupt program is executed as follows. - If an interrupt program included in the main program is the same as that included in the sub-program, the interrupt program included in the currently executed program is executed. - 2) If one of the following interrupt factors occurs during execution of the main program or the sub-program which does not contain an interrupt program, the following occurs. - 10 to 123: An operation error occurs and the PC CPU stops. - 129 to 131: Ignored. - (d) Timers cannot be set in the interrupt programs. If a timer is used in an interrupt program, the program operation may often be disordered. For example, the coil of a timer is OFF when the contact of the timer is ON, or the current value becomes equal with the set value. - (e) Timing of the internal clock of the PC CPU is sometimes suspended by execution of an interrupt program. The timer current value scan time and constant scan time are delayed, as follows, every time an interrupt program is executed. Check the processing time of each instruction, and create an interrupt program whose processing time is not more than 8 ms. - 1) 0 < t < 8 Not delayed. - 2) $8 \le t < 20$ 0 or 10 ms delay depending on timing - 3) 20 ≤ t < 30 10 or 20 ms delay depending on timing (t: Interrupt program processing time) Type of interrupt program specified by the I number, which causes the timer current value scan time and constant scan time to be delayed, differs with type of PC CPU. | 1) A1, A1N, A2, A2N, A3N, A73, A0J2H | 10 to 131 | |--------------------------------------|------------| | 2) A3 | None | | 3) A3H, A3M | I29 to I31 | | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|----------------------------------------------|-------------------------|--------------------------|------------------------|-----------------------|------------|-------------|--------|-------|-------------|-----| | 0,0 | 0*2 | 0*2 | 0 | 0*2 | 0*2 | △*1*3 | 0*3 | 0*3 | 0 | 0 | 0*2 | | Remark | *1: Applid<br>(Refe<br>*2: Refer<br>*3: Only | r to the M<br>to page : | IELSAP II<br>5-1 for app | Programm<br>dicable mi | ing Manu<br>icrocompu | al Version | | ter.) | | | | ## 5.2 Microcomputer Programs The microcomputer programs are written in a machine language (machine codes) which can be used with the PC CPU. ## (1) Classification The microcomputer programs are classified as the utility program, SFC program and the user-created microcomputer program. Fig. 5.9 Structure of the Microcomputer Programs #### (2) Execution The microcomputer programs are executed when they are called by the SUB instruction in the sequence program. The head address (hexadecimal) of the microcomputer program to be executed is specified by the SUB instruction. Fig. 5.10 Execution of the Microcomputer Program | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----------|-----------|------------|------|-----|-------------|--------|-------|-------------|-----| | 0.0 | 0 | 0 | 0 | 0 | 0 | ∆*1 | △*1 | △*1 | 0 | 0 | 0 | | Remark | *1: Only t | he SFC p | rograms a | re applica | ble. | | | | | | | #### 5.2.1 Utility program The utility program is provided by Mitsubishi and enables PID control, trigonometric function operations, and other control and operations which cannot be executed by the sequence program. (1) Storage of the utility program The utility program must be stored in the microcomputer program area before it is used. Use the system floppy disk which contains the utility program to store it in the microcomputer program area. Refer to the Instruction Manual for the utility program to be used for detail. #### (2) Precautions - (a) The utility program must be stored at the head address (address 0) in the microcomputer program area.If the head address of the utility program is other than 0, the utility program cannot be executed. - (b) The utility program cannot be stored in the sub-program microcomputer program area. #### 5.2.2 User-created microcomputer program The user-created microcomputer program is written by a user in a machine language which can be used with the PC CPU. Refer to the ACPU Programming Manual (Common Instructions) (IB-66250) for the specification of the machine language and the creation and storage procedure of the microcomputer program. #### 5.2.3 SFC program (1) What is SFC? "SFC" is the abbreviation for "Sequential Function Chart" which is a format for describing the control specifications such as program execution sequence and conditions in the form of steps which comprise a series of control operations. (2) SFC program In an SFC program, each unit operation of a series of machine operation is described as one step, and a ladder diagram is used for programming each control operation in each step. # REMARK For the PC CPU types which can execute an SFC program, refer to the MELSAP II Programming Manual (IB-66361) Version B and later. \_ .. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|-----------|------------|------------|-----------|-----------|-------------|--------|-------|-------------|-----| | Cro | △*1 | △*1 | х | 0 | 0 | ∆*1 | △*1 | △*1 | х | х | 0 | | Remark | *1 : Only | the A3, A | 3N, A3A, A | A3U, and | A4U, Q061 | dare appl | icable. | | | | | ## 5.3 How to Use the Sub-Programs When an A3, A3N, A3H, A3M, A3V, A3A, A3U, A4U, Q06H, or A73 is used, the main and sub program operations can be switched by using a CHG instruction. [For details of the CHG instruction, refer to the ACPU Programming Manual (Common Instructions) (IB-66250).] A sub-program can be executed in the form of "serial execution" or "parallel execution". Serial execution: This is used when the program capacity (30 k steps) is insufficient. By switching the main program and subprogram alternately with a CHG instruction, a program which is larger than 30 k steps can be executed. Parallel execution: This is used when the program needs to be switched according to the object of control with one system. Programs stored in the main and subprogram areas are switched by a CHG instruction according to the object of control. Since the execution condition of the CHG instruction and the configuration of the instruction execution/non-execution result storage memory area differ with the CPU type used, the procedure of use of a sub-program accordingly differs. (1) The CHG instruction execution condition is provided in the following two different timings: (a) Execution at leading edge: Executed when the condition is turned from OFF to ON. (b) Execution during ON : Executed while the condition is ON. (2) The instruction execution/non-execution result storage area is used with the operating system of the PC CPU for the determination of execution of the PLS and TP instructions in the next scan. Table 5.2 gives the correspondence between the CPU type and the CHG instruction execution conditions and the instruction execution/non-execution result storage memory area. Table 5.2 Correspondence between the CPU Type, CHG Instruction Execution Conditions, and the Instruction Execution/Non-Execution Result Storage Memory Area | ODU Tyra | CHG Inst | | | xecution/Non-<br>ult Storage Area | Defeate | |----------|------------------------------|------------------------|--------------------|-----------------------------------|---------------| | CPU Type | Execution at<br>Leading Edge | Execution<br>During ON | Main/sub<br>Common | Main/sub<br>Independent | Refer to | | АЗ | 0 | | 0 | _ | Section 5.3.1 | | A3N | | | | | | | A3V | 0 | _ | <del></del> | | Section 5.3.2 | | A73 | | | | | | | АЗН | | | <u> </u> | | | | АЗМ | | | | | | | АзА | | 0 | | o | Section 5.3.3 | | A3U | | | | | | | A4U | ] | | | | | | Q06H | ] | | | | | #### POINTS - (1) Devices except pointers (P), interrupt points (I), timers (T), and counters (C) are used in common to the main and sub-programs. - (a) Pointers (P) and interrupt pointers (I) can be designated independently with the main and sub-programs. - (b) Timer (T) numbers and counter (C) numbers used with the main programs cannot be used with the sub-programs. - (2) Refer to the ACPU Programming Manual (Common Instructions) (IB-66250) for the operations of the PLS instruction, counters, and P instruction when the CHG instruction is used to switch the operation between the main programs and the sub-programs. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|-----------|------------|------------|-----|-----|-------------|--------|-------|-------------|-----| | | x | △*1 | x | ·x | х | х | х | х | x | x | х | | Remark | *1 : Only | the A3 is | applicable | ), | | | | | | | | 5.3.1 When the CHG instruction is executed at the leading edge of the input and the execution/nonexecution result storage memory is used commonly with the main programs and the sub-programs When the CHG instruction is executed at the leading edge of the input and the execution/non-execution result storage memory is used commonly with the main programs and the sub-programs, the operation processing is performed as follows. - (1) The results of execution/non-execution of the main (sub) program instructions stored in the memory are cleared when the main (sub) program is switched to the sub (main) program by the CHG instruction. - (2) When the main (sub) program is switched to the sub (main) program, and then switched again to the main (sub) program, and when an instruction of which execution conditions vary according to the result of the last execution/non-execution of the instruction is executed, the result of the last execution/non-execution of the instruction with the same program is required. By setting M9050 special relay to ON before execution of the CHG instruction, the result of execution/non-execution of instructions stored in the memory area is transferred to the save area. Therefore, the result of execution/non-execution is not cleared though the data in the memory area is cleared by execution of the CHG instruction. - (3) When M9050 is ON - (a) The main program is run with the repeatedly triggered instruction executed in accordance with its input condition and the edge triggered instruction executed in accordance with its input condition and previous operation result. - ↓ [CHG] instruction executed - (b) The data in the execution/nonexecution result storage memory area is exchanged with that in the save area. (c) The subprogram is run with the repeatedly triggered instruction executed in accordance with its input condition and the edge triggered instruction executed in accordance with its input condition and previous operation result. ↓ [CHG] instruction executed (d) The data in the execution/ non-execution result storage memory area is exchanged with that in the save area. Return to step (a). - (4) When M9050 is OFF - (a) The main program is run with the repeatedly triggered instruction executed in accordance with its input condition and the edge triggered instruction executed in accordance with its input condition and previous operation result. ↓ [CHG] instruction executed (b) The data in the execution/ non-execution result storage memory area is cleared. 1 (c) The subprogram is run with the repeatedly triggered instruction executed in accordance with its input condition and the edge triggered instruction executed in accordance with its input condition and previous operation result. ↓ [CHG] instruction executed (d) The data in the execution/ non-execution result storage memory area is cleared. Return to step (a). | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|---------------------------------------|----------|------|------------|-----------|------------|-------------|--------|-------|-------------|-----| | 5, \$ | Δ'1 | x | х | 0*3 | 0*2 | △*1*3 | △*1*3 | △*1*3 | х | х | 0*2 | | Remark | *1 : Only<br>*2 : Refer<br>*3 : Refer | to Secti | | and A4U | , Q06H ar | e applicab | le. | | | | | 5.3.2 When the CHG instruction is executed at the leading edge of the input and the execution/nonexecution result storage memory is sued independently with the main programs and the subprograms When the CHG instruction is executed at the leading edge of the input and the execution/non-execution result storage memory is used independently with the main programs and the subprograms, the operation processing is performed as follows. (a) The main program is run with the repeatedly triggered instruction executed in accordance with its input condition and the edge triggered instruction executed in accordance with its input condition and previous operation result. ↓ [CHG] instruction executed (b) The subprogram is run with the repeatedly triggered instruction executed in accordance with its input condition and the edge triggered instruction executed in accordance with its input condition and previous operation result. ↓ [CHG] instruction executed Return to step (a). 5.3.3 When the CHG instruction is executed when the input is ON and the execution/non-execution result storage memory is used independently with the main programs and the sub-programs When the CHG instruction is executed when the input is ON and the execution/non-execution result storage memory is used independently with the main programs and the sub-programs, the operation processing is performed as follows. - (a) The main program is run with the repeatedly triggered instruction executed in accordance with its input condition and the edge triggered instruction executed in accordance with its input condition and previous operation result. - ↓ [CHG] instruction executed - (b) The subprogram is run with the repeatedly triggered instruction executed in accordance with its input condition and the edge triggered instruction executed in accordance with its input condition and previous operation result. ↓ [CHG] instruction executed Return to step (a). | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | VEA | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|-----------|------------|------------|-----------|------------|-------------|--------|-------|-------------|-----| | 0.0 | ∆*1 | △*1 | x | 0 | 0 | △*1 | ∆*1 | △*1 | х | × | 0 | | Remark | *1: Only t | he A3, A3 | BN, A3U, A | 4U and Q | 06H are a | pplicable. | | | | | | #### 5.3.4 Notes on write during run (1) When a main program and sub program have been created, it is possible to modify or re-write the sub (or main) program while the main (or sub) program is being executed. However, if a CHG instruction is executed at the main (sub) program and a switch made to the sub (main) program during transfer of a program to the CPU from a peripheral device, or when the CPU is modifying pointer (P) or index pointer (I) addresses, correct operation of the sub (main) program will not be possible, and for this reason processing that prohibits the execution of CHG instructions is executed. However, depending on the combination of the CPU type and the GPP function software package used at the peripheral device, these notes may not apply. The table below shows whether or not these notes apply with each combination of CPU type and GPP function software package. | GPP Function Software Package | Applicable CPU | | | | | | | | |---------------------------------------------------------------------------------|---------------------|------------------------------|--|--|--|--|--|--| | GIT I dilotion Contware I dokage | A3A, A3U, A4U, Q06H | CPU Other than Those to Left | | | | | | | | SW4GP-GPPAEE (software version R or higher) SW[]IVD-GPPA ([] = 1 or higher) | 0 | × | | | | | | | | Software packages other than above | х | x | | | | | | | - Notes do not apply (write during run is possible even during execution of a CHG instruction) - x: Notes apply (processing to prohibit execution of the CHG instruction when write during run is executed is performed) When special relays M9051, M9056, M9057 are used as the execution condition for the CHG instruction, the execution status of the CHG instruction can be confirmed. Fig. 5.11 Interlocking the [CHG] Instruction Execution Conditions (2) The main and sub programs are rewritten as shown below. Fig. 5.12 Program Rewrite Timing Chart ## (3) Main (sub) program rewrite procedure | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | VEA | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|-----------|------------|------------|-----------|------------|-------------|--------|-------|-------------|-----| | | ∆*1 | △*1 | x | 0 | 0 | ∆*1 | △*1 | △*1 | х | x | 0 | | Remark | *1: Only t | the A3, A | BN, A3U, A | 4U and Q | 06H are a | pplicable. | | | | | | ## 5.3.5 Notes on writing subprogram - (1) When there is an interrupt program, the same interrupt programs must be written in the main and subsequence programs using the same interrupt pointer numbers. - (2) A timer and a counter cannot be used with the same device number in the main and subsequence programs. If the timer and counter numbers are the same, the RST T/C instruction may be used in the main (sub) sequence program when the OUT T/C instruction exists in the (sub) sequence program because the RST T/C instruction resets the T/C present value on completion of its execution. - (3) Any interrupt is disabled while the CHG instruction is being executed. Hence, an interrupt program is only executed after the CHG instruction is executed if the corresponding interrupt factor occurs. - (4) The pointer (P) indicating the destination of the branch instruction (CJ, SCJ, CALL, JMP)may be used with the same numbers in both the main and subsequence programs. # 6. FUNCTIONS Table 6.1 gives principal functions of the CPU module. Table 6.1 Table of Functions | Function | Description | | |-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---| | Constant scan | The sequence program is executed at constant intervals regardless of scan time. | | | Latch<br>(power-failure backup) | <ul> <li>Contents of devices are retained when the power is cut OFF, when the module is reset, or when a momentary power failure over 20 ms occurred.</li> <li>Devices L, B, T, C, D, and W can be latched.</li> </ul> | | | Remote RUN/STOP | Remote RUN/STOP can be instructed from a peripheral device when the RUN keyswitch is set to RUN. | | | PAUSE | The CPU operation is stopped retaining the output (Y) state. | | | Status latch | Contents of all devices at the time when the status latch condition is established are stored in the status latch area in a memory cassette. The contents of devices stored in the status latch area can be monitored with a peripheral device. | | | Sampling trace | Operating state of specified devices is sampled at specified intervals and the result of sampling is stored in the sampling trace area in a memory cassette. Data stored in the sampling trace area can be monitored with a peripheral device. | | | Offline switch | Devices (Y, M, L, S, F, B) used with the OUT instruction can be separated from the sequence program operation. | | | Step run | The sequence program stops after execution of each instruction. Step run operation is classified into two different methods as follows. By specified loop count By each instruction | | | Clock | The clock operation is enabled in the CPU module. The clock data is controlled in year, month, date, hour, minute, second, and day of the week. The clock data can be stored in special registers D9025 to D9028. | | | Online I/O module replacement | The I/O modules can be replaced when the CPU is running (power ON). | | | Interrupt processing | When an interrupt factor occurs, the corresponding interrupt program is executed with priority over the sequence program. | | | Comment | Comments of meaning and purposes are provided for each device and printed or monitored with a peripheral device to help recognition of ladder blocks. | | | Watchdog timer<br>(10 to 2000 ms) | An internal timer used for hardware or software faults of the PC CPU. Setting value is variable. | | | Microcomputer mode | The utility programs and the user-created microcomputer programs are stored in the microcomputer program area and are called by the sequence program for various control operations and processings. | — | | Self-diagnosis | The CPU checks itself and detects and indicates occurrences of errors or stops CPU operations. | | | Output setting at<br>STOP → RUN | The state of output (Y) when operation state is switched from STOP to RUN. | | | Entry code registration | Read and write of the programs (main/sub-programs and parameters) and comments from the PC CPU are disabled. | | | Print title registration | Comments for the system names and program names are registered and printed. | | | Annunciator display mode | Comments and the F numbers are displayed on the LED indicators when the annunciators are set. | | | ERROR LED priority setting | Whether the ERROR LED at an error occurrence is lit or unlit is set. | | | A A A A A A A A A A A A A A A A A A A | A<br>1 | A 2 (S 1) | A<br>3 | A<br>1<br>N | A 2 N ( S 1 ) | A<br>3<br>N<br>,<br>A<br>73 | A 3 V | A<br>3<br>H<br>,<br>A<br>3<br>M | A 2 A S (S 1 ) S 30 ) | A 2 U , A 2 U S H , G 0 6 H | A 3 A , A 3 U , A 4 U | A<br>0<br>J<br>2<br>H | A 2 C , A 52 G | Refer to | |---------------------------------------|--------|-----------|--------|-------------|---------------|-----------------------------|-------|---------------------------------|-----------------------|-----------------------------|-----------------------|-----------------------|----------------|--------------------------------| | 0 | | | | 0 | 0 | 0 | 0 | 0 | C | ) | 0 | 0 | 0 | Sec. 6.1 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | c | ) | 0 | 0 | 0 | Sec. 6.2 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | c | ) | 0 | 0 | 0 | Sec. 6.3 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C | ) | 0 | 0 | 0 | Sec. 6.4 | | 0 | _ | 0 | 0 | | 0 | 0 | 0 | 0 | | ) | 0 | 0 | 0 | Sec. 6.5 | | 0 | _ | 0 | 0 | | 0 | 0 | 0 | 0 | C | ) | 0 | 0 | 0 | Sec. 6.6 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | _ | _ | | T | 0 | 0 | Sec. 6.7 | | _ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C | ) | 0 | | | Sec. 6.8 | | O | | | 1 | 0 | 0 | 0 | 0 | | 0 | | 0 | _ | Δ" | Sec. 6.9 | | _ | _ | | | 0 | 0 | 0 | | _ | C | ) | 0 | _ | _ | Sec. 6.10 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C | ) | 0 | 0 | _ | Sec. 5.1.13 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C | ) | 0 | 0 | 0 | Sec. 6.11 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 200 ms fix | æd | | 0 | 0 | Sec. 6.12 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | _ | _ | _ | 0 | 0 | Sec. 5.2 | | 0 . | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C | ) | 0 | 0 | 0 | Sec. 6.13 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C | ) | 0 | 0 | 0 | Sec. 6.14 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C | | 0 | 0 | 0 | Sec. 6.15 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | C | ) | 0 | 0 | 0 | Sec. 6.16 | | _ | _ | _ | 0 | | _ | 0 | 0 | 0 | | <u>-</u> | 0 | | | Sec. 6.17 | | 0 | | | | | _ | _ | _ | _ | C | | 0 | 0 | 0 | Sec. 6.18<br>e clock function. | . . | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | | 0 | x | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Remark | | | | | | | | | | | | #### 6.1 Constant Scan #### (1) Constant scan Scan time varies with the number of instructions executed in each scan. The constant scan function executes a sequence program at constant intervals. By use of this function, a sequence program can be executed maintaining constant scan time. Fig. 6.1 Constant Scan Operation #### (2) Setting constant scan time (a) Constant scan time should be set with special register D9020. Constant scan begins when the constant scan time is set. Content of D9020 is cleared when power is turned ON or when the CPU is reset. To begin constant scan when power is turned ON or when the CPU is reset, write the following program at the beginning of the sequence program. (b) If scan time of a sequence program is longer than set constant scan time, the set constant scan time is ignored and the sequence program is executed according to its scan time. (c) Set a value greater than the maximum sequence program scan time for the constant scan setting. If the sequence program scan time is longer than the setting for constant scan, processing will be performed in accordance with the sequence program scan time and the constant scan function will not operate normally. Fig. 6.2 Operation when Scan Time is Longer than Constant Scan Time - (d) During the interval between execution of the sequence program END instruction and the start of the next scan, sequence program processing is stopped (each device retains the status it had before execution of the END instruction.) However, when an interrupt cause occurs, the interrupt program is executed. - (3) Notes on constant - (a) The relationship between the set value for constant scan and the set time for WDT (watchdog timer) is given by the expression below. If the set value is longer than the WDT set time, a WDT error occurs. (Constant scan set value) ≤ (WDT set value) — 1 \_ | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ## 6.2 Retaining Device Data (Latch Function) Data of all devices is cleared to the initial value (bit devices: OFF, word devices: 0) when the PC CPU is turned ON, when the RUN keyswitch is turned to RESET, or when a momentary power failure of more than 20 ms occurs. The latch function is used to retain device data when the PC CPU is turned ON, when the RUN keyswitch is turned to RESET, or when a momentary power failure of more than 20 ms occurs. The sequence program operation is not influenced by the latch function. ## (1) Purpose The latch function is used, when continuous control is being performed, to retain data such as number of products, number of defectives and addresses even when a momentary power failure of more than 20 ms occurs and to enable continuous control. ## (2) Devices usable with the latch function - (a) The following devices are usable. - 1) Latch relays - 2) Link relays - 3) Timers - 4) Counters - 5) Data registers - 6) Link registers - (b) Latch range is set with parameters on a peripheral device. Refer to Chapter 8 for the latch range of each device. # POINT Device data within the latch range is retained by the battery (A6BAT) attached to the CPU module or the memory cassette. - (1) If the sequence program operation is performed with the sequence program stored in a ROM, a backup battery is necessary to enable the latch function. - (2) If the battery connector is uncoupled from the CPU module or the memory cassette when the CPU module or the memory cassette is being turned OFF, device data within the latch range is destroyed. - (3) Clearing device data within the latch range - (a) To clear device data within the latch range and to set the initial data, execute "LATCH CLEAR". When LATCH CLEAR is executed, device data out of the latch range is also cleared as follows. - 1) Y, M/L/S, F, B..... Turned OFF. - 2) Special relays M9000 to M9255...... Retained. - 3) T,C...... Contacts and coils are turned OFF and current value becomes 0. - 4) D, Z, V, W, A.....Become 0. - 5) R.....Retained. - 6) Special registers D9000 to D9255...... Retained. - (b) The method of latch clear differs with type of CPU. For the method of latch clear, refer to the User's Manual for the PC CPU to be used. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | Anu<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | | |-------------------|--------------------|------------------------------------------------|------|------------|-----|-----|-------------|--------|-------|-------------|-----|--| | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | △*1 | 0 | | | Remark | *1 : Remo | 1 : Remote RUN/STOP by a computer is disabled. | | | | | | | | | | | #### 6.3 PC CPU RUN/STOP with a Peripheral Device (Remote RUN/STOP) The RUN keyswitch is used to RUN/STOP the PC CPU. Remote RUN/STOP is executed with a peripheral device, remote RUN contacts, or computers with the RUN keyswitch set in the RUN position. ## (1) Purpose Remote RUN/STOP is used in the following cases. - (a) The PC CPU is located out of reach of operators. - (b) To RUN/STOP the PC CPU mounted in a control panel with a device located outside the control panel. #### (2) Remote RUN/STOP operation The sequence program operation of remote RUN/STOP is as follows. - (a) Remote STOP....... The sequence program operation stops after execution of the END instruction. - (b) Remote RUN.......... When remote RUN is executed when the sequence program operation is in the stop state caused by remote STOP, the sequence program operation begins with step 0. #### (3) Remote RUN/STOP procedures The following procedures are used to enable remote STOP/RUN. - (a) Using the remote RUN contact Remote RUN/STOP can be controlled by turning the remote RUN contact ON/OFF. - 1) When the remote RUN contact is OFF, remote RUN is enabled. - 2) When the remote RUN contact is ON, remote STOP is enabled. Fig. 6.3 RUN/STOP Timing when the Remote RUN Contact is Used # POINT Use parameter setting to set the remote RUN contacts. Refer to Chapter 8 for the remote RUN contacts that can be set. (b) Using a peripheral device or a computer Remote RUN/STOP can be controlled with a peripheral device or a computer as shown below. Fig. 6.4 RUN/STOP Timing when a Peripheral Device or a Computer is Used ## (4) Precautions Since priority is given to the STOP state, the following points should be considered. - (a) When remote STOP is executed with a remote RUN contact, a peripheral device, or a computer, the PC CPU goes into the STOP state. - (b) To return the PC CPU from the STOP state caused by remote STOP to the RUN state, set all the external factors (remote RUN contacts, peripheral devices, computers, etc.) which were used for remote STOP to the RUN state. # REMARK The RUN and STOP states are described as follows. - RUN state...... The sequence program is executed repeatedly from step 0 to the END instruction. - STOP state......... The sequence program operation is being stopped. All outputs (Y) are turned OFF. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|-----------------------------------------------|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | | 0 | 0 | o | 0 | 0 | 0 | 0 | Δ | Δ | Δ | 0 | | Remark | △: PAUS | ∆ : PAUSE with the RUN keyswitch is disabled. | | | | | | | | | | #### 6.4 Stopping the Sequence Program Operation Retaining the State of Outputs (PAUSE) The PAUSE function is used to stop the sequence program operation while retaining the ON/OFF state of all outputs (Y). The following methods are used to enable PAUSE. - 1) Using the RUN keyswitch - 2) Using the remote PAUSE contact - 3) Using the GPP/HGP/PHP ## (1) Purpose The PAUSE function is useful when outputs (Y) need to remain ON when the PC CPU is stopped. ### (2) Using the RUN keyswitch - (a) When M9040 is turned ON when the RUN keyswitch is being set in the PAUSE position, the PAUSE state contact (M9041) is turned ON after execution of the END instruction of the next scan. When the END instruction of the scan after the scan in which the PAUSE state contact is turned ON is executed, the PC CPU goes into PAUSE and stops the sequence program operation. - (b) Either set the RUN keyswitch in the RUN position or turn M9040 OFF with a peripheral device to restart the sequence program operation. Fig. 6.5 PAUSE Timing when the RUN Keyswitch is Used. - (3) Using the remote PAUSE contact - (a) When the remote PAUSE contact and the PAUSE enable flag (M9040) are turned ON, the PAUSE state contact (M9041) is turned ON after execution of the END instruction of the scan. When the END instruction of the scan after the scan in which the PAUSE state contact is turned ON is executed, the PC CPU goes into PAUSE and stops the sequence program operation. - (b) Either turn OFF the remote PAUSE contact or turn M9040 OFF with a peripheral device to restart the sequence program operation. Fig. 6.6 PAUSE Timing when the Remote PAUSE Contact is Used. ## POINT Use parameter setting to set the remote PAUSE contacts. Refer to Chapter 8 for the remote PAUSE contacts that can be set. - (4) Using a peripheral device - (a) The PAUSE state contact (M9041) is turned ON after execution of the END instruction of the scan in which a remote PAUSE command from a peripheral device is received. When the END instruction of the scan after the scan in which the PAUSE state contact is turned ON is executed, the PC CPU goes into PAUSE and stops the sequence program operation. - (b) When a remote RUN command from a peripheral device is received, the PC CPU restarts the sequence program operation beginning with step 0. Fig. 6.6 PAUSE Timing when the Remote PAUSE Contact is Used. . . | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | | |-------------------|--------------------|------------------------------|------|------------|-----|-----|-------------|--------|-------|-------------|-----|--| | 0.0 | ∆*1 | △*1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Remark | *1 : A1 ar | 1 : A1 and A1N are unusable. | | | | | | | | | | | #### 6.5 Retaining Device Data when a Specific Condition is Established (Status Latch) Device data at a specific moment cannot be checked by monitoring with a peripheral device. If the status latch function is used, data of all devices when the SLT instruction is executed is transmitted and stored to preset status latch area. Data stored by status latch can be monitored with the peripheral device. Fig. 6.8 Status Latch Processing #### (1) Purpose Status latch is useful if device data when an error occurs needs to be stored and monitored. It is also useful to check the cause of occurrence of an error by setting the SLT instruction to be executed when a condition of error is established during the sequence program operation. ### (2) Status latch processing (a) The following data is stored in the status latch area when the SLT instruction is executed. | 1) Device memory | | |-----------------------|----------------------------------| | X, Y, M, L, S, F, B | ON/OFF data | | | Contact and coil ON/OFF data and | | | current values | | D,W,A,Z,V | Stored data | | 2) File registers (R) | Stored data | (b) Data is stored in the status latch area when the SLT instruction is executed. If there are outputs which are turned ON/OFF or if device data is stored using the same input condition, data stored before execution of the SLT instruction differs from that stored after execution of the SLT instruction. #### (3) Precautions Scan time increases each time an SLT instruction is executed. Set the time of the WDT and constant scan considering the time increase due to execution of the SLT instruction. Refer to the ACPU Programming Manual (Common Instructions) (IB-66250) for the execution time of the SLT instruction. #### POINT Use parameter setting to set the devices used for status latch. Refer to Chapter 8 for the setting of the devices used for status latch. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | VEA | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | | |-------------------|--------------------|------------------------------|------|------------|-----|-----|-------------|--------|-------|-------------|-----|--| | 0, 0 | △*1 | ∆*1 | 0 | 0 | 0 | 0 | 0 | o | 0 | 0 | 0 | | | Remark | *1 : A1 a | 1 : A1 and A1N are unusable. | | | | | | | | | | | # 6.6 Sampling Device Data at Constant Intervals (Sampling Trace) Changes of the ON/OFF status of bit devices and word device data cannot be checked by monitoring with a peripheral device. Sampling trace is used to sample and store data of specified devices to the sampling trace area at constant intervals. Data stored in the sampling trace area is sampled specified number of times and latched when the STRA instruction is executed. Data stored in the sampling trace area can be monitored with the peripheral device. Fig. 6.9 Sampling Trace Processing #### (1) Purpose Sampling trace is useful to check data of specified devices sampled at constant intervals. This is effective to save time when correcting a sequence program. (2) Devices usable with sampling trace The following devices are usable. - (a) Bit devices (X, Y, M, L, S, F, B, and contacts and coils of T and C) - (b) Word devices (Current value of T and C, and D, W, R, A, Z, V) (3) Number of times of sampling The number of times of sampling is set for the total number of times and for that after the STRA instruction execution. - (a) Setting the total number of times sets the sampling trace area. This can be set by 128 times within the range of 0 to 1024 times. - (b) Setting the number of times after the STRA instruction execution enables completion of sampling trace and data latch after the STRA instruction execution. This can be set by 128 times within the range of 0 to 1024 times. Fig. 6.10 Number of Times of Sampling (c) Setting of the number of times of sampling is provided as follows. ``` igg( ext{Number of times of sampling after} igg) \leq igg( ext{Total number of times of sampling} igg) \leq 1024 ext{ times} ``` # (4) Sampling interval The sampling interval sets the timing of sampling. The following two kinds of settings are used. (a) Sampling by END Sampling trace is executed after execution of every END instruction of the sequence program. Fig. 6.11 Sampling Trace Execution by Every END (b) Sampling at specified intervals Sampling trace is executed every 10 x n ms. (Sampling trace is executed also when other instructions of the sequence program are being executed.) Fig. 6.12 Sampling Trace at Specified Intervals | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0/ 0 | o | 0 | 0 | 0 | 0 | x | x | x | 0 | 0 | 0 | | Remark | | | | | | | | | | | | ## 6.7 Forced ON/OFF of the OUT Instruction with a Peripheral Device in the RUN Stare (Offline Switch) When the PC CPU is in the RUN state (when the sequence program operation is being executed), the devices used with the OUT instruction of the sequence program cannot be turned ON/OFF with a peripheral device using the test function. The offline switch function is used to separate the OUT instruction execution from the sequence program operation and enables turning ON and OFF of the devices used with the OUT instruction with a peripheral device using the test function even when the PC CPU is in the RUN state. The offline switch function is useful to check operation of the output modules and wiring between the output modules and peripheral devices using the test function on a peripheral device when the sequence program operation is being executed. Fig. 6.13 Offline State and Online State (1) Devices usable with the offline switch function The following devices used with the OUT instruction can be used with the offline switch function. - (a) Outputs (Y) - (b) Internal relays (M) - (c) Latch relays (L) - (d) Step relays (S) - (e) Link relays (B) - (f) Annunciators (F) - (2) State of devices on offline state State of devices in offline state (when the offline switch is open) is as follows. - (a) State of devices before the offline switch function is used is retained. - (b) If forcible set/reset of devices is executed with a peripheral device in offline state, the forcibly set/reset state of devices is retained. #### POINTS - (1) Devices in offline state cannot be turned ON/OFF by the sequence program operation. - If devices are set to offline in a test run of the CPU, reset them online by disabling the offline switch function after the test run. - (2) Devices reset from offline to online can be turned ON/OFF by the sequence program operation. - To set the devices online, check the input condition of the OUT instruction and make sure that there is no problem when they are reset online. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|----------------------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0.0 | △*1 | 0 | × | 0 | 0 | 0 | 0 | 0 | х | х | o | | Remark | *1 : Only the AnN is applicable. | | | | | | | | | | | #### 6.8 Step Operation Sequence program steps can be executed one-at-a-time, beginning with a specified step. Step operation can be used to confirm sequence program operation and contents of each device while the sequence program is being monitored for debugging or other purpose. #### 6.8.1 Step operation (I) (1) Contents of step operation (I) There are two methods used for step operation (I): (a) Step operation of each instruction Instructions are executed one-at-a-time from the current step. Operation steps after each execution. It can be used when each device state is confirmed at the execution of each instruction. Fig. 6.14 Step Operation by Each Instruction (b) Step operation by specifying a loop count.Step operation is executed for the specified loop count (1 through 1 to 32767) beginning with step 0 or the current step and stops at the specified step. Fig. 6.15 Step Operation by Specifying the Loop Count #### (2) Method of step operation Use the following procedure to execute step operation: - (a) Set the RUN keyswitch on the PC CPU to the "STEP RUN" position. - (b) Execute step operation with the GPP/PHP/HGP. Refer to the Operating Manual of the peripheral device for the step operation. #### (3) Output (Y) state at step operation The state of output (Y) differs with the method of setting the RUN key switch to the STEP RUN position. (a) Operation: RUN → PAUSE → STEP RUN When the RUN keyswitch is set to the STEP RUN position, the output ON/OFF state is retained, and the operation is stopped. The step operation executed with the GPP/PHP/HGP uses the state of ON/OFF of output (Y) at stop. (b) Operation: RUN → STOP → STEP RUN After storing all output in the internal memory, all outputs (Y) are turned OFF and the operation is stopped. (4) Processing of timers and special timing clocks at step operation Processing of timer and special timing clocks (M9030 to M9034) in the sequence program is as follows. - (a) Timers - 10 ms timer......10 ms is added every 1 scan execution. - 100 ms timer......100 ms is added every 10 scan executions. - (b) Special timing clocks - M9030 (0.1 s clock)......Turned ON/OFF every 5 scans. - M9031 (0.2 s clock)......Turned ON/OFF every 10 scans. - M9032 (1 s clock)......Turned ON/OFF every 50 scans. - M9033 (2 s clock).....Turned ON/OFF every 100 scans. - M9034 (1 min clock)......Turned ON/OFF every 3000 scans. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | VEA | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | | х | x | х | x | x | 0 | 0 | 0 | x | х | x | | Remark | | | | | | | | | '' | | | #### 6.8.2 Step operation (II) (1) Contents of step operation (II) Step operation (II) can be executed with type AnA, A2AS, and AnU CPUs. There are five methods used for step operation: - (a) Step operation of each instruction (Same as the step operation (I)) Instructions are executed one-at-a-time from the current step. Operation stops after each execution. It can be used to confirm each device state of each instruction execution. - (b) Step operation with step interval and loop count specification. Instructions are executed one-at-a-time every specified step interval (1 to 99 s). Operation is executed for the specified loop count (1 to 32767) and stops. Fig. 6.16 Step Operation by Specifying Step Interval Loop Count (c) Step operation by ladder block Ladder blocks are executed one-at-a-time from the current step. Operation stops after each ladder. It can be used to confirm each device state at each ladder block execution. Fig. 6.17 Step Operation by Ladder Block - (d) Step operation by specifying loop count and break points Step operation is executed for the specified loop count (1 to 9999) and stops at a specified break point. There are two methods used for specifying a break point. - Step operation using a label (Pn) as a break point This is the method of setting the pointer (Pn) that is set in the sequence program as the label of the break point. A maximum of 4 places can be specified as the break point. Fig. 6.18 Step Operation by Specifying Loop Count and Label Step operation using a specified step as a break point. This is the method of setting a step of a sequence program as a break point. A maximum of 4 places can be specified as the break point. A total of 4 places can be specified as break point when using both of above-mentioned 1) and 2). Fig. 6.19 Step Operation by Specifying Loop Count and Step Number (e) Step operation according to device state Operation stops when data of a specified bit device or a word device equals the set data. Verify of data with the set data is executed when data is written to the specified device. | Number of the<br>Trigger Devices | Device that can be Specified | Device State | Device Data | | | |----------------------------------|------------------------------|----------------------|---------------------------------------------|--|--| | 1 point | All bit devices | ON → OFF<br>ON ← OFF | | | | | . point | All word devices | <del>_</del> | <sup>*1</sup> Current value<br>& Mask value | | | \*1 Current value & Mask value. The following example describes the relation between the set values of the current value, the mask value and step operation. The bit of which current value is verified with the trigger device is set with the mask value. When the bit of the mask value is 1, the bit is verified, and when it is 0, the bit is not verified. 1) When the current value is "3" and the mask value is "FFFF" When the mask value is "FFFF", step operation is stopped when all bits of the current value and the trigger device become equal with each other. 2) When the current value is "14" and the mask value is "FFFCH" When the mask value is "FFFC", step operation is stopped when the bit data except 2 lower bits of the current value and the trigger device value become equal with each other. Lower 2 bits of the trigger device are ignored. When the value of the trigger devices becomes "12", "13", "14" or "15", step operation is stopped. #### **POINT** When status latch is being executed by a specified device, step operation according to break specification of a device condition can not be executed. #### (2) Method of step operation Use the following procedure to execute step operation: - (a) Set the RUN keyswitch on the PC CPU to the STEP RUN position. - (b) Execute the step operation with the GPP/PHP/HGP. Refer to the Operating Manual of a peripheral device for step operation. #### (3) Output (Y) state during step operation The state of output (Y) differs with the method of setting the RUN keyswitch to the STEP-RUN position. (a) Operation: RUN → PAUSE → STEP RUN When the RUN keyswitch is set to the STEP RUN position, the ON/OFF state of all outputs (Y) are retained and the operation is stopped. Step operation with the GPP/PHP/HGP is executed by using the (b) Operation :RUN → STOP → STEP RUN After storing the state of all outputs (Y) in the internal memory, all outputs (Y) are turned OFF, operation is stopped. (4) Processing of timers and special timing clocks when step operation is executed Processing of timers in the sequence program and special timing clock (M9030 to M9034) is as follows. - (a) Timers - 10 ms timer......10 ms is added every 1 scan execution. - 100 ms timer......100 ms is added every 10 scans execution. - (b) Special timing clock - M9030 (0.1 s clock)......Turned ON/OFF every 5 scans. - M9031 (0.2 s clock)......Turned ON/OFF every 10 scans. - M9032 (1 s clock)......Turned ON/OFF every 50 scans. - M9033 (2 s clock).....Turned ON/OFF every 100 scans. - M9034 (1 min clock).... Turned ON/OFF every 3000 scans. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|---------------------------------|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 0,0 | ∆*1 | 0 | х | 0 | 0 | 0 | 0 | 0 | х | х | 0 | | Remark | *1 : Only | 1 : Only the AnN is applicable. | | | | | | | | | | #### 6.8.3 Precautions for step operation The following describes the precautions for step operation. - (1) Loop count is counted after execution of the step specified as a stop step in the step operation with the loop count specification. Therefore, when the step specified as a stop step has not been executed due to the CJ instruction, loop count is not counted. - (2) When the RUN keyswitch is moved from the STEP RUN position into the STOP position or from the RUN position into the STOP position, the state of outputs before STOP is retained in the internal memory of the CPU module. Therefore, when the RUN keyswitch is moved from the STOP position into the STEP RUN position or from the STOP position into the RUN position, the outputs retained in the internal memory of the CPU module are re-output before executing the operation. Move the keyswitch from the STOP position into the STEP RUN position or the RUN position after reset in order to disable output of the outputs in the internal memory of the CPU module at the STOP state. - (3) The next step of the NEXT instruction step can not be set to a stop step in the step operation by the loop count specification. - If the next step of the NEXT instruction is set to a stop step in the step operation by the loop count specification, an error occurs and the PC CPU stops. At that time, the error message "CAN'T EXECUTE(P)" is displayed. In the case of the operation by each instruction, this setting does not cause an error. (4) When the operation processing is stopped with the step operation, I/O refresh is executed. The PC CPU using the refresh mode receives or outputs signals during the operation. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|------------|--------|------------|---------|----------|-------------|--------|-------|-------------|-----| | | 0 | x | 0 | x | 0 | 0 | 0 | 0 | х | ∆*1 | 0 | | Remark | *1: Usabl | e with the | A2CCPU | C24(-PRF | and A52 | GCPU(-T2 | 1B). | | | | | #### 6.9 Clock Function Some PC CPUs have the clock function inside of the CPU module. It can be used for time management, because clock data can be read with a sequence program. Clock operation by the clock function is continued with a battery when the PC CPU is powered off or at momentary power failure more than 20 ms. ## POINT Clock operation can not be continued if the following is done when the PC CPU is powered OFF or at momentary power failure more than 20 ms. - The connector of the battery is uncoupled. - The memory cassette is removed from the CPU module. #### (1) Clock data Clock data is the data comprised of year, month, day, hour, minute, second, and day of the week used by the clock element installed inside the PC CPU. | Data Name | | Description | | | | | | | |-----------------|-----|------------------------------------------------------|--|--|--|--|--|--| | Year | Th | e lower 2 digits of the Christian Era | | | | | | | | Month | 1 t | 0 12 | | | | | | | | Day | 1 t | 1 to 31 (A leap year is distinguished automatically) | | | | | | | | Hour | 0 t | 0 to 23 (Controlled 24 hours) | | | | | | | | Minute | O t | 0 to 59 | | | | | | | | Second | 0 t | 0 to 59 | | | | | | | | | 0 | Sunday | | | | | | | | | 1 | Monday | | | | | | | | Day of the week | 2 | Tuesday | | | | | | | | Day of the week | 3 | Wednesday | | | | | | | | | 4 | Thursday | | | | | | | | | 5 | Friday | | | | | | | | | 6 | Saturday | | | | | | | #### (2) Precision Precision of the clock element depends on the operating ambient temperature as shown below. | Ambient Temperature (°C) | Precision (Week by Error in Seconds) | | | | | | | |--------------------------|--------------------------------------|-------------|--|--|--|--|--| | Ambient Temperature (C) | Except AnA and AnU | AnA and AnU | | | | | | | +55 | +15.5 | within ± 8 | | | | | | | +25 | +2.75 | within ± 15 | | | | | | | 0 | +6.5 | within ± 7 | | | | | | - (3) Special relays and special registers for reading and writing clock data. The following describes the special relays and special registers used for setting data and reading clock data for clock operation. The devices enclosed in square brackets [ ] are used for the A2CCPUC24(-PRF) and A52GCPU(-T21B). - (a) Special relays used for the clock function | Device | Name | Description | |---------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | M9025<br>[M9073] | Clock data set request | Clock data is written to the special register (D9025 to D9028) for the clock operation. | | | | After the END instruction is executed in a scan in which<br>M9025 is turned ON the clock data stored in D9025 to<br>D9028 is written to the clock element. | | M9026 | Clock data error | Error is detected when a clock data is set. | | [M9074] | | <ul> <li>Turned ON when each data is not BCD data.</li> </ul> | | M9027 <sup>*1</sup> | Clock data<br>display | Clock data is displayed on the LED display on the front of the PC CPU. | | | | When M9027 is turned ON, clock data is displayed on<br>the LED display on the front of the CPU module. | | M9028<br>[M9076] | Clock data read request | Clock data is read to the special registers (D9025 to D9028). | | | | When M9028 is turned ON, clock data is read to D9025<br>to D9028 after execution of the END instruction. | \*1 Usable with A3A A73 and A3N. ## (b) Special registers used clock data | Device | Name | Description | |------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | D9025<br>[D9073] | Clock data<br>(year and month) | Year and Month are as follows. 15 to b8 b7 to b0 | | D9026<br>[D9074] | Clock data<br>(day and hour) | Day and Hour are as follows. b15 to b8 b7 to b0 Hour (01 to 31 are stored in BCD) Day (00 to 23 are stored in BCD) | | D9027<br>[D9075] | Clock data<br>(minute and<br>second) | Minute and Second are as follows. b15 | | D9028<br>[D9076] | Clock data<br>(day of the week) | The day of the week is as follows. The day of the week (0 to 6 are stored in BCD) O is stored. Setting of the day of the week is as follows. Day of the week Sun. Mon. Tues. Wed. Thur. Fri. Sat. Data stored 0 1 2 3 4 5 6 | \_ - (4) Writing clock data to the clock element - (a) Use the following procedure to write clock data to the clock element. - 1) Store clock data to D9025 to D9028 in the BCD code by use of the sequence program or a peripheral device. - 2) Turn M9025 ON by use of the sequence program or a peripheral device, and write the data of D9025 to D9028 to the clock element. - (b) Writing example of the clock data by use of the sequence program. (c) When writing clock data with a peripheral device, use the test mode. Refer to the Operation Manual of the peripheral device for turning ON/OFF the special relays and writing data to the special registers with the test mode. ## POINTS - (1) The CPU is shipped without clock data being correctly set. When using the clock function, write clock data to the clock element. - (2) When correcting some parts of clock data, it is necessary to write all data again to the clock element. - (3) If illegal clock data is written to the clock element, the clock operation can not be executed normally. Example: 13 (month) 32 (day) - (5) Reading clock data - (a) When reading clock data to D9025 to D9028, turn M9028 ON by use of the sequence program or a peripheral device. - (b) The PC CPU which has a 16 digit LED indicator on the front can display clock data (month, day, hour, minute, second). To display clock data on the LED indicator, turn M9027 ON. Clock data has the lower priority of order for display when an error occurs it is displayed, and clock data is not displayed. (6) When an AnA, A2AS, AnU and QCPU-A is used, data of a specified word device can be written to, and read from the clock element with a dedicated instruction. When clock data is set with peripheral digital switches, use a dedicated instruction. . ... ## (7) Handling the year 2000 Year 2000 is a leap year, so February 29 comes after February 28. The AnSHCPU automatically fixes data by the clock element in the CPU module, so the user does not have to manually set the date to the clock element. The year only contains the last two digits of the year. Therefore, when the clock data is read from the PC CPU and used in the sequence control, the year data may have to be fixed using a sequence program depending on the usage. Year 1999 → "99" Year 2000 → "00" When comparison is made only with the last two digits of the year read, the year 2000 and consecutive years are considered older than the year 1999. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|----------------------------------------------------------------------|----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 5.0 | △*1 | x | х | x | x | 0 | △*2 | х | х | х | 0 | | Remark | *1 : Only the AnN is applicable.<br>*2 : Only the AnU is applicable. | | | | | | | | | | | #### 6.10 I/O Module Replacement During Online When I/O modules or special-function modules are replaced when the PC CPU is in the ON state, the "UNIT VERIFY ERROR" occurs. And the operation of the PC CPU stops or the I/O numbers become different from set numbers. The I/O module replacement during online is to replace I/O modules without causing the "UNIT VERIFY ERROR" when the the PC CPU is in the ON state. Fig. 6.20 I/O Module Replacement During Online ## (1) Purpose The I/O module replacement during online can be used while continuing the control with the sequence program and allow I/O modules to be replaced without causing "UNIT VERIFY ERROR" #### (2) Operation procedure - (a) Use the following procedure to replace an I/O module during online: - Set the upper 2 digits of the head I/O number displayed in 3 digits of the I/O module to be replaced into D9094 (Replacement I/O head I/O number storage register). Example : Head I/O number $070 \rightarrow Set$ number: $\underline{H07}$ Head I/O number $170 \rightarrow Set$ number: $\underline{H17}$ - 2) Set M9094 (I/O replacement flag). - 3) Replace the specified I/O module. - 4) Reset M9094 (I/O replacement flag) (b) Data can be set for D9094 and M9094 can be turned ON/OFF by sequence program or a peripheral device. (3) Each module executes processings as follows according to the ON/OFF state of special relay M9094. | M9094 | Module | Processing Contents in the CPU "RUN" State | |-------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | <ol> <li>The operation state is stored to the image memory area of X or Y in the CPU when the first END<br/>is processed after M9094 is turned ON.</li> <li>After that, the corresponding input or output module is not accessed.</li> </ol> | | | СРИ | 2) After M9094 is turned ON, the operation processing of the corresponding input module is executed (ON or OFF) of the image memory area of X. | | ON | 3 | 3) After M9094 is turned ON, the result of the execution processing of the CPU is stored in the image memory area of Y by the operation of the corresponding output module. | | | | After M9094 is turned ON, verify of module and fuse blown check are not executed for all modules. | | | Replaced<br>module | The operation state at the first END instruction processing after turning ON M9094 is retained and the operation is stopped. | | | Other<br>modules | Normal operation. The module which executes output according to data of the input module to be replaced operates in the condition that the input data is fixed. | | | | The input module executes operation processing with data of the image memory area of X in the first END processing after M9094 is turned OFF. The corresponding input module is accessed. | | OFF | CPU | An output module outputs data (ON or OFF) of the image memory area of Y in the first END processing after M9094 is turned OFF. The corresponding output module is accessed. | | | | 3) After turning M9094 OFF, verify of module and fuse blown check are restarted for all modules. | | | Replaced<br>module | <ol> <li>Access is restarted with data of the image memory area of the CPU after the END processing<br/>after M9094 is turned OFF.</li> </ol> | | | Other<br>modules | 1) Normal operation. | <sup>\*</sup> Replacement with a peripheral device (force M9094 ON/OFF) while the CPU is in the STOP state is the same as mentioned above. Since all outputs are turned OFF, all processing stops. Output resumes in the RUN state. ## (4) Precautions | NO. | Item | Precautions | |------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1. | Replacement of special function module | They cannot be replaced online. Turn OFF the power and replace. | | | | Only the I/O modules which have the same number of I/O points can be substituted. (When the number of I/O points is different, errors may occur.) | | 2. | Replaceable I/O module | <ol> <li>Only the modules specified with special register D9094 can be replaced.</li> <li>If module that is not specified is replaced, I/O misoperation of the devices connected with the module may occur because the module being replaced is still operating.</li> </ol> | | 3. | Keyswitch operation to the RUN and the STOP position | Set the keyswitch before replacement. Do not operate it until replacement is completed. If it is operated while replacement, the operation processing of the CPU is changed and I/O misoperation is caused. | | 4. | Operation of D9094 | <ol> <li>When the power to the CPU is turned ON, HFF is set, and when the power is turned<br/>OFF, the data memory is cleared.</li> <li>Data is overwritten by specifying the upper 2 digits of the head I/O number.</li> </ol> | | | | 2) As the setting range and the set value of D9094 is not checked in the CPU, set the I/O number correctly and replace. | | 5. | Prohibition of the test<br>operation with a<br>peripheral device | After turning special relay M9094 ON, do not execute the test operation with a peripheral device. If the test operation is executed, the content of the relay enters the image memory area, and when M9094 is turned OFF, it is output. | | 6. | Safe measures for replacement when the CPU is in the RUN state | <ol> <li>When the special relay M9094 is turned ON, the replacement module is stopped and<br/>when the relay is turned OFF, it is operated with data of the image memory area.<br/>Check the operation of the device after the replacement of the module.<br/>Turn M9094 OFF, and restart the operation.</li> </ol> | | <b>3</b> . | | 2) When a peripheral device which receives output is a display module such as the<br>A6FD, safe measures are not needed.<br>When a peripheral device is operated, provide interlock by use of the sequence<br>program or turn off the device. | | | · | <ol> <li>Turn OFF the power supply, and load the replacement module. The "UNIT VERIFY ERR" error message appears, if a module is loaded in the ON state. </li> </ol> | | 7 | In case a power failure<br>more than 20 ms<br>occurs (CPU is started | If I/O numbers are allocated, the I/O numbers are not changed. This can prevent wrong input and output. | | 7. | initially) while the<br>module is removed | 3) If I/O numbers are not allocated, when the CPU module is started initially, the vacant slot allocated automatically as vacant 16 points. (Refer to Section 6.4.1.) When the removed I/O module has more than 16 points, the I/O numbers will be changed, and wrong input and output may occur. Therefore load the module in the OFF state. | | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | #### 6.11 Device Comments The Name and application of a device can be assigned when programming. The device name and application are called comments. #### (1) Purpose of a comment If a comment is registered, it can be used as follows. - (a) A comment can be attached to a device and displayed when the program is monitored. The devices used in the program are displayed with name and application, so that it is convenient when corrections are to be made to the program. - (b) A comment can be attached to the sequence program and can be printed. Sequence program, device names and applications are printed at the same time, so that a program can be understood easily. - (c) The A6FD can display the comment data of the PC CPU by use of the sequence program. The A6FD can display error contents by use of the fault detection ladder with annunciators. #### (2) Number of comments and storage area Number of comments that can be stored in the PC CPU and the storage area are as shown in Table 6.2. Table 6.2 Number of Comment and Storage Area | | A2S(S1), A1SJ-S3<br>A1S(S1), A2C<br>A0J2H, A52G | A1<br>A1N | A1SJH, A1SH<br>A2SH(S1), A1FX | A2(S1), A3, A3H, A2A(S1), A3A, A73, A4U<br>A2N(S1), A3N, A3M, A2U(S1), A3U,<br>A2AS(S1/S30), A2USH-S1, Q02, Q02H,<br>Q06H | | | | |--------------------|-------------------------------------------------|---------------------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------|--|--|--| | Number of comments | 0 to 1600* | 0 to 128*<br>(F0 to F127) | 0 to 3648<br>(In unit of 84) | | | | | | Storage<br>area | Memory a | area in the CPU | module | User memory area in the memory cassette | | | | \*0 to 4032 comments can be created with a peripheral device. - (3) Devices to which a comment can be added - (a) Bit devices Input (X)/output (Y) Internal relay (M) Latch relay (L) Step relay (S) Link relay (B) Annunciator (F) Timer (T) Counter (C) - (b) Word devices Data register (D) Link register (W) File register (R) - (c) Others Pointer (P) Interrupt pointer (I) #### POINTS - Comments of the special relay and the special register are stored on a system floppy disk. User can not create comment for the special relay and the special register. - (2) The comment of input (X) and output (Y) can not be created with the same I/O number. - (3) All devices' (except the input and output devices) comments can be created with the same device number independently in the main program and the sub-program. - (4) Creating a comment - (a) A maximum of 15 characters can be used for the comment of 1 device. - (b) Alphanumeric characters (upper and a lower cases) and special symbols can be used to create a comment. | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ## 6.12 Watchdog Timer #### (1) Watchdog timer The watchdog timer is an internal timer of a programmable controller to detect the error of hardware and a sequence program. Default value is set for 200 ms. #### (2) Reset watchdog timer Before step 0 is executed (after the END processing is executed), a programmable controller resets the watchdog timer. When a programmable controller is operating normally and the END instruction is executed within the set value in a sequence program, the watchdog timer does not time out. When the END instruction has not been executed within the set value due to an error in the programmable controller or the scan time of the sequence program was too long, the watchdog timer times out. Fig. 6.21 Reset of the Watchdog Timer (3) Processing when the watchdog timer has timed out When scan time exceeds the set value of the watchdog timer, a watchdog timer error occurs, and the programmable controller operates as follows. - (a) Outputs of the programmable controller are all turned OFF. - (b) The RUN LED on the front of the CPU module goes out or flashes. - (c) M9008 is turned ON, and an error code is stored to D9008. ## REMARKS - 1) The setting time of the watchdog timer can be changed by the parameter setting with the peripheral device. - But when A3H, A3M, AnA, A2AS, AnU and QCPU-A are used, the setting time of the watchdog timer can not be changed. - Refer to Chapter 8 for details on the parameter setting. - 2) The watchdog timer can be reset with the WDT instruction in the sequence program. Scan time is not reset and is measured till the END instruction. | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | #### 6.13 Self-diagnosis Function The self-diagnosis is the function that diagnoses an error in the PC CPU itself. #### (1) Self-diagnosis timing The self-diagnosis is executed when the PC CPU is powered on or reset and when each instruction including the END instruction is executed. - (a) At power on or reset Executability of operation by the PC CPU is diagnosed. - (b) At the execution of each instruction\*<sup>1</sup> When the operation of each instruction of a sequence program cannot be executed normally, an error occurs. - (c) At the execution of the END instruction The diagnosis (watchdog, I/O module verify and fuse blown) that does not influence the operation of the sequence program is executed. #### (2) Operation mode at error detection There are two methods of operation mode, one of which stops the operation of the PC CPU and the other continues operation when an error is detected by the self-diagnosis. There is an option, by parameter setting, to stop the operation when an error occurs in the mode that continues the operation. (Refer to Section 6.13.1.) - (a) When an error which stops operation is detected by the self-diagnosis, operation is stopped and all outputs (Y) are turned OFF. - (b) When an error which continues operation is detected, only the part of the program where the error occurred is not executed, the next step and remaining program is executed. When an I/O module verify error is detected, operation is continued with the I/O addresses before the detection of the error. #### (3) Confirmation of error contents When an error is detected, M9008 (self-diagnosis error) is turned ON and an error code is stored to D9008 (self-diagnosis error). Confirm error contents, especially in the continue mode, to prevent the PC CPU or a machine system from misoperating. Error contents detected by the self-diagnosis are as shown in Table 6.3. Refer to the User's Manual of the PC CPU on the self-diagnosis contents that can be used in each PC CPU. ## REMARKS - (1) Two different states mentioned in the "state of the CPU" and the "state of RUN LED" columns in Table 6.3 can be switched by the setting with a peripheral device. - (2) The message on the LED display is as shown below when the error contents of the error is related with the CHK instruction in the Operation Check Error. (3) \*1: When an error is detected during a sequence program execution, an operation error flag (M9010, M9011) is set, and the error step of the instruction with which the error is detected is stored in an error step storage register (D9010, D9011). When an operation error (D9008: 50) occurs with an AnA, AnU or QCPU-A the error step number can be checked by monitoring D9010 and D9011. Table 6.3 Self-diagnosis is Contents and Error Messages | ı | Diagnosis Contents | Diagnosis Timing | State of the CPU | State of the<br>RUN LED | LED Message<br>(A3N, A3A, A3U, A4U) | | |------------------------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------------|-------------------------------------|--| | | Instruction code check | At the execution of each instruction | | | INSTRCT. CODE ERR | | | | Parameter setting check | At power on or reset<br>When {STOP/PAUSE} is change<br>into {RUN/STEP-RUN} | | | PARAMETER ERROR | | | or | Without the END instruction | When M9056 or M9057 is in the ON state When switching from {STOP/ PAUSE} to {RUN/STEP-RUN} | | | MISSING END INS. | | | Memory error | Instruction execution is disabled | At the execution of each instruction [CJ] [SCJ] [JMP] [CALL(P)] [FOR-NEXT] When switching from {STOP/PAUSE} to {RUN/STEP-RUN} | Stop | Flicker | CAN, T EXECUTE(P) | | | | Format (CHK instruction)<br>check | When switching from {STOP/<br>PAUSE} to {RUN/STOP-RUN} | | | CHK FORMAT ERR. | | | į | Instruction execution is disabled | At interruption occurrence When switching {STOP/PAUSE} to {RUN/STEP-RUN} | | | CAN, T EXECUTE (I) | | | | Without a memory cassette | At power on or reset | | | CASSETTE ERROR | | | | RAM check | At power on or reset<br>When M9084 is in the ON state<br>during STOP | | | RAM ERROR | | | orro | Operation ladder check | At power on reset | | | OPE. CIRCUIT ERR. | | | CPU error | Watchdog error monitor | At the execution of the END instruction | Stop | Flicker | WDT ERROR | | | | The END instruction is not executed | At the execution of the END instruction | | | END NOT EXECUTE | | | | Main CPU check | Usually | | | WDT ERROR | | | error | I/O module verify | At the execution of the END instruction (It is not checked when M9084 or M9094 is in the ON state.) | Stop | Flicker | UNIT VERIFY ERR. | | | e 0/I | Fuse blown | At the execution of the END instruction (It is not checked when M9084 or M9094 is in the ON state.) | Operation | ON | FUSE BREAK OFF. | | | | Control bus check | At the execution of the FROM and the TO instructions | | | CONTROL-BUS ERR. | | | <u>.</u> | Special-function module error | At the execution of the FROM and the TO instructions | | | SP. UNIT DOWN | | | odule erro | Link module error | At power on or reset When switching<br>{STOP/PAUSE} to {RUN/STEP-<br>RUN} | Stop | Flicker | LINK UNIT ERROR | | | Ě | I/O interrupt error | At interruption occurrence | | | I/O INT. ERROR | | | Special-function module erro | Special-function module allocation error | At power on or reset When switching {STOP/PAUSE} to {RUN/STEP-RUN} | | | SP. UNIT LAY. ERR. | | | Specia | Special-function module error | At the execution of the FROM and the TO instructions | Stop<br>Operation | Flicker | SP. UNIT ERROR | | | | Link parameter error | At power on or reset When switching {STOP/PAUSE} to {RUN/STEP-RUN} | Operation | ON | LINK PARA, ERROR | | | Battery | Battery voltage drop | Regularly (It is not checked when M9084 is in the ON state.) | Operation | ON | BATTERY ERROR | | | * Operat | ion check error | At the execution of each instruction | Stop | Flicker | OPERATION ERROR | | | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ## 6.13.1 Operation mode when an error occurs The PC CPU can be set to stop or continue operation when the following errors occur. Stopping or continuing the operation is set with parameters. - (a) Operation error - (b) I/O module verify error - (c) Fuse blown - (d) Special-function module error - (1) Default value of the operation mode when an error occurs The default value (initial value) of the operation mode and the state of the PC CPU when an error occurs are as shown in Table 6.4. Table 6.4 Operation Mode at Time of Error | | | CPU Status | | | | | | | | |----------------------------|-----------------------------------------------------------------------------------------------------------|-------------------|-----------------------|---------------------------------------|-------------------------|---------------------------------|-------------------------------------|--|--| | | | Operation RUN LED | | | Special | Special | Self- | | | | | Error | Default<br>Value | NO "ERROR"<br>LED CPU | "ERROR" on<br>the LED of<br>other CPU | Relay<br>Switched<br>On | Register<br>for Storing<br>Data | check<br>Error<br>Number<br>(D9008) | | | | Operation<br>error | 1 | | Flicker | On | M9010<br>M9011 | D9010<br>D9011 | 50 | | | | I/O module<br>verify error | Any I/O module status<br>detected is different from that<br>at power on (e.g. 32-point<br>module change). | Stop | Flicker | A3: Off<br>A3N, A3H:<br>Flicker | M9002 | D9002 | 31 | | | | Fuse blow<br>error | An output module fuse has blown. | Continue | Flicker | On | M9000 | D9000 | 32 | | | | Function<br>module error | FROM/TO Instruction has been executed to the slot without any special function module. | Stop | Flicker | A3: Off<br>A3N, A3H:<br>Flicker | M9010<br>M9011 | D9010<br>D9011 | 46 | | | | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ## 6.14 Setting of the Output (Y) State when Switching from STOP to RUN When the operation state is switched from RUN to STOP, outputs (Y) in the RUN state are stored to the PC CPU. Whether re-outputting outputs (Y) when the operation state is switched from STOP to RUN or outputting them after executing the operation can be set with the parameter. - (1) Re-output ...... The operation of a sequence program is executed after outputting the outputs (Y) state which were stored before the operation state was switched to STOP. - (2) Output after executing... After clearing all outputs (Y) and executing the operation the operation of a sequence program, outputs (Y) are output. Fig. 6.22 Processing when the Operation STOP State is Switched from RUN | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ## 6.15 Registration of the Entry Code The entry code is used to prohibit programs and comments in the PC CPU from being read or rewritten with a peripheral device. - (1) Read/write from the PC CPU to which the entry code is registered. In case the key word is registered, parameters, main/subprograms and comments can not be read or written from the PC CPU to a peripheral device unless the entry code is entered to the peripheral device. - (2) Registration and cancellation of the entry code A maximum of 6 digits in hexadecimal (0 to 9, A to F) can be used to set the entry code. The entry code is registered or canceled with parameter setting. | Applicable<br>CPU | All Types of CPUs | |-------------------|-------------------| | Remark | | ## 6.16 Registration of the Print Title The print title is the comment of the system name and the program name used with the sequence program. ## (1) Purpose If the print title is registered, it can be printed. The printed print title can be used for the cover of a sequence program. ## (2) Setting the print title - (a) A maximum of 128 characters (32 characters x 4 lines) can be used to make the print title. - (b) The print title is set by parameters with a peripheral device. | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|----------------------------------------------------------|-----|------|------------|-----|-----|-------------|--------|-------|-------------|-----| | 010 | △*1 | △*1 | х | 0 | 0 | Δ*1 | △*1 | х | х | х | 0 | | Remark | *1 : Only the A3, A3N, A3A, A3U, and A4U are applicable. | | | | | | | | | | | # 6.17 Display Mode Setting of Annunciators (In case of the CPU module with the LED indicator of 16 characters) As for the PC CPU that has the LED indicator of 16 characters on the front of the CPU module, the LED indicator displays the annunciator number stored in D9009 when the annunciator (F) is turned ON. At this time, in case a comment has been added to the annunciator, the following setting is enabled with a parameter. (In case a comment has not been added to the annunciator, the setting with comment is disabled.) (1) Without comment : Only the annunciator number is displayed on the LED indicator. Fig. 6.23 Without Comment (2) With comment: An annunciator number and a comment are displayed alternately on the LED indicator every 2 s. Fig. 6.24 With Comment | Applicable<br>CPU | AnS<br>AnN<br>AnSH | An | A1FX | A3H<br>A3M | A3V | AnA | AnU<br>A2AS | QCPU-A | A0J2H | A2C<br>A52G | A73 | |-------------------|--------------------|----------|------|------------|-----|-----|-------------|--------|-------|-----------------|-----| | 0.0 | △*1 | x | 0 | x | × | 0 | О | 0 | 0 | 0 | 0 | | Remark | *1 : AnN i | s unusab | ile. | | • | | | | | · · · · · · · · | | #### 6.18 ERROR LED Indication Priority Setting The following functions are available by changing the ERROR LED indication priority setting: - (a) Unnecessary error indications among those given in Table 6.5 can be avoided. - For example, it is possible to set the ERR. LED not to be lit even when an annunciator is turned ON. - This feature is not available with the errors that stop the sequence program operation. - (b) It is possible to reset an annunciator by using a LEDR instruction. By setting the annunciator to the first priority, it is possible to reset the annunciator (F) by using a LEDR instruction regardless of other error contents. - (The LEDR instruction cannot be used for resetting the annunciator (F) when an error whose ERR. LED indication priority is higher than the annunciator occurs.) - (1) Default priority settings for the ERR. LED indication are as given in Table 6.5. **Table 6.5 Error Indication Priority** | Priority | Error Contents | Error Item<br>No. | ERROR LED State at an<br>Error Occurrence | | |----------|---------------------------------------------------------------------------------------------------|-------------------|-------------------------------------------|--| | High | Error with which the operation stops unconditionally | _ | Lit | | | | I/O module verify Fuse blown | 1 | | | | | Special module error Operation error Link parameter error SFC parameter error SFC operation error | 2 | | | | | CHK instruction execution | 3 | Unlit | | | Low | Annunciator (F) on | 4 | Flicker | | | | Battery error | 6 | Lit | | (2) Changing the priority Change the ERR. LED indication priority by designating an error item number given in Table 6.5 with D9038 and D9039 (LED indication priority storage registers). The priority order and default settings (settings by the PC CPU initial processing) to be set with D9038 and D9039 are as given in Table 6.25. Fig. 6.25 Priority Settings with D9038 and D9039 # 7. METHOD OF DATA COMMUNICATION WITH SPECIAL-FUNCTION MODULE **MELSEC-A** | Applicable<br>CPU | All Types of CPUs | | | | | |-------------------|-------------------|--|--|--|--| | Remark | | | | | | ## 7. METHOD OF DATA COMMUNICATION WITH SPECIAL-FUNCTION MODULE The following describes the method of reading data to the PC CPU from a special-function module and writing data to a special-function module from the PC CPU. #### (1) Special-function modules Special-function modules are used to deal with the analog data and high-speed pulses in the PC CPU which can not be processed only with the I/O modules. For example, analog data is converted to digital data through an analogdigital converter module of the special-function module to be used with the PC CPU. The special-function modules have memory (buffer memory) in which data received from the outside and data output to the outside is stored. #### (2) Read/write of data from the PC CPU Read and write data with the FROM/TO instruction. When the FROM/TO instruction is executed, data stored in the buffer memory of the special-function module is read, or data is written to the buffer memory when the FROM/TO instruction is executed. Fig. 7.1 Data Communication with A Special-Function Module #### REMARKS - (1) Refer to the ACPU Programming Manual (Common Instructions) (IB-66250) for details on the FROM/TO instruction. - (2) Refer to the manual of the special-function module for details on the buffer memory of the special-function module. #### 8. PARAMETER SETTING - (1) Parameters are used to specify the allocation of the user memory area in the CPU module and the ranges of use of various functions. Parameter data is stored in the head 3 k bytes of the user memory area. - (2) The default value has been arranged for parameter data as shown in Table 8.1. Parameter data utilize the default values. - (3) Parameter data can be changed within the setting range shown in Table 8.1 according to the purpose. Execute parameter setting with a peripheral device. Refer to the Operating Manual of each peripheral device for the operation of parameter setting. ## REMARKS (1) The conversion from the setting unit to the number of bytes used with the main sequence program and the subsequence program is as shown in Table 8.1. | Item | Setting Unit | Number of Bytes | | |--------------------------------|--------------|-----------------|--| | Main sequence program capacity | 1 k step | 2 k bytes | | | Subsequence program capacity | i k step | | | | File register capacity | 1 k points | 2 k bytes | | | Comment capacity | 64 points | 1 k bytes | | | Sampling trace memory capacity | 128 times | 1 k bytes | | (2) As for the comment capacity, additional 1 k bytes are included in the displayed value, because 1 k bytes are added automatically when the comment capacity is set with a peripheral device. Table 8.1 List of Parameter Setting Ranges | | | | | | | | | Setting | Range | | | | |---------------------------|----------------------------|--------------|---------|---------------------|----------------------------------------|--------------------------|-----------------------|--------------------------------------------------------|----------------------------------|--------------------------------------|---|--| | | ľ | tem | | | Default<br>Value | Setting<br>Unit | A1<br>A1N | A1S<br>A1S-S1<br>A1SJ-S3<br>A1SH<br>A1SJH(S8)<br>A0J2H | A2<br>A2N<br>A2S<br>A2SH<br>A1FX | A2-S1<br>A2N-S1<br>A2S-S1<br>A2SH-S1 | | | | | | | ence pr | | 6 k steps | 1 k step | 1 to 6 k<br>steps | 1 to 8 k<br>steps | 1 1 to 1/ K etabe | | | | | | | | | | Subsequence program<br>memory capacity | | | 1 k step | | | _ | | | | | File re | egister | capacity | _ | 1 k point | _ | 1 | to 4 k po | ints | | | | | | Comment ca | | pacity | None | 128 points/<br>64 points | 128 points<br>(fixed) | 0 | 0 to 4032 points | | | | | | Allocation of user | Status latch | | Memory<br>capacity | | | | 0/8 to 16 k bytes | | | | | | | memory<br>area | | | Data<br>memory | None | | <u> </u> | N | lone/Provi | ded | | | | Common<br>parame-<br>ters | | : | | File<br>register | | | | N | None/Provided | | | | | ters | | | | Memory<br>capacity | | 128 times | _ | 0/8 k bytes | | | | | | | | Samp | ling | Device<br>setting | _ | | | Device number | | | | | | | | trace | | Execution condition | | | | Every scan<br>Every hour | | | | | | | | ver Timer | | Sampling count | | | | 0 | to 1024 ti | mes | | | | | | | | | None | 2 k bytes | 0 to 10 k<br>bytes | 0 to 14 k<br>bytes | 0 to 2 | 6 k bytes | | | | | | | | elay (B) | | | | B0 to | 3FF | | | | | | Latch (pow | | | (T) | L1000 to | | | T0 to | 255 | | | | | | failure bac<br>range setti | | Count | er (C) | 2047 only | 1 point | | C0 to | 255 | | | | | | | | Data r | egister (D) | | | | D0 to | 1023 | | | | | | | | Link re | egister (W) | | | | W0 to | 3FF | | | | o : Setting possible x : Setting impossible | | | | | | | | 111 | | | | Peripher<br>Usable fo | al Device<br>r Setting * | |---|-----------|------------|------------------|----------------------|--------------------|-----------------------------------------------------|--------------------|--------------------------------------------------------|--------------------|--------------------|-----------------------|--------------------------| | | A3<br>A3N | A73 | A3H<br>A3M | A2C<br>A52G | A2A<br>A2U<br>A2AS | A2A-S1<br>A2U-S1<br>A2AS-S1<br>A2AS-S30<br>A2USH-S1 | A3A<br>A3U | A4U | Q02<br>Q02H | Ооен | PU | Other<br>than PU | | - | 1 to | 30 k ste | eps | 1 to 8 k<br>steps | 1 to | 14 k steps | 1 to | 30 k steps | 1 to 28 k<br>steps | 1 to 30 k<br>steps | 0 | 0 | | | 1 to | o 30 k ste | eps | | | _ | 1 to 30<br>k steps | 1 to 30 k steps<br>(up to 3<br>programs can<br>be set) | | 1 to 30 k<br>steps | 0 | o | | | 1 t | o 8 k poi | nts | 1 to 4 k<br>points | 1 to | 8 k points | | 0 to 8 k | points | | 0 | 0 | | | | | | | 0 | to 4032 poi | nts | | | | x | 0 | | | 0/8 k | to 24 k l | bytes | 0/8 to 16<br>k bytes | | | | | | | | | | | | None/F | Provided | | | | | | | | x | 0 | | | Noi | ne/Provid | ded | None/<br>Provided | | | | | | | | | | | | 0/8 k | bytes | | | | | | | | | | | | | Device | number | | | | | | | | x | 0 | | | | | y scan<br>y hour | | | , i | | _ | | | * | | | | | 0 to 10 | 24 times | 1 | | | | | | | | | | | 0 to | 58 k by | tes | 0 to 14 k<br>bytes | 0 to 2 | 0 to 26 k bytes 0 to 58 k bytes | | | | | | 0 | | • | | | | | AnA | AnA: B0 to BFFF, AnU: B0 to B1FFF B0 to B1FFF | | | | | | | | | | | | | | | | 55, T256 to T20 | | | o | | | | | | | | ΔnΔ | | | 55, C256 to C10 | | D8101 | | | | | | | - | | | AnA : D0 to D6143, AnU: D0 to D8191 | | | | | | | <sup>\*: &</sup>quot;PU" and "Other than PU" in the Peripheral Devices Usable for Setting column correspond to the following devices: PU: A8PUE Other than PU: Devices which are not using GPP function software package and which can set the CPU type by PC type setting. Table 8.1 List of Parameter Setting Ranges (continued) | | | | | | | Settin | g Range | | | |---------------------------|---------------------------------------------------|---------------------------------------|-------------------------------------------|-----------------|--------------------------------------------------------------------------------------|--------------------------------------------------------|----------------------------------|--------------------------------------|--| | | Item | | Default Value | Setting<br>Unit | A1<br>A1N | A1S<br>A1S-S1<br>A1SJ-S3<br>A1SH<br>A1SJH(S8)<br>A0J2H | A2<br>A2N<br>A2S<br>A2SH<br>A1FX | A2-S1<br>A2N-S1<br>A2S-S1<br>A2SH-S1 | | | | | Number of link stations | | | 1 to 64 | | | | | | | Link range | Input (X) | None | 16<br>points | X0 to FF | X0 to FF<br>A0J2H,<br>A1S-S1:<br>X0 to 1FF | X0 to 1FF | X0 to 3FF | | | | setting | Output (Y) | | , | Y0 to FF | Y0 to FF<br>A0J2H,<br>A1S-S1:<br>Y0 to 1FF | Y0 to 1FF | Y0 to 3FF | | | | | Link relay (B) | | | | | B0 t | o 3FF | | | Common<br>parame-<br>ters | | Link register<br>(W) | | 1<br>point | W0 to 3FF | | | | | | | | (M), latch relay<br>relay (S) setting | M0 to 999<br>L1000 to 2047 | 1<br>point | M/L/S 0 to 2047<br>M, L, and S are continuous numbers | | | | | | | Watchdog tim | er setting | 200 ms | 10 ms | 10 ms to 2000 ms | | | | | | | Timer T0 to T255 | | 100 ms : T0 to 199<br>10 ms : T200 to 255 | 8<br>points | 256 points for 100 ms, 10 ms, and retentive timers Timers must be continuous numbers | | | | | | | Counter counter setting Interrupt counter setting | | None | 8<br>points | 256 points for counters and interrupt counters Counters must be continuous numbers. | | | | | o : Setting possible x : Setting impossible | | | | | , | | | | | | Peripher<br>Usable fo | al Device<br>r Setting * | |-----------|---------------------------------------------------------------|-----------------|-------------------------|-------------------------|-----------------------------------------------------|------------|------|-------------|------|-----------------------|--------------------------| | A3<br>A3N | A73 | A3H<br>A3M | A2C<br>A52G | A2A<br>A2U<br>A2AS | A2A-S1<br>A2U-S1<br>A2AS-S1<br>A2AS-S30<br>A2USH-S1 | A3A<br>A3U | A4U | Q02<br>Q02H | Q06H | PU | Other<br>than PU | | | | | | | | | | | | | | | | X0 to 7 | FF | X0 to 1FF | X0 to 1FF | X0 to 3FF | X0 to 7FF | | X0 to FFF | : | | | | | Y0 to 7 | FF | Y0 to 1FF | Y0 to 1FF | Y0 to 3FF | Y0 to 7FF | | Y0 to FFF | | X | 0 | | | | | L | | | B0 to 1 | FFF | | | | | | | | | | | | W0 to | 1FFF | | | | | | | | | | M/L/S 0 to<br>M, L, and | 8191<br>S are conti | nuous num | bers | | | 0 | 0 | | | | 200 ms<br>fixed | 100 ms<br>to<br>2000 ms | 200 ms fix | (ed | | | | | 0 | 0 | | | 7 | | | | | | | | | 0 | 0 | | | Interrupt count counters (C224 to 255) setting (C225) setting | | | | | 0 | o | | | | | <sup>\*: &</sup>quot;PU" and "Other than PU" in the Peripheral Devices Usable for Setting column correspond to the following devices: PU : A8PUE Other than PU: Devices which are not using GPP function software package and which can set the CPU type by PC type setting. Table 8.1 List of Parameter Setting Ranges (continued) | | | | | | | Settin | g Range | | | |--------------------------------|-------------------------------|----------------------------------------------|----------------------------------------------|-----------------|----------------------------------------------------------|--------------------------------------------------------|----------------------------------|--------------------------------------|--| | | Item | | Default Value | Setting<br>Unit | A1<br>A1N | A1S<br>A1S-S1<br>A1SJ-S3<br>A1SH<br>A1SJH(S8)<br>A0J2H | A2<br>A2N<br>A2S<br>A2SH<br>A1FX | A2-S1<br>A2N-S1<br>A2S-S1<br>A2SH-S1 | | | | | Input (X)<br>module | | | | | | | | | | I/O number<br>allocation | Output (Y)<br>module | None | 16 points | 0 to 64 points | | | | | | | anocanon | Special func-<br>tion module | | · | | | · | | | | | | Vacant slot | | | | | | | | | | Remote RUN/<br>setting | PAUSE contact | None | 1 point | X0 to FF | X0 to FF<br>A0J2H,<br>A1S-S1 :<br>X0 to 1FF | X0 to 1FF | X0 to 3FF | | | | Fuse blown | | Continue | | | | | | | | Common<br>parame- | Operation I/O verify error | | Stop | | | | | | | | ters | mode at Operation error error | | Continue | _ | Stop/Continue | | | | | | | occurrence | Special<br>function<br>module check<br>error | Stop | | | | | | | | | Annunciator d | lisplay mode | _ | _ | _ | | | | | | | STOP → RUN | l display mode | Operation state<br>before STOP is<br>output. | _ | Output of state before STOP or after operation execution | | | | | | | Print title regi | stration | None | _ | 128 chara | cters using | ali keys on N | MELSAP | | | | Entry code re | gistration | None | _ | Hexadecir | nal (0 to 9, / | A to F) Max | . 6 digits | | | | | Total number of slave stations | | | | | | | | | | | Protocol | | · | | | | | | | Parameter | Remote Head station number | | | _ | | | _ | | | | for A2C | setting | Mode setting | | | | | | | | | Parameter<br>for A3H<br>ad A3M | I/O control se | tting | _ | _ | | | | | | $o: Setting\ possible \quad x: Setting\ impossible$ | | | | | | | | | | | Peripher<br>Usable fo | al Device<br>r Setting * | |-----------------------------|-----------------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------------------------------------------|--------------------------------------------|--------------------------|-------------|------|-----------------------|--------------------------| | A3<br>A3N | A73 | A3H<br>A3M | A2C<br>A52G | A2A<br>A2U<br>A2AS | A2A-S1<br>A2U-S1<br>A2AS-S1<br>A2AS-S30<br>A2USH-S1 | A3A<br>A3U | A4U | Q02<br>Q02H | Q06H | PU | Other<br>than PU | | | | | _ | | (<br>Module | ) to 64 poil<br>type can b | nts<br>e entere | d. | | x | o | | x | 0 to 7FF | | X0 to 1FF | X0 to 1FF | X0 to 3FF | X0 to 7FF | × | (0 to FFI | = | x | 0 | | | | | | | • | | | | | x | o | | Alterna<br>n<br>F numbe | te displa<br>umber /<br>r with co | | _ | | <del></del> | Alternate of F numb<br>number w<br>comment | display<br>er / F<br>ith | _ | _ | x | o | | | | | | | | | | | | x | 0 | | , | | | | | | | | | | х | 0 | | | | | | ı | | | | | | 0 | 0 | | | | | 1 to 64 MINI standard / No protocol 1 to 61 0: Automatic online return enabled 1: Automatic online return disabled 2: Transmission stop at online fault | | | _ | | | | x | ο | | Direct/rei<br>input<br>inde | fresh set<br>t and out<br>ependen | put | | | | | | | | ۰ | 0 | <sup>\*: &</sup>quot;PU" and "Other than PU" in the Peripheral Devices Usable for Setting column correspond to the following devices: PU : A8PUE Other than PU : Devices which are not using GPP function software package and which can set the CPU type by PC type setting. Table 8.1 List of Parameter Setting Ranges (continued) | | | | - | | | Setting | Range | | |---------------------|---------------------------|----------------------------------------------|---------------|-----------------|-----------|--------------------------------------------------------|----------------------------------|--------------------------------------| | | Item | | Default Value | Setting<br>Unit | A1<br>A1N | A1S<br>A1S-S1<br>A1SJ-S3<br>A1SH<br>A1SJH(S8)<br>A0J2H | A2<br>A2N<br>A2S<br>A2SH<br>A1FX | A2-S1<br>A2N-S1<br>A2S-S1<br>A2SH-S1 | | · | Extension timer | T256 to T2047 | _ | _ | | | | | | | | Number of points in use | | | | | | | | | | Set value device | | - | | | | | | | Extension counter | Number of points in use | _ | | | _ | _ | | | | oo anton | Set value device | | | | | | | | | MELSECNET | Number of link stations | _ | | | | | | | | -II link<br>range setting | Link relay | | _ | | | | | | | | Link register | | | | | | | | Parame-<br>ters for | | Number of modules supported | | | | | | | | the AnA, | | Head I/O number | | | | | | | | and AnU | | Type registration | | | | | | | | | | Received data | | | | | | | | | MELOFONET | Send data | | | | | | | | | MELSECNET/ | Retry count | | | | | | | | | MELSECNET/<br>MINI-S3 | FROM/TO<br>response<br>designation | _ | | | _ | <del>-</del> | | | | | 1222211217 | | | | | | | | | | Faulty station detection | | | | | | | | | | Error No. | | | | | | | | | | Total number of remote stations | | | | | | | | | | Transmission condition setting in line fault | | | | | | | \_ \_ o : Setting possible $\, x : Setting \, impossible \,$ | , | | | | | | | | | | Periphei<br>Usable fo | ral Device<br>or Setting * | |-----------|-----|------------|-------------|--------------------|------------------------------------------------------------------------------------------|-----------------------------|-------------------------|--------------------------------|------------------------------------------------------------------|-----------------------|----------------------------| | A3<br>A3N | A73 | A3H<br>A3M | A2C<br>A52G | A2A<br>A2U<br>A2AS | A2A-S1<br>A2U-S1<br>A2AS-S1<br>A2AS-S30<br>A2USH-S1 | A3A<br>A3U | A4U | Q02<br>Q02H | Q06H | PU | Other<br>than PU | | | | | • | | points for 100<br>retentive<br>s must be con | timers | | ms, 10 ms<br>timer a<br>Timers | nts for 100<br>s, retentive<br>nd 1 ms.<br>must be<br>is numbers | 0 | 0 | | | | | | | | 0 to 2048 | points | | | | | | | | | | D, W | V, and R wher | the numb | er of poin | ts exceeds | 256 | | | | | | | | | | 0 to 1024 | points | | | o | 0 | | | | | *** | D, W | /, and R wher | the numb | er of poin | ts exceeds | 256 | | 1 | | | | | | | | 0 to 64 st | ations | | | | | | | | | | | | B0 to B | FFF | | | × | 0 | | <br> | | | | | | W0 to W | /FFF | | | | | | | | | | | | 0 to 8 mo | dules | | | | | | | | | | o to 1F0 | 0 to 3F0 | 0 to 7F0 | | 0 to FF0 | | | | | | | | | | | MINI, MI | NI-S3 | | | | | | | | | | х | , M, L, B, T, 0<br>(Bit device | C, D, W, ar<br>es are set i | nd R are r<br>n 16-poin | ot provide<br>t units.) | d. | | | | | | | | Y | ', M, L, B, T, (<br>(Bit device | C, D, W, ar<br>es are set i | nd R are r<br>n 16-poin | ot provide<br>t units.) | d. | | | | | | | | | | 0 to 32 t | imes | | | | | | | | | | | Priority to link/CPU | | | | | | 0 | | | | | | | Hold/Clear | | | | | | | | | | | | | M, L, B, T, C, D, W, and R are not provided.<br>(Bit devices are set in 16-point units.) | | | | | | | | | | | | | T, C, D, W, R | | | | | | | | | | | | | 0 to 64 stations | | | | | | | | | | | | | Test messag | | | | | | | <sup>\*: &</sup>quot;PU" and "Other than PU" in the Peripheral Devices Usable for Setting column correspond to the following devices: PU : A8PUE Other than PU : Devices which are not using GPP function software package and which can set the CPU type by PC type setting. #### 9. CONFIGURATION OF USER MEMORY AREA This chapter gives the configuration of the user memory area of the PC CPU. (1) The following programs can be stored in the sequence program area of the PC CPU: Fig. 9.1 Configuration of the Sequence Program Area - (2) The user memory area can be used for a sequence program area, comment area, file register area, etc. by parameter setting with peripheral device. - (a) When parameter setting is not done A parameter area, T/C set value area, sequence program area of 6 k steps are allocated beginning with the head of the user memory area. - 1) Parameter area The area where the parameters given in Table 8.1 are stored. - 2) T/C set value area The area where the timer and and counter set values used with the sequence program are stored. - 3) Sequence program area The area where the main routine programs, subroutine programs, and interrupt programs are stored. (Refer to Section 5.1 for the details of the main routine programs, subroutine programs, and interrupt programs.) - (b) When parameter setting is done - 1) A parameter area, T/C set value area, sequence program area, and sub-program area are allocated beginning with the head of the user memory area. - 2) Comments and file registers set with parameters given in Table 8.1 are allocated beginning with the end of the user memory area. #### 9.1 A1CPU and A1NCPU Configuration of the user memory area of the A1 and A1NCPUs is the same regardless of the memory type (IC-RAM, EPROM, E<sup>2</sup>PROM) installed. For the operation using a ROM, parameters, T/C set values, sequence program, and microcomputer program in the user memory area can be stored to the ROM. (1) When parameter setting is not done The user memory area is set with defaults and has a configuration as shown in Fig. 9.2. Fig. 9.2 Cofiguration of the User Memory Area - (2) When parameter setting is done - (a) The sequence program area can be changed to the microcomputer program area by parameter setting. (User-created microcomputer programs and utility programs can be stored in the microcomputer program area.) Flg. 9.3 Configuration of the User Memory Area and Comment Area #### POINTS - (1) Comments are stored in the comment area (internal memory) of the A1 or A1N. The 16 k byte user memory area shown in Fig. 9.3 will not be reduced even when a comment area is set by parameter setting. - (2) Comments, which are created by using a peripheral device, of 124 points from F0 to F123 can be stored in the comment area of the A1 or A1N. ## 9.2 A2CPU(S1) and A2NCPU(S1) Configuration of the user memory area of the A2(S1) and A2N(S1)CPUs varies according to the memory cassette type. However, when parameter setting is not done, the user memory area is set with defaults regardless of the memory type and 16 k bytes are allocated. (1) When parameter setting is not done Configuration of the user memory area when parameter setting is not done is as shown in Fig. 9.4. Fig. 9.4 Configuration of the User Memory Area (2) When parameter setting is done A maximum of 144 k bytes of the user memory area can be used by allocating it as shown in Fig. 9.5. An area exceeding 144 k bytes can be used as extension file registers by using the SW0GHP-UTLP-FN1 utility program. Fig. 9.5 Configuration of the User Memory Area \_ \_ #### 9.3 A0J2HCPU, A2CCPU, A52GCPU, A1SCPU, and A1SJCPU-S3 The A0J2HCPU, A2CCPU, A52GCPU, A1SCPU and A1SJCPU-S3 have a 32 k byte user memory area. (1) When parameter setting is not done Configuration of the user memory area when parameter setting is not done is as shown in Fig. 9.6. Fig. 9.6 Configuration of the User Memory Area (2) When parameter setting is done A maximum of 32 k bytes of the memory area can be used by allocating it as shown in Fig. 9.7. Fig. 9.7 Configuration of the User Memory Area #### 9.4 A2SCPU(S1) The A2S and the A2S-S1 have user memory area of 64 k bytes and 192 k bytes, respectively. (1) When parameter setting is not changed Configuration of the user memory area when parameter setting is not changed is as shown in Fig. 9.8. Fig. 9.8 Configuration of the User Memory Area (2) When parameter setting is changed By changing the parameter setting, it is possible to use the user memory area (64 k bytes, 192 k bytes) by allocating it as shown in Fig. 9.9. Fig. 9.9 Configuration of the User Memory Area ^ - #### 9.5 A1SHCPU(S8), A1SJHCPU and A2HCPU(S1) The A1SH, A1SJH and A2SH, and the A2SH-S1 have user memory area of 64 k bytes and 192 k bytes, respectively. (1) When parameter setting is not changed Configuration of the user memory area when parameter setting is not changed is as shown in Fig. 9.10. Fig. 9.10 Configuration of the User Memory Area (2) When parameter setting is changed By changing the parameter setting, it is possible to use the user memory area (64 k bytes, 192 k bytes) by allocating it as shown in Fig. 9.11. Fig. 9.11 Configuration of the User Memory Area #### 9.6 A1FXCPU The A1FX has user memory area of 64 k bytes. (1) When parameter setting is not changed Configuration of the user memory area when parameter setting is not changed is as shown in Fig. 9.12. Fig. 9.12 Configuration of the User Memory Area (2) When parameter setting is changed By changing the parameter setting, it is possible to use the user memory area (64 k bytes) by allocating it as shown in Fig. 9.13. Fig. 9.13 Configuration of the User Memory Area #### 9.7 A2ASCPU, A2ASCPU-S1, A2ASCPU-S30, and A2USHCPU-S1 The A2AS, and the A2AS-S1, A2AS-S30 and A2USH-S1 have user memory area of 64 k bytes and 256 k bytes, respectively. (1) When parameter setting is not changed Configuration of the user memory area when parameter setting is not changed is as shown in Fig. 9.14. Fig. 9.14 Configuration of the User Memory Area (2) When parameter setting is changed By changing the parameter setting, it is possible to use the user memory area (64 k bytes, 256 k bytes) by allocating it as shown in Fig. 9.15. Fig. 9.15 Configuration of the User Memory Area Λ ( #### 9.8 A3CPU, A3NCPU, A3VCPU, A73CPU, and A3HCPU Configuration of the user memory area of the A3CPU, A3NCPU, A3VCPU, A73CPU, and A3HCPU varies according to the memory cassette type. However, when parameter setting is not done, the user memory area is set with defaults regardless of the memory type and 16 k bytes are allocated. (1) When parameter setting is not done Configuration of the user memory area when parameter setting is not done is as shown in Fig. 9.16. Fig. 9.16 Configuration of the User Memory Area (2) When parameter setting is done A maximum of 144 k bytes of the user memory area can be used by allocating it as shown in Fig. 9.17. Unused areas can be used as extension file registers by using the SW0GHP-UTLP-FN1 utility program. Fig. 9.17 Configuration of the User Memory Area #### 9.9 A3MCPU Configuration of the user memory area of the A3MCPU varies according to the memory cassette type. However, when parameter setting is not done, the user memory area is set with defaults regardless of the memory type and 16 k bytes are allocated. (1) When parameter setting is not done Configuration of the user memory area when parameter setting is not done is as shown in Fig. 9.18. Fig. 9.18 Configuration of the User Memory Area (2) When parameter setting is done A maximum of 144 k bytes of the user memory area be used by allocating it as shown in Fig. 9.19. Areas exceeding 144 k bytes can be used as extension file registers or BASIC program areas. Fig. 9.19 Configuration of the User Memory Area . . #### 9.10 A2ACPU(S1) and A3ACPU Configuration of the user memory area of the A2A(S1) and A3ACPUs varies according to the memory cassette type. However, when parameter setting is not done, the user memory area is set with defaults regardless of the memory type and 16 k bytes are allocated. (1) When parameter setting is not done Configuration of the user memory area when parameter setting is not done is as shown in Fig. 9.20. Fig. 9.20 Configuration of the User Memory Area (2) When parameter setting is done A maximum of 448 k bytes of the user memory area can be used by allocating it as shown in Fig. 9.21. Fig. 9.21 Configuration of the User Memory Area . .. #### 9.11 A2UCPU(S1) and A3UCPU Configuration of the user memory area of the A2U(S1) and A3UCPUs varies according to the memory cassette type. However, when parameter setting is not done, the user memory area is set with defaults regardless of the memory type and 16 k bytes are allocated. (1) When parameter setting is not done Configuration of the user memory area when parameter setting is not done is as shown in Fig. 9.22. Fig. 9.22 Configuration of the User Memory Area (2) When parameter setting is done A maximum of 448 k bytes of the user memory area can be used by allocating it as shown in Fig. 9.23. Fig. 9.23 Configuration of the User Memory Area #### 9.12 A4UCPU Configuration of the user memory area of the A4UCPU varies according to the memory cassette type. However, when parameter setting is not done, the user memory area is set with defaults regardless of the memory type and 16 k bytes are allocated. Sub-programs 2 and 3 can be set by using an A3AMCA-96 or A4UMCA-128 memory cassette with the A4U. Sub-programs 2 and 3 cannot be set by using a memory cassette other than those mentioned above. (1) When parameter setting is not done Configuration of the user memory area when parameter setting is not done is as shown in Fig. 9.24. Fig. 9.24 Configuration of the User Memory Area (2) When parameter setting is done (When sub-programs 2 and 3 are not used)A maximum of 880 k bytes of the user memory area can be used by A maximum of 880 k bytes of the user memory area can be allocating it as shown in Fig. 9.25. Fig. 9.25 Configuration of the User Memory Area . .. (3) When parameter setting is done (When sub-programs 2 and 3 are set with an A3AMCA-96 memory cassette) When parameter setting is done with an A3AMCA-96, a maximum of 624 k bytes of the user memory area can be used by allocating it as shown in Fig. 9.26. Sub-programs 2 and 3 are allocated beginning with the last block of the extension file registers. Fig. 9.26 Configuration of the User Memory Area (4) When parameter setting is done (When sub-programs 2 and 3 are set with an A4UMCA-128 memory cassette) When parameter setting is done with an A4UMCA-128, a maximum of 880 k bytes of the user memory area can be used by allocating it as shown in Fig. 9.27. Sub-programs 2 and 3 are allocated by a RAM operation beginning with the last block (block No. 64) of the extension file registers. To perform a ROM operation, the main programs and sub-programs (1 to 3) whose capacity has been set need to be stored in the ROM. (EPROM: 256 k ROM is used) Fig. 9.27 Configuration of the User Memory Area #### 9.13 Q02CPU-A, Q02HCPU-A and Q06HCPU-A The Q02CPU-A, Q02HCPU-A and Q06HCPU-A have user memory area of 144 k bytes respectively. (1) When parameter setting is not done Configuration of the user memory area when parameter setting is not done is as shown in Fig. 9.28. Fig. 9.28 Configuration of the User Memory Area (2) When parameter setting is done By changing the parameter setting, it is possible to use the user memory area (144 k bytes) by allocating it as shown in Fig. 9.29. Fig. 9.29 Configuration of the User Memory Area 10 # 10. CONFIGURATION OF USER MEMORY AREA (WHEN AN SFC PROGRAM IS USED) **MELSEC-A** # 10. CONFIGURATION OF USER MEMORY AREA (WHEN AN SFC PROGRAM IS USED) When an SFC program is used, an SFC program memory area is added to the user memory area mentioned in Chapter 9. Memory areas other than the SFC program area conform to the memory area configuration mentioned in Chapter 9. #### 10.1 SFC Program Memory Area The SFC program memory area is classified into SFC program area, SFC program work area, and step trace area. Refer to the MELSAP-II Programming Manual (IB-66361) for the details of the SFC program memory area. ## (1) SFC program area The SFC programs are stored in the microcomputer program area. When setting parameters, set the total capacity of the sequence program area and microcomputer program area (SFC program + utility program + user-created microcomputer program) to a value smaller than the main program capacity of the PC CPU to be used. Fig. 10.1 Allocation of the SFC Program - (2) SFC program work area and step trace area \* - (a) The SFC program work area is used by the OS to execute an SFC program, and 4 k bytes are required in the user memory area. (The SFC program work area is not accessible by the user.) When the SFC program work area cannot occupy 4 k bytes, the SFC program execution is disabled. - (b) A step trace area can be set in the 0 to 12 k byte range and is used for executing step tracing with peripheral devices. ## **POINT** \* : Allocation of the SFC program work area and step trace area is determined by the CPU type and memory cassette type to used. Refer to Sections 10.2 to 10.4 for details. **MELSEC-A** ## 10.2 A2NCPU(S1) and A3NCPU When the A2N(S1) and A3N are used, the feasibility of SFC program execution depends on the vacant capacity in the memory cassette used. The following gives the feasibility of SFC program execution depending on the vacant capacity in the memory cassette used and the allocation of the SFC program work area and step trace area. #### POINTS - (1) \*: The feasibility of SFC program execution when the A2N(S1) or A3N is used is determined by the version of the CPU module. For the details of the CPU versions which are compatible with the SFC program, refer to the MELSAP-II Programming Manual (IB-66361) (Version: B and later). - (2) Refer to Section 10.1 for the allocation of the SFC program memory area. | Memory<br>Cassette<br>type | Memory<br>Cassette<br>Capacity (M) | Parameter<br>Setting<br>Range (A) | Vacant Area<br>Capacity (B) | SFC Program<br>Execution Feasibility | Available Stap Trace<br>Area Capacity | |----------------------------------------------------------------|---------------------------------------------------------------------|---------------------------------------------------------------------|--------------------------------------------------------------|----------------------------------------|--------------------------------------------------------------------------| | A3(N)MCA-2<br>A3(N)MCA-4<br>A3(N)MCA-8<br>A3MCA-12<br>A3MCA-18 | 16 k bytes<br>32 k bytes<br>64 k bytes<br>96 k bytes<br>144 k bytes | 16 k bytes<br>32 k bytes<br>64 k bytes<br>96 k bytes<br>144 k bytes | 16 k bytes or more<br>//4 to 15 k bytes<br>3 k bytes or less | Excution possible Excution impossible | /// 12 k bytes<br>// [(4 to 15) -4] k bytes<br>// | | A3NMCA-16<br>A3NMCA-24<br>A3NMCA-40 | 128 k bytes<br>192 k bytes<br>320 k bytes | 96 k bytes<br>144 k bytes<br>144 k bytes | 16 k bytes or more 4 to 15 k bytes 3 k bytes or less | Excution possible | 12 k bytes<br>[(4 to 15) -4] k bytes<br>12 k bytes*<br>( ) area is used) | <sup>\*1:</sup> When the extension file registers are used by using the SW0GHP-UTLP-FN1 utility program, extension file register No.1 cannot be used. Fig. 10.2 Allocation of the SFC Program Memory Area <sup>\*2:</sup> When the extension file registers are used by using the SW0GHP-UTLP-FN1 utility program, extension file register No. 10 ( area) cannot be used. # 10. CONFIGURATION OF USER MEMORY AREA (WHEN AN SFC PROGRAM IS USED) **MELSEC-A** #### 10.3 Compact Type CPU The SFC program work area and step trace area are allocated in the following user memory area. | Type CPU | User Memory Area | |----------------------------------------|------------------| | A0J2H, A2C, A52G, A1S, A1S-S1, A1SJ-S3 | 32 k bytes | | A1SH, A1SJH, A2SH, A1FX, A2S, A2AS | 64 k bytes | | A2S-S1, A2SH-S1 | 192 k bytes | | A2AS-S1, A2AS-S30, A2AS-S60 | 256k bytes | The following gives the feasibility of SFC program execution depending on the vacant capacity in the user memory area and the allocation of the SFC program work area and step trace area. Fig 10.3 SFC Program Memory Area #### 10.4 AnACPU\* and AnUCPU When the AnA, or AnU is used, the feasibility of SFC program execution depends on the vacant capacity in the memory cassette used and setting of extension comment capacity. #### **POINTS** - (1) \*: The feasibility of SFC program execution when the AnA is used is determined by the version of the CPU module. For the details of the CPU versions which are compatible with the SFC program, refer to the MELSAP-II Programming Manual (IB-66361) (Version: B and later). - (2) Refer to Section 10.1 for the allocation of the SFC program memory area. **MELSEC-A** #### 10.4.1 Allocation when extension comment capacity is not set The feasibility of SFC program execution depends on the vacant capacity in the memory cassette used. The following gives the feasibility of SFC program execution depending on the vacant capacity in the memory cassette used and the allocation of the SFC program work area and step trace area. Fig. 10.4 Allocation of the SFC Program Memory Area Λ 4 **MELSEC-A** #### 10.4.2 Allocation when extension comment capacity is set Allocation when the parameter setting capacity contains vacant area capacity when the extension comment capacity is set conforms to the allocation when the extension comment capacity is not set. (Refer to Section 10.4.1.) When the capacity after setting the extension comment capacity exceeds the parameter setting capacity, extension comments will be stored in extension file register Nos. 10 and after when the following memory cassettes are used. The feasibility of SFC program execution and the allocation of the SFC program work area and step trace area depend on the vacant area capacity in the memory capacity less the extension comment capacity. - A3NMCA-16 A3NMCA-24 A3NMCA-40 - A3NMCA-56 A3AMCA-96\*1 A4UMCA-128\*2 - \*1: Compatible with A3ACPU and AnUCPU only. - \*2: Compatible with A4UCPU only. <sup>\*:</sup> Extension comments are stored in extension file register Nos. 10 and the following areas according to set capacity. #### Examples: When the extension comment capacity is 20 k bytes, extension comments are stored in extension file register Nos. 10 and 11. Areas used for the extension comments cannot be used as extension file registers. Fig. 10.5 Allocation of the SFC Program Area # 11. ALLOCATION OF THE MELSECNET/10 NETWORK PARAMETERS To use a MELSECNET/10 data link system with an AnUCPU, A2ASCPU and QCPU-A, it is necessary to set the MELSECNET/10 network parameters. (1) MELSECNET/10 network parameter capacity The MELSECNET/10 network parameters need to be set with each MELSECNET/10 link module. The set network parameters are stored in a range of 64 k bytes from the head of the memory area of the memory cassette. Because of this, when MELSECNET/10 network parameters are set with an A3U or A4U, the main program setting range is reduced by 30 k steps. (2) The capacity used for network parameters varies depending on the settings made. Network parameter setting capacity o : Must be set $\Delta$ : Set if necessary x : Setting not necessary | Item | Control Station | Normal Station | |-------------------------------------------------|-----------------|----------------| | Internal data (30 bytes) | o | o | | Routing parameters (390 bytes) | Δ | Δ | | Transfer parameters for data link (246 bytes) | Δ | Δ | | Common parameters (2164 bytes/module) *1 | 0 | х | | Refresh parameters (92 bytes/module) *2 | 0 | 0 | | Station-specific parameters (1490 bytes/module) | Δ | Δ | \*1 For a remote master station, the common parameters occupy 2722 bytes. \*2 If for example the number of network modules mounted is two, the refresh parameters occupy 92 x 2 = 184 bytes. For the network parameter capacity, secure an area on the basis of the total of each of the settings in 2 k byte units. | Total Capacity of Each Setting | Network Parameter Setting Capacity | |--------------------------------|------------------------------------| | 30 to 2048 bytes | 2 k bytes | | 2049 to 4096 bytes | 4 k bytes | | 4097 to 6144 bytes | 6 k bytes | | 6145 to 8192 bytes | 8 k bytes | | 8193 to 10240 bytes | 10 k bytes | | 10241 to 12288 bytes | 12 k bytes | | 12289 to 14336 bytes | 14 k bytes | | 14337 to 16384 bytes | 16 k bytes | (3) Range to be stored to the ROM for the ROM operation When the memory contents are stored to a ROM, the MELSECNET/10 netowork parameters are also stored the ROM. Use an EPROM which can store parameters, T/C set values, main programs, and MELSECNET/10 network parameters. Fig 11.1 Allocation of the MELSECNET/10 Link Parameters 44 6 # **APPENDIX** # APPENDIX 1 Differences between A3NCPU and A3N board | Refer to | ltem . | A3NCPU | A3N Board | |----------|------------------------------------------|--------|-----------| | 2.4.2 | Refresh method | 0 | x | | 3.7.2 | Count processing during refreshing | 0 | ∆ ±1 | | 4.2.2 | I/O allocation using peripheral devices | 0 | х | | 6.10 | Changing I/O modules in online | 0 | х | | 6.17 | Setting the display mode for annunciator | 0 | x | <sup>\*1</sup> Applied only for A7LMS-F | Error Message | Description | Course of Action | |-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CIRCUIT<br>CONTINUATION ERROR. | The return ladder is not correct. | Ladder the return. | | COMMAND ERROR. | Method of specification is incorrect. | Look at HELP Information and specify correctly. | | | There is an incorrect code in the sequence program. | Delete the incorrect step using list mode. | | COMMAND ERROR.<br>ERROR STEP=%S. | When writing a parameter + main, main program or sub-program in PC mode, the step indicated by "Error Step\XXX" has an incorrect code. | Using step mode, check the following, then edit or delete the error step. Did you use a "W" command with a CPU that has no link card in the A0J or in the X,Y device range? Otherwise, the program is irregular. | | COMMENT CAPACITY<br>NOT SET. | The comment capacity parameter has not been set. | Set the comment capacity with Parameter Setup. | | DATA NOT FOUND. | When reading out file maintenance data, the data file is smaller than the parameter capacity. | Set the parameter correctly. | | | When recording items for the Ladder Mode<br>Monitor, you selected Device Memory or Status<br>Latch, but the required data is not in the AT's<br>memory. | Read out the required data in PC mode or in File Maintenance. | | DATA OVERFLOWS ONE<br>SCREEN.<br>PRESS [ENTER]. | The SFC Device Search found more devices than it can display on one screen. | Press [ENTER] to see the next screen. | | DEVICE NUMBER OUT<br>OF RANGE. | The number specified for the device is out of range. | Set the device number to an in-range value. | | DRIVE NOT READY. | When writing to the floppy disk, there is no disk inserted in the destination drive. | Insert a disk in the destination drive. | | EXECUTABLE DURING BLOCK STOP ONLY. | You selected the test functions Restart or without first stopping the block. | Execute Continue or One Cycle Execute only when the block is stopped. | | FILE NOT FOUND. | Your search selection has no file. | Change your selection. | | FLOPPY DISK ERROR. | You tried to access a drive that has no disk inserted. | Insert a floppy disk or change the drive number. | | | You tried to write a write-protected disk. | Switch the disk's write protect tab to write-enable. | | | Disk is unusable. | Change the disk. | | INCORRECT BRANCH/<br>CONNECTION. | A branch or converge on the SFC chart does not follow the language format values. | Correct the branch or converge in accordance with the language format rules. | | INCORRECT DATA. | A block containing no set steps has been recorded for Step Trace. | Set a base step for the block. | | INCORRECT DATA<br>NAME. | The sampling trace, status latch or device memory data name has been incorrectly specified. | Enter a correct data name. You may use alphanumeric characters and "-"," _". (Up to 8 characters.) You must begin the name with an alphabetic character (A-Z). | | Error Message | Description | Course of Action | |-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------| | INCORRECT EXECUTION POSITION. | You selected Zoom while not at a step or transition condition. | Move the cursor to a step or transition consition before selecting Zoom. | | | When deleting a branch or converge on the SFC Chart, the chart symbol specified by the cursor is different from the function key diagram symbol. | Press a function key with the same diagram symbol as the one specified by the cursor. | | INCORRECT JUMP DESTINATION. | You specified a Jump out of or into a branched area. | Please follow SFC language format. | | INCORRECT<br>OPERATION. | The order of your settings is incorrect. | Input settings in correct order. | | INCORRECT SYSTEM NAME. | When performing an intra-disk file copy (source and destination are the same floppy disk), you specified the same system name for source and destination. | Change the destination system name. | | INCORRECT<br>TERMINATION. | The bottom edge of the SFC diagram is not a Jump or End step. | Enter a Jump or End step on the bottom edge. | | INVALID KEY. | You pressed an improper key. | Follow the explanations on the screen, consult HELP or read the manual and press a proper key. | | JUMP DESTINATION NOT FOUND. | When writing the SFC diagram, you created a Jump node with a non-existent destination step. | Write the Jump destination step before writing in the Jump transition. | | LADDER NOT ENTERED. | You selected an unsaved ladder for program copy. | Select a saved ladder. | | LADDER OVERFLOW. | The ladder has more than 8 ANB or ORB commands in a row, or more than 9 LD commands in a row. | Edit the ladder to correct the error condition. | | MICROCOMPUTER<br>PROGRAM CAPACITY<br>NOT SET. | You tried to create a program in SFC mode without setting the microcomputer capacity. | Set the microcomputer capacity with Parameter setting. | | NOT BROKEN. | You tried to perform the test function Restart or Cancel Break when there was no break set. | Set a break point or blockbreak. | | NO 'END' COMMAND. | A transition condition or output directive program created with the List language has no End statement. | Add an End statement to the end of the transition condition or output directive program. | | NOT ENOUGH MEMORY. | The remaining memory capacity on the floppy disk is too small to perform the requested write operation. | Insert a new disk and re-execute the write operation. If there is unneeded data on the disk, delete it to free up space. | | NOT USABLE FOR<br>SFC-STEP. | You entered a command or label that is not alowed in output directives (commands MC, MCR, CJ, SCJ, JMP, FEND, RET, IRET, CHK, CHG or labels P,I). | Enter an acceptable command for an output directive. | | NUMBER NOT<br>ENTERED. | You selected an entry number that does not contain an entered program for Macro Recall. | Select an entry number that contains an entered program. | | OR LADDER EXCEEDS<br>24 LINES AND<br>OVERFLOWS DISPLAY<br>AREA. | You tried to display a ladder block that is more than 25 lines long. | Verify via List Display. When you verify via Ladder Display, the block is truncated to 24 lines. | | OUT OF SETTING<br>RANGE. | Capacity setting is out of range.<br>Specified step number is out of range. | Set capacity in-range.<br>Specify step number in-range. | | PARAMETER ERROR. | You tried to record a Sampling Trace, but the PC Sampling Trace capacity has not been set. | Set PC Sampling Trace to "Y" with Parameter Setting. | | Error Message | Description | Course of Action | |---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------| | PARAMETER SETTING<br>MISMATCH. | When trying to read or write in PC mode, settings in parameter memory do not correspond. | Correct the appropriate parameters. | | | During parameter verification, the contents do not correspond. | | | | You tried to display Sampling Trace without executing Sampling Trace from Parameters. | Select "Y" for Sampling Trace from Parameters. | | PC CAPACITY NOT SET. | You executed a write in PC mode, but the PC capacity parameter has not been set. | Set the PC capacity with Parameter Setting. | | PC COMMUNICATION ERROR. | PC power is off. | Turn the PC power on. | | Emion. | Cable or connection is bad. | Re-connect carefully with the correct cable type. | | | The PC was reset during transmission. | Re-start the transmission from the AT. | | | The RUN LED began to flash during transmission. | Correct the cause of the flashing, reset the PC, and re-start the transmission from the AT. | | | The AT issued a Remote Run when the PC was obeying a Remote Stop issued by the computer link unit. | Cancel the Remote Stop issued by the computer link unit and issue a Remote Run from the AT. | | PC SELECTION ERROR. | The PC type specified in the initial data and the PC actually connected are different. | Re-display the initialization setting screen and enter the correct PC type. | | PC TYPE MISMATCH. | The PC type specified by parameters does not match the PC actually connected. | Re-set the parameter to the connected PC type. | | PRINTER NOT READY. | You tried to execute a printout, but the printer is not connected. | Connect the printer. | | PROGRAM NOT FOUND. | Your search selection has no program. | Change your selection. | | RANGE SETTING<br>ERROR. | The specified range is outside of the acceptable range. | Specify a proper range. | | SELECT "DETAILED<br>DISPLAY". | You tried to write a diagram while it was in skeleton diagram display mode. | Set the display to "detailed" mode. | | SELECT "DISPLAY WITH COMMENT". | You selected Create Comments when the display was not in "include comments" mode. | Change the display to include comment 1 or comment 2. | | SELECT "DISPLAY<br>WITHOUT COMMENT". | You tried to write, Insert or Delete to a circuit in Zoom mode when the display was in "With comments" mode. | Change the display to "Without comments" mode. | | SET PC TO STEP-RUN. | You selected a test function (F1 to F7) when the PC was not in Step Run mode. | Set the PC to Step Run mode and re-select the test function. | | SFC DIAGRAM ERROR. | There is a ladder entry that does not follow SFC grammar. | Re-enter following the SFC grammar. | | STEP NUMBER<br>ALREADY EXISTS. | In statement mode, you selected a step that already has a program. | Check the program and choose a correct step number. | | SYSTEM NAME NOT FOUND. | The read origin system name does not exist on the specified drive. | View the directory to confirm the system name and re-enter. | | THE PC CHANNEL AND PC NUMBER ARE INCORRECT. | The operation is prohibited for the currently set PC<br>Channel and PC Number, or you tried to set the<br>Remote I/O port while it was connected. | Consult HELP or the manual to avoid prohibited operations. | | Error Message | Description | Course of Action | |-----------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------| | WRITE TO ROM<br>IMPOSSIBLE. | You executed a write in PC mode, but the RAM/ROM switch in the PC memory cassette was set to ROM. | Set the RAM/ROM switch in the PC memory cassette to RAM. | | WRITE-IN ERROR. | You executed "write" (download) in PC mode when the PC memory cassette RAM/ROM switch was set to ROM. | Change the memory cassette RAM/ROM switch to RAM. | | | When writing a file, you exceeded the disk capacity. | Delete unnecessary files to increase free space on the disk. | | Information Message | Description | |---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------| | COMPLETE. STEP NUMBER<br>CHANGED. | When a step number has been changed. | | COPYING TO THE RAM DISK. | You chose PC mode or ladder mode from the menu. | | EXECUTING. | When a Read, Write or Verify (to/from the PC, floppy disk or ROM) is in progress, or when a circuit conversion is in progress. | | LADDER END. | In ladder display, when the last part of the program has been read out. | | MONITOR STARTED. | When monitoring is in progress (Monitor function). | | MONITOR STOPPED. | In ladder monitor, a trigger stop has been encountered, or you pressed ESC. | | OPERATION COMPLETE. | When a Read, Write or Verify (to/from the PC, floppy disk or ROM) has completed or when a circuit conversion is complete. | | PLEASE SELECT PC TYPE. | When you select a PC type during system setting. | | PRESS [CONV.] (SHIFT + F4) TO<br>DELETE A LADDER BLOCK. | When a circuit block is deleted. | | PROCESSING. | Internal management in progress. | | READOUT PC MEMORY. | It is necessary to read from the PC. | | SAMPLING STARTED. | In Sampling Trace mode, the PC has begun sampling. | | SAMPLING STOPPED. | In Sampling Trace mode, you pressed ESC during sampling execution to abort sampling. | | STOPPED. | A function has been aborted in progress by the user. | | VERIFYING. | When a verify is in progress. | | WRITE SETTING DATA TO PC. | It is necessary to write setup data to the PC. | # **WARRANTY** Please confirm the following product warranty details before starting use. #### 1. Gratis Warranty Term and Gratis Warranty Range If any faults or defects (hereinafter "Failure") found to be the responsibility of Mitsubishi occurs during use of the product within the gratis warranty term, the product shall be repaired at no cost via the dealer or Mitsubishi Service Company. Note that if repairs are required at a site overseas, on a detached island or remote place, expenses to dispatch an engineer shall be charged for. ## [Gratis Warranty Term] The gratis warranty term of the product shall be for one year after the date of purchase or delivery to a designated place. Note that after manufacture and shipment from Mitsubishi, the maximum distribution period shall be six (6) months, and the longest gratis warranty term after manufacturing shall be eighteen (18) months. The gratis warranty term of repair parts shall not exceed the gratis warranty term before repairs. #### [Gratis Warranty Range] - (1) The range shall be limited to normal use within the usage state, usage methods and usage environment, etc., which follow the conditions and precautions, etc., given in the instruction manual, user's manual and caution labels on the product. - (2) Even within the gratis warranty term, repairs shall be charged for in the following cases. - 1. Failure occurring from inappropriate storage or handling, carelessness or negligence by the user. Failure caused by the user's hardware or software design. - 2. Failure caused by unapproved modifications, etc., to the product by the user. - 3. When the Mitsubishi product is assembled into a user's device, Failure that could have been avoided if functions or structures, judged as necessary in the legal safety measures the user's device is subject to or as necessary by industry standards, had been provided. - Failure that could have been avoided if consumable parts (battery, backlight, fuse, etc.) designated in the instruction manual had been correctly serviced or replaced. - Failure caused by external irresistible forces such as fires or abnormal voltages, and Failure caused by force majeure such as earthquakes, lightning, wind and water damage. - 6. Failure caused by reasons unpredictable by scientific technology standards at time of shipment from Mitsubishi. - 7. Any other failure found not to be the responsibility of Mitsubishi or the user. # 2. Onerous repair term after discontinuation of production - (1) Mitsubishi shall accept onerous product repairs for seven (7) years after production of the product is discontinued. Discontinuation of production shall be notified with Mitsubishi Technical Bulletins, etc. - (2) Product supply (including repair parts) is not possible after production is discontinued. #### 3. Overseas service Overseas, repairs shall be accepted by Mitsubishi's local overseas FA Center. Note that the repair conditions at each FA Center may differ. ## 4. Exclusion of chance loss and secondary loss from warranty liability Regardless of the gratis warranty term, Mitsubishi shall not be liable for compensation to damages caused by any cause found not to be the responsibility of Mitsubishi, chance losses, lost profits incurred to the user by Failures of Mitsubishi products, damages and secondary damages caused from special reasons regardless of Mitsubishi's expectations, compensation for accidents, and compensation for damages to products other than Mitsubishi products and other duties. #### 5. Changes in product specifications The specifications given in the catalogs, manuals or technical documents are subject to change without prior notice. #### 6. Product application - (1) In using the Mitsubishi MELSEC programmable logic controller, the usage conditions shall be that the application will not lead to a major accident even if any problem or fault should occur in the programmable logic controller device, and that backup and fail-safe functions are systematically provided outside of the device for any problem or fault. - (2) The Mitsubishi general-purpose programmable logic controller has been designed and manufactured for applications in general industries, etc. Thus, applications in which the public could be affected such as in nuclear power plants and other power plants operated by respective power companies, and applications in which a special quality assurance system is required, such as for Railway companies or National Defense purposes shall be excluded from the programmable logic controller applications. Note that even with these applications, if the user approves that the application is to be limited and a special quality is not required, application shall be possible. When considering use in aircraft, medical applications, railways, incineration and fuel devices, manned transport devices, equipment for recreation and amusement, and safety devices, in which human life or assets could be greatly affected and for which a particularly high reliability is required in terms of safety and control system, please consult with Mitsubishi and discuss the required specifications. # type ACPU/QCPU-A (A Mode)(Fundamentals) # **Programming Manual** | MODEL | ACPU(FUNDA.)-P-E | |-------------------------|------------------| | MODEL<br>CODE | 13J740 | | IB(NA)-66249-N(0012)MEE | | HEAD OFFICE : MITSUBISHI DENKI BLDG MARUNOUCHI TOKYO 100-8310 TELEX : J24532 CABLE MELCO TOKYO NAGOYA WORKS : 1-14 , YADA-MINAMI 5 , HIGASHI-KU, NAGOYA , JAPAN When exported from Japan, this manual does not require application to the Ministry of International Trade and Industry for service transaction permission.