summaryrefslogtreecommitdiffstats
path: root/interface.c
diff options
context:
space:
mode:
authorSuper User2007-05-09 07:39:20 +0200
committerSuper User2007-05-09 07:39:20 +0200
commit559ff64e3062b70f27ddceba825f40642a6c5725 (patch)
tree5d1fcfb704616da846db41ec7985b84a32e0bfd1 /interface.c
parentonly for backup, still in coding state - no compile!!! (diff)
downloadlcr-559ff64e3062b70f27ddceba825f40642a6c5725.tar.gz
lcr-559ff64e3062b70f27ddceba825f40642a6c5725.tar.xz
lcr-559ff64e3062b70f27ddceba825f40642a6c5725.zip
backup work
Diffstat (limited to 'interface.c')
-rw-r--r--interface.c58
1 files changed, 55 insertions, 3 deletions
diff --git a/interface.c b/interface.c
index 8ff0932..520ecbd 100644
--- a/interface.c
+++ b/interface.c
@@ -158,6 +158,11 @@ static int inter_ptp(struct interface *interface, char *filename, int line, char
SPRINT(interface_error, "Error in %s (line %d): parameter '%s' expects previous 'port' definition.\n", filename, line, parameter);
return(-1);
}
+ if (interface->ifport->ptmp)
+ {
+ SPRINT(interface_error, "Error in %s (line %d): parameter '%s' previously ptmp was given.\n", filename, line, parameter);
+ return(-1);
+ }
/* goto end of chain */
ifport = interface->ifport;
while(ifport->next)
@@ -171,6 +176,34 @@ static int inter_ptp(struct interface *interface, char *filename, int line, char
ifport->ptp = 1;
return(0);
}
+static int inter_ptmp(struct interface *interface, char *filename, int line, char *parameter, char *value)
+{
+ struct interface_port *ifport;
+
+ /* port in chain ? */
+ if (!interface->ifport)
+ {
+ SPRINT(interface_error, "Error in %s (line %d): parameter '%s' expects previous 'port' definition.\n", filename, line, parameter);
+ return(-1);
+ }
+ if (interface->ifport->ptp)
+ {
+ SPRINT(interface_error, "Error in %s (line %d): parameter '%s' previously ptp was given.\n", filename, line, parameter);
+ return(-1);
+ }
+ /* goto end of chain */
+ ifport = interface->ifport;
+ while(ifport->next)
+ ifport = ifport->next;
+ /* add value */
+ if (value[0])
+ {
+ SPRINT(interface_error, "Error in %s (line %d): parameter '%s' expects no value.\n", filename, line, parameter);
+ return(-1);
+ }
+ ifport->ptmp = 1;
+ return(0);
+}
static int inter_tones(struct interface *interface, char *filename, int line, char *parameter, char *value)
{
if (!strcasecmp(value, "yes"))
@@ -641,6 +674,11 @@ struct interface_param interface_param[] = {
"This is required on NT-mode ports that are multipoint by default.\n"
"This parameter must follow a 'port' parameter."},
+ {"ptmp", &inter_ptmp, "",
+ "The given port above is opened as point-to-multipoint.\n"
+ "This is required on PRI NT-mode ports that are point-to-point by default.\n"
+ "This parameter must follow a 'port' parameter."},
+
{"channel_out", &inter_channel_out, "[force,][<number>][,...][,free][,any][,no]",
"Channel selection list for all outgoing calls to the interface.\n"
"A free channels is searched in order of appearance.\n"
@@ -1010,15 +1048,29 @@ void relink_interfaces(void)
if (!ifport->mISDNport)
{
/* open new port */
- mISDNport = mISDNport_open(ifport->portnum, ifport->ptp);
+ mISDNport = mISDNport_open(ifport->portnum, ifport->ptp, ifport->ptmp);
if (mISDNport)
{
ifport->mISDNport = mISDNport;
mISDNport->ifport = ifport;
}
}
- if (ifport->mISDNport && !ifport->selchannel)
- default_selchannel(ifport);
+ if (ifport->mISDNport)
+ {
+ /* default channel selection list */
+ if (!ifport->selchannel)
+ default_selchannel(ifport);
+ /* default is_tones */
+ if (ifport->interface->is_tones)
+ ifport->mISDNport->is_tones = (ifport->interface->is_tones==IS_YES);
+ else
+ ifport->mISDNport->is_tones = (ifport->mISDNport->ntmode)?1:0;
+ /* default is_earlyb */
+ if (ifport->interface->is_earlyb)
+ ifport->mISDNport->is_earlyb = (ifport->interface->is_earlyb==IS_YES);
+ else
+ ifport->mISDNport->is_earlyb = (ifport->mISDNport->ntmode)?0:1;
+ }
}
interface = interface->next;
}