网络继电器的EPICS IOC搭建
http://www.corxnet.com/product/showproduct.php?id=36
https://item.taobao.com/item.htm?spm=a1z10.5-c-s.w4002-21473915904.22.6e3c5ed08NWExp&id=520395007720

推荐这款可网络控制的继电器,16路继电器,16路IN,折腾了好几天在几位同事的帮助下终于把IOC调通了。基本的通过PV控制继电器的开关都调试成功,点控还没做,以后有空再做吧,如果看到的愿意做的可以继续做下去,不过labview程序把点控做好了,欢迎去下载:
https://gitee.com/lup9304/tuning-tools/blob/master/netio1.0.llb
这东西用起来很方便,比plc、西门子模块等方式搭建IO控制省事多了,一般的使用足够了,如果大电流大功率使用,可以自己外加继电器,用这个网络继电器控制外加的继电器即可。
具体怎么编译IOC,可以参看下面链接:
https://epics.anl.gov/modules/soft/asyn/R4-24/HowToDoSerial/HowToDoSerial_StreamDevice.html
需要socket通信,在上面链接里加dbd这一步时:HPE3631Atest_DBD += drvAsynSerialPort.dbd,换成:drvAsynIPPort.dbd就好了。
之后就是编写db、proto、st.cmd文件了。附上相关的文件,写的很不专业,欢迎大家下载使用并请修改的更简洁:
[ioc@localhost iocJDQ016]$ cat st.cmd
#!../../bin/linux-x86_64/JDQ016
#- You may have to change JDQ016 to something else
#- everywhere it appears in this file
< envPaths
epicsEnvSet "P" "HALF:BD:"
epicsEnvSet "R" "IO:"
epicsEnvSet("ETHER","192.168.1.18:50000")
cd "${TOP}"
## Register all support components
dbLoadDatabase "dbd/JDQ016.dbd"
JDQ016_registerRecordDeviceDriver pdbbase
epicsEnvSet "STREAM_PROTOCOL_PATH" "$(TOP)/db"
# Set up ASYN ports
#vxi11Configure("L0", "$(ETHER)", 0, 0.0, "inst0", 0)
drvAsynIPPortConfigure("L0", "$(ETHER)", 0, 0, 0)
## Load record instances
#dbLoadRecords("db/xxx.db","user=ioc")
dbLoadTemplate "db/bo.substitutions"
#dbLoadRecords("db/devJDQ016.db","P=$(P),R=$(R),PORT=L0,A=0")
cd "${TOP}/iocBoot/${IOC}"
iocInit
#var streamDebug 1
## Start any sequence programs
#seq sncxxx,"user=ioc"
[ioc@localhost iocJDQ016]$
[ioc@localhost db]$ cat bo.substitutions
# Example substitutions file
file "db/devJDQ016.db" {
pattern { P, R, PORT, A }
{ "HALF:", "BD:NetIO:", "L0", 0 }
}
file db/devJDQ016-bo.db {
pattern { P, R, Chan, Next, PORT, A }
{ "HALF:", "BD:NetIO:", 0, 1, "L0", 0 }
{ "HALF:", "BD:NetIO:", 1, 2, "L0", 0 }
{ "HALF:", "BD:NetIO:", 2, 3, "L0", 0 }
{ "HALF:", "BD:NetIO:", 3, 4, "L0", 0 }
{ "HALF:", "BD:NetIO:", 4, 5, "L0", 0 }
{ "HALF:", "BD:NetIO:", 5, 6, "L0", 0 }
{ "HALF:", "BD:NetIO:", 6, 7, "L0", 0 }
{ "HALF:", "BD:NetIO:", 7, 8, "L0", 0 }
{ "HALF:", "BD:NetIO:", 8, 9, "L0", 0 }
{ "HALF:", "BD:NetIO:", 9, A, "L0", 0 }
{ "HALF:", "BD:NetIO:", A, B, "L0", 0 }
{ "HALF:", "BD:NetIO:", B, C, "L0", 0 }
{ "HALF:", "BD:NetIO:", C, D, "L0", 0 }
{ "HALF:", "BD:NetIO:", D, E, "L0", 0 }
{ "HALF:", "BD:NetIO:", E, F, "L0", 0 }
{ "HALF:", "BD:NetIO:", F, 0, "L0", 0 }
}
[ioc@localhost db]$
[ioc@localhost db]$ cat devJDQ016.db
#
# Simple database and stream protocol file for basic SCPI (IEEE488.2) commands
#
#
# Short and long form of identification string
#
record(mbbiDirect, "$(P)$(R)Relay:mbbiD")
{
field(SCAN, "2 second")
field(DESC, "Relay open or close state")
field(DTYP, "stream")
field(INP, "@devJDQ016.proto readRelayState $(PORT)")
field(FLNK, "$(P)$(R)R1:bi")
}
record(mbbiDirect, "$(P)$(R)IN:mbbiD")
{
field(SCAN, "2 second")
field(DESC, "Input open or close state")
field(DTYP, "stream")
field(INP, "@devJDQ016.proto readInState $(PORT)")
field(FLNK, "$(P)$(R)IN0:bi")
}
record(bo, "$(P)$(R)Relay:SetAll")
{
field(DESC, "Control Relay open all")
field(DTYP, "stream")
field(OUT, "@devJDQ016.proto setAll $(PORT)")
field(ZNAM,"closeAll")
field(ONAM,"openAll")
field(FLNK, "$(P)$(R)Relay:mbbiD")
}
[ioc@localhost db]$
[ioc@localhost db]$ cat devJDQ016-bo.db
## Simple database and stream protocol file for basic SCPI (IEEE488.2) commands
#
#
# Short and long form of identification string
#
record(bi, "$(P)$(R)R$(Chan):bi")
{
field(DESC, "lost phase state")
field(INP, "$(P)$(R)Relay:mbbiD.B$(Chan) NPP")
field(ZNAM,"off")
field(ONAM,"on")
field(FLNK, "$(P)$(R)R$(Next):bi")
}
record(bi, "$(P)$(R)IN$(Chan):bi")
{
field(DESC, "lost phase state")
field(INP, "$(P)$(R)IN:mbbiD.B$(Chan) NPP")
field(ZNAM,"off")
field(ONAM,"on")
field(FLNK, "$(P)$(R)IN$(Next):bi")
}
record(bo, "$(P)$(R)R$(Chan):bo")
{
field(DESC, "Set Relay Chan$(Chan)")
field(DTYP, "stream")
field(ZNAM,"close")
field(ONAM,"open")
field(OUT, "@devJDQ016.proto setRelay$(Chan) $(PORT) $(A)")
field(FLNK, "$(P)$(R)Relay:mbbiD")
}
[ioc@localhost db]$
[ioc@localhost db]$ cat devJDQ016.proto
InTerminator = "";
OutTerminator = "";
setRelay0 {
out "\xCC\xDD\xA1\x01%{\x00\x00\x00\x01|\x00\x01\x00\x01}%2<sum>%2<sum>";
in "%s";
}
setRelay1 {
out "\xCC\xDD\xA1\x01%{\x00\x00\x00\x02|\x00\x02\x00\x02}%2<sum>%2<sum>";
in "%s";
}
setRelay2 {
out "\xCC\xDD\xA1\x01%{\x00\x00\x00\x04|\x00\x04\x00\x04}%2<sum>%2<sum>";
in "%s";
}
setRelay3 {
out "\xCC\xDD\xA1\x01%{\x00\x00\x00\x08|\x00\x08\x00\x08}%2<sum>%2<sum>";
in "%s";
}
setRelay4 {
out "\xCC\xDD\xA1\x01%{\x00\x00\x00\x10|\x00\x10\x00\x10}%2<sum>%2<sum>";
in "%s";
}
setRelay5 {
out "\xCC\xDD\xA1\x01%{\x00\x00\x00\x20|\x00\x20\x00\x20}%2<sum>%2<sum>";
in "%s";
}
setRelay6 {
out "\xCC\xDD\xA1\x01%{\x00\x00\x00\x40|\x00\x40\x00\x40}%2<sum>%2<sum>";
in "%s";
}
setRelay7 {
out "\xCC\xDD\xA1\x01%{\x00\x00\x00\x80|\x00\x80\x00\x80}%2<sum>%2<sum>";
in "%s";
}
setRelay8 {
out "\xCC\xDD\xA1\x01%{\x00\x00\x01\x00|\x01\x00\x01\x00}%2<sum>%2<sum>";
in "%s";
}
setRelay9 {
out "\xCC\xDD\xA1\x01%{\x00\x00\x02\x00|\x02\x00\x02\x00}%2<sum>%2<sum>";
in "%s";
}
setRelayA {
out "\xCC\xDD\xA1\x01%{\x00\x00\x04\x00|\x04\x00\x04\x00}%2<sum>%2<sum>";
in "%s";
}
setRelayB {
out "\xCC\xDD\xA1\x01%{\x00\x00\x08\x00|\x08\x00\x08\x00}%2<sum>%2<sum>";
in "%s";
}
setRelayC {
out "\xCC\xDD\xA1\x01%{\x00\x00\x10\x00|\x10\x00\x10\x00}%2<sum>%2<sum>";
in "%s";
}
setRelayD {
out "\xCC\xDD\xA1\x01%{\x00\x00\x20\x00|\x20\x00\x20\x00}%2<sum>%2<sum>";
in "%s";
}
setRelayE {
out "\xCC\xDD\xA1\x01%{\x00\x00\x40\x00|\x40\x00\x40\x00}%2<sum>%2<sum>";
in "%s";
}
setRelayF {
out "\xCC\xDD\xA1\x01%{\x00\x00\x80\x00|\x80\x00\x80\x00}%2<sum>%2<sum>";
in "%s";
}
set {
out "\xCC\xDD\xA1\x01\$1%2<sum>%2<sum>";
in "%s";
}
setAll {
out "\xCC\xDD\xA1\x01%{\x00\x00\xFF\xFF|\xFF\xFF\xFF\xFF}%2<sum>%2<sum>";
in "%s";
}
readRelayState {
wait 50;
out "\xCC\xDD\xB0\x01\x00\x00\x0D\xBE\x7C";
in "%*4c%2r[^\x0D]";
# in "\xAA\xBB\xB0\x01%2r\x0D%2<sum>%2<sum>";
}
readInState {
wait 50;
out "\xCC\xDD\xC0\x01\x00\x00\x0D\xCE\x9C";
# in "\xAA\xBB\xC0\x01%2x\x0D%2<sum>%2<sum>";
in "%*4c%2r[^\x0D]";
}
[ioc@localhost db]$
网络继电器的EPICS IOC搭建的更多相关文章
- [New learn] 网络基础-apache本地服务搭建(支持php)
1.简介 无网不利,无网不胜.对于移动应用来说离开网络那和咸鱼有什么分别?所以对于开发者来说更要学习好网络开发的技术. 2.搭建apache本地服务器 1.在finder中显示影藏的用户文件夹 fin ...
- 基于Ubuntu14.04下Suricata(一款高性能的网络IDS、IPS和网络安全监控引擎)的搭建(图文详解)(博主推荐)
为什么,要写这篇论文? 是因为,目前科研的我,正值研三,致力于网络安全.大数据.机器学习研究领域! 论文方向的需要,同时不局限于真实物理环境机器实验室的攻防环境.也不局限于真实物理机器环境实验室的大数 ...
- 基于CentOS6.5下Suricata(一款高性能的网络IDS、IPS和网络安全监控引擎)的搭建(图文详解)(博主推荐)
不多说,直接上干货! 为什么,要写这篇论文? 是因为,目前科研的我,正值研三,致力于网络安全.大数据.机器学习研究领域! 论文方向的需要,同时不局限于真实物理环境机器实验室的攻防环境.也不局限于真实物 ...
- linux中网络存储与考试系统搭建(实现多用户可以共享文件)
上期内容回顾 1.数据备份的方式有哪些 全量和增量 2.数据备份的命令有哪些 都有哪些优点缺点 cp : 本地复制,全量复制 scp : 远程复制,全量复制 rsync : 远程复制,增量复制 3.r ...
- 【网络】博客网站搭建之Typecho(命令版)
目录 前言 个人博客系统筛选 内网穿透 安装nginx 安装PHP 安装mysql Typecho 环境安装 参考 安装typecho Nginx与PHP进行连接配置&指定博客路径 验证 配置 ...
- UNIX网络编程卷1 - >环境搭建(ubuntu16.04)
学习unp网络编程,树上的例子均存在#include“unp.h”,故需要对环境进行配置. 1.到资源页下载www.unpbook.com 2.解压并将unpv13e移动到相应的文件夹下 (因为我 ...
- 搭建免费wifi,嗅探接入该wifi的所有网络信息
环境: 1: create_ap , 搭建免费wifi. 2: wireshark , 嗅探网络信息. 搭建热点 搭建热点: git clone https://github.com/oblique/ ...
- iOS网络1——NSURLConnection使用详解
原文在此 一.整体介绍 NSURLConnection是苹果提供的原生网络访问类,但是苹果很快会将其废弃,且由NSURLSession(iOS7以后)来替代.目前使用最广泛的第三方网络框架AFNetw ...
- openstack网络(neutron)模式之GRE的基本原理
neutron网络目的是为OpenStack云更灵活的划分网络,在多租户的环境下提供给每个租户独立的网络环境. neutron混合实施了第二层的VLAN和第三层的路由服务,它可为支持的网络提供防火墙, ...
- Maven学习 (四) 使用Nexus搭建Maven私服
为什么要搭建nexus私服,原因很简单,有些公司都不提供外网给项目组人员,因此就不能使用maven访问远程的仓库地址,所以很有必要在局域网里找一台有外网权限的机器,搭建nexus私服,然后开发人员连到 ...
随机推荐
- vivo霍金实验平台设计与实践-平台产品系列02
vivo 互联网平台产品研发团队 - Bao Dawei 本篇介绍了vivo霍金实验平台的系统架构以及业务发展过程中遇到的问题以及对应的解决方案. <平台产品>系列文章: 1.vivo平台 ...
- Training: ASCII
题目链接:http://www.wechall.net/challenge/training/encodings/ascii/index.php 让我们使用标准的美国信息交换编码格式解下面的ASCLL ...
- windows 搭建iis文件服务器
1.运行打开控制面板->程序->启用或关闭Windows功能,勾选下面所有的选项. 注意,必须安装功能所需文件. 等待 关闭即可. 2.在控制面板找到管理工具,不同版本的Windows不尽 ...
- 【每日一题】【字符串与数字互转】【去除空格】【大数处理】2021年12月12日-8. 字符串转换整数 (atoi)
请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数). 函数 myAtoi(string s) 的算法如下: ...
- VMware ESXi 8.0 SLIC & Unlocker 集成网卡驱动和 NVMe 驱动 (集成驱动版)
发布 ESXi 8.0 集成驱动版,在个人电脑上运行企业级工作负载 请访问原文链接:VMware ESXi 8.0 SLIC & Unlocker 集成网卡驱动和 NVMe 驱动 (集成驱动版 ...
- pycharm全局搜索
方法有:1.使用[Ctrl+N]快捷键按文件名搜索py文件: 2.使用[Ctrl+shift+N]快捷键按文件名搜索所有类型的文件: 3.使用[ctrl+shift+f]快捷全局字符串搜索: 3.使用 ...
- Prometheus及Grafana监控服务的安装使用
说明 Prometheus 是一个开放性的监控解决方案,通过 Node Exporter 采集当前主机的系统资源使用情况,并通过 Grafana 创建一个简单的可视化仪表盘. docker 安装 pr ...
- Linux基础第五章 进程控制
5.2 fork fork函数实现进程复制,类似于动物界的单性繁殖,fork函数直接创建一个子进程.这是Linux创建进程最常用的方法.在这一小节中,子进程概念指fork产生的进程,父进程指主动调用f ...
- 【RocketMQ】负载均衡源码分析
RocketMQ在集群模式下,同一个消费组内,一个消息队列同一时间只能分配给组内的某一个消费者,也就是一条消息只能被组内的一个消费者进行消费,为了合理的对消息队列进行分配,于是就有了负载均衡. 接下来 ...
- [C++标准模板库:自修教程与参考手册]关于vector
什么是vector 可以这样认为,vector就是一个动态的数组,其中的元素必须具备assignable(可赋值)和copyable(可拷贝)两个性质. vector的一些重要的性质 vector支持 ...