| /* SPDX-License-Identifier: GPL-2.0-or-later */ | 
 | /* | 
 |  * 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 | 
 |  */ | 
 | #ifndef _FRAD_H_ | 
 | #define _FRAD_H_ | 
 |  | 
 | #include <uapi/linux/if_frad.h> | 
 |  | 
 |  | 
 | #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 | 
 | { | 
 |    /* 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; | 
 |    struct net_device *dev; | 
 |    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 |