| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * 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_
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-13 10:46:48 +01:00
										 |  |  | #include <uapi/linux/if_frad.h>
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-26 12:30:12 -08:00
										 |  |  | #if defined(CONFIG_DLCI) || defined(CONFIG_DLCI_MODULE)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /* these are the fields of an RFC 1490 header */ | 
					
						
							|  |  |  | struct frhdr | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2006-01-08 01:05:07 -08:00
										 |  |  |    unsigned char  control; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |    /* for IP packets, this can be the NLPID */ | 
					
						
							| 
									
										
										
										
											2006-01-08 01:05:07 -08:00
										 |  |  |    unsigned char  pad; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-08 01:05:07 -08:00
										 |  |  |    unsigned char  NLPID; | 
					
						
							|  |  |  |    unsigned char  OUI[3]; | 
					
						
							| 
									
										
										
										
											2007-12-22 17:52:52 +00:00
										 |  |  |    __be16 PID; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define IP_NLPID pad 
 | 
					
						
							| 
									
										
										
										
											2010-06-03 03:21:52 -07:00
										 |  |  | } __packed; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* 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 */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-16 02:18:02 -03:00
										 |  |  | extern void dlci_ioctl_set(int (*hook)(unsigned int, void __user *)); | 
					
						
							| 
									
										
										
										
											2009-01-26 12:30:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #endif
 |