欧姆龙(Omron)协议解析

news2024/10/7 3:40:17

1. 协议概述
   欧姆龙(Omron)是来自日本的知名电子和自控设备制造商,其中、小型PLC在国内市场有较高的占有率,有CJ、CM等系列。PLC可以支持Fins、Host link等协议进行通信。

  支持以太网的欧姆龙PLC CPU、以太网通信模块根据型号的不同,一般都会持 FINS(Factory Interface Network Service)协议,一些模块也会支持EtherNet/IP协议。Omron fins协议缺省TCP/UDP端口号为9600。Fins协议封装在TCP/UDP之上,需要注意的是基于TCP的Fins数据包和基于UDP的包在头部上差异较大。协议的具体构造可以参考欧姆龙官方文档。

  FINS协议实现了OMRON PLC与上位机以太网通信。Fins基于TCP/UDP的报文的概览如下:

Fins over TCP
+-----------------------------------------------------------+
|  Fins/TCP Header  |         Fins over UDP(optional)       |
+-----------------------------------------------------------+
                     /                                    \
                    /              Fins over UDP           \  
                    +---------------------------------------+
                    |  Fins/UDP Header  |   Command Data    |
                    +---------------------------------------+

由上图可知,Fins/TCP实际上是将Fins/UDP报文作为其负载,在其前面加了一个Fins/TCP报头。需要注意的是,Fins/TCP报文中负载即Fins/UDP部分不一定会出现,它可以只有一个简单的Fins/TCP报头。

  先介绍Fins/UDP报文的组成,然后再介绍Fins/TCP结构。

2. 协议详解
2.1 Fins over UDP
  基于UDP的Fins协议的结构相对简单,整体结构由报头和数据两部分组成,如下所示:

Fins over UDP
+--------------------------+
|      Fins/UDP Header     |
+--------------------------+
|  Command Data(opitonal)  |
+--------------------------+

 其中报头部分为必要组成部分,为固定长度12个字节,数据部分非必现。

2.1.1 Fins/UDP Header
  报头部分由11个定长字段组合而成,前面10个字段分别简称为:ICF、RSV、GCT、DNA、DA1、DA2、SNA、SA1、SA2、SID,如下所示:

0         1           2          6                     7
+---------+-----------+----------+---------------------+
| Gateway | Data Type | Reserved |  Response setting   |
+------------------------------------------------------+
|                      Reserved                        |
+------------------------------------------------------+
|                    Gateway Counts                    |
+------------------------------------------------------+
|                Destination Network Address           |
+------------------------------------------------------+
|                Destination Node Number               |
+------------------------------------------------------+
|                Destination Unit Addres               |
+------------------------------------------------------+
|                 Source Network Address               |
+------------------------------------------------------+
|                   Source Node Number                 |
+------------------------------------------------------+
|                    Source Unit Addres                |
+------------------------------------------------------+
|                         Service Id                   |
+------------------------------------------------------+
|                       Command                        |
+                                                      +
|                       Code(2B)                       |
+------------------------------------------------------+

上述11个字段中,除最后一个Command Code字段为2个字节外,其余所有字段均只占1个字节。

2.1.2 Information control filed
  ICF,信息控制字段,1个字节,由4个子字段组成,分述如下:

1... .... = Gateway bit,是否使用网关,0x01表示使用;
.1.. .... = Data Type bit,数据类型比特位,0x01表示响应,0x00表示命令;
..0. .... = Reserved bit,保留比特位,默认置0;
...0 .... = Reserved bit,保留比特位,默认置0;
.... 0... = Reserved bit,保留比特位,默认置0;
.... .0.. = Reserved bit,保留比特位,默认置0;
.... ..0. = Reserved bit,保留比特位,默认置0;
.... ...1 = Response setting bit,响应标志,0x01表示非必需回应,0x00表示必须进行回应。


2.1.3 Reserved
  保留字段,1个字节,置为0x00。

2.1.4 Gateway count
  网关计数,1个字节,置为0x02。

2.1.5 Destination network address
  目标网络地址,1个字节,取值如下:

  1.  00:表示本地网络;
  2.  0x01~0x7F:表示远程网络。

2.1.6 Destination node number
  目标节点编号,1个字节,取值如下:

  1.  0x01~0x3E: SYSMAC LINK网络中的节点号;
  2.  0x01~0x7E: YSMAC NET网络中的节点号;
  3.  0xFF: 广播传输。

  Omron的官方手册中,该字段只能取上述值,实际抓包有其它值出现,被wireshark标记为unknown。

2.1.7 Destination unit address
  目标单元地址,1个字节,取值如下:

  1. 0x00:PC(CPU);
  2. 0xFE: SYSMAC NET Link Unit or SYSMAC LINK Unit connected to network;
  3. 0x10~0x1F:CPU总线单元 ,其值等于10 + 单元号(前端面板中配置的单元号)。

  Omron的官方手册中,该字段只能取上述值,实际抓包有其它值出现,被wireshark标记为unknown。

2.1.8 Source network address
  源网络地址,1个字节,取值如下:

  1. 0x00:表示本地网络;
  2. 0x01~0x7F:表示远程网络。

2.1.9 Source node number
  源节点编号,1个字节,取值如下:

  1. 0x01~0x3E: SYSMAC LINK网络中的节点号;
  2. 0x01~0x7E: YSMAC NET网络中的节点号;
  3. 0xFF: 广播传输

Omron的官方手册中,该字段只能取上述值,网上的实际抓包发现会有其它值出现,被wireshark标记为unknown。

2.1.10 Source unit address
  源单元地址,1个字节,取值如下:

  1. 0x00:PC(CPU);
  2. 0xFE: SYSMAC NET Link Unit or SYSMAC LINK Unit connected to network;
  3. 0x10~0x1F:CPU总线单元 ,其值等于10 + 单元号(前端面板中配置的单元号)。

Omron的官方手册中,该字段只能取上述值,实际抓包有其它值出现,被wireshark标记为unknown。

2.1.11 Service ID
  服务ID,1个字节,取值0x00~0xFF,产生会话的进程的唯一标识。

2.1.12 Command Code字段
  2个字节,其取值由第一个字节表示的大分类和第二个字节表示的子分类复合而成,取值及其含义如下表:

Command CodeEnglish Explanation中文解释
0x0101MEMORY AREA READ内存区域读取
0x0102MEMORY AREA WRITE内存区域写入
0x0103MEMORY AREA FILL内存区域填充
0x0104MULTIPLE MEMORY AREA READ多内存区域读取
0x0105MEMORY AREA TRANSFER内存区域传输
0x0201PARAMETER AREA READ参数区域读取
0x0202PARAMETER AREA WRITE参数区域写入
0x0203PARAMETER AREA CLEAR参数区域清除
0x0220DATA LINK TABLE READ数据链表读取
0x0221DATA LINK TABLE WRITE数据链表写入
0x0304PROGRAM AREA PROTECT程序区保护
0x0305PROGRAM AREA PROTECT CLEAR程序区保护清除
0x0306PROGRAM AREA READ程序区读取
0x0307PROGRAM AREA WRITE程序区写入
0x0308PROGRAM AREA CLEAR程序区清除
0x0401RUN运行
0x0402STOP停止
0x0403RESET重置
0x0501CONTROLLER DATA READ控制器数据读取
0x0502CONNECTION DATA READ连接数据读取
0x0601CONTROLLER STATUS READ控制器状态读取
0x0602NETWORK STATUS READ网络状态读取
0x0603DATA LINK STATUS READ数据链接状态读取
0x0620CYCLE TIME READ循环次数读取
0x0701CLOCK READ时钟读取
0x0702CLOCK WRITE时钟写入
0x0801LOOP-BACK TEST/INTERNODE ECHO TEST环路测试/内部节点测试
0x0802BROADCAST TEST RESULTS READ广播测试结果读取
0x0803BROADCAST TEST DATA SEND广播测试数据发送
0x0920MESSAGE READ消息读取
0x0921MESSAGE CLEAR消息清除
0x0C01ACCESS RIGHT ACQUIRE访问权限获取
0x0C02ACCESS RIGHT FORCED ACQUIRE访问权限强制获取
0x0C03ACCESS RIGHT RELEASE访问权限释放
0x2101ERROR CLEAR错误清除
0x2102ERROR LOG READ错误日志读取
0x2103ERROR LOG CLEAR错误日志清除
0x2201FILE NAME READ文件名读取
0x2202SINGLE FILE READ单文件读取
0x2203SINGLE FILE WRITE单文件写入
0x2204MEMORY CARD FORMAT记忆卡格式化
0x2205FILE DELETE文件删除
0x2206VOLUME LABEL CREATE/DELETE卷标创建/删除
0x2207FILE COPY文件复制
0x2208FILE NAME CHANGE文件名更改
0x2209FILE DATA CHECK文件数据核查
0x220AMEMORY AREA FILE TRANSFER内存区域文件传输
0x220BPARAMETER AREA FILE TRANSFER参数区域文件传输
0x220CPROGRAM AREA FILE TRANSFER程序区域文件传输
0x220DFILE MEMORY INDEX READ文件内存索引读取
0x2210FILE MEMORY READ文件内存读取
0x2211FILE MEMORY WRITE文件内存写入
0x2301FORCED SET/RESET强制设置/重置
0x2302FORCED SET/RESET CANCEL取消强制设置/重置
0x230AMULTIPLE FORCED STATUS READ多强制状态读取
0x2601NAME SET名称设置
0x2602NAME DELETE名称删除
0x2603NAME READ名称读取

合计:14个大类,57个子类,共57个Command Code。

2.2 Fins Over TCP
  基于TCP的FINS报文结构也不复杂,无非就是一个FINS/TCP头部(必选),加上FINS/UDP报文(可选),如下所示:

Fins over TCP
+----------------------------------------+
|             Fins/TCP Header            |
+----------------------------------------+
|    Fins/UDP Header(not neccessary)     |
+----------------------------------------+
|      Command Data(not neccessary)       |
+----------------------------------------+

2.2.1 Fins/TCP Header
  Fins/TCP的报头与Fins/UDP不同的是,它由4个固定字段和2个可选字段组成,如下所示:

Fins/TCP Header
0                                                     31
+---------+-----------+----------+---------------------+
|                    Magic Bytes                       |
+------------------------------------------------------+
|                      Length                          |
+------------------------------------------------------+
|                      Command                         |
+------------------------------------------------------+
|                     Error Code                       |
+------------------------------------------------------+
|            Client Node Address(optional)             |
+------------------------------------------------------+
|            Server Node Address(optional)             |
+------------------------------------------------------+

2.2.2 Magic
  其ASCII码(0x46494E53)是单词‘FINS’,值是固定的。

2.2.3 Length
  Length 的值表示其后所有字段(包括可能出现的Fins/UDP包)的总长度

       Length 的值等于TCP负载的总长度减去8个字节。

2.2.4 Command
  Command 表示消息中随附的命令的类型。

       这个字段的取值直接决定了后续可选的字段Client Node Address、Server Node Address是否出现,具体情况如下所示:

1)0x00000000:Node Address Data Send(client to server),此时仅有Client Node Address字段;

(2)0x00000001: Node Address Data send(Server to client)(0x00000001),此时Client/Server Node Address字段均出现;

(3)其它:不会出现上述两个字段。


2.2.5 Error Code
  Error Code 表示错误代码,提示发送的数据包是否有错误。根据 wireshark源代码所提供的信息,错误代码目前共定义了10种类型,如下所示:

错误码对应含义
0x00000000Normal
0x00000001The header is not ‘FINS’ (ASCII code)
0x00000002The data length is too long
0x00000003The command is not supported
0x00000020All connections are in use
0x00000021The specified node is already connected
0x00000022Attempt to access a protected node from an unspecified IP address
0x00000023The client FINS node address is out of range
0x00000024The same FINS node address is being used by the client and server
0x00000025All the node addresses available for allocation have been used

2.2.6 Client Node Address  

1. 设备识别

  • Client Node Address 用于唯一标识网络中的每个客户端设备。它确保数据能够正确地发送到特定的客户端。

2. 通信管理

  • 在进行数据传输时,FINS 协议通过 Client Node Address 确定目标设备,从而实现不同设备之间的有效通信。

3. 多节点支持

  • FINS 协议允许多个客户端在同一网络中同时存在。每个客户端通过其唯一的 Node Address 进行区分,这使得系统可以支持复杂的多节点通信。

4. 地址范围

  • Client Node Address 通常是一个范围在 0 到 254 之间的整数(某些情况下可能更具体,具体取决于网络设置)。地址 0 通常用于广播。       

示例

  • 在一个工厂自动化系统中,PLC 可能使用 Client Node Address 1,而传感器可能使用 Client Node Address 2。通过这些地址,PLC 可以向特定的传感器发送数据请求或指令。

       Fins/TCP协议的客户端/服务器在传输有效的命令数据之前,由客户端先向服务器发送一个包含Client Node Address字段的报文申请节点地址。由于客户端申请的时候还没有节点地址,因此该字段被置为0x00000000。     

2.2.7 Server Node Address
  

1. 设备识别

  • Server Node Address 用于唯一标识网络中的每个服务器设备(例如 PLC、I/O 设备、HMI 等)。它确保请求能够正确地发送到特定的服务器。

2. 通信管理

  • 在 FINS 协议中,客户端(如 PC 或控制器)通过 Server Node Address 确定目标服务器,以便发送数据请求或指令。

3. 多节点支持

  • FINS 协议支持在同一网络中存在多个服务器。每个服务器都有其唯一的 Server Node Address,这使得系统能够同时处理多个客户端请求。

4. 地址范围

  • Server Node Address 通常是一个范围在 0 到 254 之间的整数(某些情况下可能更具体,具体取决于网络设置)。地址 0 通常用于广播,允许客户端向网络中的所有服务器发送请求。

示例:在一个工厂自动化系统中,PLC 可能使用 Server Node Address 1,而另一个控制器可能使用 Server Node Address 2。客户端通过这些地址与特定的服务器进行通信,发送指令或获取数据。

        服务器收到客户端请求后,给客户端分配相应的节点地址并通告给客户端,同时在报文中包含服务器自己的节点地址信息

2.3 Command Data
   Fins/UDP、Fins/TCP协议的实际负载部分。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2193489.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

dockertop提示Failed to fetch extensions

解决办法:重装dockertop 第一步:卸载当前的dockertop 如果卸载过程中存在AlibabaProtect的相关软件关不掉,那么参考这篇文章:卸载AlibabaProtect 第二步:删除C:\Program Files路径下的Docker文件夹 第三步&#xff1…

代码随想录Day 62|Floyd 算法精讲、A \* 算法精讲 (A star算法),题目:97. 小明逛公园、127. 骑士的攻击

提示:DDU,供自己复习使用。欢迎大家前来讨论~ 文章目录 图论part11Floyd 算法精讲题目:97. 小明逛公园解题思路: A \* 算法精讲 (A star算法)题目:127. 骑士的攻击问题描述算法选择解题思路C代…

什么是重卡充电桩?

有什么广告?没有广告,纯纯的介绍。 在政策与市场双重驱动下,充电桩市场已经开启加速模式,行业的火苗越烧越旺。同时,随着新能源重卡的广泛普及,重卡充电桩也迎来了新的发展机遇。 此种背景下 &#xff0c…

Pikachu-敏感信息泄露

直接访问页面,查看页面源码 如:返回了测试账号信息; 例如:返回服务端的信息

仿RabbitMQ实现消息队列三种主题的调试及源码

文章目录 开源仓库和项目上线广播交换模式下的测试直接交换模式下的测试主题交换模式下的测试 开源仓库和项目上线 本项目已开源到下面链接下的仓库当中 仿RabbitMQ实现消息队列 广播交换模式下的测试 消费者客户端 在进行不同测试下,消费者客户端只需要改变交换机…

【Blender Python】4.获取场景对象的几种方式

概述 有时候我们需要获取场景中已经添加或存在的对象。本节就总结在Blender Python中获取场景中对象的一些方法。 通过名称获取 py.data的objects()方法返回一个对象集合,可以使用键名或者下标形式获取具体的对象。 在默认新建的场景中,存在三个对象…

初始Linux(二)基础命令

前言: 之前那一篇我们已经介绍了一部分的基础命令,当然那只不过是九牛一毛,本篇我们继续介绍一些比较重要且需要掌握的基础命令。 mv命令: 其实这个命令有两个功能,一个是移动(剪切)文件&#…

可查询全部快递api接口分析

使用三方平台该API接口需要先注册后申请此API接口。申请后可直接在线请求接口数据。 该api接口可自动识别单号信息。调用简单方便,性价比高,一条链接即可。 API接口地址为:https://www.tanshuapi.com/market/detail-68 其中,KEY…

掌握嵌套子查询:复杂 SQL 中 * 列的准确表列关系

在日常开发中,我们常常需要对复杂的 SQL 进行数据血缘分析。 本文重点讨论在具有 * 列的嵌套子查询中建立表和列之间正确关系的挑战。使用 Teradata SQL 代码示例来说明该过程。 本文聚焦于一个别名为 SUBSCRIBER_ 的子查询及其派生的列,这些列在外层查…

【Canvas与艺术】玻璃光小红灯

【成图】 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><title>玻璃光红灯Draft1</title><style type"text/css"…

RFID学习

24.10.5学习目录 一.简介1.组成2.RFID协议3.RFID卡 一.简介 RFID被称为无线射频识别&#xff0c;其是一种通信技术&#xff0c;通过无线电讯号耦合识别特定目标并读写相关数据&#xff1b; RFID主要位于典型物联网架构中的感知层&#xff0c;其因为具有非接触式特性&#xff…

数据结构与算法篇(树 - 常见术语)

目录 一、什么是树&#xff1f; 二、相关术语 根结点 边 叶子结点 兄弟结点 祖先结点 结点的大小 树的层 结点的深度 结点的高度 树的高度 斜树 一、什么是树&#xff1f; 树是一种类似于链表的数据结构&#xff0c;不过链表的结点是以线性方式简单地指向其后继结…

STM32驱动直流电机

stm32通过PWM控制直流电机的方向和速度。 小直流电机需要几百毫安的电流&#xff0c;单片机只能提供几毫安的电流。电机内线圈转动时切割磁感线以及电机内转子线圈的电感效应都会产生反电动势&#xff0c;损坏芯片。 电机驱动芯片能够作为STM32驱动电机的帮手。 SLEEP暂停工作…

Linux环境下的日志文件的实现

目录 日志 相关函数 time函数 localtime函数 va_list类型 vsnprintf函数 宏支持可变参数 __FILE__和__LINE__ 完整代码 Log.hpp 标记黏合操作符##&#xff08;重点&#xff09; LockGuard.hpp 日志 基本概念&#xff1a;用于记录软件运行时的信息&#xff0c…

数据结构与算法——Java实现 30.合并多个有序链表 小顶堆实现

后来我们都走了很久&#xff0c;远到提及往事时&#xff0c; 总会加上once upon a time —— 24.10.6 23. 合并 K 个升序链表 给你一个链表数组&#xff0c;每个链表都已经按升序排列。 请你将所有链表合并到一个升序链表中&#xff0c;返回合并后的链表。 示例 1&#xff1…

linux桌面软件(wps)内嵌到主窗口后的关闭问题

程序测试环境是&#xff1a;slackware系统&#xff0c;属于linux系统&#xff0c;有桌面&#xff08;Xface Session&#xff09;。系统镜像是&#xff1a;slackware64-15.0-install-dvd.iso。qt、c代码实现。 问题描述&#xff1a;延续上一篇文章&#xff0c;将wps软件窗口内嵌…

中断系统的原理

一、介绍 中断是为使单片机具有对外部或内部随机发生的事件实时处理而设置的。中断是指‌CPU在正常运行程序时&#xff0c;由于内部或外部事件的发生&#xff0c;导致CPU中断当前运行的程序&#xff0c;转而去执行其他程序的过程。‌ 中断可以是硬件产生的&#xff0c;也可以是…

神经网络激活函数列表大全及keras中的激活函数定义

一、概述 在机器学习中&#xff0c;激活函数是神经网络中的一种函数&#xff0c;用于在神经网络的每个神经元中引入非线性。没有激活函数&#xff0c;神经网络就无法学习复杂的模式&#xff0c;因为线性变换的组合仍然是线性的。 在神经网络的每层中&#xff0c;将该层所有输…

ElasticSearch备考 -- Multi match

一、题目 索引task有3个字段a、b、c&#xff0c;写一个查询去匹配这三个字段为mom&#xff0c;其中b的字段评分比a、c字段大一倍&#xff0c;将他们的分数相加作为最后的总分数 二、思考 通过题目要求对多个字段进行匹配查询&#xff0c;可以考虑multi match、bool query操作。…

计算机毕业设计 基于Python的人事管理系统的设计与实现 Python+Django+Vue 前后端分离 附源码 讲解 文档

&#x1f34a;作者&#xff1a;计算机编程-吉哥 &#x1f34a;简介&#xff1a;专业从事JavaWeb程序开发&#xff0c;微信小程序开发&#xff0c;定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事&#xff0c;生活就是快乐的。 &#x1f34a;心愿&#xff1a;点…