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 2023 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 2022 2023 2024 2025 |
<== Date ==> | <== Thread ==> |
---|
Subject: | Hytec DAC8402 DAC Register Write Problem |
From: | "Darrell Nineham" <[email protected]> |
To: | "'Eric Bjorklund'" <[email protected]>, "'Sibley III, Coles'" <[email protected]>, "'Ernest L. Williams Jr.'" <[email protected]> |
Cc: | "'EPICS tech-talk'" <[email protected]> |
Date: | Fri, 17 Jun 2005 12:30:04 +0100 |
Dear All,
I have repeated the test with the present driver and our hardware, and the 'waitcount' is always 0.
If you are using an out of date version of the driver you need to ensure that the configuration is as follows....
Hy8402ipConfigure ( 1, 1, 1, 0, 0, 0, 12, 0)
# cardnumber =
1
# vmeslot = 1
#
Ipslot = 1
(0=A,1=B,2=C,3=D)
#
intnum = 0 (Interrupt
Vector 0=find me one)
#
doram = 1 (0 - Output via
Registers & ClockRate 12, 1 - Output via RAM & Set to passed ClockRate
)
# clocksource = 0 (0 - internal, 1 - external)
#
clockrate = 12 (10KHz)
#
inhibit = 0 (no
inhibit)
Darrell Nineham
Hytec Electronics Ltd.
Tel: +44 (0) 118 975 7770
Fax: +44 (0) 118 975 7566
Web: www.hytec-electronics.co.uk
++++++++++++++++++++++++++++++++++++++++++++
This email and any files transmitted with it are confidential and intended solely for the use of the individual or entity to whom they are addressed. If you have received this email in error, please notify the sender immediately. The views expressed in the message are those of the individual author and may not necessarily represent the views of Hytec Electronics Ltd.
-----Original Message-----Coles,
From: Eric Bjorklund [mailto:[email protected]]
Sent: 16 June 2005 23:49
To: EPICS tech-talk
Subject: Re: Hytec DAC8402
Where does the DAC8402 reside in I/O space? We had a similar problem with a serial driver in A32 space a few years ago. As near as we could tell, the hardware was working fine, but the register data seemed like it was being cached (even though it looked like the mapping registers in the BSP were disabling caching for A32 space). Our fix was to insert a
cacheInvalidate (DATA_CACHE, (void *)statadr, 12);
call into the loop. We never really figured out whether this defeated the hardware cache, or just broke the loop out of the CPU instruction pipeline, but it worked.
You might try a bus-analyzer to see how many reads you really are issuing to the DAC.
Hope this helps...
-Eric Bj.
On Jun 16, 2005, at 10:47 AM, Sibley III, Coles wrote:
Hello,
We are using a Hytec DAC8402 at SNS for our beam loss monitor reference. The driver uses far too much CPU time when we update 8 dacs every 5 seconds. In fact it goes to 100% cpu usage. The offending code is below. We can fix the code but the question is why does it take so long to set 16 register?
The 8402 can be set to uses registers (for a typical dac application) or memory (for arbitrary waveforms). We need the typical dac configuration, not the arbitrary waveforms.
We are using a Motorola MVME5100 cpu.
The wait count goes to 600000 in our case, as if statadr was not declared as volatile or the 512K of memory is getting loaded, not just the 16 registers. Our WAITLIM has to be set to 1000000.
while(((*statadr&CSR_ARM) !=0) && waitcount < WAITLIM)waitcount++;
if( waitcount < WAITLIM )
{
/* set dac value and rearm */
card->pMem->Data[signal]=val;
*statadr |=CSR_ARM;
}
The manual says:
“
While the unit is ARMed the DACs are constantly refreshed with the contents of the registers which can be changed during this time. There is a delay which is fixed of approximately 32us after ARM is set, before all the outputs change together.”
The problem seems to be that the ARM stays high far longer than seems reasonable, as the count rate indicates.
The initialization in st.cmd is:
Hy8402Configure(1,1,0,0,0,0,0,0)
Hy8402Configure(2,1,1,0,0,0,0,0)
Any suggestions?
Coles Sibley
SNS – ORNL
Controls Hardware Engineer
865-241-8055
[email protected]
<><><><><><><><><><><><><><><><><><><><><><><><><><><><>
Eric Björklund
Los Alamos Neutron Science Center (LANSCE)
phone: 505-667-6031 email: [email protected]
<><><><><><><><><><><><><><><><><><><><><><><><><><><><>
TSPA :: DUSA=ADTO