Intro
The ESTHER Slow Controller system controls the gas injection into the combustion chamber of the shock tube. This system uses the EPICS framework to communicate with a Siemens SIMANTIC S7-1200 PLC using the Open Source EPICS Device Support Library s7nodave. A Control System Studio graphic user interface client is used to visualize and control the whole experiment by connection with the EPICS IOC server.
This tutorial is presented as a reference to setup a server computer running an EPICS server that connects to the S7 PLC. An example EPICS IOC "testS7" application and accompanying CSS interface are provided. This example application allows the control and observation of all digital IO and analog inputs of the connected S7-1200 PLC.
Getting Started
Setup Supervisor Example EPICS Server
 - Install clean Debian 7.7.0 32-bit distribution on a computer or virtual machine with bridged network adapter
- Compile EPICS Base:  - Follow the Getting Started of http://epics.nsls2.bnl.gov/debian/
- apt-get install epics-dev build-essential
- apt-get install epics-synapps-dev epics-iocstats-dev visualdct openjdk-6-jdk sysv-rc-softioc
- The latest EPICS base version is then installed to /usr/lib/epics
 
- Install s7nodave device support library  - cd /opt/epics/modules
- wget -c http://oss.aquenos.com/epics/s7nodave/download/s7nodave-1.0.3.tar.gz -O - | tar -zx
- cd s7nodave-1.0.3/
- vi configure/RELEASE
- Replace "EPICS_BASE=/usr/lib/epics" or add to the end of the file
- Save and exit
- Install libboost if needed: apt-get install libboost-all-dev
- make
- cd ..
- Create symbolink link to folder: ln -s ./s7nodave-1.0.3/ s7nodave
 
- Install the EPICS state-machine sequencer library  - wget -c http://www-csr.bessy.de/control/SoftDist/sequencer/releases/seq-2.1.17.tar.gz -O - | tar -zx
- cd seq-2.1.17/ 
- vi configure/RELEASE
- Replace "EPICS_BASE=/usr/lib/epics" or add to the end of the file
- Install lexer generator tool re2c: apt-get install re2c
- make
- cd ..
- Create symbolink link to folder: ln -s ./seq-2.1.17/ seq
 
- Add testS7 project from the SVN repository  - apt-get install subversion
- svn co http://metis.ipfn.ist.utl.pt/svn/cdaq/ESTHER/Software/EPICS/IOC/testS7/
- cd testS7/
- Set the correct library dependencies for the modules:  - vi configure/RELEASE
- Replace or add "SNCSEQ=/opt/epics/modules/seq"
- Replace or add "S7NODAVE=/opt/epics/modules/s7nodave"
- Replace or add "EPICS_BASE=/usr/lib/epics"
- Save and exit
 
- make
 
- Execute the testS7 example IOC  - cd iocBoot/ioctests7/
- ./st.cmd
 
 
testS7 IOC Example Application
The EPICS testS7 IOC Application consists in the following sections:
 - A database file containing the records of the process variables for the expected IOC application. These are in the ./tests7App/Db/dbS7.db file.
- The state-machine sequencer program that is located in the ./tests7App/src/snctests7.stt file.
 
In thisexample IOC application, all the available S7-1200 PLC digital and analog IO are set in the application database records.
The standard S7-1200 PLC contains 10 digital outputs ports, 14 digital inputs ports and 2 analog inputs ports.
The digital inputs and outputs can only have the values 1 or 0 and must be read by the IOC application using a binary in (bi) or written to using a binary out (bo) record.
A PLC digital input port can only be read and not written to, so only a bi record is set in the IOC application database.
A PLC digital output port can be both read and written to. This means that to read the status of the PLC digital output, the IOC application must use the bi record for that PLC port. And to set the status of that port, the IOC application must use the corresponding bo port.
The mnemonic to consider here is that the bi and bo records correspond to what is being read or written by the IOC application, and not the PLC.
 
In the case of the S7-1200 PLC, the port is for each record is defined by setting the value "@myPLC Q0.1" in the INP or OUT fields, for example. In this case the "myPLC" value is the alias given to the PLC in the iocBoot/ioctests7/st.cmd file (s7nodaveConfigureIsoTcpPort("myPLC", "192.168.0.1", 0)), and the Q0.1 corresponds to the digital output group 0, bit 1.
 
The S7-1200 PLC have the following address aliases:
Digital Outputs (prefix Q):
Group 0 bit 0 -> Q0.0
...
Group 0 bit 7 -> Q0.7
Group 1 bit 0 -> Q1.0
Group 1 bit 1 -> Q1.1
Digital Inputs (prefix I):
Group 0 bit 0 -> I0.0
...
Group 0 bit 7 -> I0.7
Group 1 bit 0 -> I1.0
Group 1 bit 6 -> I1.5
Analog Inouts:
Analog Input 0 -> IW64
Analog Input 1 -> IW66
 
 
All the input records in the database have a SCAN field. The IOC application will scan the value of each record at the interval defined in the SCAN field. For a SCAN field of "0.1 second" of a input record, the IOC application will query the PLC for that record's value once every 100 miliseconds. By setting the SCAN field of every bi record in this way, the IOC  A SCAN field with the value "I/O Intr"
 
 
 
 
 
 
 
 -------- IGNORE --------
 
 Download EPICS Base R3.14.12 or higher:
-   - Most recent: http://www.aps.anl.gov/epics/download/base/index.php
- Or: http://www.aps.anl.gov/epics/download/base/baseR3.14.12.4.tar.gz
 
- Compile EPICS  - Dependencies:  - apt-get install g++
- Follow the Getting Started of http://epics.nsls2.bnl.gov/debian/
-  apt-get install epics-dev build-essential 
-    
 
 
 
 -   - cd /tmp/
-  wget -c http://www.aps.anl.gov/epics/downloa...14.12.4.tar.gz -O - | tar -zx 
-    cp -r base-3.14.12.4/ /usr/lib/epics/ 
-  cd /usr/lib/epics/ 
-  export EPICS_HOST_ARCH=$(perl startup/EpicsHostArch.pl)  
- make clean uninstall
- make 
 
-   - Install Asyn driver  - mkdir /opt/epics
- mkdir /opt/epics/modules
- cd /opt/epics/modules
- wget -c http://www.aps.anl.gov/epics/downloa...syn4-24.tar.gz -O - | tar -zx
- cd asyn4-24
- ech
 
   
-