Skip to content

Commit

Permalink
Add DBus bit trig for pulsers
Browse files Browse the repository at this point in the history
  • Loading branch information
ZanMaticPratnemer committed Oct 7, 2022
1 parent 789176b commit d498d6b
Show file tree
Hide file tree
Showing 7 changed files with 73 additions and 0 deletions.
21 changes: 21 additions & 0 deletions evrApp/Db/evrpulser.db
Original file line number Diff line number Diff line change
Expand Up @@ -186,3 +186,24 @@ record(mbbiDirect, "$(PN)PSTrig-RB")
field(NOBT, "8")
info(autosaveFields_pass0, "RVAL")
}

# Trigger pulser generator by one or more DBus bits
record(mbboDirect, "$(PN)DBusTrig-Sel")
{
field(DTYP, "Obj Prop uint32")
field(OUT , "@OBJ=$(OBJ), PROP=DBusTrig")
field(PINI, "YES")
field(NOBT, "8")
field(VAL , "0")
field(FLNK, "$(PN)DBusTrig-RB")
info(autosaveFields_pass0, "RVAL")
}

record(mbbiDirect, "$(PN)DBusTrig-RB")
{
field(DTYP, "Obj Prop uint32")
field(INP , "@OBJ=$(OBJ), PROP=DBusTrig")
field(PINI, "YES")
field(NOBT, "8")
info(autosaveFields_pass0, "RVAL")
}
3 changes: 3 additions & 0 deletions evrApp/src/evr.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
* Copyright (c) 2010 Brookhaven Science Associates, as Operator of
* Brookhaven National Laboratory.
* Copyright (c) 2015 Paul Scherrer Institute (PSI), Villigen, Switzerland
* Copyright (c) 2022 Cosylab d.d.
* mrfioc2 is distributed subject to a Software License Agreement found
* in file LICENSE that is included with this distribution.
\*************************************************************************/
Expand Down Expand Up @@ -187,6 +188,8 @@ OBJECT_BEGIN(Pulser) {

OBJECT_PROP2("PSTrig", &Pulser::psTrig, &Pulser::setPSTrig);

OBJECT_PROP2("DBusTrig", &Pulser::dbusTrig, &Pulser::setDBusTrig);

} OBJECT_END(Pulser)


Expand Down
8 changes: 8 additions & 0 deletions evrApp/src/evr/pulser.h
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
/*************************************************************************\
* Copyright (c) 2010 Brookhaven Science Associates, as Operator of
* Brookhaven National Laboratory.
* Copyright (c) 2022 Cosylab d.d.
* mrfioc2 is distributed subject to a Software License Agreement found
* in file LICENSE that is included with this distribution.
\*************************************************************************/
Expand Down Expand Up @@ -84,6 +85,13 @@ class epicsShareClass Pulser : public mrf::ObjectInst<Pulser>
virtual void setPSTrig(epicsUInt32)=0;
/*@}*/

/**\defgroup DBus Set DBus triggering
*/
/*@{*/
virtual epicsUInt32 dbusTrig() const=0;
virtual void setDBusTrig(epicsUInt32)=0;
/*@}*/

/**\defgroup pol Set output polarity
*
* Selects normal or inverted.
Expand Down
4 changes: 4 additions & 0 deletions evrFRIBApp/src/evr_frib.h
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
/*
* This software is Copyright by the Board of Trustees of Michigan
* State University (c) Copyright 2017.
* Copyright (c) 2022 Cosylab d.d.
*
* Author: Michael Davidsaver <[email protected]>
*/
Expand Down Expand Up @@ -77,6 +78,9 @@ struct PulserFRIB : public Pulser
virtual epicsUInt32 psTrig() const { return 0u; }
virtual void setPSTrig(epicsUInt32) {}

virtual epicsUInt32 dbusTrig() const { return 0u; }
virtual void setDBusTrig(epicsUInt32) {}

virtual bool polarityInvert() const { return false; }
virtual void setPolarityInvert(bool) {}

Expand Down
29 changes: 29 additions & 0 deletions evrMrmApp/src/drvemPulser.cpp
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
/*************************************************************************\
* Copyright (c) 2010 Brookhaven Science Associates, as Operator of
* Brookhaven National Laboratory.
* Copyright (c) 2022 Cosylab d.d.
* mrfioc2 is distributed subject to a Software License Agreement found
* in file LICENSE that is included with this distribution.
\*************************************************************************/
Expand All @@ -9,6 +10,7 @@
*/

#include "evrRegMap.h"
#include "evgRegMap.h"
#include "drvem.h"

#include <stdexcept>
Expand Down Expand Up @@ -165,6 +167,33 @@ MRMPulser::setPSTrig(epicsUInt32 v)
}
}

epicsUInt32
MRMPulser::dbusTrig() const
{
epicsUInt32 r = 0;
for (int i = 0; i < evgNumDbusBit; i++) {
if (READ32(owner.base, DBusPulsTrig(i)) & (1 << id)) {
r |= 1 << i;
}
}

return r;
}

void
MRMPulser::setDBusTrig(epicsUInt32 v)
{
for (int i = 0; i < evgNumDbusBit; i++) {
epicsUInt32 t = READ32(owner.base, DBusPulsTrig(i));
if (v & (1 << i)) {
t |= 1 << id;
} else {
t &= ~(1 << id);
}
WRITE32(owner.base, DBusPulsTrig(i), t);
}
}

bool
MRMPulser::polarityInvert() const
{
Expand Down
4 changes: 4 additions & 0 deletions evrMrmApp/src/drvemPulser.h
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
/*************************************************************************\
* Copyright (c) 2010 Brookhaven Science Associates, as Operator of
* Brookhaven National Laboratory.
* Copyright (c) 2022 Cosylab d.d.
* mrfioc2 is distributed subject to a Software License Agreement found
* in file LICENSE that is included with this distribution.
\*************************************************************************/
Expand Down Expand Up @@ -49,6 +50,9 @@ class MRMPulser : public mrf::ObjectInst<MRMPulser, Pulser>
virtual epicsUInt32 psTrig() const OVERRIDE FINAL;
virtual void setPSTrig(epicsUInt32) OVERRIDE FINAL;

virtual epicsUInt32 dbusTrig() const OVERRIDE FINAL;
virtual void setDBusTrig(epicsUInt32) OVERRIDE FINAL;

virtual bool polarityInvert() const OVERRIDE FINAL;
virtual void setPolarityInvert(bool) OVERRIDE FINAL;

Expand Down
4 changes: 4 additions & 0 deletions evrMrmApp/src/evrRegMap.h
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
* Copyright (c) 2010 Brookhaven Science Associates, as Operator of
* Brookhaven National Laboratory.
* Copyright (c) 2015 Paul Scherrer Institute (PSI), Villigen, Switzerland
* Copyright (c) 2022 Cosylab d.d.
* mrfioc2 is distributed subject to a Software License Agreement found
* in file LICENSE that is included with this distribution.
\*************************************************************************/
Expand Down Expand Up @@ -193,6 +194,9 @@
# define ScalerPhasOffs_offset 0x20
#define U32_ScalerPulsTrig(N) (U32_ScalerN + 0x40 + (4*(N)))

#define U32_DBusTrigN 0x180
#define U32_DBusPulsTrig(N) (U32_DBusTrigN + (4*(N)))

#define U32_PulserNCtrl 0x200
#define U32_PulserNScal 0x204
#define U32_PulserNDely 0x208
Expand Down

0 comments on commit d498d6b

Please sign in to comment.