kopia lustrzana https://github.com/Hamlib/Hamlib
added open/not open flag
git-svn-id: https://hamlib.svn.sourceforge.net/svnroot/hamlib/trunk@690 7ae35d74-ebe9-4afe-98af-79ac388436b8Hamlib-1.1.3
rodzic
9d62785b61
commit
39f604062f
|
@ -2,7 +2,7 @@
|
||||||
* Hamlib Interface - API header
|
* Hamlib Interface - API header
|
||||||
* Copyright (c) 2000,2001 by Stephane Fillod and Frank Singleton
|
* Copyright (c) 2000,2001 by Stephane Fillod and Frank Singleton
|
||||||
*
|
*
|
||||||
* $Id: rig.h,v 1.51 2001-10-16 19:19:46 f4cfe Exp $
|
* $Id: rig.h,v 1.52 2001-10-16 21:18:02 f4cfe Exp $
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or modify
|
* This library is free software; you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU Library General Public License as
|
* it under the terms of the GNU Library General Public License as
|
||||||
|
@ -986,6 +986,7 @@ struct rig_state {
|
||||||
|
|
||||||
int level_gran[RIG_SETTING_MAX]; /* level granularity */
|
int level_gran[RIG_SETTING_MAX]; /* level granularity */
|
||||||
|
|
||||||
|
int comm_state; /* opened or not */
|
||||||
/*
|
/*
|
||||||
* Pointer to private data
|
* Pointer to private data
|
||||||
* stuff like CI_V_address for Icom goes in this *priv 51 area
|
* stuff like CI_V_address for Icom goes in this *priv 51 area
|
||||||
|
|
69
src/rig.c
69
src/rig.c
|
@ -12,7 +12,7 @@
|
||||||
* Hamlib Interface - main file
|
* Hamlib Interface - main file
|
||||||
* Copyright (c) 2000,2001 by Stephane Fillod and Frank Singleton
|
* Copyright (c) 2000,2001 by Stephane Fillod and Frank Singleton
|
||||||
*
|
*
|
||||||
* $Id: rig.c,v 1.45 2001-10-16 19:19:46 f4cfe Exp $
|
* $Id: rig.c,v 1.46 2001-10-16 21:18:02 f4cfe Exp $
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or modify
|
* This library is free software; you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU Library General Public License as
|
* it under the terms of the GNU Library General Public License as
|
||||||
|
@ -77,6 +77,13 @@ struct opened_rig_l {
|
||||||
};
|
};
|
||||||
static struct opened_rig_l *opened_rig_list = { NULL };
|
static struct opened_rig_l *opened_rig_list = { NULL };
|
||||||
|
|
||||||
|
/*
|
||||||
|
* rig_state.comm_state
|
||||||
|
*/
|
||||||
|
enum {
|
||||||
|
RIG_COMM_NOTOPEN,
|
||||||
|
RIG_COMM_OPEN
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Careful, the order must be the same as their RIG_E* counterpart!
|
* Careful, the order must be the same as their RIG_E* counterpart!
|
||||||
|
@ -237,6 +244,7 @@ RIG *rig_init(rig_model_t rig_model)
|
||||||
|
|
||||||
rs = &rig->state;
|
rs = &rig->state;
|
||||||
|
|
||||||
|
rs->comm_state = RIG_COMM_NOTOPEN;
|
||||||
rs->rigport.type.rig = caps->port_type; /* default from caps */
|
rs->rigport.type.rig = caps->port_type; /* default from caps */
|
||||||
strncpy(rs->rigport.pathname, DEFAULT_SERIAL_PORT, FILPATHLEN);
|
strncpy(rs->rigport.pathname, DEFAULT_SERIAL_PORT, FILPATHLEN);
|
||||||
rs->rigport.parm.serial.rate = caps->serial_rate_max; /* fastest ! */
|
rs->rigport.parm.serial.rate = caps->serial_rate_max; /* fastest ! */
|
||||||
|
@ -337,6 +345,7 @@ RIG *rig_init(rig_model_t rig_model)
|
||||||
int rig_open(RIG *rig)
|
int rig_open(RIG *rig)
|
||||||
{
|
{
|
||||||
const struct rig_caps *caps;
|
const struct rig_caps *caps;
|
||||||
|
struct rig_state *rs;
|
||||||
int status;
|
int status;
|
||||||
vfo_t vfo;
|
vfo_t vfo;
|
||||||
|
|
||||||
|
@ -346,20 +355,25 @@ int rig_open(RIG *rig)
|
||||||
return -RIG_EINVAL;
|
return -RIG_EINVAL;
|
||||||
|
|
||||||
caps = rig->caps;
|
caps = rig->caps;
|
||||||
rig->state.rigport.fd = -1;
|
rs = &rig->state;
|
||||||
|
|
||||||
switch(rig->state.rigport.type.rig) {
|
if (rs->comm_state != RIG_COMM_NOTOPEN)
|
||||||
|
return -RIG_EINVAL;
|
||||||
|
|
||||||
|
rs->rigport.fd = -1;
|
||||||
|
|
||||||
|
switch(rs->rigport.type.rig) {
|
||||||
case RIG_PORT_SERIAL:
|
case RIG_PORT_SERIAL:
|
||||||
status = serial_open(&rig->state.rigport);
|
status = serial_open(&rs->rigport);
|
||||||
if (status != 0)
|
if (status != 0)
|
||||||
return status;
|
return status;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RIG_PORT_DEVICE:
|
case RIG_PORT_DEVICE:
|
||||||
status = open(rig->state.rigport.pathname, O_RDWR, 0);
|
status = open(rs->rigport.pathname, O_RDWR, 0);
|
||||||
if (status < 0)
|
if (status < 0)
|
||||||
return -RIG_EIO;
|
return -RIG_EIO;
|
||||||
rig->state.rigport.fd = status;
|
rs->rigport.fd = status;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RIG_PORT_NONE:
|
case RIG_PORT_NONE:
|
||||||
|
@ -375,48 +389,48 @@ int rig_open(RIG *rig)
|
||||||
* FIXME: what to do if PTT open fails or PTT unsupported?
|
* FIXME: what to do if PTT open fails or PTT unsupported?
|
||||||
* fail rig_open? remember unallocating..
|
* fail rig_open? remember unallocating..
|
||||||
*/
|
*/
|
||||||
switch(rig->state.pttport.type.ptt) {
|
switch(rs->pttport.type.ptt) {
|
||||||
case RIG_PTT_NONE:
|
case RIG_PTT_NONE:
|
||||||
case RIG_PTT_RIG:
|
case RIG_PTT_RIG:
|
||||||
break;
|
break;
|
||||||
case RIG_PTT_SERIAL_RTS:
|
case RIG_PTT_SERIAL_RTS:
|
||||||
case RIG_PTT_SERIAL_DTR:
|
case RIG_PTT_SERIAL_DTR:
|
||||||
rig->state.pttport.fd = ser_open(&rig->state.pttport);
|
rs->pttport.fd = ser_open(&rs->pttport);
|
||||||
if (rig->state.pttport.fd < 0)
|
if (rs->pttport.fd < 0)
|
||||||
rig_debug(RIG_DEBUG_ERR, "Cannot open PTT device \"%s\"\n",
|
rig_debug(RIG_DEBUG_ERR, "Cannot open PTT device \"%s\"\n",
|
||||||
rig->state.pttport.pathname);
|
rs->pttport.pathname);
|
||||||
break;
|
break;
|
||||||
case RIG_PTT_PARALLEL:
|
case RIG_PTT_PARALLEL:
|
||||||
rig->state.pttport.fd = par_open(&rig->state.pttport);
|
rs->pttport.fd = par_open(&rs->pttport);
|
||||||
if (rig->state.pttport.fd < 0)
|
if (rs->pttport.fd < 0)
|
||||||
rig_debug(RIG_DEBUG_ERR, "Cannot open PTT device \"%s\"\n",
|
rig_debug(RIG_DEBUG_ERR, "Cannot open PTT device \"%s\"\n",
|
||||||
rig->state.pttport.pathname);
|
rs->pttport.pathname);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
rig_debug(RIG_DEBUG_ERR, "Unsupported PTT type %d\n",
|
rig_debug(RIG_DEBUG_ERR, "Unsupported PTT type %d\n",
|
||||||
rig->state.pttport.type.ptt);
|
rs->pttport.type.ptt);
|
||||||
}
|
}
|
||||||
|
|
||||||
switch(rig->state.dcdport.type.dcd) {
|
switch(rs->dcdport.type.dcd) {
|
||||||
case RIG_DCD_NONE:
|
case RIG_DCD_NONE:
|
||||||
case RIG_DCD_RIG:
|
case RIG_DCD_RIG:
|
||||||
break;
|
break;
|
||||||
case RIG_DCD_SERIAL_DSR:
|
case RIG_DCD_SERIAL_DSR:
|
||||||
case RIG_DCD_SERIAL_CTS:
|
case RIG_DCD_SERIAL_CTS:
|
||||||
rig->state.dcdport.fd = ser_open(&rig->state.dcdport);
|
rs->dcdport.fd = ser_open(&rs->dcdport);
|
||||||
if (rig->state.dcdport.fd < 0)
|
if (rs->dcdport.fd < 0)
|
||||||
rig_debug(RIG_DEBUG_ERR, "Cannot open DCD device \"%s\"\n",
|
rig_debug(RIG_DEBUG_ERR, "Cannot open DCD device \"%s\"\n",
|
||||||
rig->state.dcdport.pathname);
|
rs->dcdport.pathname);
|
||||||
break;
|
break;
|
||||||
case RIG_DCD_PARALLEL:
|
case RIG_DCD_PARALLEL:
|
||||||
rig->state.dcdport.fd = par_open(&rig->state.dcdport);
|
rs->dcdport.fd = par_open(&rs->dcdport);
|
||||||
if (rig->state.dcdport.fd < 0)
|
if (rs->dcdport.fd < 0)
|
||||||
rig_debug(RIG_DEBUG_ERR, "Cannot open DCD device \"%s\"\n",
|
rig_debug(RIG_DEBUG_ERR, "Cannot open DCD device \"%s\"\n",
|
||||||
rig->state.dcdport.pathname);
|
rs->dcdport.pathname);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
rig_debug(RIG_DEBUG_ERR, "Unsupported DCD type %d\n",
|
rig_debug(RIG_DEBUG_ERR, "Unsupported DCD type %d\n",
|
||||||
rig->state.dcdport.type.dcd);
|
rs->dcdport.type.dcd);
|
||||||
}
|
}
|
||||||
|
|
||||||
add_opened_rig(rig);
|
add_opened_rig(rig);
|
||||||
|
@ -434,6 +448,8 @@ int rig_open(RIG *rig)
|
||||||
if (!caps->targetable_vfo && caps->get_vfo)
|
if (!caps->targetable_vfo && caps->get_vfo)
|
||||||
caps->get_vfo(rig, &vfo);
|
caps->get_vfo(rig, &vfo);
|
||||||
|
|
||||||
|
rs->comm_state = RIG_COMM_OPEN;
|
||||||
|
|
||||||
return RIG_OK;
|
return RIG_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -464,6 +480,9 @@ int rig_close(RIG *rig)
|
||||||
caps = rig->caps;
|
caps = rig->caps;
|
||||||
rs = &rig->state;
|
rs = &rig->state;
|
||||||
|
|
||||||
|
if (rs->comm_state != RIG_COMM_OPEN)
|
||||||
|
return -RIG_EINVAL;
|
||||||
|
|
||||||
if (rs->transceive) {
|
if (rs->transceive) {
|
||||||
/*
|
/*
|
||||||
* TODO: check error codes et al.
|
* TODO: check error codes et al.
|
||||||
|
@ -550,6 +569,12 @@ int rig_cleanup(RIG *rig)
|
||||||
if (!rig || !rig->caps)
|
if (!rig || !rig->caps)
|
||||||
return -RIG_EINVAL;
|
return -RIG_EINVAL;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* check if they forgot to close the rig
|
||||||
|
*/
|
||||||
|
if (rig->state.comm_state == RIG_COMM_OPEN)
|
||||||
|
rig_close(rig);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* basically free up the priv struct
|
* basically free up the priv struct
|
||||||
*/
|
*/
|
||||||
|
|
Ładowanie…
Reference in New Issue