1
Lesson 3
Processor Memory Organization
and Program Scan
Processor Memory Organization
While the fundamental concepts of PLC programming are common to all
manufacturers, differences in memory organization, I/O addressing, and
instruction sets mean that PLC programs are never perfectly interchangeable
among different makers. Even within the same product line of a single
manufacturer, different models may not be directly compatible.
The memory map or structure for a PLC processor consists of several
areas, some of these having specific roles. Allen-Bradley PLCs have two
different memory structures identified by the terms rack-based systems and
tag-based systems. The SLC 500 family of controllers use a rack-based fixed
memory structure. The I/O addresses are derived using the slot location of the
input and output modules within the PLC rack. In comparison, the ControlLogix
5000 series of controllers use a tag-based memory structure for assigning and
referencing memory locations. A tag is a friendly name for a memory location.
In tag-based memory structures, there are no fixed areas of memory allocated
for I/O addresses or other types of data.
Memory organization takes into account the way a PLC divides the
available memory into different sections. The memory space can be divided
into two broad categories: program files and data files. Individual sections,
their order, and the sections’ length will vary and may be fixed or variable,
depending on the manufacturer and model.
Program files are the part of the processor memory that stores the user
ladder logic program. The program accounts for most of the total memory of a
given PLC system. It contains the ladder logic that controls the machine
operation. This logic consists of instructions that are programmed in a ladder
logic format. Most instructions require one word of memory.
Module II
2
The data files store the information needed to carry out the user
program. This includes information such as the status of input and output
devices, timer and counter values, data storage, and so on. Contents of the
data table can be divided into two categories: status data and numbers or
codes. Status is ON/OFF type of information represented by 1s and 0s, stored
in unique bit locations. Number or code information is represented by groups
of bits that are stored in unique byte or word locations.
Figure 1 shows the program and data file organization for the SLC 500
controller. The contents of each file are as follows.
Figure 1. Program and data file organization for the SLC 500 controller.
Source Google
Program Files
Program files are the areas of processor memory where ladder logic
programming is stored. They may include:
• System functions (file 0) — this file is always included and contains
various system-related information and user-programmed
Module II
3
information such as processor type, I/O configuration, processor file
name, and password.
• Reserved (file 1) — this file is reserved by the processor and is not
accessible to the user.
• Main ladder program (file 2) — this file is always included and
contains user-programmed instructions that define how the
controller is to operate.
• Subroutine ladder program (files 3–255) — these files are user-
created and are activated according to subroutine instructions
residing in the main ladder program file.
Data Files
The data file portion of the processor’s memory stores input and
output status, processor status, the status of various bits, and numerical
data. All this information is accessed via the ladder logic program. These
files are organized by the type of data they contain and may include:
• Output (file 0)—This file stores the state of the output terminals for
the controller.
• Input (file 1)—This file stores the status of the input terminals for
the controller.
• Status (file 2)—This file stores controller operation information and
is useful for troubleshooting controller and program operation.
• Bit (file 3)—This file is used for internal relay logic storage.
• Timer (file 4)—This file stores the timer accumulated and pre-set
values and status bits.
• Counter (file 5)—This file stores the counter accumulated and pre-
set values and status bits.
• Control (file 6)—This file stores the length, pointer position, and
status bit for specific instructions such as shift registers and
sequencers.
• Integer (file 7)—This file is used to store whole number values or bit
information.
Module II
4
• Float (file 8)—The floating-point file is used to store fractional
numerical data or numerical values greater than 32,767. This file
applies to selected PLC processors.
The I/O address format for the SLC family of PLCs is shown in Figure 2.
The format consists of the following three parts:
• Part 1: I for input and a colon to separate the module type from the slot.
O for output and a colon to separate the module type from the slot.
• Part 2: The module slot number and a forward slash to separate the slot
from the terminal screw.
• Part 3: The screw terminal number.
Figure 2. I/O address format for the SLC family of PLCs.
Source: Image Courtesy of Rockwell Automation, Inc.
The SLC 500 stores data in data tables that are based on 16-bit words.
The input image table file is that part of the program memory allocated to
store the on/off status of connected discrete inputs. Figure 3 shows the
connection of an open and closed switch to the input image table file through
the input module. Its operation can be summarized as follows:
• For the switch that is closed, the processor detects a voltage at the input
terminal and records that information by storing a binary 1 in its bit
location.
• For the open switch, the processor detects no voltage at the input
terminal and records that information by storing a binary 0 in its bit
location.
Module II
5
• Each connected input has a bit in the input image table file that
corresponds exactly to the terminal to which the input is connected.
• The input image table file is changed to reflect the current status of the
switch during the I/O scan phase of operation.
• If the input is on (switch closed), its corresponding bit in the table is set
to 1.
• If the input is off (switch open), the corresponding bit is cleared, or reset
to 0.
• The processor continually reads the current input status and updates the
input image table file.
Figure 3. Connection of an open and closed switch to the input
image table file through the input module. Source Google
The output image table file is that part of the program memory
allocated to storing the actual on/off status of connected discrete outputs.
Figure 4 shows a typical connection of two pilot lights to the output image
table file through the output module. Its operation can be summarized as
follows:
• The status of each light (ON/OFF) is controlled by the user program and is
indicated by the presence of 1 (ON) and 0 (OFF).
• Each connected output has a bit in the output image table file that
corresponds exactly to the terminal to which the output is connected.
Module II
6
• If the program calls for a specific output to be ON, its corresponding bit in
the table is set to 1.
• If the program calls for the output to be OFF, its corresponding bit in the
table is set to 0.
• The processor continually activates or deactivates the output status
according to the output table file status.
Figure 4. Connections of pilot lights to the output image table
file through the output module. Source Google
Typically, micro PLCs have a fixed number of inputs and outputs. Figure 5
shows the MicroLogix controller from the Allen-Bradley MicroLogix 1000 family
of controllers. The controller has 20 discrete inputs with predefined addresses
I/0 through I/19 and 12 discrete outputs with predefined addresses O/0
through O/11. Some units also contain analog inputs and outputs embedded
into the base unit or available through add-on modules.
Program Scan
When a PLC executes a program, it must know — in real-time — when
external devices controlling a process are changing. During each operating
cycle, the processor reads all the inputs, takes these values, and energizes or
de-energizes the outputs according to the user program. This process is known
Module II
7
Figure 5. Typical micro PLC with predefined addresses.
Source: Image Courtesy of Rockwell Automation, Inc.
as a program scan cycle. Figure 6 illustrates a single PLC operating cycle
consisting of the input scan, program scan, output scan, and housekeeping
duties. Because the inputs can change at any time, it constantly repeats this
cycle as long as the PLC is in the RUN mode.
The time it takes to complete a scan cycle is called the scan cycle time
and indicates how fast the controller can react to changes in inputs. The time
required to make a single scan can vary from about 1 to 20 ms. If a controller
has to react to an input signal that changes states twice during the scan time,
the PLC may never be able to detect this change. For example, if it takes 8 ms
for the CPU to scan a program, and an input contact is opening and closing
every 4 ms, the program may not respond to the contact changing state. The
CPU will detect a change if it occurs during the update of the input image
table file, but the CPU will not respond to every change. The scan time is a
function of the following:
• The speed of the processor module
• The length of the ladder program
• The type of instructions executed
• The actual ladder true/false conditions
Module II
8
Figure 6. PLC program scan cycle. Source: Google
The actual scan time is calculated and stored in the PLC’s memory. The
PLC computes the scan time each time the END instruction is executed. Scan
time data can be monitored via the PLC programming. Typical scan time data
include the maximum scan time and the last scan time.
The scan is normally a continuous and sequential process of reading the
status of inputs, evaluating the control logic, and updating the outputs.
Figure 7 shows an overview of the data flow during the scan process. For each
rung executed, the PLC processor will:
• Examine the status of the input image table bits.
• Solve the ladder logic to determine logical continuity.
• Update the appropriate output image table bits, if necessary.
• Copy the output image table status to all of the output terminals. Power
is applied to the output device if the output image table bit has been
previously set to a 1.
• Copy the status of all of the input terminals to the input image table. If
an input is active (i.e., there is electrical continuity), the corresponding
bit in the input image table will be set to a 1.
Module II
9
Figure 7. Overview of the data flows during the scan process. Source: Google
In a rung of any hardwired circuit, there must be electrical continuity
for the load to energize. The rung has electrical continuity only when the
current flow is established in a path from one side of the power rail to the
other. There is no electrical continuity in the PLC ladder logic program.
Instead, the rung must be evaluated in terms of logical continuity rather than
electrical continuity. When there is a continuous path of true conditional
instructions in a rung, logical continuity exists; accordingly, the output
instruction is true and the status bit will be set to a 1 (ON).
The controller evaluates ladder logic rung instructions based on the rung
condition preceding the instruction (rung-condition-in), as illustrated in Figure
8.
• If the rung-condition-in to an input instruction is true, the controller
evaluates the instruction and sets the rung-condition-out to match the
results of the evaluation.
• If the instruction evaluates to true, the rung-condition-out is true.
• If the instruction evaluates to false, the rung-condition-out is false.
• If the rung-condition-in to an output instruction is true, the rung-
condition-out is set to true.
• If the rung-condition-in to an output instruction is false, the rung-
condition-out is set to false.
Module II
10
Figure 8. Evaluating ladder logic rung conditions. Source: Google
Figure 9 illustrates the scan process applied to a simple single rung
program. The operation of the scan process can be summarized as follows:
• If the input device connected to address I:3/6 is closed, the input module
circuitry senses the voltage at the input terminal, and a 1 (ON) condition
is entered into the input image table bit I:3/6.
• During the program scan, the processor examines bit I:3/6 for a 1 (ON)
condition.
• In this case, because input I:3/6 is 1, the rung is said to be TRUE or have
logic continuity
• The processor then sets the output image table bit O:4/7 to 1.
• The processor turns on output O:4/7 during the next I/O scan, and the
output device (light) wired to this terminal becomes energized.
• This process is repeated as long as the processor is in RUN mode.
• If the input device opens, electrical continuity is lost, and a 0 would be
placed in the input image table. As a result, the rung is said to be FALSE
due to loss of logic continuity.
Figure 9. Scan process applied to a single rung program. Source: Google
• The processor would then set the output image table bit O:4/7 to 0,
causing the output device to turn off.
Module II
11
Ladder programs process inputs at the beginning of a scan and outputs at
the end of a scan, as illustrated in Figure 10. For each rung executed, the PLC
processor will:
• Step 1. Update the input image table by sensing the voltage of the input
terminals. Based on the absence or presence of a voltage, a 0 or a 1 is
stored into the memory bit location designated for a particular input
terminal.
• Step 2. Solve the ladder logic to determine logical continuity. The
processor scans the ladder program and evaluates the logical continuity of
each rung by referring to the input image table to see if the input
conditions are met. If the conditions controlling an output are met, the
processor immediately writes a 1 in its memory location, indicating that
the output will be turned ON; conversely, if the conditions are not met a
0 indicating that the device will be turned OFF is written into its memory
location.
Figure 10. Scan process applied
to a multiple rung program. Source: Google
• Step 3. The final step of the scan process is to update the actual states of
the output devices by transferring the output table results to the output
module, thereby switching the connected output devices ON (1) or OFF
(0). If the status of any input devices changes when the processor is in
Module II
12
step 2 or 3, the output condition will not react to them until the next
processor scan.
Each instruction entered into a program requires a certain amount of time
for the instruction to be executed. The amount of time required depends on
the instruction. For example, it takes less time for a processor to read the
status of an input contact than it does to read the accumulated value of a
timer or counter. The time taken to scan the user program is also dependent
on the clock frequency of the microprocessor system. The higher the clock
frequency, the faster is the scan rate.
There are two basic scan patterns that different PLC manufacturers use to
accomplish the scan function (Figure 11). Allen-Bradley PLCs use the horizontal
scan by rung method. In this system, the processor examines input and output
instructions from the first command, top left in the program, horizontally, rung
by rung.
Figure 11. Scanning can be vertical or horizontal. Source: Google
Module II
13
LEARNING ACTIVITY
I. Answer briefly what are asked for:
1. What does the memory map for a typical PLC processor consist of?
2. Compare the function of the PLC program and data files.
3. List eight different types of data files used by an SLC 500 controller.
4. a. What information is stored in the input image table file?
b. In what form is this information stored?
5. a. What information is stored in the output image table file?
b. In what form is this information stored?
6. Outline the sequence of events involved in a PLC scan cycle.
7. List four factors that enter into the length of the scan time.
Module II