afafa09547
ioc: check for mis-matched onStartSubscription()/onDisableSubscription() ioc: fix subscription lifetime ioc: catch exceptions in dbEvent callbacks ioc: avoid unnecessary virtual ioc: minor ioc: fix qsrv -S ioc: qsrvGroupSourceInit() catch+log ioc: runOnServer avoid std::function ioc: cleanup and simplifications. Avoid some redundant std::map lookups. Make Group partially const to prevent implicit ctor. ioc: avoid typedefs only used once ioc: overhaul Group::show(). shows triggers ioc: MappingType ioc: pvxsgl -> pvxgl ioc: separate group config singleton from server singleton ioc: remove unnecessary forward declarations ioc: restructure pvxsInitHook ioc: qsrv runtime disable by default ioc: compat w/ older Base ioc: link pvxsIoc w/ DB libs ioc: Channel proper detection of invalid PV ioc: no need to keep vector<dbCommon*> around ioc: fix initial group update for mappings w/o dbChannel ioc: redo testing split out group tests, only run with Base >= 7.0 ioc: minor ioc: loc_bad_alloc ioc: avoid symbol/DTYP clash with pva2pva ioc: test record alias in group json ioc: test put failure when SPC_NOMOD and DISP=1 ioc: test channel filters ioc: unnecessary capture ioc: avoid sharing Value between multiple subscriptions It is possible to create two subscriptions through the same channel. ioc: group subscription include queueSize ioc: eliminate unused atomicMonitor ioc: consolidate GroupSource::get() avoid some indirection ioc: pvRequest override of atomicPutGet ioc: fix group non-atomic put ioc: test asTrap hooks ioc: test putOrder also sets field order ioc: simplify GroupConfigProcessor::loadConfigFiles() Also ensure that groupMapMutex is held ioc: testqgroup cover JSON def. ioc: dbLoadGroup() use macros ioc: pvxsl() take integer argument ioc: display.form and info(Q:form ioc: "NO_ALARM" -> "" ioc: use dbServer at least for informational callbacks. ioc: consolidate createRequestAndSubscriptionHandlers() ioc: eliminate ChannelAndLock properties dbChannel doesn't need a separate DBManyLock ioc: test that putOrder also controls field order ioc: MappingType -> MappingInfo Handle info(Q:time:tag Add +type:"const" ioc: cleanup includes ioc: test dbNotifyCancel() ioc: inline checkForTrailingCommentsAtEnd()
68 lines
1.4 KiB
Plaintext
68 lines
1.4 KiB
Plaintext
record(ao, "$(N)Rate") {
|
|
field(VAL, "1.0")
|
|
field(PINI, "YES")
|
|
field(PREC, "3")
|
|
field(DRVH, "2.0")
|
|
field(DRVL, "0.000000000001")
|
|
field( OUT, "$(N)dly_.ODLY NPP")
|
|
}
|
|
|
|
record(ao, "$(N)Delta") {
|
|
field(VAL, "0.0")
|
|
field(PINI, "YES")
|
|
}
|
|
|
|
record(calc, "$(N)Phase:I") {
|
|
field(PINI, "RUNNING")
|
|
field(INPA, "$(N)Phase:I")
|
|
field(CALC, "A+1")
|
|
field( EGU, "rad")
|
|
field(PREC, "3")
|
|
field(FLNK, "$(N)Phase:Q")
|
|
info(Q:group, {
|
|
"$(N)iq":{"phas.i": {+type:"plain", +channel:"VAL"}}
|
|
})
|
|
#field(TPRO, "1")
|
|
}
|
|
|
|
record(calc, "$(N)Phase:Q") {
|
|
field(INPA, "$(N)Phase:I")
|
|
field(INPB, "$(N)Delta NPP")
|
|
field(CALC, "A+B")
|
|
field( EGU, "rad")
|
|
field(PREC, "3")
|
|
field(FLNK, "$(N)I")
|
|
info(Q:group, {
|
|
"$(N)iq":{"phas.q": {+type:"plain", +channel:"VAL"}}
|
|
})
|
|
}
|
|
|
|
record(waveform, "$(N)I") {
|
|
field(DTYP, "QSRV2 Demo")
|
|
field( INP, "$(N)Phase:I")
|
|
field(FTVL, "DOUBLE")
|
|
field(NELM, "500")
|
|
field(FLNK, "$(N)Q")
|
|
info(Q:group, {
|
|
"$(N)iq":{"I": {+channel:"VAL"}}
|
|
})
|
|
info(Q:form, "Engineering")
|
|
}
|
|
|
|
record(waveform, "$(N)Q") {
|
|
field(DTYP, "QSRV2 Demo")
|
|
field( INP, "$(N)Phase:Q")
|
|
field(FTVL, "DOUBLE")
|
|
field(NELM, "500")
|
|
field(FLNK, "$(N)dly_")
|
|
info(Q:group, {
|
|
"$(N)iq":{"Q": {+channel:"VAL", +trigger:"*"}}
|
|
})
|
|
info(Q:form, "Engineering")
|
|
}
|
|
|
|
record(calcout, "$(N)dly_") {
|
|
field(ODLY, "1.0")
|
|
field(OUT , "$(N)Phase:I.PROC CA")
|
|
}
|