EPICS Controls Argonne National Laboratory

Experimental Physics and
Industrial Control System

1994  1995  1996  1997  1998  1999  2000  2001  2002  2003  2004  2005  2006  2007  2008  2009  2010  2011  2012  2013  2014  2015  2016  2017  2018  2019  2020  2021  2022  <20232024  Index 1994  1995  1996  1997  1998  1999  2000  2001  2002  2003  2004  2005  2006  2007  2008  2009  2010  2011  2012  2013  2014  2015  2016  2017  2018  2019  2020  2021  2022  <20232024 
<== Date ==> <== Thread ==>

Subject: RE: modbus ioc start
From: Mark Rivers via Tech-talk <tech-talk at aps.anl.gov>
To: Dale Cox <dale.cox at acu.edu>, "tech-talk at aps.anl.gov" <tech-talk at aps.anl.gov>
Date: Thu, 13 Apr 2023 21:38:21 +0000

Hi Dale,

 

  • My issue is that the PV values aren't being updated when the IOC starts -- meaning that after the IOC start, the bo and mbbo values stored in that register don't match what was returned via the initial modbus request.

 

I am not sure I completely understand what you are saying.  Here is what should happen:

 

  1. Because this port you created uses function code 6 (write single register) and because you have a non-zero poll time, the driver will do one initial read of that register using function code 3.
  2. EPICS device support for the bo records does a read operation from the port during init_record.  If this read returns asynSuccess (which it should) then the value of the bo record is set to the value read from the driver.  This is the “bumpless reboot” concept.
  3. You have not set PINI=YES in these records, so the value from the record will not be written back to the device during iocInit.  However, the record value should still match the device, because of steps 1 and 2 above.

 

If I understand correctly you are saying that the bo record does have the correct value read from the device during steps 1-2.  But now the device has a different value from that in the record?  I don’t understand that, since it seems like there must have been a write to the device to change the value?

 

Mark

 

 

From: Tech-talk <tech-talk-bounces at aps.anl.gov> On Behalf Of Dale Cox via Tech-talk
Sent: Thursday, April 13, 2023 8:29 AM
To: tech-talk at aps.anl.gov
Subject: modbus ioc start

 

Good Morning,

 

I have an IOC that is currently reading registers via modbus rtu over rs485.  There are a set of registers that store multiple configuration options in a single register.  I set up the port using this line:

 

> drvModbusAsynConfigure("Z8TC1_Config", "SenecaBus", 5, 6, 53, 4, "UINT16", 100, "SenecaZ")

 

I've enabled the debugging lines on this IOC. When the IOC starts, I can see that the correct registers are being retrieved when the port is created.  I can also write config changes to those registers at their assigned PV's with no issues that I have found.  My issue is that the PV values aren't being updated when the IOC starts -- meaning that after the IOC start, the bo and mbbo values stored in that register don't match what was returned via the initial modbus request.

 

Here are a couple of the DB entries that I'm using:

 

record(bo,"$(P)$(R)-TC1_enable") {
    field(DTYP,"asynUInt32Digital")
    field(OUT,"@asynMask($(PORT), 0, 0x8000 )")
    field(ZNAM,"Disabled")
    field(ONAM,"Enabled")
}

record(bo,"$(P)$(R)-TC2_enable") {
    field(DTYP,"asynUInt32Digital")
    field(OUT,"@asynMask($(PORT), 0, 0x4000 )")
    field(ZNAM,"Disabled")
    field(ONAM,"Enabled")
}

record(bo,"$(P)$(R)-TC1-2_units") {
    field(DTYP,"asynUInt32Digital")
    field(OUT,"@asynMask($(PORT), 0, 0x2000 )")
    field(ZNAM,"tempDegC")
    field(ONAM,"mV")
}

 

Any help is appreciated.

 

Dale 

 

--

Dale Cox

Instrumentation and Electrical Engineer

ACU NEXT Lab 


Replies:
Re: modbus ioc start Dale Cox via Tech-talk
References:
modbus ioc start Dale Cox via Tech-talk

Navigate by Date:
Prev: RE: areadetector on windows, xml2 done, now Lightfield Mark Rivers via Tech-talk
Next: Re: Is the Sequencer and SNL still widely used? LEI Ge via Tech-talk
Index: 1994  1995  1996  1997  1998  1999  2000  2001  2002  2003  2004  2005  2006  2007  2008  2009  2010  2011  2012  2013  2014  2015  2016  2017  2018  2019  2020  2021  2022  <20232024 
Navigate by Thread:
Prev: modbus ioc start Dale Cox via Tech-talk
Next: Re: modbus ioc start Dale Cox via Tech-talk
Index: 1994  1995  1996  1997  1998  1999  2000  2001  2002  2003  2004  2005  2006  2007  2008  2009  2010  2011  2012  2013  2014  2015  2016  2017  2018  2019  2020  2021  2022  <20232024 
ANJ, 14 Apr 2023 Valid HTML 4.01! · Home · News · About · Base · Modules · Extensions · Distributions · Download ·
· Search · EPICS V4 · IRMIS · Talk · Bugs · Documents · Links · Licensing ·