Debugging: Forcing, Overwriting, Single Cycle Operations

 

This topic contains information on the following:

What is the debug mode?

To analyze the behavior of the Safety Logic Controller (i.e., of your safety logic) and as a supplement to the mandatory function test, you can display the variable status in EcoStruxure Machine Expert - Safety. In this mode, online values are read cyclically from the Safety Logic Controller and displayed in the editor.

In addition to the function test, you can use the debug mode in EcoStruxure Machine Expert - Safety while commissioning the applica­tion. Instead of, for example, pressing an emergency-stop button, you can force the variable corresponding to the safety-related control device in the FBD/LD editor.

Debug mode provides the possibility of

Debug mode and forcing I/Os is also possible in the EASYSIM Controller Simulation.

NOTE:

Switching the Safety Logic Controller into debug mode is only possible after entering the correct Safety Logic Controller password.

Safety-related Program Execution

Debug mode is considered as non-safety-related because you can influ­ence the execution of the program by forcing/overwriting variables.

WARNING

UNINTENDED EQUIPMENT OPERATION

  • Prior to switching to debug mode, make certain that suitable orga­nizational measures (according to applicable sector standards) have been taken to avoid hazardous situations if the safety logic application operates in an unintended or incorrect way, or an incor­rect target for debugging was selected.

  • Verify the impact of forcing or overwriting variables or using the single cycle operation.

  • Do not enter the zone of operation while the machine is operating.

  • Ensure that no other persons can access the zone of operation while the machine is operating.

  • Observe the regulations given by relevant sector standards while the machine is running in any other operating mode than "opera­tional".

  • Use appropriate safety interlocks where personnel and/or equip­ment hazards exist.

Failure to follow these instructions can result in death, serious injury, or equipment damage.

NOTE:

The test of the safety-related application in debug mode must not replace the proper function test using safety-related I/O devices/sensors/actuators under any circumstances. The test in debug mode may only be performed in addition to the standard function test.

Forcing and overwriting variables in debug mode

Forcing and overwriting means assigning a new value to a variable. Both operations are only possible while the debug mode is active. What is the difference between forcing and overwriting?

Timing sequence in the Safety Logic Controller cycle when forcing vari­ables

Generally, forcing is performed once per cycle. The point of time, however, at which a variable is forced differs depending on the variable type:

  • Inputs are forced at the beginning of a cycle before processing the input variable. This way, the Safety Logic Controller application uses the forced value.

  • Outputs are forced at the end of a cycle. The variable value processed by the application is finally replaced by the forced value in the output image.

    NOTE:

    EcoStruxure Machine Expert - Safety allows reading of output variables. When forcing an output variable and this output variable is read during the Safety Logic Controller cycle, reading is done before forcing. In this case, the present value calculated by the application is read and further processed but not the force value.

    As the force value is written at the end of the cycle, the displayed online value may differ from the forced value until the I/O image is updated and the variable status is read and displayed.

How to force/overwrite variables

  1. Click the 'SafePLC' icon on the toolbar.

    The 'SafePLC' control dialog appears.

  2. Not yet logged-on to the Safety Logic Controller?

    If you are not yet logged-on to the Safety Logic Controller, the button for switching to debug mode is inactive in the control dialog. For logging on, select 'Online > SafePLC Log On' and enter the Safety Logic Controller password.

    Refer to the topic "Password protection" for further information.

  3. In the control dialog, click the 'Debug' button to switch the Safety Logic Controller to debug mode.

    Observe the appearing message and confirm the dialog within 30 seconds.

  4. Open the worksheet to be debugged in variable status by clicking the 'Variable status' icon on the toolbar or pressing <F10>:

    iconVariableState.gif
  5. In FBD/LD code or variables worksheets:

    Right-click on a variable to be forced/overwritten and select 'Debug dialog...' from the context menu, or double-click on the variable. The 'Debug' dialog appears.

    In ST code worksheets:

    Double-click on an online variable value (not the name) that is displayed with a yellow background in order to overwrite it. The edit field and the button for overwriting the variable appear.

    ExampleST_Force.png 

  6. In FBD/LD code or variables worksheets:

    In the 'Debug' dialog, enter the desired value for a non-Boolean variable or select TRUE or FALSE for a Boolean variable.

    In ST code worksheets:

    In the edit field, enter the desired value for a non-Boolean variable or select TRUE or FALSE for a Boolean variable.

    NOTE:

    Enter force/overwrite values for safety-related variables with preceding data type in the following format: SAFEINT#value, SAFEBYTE#value, SAFEWORD#value, SAFEDWORD#value, or SAFETIME#values.

    (value represents the proper value, e.g., SAFEINT#13 or SAFE­TIME#1s.)

    To force a safety-related Boolean value to FALSE, you can either enter SAFEBOOL#0 or SAFEFALSE. Use accordingly SAFEBOOL#1 or SAFETRUE to force a safety-related Boolean variable to TRUE.

  7. In FBD/LD code or variables worksheets:

    • Click 'Overwrite' to overwrite in case of a symbolic variable (not an I/O variable).

    • Click 'Force' to force an I/O variable.

      Forced variables are shown on a pink background in online code work­sheets and in the global variables worksheet in online mode.

    In ST code worksheets, forcing is not possible because I/O variables cannot be processed in ST POUs.

    Click the ico_overwrite.gif button to overwrite the symbolic variable.

How to unforce variables

  1. Select 'Debug dialog...' from the context menu of the variable (in variable status).

    The 'Debug' dialog appears.

  2. In the dialog, you can reset one specific forced variable or all forced variables.

    • 'Reset force' unforces the selected variable.

    • 'Reset force list' unforces all forced variables.

Single cycle operation

NOTE:

EcoStruxure Machine Expert - Safety displays a simulation while single cycle operation is activated. No outputs are set on the Safety Logic Controller.

In debug mode, EcoStruxure Machine Expert - Safety provides an additional debug function referred to as single cycle operation. In single cycle operation, the Safety Logic Controller interrupts the continuous cyclic processing.

To activate this mode, press the 'Halt' button in the 'SafePLC' dialog. The Safety Logic Controller state switches to HALT [Debug].

  • By clicking the 'Single cycle' button, exactly one cycle is processed. After this, the Safety Logic Controller waits for the next command.

  • By clicking the 'Continue' button, the Safety Logic Controller continues normal cyclic processing.

Refer to the topic "'SafePLC' Dialog" for details on the buttons available in the dialog.

  DlgControl_Debug_HALT.gif