/*
* Hittite HMC-T2100 device support
*/
#include <epicsStdio.h>
#include <devCommonGpib.h>
#include <string.h>
#include <strings.h>
/******************************************************************************
*
* The following define statements are used to declare the names to be used
* for the dset tables.
*
* A DSET_AI entry must be declared here and referenced in an application
* database description file even if the device provides no AI records.
*
******************************************************************************/
#define DSET_AI devAiHMCT2100
#define DSET_AO devAoHMCT2100
#define DSET_BI devBiHMCT2100
#define DSET_BO devBoHMCT2100
#define DSET_EV devEvHMCT2100
#define DSET_LI devLiHMCT2100
#define DSET_LO devLoHMCT2100
#define DSET_MBBI devMbbiHMCT2100
#define DSET_MBBID devMbbidHMCT2100
#define DSET_MBBO devMbboHMCT2100
#define DSET_MBBOD devMbbodHMCT2100
#define DSET_SI devSiHMCT2100
#define DSET_SO devSoHMCT2100
#define DSET_WF devWfHMCT2100
#include <devGpib.h> /* must be included after DSET defines */
#define TIMEOUT 1.0 /* I/O must complete within this time */
#define TIMEWINDOW 2.0 /* Wait this long after device timeout */
# line 2 "devHMCT2100.gt"
/* static short get_onedata(char wa1[]);
static int rd_data(char wav[], short temp[]);
static int rd_wf_data(struct gpibDpvt *pdpvt, int p1, int p2, char **p3);
*/
/*static int rd_efast_data(struct gpibDpvt *pdpvt, int p1, int p2, char **p3);
*/
/******************************************************************************
* Strings used by the init routines to fill in the znam,onam,...
* fields in BI and BO record types.
******************************************************************************/
/*static char *AcqStateList[] = { "STOP", "RUN" };
static struct devGpibNames AcqState = { 2, AcqStateList, 0, 1 };
*/
static char *OnOffList[]={"Off","On"};
static struct devGpibNames OnOffState ={2, OnOffList,0, 1};
/******************************************************************************
* Structures used by the init routines to fill in the onst,twst,... and the
* onvl,twvl,... fields in MBBI and MBBO record types.
*
* Note that the intExtSsBm and intExtSsBmStop structures use the same
* intExtSsBmStopList and intExtSsBmStopVal lists but have a different number
* of elements in them that they use... The intExtSsBm structure only represents
* 4 elements,while the intExtSsBmStop structure represents 5.
******************************************************************************/
/******************************************************************************
* String arrays for EFAST operations. The last entry must be 0.
*
* On input operations,only as many bytes as are found in the string array
* elements are compared. Additional bytes are ignored.
* The first matching string will be used as a match.
*
* For the input operations,the strings are compared literally! This
* can cause problems if the instrument is returning things like \r and \n
* characters. When defining input strings so you include them as well.
******************************************************************************/
static char *(OnOffLine[])={"OUTP 0\r\n","OUTP 1\r\n",0};
/******************************************************************************
* Array of structures that define all GPIB messages
* supported for this type of instrument.
******************************************************************************/
static struct gpibCmd gpibCmds[] = {
/* Command 0 Reset */
{&DSET_AO,GPIBWRITE,IB_Q_LOW,NULL, "*RST\r\n",0,127,NULL,0,0,NULL,NULL,NULL },
/* Command 1 Normal set */
{&DSET_AO,GPIBWRITE,IB_Q_LOW,NULL,"FREQ:MODE CW\r\n",0,127,NULL,0,0,NULL,NULL,NULL},
/* Command 2 RF on off SET */
{&DSET_BO, GPIBEFASTO, IB_Q_LOW, NULL,NULL, 0, 127, NULL, 0, 0, OnOffLine, &OnOffState, NULL },
/* Command 3 RF on off READ */
{&DSET_BI, GPIBREAD, IB_Q_LOW, "OUTP?\r\n", NULL, 0, 127, NULL, 0, 0, NULL, &OnOffState, NULL },
/* Command 4 Frequency SET */
{&DSET_AO,GPIBWRITE,IB_Q_LOW,NULL,"FREQ %lfMHZ\r\n",0,127,NULL,0,0,NULL,NULL,NULL},
/* Command 5 Frequency READ */
{&DSET_AI,GPIBREAD,IB_Q_LOW,"FREQ?\r\n","%lf\n",0,127,NULL,0,0,NULL,NULL,NULL},
/* Command 6 Power SET */
{&DSET_AO,GPIBWRITE,IB_Q_LOW,NULL,"POW %lfDBM\r\n",0,127,NULL,0,0,NULL,NULL,NULL},
/* Command 7 Power READ */
{&DSET_AI,GPIBREAD,IB_Q_LOW,"POW?\r\n","%lf\n",0,127,NULL,0,0,NULL,NULL,NULL}
};
/* The following is the number of elements in the command array above. */
#define NUMPARAMS sizeof(gpibCmds)/sizeof(struct gpibCmd)
/******************************************************************************
* Initialize device support parameters
*
*****************************************************************************/
static long init_ai(int parm)
{
if(parm==0) {
devSupParms.name = "devHMCT2100";
devSupParms.gpibCmds = gpibCmds;
devSupParms.numparams = NUMPARAMS;
devSupParms.timeout = TIMEOUT;
devSupParms.timeWindow = TIMEWINDOW;
devSupParms.respond2Writes = -1;
}
return(0);
}
/******************************************************************************
*
* c code
*
*****************************************************************************/
# line 60 "devHMCT2100.gt"
Makoto Tobiyama
Last update: 10/Sep/2011