From b89c707e37f530596d165600174aba24c244d455 Mon Sep 17 00:00:00 2001 From: Marty Kraimer Date: Wed, 2 Sep 1992 12:15:06 +0000 Subject: [PATCH] Call driver at init_record time --- src/dev/devAllenBradley.c | 54 +++++++++++++++++++++++++++++++++++++-- 1 file changed, 52 insertions(+), 2 deletions(-) diff --git a/src/dev/devAllenBradley.c b/src/dev/devAllenBradley.c index f06cfcdda..0e1972705 100644 --- a/src/dev/devAllenBradley.c +++ b/src/dev/devAllenBradley.c @@ -116,11 +116,13 @@ static long init_bi(); static long ioinfo_bi(); static long read_bi(); static long init_bi16(); +static long ioinfo_bi16(); static long read_bi16(); static long init_mbbi(); static long ioinfo_mbbi(); static long read_mbbi(); static long init_mbbi16(); +static long ioinfo_mbbi16(); static long read_mbbi16(); typedef struct { long number; @@ -131,9 +133,9 @@ typedef struct { DEVSUPFUN read_bi;} ABBIDSET; ABBIDSET devBiAb={ 5, NULL, NULL, init_bi, ioinfo_bi, read_bi}; -ABBIDSET devBiAb16={ 5, NULL, NULL, init_bi16, ioinfo_bi, read_bi16}; +ABBIDSET devBiAb16={ 5, NULL, NULL, init_bi16, ioinfo_bi16, read_bi16}; ABBIDSET devMbbiAb={ 5, NULL, NULL, init_mbbi, ioinfo_mbbi, read_mbbi}; -ABBIDSET devMbbiAb16={ 5, NULL, NULL, init_mbbi16, ioinfo_mbbi, read_mbbi16}; +ABBIDSET devMbbiAb16={ 5, NULL, NULL, init_mbbi16, ioinfo_mbbi16, read_mbbi16}; static long init_bo(); static long write_bo(); @@ -638,9 +640,15 @@ static long ioinfo_bi( IOSCANPVT *ppvt) { struct abio *pabio; + long value; pabio = (struct abio *)&(pbi->inp.value); ab_bi_getioscanpvt(pabio->link,pabio->adapter,pabio->card,ppvt); + /*call ab_bidriver so that it knows it has a binary input*/ + if(cmd==0) { + (void) ab_bidriver(ABBI_08_BIT,pabio->link,pabio->adapter, + pabio->card,pabio->plc_flag,pbi->mask,&value); + } return(0); } @@ -682,6 +690,24 @@ static long init_bi16(struct biRecord *pbi) return(0); } +static long ioinfo_bi16( + int cmd, + struct biRecord *pbi, + IOSCANPVT *ppvt) +{ + struct abio *pabio; + long value; + + pabio = (struct abio *)&(pbi->inp.value); + ab_bi_getioscanpvt(pabio->link,pabio->adapter,pabio->card,ppvt); + /*call ab_bidriver so that it knows it has a binary input*/ + if(cmd==0) { + (void) ab_bidriver(ABBI_16_BIT,pabio->link,pabio->adapter, + pabio->card,pabio->plc_flag,pbi->mask,&value); + } + return(0); +} + static long read_bi16(struct biRecord *pbi) { struct abio *pabio; @@ -724,9 +750,15 @@ static long ioinfo_mbbi( IOSCANPVT *ppvt) { struct abio *pabio; + unsigned long value; pabio = (struct abio *)&(pmbbi->inp.value); ab_bi_getioscanpvt(pabio->link,pabio->adapter,pabio->card,ppvt); + /*call ab_bidriver so that it knows it has a binary input*/ + if(cmd==0) { + (void) ab_bidriver(ABBI_08_BIT,pabio->link,pabio->adapter, + pabio->card,pabio->plc_flag,pmbbi->mask,&value); + } return(0); } @@ -765,6 +797,24 @@ static long init_mbbi16(struct mbbiRecord *pmbbi) return(0); } +static long ioinfo_mbbi16( + int cmd, + struct mbbiRecord *pmbbi, + IOSCANPVT *ppvt) +{ + struct abio *pabio; + unsigned long value; + + pabio = (struct abio *)&(pmbbi->inp.value); + ab_bi_getioscanpvt(pabio->link,pabio->adapter,pabio->card,ppvt); + /*call ab_bidriver so that it knows it has a binary input*/ + if(cmd==0) { + (void) ab_bidriver(ABBI_16_BIT,pabio->link,pabio->adapter, + pabio->card,pabio->plc_flag,pmbbi->mask,&value); + } + return(0); +} + static long read_mbbi16(struct mbbiRecord *pmbbi) { struct abio *pabio;