Commit c561747e authored by Armin Schindler's avatar Armin Schindler Committed by Linus Torvalds

[PATCH] ISDN Eicon driver: restructured capi list and lock handling

Restructered the CAPI code of list handling and lock.

Removed obsolete code.
parent e650bfc3
/* $Id: capifunc.c,v 1.48 2004/01/11 19:20:54 armin Exp $ /* $Id: capifunc.c,v 1.57 2004/03/20 18:18:03 armin Exp $
* *
* ISDN interface module for Eicon active cards DIVA. * ISDN interface module for Eicon active cards DIVA.
* CAPI Interface common functions * CAPI Interface common functions
...@@ -18,6 +18,7 @@ ...@@ -18,6 +18,7 @@
#include "divacapi.h" #include "divacapi.h"
#include "divasync.h" #include "divasync.h"
#include "capifunc.h" #include "capifunc.h"
#include "dlist.h"
#define DBG_MINIMUM (DL_LOG + DL_FTL + DL_ERR) #define DBG_MINIMUM (DL_LOG + DL_FTL + DL_ERR)
#define DBG_DEFAULT (DBG_MINIMUM + DL_XLOG + DL_REG) #define DBG_DEFAULT (DBG_MINIMUM + DL_XLOG + DL_REG)
...@@ -39,9 +40,9 @@ extern word CapiRegister(word); ...@@ -39,9 +40,9 @@ extern word CapiRegister(word);
extern word api_put(APPL *, CAPI_MSG *); extern word api_put(APPL *, CAPI_MSG *);
static diva_os_spin_lock_t api_lock; static diva_os_spin_lock_t api_lock;
static diva_os_spin_lock_t ll_lock;
static diva_card *cards; static LIST_HEAD(cards);
static dword notify_handle; static dword notify_handle;
static void DIRequest(ENTITY * e); static void DIRequest(ENTITY * e);
static DESCRIPTOR MAdapter; static DESCRIPTOR MAdapter;
...@@ -57,6 +58,11 @@ static u16 diva_send_message(struct capi_ctr *, ...@@ -57,6 +58,11 @@ static u16 diva_send_message(struct capi_ctr *,
diva_os_message_buffer_s *); diva_os_message_buffer_s *);
extern void diva_os_set_controller_struct(struct capi_ctr *); extern void diva_os_set_controller_struct(struct capi_ctr *);
/*
* include queue functions
*/
#include "dlist.c"
extern void DIVA_DIDD_Read(DESCRIPTOR *, int); extern void DIVA_DIDD_Read(DESCRIPTOR *, int);
/* /*
...@@ -152,26 +158,15 @@ byte UnMapController(byte MappedController) ...@@ -152,26 +158,15 @@ byte UnMapController(byte MappedController)
static int find_free_id(void) static int find_free_id(void)
{ {
int num = 0; int num = 0;
diva_card *p; DIVA_CAPI_ADAPTER *a;
diva_os_spin_lock_magic_t old_irql;
diva_os_enter_spin_lock(&ll_lock, &old_irql, "find free id"); while (num < MAX_DESCRIPTORS) {
while (num < 100) { a = &adapter[num];
num++; if (!a->Id)
p = cards;
while (p) {
if (p->Id == num)
break; break;
p = p->next; num++;
}
if(!p) {
diva_os_leave_spin_lock(&ll_lock, &old_irql,
"find free id");
return (num);
}
} }
diva_os_leave_spin_lock(&ll_lock, &old_irql, "find free id"); return(num + 1);
return (999);
} }
/* /*
...@@ -179,21 +174,17 @@ static int find_free_id(void) ...@@ -179,21 +174,17 @@ static int find_free_id(void)
*/ */
static diva_card *find_card_by_ctrl(word controller) static diva_card *find_card_by_ctrl(word controller)
{ {
diva_card *p; struct list_head *tmp;
diva_os_spin_lock_magic_t old_irql; diva_card *card;
diva_os_enter_spin_lock(&ll_lock, &old_irql, "find card ctrl");
p = cards;
while (p) { list_for_each(tmp, &cards) {
if (ControllerMap[p->Id] == controller) { card = list_entry(tmp, diva_card, list);
diva_os_leave_spin_lock(&ll_lock, &old_irql, if (ControllerMap[card->Id] == controller) {
"find card ctrl"); if (card->remove_in_progress)
return p; card = NULL;
return(card);
} }
p = p->next;
} }
diva_os_leave_spin_lock(&ll_lock, &old_irql, "find card ctrl");
return (diva_card *) 0; return (diva_card *) 0;
} }
...@@ -358,28 +349,18 @@ void sendf(APPL * appl, word command, dword Id, word Number, byte * format, ...) ...@@ -358,28 +349,18 @@ void sendf(APPL * appl, word command, dword Id, word Number, byte * format, ...)
/* /*
* cleanup adapter * cleanup adapter
*/ */
static void clean_adapter(int id) static void clean_adapter(int id, diva_entity_queue_t* free_mem_q)
{ {
DIVA_CAPI_ADAPTER *a; DIVA_CAPI_ADAPTER *a;
#if IMPLEMENT_LINE_INTERCONNECT2
int i, k; int i, k;
#endif /* IMPLEMENT_LINE_INTERCONNECT2 */
a = &adapter[id]; a = &adapter[id];
#if IMPLEMENT_LINE_INTERCONNECT
if (a->li_pri) {
if (a->li_config.pri)
diva_os_free(0, a->li_config.pri);
} else {
if (a->li_config.bri)
diva_os_free(0, a->li_config.bri);
}
#endif /* IMPLEMENT_LINE_INTERCONNECT */
#if IMPLEMENT_LINE_INTERCONNECT2
k = li_total_channels - a->li_channels; k = li_total_channels - a->li_channels;
if (k == 0) { if (k == 0) {
diva_os_free(0, li_config_table); if (li_config_table) {
diva_q_add_tail(free_mem_q, (diva_entity_link_t*)li_config_table);
li_config_table = NULL; li_config_table = NULL;
}
} else { } else {
if (a->li_base < k) { if (a->li_base < k) {
memmove(&li_config_table[a->li_base], memmove(&li_config_table[a->li_base],
...@@ -401,9 +382,8 @@ static void clean_adapter(int id) ...@@ -401,9 +382,8 @@ static void clean_adapter(int id)
if (adapter[i].request) if (adapter[i].request)
adapter[i].li_base -= a->li_channels; adapter[i].li_base -= a->li_channels;
} }
#endif /* IMPLEMENT_LINE_INTERCONNECT2 */
if (a->plci) if (a->plci)
diva_os_free(0, a->plci); diva_q_add_tail(free_mem_q, (diva_entity_link_t*)a->plci);
memset(a, 0x00, sizeof(DIVA_CAPI_ADAPTER)); memset(a, 0x00, sizeof(DIVA_CAPI_ADAPTER));
while ((max_adapter != 0) && !adapter[max_adapter - 1].request) while ((max_adapter != 0) && !adapter[max_adapter - 1].request)
...@@ -411,67 +391,87 @@ static void clean_adapter(int id) ...@@ -411,67 +391,87 @@ static void clean_adapter(int id)
} }
/* /*
* remove cards * remove a card, but ensures consistent state of LI tables
* in the time adapter is removed
*/ */
static void DIVA_EXIT_FUNCTION divacapi_remove_cards(void) static void divacapi_remove_card(DESCRIPTOR * d)
{ {
diva_card *last; struct list_head *tmp;
diva_card *card; diva_card *card = NULL;
diva_entity_queue_t free_mem_q;
diva_entity_link_t* link;
diva_os_spin_lock_magic_t old_irql; diva_os_spin_lock_magic_t old_irql;
diva_os_enter_spin_lock(&ll_lock, &old_irql, "remove cards"); diva_q_init (&free_mem_q);
card = cards;
while (card) { /*
* Set "remove in progress flag".
* Ensures that there is no call from sendf to CAPI in
* the time CAPI controller is about to be removed.
*/
diva_os_enter_spin_lock(&api_lock, &old_irql, "remove card");
list_for_each(tmp, &cards) {
card = list_entry(tmp, diva_card, list);
if (card->d.request == d->request) {
card->remove_in_progress = 1;
list_del(tmp);
break;
}
}
diva_os_leave_spin_lock(&api_lock, &old_irql, "remove card");
if (card) {
/*
* Detach CAPI. Sendf cannot call to CAPI any more.
* After detach no call to send_message() is done too.
*/
detach_capi_ctr(&card->capi_ctrl); detach_capi_ctr(&card->capi_ctrl);
clean_adapter(card->Id - 1);
DBG_TRC(("adapter remove, max_adapter=%d", max_adapter)); /*
card = card->next; * Now get API lock (to ensure stable state of LI tables)
* and update the adapter map/LI table.
*/
diva_os_enter_spin_lock(&api_lock, &old_irql, "remove card");
clean_adapter(card->Id - 1, &free_mem_q);
DBG_TRC(("DelAdapterMap (%d) -> (%d)",
ControllerMap[card->Id], card->Id))
ControllerMap[card->Id] = 0;
DBG_TRC(("adapter remove, max_adapter=%d",
max_adapter));
diva_os_leave_spin_lock(&api_lock, &old_irql, "remove card");
/* After releasing the lock, we can free the memory */
diva_os_free (0, card);
} }
card = cards; /* free queued memory areas */
while (card) { while ((link = diva_q_get_head(&free_mem_q))) {
last = card; diva_q_remove(&free_mem_q, link);
card = card->next; diva_os_free(0, link);
diva_os_free(0, last);
} }
diva_os_leave_spin_lock(&ll_lock, &old_irql, "remove cards");
} }
/* /*
* remove a card * remove cards
*/ */
static void divacapi_remove_card(DESCRIPTOR * d) static void DIVA_EXIT_FUNCTION divacapi_remove_cards(void)
{ {
diva_card *last; DESCRIPTOR d;
struct list_head *tmp;
diva_card *card; diva_card *card;
diva_os_spin_lock_magic_t old_irql; diva_os_spin_lock_magic_t old_irql;
diva_os_enter_spin_lock(&ll_lock, &old_irql, "remove card"); rescan:
last = card = cards; diva_os_enter_spin_lock(&api_lock, &old_irql, "remove cards");
while (card) { list_for_each(tmp, &cards) {
if (card->d.request == d->request) { card = list_entry(tmp, diva_card, list);
detach_capi_ctr(&card->capi_ctrl); diva_os_leave_spin_lock(&api_lock, &old_irql, "remove cards");
clean_adapter(card->Id - 1); d.request = card->d.request;
DBG_TRC( divacapi_remove_card(&d);
("DelAdapterMap (%d) -> (%d)", goto rescan;
ControllerMap[card->Id], card->Id))
ControllerMap[card->Id] = 0;
DBG_TRC(
("adapter remove, max_adapter=%d",
max_adapter));
if (card == last)
cards = card->next;
else
last->next = card->next;
diva_os_free(0, card);
break;
}
last = card;
card = card->next;
} }
diva_os_leave_spin_lock(&ll_lock, &old_irql, "remove card"); diva_os_leave_spin_lock(&api_lock, &old_irql, "remove cards");
} }
/* /*
...@@ -500,10 +500,9 @@ static int diva_add_card(DESCRIPTOR * d) ...@@ -500,10 +500,9 @@ static int diva_add_card(DESCRIPTOR * d)
DIVA_CAPI_ADAPTER *a = NULL; DIVA_CAPI_ADAPTER *a = NULL;
IDI_SYNC_REQ sync_req; IDI_SYNC_REQ sync_req;
char serial[16]; char serial[16];
#if IMPLEMENT_LINE_INTERCONNECT2 void* mem_to_free;
LI_CONFIG *new_li_config_table; LI_CONFIG *new_li_config_table;
int j; int j;
#endif /* IMPLEMENT_LINE_INTERCONNECT2 */
if (!(card = (diva_card *) diva_os_malloc(0, sizeof(diva_card)))) { if (!(card = (diva_card *) diva_os_malloc(0, sizeof(diva_card)))) {
DBG_ERR(("diva_add_card: failed to allocate card struct.")) DBG_ERR(("diva_add_card: failed to allocate card struct."))
...@@ -529,7 +528,11 @@ static int diva_add_card(DESCRIPTOR * d) ...@@ -529,7 +528,11 @@ static int diva_add_card(DESCRIPTOR * d)
diva_os_free(0, card); diva_os_free(0, card);
return (0); return (0);
} }
diva_os_enter_spin_lock(&api_lock, &old_irql, "find id");
card->Id = find_free_id(); card->Id = find_free_id();
diva_os_leave_spin_lock(&api_lock, &old_irql, "find id");
strlcpy(ctrl->manu, M_COMPANY, sizeof(ctrl->manu)); strlcpy(ctrl->manu, M_COMPANY, sizeof(ctrl->manu));
ctrl->version.majorversion = 2; ctrl->version.majorversion = 2;
ctrl->version.minorversion = 0; ctrl->version.minorversion = 0;
...@@ -600,9 +603,7 @@ static int diva_add_card(DESCRIPTOR * d) ...@@ -600,9 +603,7 @@ static int diva_add_card(DESCRIPTOR * d)
#if IMPLEMENT_DTMF #if IMPLEMENT_DTMF
a->profile.Global_Options |= 0x8; a->profile.Global_Options |= 0x8;
#endif /* IMPLEMENT_DTMF */ #endif /* IMPLEMENT_DTMF */
#if (IMPLEMENT_LINE_INTERCONNECT || IMPLEMENT_LINE_INTERCONNECT2) a->profile.Global_Options |= 0x80; /* Line Interconnect */
a->profile.Global_Options |= 0x80;
#endif /* (IMPLEMENT_LINE_INTERCONNECT || IMPLEMENT_LINE_INTERCONNECT2) */
#if IMPLEMENT_ECHO_CANCELLER #if IMPLEMENT_ECHO_CANCELLER
a->profile.Global_Options |= 0x100; a->profile.Global_Options |= 0x100;
#endif /* IMPLEMENT_ECHO_CANCELLER */ #endif /* IMPLEMENT_ECHO_CANCELLER */
...@@ -620,25 +621,6 @@ static int diva_add_card(DESCRIPTOR * d) ...@@ -620,25 +621,6 @@ static int diva_add_card(DESCRIPTOR * d)
a->manufacturer_features = 0; a->manufacturer_features = 0;
} }
#if IMPLEMENT_LINE_INTERCONNECT
a->li_pri = (a->profile.Channels > 2);
if (a->li_pri) {
if (!(a->li_config.pri = (LI_CONFIG_PRI *) diva_os_malloc(0, sizeof(LI_CONFIG_PRI)))) {
DBG_ERR(("diva_add_card: failed alloc li_config.pri struct."))
memset(a, 0, sizeof(DIVA_CAPI_ADAPTER));
return (0);
}
memset(a->li_config.pri, 0, sizeof(LI_CONFIG_PRI));
} else
if (!(a->li_config.bri = (LI_CONFIG_BRI *) diva_os_malloc(0, sizeof(LI_CONFIG_BRI)))) {
DBG_ERR(("diva_add_card: failed alloc li_config.bri struct."))
memset(a, 0, sizeof(DIVA_CAPI_ADAPTER));
return (0);
}
memset(a->li_config.bri, 0, sizeof(LI_CONFIG_BRI));
}
#endif /* IMPLEMENT_LINE_INTERCONNECT */
#if IMPLEMENT_LINE_INTERCONNECT2
a->li_pri = (a->profile.Channels > 2); a->li_pri = (a->profile.Channels > 2);
a->li_channels = a->li_pri ? MIXER_CHANNELS_PRI : MIXER_CHANNELS_BRI; a->li_channels = a->li_pri ? MIXER_CHANNELS_PRI : MIXER_CHANNELS_BRI;
a->li_base = 0; a->li_base = 0;
...@@ -654,6 +636,10 @@ static int diva_add_card(DESCRIPTOR * d) ...@@ -654,6 +636,10 @@ static int diva_add_card(DESCRIPTOR * d)
memset(a, 0, sizeof(DIVA_CAPI_ADAPTER)); memset(a, 0, sizeof(DIVA_CAPI_ADAPTER));
return (0); return (0);
} }
/* Prevent access to line interconnect table in process update */
diva_os_enter_spin_lock(&api_lock, &old_irql, "add card");
j = 0; j = 0;
for (i = 0; i < k; i++) { for (i = 0; i < k; i++) {
if ((i >= a->li_base) && (i < a->li_base + a->li_channels)) if ((i >= a->li_base) && (i < a->li_base + a->li_channels))
...@@ -694,25 +680,26 @@ static int diva_add_card(DESCRIPTOR * d) ...@@ -694,25 +680,26 @@ static int diva_add_card(DESCRIPTOR * d)
} }
li_total_channels = k; li_total_channels = k;
if (li_config_table != NULL) mem_to_free = li_config_table;
diva_os_free(0, li_config_table);
li_config_table = new_li_config_table; li_config_table = new_li_config_table;
for (i = card->Id; i < max_adapter; i++) { for (i = card->Id; i < max_adapter; i++) {
if (adapter[i].request) if (adapter[i].request)
adapter[i].li_base += a->li_channels; adapter[i].li_base += a->li_channels;
} }
#endif /* IMPLEMENT_LINE_INTERCONNECT2 */
if (a == &adapter[max_adapter]) if (a == &adapter[max_adapter])
max_adapter++; max_adapter++;
diva_os_enter_spin_lock(&ll_lock, &old_irql, "add card"); list_add(&(card->list), &cards);
card->next = cards;
cards = card;
diva_os_leave_spin_lock(&ll_lock, &old_irql, "add card");
AutomaticLaw(a); AutomaticLaw(a);
diva_os_leave_spin_lock(&api_lock, &old_irql, "add card");
if (mem_to_free) {
diva_os_free (0, mem_to_free);
}
i = 0; i = 0;
while (i++ < 30) { while (i++ < 30) {
if (a->automatic_law > 3) if (a->automatic_law > 3)
...@@ -863,6 +850,7 @@ static void diva_release_appl(struct capi_ctr *ctrl, __u16 appl) ...@@ -863,6 +850,7 @@ static void diva_release_appl(struct capi_ctr *ctrl, __u16 appl)
{ {
diva_os_spin_lock_magic_t old_irql; diva_os_spin_lock_magic_t old_irql;
APPL *this = &application[appl - 1]; APPL *this = &application[appl - 1];
void *mem_to_free = NULL;
DBG_TRC(("application %d(%d) cleanup", this->Id, appl)) DBG_TRC(("application %d(%d) cleanup", this->Id, appl))
...@@ -874,13 +862,15 @@ static void diva_release_appl(struct capi_ctr *ctrl, __u16 appl) ...@@ -874,13 +862,15 @@ static void diva_release_appl(struct capi_ctr *ctrl, __u16 appl)
diva_os_enter_spin_lock(&api_lock, &old_irql, "release_appl"); diva_os_enter_spin_lock(&api_lock, &old_irql, "release_appl");
if (this->Id) { if (this->Id) {
CapiRelease(this->Id); CapiRelease(this->Id);
if (this->DataNCCI) mem_to_free = this->DataNCCI;
diva_os_free(0, this->DataNCCI);
this->DataNCCI = NULL; this->DataNCCI = NULL;
this->Id = 0; this->Id = 0;
} }
diva_os_leave_spin_lock(&api_lock, &old_irql, "release_appl"); diva_os_leave_spin_lock(&api_lock, &old_irql, "release_appl");
if (mem_to_free)
diva_os_free(0, mem_to_free);
} }
/* /*
...@@ -906,6 +896,11 @@ static u16 diva_send_message(struct capi_ctr *ctrl, ...@@ -906,6 +896,11 @@ static u16 diva_send_message(struct capi_ctr *ctrl,
} }
DBG_PRV1(("Write - appl = %d, cmd = 0x%x", this->Id, command)) DBG_PRV1(("Write - appl = %d, cmd = 0x%x", this->Id, command))
if (card->remove_in_progress) {
DBG_ERR(("CAPI_SEND_MSG - remove in progress!"))
return CAPI_REGOSRESOURCEERR;
}
if (!this->Id) { if (!this->Id) {
return CAPI_ILLAPPNR; return CAPI_ILLAPPNR;
} }
...@@ -1162,12 +1157,31 @@ static void remove_main_structs(void) ...@@ -1162,12 +1157,31 @@ static void remove_main_structs(void)
diva_os_free(0, mapped_msg); diva_os_free(0, mapped_msg);
} }
/*
* api_remove_start
*/
static void do_api_remove_start(void)
{
diva_os_spin_lock_magic_t old_irql;
int ret = 1, count = 100;
do {
diva_os_enter_spin_lock(&api_lock, &old_irql, "api remove start");
ret = api_remove_start();
diva_os_leave_spin_lock(&api_lock, &old_irql, "api remove start");
diva_os_sleep(10);
} while (ret && count--);
if (ret)
DBG_ERR(("could not remove signaling ID's"))
}
/* /*
* init * init
*/ */
int DIVA_INIT_FUNCTION init_capifunc(void) int DIVA_INIT_FUNCTION init_capifunc(void)
{ {
diva_os_initialize_spin_lock(&ll_lock, "capifunc");
diva_os_initialize_spin_lock(&api_lock, "capifunc"); diva_os_initialize_spin_lock(&api_lock, "capifunc");
memset(ControllerMap, 0, MAX_DESCRIPTORS + 1); memset(ControllerMap, 0, MAX_DESCRIPTORS + 1);
max_adapter = 0; max_adapter = 0;
...@@ -1175,12 +1189,16 @@ int DIVA_INIT_FUNCTION init_capifunc(void) ...@@ -1175,12 +1189,16 @@ int DIVA_INIT_FUNCTION init_capifunc(void)
if (!init_main_structs()) { if (!init_main_structs()) {
DBG_ERR(("init: failed to init main structs.")) DBG_ERR(("init: failed to init main structs."))
diva_os_destroy_spin_lock(&api_lock, "capifunc");
return (0); return (0);
} }
if (!divacapi_connect_didd()) { if (!divacapi_connect_didd()) {
DBG_ERR(("init: failed to connect to DIDD.")) DBG_ERR(("init: failed to connect to DIDD."))
do_api_remove_start();
divacapi_remove_cards();
remove_main_structs(); remove_main_structs();
diva_os_destroy_spin_lock(&api_lock, "capifunc");
return (0); return (0);
} }
...@@ -1192,21 +1210,9 @@ int DIVA_INIT_FUNCTION init_capifunc(void) ...@@ -1192,21 +1210,9 @@ int DIVA_INIT_FUNCTION init_capifunc(void)
*/ */
void DIVA_EXIT_FUNCTION finit_capifunc(void) void DIVA_EXIT_FUNCTION finit_capifunc(void)
{ {
int count = 100; do_api_remove_start();
word ret = 1;
while (ret && count--) {
ret = api_remove_start();
diva_os_sleep(10);
}
if (ret)
DBG_ERR(("could not remove signaling ID's"))
divacapi_disconnect_didd(); divacapi_disconnect_didd();
divacapi_remove_cards(); divacapi_remove_cards();
remove_main_structs(); remove_main_structs();
diva_os_destroy_spin_lock(&api_lock, "capifunc"); diva_os_destroy_spin_lock(&api_lock, "capifunc");
diva_os_destroy_spin_lock(&ll_lock, "capifunc");
} }
/* $Id: capifunc.h,v 1.10 2003/08/25 10:06:37 schindler Exp $ /* $Id: capifunc.h,v 1.11 2004/03/20 17:19:58 armin Exp $
* *
* ISDN interface module for Eicon active cards DIVA. * ISDN interface module for Eicon active cards DIVA.
* CAPI Interface common functions * CAPI Interface common functions
...@@ -24,8 +24,9 @@ ...@@ -24,8 +24,9 @@
extern char DRIVERRELEASE_CAPI[]; extern char DRIVERRELEASE_CAPI[];
typedef struct _diva_card { typedef struct _diva_card {
struct list_head list;
int remove_in_progress;
int Id; int Id;
struct _diva_card *next;
struct capi_ctr capi_ctrl; struct capi_ctr capi_ctrl;
DIVA_CAPI_ADAPTER *adapter; DIVA_CAPI_ADAPTER *adapter;
DESCRIPTOR d; DESCRIPTOR d;
......
/* $Id: platform.h,v 1.35 2003/12/05 18:45:05 armin Exp $ /* $Id: platform.h,v 1.37 2004/03/20 17:44:29 armin Exp $
* *
* platform.h * platform.h
* *
...@@ -29,6 +29,7 @@ ...@@ -29,6 +29,7 @@
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/smp_lock.h> #include <linux/smp_lock.h>
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/list.h>
#include <asm/types.h> #include <asm/types.h>
#include <asm/io.h> #include <asm/io.h>
...@@ -332,7 +333,6 @@ diva_os_atomic_decrement(diva_os_atomic_t* pv) ...@@ -332,7 +333,6 @@ diva_os_atomic_decrement(diva_os_atomic_t* pv)
*/ */
#define NO_CORNETN #define NO_CORNETN
#define IMPLEMENT_DTMF 1 #define IMPLEMENT_DTMF 1
#define IMPLEMENT_LINE_INTERCONNECT2 1
#define IMPLEMENT_ECHO_CANCELLER 1 #define IMPLEMENT_ECHO_CANCELLER 1
#define IMPLEMENT_RTP 1 #define IMPLEMENT_RTP 1
#define IMPLEMENT_T38 1 #define IMPLEMENT_T38 1
...@@ -346,7 +346,6 @@ diva_os_atomic_decrement(diva_os_atomic_t* pv) ...@@ -346,7 +346,6 @@ diva_os_atomic_decrement(diva_os_atomic_t* pv)
#define IMPLEMENT_FAX_NONSTANDARD 1 #define IMPLEMENT_FAX_NONSTANDARD 1
#define VSWITCH_SUPPORT 1 #define VSWITCH_SUPPORT 1
#define IMPLEMENT_LINE_INTERCONNECT 0
#define IMPLEMENT_MARKED_OK_AFTER_FC 1 #define IMPLEMENT_MARKED_OK_AFTER_FC 1
#define DIVA_IDI_RX_DMA 1 #define DIVA_IDI_RX_DMA 1
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment