128 lines
2.8 KiB
C
128 lines
2.8 KiB
C
/* devMbbiTestAsyn.c */
|
||
/* share/src/dev $Id$ */
|
||
|
||
/* devMbbiTestAsyn.c - Device Support Routines for testing asynchronous processing*/
|
||
|
||
|
||
#include <vxWorks.h>
|
||
#include <types.h>
|
||
#include <stdioLib.h>
|
||
#include <wdLib.h>
|
||
|
||
#include <alarm.h>
|
||
#include <dbDefs.h>
|
||
#include <dbAccess.h>
|
||
#include <recSup.h>
|
||
#include <devSup.h>
|
||
#include <link.h>
|
||
#include <mbbiRecord.h>
|
||
|
||
/* Create the dset for devMbbiTestAsyn */
|
||
long init_record();
|
||
long read_mbbi();
|
||
struct {
|
||
long number;
|
||
DEVSUPFUN report;
|
||
DEVSUPFUN init;
|
||
DEVSUPFUN init_record;
|
||
DEVSUPFUN get_ioint_info;
|
||
DEVSUPFUN read_mbbi;
|
||
DEVSUPFUN special_linconv;
|
||
}devMbbiTestAsyn={
|
||
6,
|
||
NULL,
|
||
NULL,
|
||
init_record,
|
||
NULL,
|
||
read_mbbi,
|
||
NULL};
|
||
|
||
/* control block for callback*/
|
||
struct callback {
|
||
void (*callback)();
|
||
int priority;
|
||
struct dbAddr dbAddr;
|
||
WDOG_ID wd_id;
|
||
void (*process)();
|
||
};
|
||
|
||
void callbackRequest();
|
||
|
||
static void myCallback(pcallback)
|
||
struct callback *pcallback;
|
||
{
|
||
struct mbbiRecord *pmbbi=(struct mbbiRecord *)(pcallback->dbAddr.precord);
|
||
|
||
dbScanLock(pmbbi);
|
||
(pcallback->process)(&pcallback->dbAddr);
|
||
dbScanUnlock(pmbbi);
|
||
}
|
||
|
||
|
||
|
||
static long init_record(pmbbi,process)
|
||
struct mbbiRecord *pmbbi;
|
||
void (*process)();
|
||
{
|
||
char message[100];
|
||
struct callback *pcallback;
|
||
|
||
/* mbbi.inp must be a CONSTANT*/
|
||
switch (pmbbi->inp.type) {
|
||
case (CONSTANT) :
|
||
pcallback = (struct callback *)(calloc(1,sizeof(struct callback)));
|
||
pmbbi->dpvt = (caddr_t)pcallback;
|
||
pcallback->callback = myCallback;
|
||
pcallback->priority = priorityLow;
|
||
if(dbNameToAddr(pmbbi->name,&(pcallback->dbAddr))) {
|
||
logMsg("dbNameToAddr failed in init_record for devMbbiTestAsyn\n");
|
||
exit(1);
|
||
}
|
||
pcallback->wd_id = wdCreate();
|
||
pcallback->process = process;
|
||
pmbbi->val = pmbbi->inp.value.value;
|
||
break;
|
||
default :
|
||
strcpy(message,pmbbi->name);
|
||
strcat(message,": devMbbiTestAsyn (init_record) Illegal INP field");
|
||
errMessage(S_db_badField,message);
|
||
return(S_db_badField);
|
||
}
|
||
return(0);
|
||
}
|
||
|
||
static long read_mbbi(pmbbi)
|
||
struct mbbiRecord *pmbbi;
|
||
{
|
||
char message[100];
|
||
long status,options,nRequest;
|
||
struct callback *pcallback=(struct callback *)(pmbbi->dpvt);
|
||
int wait_time;
|
||
|
||
/* mbbi.inp must be a CONSTANT*/
|
||
switch (pmbbi->inp.type) {
|
||
case (CONSTANT) :
|
||
if(pmbbi->pact) {
|
||
printf("%s Completed\n",pmbbi->name);
|
||
return(2); /* don't convert */
|
||
} else {
|
||
wait_time = (int)(pmbbi->disv * vxTicksPerSecond);
|
||
if(wait_time<=0) return(0);
|
||
printf("%s Starting asynchronous processing\n",pmbbi->name);
|
||
wdStart(pcallback->wd_id,wait_time,callbackRequest,pcallback);
|
||
return(1);
|
||
}
|
||
default :
|
||
if(pmbbi->nsev<VALID_ALARM) {
|
||
pmbbi->nsev = VALID_ALARM;
|
||
pmbbi->nsta = SOFT_ALARM;
|
||
if(pmbbi->stat!=SOFT_ALARM) {
|
||
strcpy(message,pmbbi->name);
|
||
strcat(message,": devMbbiTestAsyn (read_mbbi) Illegal INP field");
|
||
errMessage(S_db_badField,message);
|
||
}
|
||
}
|
||
}
|
||
return(0);
|
||
}
|