Blame view
include/linux/if_pppox.h
6.02 KB
1da177e4c
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
/*************************************************************************** * 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: * 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 __LINUX_IF_PPPOX_H #define __LINUX_IF_PPPOX_H |
00bfddaf7
|
18 |
#include <linux/types.h> |
1da177e4c
|
19 20 21 22 23 24 |
#include <asm/byteorder.h> #ifdef __KERNEL__ #include <linux/if_ether.h> #include <linux/if.h> #include <linux/netdevice.h> |
1da177e4c
|
25 26 |
#include <linux/ppp_channel.h> #endif /* __KERNEL__ */ |
cf14a4d06
|
27 |
#include <linux/if_pppol2tp.h> |
1da177e4c
|
28 29 30 31 32 33 34 35 36 37 38 39 |
/* For user-space programs to pick up these definitions * which they wouldn't get otherwise without defining __KERNEL__ */ #ifndef AF_PPPOX #define AF_PPPOX 24 #define PF_PPPOX AF_PPPOX #endif /* !(AF_PPPOX) */ /************************************************************************ * PPPoE addressing definition */ |
b963dc1df
|
40 |
typedef __be16 sid_t; |
1da177e4c
|
41 42 43 44 45 46 47 48 49 50 |
struct pppoe_addr{ sid_t sid; /* Session identifier */ unsigned char remote[ETH_ALEN]; /* Remote address */ char dev[IFNAMSIZ]; /* Local device to use */ }; /************************************************************************ * Protocols supported by AF_PPPOX */ #define PX_PROTO_OE 0 /* Currently just PPPoE */ |
cf14a4d06
|
51 52 |
#define PX_PROTO_OL2TP 1 /* Now L2TP also */ #define PX_MAX_PROTO 2 |
1da177e4c
|
53 54 55 56 57 58 |
struct sockaddr_pppox { sa_family_t sa_family; /* address family, AF_PPPOX */ unsigned int sa_protocol; /* protocol identifier */ union{ struct pppoe_addr pppoe; }sa_addr; |
bc10502db
|
59 |
} __packed; |
1da177e4c
|
60 |
|
cf14a4d06
|
61 62 63 64 65 66 67 68 69 |
/* The use of the above union isn't viable because the size of this * struct must stay fixed over time -- applications use sizeof(struct * sockaddr_pppox) to fill it. We use a protocol specific sockaddr * type instead. */ struct sockaddr_pppol2tp { sa_family_t sa_family; /* address family, AF_PPPOX */ unsigned int sa_protocol; /* protocol identifier */ struct pppol2tp_addr pppol2tp; |
bc10502db
|
70 |
} __packed; |
1da177e4c
|
71 |
|
e0d4435f9
|
72 73 74 75 76 77 78 |
/* The L2TPv3 protocol changes tunnel and session ids from 16 to 32 * bits. So we need a different sockaddr structure. */ struct sockaddr_pppol2tpv3 { sa_family_t sa_family; /* address family, AF_PPPOX */ unsigned int sa_protocol; /* protocol identifier */ struct pppol2tpv3_addr pppol2tp; |
bc10502db
|
79 |
} __packed; |
e0d4435f9
|
80 |
|
1da177e4c
|
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 |
/********************************************************************* * * ioctl interface for defining forwarding of connections * ********************************************************************/ #define PPPOEIOCSFWD _IOW(0xB1 ,0, size_t) #define PPPOEIOCDFWD _IO(0xB1 ,1) /*#define PPPOEIOCGFWD _IOWR(0xB1,2, size_t)*/ /* Codes to identify message types */ #define PADI_CODE 0x09 #define PADO_CODE 0x07 #define PADR_CODE 0x19 #define PADS_CODE 0x65 #define PADT_CODE 0xa7 struct pppoe_tag { |
b963dc1df
|
98 99 |
__be16 tag_type; __be16 tag_len; |
1da177e4c
|
100 101 102 103 |
char tag_data[0]; } __attribute ((packed)); /* Tag identifiers */ |
f3a7c66b5
|
104 105 106 107 108 109 110 111 112 113 |
#define PTT_EOL __cpu_to_be16(0x0000) #define PTT_SRV_NAME __cpu_to_be16(0x0101) #define PTT_AC_NAME __cpu_to_be16(0x0102) #define PTT_HOST_UNIQ __cpu_to_be16(0x0103) #define PTT_AC_COOKIE __cpu_to_be16(0x0104) #define PTT_VENDOR __cpu_to_be16(0x0105) #define PTT_RELAY_SID __cpu_to_be16(0x0110) #define PTT_SRV_ERR __cpu_to_be16(0x0201) #define PTT_SYS_ERR __cpu_to_be16(0x0202) #define PTT_GEN_ERR __cpu_to_be16(0x0203) |
1da177e4c
|
114 115 116 117 118 119 120 121 122 123 124 125 |
struct pppoe_hdr { #if defined(__LITTLE_ENDIAN_BITFIELD) __u8 ver : 4; __u8 type : 4; #elif defined(__BIG_ENDIAN_BITFIELD) __u8 type : 4; __u8 ver : 4; #else #error "Please fix <asm/byteorder.h>" #endif __u8 code; |
b963dc1df
|
126 127 |
__be16 sid; __be16 length; |
1da177e4c
|
128 |
struct pppoe_tag tag[0]; |
bc10502db
|
129 |
} __packed; |
1da177e4c
|
130 |
|
516299d2f
|
131 132 |
/* Length of entire PPPoE + PPP header */ #define PPPOE_SES_HLEN 8 |
1da177e4c
|
133 |
#ifdef __KERNEL__ |
797659fb4
|
134 135 136 137 |
#include <linux/skbuff.h> static inline struct pppoe_hdr *pppoe_hdr(const struct sk_buff *skb) { |
d56f90a7c
|
138 |
return (struct pppoe_hdr *)skb_network_header(skb); |
797659fb4
|
139 |
} |
1da177e4c
|
140 141 |
struct pppoe_opt { struct net_device *dev; /* device associated with socket*/ |
6f30e1867
|
142 |
int ifindex; /* ifindex of device associated with socket */ |
1da177e4c
|
143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 |
struct pppoe_addr pa; /* what this socket is bound to*/ struct sockaddr_pppox relay; /* what socket data will be relayed to (PPPoE relaying) */ }; #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; } proto; |
b963dc1df
|
158 |
__be16 num; |
1da177e4c
|
159 160 |
}; #define pppoe_dev proto.pppoe.dev |
6f30e1867
|
161 |
#define pppoe_ifindex proto.pppoe.ifindex |
1da177e4c
|
162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 |
#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 { |
1b8d7ae42
|
178 |
int (*create)(struct net *net, struct socket *sock); |
1da177e4c
|
179 180 181 182 183 184 185 186 |
int (*ioctl)(struct socket *sock, unsigned int cmd, unsigned long arg); struct module *owner; }; extern int register_pppox_proto(int proto_num, struct pppox_proto *pp); extern void unregister_pppox_proto(int proto_num); extern void pppox_unbind_sock(struct sock *sk);/* delete ppp-channel binding */ |
17ba15fb6
|
187 |
extern int pppox_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg); |
1da177e4c
|
188 189 190 191 192 193 194 195 196 197 198 199 200 201 |
/* 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_ZOMBIE = 8, /* dead, but still bound to ppp device */ PPPOX_DEAD = 16 /* dead, useless, please clean me up!*/ }; #endif /* __KERNEL__ */ #endif /* !(__LINUX_IF_PPPOX_H) */ |