SKF MB350g3 Chopper - ISISComputingGroup/ibex_developers_manual GitHub Wiki
Wiki > The Backend System > Specific Device IOC > Choppers > SKF MB350g3 Chopper
The SKF MB350g3 chopper is a fermi chopper located on the EMMA beamline and was previously used on the LET beamline. The chopper is mounted on a lifting mechanism detailed here.
It's possible that the controller may need to be reset (press RESET
button on front panel) after power-on or other condition. The display will show INHIBIT
in this case and READY
after resetting. The indicator marked READY
on the OPI will be initially unlit and then lit afterwards.
Physical setup
Original configuration: NDXLET <---Ethernet---> AnyWhereUSB <---USB/RS232---> SeaLevel RS232-RS485 converter <---RS485---> MB350PC
New configuration: NDXLET <---Ethernet---> MOXA NPort <---RS232---> Patton RS232-RS485 converter <---RS485---> MB350PC
Notes: Originally, the passive RS232-RS485 converter could not be made to work correctly despite much effort, so an alternative, more convoluted solution was adopted in the hope that the original design could be reinstated at a later date. This alternative solution involved a "SeaLevel SeaLink USB serial adapter" (RS232-RS485 converter) connected to a "Digi USBAnywhere" (remote USB hub over Ethernet).
This worked well for many cycles, however, the USBAnywhere box suddenly developed a regular problem in that it appeared to lose connection to the chopper controllers every couple of days. Suspected causes are a network scan (either for security or inventory) or a driver issue for the USBAnywhere or SeaCOM converter. The remedy was to reboot the USBAnywhere box either using the utility on NDXLET or by power-cycling the unit.
New solution follows the original design to use a passive converter (Patton 2085) in circuit with the serial line between the MOXA and chopper controller. This removes the dependency on additional Windows drivers for extra hardware (AnyWhere USB & SeaLink) and simplifies the cabling as a MOXA is already present.
Switch settings for Patton 2085 Converter:
DCE / DTE switch: DCE selected
DIP switches: (All off originally, but this configuration seems to work also) 1: Off 2: Off 3: On 4: Off 5: On 6: Off 7: Off 8: Off
DB9M Pin to 2085 terminal connections: 1 -> RCV- 2 -> RCV+ 3 -> XMT+ 4 -> XMT- 5 -> G
Software setup
From a software setup point of view this can be treated as a standard serial device. It needs a COM port and all the usual COM settings to talk to (Baud, parity etc.). From testing on EMMA, the defaults in st.cmd are ok.
Software
The driver for this chopper has a couple of peculiarities:
Serial breaks
The device requires the changes in https://github.com/ISISComputingGroup/EPICS-asyn/pull/6 and the following lines in its st.cmd:
$(IFNOTDEVSIM) $(IFNOTRECSIM) asynSetOption("L0", -1, "break_duration", "20")
$(IFNOTDEVSIM) $(IFNOTRECSIM) asynSetOption("L0", -1, "break_delay", "20")
These lines tell it to sleep for 20ms and then send a serial break for 20ms after every message. If these items are not done then the chopper will not respond to messages.
Custom checksum
The device implements a custom checksum algorithm which has been implemented in https://github.com/ISISComputingGroup/EPICS-StreamDevice/pull/3 and also in the lewis emulator
Packet format
The device sends and receives a modbus-like (but not actually modbus) packet. This is a packet of binary data which contains various data from the chopper
Addressing
The chopper can be set up on a multi-drop setup. The first byte of every packet to/from the chopper contains the address of the chopper which is an integer between 0 and 15.