|  | /* | 
|  | * DLCI/FRAD	Definitions for Frame Relay Access Devices.  DLCI devices are | 
|  | *		created for each DLCI associated with a FRAD.  The FRAD driver | 
|  | *		is not truly a network device, but the lower level device | 
|  | *		handler.  This allows other FRAD manufacturers to use the DLCI | 
|  | *		code, including its RFC1490 encapsulation alongside the current | 
|  | *		implementation for the Sangoma cards. | 
|  | * | 
|  | * Version:	@(#)if_ifrad.h	0.15	31 Mar 96 | 
|  | * | 
|  | * Author:	Mike McLagan <mike.mclagan@linux.org> | 
|  | * | 
|  | * Changes: | 
|  | *		0.15	Mike McLagan	changed structure defs (packed) | 
|  | *					re-arranged flags | 
|  | *					added DLCI_RET vars | 
|  | * | 
|  | *		This program is free software; you can redistribute it and/or | 
|  | *		modify it under the terms of the GNU General Public License | 
|  | *		as published by the Free Software Foundation; either version | 
|  | *		2 of the License, or (at your option) any later version. | 
|  | */ | 
|  |  | 
|  | #ifndef _FRAD_H_ | 
|  | #define _FRAD_H_ | 
|  |  | 
|  | #include <linux/if.h> | 
|  |  | 
|  | /* Structures and constants associated with the DLCI device driver */ | 
|  |  | 
|  | struct dlci_add | 
|  | { | 
|  | char  devname[IFNAMSIZ]; | 
|  | short dlci; | 
|  | }; | 
|  |  | 
|  | #define DLCI_GET_CONF	(SIOCDEVPRIVATE + 2) | 
|  | #define DLCI_SET_CONF	(SIOCDEVPRIVATE + 3) | 
|  |  | 
|  | /* | 
|  | * These are related to the Sangoma SDLA and should remain in order. | 
|  | * Code within the SDLA module is based on the specifics of this | 
|  | * structure.  Change at your own peril. | 
|  | */ | 
|  | struct dlci_conf { | 
|  | short flags; | 
|  | short CIR_fwd; | 
|  | short Bc_fwd; | 
|  | short Be_fwd; | 
|  | short CIR_bwd; | 
|  | short Bc_bwd; | 
|  | short Be_bwd; | 
|  |  | 
|  | /* these are part of the status read */ | 
|  | short Tc_fwd; | 
|  | short Tc_bwd; | 
|  | short Tf_max; | 
|  | short Tb_max; | 
|  |  | 
|  | /* add any new fields here above is a mirror of sdla_dlci_conf */ | 
|  | }; | 
|  |  | 
|  | #define DLCI_GET_SLAVE	(SIOCDEVPRIVATE + 4) | 
|  |  | 
|  | /* configuration flags for DLCI */ | 
|  | #define DLCI_IGNORE_CIR_OUT	0x0001 | 
|  | #define DLCI_ACCOUNT_CIR_IN	0x0002 | 
|  | #define DLCI_BUFFER_IF		0x0008 | 
|  |  | 
|  | #define DLCI_VALID_FLAGS	0x000B | 
|  |  | 
|  | /* defines for the actual Frame Relay hardware */ | 
|  | #define FRAD_GET_CONF	(SIOCDEVPRIVATE) | 
|  | #define FRAD_SET_CONF	(SIOCDEVPRIVATE + 1) | 
|  |  | 
|  | #define FRAD_LAST_IOCTL	FRAD_SET_CONF | 
|  |  | 
|  | /* | 
|  | * Based on the setup for the Sangoma SDLA.  If changes are | 
|  | * necessary to this structure, a routine will need to be | 
|  | * added to that module to copy fields. | 
|  | */ | 
|  | struct frad_conf | 
|  | { | 
|  | short station; | 
|  | short flags; | 
|  | short kbaud; | 
|  | short clocking; | 
|  | short mtu; | 
|  | short T391; | 
|  | short T392; | 
|  | short N391; | 
|  | short N392; | 
|  | short N393; | 
|  | short CIR_fwd; | 
|  | short Bc_fwd; | 
|  | short Be_fwd; | 
|  | short CIR_bwd; | 
|  | short Bc_bwd; | 
|  | short Be_bwd; | 
|  |  | 
|  | /* Add new fields here, above is a mirror of the sdla_conf */ | 
|  |  | 
|  | }; | 
|  |  | 
|  | #define FRAD_STATION_CPE	0x0000 | 
|  | #define FRAD_STATION_NODE	0x0001 | 
|  |  | 
|  | #define FRAD_TX_IGNORE_CIR	0x0001 | 
|  | #define FRAD_RX_ACCOUNT_CIR	0x0002 | 
|  | #define FRAD_DROP_ABORTED	0x0004 | 
|  | #define FRAD_BUFFERIF		0x0008 | 
|  | #define FRAD_STATS		0x0010 | 
|  | #define FRAD_MCI		0x0100 | 
|  | #define FRAD_AUTODLCI		0x8000 | 
|  | #define FRAD_VALID_FLAGS	0x811F | 
|  |  | 
|  | #define FRAD_CLOCK_INT		0x0001 | 
|  | #define FRAD_CLOCK_EXT		0x0000 | 
|  |  | 
|  | #ifdef __KERNEL__ | 
|  |  | 
|  | #if defined(CONFIG_DLCI) || defined(CONFIG_DLCI_MODULE) | 
|  |  | 
|  | /* these are the fields of an RFC 1490 header */ | 
|  | struct frhdr | 
|  | { | 
|  | unsigned char  control; | 
|  |  | 
|  | /* for IP packets, this can be the NLPID */ | 
|  | unsigned char  pad; | 
|  |  | 
|  | unsigned char  NLPID; | 
|  | unsigned char  OUI[3]; | 
|  | __be16 PID; | 
|  |  | 
|  | #define IP_NLPID pad | 
|  | } __packed; | 
|  |  | 
|  | /* see RFC 1490 for the definition of the following */ | 
|  | #define FRAD_I_UI		0x03 | 
|  |  | 
|  | #define FRAD_P_PADDING		0x00 | 
|  | #define FRAD_P_Q933		0x08 | 
|  | #define FRAD_P_SNAP		0x80 | 
|  | #define FRAD_P_CLNP		0x81 | 
|  | #define FRAD_P_IP		0xCC | 
|  |  | 
|  | struct dlci_local | 
|  | { | 
|  | struct net_device      *master; | 
|  | struct net_device      *slave; | 
|  | struct dlci_conf       config; | 
|  | int                    configured; | 
|  | struct list_head	  list; | 
|  |  | 
|  | /* callback function */ | 
|  | void              (*receive)(struct sk_buff *skb, struct net_device *); | 
|  | }; | 
|  |  | 
|  | struct frad_local | 
|  | { | 
|  | struct net_device_stats stats; | 
|  |  | 
|  | /* devices which this FRAD is slaved to */ | 
|  | struct net_device     *master[CONFIG_DLCI_MAX]; | 
|  | short             dlci[CONFIG_DLCI_MAX]; | 
|  |  | 
|  | struct frad_conf  config; | 
|  | int               configured;	/* has this device been configured */ | 
|  | int               initialized;	/* mem_start, port, irq set ? */ | 
|  |  | 
|  | /* callback functions */ | 
|  | int               (*activate)(struct net_device *, struct net_device *); | 
|  | int               (*deactivate)(struct net_device *, struct net_device *); | 
|  | int               (*assoc)(struct net_device *, struct net_device *); | 
|  | int               (*deassoc)(struct net_device *, struct net_device *); | 
|  | int               (*dlci_conf)(struct net_device *, struct net_device *, int get); | 
|  |  | 
|  | /* fields that are used by the Sangoma SDLA cards */ | 
|  | struct timer_list timer; | 
|  | int               type;		/* adapter type */ | 
|  | int               state;		/* state of the S502/8 control latch */ | 
|  | int               buffer;		/* current buffer for S508 firmware */ | 
|  | }; | 
|  |  | 
|  | #endif /* CONFIG_DLCI || CONFIG_DLCI_MODULE */ | 
|  |  | 
|  | extern void dlci_ioctl_set(int (*hook)(unsigned int, void __user *)); | 
|  |  | 
|  | #endif /* __KERNEL__ */ | 
|  |  | 
|  | #endif |