7 #ifndef INC_lsiRecord_H
8 #define INC_lsiRecord_H
21 long (*read_string)(
struct lsiRecord *prec);
60 struct asgMember *
asp;
62 struct processNotifyRecord *
ppnr;
156 lsiRecordOLDSIMM = 60,
162 #ifdef GEN_SIZE_OFFSET
173 if (prt->no_fields != 64) {
175 " The lsiRecord defined in the DBD file has %d fields,\n"
176 " but the record support code was built with 64.\n",
179 prt->papFldDes[lsiRecordNAME]->size =
sizeof(prec->
name);
180 prt->papFldDes[lsiRecordNAME]->offset = (
unsigned short)((
char *)&prec->
name - (
char *)prec);
181 prt->papFldDes[lsiRecordDESC]->size =
sizeof(prec->
desc);
182 prt->papFldDes[lsiRecordDESC]->offset = (
unsigned short)((
char *)&prec->
desc - (
char *)prec);
183 prt->papFldDes[lsiRecordASG]->size =
sizeof(prec->
asg);
184 prt->papFldDes[lsiRecordASG]->offset = (
unsigned short)((
char *)&prec->
asg - (
char *)prec);
185 prt->papFldDes[lsiRecordSCAN]->size =
sizeof(prec->
scan);
186 prt->papFldDes[lsiRecordSCAN]->offset = (
unsigned short)((
char *)&prec->
scan - (
char *)prec);
187 prt->papFldDes[lsiRecordPINI]->size =
sizeof(prec->
pini);
188 prt->papFldDes[lsiRecordPINI]->offset = (
unsigned short)((
char *)&prec->
pini - (
char *)prec);
189 prt->papFldDes[lsiRecordPHAS]->size =
sizeof(prec->
phas);
190 prt->papFldDes[lsiRecordPHAS]->offset = (
unsigned short)((
char *)&prec->
phas - (
char *)prec);
191 prt->papFldDes[lsiRecordEVNT]->size =
sizeof(prec->
evnt);
192 prt->papFldDes[lsiRecordEVNT]->offset = (
unsigned short)((
char *)&prec->
evnt - (
char *)prec);
193 prt->papFldDes[lsiRecordTSE]->size =
sizeof(prec->
tse);
194 prt->papFldDes[lsiRecordTSE]->offset = (
unsigned short)((
char *)&prec->
tse - (
char *)prec);
195 prt->papFldDes[lsiRecordTSEL]->size =
sizeof(prec->
tsel);
196 prt->papFldDes[lsiRecordTSEL]->offset = (
unsigned short)((
char *)&prec->
tsel - (
char *)prec);
197 prt->papFldDes[lsiRecordDTYP]->size =
sizeof(prec->
dtyp);
198 prt->papFldDes[lsiRecordDTYP]->offset = (
unsigned short)((
char *)&prec->
dtyp - (
char *)prec);
199 prt->papFldDes[lsiRecordDISV]->size =
sizeof(prec->
disv);
200 prt->papFldDes[lsiRecordDISV]->offset = (
unsigned short)((
char *)&prec->
disv - (
char *)prec);
201 prt->papFldDes[lsiRecordDISA]->size =
sizeof(prec->
disa);
202 prt->papFldDes[lsiRecordDISA]->offset = (
unsigned short)((
char *)&prec->
disa - (
char *)prec);
203 prt->papFldDes[lsiRecordSDIS]->size =
sizeof(prec->
sdis);
204 prt->papFldDes[lsiRecordSDIS]->offset = (
unsigned short)((
char *)&prec->
sdis - (
char *)prec);
205 prt->papFldDes[lsiRecordMLOK]->size =
sizeof(prec->
mlok);
206 prt->papFldDes[lsiRecordMLOK]->offset = (
unsigned short)((
char *)&prec->
mlok - (
char *)prec);
207 prt->papFldDes[lsiRecordMLIS]->size =
sizeof(prec->
mlis);
208 prt->papFldDes[lsiRecordMLIS]->offset = (
unsigned short)((
char *)&prec->
mlis - (
char *)prec);
209 prt->papFldDes[lsiRecordBKLNK]->size =
sizeof(prec->
bklnk);
210 prt->papFldDes[lsiRecordBKLNK]->offset = (
unsigned short)((
char *)&prec->
bklnk - (
char *)prec);
211 prt->papFldDes[lsiRecordDISP]->size =
sizeof(prec->
disp);
212 prt->papFldDes[lsiRecordDISP]->offset = (
unsigned short)((
char *)&prec->
disp - (
char *)prec);
213 prt->papFldDes[lsiRecordPROC]->size =
sizeof(prec->
proc);
214 prt->papFldDes[lsiRecordPROC]->offset = (
unsigned short)((
char *)&prec->
proc - (
char *)prec);
215 prt->papFldDes[lsiRecordSTAT]->size =
sizeof(prec->
stat);
216 prt->papFldDes[lsiRecordSTAT]->offset = (
unsigned short)((
char *)&prec->
stat - (
char *)prec);
217 prt->papFldDes[lsiRecordSEVR]->size =
sizeof(prec->
sevr);
218 prt->papFldDes[lsiRecordSEVR]->offset = (
unsigned short)((
char *)&prec->
sevr - (
char *)prec);
219 prt->papFldDes[lsiRecordAMSG]->size =
sizeof(prec->
amsg);
220 prt->papFldDes[lsiRecordAMSG]->offset = (
unsigned short)((
char *)&prec->
amsg - (
char *)prec);
221 prt->papFldDes[lsiRecordNSTA]->size =
sizeof(prec->
nsta);
222 prt->papFldDes[lsiRecordNSTA]->offset = (
unsigned short)((
char *)&prec->
nsta - (
char *)prec);
223 prt->papFldDes[lsiRecordNSEV]->size =
sizeof(prec->
nsev);
224 prt->papFldDes[lsiRecordNSEV]->offset = (
unsigned short)((
char *)&prec->
nsev - (
char *)prec);
225 prt->papFldDes[lsiRecordNAMSG]->size =
sizeof(prec->
namsg);
226 prt->papFldDes[lsiRecordNAMSG]->offset = (
unsigned short)((
char *)&prec->
namsg - (
char *)prec);
227 prt->papFldDes[lsiRecordACKS]->size =
sizeof(prec->
acks);
228 prt->papFldDes[lsiRecordACKS]->offset = (
unsigned short)((
char *)&prec->
acks - (
char *)prec);
229 prt->papFldDes[lsiRecordACKT]->size =
sizeof(prec->
ackt);
230 prt->papFldDes[lsiRecordACKT]->offset = (
unsigned short)((
char *)&prec->
ackt - (
char *)prec);
231 prt->papFldDes[lsiRecordDISS]->size =
sizeof(prec->
diss);
232 prt->papFldDes[lsiRecordDISS]->offset = (
unsigned short)((
char *)&prec->
diss - (
char *)prec);
233 prt->papFldDes[lsiRecordLCNT]->size =
sizeof(prec->
lcnt);
234 prt->papFldDes[lsiRecordLCNT]->offset = (
unsigned short)((
char *)&prec->
lcnt - (
char *)prec);
235 prt->papFldDes[lsiRecordPACT]->size =
sizeof(prec->
pact);
236 prt->papFldDes[lsiRecordPACT]->offset = (
unsigned short)((
char *)&prec->
pact - (
char *)prec);
237 prt->papFldDes[lsiRecordPUTF]->size =
sizeof(prec->
putf);
238 prt->papFldDes[lsiRecordPUTF]->offset = (
unsigned short)((
char *)&prec->
putf - (
char *)prec);
239 prt->papFldDes[lsiRecordRPRO]->size =
sizeof(prec->
rpro);
240 prt->papFldDes[lsiRecordRPRO]->offset = (
unsigned short)((
char *)&prec->
rpro - (
char *)prec);
241 prt->papFldDes[lsiRecordASP]->size =
sizeof(prec->
asp);
242 prt->papFldDes[lsiRecordASP]->offset = (
unsigned short)((
char *)&prec->
asp - (
char *)prec);
243 prt->papFldDes[lsiRecordPPN]->size =
sizeof(prec->
ppn);
244 prt->papFldDes[lsiRecordPPN]->offset = (
unsigned short)((
char *)&prec->
ppn - (
char *)prec);
245 prt->papFldDes[lsiRecordPPNR]->size =
sizeof(prec->
ppnr);
246 prt->papFldDes[lsiRecordPPNR]->offset = (
unsigned short)((
char *)&prec->
ppnr - (
char *)prec);
247 prt->papFldDes[lsiRecordSPVT]->size =
sizeof(prec->
spvt);
248 prt->papFldDes[lsiRecordSPVT]->offset = (
unsigned short)((
char *)&prec->
spvt - (
char *)prec);
249 prt->papFldDes[lsiRecordRSET]->size =
sizeof(prec->
rset);
250 prt->papFldDes[lsiRecordRSET]->offset = (
unsigned short)((
char *)&prec->
rset - (
char *)prec);
251 prt->papFldDes[lsiRecordDSET]->size =
sizeof(prec->
dset);
252 prt->papFldDes[lsiRecordDSET]->offset = (
unsigned short)((
char *)&prec->
dset - (
char *)prec);
253 prt->papFldDes[lsiRecordDPVT]->size =
sizeof(prec->
dpvt);
254 prt->papFldDes[lsiRecordDPVT]->offset = (
unsigned short)((
char *)&prec->
dpvt - (
char *)prec);
255 prt->papFldDes[lsiRecordRDES]->size =
sizeof(prec->
rdes);
256 prt->papFldDes[lsiRecordRDES]->offset = (
unsigned short)((
char *)&prec->
rdes - (
char *)prec);
257 prt->papFldDes[lsiRecordLSET]->size =
sizeof(prec->
lset);
258 prt->papFldDes[lsiRecordLSET]->offset = (
unsigned short)((
char *)&prec->
lset - (
char *)prec);
259 prt->papFldDes[lsiRecordPRIO]->size =
sizeof(prec->
prio);
260 prt->papFldDes[lsiRecordPRIO]->offset = (
unsigned short)((
char *)&prec->
prio - (
char *)prec);
261 prt->papFldDes[lsiRecordTPRO]->size =
sizeof(prec->
tpro);
262 prt->papFldDes[lsiRecordTPRO]->offset = (
unsigned short)((
char *)&prec->
tpro - (
char *)prec);
263 prt->papFldDes[lsiRecordBKPT]->size =
sizeof(prec->
bkpt);
264 prt->papFldDes[lsiRecordBKPT]->offset = (
unsigned short)((
char *)&prec->
bkpt - (
char *)prec);
265 prt->papFldDes[lsiRecordUDF]->size =
sizeof(prec->
udf);
266 prt->papFldDes[lsiRecordUDF]->offset = (
unsigned short)((
char *)&prec->
udf - (
char *)prec);
267 prt->papFldDes[lsiRecordUDFS]->size =
sizeof(prec->
udfs);
268 prt->papFldDes[lsiRecordUDFS]->offset = (
unsigned short)((
char *)&prec->
udfs - (
char *)prec);
269 prt->papFldDes[lsiRecordTIME]->size =
sizeof(prec->
time);
270 prt->papFldDes[lsiRecordTIME]->offset = (
unsigned short)((
char *)&prec->
time - (
char *)prec);
271 prt->papFldDes[lsiRecordUTAG]->size =
sizeof(prec->
utag);
272 prt->papFldDes[lsiRecordUTAG]->offset = (
unsigned short)((
char *)&prec->
utag - (
char *)prec);
273 prt->papFldDes[lsiRecordFLNK]->size =
sizeof(prec->
flnk);
274 prt->papFldDes[lsiRecordFLNK]->offset = (
unsigned short)((
char *)&prec->
flnk - (
char *)prec);
275 prt->papFldDes[lsiRecordVAL]->size =
sizeof(prec->
val);
276 prt->papFldDes[lsiRecordVAL]->offset = (
unsigned short)((
char *)&prec->
val - (
char *)prec);
277 prt->papFldDes[lsiRecordOVAL]->size =
sizeof(prec->
oval);
278 prt->papFldDes[lsiRecordOVAL]->offset = (
unsigned short)((
char *)&prec->
oval - (
char *)prec);
279 prt->papFldDes[lsiRecordSIZV]->size =
sizeof(prec->
sizv);
280 prt->papFldDes[lsiRecordSIZV]->offset = (
unsigned short)((
char *)&prec->
sizv - (
char *)prec);
281 prt->papFldDes[lsiRecordLEN]->size =
sizeof(prec->
len);
282 prt->papFldDes[lsiRecordLEN]->offset = (
unsigned short)((
char *)&prec->
len - (
char *)prec);
283 prt->papFldDes[lsiRecordOLEN]->size =
sizeof(prec->
olen);
284 prt->papFldDes[lsiRecordOLEN]->offset = (
unsigned short)((
char *)&prec->
olen - (
char *)prec);
285 prt->papFldDes[lsiRecordINP]->size =
sizeof(prec->
inp);
286 prt->papFldDes[lsiRecordINP]->offset = (
unsigned short)((
char *)&prec->
inp - (
char *)prec);
287 prt->papFldDes[lsiRecordMPST]->size =
sizeof(prec->
mpst);
288 prt->papFldDes[lsiRecordMPST]->offset = (
unsigned short)((
char *)&prec->
mpst - (
char *)prec);
289 prt->papFldDes[lsiRecordAPST]->size =
sizeof(prec->
apst);
290 prt->papFldDes[lsiRecordAPST]->offset = (
unsigned short)((
char *)&prec->
apst - (
char *)prec);
291 prt->papFldDes[lsiRecordSIML]->size =
sizeof(prec->
siml);
292 prt->papFldDes[lsiRecordSIML]->offset = (
unsigned short)((
char *)&prec->
siml - (
char *)prec);
293 prt->papFldDes[lsiRecordSIMM]->size =
sizeof(prec->
simm);
294 prt->papFldDes[lsiRecordSIMM]->offset = (
unsigned short)((
char *)&prec->
simm - (
char *)prec);
295 prt->papFldDes[lsiRecordSIMS]->size =
sizeof(prec->
sims);
296 prt->papFldDes[lsiRecordSIMS]->offset = (
unsigned short)((
char *)&prec->
sims - (
char *)prec);
297 prt->papFldDes[lsiRecordSIOL]->size =
sizeof(prec->
siol);
298 prt->papFldDes[lsiRecordSIOL]->offset = (
unsigned short)((
char *)&prec->
siol - (
char *)prec);
299 prt->papFldDes[lsiRecordOLDSIMM]->size =
sizeof(prec->
oldsimm);
300 prt->papFldDes[lsiRecordOLDSIMM]->offset = (
unsigned short)((
char *)&prec->
oldsimm - (
char *)prec);
301 prt->papFldDes[lsiRecordSSCN]->size =
sizeof(prec->
sscn);
302 prt->papFldDes[lsiRecordSSCN]->offset = (
unsigned short)((
char *)&prec->
sscn - (
char *)prec);
303 prt->papFldDes[lsiRecordSDLY]->size =
sizeof(prec->
sdly);
304 prt->papFldDes[lsiRecordSDLY]->offset = (
unsigned short)((
char *)&prec->
sdly - (
char *)prec);
305 prt->papFldDes[lsiRecordSIMPVT]->size =
sizeof(prec->
simpvt);
306 prt->papFldDes[lsiRecordSIMPVT]->offset = (
unsigned short)((
char *)&prec->
simpvt - (
char *)prec);
307 prt->rec_size =
sizeof(*prec);
epicsEnum16 dtyp
Device Type.
epicsEnum16 scan
Scan Mechanism.
epicsUInt8 bkpt
Break Point.
void * dpvt
Device Private.
epicsInt16 disv
Disable Value.
unambiguous_dset * dset
DSET address.
char name[61]
Record Name.
DBLINK flnk
Forward Process Link.
struct typed_rset * rset
Address of RSET.
struct dbRecordType * rdes
Address of dbRecordType.
struct scan_element * spvt
Scan Private.
LIBCOM_API void cantProceed(const char *errorMessage,...) EPICS_PRINTF_STYLE(1
Suspend this thread, the caller cannot continue or return.
Declaration of lsi record type.
The core data types used by epics.
char asg[29]
Access Security Group.
epicsEnum16 sevr
Alarm Severity.
epicsUInt8 putf
dbPutField process
epicsEnum16 stat
Alarm Status.
epicsEnum16 oldsimm
Prev. Simulation Mode.
struct processNotifyRecord * ppnr
pprocessNotifyRecord
epicsEnum16 nsev
New Alarm Severity.
epicsEnum16 sims
Simulation Mode Severity.
epicsUInt32 olen
Length of OVAL.
char namsg[40]
New Alarm Message.
DBLINK sdis
Scanning Disable.
Routines for code that can't continue or return after an error.
epicsEnum16 apst
Post Archive Monitors.
epicsUInt8 disp
Disable putField.
epicsEnum16 prio
Scheduling Priority.
epicsUInt8 rpro
Reprocess.
EPICS time stamp, for use from C code.
A doubly-linked list library.
epicsUInt8 tpro
Trace Processing.
epicsEnum16 pini
Process at iocInit.
struct asgMember * asp
Access Security Pvt.
epicsEnum16 diss
Disable Alarm Sevrty.
epicsEnum16 udfs
Undefined Alarm Sevrty.
APIs for the epicsMutex mutual exclusion semaphore.
epicsCallback * simpvt
Sim. Mode Private.
epicsEnum16 nsta
New Alarm Status.
epicsUInt8 pact
Record active.
epicsUInt32 len
Length of VAL.
epicsEnum16 acks
Alarm Ack Severity.
epicsEnum16 sscn
Sim. Mode Scan.
epicsEnum16 simm
Simulation Mode.
epicsEnum16 ackt
Alarm Ack Transient.
DBLINK tsel
Time Stamp Link.
char amsg[40]
Alarm Message.
DBLINK inp
Input Specification.
epicsUInt64 utag
Time Tag.
#define epicsExportRegistrar(fun)
Declare a registrar function for exporting.
epicsInt16 phas
Scan Phase.
DBLINK siol
Simulation Input Link.
epicsUInt8 lcnt
Lock Count.
ELLLIST mlis
Monitor List.
epicsMutexId mlok
Monitor lock.
EPICS time-stamps (epicsTimeStamp), epicsTime C++ class and C functions for handling wall-clock times...
epicsInt16 tse
Time Stamp Event.
struct lockRecord * lset
Lock Set.
ELLLIST bklnk
Backwards link tracking.
epicsEnum16 mpst
Post Value Monitors.
epicsUInt16 sizv
Size of buffers.
epicsUInt8 proc
Force Processing.
DBLINK siml
Simulation Mode Link.
struct epicsMutexParm * epicsMutexId
An identifier for an epicsMutex for use with the C API.
struct processNotify * ppn
pprocessNotify
epicsFloat64 sdly
Sim. Mode Async Delay.