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  <20212022  2023  2024  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  <20212022  2023  2024 
<== Date ==> <== Thread ==>

Subject: RE: Asyn Stopping Transfer Short
From: Iain Marcuson via Tech-talk <tech-talk at aps.anl.gov>
To: Mark Rivers <rivers at cars.uchicago.edu>
Cc: EPICS Tech-Talk <tech-talk at aps.anl.gov>
Date: Tue, 30 Mar 2021 18:54:31 +0000

It is a TCP port.  I had the noProcessEos flag at 1.  Setting it to 0 results in me getting a full count of the pixel data.

 

From: Mark Rivers <rivers at cars.uchicago.edu>
Sent: Tuesday, March 30, 2021 2:23 PM
To: Iain Marcuson <iain.marcuson at sydortechnologies.com>
Cc: EPICS Tech-Talk <tech-talk at aps.anl.gov>
Subject: RE: Asyn Stopping Transfer Short

 

Hi Iain,

 

Is this a TCP port or a UDP port?

 

What arguments did you pass to drvAsynIPPortConfigure?  Did you leave the noProcessEos flag at the default of 0, or did you set it to 1?  You should leave it at 0.  This may seem counterintuitive, since you are presumably not setting an input EOS string for the binary payload data.  However, the asynInterposeEos does not just do EOS processing, it also does the buffering required to read a specific number of input bytes when that data might span multiple network packets.

 

Mark

 

 

From: Tech-talk <tech-talk-bounces at aps.anl.gov> On Behalf Of Iain Marcuson via Tech-talk
Sent: Tuesday, March 30, 2021 12:48 PM
To: tech-talk at aps.anl.gov
Subject: Asyn Stopping Transfer Short

 

I am running an AreaDetector program based off of Mythen.  The protocol is for the IOC to listen to a socket, first reading two headers, then the payload.  The headers appear to be read correctly, as the reported image size and byte count are correct.  However, the IOC usually doesn’t read the requested number of bytes; the number seems random, and on one occasion a full frame was read.  However, the return value and EOM value from asynOctetSyncIO are zero for the first payload transaction.  Future reads return a timeout, as corrupted headers result in large reads that are not met by the data source.  Is there a buffer option or similar I am missing?

 

Iain Marcuson

Software Engineer, Sydor Technologies

585.278.1168 | www.SydorTechnologies.com

Skype: iain.marcuson at sydorinstruments.com

 

 

This message has been scanned for malware by Forcepoint. www.forcepoint.com

 

Click here to report this email as spam.


References:
Asyn Stopping Transfer Short Iain Marcuson via Tech-talk
RE: Asyn Stopping Transfer Short Mark Rivers via Tech-talk

Navigate by Date:
Prev: RE: Asyn Stopping Transfer Short Mark Rivers via Tech-talk
Next: Re: Questions about arrays William Layne 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  <20212022  2023  2024 
Navigate by Thread:
Prev: RE: Asyn Stopping Transfer Short Mark Rivers via Tech-talk
Next: Question on Multiple Instruments in one IOC or Multiple IOCs for each Manoussakis, Adamandios 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  <20212022  2023  2024 
ANJ, 30 Mar 2021 Valid HTML 4.01! · Home · News · About · Base · Modules · Extensions · Distributions · Download ·
· Search · EPICS V4 · IRMIS · Talk · Bugs · Documents · Links · Licensing ·