| /* SPDX-License-Identifier: GPL-2.0-or-later */ | 
 | /*************************************************************************** | 
 |  * Linux PPP over X - Generic PPP transport layer sockets | 
 |  * Linux PPP over Ethernet (PPPoE) Socket Implementation (RFC 2516)  | 
 |  * | 
 |  * This file supplies definitions required by the PPP over Ethernet driver | 
 |  * (pppox.c).  All version information wrt this file is located in pppox.c | 
 |  * | 
 |  * License: | 
 |  */ | 
 | #ifndef __LINUX_IF_PPPOX_H | 
 | #define __LINUX_IF_PPPOX_H | 
 |  | 
 | #include <linux/if.h> | 
 | #include <linux/netdevice.h> | 
 | #include <linux/ppp_channel.h> | 
 | #include <linux/skbuff.h> | 
 | #include <linux/workqueue.h> | 
 | #include <uapi/linux/if_pppox.h> | 
 |  | 
 | static inline struct pppoe_hdr *pppoe_hdr(const struct sk_buff *skb) | 
 | { | 
 | 	return (struct pppoe_hdr *)skb_network_header(skb); | 
 | } | 
 |  | 
 | struct pppoe_opt { | 
 | 	struct net_device      *dev;	  /* device associated with socket*/ | 
 | 	int			ifindex;  /* ifindex of device associated with socket */ | 
 | 	struct pppoe_addr	pa;	  /* what this socket is bound to*/ | 
 | 	struct sockaddr_pppox	relay;	  /* what socket data will be | 
 | 					     relayed to (PPPoE relaying) */ | 
 | 	struct work_struct      padt_work;/* Work item for handling PADT */ | 
 | }; | 
 |  | 
 | struct pptp_opt { | 
 | 	struct pptp_addr src_addr; | 
 | 	struct pptp_addr dst_addr; | 
 | 	u32 ack_sent, ack_recv; | 
 | 	u32 seq_sent, seq_recv; | 
 | 	int ppp_flags; | 
 | }; | 
 | #include <net/sock.h> | 
 |  | 
 | struct pppox_sock { | 
 | 	/* struct sock must be the first member of pppox_sock */ | 
 | 	struct sock sk; | 
 | 	struct ppp_channel chan; | 
 | 	struct pppox_sock	*next;	  /* for hash table */ | 
 | 	union { | 
 | 		struct pppoe_opt pppoe; | 
 | 		struct pptp_opt  pptp; | 
 | 	} proto; | 
 | 	__be16			num; | 
 | }; | 
 | #define pppoe_dev	proto.pppoe.dev | 
 | #define pppoe_ifindex	proto.pppoe.ifindex | 
 | #define pppoe_pa	proto.pppoe.pa | 
 | #define pppoe_relay	proto.pppoe.relay | 
 |  | 
 | static inline struct pppox_sock *pppox_sk(struct sock *sk) | 
 | { | 
 | 	return (struct pppox_sock *)sk; | 
 | } | 
 |  | 
 | static inline struct sock *sk_pppox(struct pppox_sock *po) | 
 | { | 
 | 	return (struct sock *)po; | 
 | } | 
 |  | 
 | struct module; | 
 |  | 
 | struct pppox_proto { | 
 | 	int		(*create)(struct net *net, struct socket *sock, int kern); | 
 | 	int		(*ioctl)(struct socket *sock, unsigned int cmd, | 
 | 				 unsigned long arg); | 
 | 	struct module	*owner; | 
 | }; | 
 |  | 
 | extern int register_pppox_proto(int proto_num, const struct pppox_proto *pp); | 
 | extern void unregister_pppox_proto(int proto_num); | 
 | extern void pppox_unbind_sock(struct sock *sk);/* delete ppp-channel binding */ | 
 | extern int pppox_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg); | 
 | extern int pppox_compat_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg); | 
 |  | 
 | #define PPPOEIOCSFWD32    _IOW(0xB1 ,0, compat_size_t) | 
 |  | 
 | /* PPPoX socket states */ | 
 | enum { | 
 |     PPPOX_NONE		= 0,  /* initial state */ | 
 |     PPPOX_CONNECTED	= 1,  /* connection established ==TCP_ESTABLISHED */ | 
 |     PPPOX_BOUND		= 2,  /* bound to ppp device */ | 
 |     PPPOX_RELAY		= 4,  /* forwarding is enabled */ | 
 |     PPPOX_DEAD		= 16  /* dead, useless, please clean me up!*/ | 
 | }; | 
 |  | 
 | #endif /* !(__LINUX_IF_PPPOX_H) */ |