12#ifndef ZEPHYR_INCLUDE_NET_PPP_H_
13#define ZEPHYR_INCLUDE_NET_PPP_H_
34#define PPP_MRU CONFIG_NET_PPP_MTU_MRU
37#define PPP_MTU PPP_MRU
40#define PPP_MAX_TERMINATE_REASON_LEN 32
43#define PPP_INTERFACE_IDENTIFIER_LEN 8
62#if defined(CONFIG_NET_STATISTICS_PPP)
74BUILD_ASSERT(offsetof(
struct ppp_api, iface_api) == 0);
133enum ppp_packet_type {
134 PPP_CONFIGURE_REQ = 1,
135 PPP_CONFIGURE_ACK = 2,
136 PPP_CONFIGURE_NACK = 3,
137 PPP_CONFIGURE_REJ = 4,
138 PPP_TERMINATE_REQ = 5,
139 PPP_TERMINATE_ACK = 6,
141 PPP_PROTOCOL_REJ = 8,
229 size_t user_data_len);
231struct ppp_my_option_data;
232struct ppp_my_option_info;
272 void (*config_info_reset)(
struct ppp_fsm *fsm);
296 enum ppp_packet_type code,
304 const struct ppp_my_option_info *
info;
307 struct ppp_my_option_data *
data;
349#define PPP_MY_OPTION_ACKED BIT(0)
350#define PPP_MY_OPTION_REJECTED BIT(1)
352struct ppp_my_option_data {
356#define IPCP_NUM_MY_OPTIONS 3
357#define IPV6CP_NUM_MY_OPTIONS 1
380#if defined(CONFIG_NET_L2_PPP_OPTION_MRU)
381#define LCP_NUM_MY_OPTIONS 1
425#if defined(CONFIG_NET_L2_PPP_OPTION_MRU)
426 struct ppp_my_option_data my_options_data[LCP_NUM_MY_OPTIONS];
430#if defined(CONFIG_NET_IPV4)
443 struct ppp_my_option_data my_options_data[IPCP_NUM_MY_OPTIONS];
447#if defined(CONFIG_NET_IPV6)
460 struct ppp_my_option_data my_options_data[IPV6CP_NUM_MY_OPTIONS];
464#if defined(CONFIG_NET_L2_PPP_PAP)
472#if defined(CONFIG_NET_SHELL)
485 size_t user_data_len;
489 struct k_sem wait_echo_reply;
562#define PPP_L2_CTX_TYPE struct ppp_context
564#define _NET_PPP_LAYER NET_MGMT_LAYER_L2
565#define _NET_PPP_CODE 0x209
566#define _NET_PPP_BASE (NET_MGMT_IFACE_BIT | \
567 NET_MGMT_LAYER(_NET_PPP_LAYER) | \
568 NET_MGMT_LAYER_CODE(_NET_PPP_CODE))
569#define _NET_PPP_EVENT (_NET_PPP_BASE | NET_MGMT_EVENT_BIT)
571enum net_event_ppp_cmd {
572 NET_EVENT_PPP_CMD_CARRIER_ON = 1,
573 NET_EVENT_PPP_CMD_CARRIER_OFF,
574 NET_EVENT_PPP_CMD_PHASE_RUNNING,
575 NET_EVENT_PPP_CMD_PHASE_DEAD,
583#define NET_EVENT_PPP_CARRIER_ON \
584 (_NET_PPP_EVENT | NET_EVENT_PPP_CMD_CARRIER_ON)
587#define NET_EVENT_PPP_CARRIER_OFF \
588 (_NET_PPP_EVENT | NET_EVENT_PPP_CMD_CARRIER_OFF)
591#define NET_EVENT_PPP_PHASE_RUNNING \
592 (_NET_PPP_EVENT | NET_EVENT_PPP_CMD_PHASE_RUNNING)
595#define NET_EVENT_PPP_PHASE_DEAD \
596 (_NET_PPP_EVENT | NET_EVENT_PPP_CMD_PHASE_DEAD)
603#if defined(CONFIG_NET_L2_PPP_MGMT)
617#if defined(CONFIG_NET_L2_PPP_MGMT)
631#if defined(CONFIG_NET_L2_PPP_MGMT)
645#if defined(CONFIG_NET_L2_PPP_MGMT)
664#if defined(CONFIG_NET_L2_PPP)
684#if defined(CONFIG_NET_L2_PPP) && defined(CONFIG_NET_SHELL)
long atomic_t
Definition atomic_types.h:15
net_verdict
Net Verdict.
Definition net_core.h:102
net_l2_flags
L2 flags.
Definition net_l2.h:36
ipcp_option_type
IPCP option types from RFC 1332.
Definition ppp.h:181
static void ppp_mgmt_raise_carrier_on_event(struct net_if *iface)
Raise CARRIER_ON event when PPP is connected.
Definition ppp.h:606
void(* net_ppp_lcp_echo_reply_cb_t)(void *user_data, size_t user_data_len)
A callback function that can be called if a Echo-Reply needs to be received.
Definition ppp.h:228
ppp_phase
PPP phases.
Definition ppp.h:97
#define PPP_MAX_TERMINATE_REASON_LEN
Max length of terminate description string.
Definition ppp.h:40
static struct ppp_context * net_ppp_context_get(int idx)
Get PPP context information.
Definition ppp.h:687
static void ppp_mgmt_raise_phase_running_event(struct net_if *iface)
Raise PHASE_RUNNING event when PPP reaching RUNNING phase.
Definition ppp.h:634
ppp_protocol_type
PPP protocol types.
Definition ppp.h:81
static int net_ppp_ping(int idx, int32_t timeout)
Send PPP Echo-Request to peer.
Definition ppp.h:667
void net_ppp_init(struct net_if *iface)
Initialize PPP L2 stack for a given interface.
#define PPP_INTERFACE_IDENTIFIER_LEN
Length of network interface identifier.
Definition ppp.h:43
lcp_option_type
LCP option types from RFC 1661 ch.
Definition ppp.h:152
static void ppp_mgmt_raise_phase_dead_event(struct net_if *iface)
Raise PHASE_DEAD event when PPP reaching DEAD phase.
Definition ppp.h:648
static void ppp_mgmt_raise_carrier_off_event(struct net_if *iface)
Raise CARRIER_OFF event when PPP is disconnected.
Definition ppp.h:620
ipv6cp_option_type
IPV6CP option types from RFC 5072.
Definition ppp.h:212
@ IPCP_OPTION_IP_ADDRESS
IP Address.
Definition ppp.h:192
@ IPCP_OPTION_DNS2
Secondary DNS Server Address.
Definition ppp.h:203
@ IPCP_OPTION_IP_COMP_PROTO
IP Compression Protocol.
Definition ppp.h:189
@ IPCP_OPTION_NBNS2
Secondary NBNS Server Address.
Definition ppp.h:206
@ IPCP_OPTION_RESERVED
Reserved IPCP option value (do not use)
Definition ppp.h:183
@ IPCP_OPTION_NBNS1
Primary NBNS Server Address.
Definition ppp.h:200
@ IPCP_OPTION_IP_ADDRESSES
IP Addresses.
Definition ppp.h:186
@ IPCP_OPTION_DNS1
Primary DNS Server Address.
Definition ppp.h:197
@ PPP_AUTH
Link authentication with peer.
Definition ppp.h:103
@ PPP_RUNNING
Network running.
Definition ppp.h:107
@ PPP_NETWORK
Network connection establishment.
Definition ppp.h:105
@ PPP_ESTABLISH
Link is being established.
Definition ppp.h:101
@ PPP_DEAD
Physical-layer not ready.
Definition ppp.h:99
@ PPP_TERMINATE
Link termination.
Definition ppp.h:109
@ PPP_IPV6
RFC 5072.
Definition ppp.h:83
@ PPP_IP
RFC 1332.
Definition ppp.h:82
@ PPP_CHAP
RFC 1334.
Definition ppp.h:90
@ PPP_LCP
RFC 1661.
Definition ppp.h:88
@ PPP_IPCP
RFC 1332.
Definition ppp.h:84
@ PPP_ECP
RFC 1968.
Definition ppp.h:85
@ PPP_CCP
RFC 1962.
Definition ppp.h:87
@ PPP_EAP
RFC 2284.
Definition ppp.h:91
@ PPP_IPV6CP
RFC 5072.
Definition ppp.h:86
@ PPP_PAP
RFC 1334.
Definition ppp.h:89
@ LCP_OPTION_ASYNC_CTRL_CHAR_MAP
Async-Control-Character-Map.
Definition ppp.h:160
@ LCP_OPTION_ADDR_CTRL_COMPRESS
Address-and-Control-Field-Compression.
Definition ppp.h:175
@ LCP_OPTION_QUALITY_PROTO
Quality-Protocol.
Definition ppp.h:166
@ LCP_OPTION_MAGIC_NUMBER
Magic-Number.
Definition ppp.h:169
@ LCP_OPTION_RESERVED
Reserved option value (do not use)
Definition ppp.h:154
@ LCP_OPTION_PROTO_COMPRESS
Protocol-Field-Compression.
Definition ppp.h:172
@ LCP_OPTION_MRU
Maximum-Receive-Unit.
Definition ppp.h:157
@ LCP_OPTION_AUTH_PROTO
Authentication-Protocol.
Definition ppp.h:163
@ IPV6CP_OPTION_INTERFACE_IDENTIFIER
Interface identifier.
Definition ppp.h:217
@ IPV6CP_OPTION_RESERVED
Reserved IPV6CP option value (do not use)
Definition ppp.h:214
#define ENOTSUP
Unsupported value.
Definition errno.h:114
Public API for network interface.
Network Management API public header.
Network packet buffer descriptor API.
flags
Definition parser.h:96
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__INT32_TYPE__ int32_t
Definition stdint.h:74
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Runtime device structure (in ROM) per driver instance.
Definition device.h:412
IPv4 address struct.
Definition net_ip.h:154
IPv4 control protocol options.
Definition ppp.h:385
struct in_addr address
IPv4 address.
Definition ppp.h:387
struct in_addr dns2_address
Secondary DNS server address.
Definition ppp.h:393
struct in_addr dns1_address
Primary DNS server address.
Definition ppp.h:390
IPv6 control protocol options.
Definition ppp.h:397
uint8_t iid[8]
Interface identifier.
Definition ppp.h:399
A structure used to submit work after a delay.
Definition kernel.h:3985
Link control protocol options.
Definition ppp.h:366
uint16_t mru
Maximum Receive Unit value.
Definition ppp.h:374
uint32_t async_map
Async char map.
Definition ppp.h:371
uint16_t auth_proto
Which authentication protocol was negotiated (0 means none)
Definition ppp.h:377
uint32_t magic
Magic number.
Definition ppp.h:368
Network Interface structure.
Definition net_if.h:690
Network Management event callback structure Used to register a callback into the network management e...
Definition net_mgmt.h:145
Network packet.
Definition net_pkt.h:91
All PPP specific statistics.
Definition net_stats.h:596
PPP L2 API.
Definition ppp.h:46
int(* stop)(const struct device *dev)
Stop the device.
Definition ppp.h:57
int(* send)(const struct device *dev, struct net_pkt *pkt)
Send a network packet.
Definition ppp.h:60
int(* start)(const struct device *dev)
Start the device.
Definition ppp.h:54
struct net_if_api iface_api
The net_if_api must be placed in first position in this struct so that we are compatible with network...
Definition ppp.h:51
PPP L2 context specific to certain network interface.
Definition ppp.h:403
struct net_mgmt_event_callback mgmt_evt_cb
Network management callback structure.
Definition ppp.h:503
struct k_sem wait_ppp_link_terminated
Signal when PPP link is terminated.
Definition ppp.h:509
enum net_l2_flags ppp_l2_flags
This tells what features the PPP supports.
Definition ppp.h:515
int network_protos_open
This tells how many network protocols are open.
Definition ppp.h:518
struct net_if * iface
Network interface related to this PPP connection.
Definition ppp.h:500
uint16_t is_ready_to_serve
Is PPP ready to receive packets.
Definition ppp.h:524
uint32_t magic
Magic-Number value.
Definition ppp.h:424
uint16_t is_pap_up
PAP status (up / down)
Definition ppp.h:545
struct k_work_delayable startup
PPP startup worker.
Definition ppp.h:410
enum ppp_phase phase
Current phase of PPP link.
Definition ppp.h:506
atomic_t flags
Flags representing PPP state, which are accessed from multiple threads.
Definition ppp.h:407
uint16_t is_ipv6cp_up
IPV6CP status (up / down)
Definition ppp.h:539
uint16_t is_ipcp_open
IPCP open status (open / closed)
Definition ppp.h:536
uint16_t is_enabled
Is PPP L2 enabled or not.
Definition ppp.h:527
uint16_t is_pap_open
PAP open status (open / closed)
Definition ppp.h:548
uint16_t is_ipcp_up
IPCP status (up / down)
Definition ppp.h:533
int network_protos_up
This tells how many network protocols are up.
Definition ppp.h:521
uint16_t is_ipv6cp_open
IPV6CP open status (open / closed)
Definition ppp.h:542
struct ppp_context::@407 lcp
LCP options.
uint16_t is_enable_done
PPP enable pending.
Definition ppp.h:530
struct k_sem wait_ppp_link_down
Signal when PPP link is down.
Definition ppp.h:512
Generic PPP Finite State Machine.
Definition ppp.h:237
char terminate_reason[32]
Reason for closing protocol.
Definition ppp.h:326
uint32_t nack_loops
Number of NACK loops since last ACK.
Definition ppp.h:320
const struct ppp_my_option_info * info
Options information.
Definition ppp.h:304
uint16_t protocol
PPP protocol number for this FSM.
Definition ppp.h:329
uint32_t retransmits
Number of re-transmissions left.
Definition ppp.h:317
uint8_t ack_received
Have received valid Ack, Nack or Reject to a Request.
Definition ppp.h:344
uint32_t flags
Option bits.
Definition ppp.h:314
uint32_t recv_nack_loops
Number of NACKs received.
Definition ppp.h:323
struct ppp_my_option_data * data
Options negotiation data.
Definition ppp.h:307
size_t count
Number of negotiated options.
Definition ppp.h:310
uint8_t id
Current id.
Definition ppp.h:338
uint8_t req_id
Current request id.
Definition ppp.h:341
const char * name
Protocol/layer name of this FSM (for debugging)
Definition ppp.h:335
struct ppp_fsm::@405 cb
FSM callbacks.
enum ppp_state state
Current state of PPP link.
Definition ppp.h:332
struct ppp_fsm::@406 my_options
My options.
struct k_work_delayable timer
Timeout timer.
Definition ppp.h:239
Shell instance internals.
Definition shell.h:890