FB_KL3228Config

FB_KL3228Config 1:

Function block for parameterizing a KL3228: 8-channel input terminal for resistance sensors.

FB_KL3228Config 2:

The function block only parameterizes one terminal channel. For parameterizing all channels, the corresponding number of function blocks has to be instantiated. A mixed configuration (e.g. different sensor types) is possible.

VAR_INPUT

VAR_INPUT
    bConfigurate   : BOOL;
    bReadConfig    : BOOL;
    iSetSensorType : INT;
    tTimeout       : TIME;
END_VAR

bConfigurate: A rising edge starts the configuration page. First, the general terminal data, i.e. "terminal designation", "special version" and "firmware version", are read. Then, the specified settings are written to the corresponding registers and finally read again for verification and information. The read information is displayed at the function block outputs. During this sequence the output bBusy is TRUE, and no further command, e.g. bReadConfig, is accepted.

bReadConfig: A rising edge only starts a read sequence. The general terminal data, i.e. "terminal designation", "special version" and "firmware version", are read, followed by the set configuration parameters. The read information is displayed at the function block outputs. During the read sequence the output bBusy is TRUE, and no further command, e.g. bConfigurate, is accepted.

iSetSensorType: This input is used to set the sensor. The setting is based on the table below.

tTimeout: The terminal configuration and reading of the configuration must be complete within the time entered here. Otherwise an error with a corresponding error number is issued at the outputs bError and iErrorId.

iSetSensorType

Element

0

PT1000

1

NI1000

2

RSNI1000 (NI1000 based on Landis & Staefa characteristics: 1000 Ω at 0 °C and 1500 Ω at 100 °C)

VAR_OUTPUT

VAR_OUTPUT
    bBusy            : BOOL;
    bError           : BOOL;
    iErrorId         : UDINT;
    iState           : USINT;
    iDataIn          : INT;
    iTerminalType    : WORD;
    iSpecialType     : WORD;
    iFirmwareVersion : WORD;
    sDescription     : STRING;
    sSensorType      : STRING;
END_VAR

bBusy: As long as the read or configuration sequence is in progress, this output is TRUE.

bError: This output is switched to TRUE, if an error occurred while a command (Configure or Read) is executed. The command-specific error code is contained in iErrorId.

iErrorId: contains the command-specific error code of the most recently executed command. It is reset to 0 by activating the function block again via the inputs bConfigurate or bReadConfig. See Error codes.

iState: Corresponds to the status variable of the process data, i.e. stInData.iState, see VAR_IN_OUT. During command execution (bBusy = TRUE) this output is set to 0. This output is suitable for status assessment during normal terminal operation. Spurious states during configuration and reading through the register communication are hidden.

iDataIn: Corresponds to the data variable of the process data, i.e. stInData.iDataIn, see VAR_IN_OUT. During command execution (bBusy = TRUE) this output retains the value it had before the command was called. This output is suitable for direct process data processing during normal terminal operation. Spurious states during configuration and reading through the register communication are hidden.

iTerminalType: Contents of register 8 (terminal designation). When used with the correct terminal, the content should be 0x0C9C (3228dec).

iSpecialType: Contents of register 29 (special version).

iFirmwareVersion: Contents of register 9 (firmware version).

sDescription: Terminal designation, special version and firmware version as string (e.g. 'terminal KL3228-0000 / firmware 1C').

sSensorType: Set sensor type in plain text.

VAR_IN_OUT

VAR_IN_OUT
    stInData  : ST_KL3228InData;
    stOutData : ST_KL3228OutData;
END_VAR

stInData : Reference to the structure of the input process image (type: ST_KL3228InData).

stOutData : Reference to the structure of the output process image (type: ST_KL3228OutData).

Requirements

Development environment

Target platform

IO Hardware

PLC libraries to include

TwinCAT v3.1.4018.26

PC/CX

KL3228

Tc2_IoFunctions from v3.3.5.0