1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
/***************************************************************************
lib/ibSad.c
-------------------
copyright : (C) 2001,2002,2003 by Frank Mori Hess
email : fmhess@users.sourceforge.net
***************************************************************************/
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#include "ib_internal.h"
int internal_ibsad(ibConf_t *conf, int address)
{
ibBoard_t *board;
struct gpib_sad_ioctl sad_cmd;
int sad;
int retval;
board = interfaceBoard(conf);
if (!address)
sad = -1;
else
sad = address - sad_offset;
if (sad < -1 || sad > gpib_sad_max) {
setIberr(EARG);
return -1;
}
sad_cmd.handle = conf->handle;
sad_cmd.sad = sad;
retval = ioctl(board->fileno, IBSAD, &sad_cmd);
if (retval < 0) {
fprintf(stderr, "libgpib: failed to change gpib secondary address\n");
setIberr(EDVR);
setIbcnt(errno);
return retval;
}
conf->settings.sad = sad;
return 0;
}
int ibsad(int ud, int v)
{
ibConf_t *conf;
int retval;
conf = enter_library(ud);
if (conf == NULL)
return exit_library(ud, 1);
retval = internal_ibsad(conf, v);
if (retval < 0)
return exit_library(ud, 1);
return exit_library(ud, 0);
}
|