在 STL 中,以下选项可用于间接寻址:
存储器间接寻址
寄存器间接内部区域寻址
寄存器间接跨区域寻址
存储器间接寻址
对于存储器间接寻址,可以在变量中存储地址。变量可以是 WORD 或 DWORD 数据类型。变量可以位于存储器区域“数据”(DB 或 DI)、“位存储器” (M) 或“临时本地数据” (L) 中。在 S7-1500 中,FB 参数也可用于保存地址。如果变量位于数据块中,那么必须是一般访问数据块。
下列示例显示的是存储器间接寻址的应用:
在 STL 中寻址 | 说明 |
---|---|
U E [MD 2] | // 执行变量输入位的 AND 逻辑操作。输入位的地址位于存储器双字 MD2 中。 |
= DIX [DBD 2] | // 将 RLO 分配到变量数据位中。数据位的地址位于数据双字 DBD2 中。 |
L EB [DID 4] | // 将变量输入位加载到 ACCU 1。输入字节地址位于实例双字 DID4 中。 |
AUF DB [LW 2] | // 打开一个变量数据块。数据块的编号位于本地数据字 LW2 中。 |
寄存器间接内部区域寻址
寄存器间接寻址使用其中一个地址寄存器(AR1 或 AR2)来获取操作数的地址。
如果是寄存器间接内部区域寻址,那么仅通过地址寄存器索引位地址和字节地址(如 P#10.0)。在编写指令之前,不输入地址寄存器中的地址所应用到的存储区。地址寄存器中的地址随后移动到指令中指定的存储区。
可能的存储区有“输入”(I)、“输出” (Q)、“I/O”(PI 或 PQ)、“位存储器” (M)、“临时本地数据” (L) 和“数据”(DB 或 DI)。如果操作数位于数据块中,那么必须是一般访问数据块。
输入寄存器间接内部区域寻址时,在指定地址寄存器之后指定偏移量。这一偏移量被添加到地址寄存器的内容中,而不会改变地址寄存器。该偏移量还具有指针的格式。必须指定指针,而且必须作为常量输入(如 P#0.0 或 P#2.0)。
下列示例显示的是寄存器间接内部区域寻址的应用:
STL | 说明 |
---|---|
LAR1 P#10.0 | // 将指针(P#10.0)加载到地址寄存器 1 中 |
L IW [AR1, P#2.0] | // 将地址寄存器 1 (P#10.0) 中的数据增加偏移量 P#2.0 中的值。 // 将输入字 IW12 的内容加载到累加器 1 中 |
L IW [AR1, P#0.0] | // 将地址寄存器 1 (P#10.0) 中的数据增加偏移量 P#0.0 中的值。 // 将输入字 IW10 的内容加到累加器 1 中 |
寄存器间接跨区域寻址
如果是寄存器间接跨区域寻址,则需使用地址寄存器来建立操作数全部地址的索引。即,位地址和字节地址,以及存储区。可能的存储区有“输入”(I)、“输出” (Q)、“I/O” (P)、“位存储器” (M)、“临时本地数据” (L) 和“数据”(DB 或 DI)。如果操作数被载入数据块,那么必须为一般访问数据块,否则操作数必须有保留设置“在 IDB 中设置”。
在指令中,仅编写操作数宽度。可能的操作数宽度为位、字节、字和双字。
下列示例显示的是寄存器间接跨区域寻址的应用:
LAR1 P#M10.0 | // 将跨区域指针(P#M10.0)加载到地址寄存器 1 中 |
L W [AR1, P#2.0] | // 将地址寄存器 1 (P#M10.0) 中的数据增加偏移量 P#2.0 中的值。 // 将存储器字“MW12”内容加载到累加器 1 中 |
LAR1 P#A10.0 | // 将跨区域指针 (P#A10.0) 加载到地址寄存器 1 中 |
L W [AR1, P#2.0] | // 将地址寄存器 1 (P#A10.0) 中的内容增加偏移量 P#2.0 中的值。 // 将输出字 QW12.0 的内容加载到累加器 1 中 |
说明 S7-1500 中的特性 在 S7-1500 中,特殊规则通过地址寄存器和数据块寄存器应用于数据交换: 在块之外,寄存器中的值不再存在。块中的语言改变时,寄存器也将复位。 如果通过寄存器间接寻址访问 BYTE、WORD 或 DWORD 类型的操作数,则地址必须以字节限制开始。 示例: LAR1 P#0.0 L MW [AR1, P#0.0] // P#0.0 + P#0.0 = P#0.0 - 允许寻址,因为 P#0.0 指向字节限制。 L MW [AR1, P#2.1] // P#0.0 + P#2.1 = P#2.1 - 不允许寻址,因为 P#2.1 没有指向字节限制。 |