2005-04-16 15:20:36 -07:00
/* $Id: isdn_concap.c,v 1.1.2.2 2004/01/12 22:37:19 keil Exp $
2012-02-19 19:52:38 -08:00
*
2005-04-16 15:20:36 -07:00
* Linux ISDN subsystem , protocol encapsulation
*
* This software may be used and distributed according to the terms
* of the GNU General Public License , incorporated herein by reference .
*
*/
/* Stuff to support the concap_proto by isdn4linux. isdn4linux - specific
* stuff goes here . Stuff that depends only on the concap protocol goes to
* another - - protocol specific - - source file .
*
*/
# include <linux/isdn.h>
# include "isdn_x25iface.h"
# include "isdn_net.h"
# include <linux/concap.h>
# include "isdn_concap.h"
/* The following set of device service operations are for encapsulation
protocols that require for reliable datalink semantics . That means :
- before any data is to be submitted the connection must explicitly
2012-02-19 19:52:38 -08:00
be set up .
2005-04-16 15:20:36 -07:00
- after the successful set up of the connection is signalled the
2012-02-19 19:52:38 -08:00
connection is considered to be reliably up .
2005-04-16 15:20:36 -07:00
2012-02-19 19:52:38 -08:00
Auto - dialing ist not compatible with this requirements . Thus , auto - dialing
2005-04-16 15:20:36 -07:00
is completely bypassed .
It might be possible to implement a ( non standardized ) datalink protocol
that provides a reliable data link service while using some auto dialing
mechanism . Such a protocol would need an auxiliary channel ( i . e . user - user -
signaling on the D - channel ) while the B - channel is down .
2012-02-19 19:52:38 -08:00
*/
2005-04-16 15:20:36 -07:00
2005-06-25 14:58:35 -07:00
static int isdn_concap_dl_data_req ( struct concap_proto * concap , struct sk_buff * skb )
2005-04-16 15:20:36 -07:00
{
2012-02-19 19:52:38 -08:00
struct net_device * ndev = concap - > net_dev ;
2008-12-03 15:49:46 -08:00
isdn_net_dev * nd = ( ( isdn_net_local * ) netdev_priv ( ndev ) ) - > netdev ;
2005-04-16 15:20:36 -07:00
isdn_net_local * lp = isdn_net_get_locked_lp ( nd ) ;
2012-02-19 19:52:38 -08:00
IX25DEBUG ( " isdn_concap_dl_data_req: %s \n " , concap - > net_dev - > name ) ;
2005-04-16 15:20:36 -07:00
if ( ! lp ) {
2012-02-19 19:52:38 -08:00
IX25DEBUG ( " isdn_concap_dl_data_req: %s : isdn_net_send_skb returned %d \n " , concap - > net_dev - > name , 1 ) ;
2005-04-16 15:20:36 -07:00
return 1 ;
}
lp - > huptimer = 0 ;
isdn_net_writebuf_skb ( lp , skb ) ;
spin_unlock_bh ( & lp - > xmit_lock ) ;
2012-02-19 19:52:38 -08:00
IX25DEBUG ( " isdn_concap_dl_data_req: %s : isdn_net_send_skb returned %d \n " , concap - > net_dev - > name , 0 ) ;
2005-04-16 15:20:36 -07:00
return 0 ;
}
2005-06-25 14:58:35 -07:00
static int isdn_concap_dl_connect_req ( struct concap_proto * concap )
2005-04-16 15:20:36 -07:00
{
2012-02-19 19:52:38 -08:00
struct net_device * ndev = concap - > net_dev ;
2010-11-15 11:12:24 +00:00
isdn_net_local * lp = netdev_priv ( ndev ) ;
2005-04-16 15:20:36 -07:00
int ret ;
2012-02-19 19:52:38 -08:00
IX25DEBUG ( " isdn_concap_dl_connect_req: %s \n " , ndev - > name ) ;
2005-04-16 15:20:36 -07:00
/* dial ... */
2012-02-19 19:52:38 -08:00
ret = isdn_net_dial_req ( lp ) ;
if ( ret ) IX25DEBUG ( " dialing failed \n " ) ;
2005-04-16 15:20:36 -07:00
return ret ;
}
2005-06-25 14:58:35 -07:00
static int isdn_concap_dl_disconn_req ( struct concap_proto * concap )
2005-04-16 15:20:36 -07:00
{
2012-02-19 19:52:38 -08:00
IX25DEBUG ( " isdn_concap_dl_disconn_req: %s \n " , concap - > net_dev - > name ) ;
2005-04-16 15:20:36 -07:00
2012-02-19 19:52:38 -08:00
isdn_net_hangup ( concap - > net_dev ) ;
2005-04-16 15:20:36 -07:00
return 0 ;
}
struct concap_device_ops isdn_concap_reliable_dl_dops = {
& isdn_concap_dl_data_req ,
& isdn_concap_dl_connect_req ,
& isdn_concap_dl_disconn_req
} ;
/* The following should better go into a dedicated source file such that
this sourcefile does not need to include any protocol specific header
files . For now :
2012-02-19 19:52:38 -08:00
*/
struct concap_proto * isdn_concap_new ( int encap )
2005-04-16 15:20:36 -07:00
{
2012-02-19 19:52:38 -08:00
switch ( encap ) {
2005-04-16 15:20:36 -07:00
case ISDN_NET_ENCAP_X25IFACE :
return isdn_x25iface_proto_new ( ) ;
}
return NULL ;
}