113 строки
4.0 KiB
C
113 строки
4.0 KiB
C
/* $Id: isdnloop.h,v 1.5.6.3 2001/09/23 22:24:56 kai Exp $
|
|
*
|
|
* Loopback lowlevel module for testing of linklevel.
|
|
*
|
|
* Copyright 1997 by Fritz Elfert (fritz@isdn4linux.de)
|
|
*
|
|
* This software may be used and distributed according to the terms
|
|
* of the GNU General Public License, incorporated herein by reference.
|
|
*
|
|
*/
|
|
|
|
#ifndef isdnloop_h
|
|
#define isdnloop_h
|
|
|
|
#define ISDNLOOP_IOCTL_DEBUGVAR 0
|
|
#define ISDNLOOP_IOCTL_ADDCARD 1
|
|
#define ISDNLOOP_IOCTL_LEASEDCFG 2
|
|
#define ISDNLOOP_IOCTL_STARTUP 3
|
|
|
|
/* Struct for adding new cards */
|
|
typedef struct isdnloop_cdef {
|
|
char id1[10];
|
|
} isdnloop_cdef;
|
|
|
|
/* Struct for configuring cards */
|
|
typedef struct isdnloop_sdef {
|
|
int ptype;
|
|
char num[3][20];
|
|
} isdnloop_sdef;
|
|
|
|
#if defined(__KERNEL__) || defined(__DEBUGVAR__)
|
|
|
|
#ifdef __KERNEL__
|
|
/* Kernel includes */
|
|
|
|
#include <linux/errno.h>
|
|
#include <linux/fs.h>
|
|
#include <linux/major.h>
|
|
#include <asm/io.h>
|
|
#include <linux/kernel.h>
|
|
#include <linux/signal.h>
|
|
#include <linux/slab.h>
|
|
#include <linux/mm.h>
|
|
#include <linux/mman.h>
|
|
#include <linux/ioport.h>
|
|
#include <linux/timer.h>
|
|
#include <linux/wait.h>
|
|
#include <linux/isdnif.h>
|
|
|
|
#endif /* __KERNEL__ */
|
|
|
|
#define ISDNLOOP_FLAGS_B1ACTIVE 1 /* B-Channel-1 is open */
|
|
#define ISDNLOOP_FLAGS_B2ACTIVE 2 /* B-Channel-2 is open */
|
|
#define ISDNLOOP_FLAGS_RUNNING 4 /* Cards driver activated */
|
|
#define ISDNLOOP_FLAGS_RBTIMER 8 /* scheduling of B-Channel-poll */
|
|
#define ISDNLOOP_TIMER_BCREAD 1 /* B-Channel poll-cycle */
|
|
#define ISDNLOOP_TIMER_DCREAD (HZ/2) /* D-Channel poll-cycle */
|
|
#define ISDNLOOP_TIMER_ALERTWAIT (10*HZ) /* Alert timeout */
|
|
#define ISDNLOOP_MAX_SQUEUE 65536 /* Max. outstanding send-data */
|
|
#define ISDNLOOP_BCH 2 /* channels per card */
|
|
|
|
/*
|
|
* Per card driver data
|
|
*/
|
|
typedef struct isdnloop_card {
|
|
struct isdnloop_card *next; /* Pointer to next device struct */
|
|
struct isdnloop_card
|
|
*rcard[ISDNLOOP_BCH]; /* Pointer to 'remote' card */
|
|
int rch[ISDNLOOP_BCH]; /* 'remote' channel */
|
|
int myid; /* Driver-Nr. assigned by linklevel */
|
|
int leased; /* Flag: This Adapter is connected */
|
|
/* to a leased line */
|
|
int sil[ISDNLOOP_BCH]; /* SI's to listen for */
|
|
char eazlist[ISDNLOOP_BCH][11];
|
|
/* EAZ's to listen for */
|
|
char s0num[3][20]; /* 1TR6 base-number or MSN's */
|
|
unsigned short flags; /* Statusflags */
|
|
int ptype; /* Protocol type (1TR6 or Euro) */
|
|
struct timer_list st_timer; /* Timer for Status-Polls */
|
|
struct timer_list rb_timer; /* Timer for B-Channel-Polls */
|
|
struct timer_list
|
|
c_timer[ISDNLOOP_BCH]; /* Timer for Alerting */
|
|
int l2_proto[ISDNLOOP_BCH]; /* Current layer-2-protocol */
|
|
isdn_if interface; /* Interface to upper layer */
|
|
int iptr; /* Index to imsg-buffer */
|
|
char imsg[60]; /* Internal buf for status-parsing */
|
|
int optr; /* Index to omsg-buffer */
|
|
char omsg[60]; /* Internal buf for cmd-parsing */
|
|
char msg_buf[2048]; /* Buffer for status-messages */
|
|
char *msg_buf_write; /* Writepointer for statusbuffer */
|
|
char *msg_buf_read; /* Readpointer for statusbuffer */
|
|
char *msg_buf_end; /* Pointer to end of statusbuffer */
|
|
int sndcount[ISDNLOOP_BCH]; /* Byte-counters for B-Ch.-send */
|
|
struct sk_buff_head
|
|
bqueue[ISDNLOOP_BCH]; /* B-Channel queues */
|
|
struct sk_buff_head dqueue; /* D-Channel queue */
|
|
spinlock_t isdnloop_lock;
|
|
} isdnloop_card;
|
|
|
|
/*
|
|
* Main driver data
|
|
*/
|
|
#ifdef __KERNEL__
|
|
static isdnloop_card *cards = (isdnloop_card *) 0;
|
|
#endif /* __KERNEL__ */
|
|
|
|
/* Utility-Macros */
|
|
|
|
#define CID (card->interface.id)
|
|
|
|
#endif /* defined(__KERNEL__) || defined(__DEBUGVAR__) */
|
|
#endif /* isdnloop_h */
|