EPICS Home

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  <20222023  2024  2025  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  <20222023  2024  2025 
<== Date ==> <== Thread ==>

Subject: Re: Change PVA structure dynamically during IOC operation
From: Andrew Johnson via Tech-talk <tech-talk at aps.anl.gov>
To: "Kasemir, Kay" <kasemirk at ornl.gov>, "tech-talk at aps.anl.gov" <tech-talk at aps.anl.gov>, "Alnajjar, Dawood" <dnajjar at slac.stanford.edu>
Date: Wed, 28 Sep 2022 13:31:56 -0500
On 9/28/22 1:25 PM, Kasemir, Kay via Tech-talk wrote:
> I need to change a PVA structure dynamically during IOC operation. Looking at pvxs::ioc::server, I do not see an update function that allows that. Does anyone know if this is possible?

I don't think that's possible.

If you check the protocol documentation, https://github.com/epics-base/pvAccessCPP/wiki/protocol, you'll find that the overall structure information is exchanged once when a client connects. From then on, only a compact bitmap that indicates what changed is sent, plus the modified values.
To change the structure, the protocol would have to send the complete new structure.
Arrays can change the number of elements, but the overall structure stays the same because the protocol was optimized for this.
PVA does support unions though, and an "any" type, so assuming you can design all the versions of the structure that you will need up front (and that the pvxs implementation supports them) you should be able to use them to make changes to your PVA structure without having to withdraw and re-add the PV. I believe a union will be more efficient than using an "any".

- Andrew
-- 
Complexity comes for free, Simplicity you have to work for.



Replies:
Re: [EXTERNAL] Re: Change PVA structure dynamically during IOC operation Kasemir, Kay via Tech-talk
References:
Change PVA structure dynamically during IOC operation Alnajjar, Dawood via Tech-talk
Re: Change PVA structure dynamically during IOC operation Kasemir, Kay via Tech-talk

Navigate by Date:
Prev: Re: Change PVA structure dynamically during IOC operation Alnajjar, Dawood via Tech-talk
Next: Re: Change PVA structure dynamically during IOC operation Kasemir, Kay 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  <20222023  2024  2025 
Navigate by Thread:
Prev: Re: Change PVA structure dynamically during IOC operation Kasemir, Kay via Tech-talk
Next: Re: [EXTERNAL] Re: Change PVA structure dynamically during IOC operation Kasemir, Kay 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  <20222023  2024  2025