SFC 51常用功能使用入门

1 sfc 51简介 1.1 程序功能介绍
通过系统功能sfc 51 rdsysst (读取系统状态),可以读取系统状态列表或部分系统状态列表,例如指示灯状态,序列号,从站状态等等。
调用sfc 51时,通过将值“1”赋给输入参数req来启动读取。如果可以立即读取系统状态,则sfc将在busy输出参数中返回值0。如果busy包含值1,则尚未完成读取功能。 表1 sfc51参数说明 参数 描述
req 输入参数 req = 1:启动处理
ssl_id 输入参数 将要读取的系统状态列表或部分列表的id号
index 输入参数 部分列表中对象的类型或编号。
ret_val 输出参数 如果执行sfc时出错,则ret_val参数
将包含错误代码。
busy 输出参数 true:尚未完成读取。
ssl_header 输出参数 lenthdr是ssl列表或ssl部分列表的数据记录的长度。
• 如果仅读取了ssl列表的标题信息,则n_dr包含属于它的数据记录数。
• 否则,n_dr包含传送到目标区域的数据记录数。
dr 输出参数 ssl列表读取或ssl部分列表读取的目标区
域:
• 如果仅读取了ssl列表的标题信息,
则不能评估dr的值,
而只能评估ssl_header的值。
• 否则,lenthdr和n_dr的乘积将指
示已在dr中输入了多少字节。
2 读取cpu指示灯
可以通过sfc 51读取cpu的指示灯状态,使用的ssl_id参数为16#74(16#19)读取全部指示灯状态 或者16#174(16#119)读取单个指示灯状态 2.1 编程
首先需要创建一个数据块,用来存放读取出来的指示灯状态结果
图1 创建db1,存放读取结果 打开ob1,在ob1的临时变量区创建一个变量length,类型设置为struct(结构)
图2 创建名为length的结构变量 双击length变量,进入结构变量成员定义,创建两个word类型的变量,本例中分别为size和number:
图3 创建length的结构变量的两个word成员 编写sfc51程序: call rdsysst
req :=true
szl_id :=w#16#74 //读取全部指示灯状态
index :=w#16#0
ret_val :=mw0
busy :=m2.0
szl_header:=#length
dr :=p#db1.dbx0.0 byte 500 //结果输出到db1数据块中
db1存放的结果即为模块的指示灯状态,每个指示灯有4个字节的长度来描述。
前两个字节表示灯的类型(见表二),表示是sf灯还是bf灯等等。
第三个字节表示灯是亮还是灭,如果为1则灯亮,如果为0则灯的状态是灭。
第四个字节表示灯是否闪烁,0表示不闪,1表示正常闪烁(2hz),2,表示慢闪(0.5hz)
灯的类型列表如下(不同的cpu会有不同数目的指示灯): 表2 前两个字节的含义 16#1 sf
16#2 intf
16#3 extf
16#4 run
16#5 stop
16#6 force
16#7 crst
16#8 baf
16#9 usr
16#a usr1
16#b bus1f
16#c bus2f
16#d redf
16#e mstr
注意事项:
关于系统功能sfc51的更多详情请参阅step 7的在线帮助,或者通过start > simatic > documentation选择手册“system software for s7-300/400 system and standard functions” 3 读取profibus dp从站 状态 3.1 编程
首先需要创建一个数据块,用来存放读取出来的状态结果
图4 创建db1,存放读取结果 打开ob1,首先在ob1的临时变量区创建一个变量length,类型设置为struct(结构)
图5 创建名为length的结构变量 双击length变量,进入结构变量成员定义,创建两个word类型的变量,本例中分别为size和number:
图6 创建length的结构变量的两个word成员 编写sfc51程序: call rdsysst
req :=true
szl_id :=w#16#294 //读取从站是否存在
index :=w#16#1
ret_val :=mw0
busy :=m2.0
szl_header:=#length
dr :=p#db1.dbx0.0 byte 500 //结果输出到db1数据块中
在本例中,p#db1.dbx0.0 byte 500中为每个dp从站(16 x 8 = 128)保留一位,地址为address 1的dp从站的状态保存在第三个字节的bit 1位中, 地址为address 3的dp从站的状态保存在第三个字节的bit 3位中,依次类推。如果从站对应的位未被置位,则表明那个dp从站没有通信上或不存在。
举例:从db1.dbw2开始,每个位对应一个bit,例如3号站对应的位是db1.dbx2.3 ,站点存在的位为1,不存在的为0。 注意事项:
关于系统功能sfc51的更多详情请参阅step 7的在线帮助,或者通过start > simatic > documentation选择手册“system software for s7-300/400 system and standard functions”
4读取cpu的序列号 4.1 编程
说明:
通过 sfc 51“rdsysst”可以从系统状态列表(ssl)中读取下列标识数据:
下面的表格指明了可以从不同型号和固件版本的 cpu 读取其它哪些标识数据。为此使用 sfc 51 和 ssl id w#16#011c。 表3 index说明 索引 名称 s7-300/c7 s7-400
w#16#0001 自动化系统的名称 从固件版本 v2.2 起 支持
w#16#0002 cpu 的名称 从固件版本 v2.2 起 支持
w#16#0003 cpu 的设备 id 从固件版本 v2.2 起 支持
w#16#0004 版权条目 从固件版本 v2.2 起 支持
w#16#0005 cpu 的序列号 从固件版本 v2.2 起 从 mlfb
6es741x-xxx04-0ab0 起
w#16#0006 为操作系统保留 - -
w#16#0007 cpu 型号名称 - 支持
w#16#0008 mmc 或 mc 的序列号 (参见条目号:19215608) 从固件版本 v2.0 起 -
(cpu317:从 v2.1 开始)
需要注意,老cpu升级到上表版本也无法实现此功能。
首先需要创建一个数据块,用来存放读取出来的状态结果
图7 创建db1,存放读取结果 打开ob1,首先在ob1的临时变量区创建一个变量length,类型设置为struct(结构)
图8 创建名为length的结构变量 双击length变量,进入结构变量成员定义,创建两个word类型的变量,本例中分别为size和number:
图9 创建length的结构变量的两个word成员 编写sfc51程序: call rdsysst
req :=true
szl_id :=w#16#11c //读取cpu 的序列号
index :=w#16#5
ret_val :=mw0
busy :=m2.0
szl_header:=#length
dr :=p#db1.dbx0.0 byte 500 //结果输出到db1数据块中
结果如下图:
图10 cpu序列号 注意事项:
关于系统功能sfc51的更多详情请参阅step 7的在线帮助,或者通过start > simatic > documentation选择手册“system software for s7-300/400 system and standard functions” 5 读取存储卡的序列号 5.1 编程
描述:
为了获得 mmc 卡的序列号,必须使用 sfc 51 rdsysst 读出系统状态列表 (ssl) :
• ssl id w#16#011c 元件的标识
• index w#16#0008 存储卡的序列号
对于所有的带有 mmc 卡的 s7-300 cpu 和 c7 从固件版本 v2.0 起都可以读出存储卡的序列号,(cpu 317: 从 v2.1 起)。
从s7-400的v5版本起,存储卡上保存唯一的序列号。
首先需要创建一个数据块,用来存放读取出来的状态结果
图11 创建db1,存放读取结果 打开ob1,首先在ob1的临时变量区创建一个变量length,类型设置为struct(结构)
图12 创建名为length的结构变量 双击length变量,进入结构变量成员定义,创建两个word类型的变量,本例中分别为size和number:
图13 创建length的结构变量的两个word成员 编写sfc51程序:
call rdsysst
req :=true
szl_id :=w#16#11c //读取mmc 的序列号
index :=w#16#8
ret_val :=mw0
busy :=m2.0
szl_header:=#length
dr :=p#db1.dbx0.0 byte 500 //结果输出到db1数据块中 结果如下:
图14 mmc序列号 注意事项:
关于系统功能sfc51的更多详情请参阅step 7的在线帮助,或者通过start > simatic > documentation选择手册“system software for s7-300/400 system and standard functions”