/* devMbbiDirectTestAsyn.c */ /* base/src/dev $Id$ */ /* devMbbiDirectTestAsyn.c - Device Support for testing asynch processing */ /* * Original Author: Bob Dalesio * Current Author: Matthew Needes * Date: 10-08-93 * * Experimental Physics and Industrial Control System (EPICS) * * Copyright 1991, the Regents of the University of California, * and the University of Chicago Board of Governors. * * This software was produced under U.S. Government contracts: * (W-7405-ENG-36) at the Los Alamos National Laboratory, * and (W-31-109-ENG-38) at Argonne National Laboratory. * * Initial development by: * The Controls and Automation Group (AT-8) * Ground Test Accelerator * Accelerator Technology Division * Los Alamos National Laboratory * * Co-developed with * The Controls and Computing Group * Accelerator Systems Division * Advanced Photon Source * Argonne National Laboratory * * Modification Log: * ----------------- * (modification log of devMbbiDirectTestAsyn.c applies) * .01 10-08-93 mcn added support for direct mbbi records */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include /* Create the dset for devMbbiDirectTestAsyn */ static long init_record(); static long read_mbbi(); struct { long number; DEVSUPFUN report; DEVSUPFUN init; DEVSUPFUN init_record; DEVSUPFUN get_ioint_info; DEVSUPFUN read_mbbi; DEVSUPFUN special_linconv; }devMbbiDirectTestAsyn={ 6, NULL, NULL, init_record, NULL, read_mbbi, NULL}; /* control block for callback*/ struct callback { CALLBACK callback; struct dbCommon *precord; WDOG_ID wd_id; }; static void myCallback(pcallback) struct callback *pcallback; { struct dbCommon *precord=pcallback->precord; struct rset *prset=(struct rset *)(precord->rset); dbScanLock(precord); (*prset->process)(precord); dbScanUnlock(precord); } static long init_record(pmbbi) struct mbbiDirectRecord *pmbbi; { 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 = (void *)pcallback; callbackSetCallback(myCallback,pcallback); pcallback->precord = (struct dbCommon *)pmbbi; pcallback->wd_id = wdCreate(); pmbbi->val = pmbbi->inp.value.value; pmbbi->udf = FALSE; break; default : recGblRecordError(S_db_badField,(void *)pmbbi, "devMbbiDirectTestAsyn (init_record) Illegal INP field"); return(S_db_badField); } return(0); } static long read_mbbi(pmbbi) struct mbbiDirectRecord *pmbbi; { 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); callbackSetPriority(pmbbi->prio,pcallback); printf("%s Starting asynchronous processing\n",pmbbi->name); wdStart(pcallback->wd_id,wait_time,(FUNCPTR)callbackRequest,(int)pcallback); pmbbi->pact=TRUE; return(0); } default : if(recGblSetSevr(pmbbi,SOFT_ALARM,INVALID_ALARM)){ if(pmbbi->stat!=SOFT_ALARM) { recGblRecordError(S_db_badField,(void *)pmbbi, "devMbbiDirectTestAsyn (read_mbbi) Illegal INP field"); } } } return(0); }