/dev/posts/

Protocol stack diagrams

Layers all the way down

Published:

Updated:

A collection of ASCII-art protocol stack diagrams.

They can be used as a base for doing quick diagrams. Feel free to copy/reuse/adapt them for your own purpose. These diagrams are released as CC0 (“No Rights Reserved”).

Table of content

Concepts

Layers, PDUs and SDUs:

                N+1 PDU
[N+1 Layer]<----------------->[N+1 Layer]
     ↑                             ↑
     |                             |  N+1 SDU
     ↓                             ↓
     o           N PDU             o  N SAP
[N Layer  ]<----------------->[N Layer  ]
     ↑                             ↑
     |                             |  N SDU
     ↓                             ↓
     o           N-1 PDU           o  N-1 SAP
[N-1 Layer]<----------------->[N-1 Layer]

Switches, bridges/hubs, routers, proxy:

[app.    ]<------------------------------------------------>[app.]<-->[app.]
[TCP     ]<------------------------------------------------>[TCP ]<-->[TCP ]
[IP      ]<------------------------------>[IP          ]<-->[IP  ]<-->[IP  ]
[Eth. MAC]<---------------->[Eth. MAC]<---[Eth. MAC|...]<-->[... ]<-->[... ]
[Eth. PHY]<-->[Eth. PHY]<-->[Eth. PHY]<-->[Eth. PHY|...]<-->[... ]<-->[... ]
                 Hub       Switch/bridge   Router           Proxy

OSI

L7 [Application ]<-------------------------------->[Application ]
L6 [Presentation]<-------------------------------->[Presentation]
L5 [Session     ]<-------------------------------->[Session     ]
L4 [Transport   ]<-------------------------------->[Transport   ]
L3 [Network     ]<-->[Network  ]<-->[Network  ]<-->[Network     ]
L2 [Data link   ]<-->[Data link]<-->[Data link]<-->[Data link   ]
L1 [Physical    ]<-->[Physical ]<-->[Physical ]<-->[Physical    ]

IP

IPv4

          [(DHCP)|DNS|app|DNS|app]
[ICMP|IGMP|UDP           |TCP    ]
[IPv4                            |ARP]
Protocol SAP Description
ICMP (Inter Control Message Protocol) IP proto. 1
ARP (Address Resolution Protocol) EtherType 0x0806 Used for non-point-to-point networks.
DHCP (Dynamic Host Configuration Protocol) UDP 67 (server)
UDP 68 (client)
IGMP (Internet Group Management Protocol) IP proto. 2 Support for multicast

IP model:

[app.]<---------------------------------->[app.]  (end to end)
[TCP ]<---------------------------------->[TCP ]  (end to end)
[IP  ]<--->[IP ]<--->[IP ]<--->[IP  ]<--->[IP  ]
[... ]<--->[...]<--->[...]<--->[... ]<--->[... ]  (local network layers)
           Router    Router    Router

IPv6

               [(DHCPv6)|DNS|app|DNS|app]
[ICMPv6+NDP+MLD|UDP             |TCP    ]
[IPv6                                   ]
Protocol SAP Description
ICMPv6 IP next header 0x58
NDP IP next header 0x58 Part of ICMPv6. Replaces ARP in IPv6.
DHCPv6 UDP 546 (client)
UDP 547 (server)
Usually NDP is used instead for address allocation, routes, DNS configuration, etc.
[MLD](Multicast Listener Discovery) IP next header 0x58 Part of ICMPv6. Replaces IGMP in IPv6.

IP Transport protocols

                                                 [app.]
                                          [app.] [SCTP] [app.]
[app.] [app.] [app.    ] [app.] [app.]    [SCTP] [DTLS] [QUIC|TLS]
[TCP ] [UDP ] [UDP-lite] [DCCP] [SCTP]    [UDP ] [UDP ] [UDP     ]
[IP  ] [IP  ] [IP      ] [IP  ] [IP  ]    [IP  ] [IP  ] [IP      ]
TCP    UDP    UDP-lite   DCCP   SCTP      SCTP   SCTP   QUIC
                                          /UDP   /DTLS   
Protocol Protocol number Description
TCP 6 Connection oriented, stream-based, checksums, connection control.
UDP 17 Unreliable datagrams. Checksums (can be disabled in IPv4).
UDP-lite 136 Unreliable datagrams. Allows for partial checksums.
DCCP 33 Connection oriented, unreliable datagrams, with congestion control.
SCTP 132 Message-based (fragmentation, reliable, ordered), multiple-streams multiplexing over a single connection. Initially designed for PSTN signaling over IP.
SCTP over UDP - Useful for NAT traversal and userspace implementations of SCTP.
SCTP over DTLS - Used by WebRTC for transporting data channels.
QUIC - Protected communications (relies on TLS for the hanshake). Multiplexing of multiple streams per QUIC connection. Used by HTTP/3.

Applications layers

DNS

                                                      [DNS       ]
                 [DNS    ]        [DNS       ]        [Obliv. DNS]
       [DNS    ] [framing] [DNS ] [HTTP      ] [DNS ] [HTTP      ]
[DNS]  [framing] [TLS    ] [DTLS] [TLS / QUIC] [QUIC] [TLS / QUIC]
[UDP]  [TCP    ] [TCP    ] [UDP ] [TCP / UDP ] [UDP ] [TCP / UDP ]
[IP ]  [IP     ] [IP     ] [IP  ] [IP        ] [IP  ] [IP        ]
“Do53” “Do53”    “DoT”            “DoH”        “DoQ”  “ODoH”
DNS    DNS       DNS       DNS    DNS          DNS    Oblivious DNS
over   over      over      over   over         over   over
UDP    TCP       TLS       DTLS   HTTPS        QUIC   HTTPS
Protocol Port ALPN Description
DNS over UDP (Do53) UDP 53 - General DNS traffic.
DNS over TCP (Do53) TCP 53 - Usually used when messages are too long for UDP.
DNS framing - - When used on top of TCP or TLS, each DNS message is prefixed with a length field (2 bytes).
DNS over TLS (DoT) TCP 853 "dot" DNS privacy.
DNS over DTLS (UDP 853) - DNS privacy. Not used in practice, deprecated in favor of DoQ.
DNS over HTTPS (DoH) TCP 443 "http/1.1", "h2", "h3", etc. DNS privacy. One HTTP request per request/response pair.
DNS over QUIC (DoQ) UDP 853 "doq" DNS privacy. One QUIC stream per request/response pair.
Oblivious DNS over HTTPS (ODoH) TCP/UDP 443 "http/1.1", "h2", "h3", etc. More DNS privacy.

Oblivious DNS over HTTPS:

[DNS       ]<--------------------->o[DNS           ]<---->o[DNS]
[Obliv. DNS]<=====================>o[Obliv. DNS|-  ]
[HTTP      ]<--->o[HTTP      ]<--->o[HTTP      |-  ]
[TLS / QUIC]<===>o[TLS / QUIC]<===>o[TLS / QUIC|-  ]
[TCP / UDP ]<--->o[TCP / UDP ]<--->o[TCP / UDP |...]<----->[...]
[IP        ]<---->[IP        ]<---->[IP            ]<----->[IP ]
Oblivious         Oblivious          Oblivious
Client            Relay              Target

HTTP

                          [HTTP/1.x] [HTTP/2] [HTTP/3|TLS]
[HTTP/1.x] [HTTP/2]       [TLS     ] [TLS   ] [QUIC      ]
[TCP     ] [TCP   ]       [TCP     ] [TCP   ] [UDP       ]
[IP      ] [IP    ]       [IP      ] [IP    ] [IP        ]
HTTP/1.x   HTTP/2         HTTP/1.x   HTTP/2   HTTP/3
           w/o TLS        over TLS   over TLS (over QUIC)
           "h2c"                     "h2"     "h3"
(HTTP)     (HTTP)         (HTTPS)    (HTTPS)  (HTTPS)
Protocol Port TLS ALPN HTTP Upgrade Description
HTTP/1.x without TLS TCP 80 - - Text protocol.
HTTP/1.x over TLS (HTTPS) TCP 443 "http/1.1", "http/1.0"
HTTP/2 without TLS TCP 80 - "h2c" HTTP/2 without TLS is not widely supported and is deprecated.
HTTP/2 over TLS (HTTPS) TCP 443 "h2" - Binary protocol. Prevents head of line blocking (HOL)at the HTTP layer byt multiplexing multiple requests/responses over the same connection but does HOL blocking still present at the TCP layer.
HTTP/3 over QUIC (HTTPS) UDP 443 "h3" - Binary protocol. Prevents HOL blocking between streams of the same connection (which was happenning at the TCP layer with HTTP/2) by replacing TCP by UDP. Encryption/integrity provided by QUIC. TLS used for the handshake (ciphersuite negotiation, authentication, key exchange, etc.)

WebSocket

[WebSocket]  [WebSocket]  [WebSocket]
[HTTP/1.x ]  [HTTP/2   ]  [HTTP/3   ]
[(TLS)    ]  [(TLS)    ]  [QUIC     ]
[TCP      ]  [TCP      ]  [UDP      ]
[IP       ]  [IP       ]  [IP       ]
WebSocket    Websocket    WebSocket
(HTTP/1.x)   (HTTP/2)     (HTTP/3)

Notes:

References:

HTTP Datagrams

[datagram ]  [datagram]  [    datagram     ]
[Capsule  ]  [Capsule ]  [Capsule |-       ]
[HTTP/1.x ]  [HTTP/2  ]  [HTTP/3  |H3 dgram]
[(TLS)    ]  [(TLS)   ]  [QUIC       +dgram]
[TCP      ]  [TCP     ]  [UDP              ]
[IP       ]  [IP      ]  [IP               ]
HTTP         HTTP        HTTP Datagrams     
Datagrams    Datagrams                      
(HTTP/1.X)   (HTTP/2)    (HTTP/3)

HTTP datagrams are unreliable datagrams, associated with a HTTP upgrade, transported over an HTTP connection. They can be sent after an upgrade to the Capsule protocol,

HTTP datagrams are currently used for,

HTTP CONNECT proxy

Without HTTP/3 datagrams:

               [application]  [IP      ]          [application]       [Eth. MAC   ]   
               [UDP prox.  ]  [IP prox.|config.]  [UDP-l prox.]       [Eth. prox. ]   
[application]  [HTTP Datag.]  [Capsule         ]  [HTTP Datag.]       [HTTP Datag.]   
[HTTP       ]  [HTTP       ]  [HTTP            ]  [HTTP       ]       [HTTP       ]   
[(TLS)/ QUIC]  [(TLS)/ QUIC]  [(TLS) / QUIC    ]  [(TLS)/ QUIC]       [(TLS)/ QUIC]   
[TCP  / UDP ]  [TCP  / UDP ]  [TCP   / UDP     ]  [TCP  / UDP ]       [TCP  / UDP ]   
[IP.        ]  [IP         ]  [IP              ]  [IP         ]       [IP         ]   
TCP in HTTP    UDP in HTTP    IP in HTTP          UDP-listen in HTTP  Ethernet in HTTP

With HTTP/3 datagrams:

                                                                                           
       [app.     ]  [config.|IP      ]         [application     ]         [Eth. MAC   ]
       [UDP prox.]  [Capsule|IP prox.]         [UDP-listen prox.]         [Eth. proxy.]
[HTTP/3|H3 dgram ]  [HTTP/3 |H3 dgram]  [HTTP/3|H3. dgram       ]  [HTTP/3|H dgram    ]
[QUIC +dgram     ]  [QUIC +dgram     ]  [QUIC +dgram            ]  [QUIC +dgram       ]
[UDP             ]  [UDP             ]  [UDP                    ]  [UDP               ]
[IP              ]  [IP              ]  [IP                     ]  [IP                ]
UDP in HTTP/3       IP in HTTP/3        UDP-listen in HTTP/3       Ethernet in HTTP/3
datagrams           datagrams           datagrams                  datagrams
Protocol Upgrade token Default URI template
Proxy TCP in HTTP (classic) (/1.x, /2, /3) - -
Proxy TCP in HTTP (template-based) "connect-tcp" /.well-known/masque/tcp/{target_host}/{tcp_port}/
Proxy UDP in HTTP "connect-udp" /.well-known/masque/udp/{target_host}/{target_port}/
Proxy UDP listen in HTTP "connect-udp-listen" /.well-known/masque/udp/{target_host}/{target_port}/
Proxy IP in HTTP "connect-ip" /.well-known/masque/ip/{target}/{ipproto}/
Proxy Ethernet in HTTP "connect-ethernet" (/.well-known/masque/ethernet/)

WebTransport

[streams|datagrams]    [streams|    datagrams        ]
[-      |Capsule  ]    [-      |Capsule|-            ]
[HTTP/2           ]    [HTTP/3             |H3 dgram.]
[TLS              ]    [QUIC                 (+dgram)]
[TCP              ]    [UDP                          ]
[IP               ]    [IP                           ]
WebTransport (HTTP/2)  WebTransport (HTP/3)
HTTP/2

Features:

Notes:

References:

File Transfer

[FTP  ] [SFTP] [HTTP+WebDAV ]       [SMB ]
[(TLS)] [SSH ] [(TLS) / QUIC] [SMB] [QUIC] [NFS]
[TCP  ] [TCP ] [TCP   / UDP ] [TCP] [UDP ] [TCP]
[IP   ] [IP  ] [IP          ] [IP ] [IP  ] [IP ]
FTP     SFTP   WebDAV         SMB   SMB    NFSv4
                                    /QUIC
Protocol Port Description
FTP (File Transfer Protocol) TCP/21 (control)
TCP/20 (data)
FTP over TLS TCP/900 (control)
TCP/989 (data)
WebDAV TCP/80 (HTTP) Extension of HTTP for remote resource (file) operation.
WebDAV Secure TCP/443
UDP/443
WebDAV with HTTPS.
SFTP (SSH File Transfer Protocol) TCP/22 (SSH) File transfer over SSH. Not related to FTP! This is not FTP over TLS!
NFS v4 (Network File System) TCP/2049
SMB over IP (modern) TCP/445 Windows file sharing.
SMB over NetBIOS over TCP (SMB/NBT) TCP/139 Windows file sharing over legacy Windows network protocols.
SMB over QUIC UDP/443

Notes:

LDAP

[LDAP       ]
[(SASL sec.)]
[(TLS)      ]
[TCP        ]
[IP         ]
LDAP

UPnP

              [Device/service desc.]  [SOAP/1.1]  [UPnP event] [UPnP event]
              [XML                 ]  [XML     ]  [XML       ] [XML       ]
[HTTP+SSDP ]  [HTTP                ]  [HTTP    ]  [HTTP+GENA ] [HTTP+GENA ]
[UDP       ]  [TCP                 ]  [TCP     ]  [TCP       ] [UDP       ]
[IP (mcast)]  [IP                  ]  [IP      ]  [IP        ] [IP (mcast)]
Service       Service                 Control     Eventing     Eventing
Discovery     Description             (RPC)       (unicast)    (multicast)

CoAP

                   [CoAP        ]
                   [WebSocket   ]
[CoAP  ]  [CoAP ]  [HTTP        ]
[(DTLS)]  [(TLS)]  [(TLS / DTLS)]
[UDP   ]  [TCP  ]  [TCP  / UDP  ]
[IP    ]  [IP   ]  [IP          ]
CoAP      CoAP/TCP CoAP/WS(S)
Protocol URI scheme Port ALPN WebSocket protocol
CoAP over UDP coap: UDP 5683 - -
CoAP over DTLS coaps: UDP 5684 coap -
CoAP over TCP coap+tcp: TCP 5683 - -
CoAP over TLS coaps+tcp: TCP 5684 coap .
CoAP over WebSocket coap+ws: (80, HTTPS) - coap
coaps+ws: (443, HTTPS) (http/1.x, …) coap

Notes:

Multimedia

SIP, RTP, RTSP

Signaling:

                                         [SDP      ]
                                         [(S/MIME) ]
                              [SDP     ] [SIP      ]
[SDP  ]   [SDP             ]  [(S/MIME)] [WebSocket]
[RTSP ]   [(S/MIME)        ]  [SIP     ] [HTTP     ]
[(TLS)]   [SIP             ]  [TLS     ] [(TLS    )]
[TCP  ]   [UDP / TCP / SCTP]  [TCP     ] [TCP      ]
[IP   ]   [IP              ]  [IP      ] [IP       ]
RTSP      SIP                 SIP-TLS    SIP/WebSocket

RTP (media transport):

[A/V]      [A/V]             [A/V ]            [A/V ]      
[RTP|RTCP] [SRTP|SRTCP] [DTLS|SRTP|SRTCP] [ZRTP|SRTP|SRTCP]
[UDP     ] [UDP       ] [UDP            ] [UDP            ]
[IP      ] [IP        ] [IP             ] [IP             ]
RTP, RTCP  SRTP, SRTCP  DTLS-SRTP         ZRTP        

Alternative transports for RTP:

              [A/V]      [A/V]
[A/V]         [RTP|RTCP  |RTP|RTCP  ]
[RTP|RTCP  ]  [RoQ stream|RoQ Datag.]
[framing   ]  [QUIC                 ]
[TCP       ]  [UDP                  ]
[IP        ]  [IP                   ]
RTP over TCP  RTP over QUIC (RoQ)
Protocol Port Description
RTSP (Real Time Streaming Protocol) TCP 554 Control RTP streams (PLAY/PAUSE, etc.)
RTSPS (Secure RTSP) TCP 322 RTSP over TLS
SIP (Session Initiation Protocol) TCP 5060
UDP 5060
SCTP 5060
SIP over TLS TCP 5061
SIP over WebSocket TCP 80
TCP or UDP 443
Protocol Description
RTP Transport A/V streams
RTCP Flow/congestion control for RTP
SRTP and SRTCP
DTLS-SRTP DTLS handshake (with mutual authentication) for keying SRTP (and SRTCP).
ZRTP Diffie-Hellman key exchange on the same port as SRTP.
S/MIME May be used in SIP to provide end-to-end protection of SDP content
Framing for RTP When used over TCP, each RTP or RTCP packet is prefixed with a length field (2 bytes).
RTP-MIDI Send MIDI 1 data over RTP
RTP-over-QUIC (RoQ)

Notes:

Message multiplexing:

WebRTC

                                                     [DCEP|data. chan.]           
                 [DCEP|data. chan.]                  [SCTP            |A/V ]      
                 [SCTP            |A/V ]        [STUN|mDTLS           |SRTP|SRTCP]
            [STUN|mDTLS           |SRTP|SRTCP]  [framing                         ]
[SDP     ]  [UDP (+ ICE)                     ]  [TCP (+ ICE)                     ]
[anything]  [IP  (+ ICE)                     ]  [IP  (+ ICE)                     ]
WebRTC      WebRTC over UDP                     WebRTC over TCP                   
Signaling

Type of payloads:

                                                                               [DCEP|data chan.]
                              [DCEP|data chan.]            [A/V ]              [SCTP           ]
           [A/V ]             [SCTP           ] [STUN|mDTLS|SRTP|SRTCP]   [STUN|mDTLS          ]
[STUN|mDTLS|SRTP|SRTCP]  [STUN|mDTLS          ] [framing              ]   [framing             ]
[UDP (+ ICE)          ]  [UDP (+ICE)          ] [TCP (+ ICE)          ]   [TCP (+ICE)          ]
[IP  (+ ICE)          ]  [IP  (+ICE)          ] [IP  (+ ICE)          ]   [IP  (+ICE)          ]
WebRTC A/V streams       WebRTC Data Channel    WebRTC A/V streams        WebRTC Data Channel 
(DTLS-SRTP)              (SCTP/DTLS)            (DTLS-SRTP)               (SCTP/DTLS)
proto=UDP/TLS/RTP/SAVPF  proto=UDP/DTLS/SCTP    proto=TCP/TLS/RTP/SAVPF   proto=TCP/DTLS/SCTP

Example WebRTC stack with TURN tunneling:


     [DCEP|data. chan.]           
     [SCTP            |A/V ]      
[STUN|mDTLS           |SRTP|SRTCP]
[TURN                            ]
[(DTLS)                          ]
[UDP                             ]
[IP                              ]
WebRTC with TURN tunnel
WebRTC Payload type SCTP PPID Description
SRTP-DTLS -
DCEP (Data Channel Establishment Protocol) 50 Used to create WebRTC data channels.
WebRTC String 51
WebRTC Binary 53
WebRTC Empty String 56
WebRTC Empty Binary 57

Notes:

References:

Security Layers

TLS

TLS sublayers:

[Handshake | ChangecipherSpec | Alert | Application]
[TLS Record Protocol: fragmentation                ] [Handshake | Alert | Application       ]
[TLS Record Protocol: compression                  ] [TLS Record Protocol: fragmentation    ]
[TLS Record Protocol: record protection            ] [TLS Record Protocol: record protection]
[Transport layer                                   ] [Transport layer                       ]
TLS v1.2                                             TLS v1.3

Some protocol stacks using TLS:

                                                  [mTLS   ]           
[HTTP] [HTTP/3|TLS] [SMTP] [IMAP] [TLS|IP / Eth.] [EAP-TLS]    [mTLS   ]
[TLS ] [QUIC      ] [TLS ] [TLS ] [OpenVPN      ] [EAP    ]    [EAP-TLS]
[TCP ] [UDP       ] [TCP ] [TCP ] [TCP / UDP    ] [EAPOL  ]    [EAP    ]
[IP  ] [IP        ] [IP  ] [IP  ] [IP           ] [Wifi   ]    [PPP    ]
HTTPS  HTTPS        SMTPS  IMAPS  OpenVPN         WPA2-EAP     PPP
       (HTTP/3)                                   with EAP-TLS with EAP-TLS 
TLS Subprotocols Description
Underlying transport layer eg. TCP
TLS Record Protocol: Record Protection Encryption and message authentication (Cipher+MAC or AEAD).
TLS Record Protocol: Compression Message compression, if negotiated. Not available in TLS v1.3.
TLS Record Protocol: Fragmentataion Subprotocols multiplexing and framing.
TLS Handshake Protocol TLS handshake (version/ciphersuite negotiation, authentication, key exchange, etc.).
TLS ChangecipherSpec Enables communication protection for this direction
TLS Alert Errors.
Application Layer eg. HTTP, SMTP, etc.

DTLS

Transports:

[app.] [app.] [app.]
[DTLS] [DTLS] [DTLS]
[UDP ] [SCTP] [DCCP]
[IP  ] [IP  ] [IP  ]
DTLS   DTLS   DTLS
over   over   over
UDP    SCTP   DCCP

QUIC

[app.]      [app. streams|app. dgrams]
[QUIC|TLS]  [QUIC         +dgram.    |TLS]
[UDP     ]  [UDP                         ]
[IP      ]  [IP                          ]
QUIC        QUIC with QUIC datagrams
Protocol Description
QUIC Protected transport. Provides multiple streams on top of a single connection.
TLS Used for the handshake (negotiation, keying)
QUIC datagrams Extension of QUIC for unreliable datagrams (not associated to any QUIC stream).

QUIC is used by:

QUIC Datagrams are used by:

References:

SSH

               [(GSS-API)|shell|command|forwarding]
[SSH Authentication Layer|SSH Connection Layer    ]
[SSH Transport Layer                              ]
[TCP                                              ]
[IP                                               ]
Protocol Description
GSS-API authentication for SSH

SSH sessions include:

SSH forwardings include:

Some applications:

VPNs and tunnels

IPSec

SA (Security Associations) establishment:

        [...  ]
        [EAP  ]
[IKEv2] [IKEv2]
[UDP  ] [UDP  ]
[IP   ] [IP   ]
IKEv2   IKEv2
        w/ EAP

IPsec:

                                          [UDP|TCP|...] [IP ]
[UDP|TCP|...] [IP]   [UDP|TCP|...] [IP ]  [ESP        ] [ESP]
[AH         ] [AH]   [ESP        ] [ESP]  [UDP        ] [UDP]
[IP         ] [IP]   [IP         ] [IP ]  [IP         ] [IP ]
AH            AH     ESP           ESP    ESP/UDP       ESP/UDP
Transport     Tunnel Transport     Tunnel Transport     Transport
Protocol IP Protocol Port Notes
AH (Authentication Header) 51 - integrity, data origin authentication, anti-replay (including the outer IP packet)
ESP (Encapsulating Security Payload) 50 - integrity, data origin authentication, anti-replay, confidentiality (of the payload)
IKEv2 - UDP 500
ESP over UDP (and IKDEv2) - UDP 4500

ESP transport mode:

[app.]<--------->[app.]
[TCP ]<--------->[TCP ]
[ESP ]<=========>[ESP ]
[IP  ]<--------->[IP  ]
correspondent    correspondent

ESP tunnel mode:

[app.]<------------------------------>[app.]
[TCP ]<------------------------------>[TCP ]
[IP  ]<-------->[IP ]<----->[IP ]<----[IP  ]
                [ESP]<=====>[ES ]
                [IP ]<----->[IP ]
correspondent   Gateway     Gateway   correspondent

AH transport mode:

[app.]<--------->[app.]
[TCP ]<--------->[TCP ]
[AH  ]<--------->[AH  ]
[IP  ]<=-=-=-=-=>[IP  ]
correspondent    correspondent

AH tunnel mode:

[app.]<---------------------------->[app.]
[TCP ]<---------------------------->[TCP ]
[IP  ]<-------->[IP]<----->[IP]<--->[IP  ]
                [AH]<----->[AH]
                [IP]<=-=-=>[IP]
correspondent   Gateway    Gateway  correspondent

References:

VPNs

[IPv4|IPv6|(TLS)]   [Eth. MAC|(TLS)]  [IP       ]  [IP / Eth. MAC]
[OpenVPN        ]   [OpenVPN       ]  [WireGuard]  [SSH          ]
[TCP / UDP      ]   [TCP /  UDP    ]  [UDP      ]  [TCP          ]
[IP             ]   [IP            ]  [IP       ]  [IP           ]
OpenVPN IP          OpenVPN Ethernet  WireGuard    OpenSSH tunnel
(TUN mode)          (TAP mode)

                                [IP    ] 
[IP     ]  [IP               ]  [PPP   ]  [IP    ]
[Capsule]  [Capsule|-        ]  [SSTP  ]  [PPP   ]
[HTTP   ]  [HTTP3  |H3 dgram.]  [HTTP  ]  [HTTP  ]
[(TLS)  ]  [QUIC      +dgram.]  [TLS   ]  [TLS   ]
[TCP    ]  [UDP              ]  [TCP   ]  [TCP   ]
[IP     ]  [IP               ]  [IP    ]  [IP    ]
IP in HTTP IP in HTTP/3         MS-SSTP   FortiSSL
Protocol Port
OpenVPN UDP 1194, TCP 1194
WireGuard UDP 51820
OpenSSH tunnel (over SSH, TCP 22)
IP in HTTP TCP/UDP 443 (HTTPS)
MS-SSTP TCP/UDP 443 (HTTPS)
FortiSSL

Notes:

Simple Tunnels

          [IP        ]  [IP  ]
          [GRE       ]  [GRE ]
          [(UDP)     ]  [DTLS]        [Eth. MAC]
[IP]      [(AH / ESP)]  [UDP ]        [EtherIP ]
[IP]      [IP        ]  [IP  ]        [IP      ]
IP in IP  GRE           GRE-UDP-DTLS  EtherIP
Protocol SAP Description
GRE (Generic Routing Encapsulation) IP proto 47 Next protocol defined as an EtherType; Optional 32 bit key (tunnel ID); optional 32 bit sequence number
GRE-in-UDP UDP 4754 (dest.)
GRE-UDP-DTLS UDP 4755 (dest.)
EtherIP IP proto 97

L2TPv3

Pseudowires:

[PPP ] [Eth. MAC] [Frame Relay] [HDLC] [ATM ]
[L2TP] [L2TP    ] [L2TP       ] [L2TP] [L2TP]
[... ] [...     ] [...        ] [... ] [... ]

Transports:

                            [... ]
                            [L2TP]
[... ]                      [SNAP] [... ]
[L2TP] [... ] [...        ] [LLC ] [L2TP]
[UDP ] [L2TP] [L2TP       ] [AAL5] [AAL5]
[IP  ] [IP  ] [Frame Relay] [ATM ] [ATM ]
L2TP   L2TP   L2TP          L2TP   L2TP
/UDP   /IP    /Frame Relay  /ATM   /ATM
                            (LLC)  (VC mux)
Protocol SAP Description
L2TP (Layer Two Tunneling Protocol) 16 bit tunnel ID, optional 16 bit sequence numbers
L2TP over IP IP proto. 115
L2TP over UDP UDP 1701 (control)

Network virtualization

[Eth. MAC  ] [Eth. / IP / ...] [Eth. / IP / ...]
[VXLAN     ] [GENEVE         ] [GRE + Key ext. ]
[UDP       ] [UDP            ] [(UDP)          ]
[(AH / ESP)] [(AH / ESP)     ] [(AH / ESP)     ]
[IP        ] [IP             ] [IP             ]
VXLAN        GENEVE            NVGRE           
Protocol Port Description
VXLAN (Virtual eXtensible LAN) UDP 4789 (dest.) 24 bit VNI (VXLAN Network Identifier), always encapsulates Ethernet
GENEVE (Generic Network Virtualization Encapsulation) UDP 6081 (dest.) 24 bit VNI, can encapsulate different protocols (EtherType)
NVGRE (Network Virtualization witg GRE) 24-bit VSID (Virtual Subnet Identifier), can encapsulate different protocols (EtherType)

Authentication, authorization

EAP

TLS-based EAP methods:

          [...     ]
          [EAP     ] [PAP     ] [CHAP    ] [... ] [... ]
          [AVP     ] [AVP     ] [AVP     ] [EAP ] [EAP ]
[mTLS   ] [TLS     ] [TLS     ] [TLS     ] [TLS ] [TLS ]
[EAP-TLS] [EAP-TTLS] [EAP-TTLS] [EAP-TTLS] [PEAP] [TEAP]
[EAP    ] [EAP     ] [EAP     ] [EAP     ] [EAP ] [EAP ]
[...    ] [...     ] [...     ] [...     ] [... ] [... ]
 EAP-TLS     EAP         PAP       CHAP    EAP    EAP
             over        over      over    over   over
           EAP-TTLS    EAP-TTLS  EAP-TTLS  PEAP   TEAP

EAP transports:

                          [... ] [...] [...      ] [...       ]
      [...     ] [...   ] [EAP ] [EAP] [EAP      ] [EAP       ]
[...] [EAP     ] [EAP   ] [PANA] [IKE] [RADIUS   ] [Diameter  ]
[EAP] [802.1X  ] [802.1X] [UDP ] [UDP] [UDP / TCP] [TCP / SCTP]
[PPP] [Ethernet] [Wifi  ] [IP  ] [IP ] [IP       ] [IP        ]
 EAP  802.1X     WPA-EAP  PANA   EAP   EAP over    EAP/Diameter
 for                             for   RADIUS
 PPP                             IKE

Example full protocol stacks:

           [EAP-MSCHAPV2]
           [EAP         ]
[mTLS   ]  [TLS         ]
[EAP-TLS]  [TEAP        ]
[EAP    ]  [EAP         ]
[802.1X ]  [802.1X      ]
[Wifi   ]  [Wifi        ]
WPA-EAP    WPA-EAP  
with       with     
EAP-TLS    EAP-EAP
           and MSCHAPv2
EAP Method Method Type Description
EAP-TLS 13 Mutual TLS authentication
EAP-TTLS 21 AVPs (attribute value pairs) in the Diameter format over TLS
PEAP (Protected EAP) 25 Inner EAP exchange over a TLS tunnel
EAP-FAST 43
TEAP (Tunnel EAP) 55 Inner EAP exchange over a TLS tunnel (standardized version of PEAP)
EAP-SIM, EAP-AKA, EAP-AKA' 18, 23, 50 SIM-based authentication
EAP-pwd 52 Authenticated key exchange based on a shared password
EAP-NOOB 56 Authentication for IoT devices based on an initial out-of-band channel
EAP Transport Description
802.1X Authetication of LAN/WLAN such as Ethernet and Wifi (WPA-EAP aka WPA-Entreprise)
PANA (Protocol for Carrying Authentication for Network Access)
RADIUS support for EAP EAP messages encapsulated in the EAP-Message attribute
Diameter support for EAP EAP messages encapsulated in EAP-Payload AVP

Kerberos

           [Kerberos]
           [MS-KKDCP]
           [HTTP    ]
[Kerberos] [TLS     ]
[UDP/TDP ] [TCP     ]
[IP      ] [IP      ]
Kerberos   MS-KKDCP
EAP Method Port Description
Kerberos UDP or TCP 88
MS-KKDCP (Kerberos Key Distribution Center Proxy) TCP or UDP 443 (HTTPS) Kerberos over HTTPS.

SASL

General SASL stack:

[mechanism]
[SASL     ]   [protocol   ]
[protocol ] → [(SASL sec.)]
[...      ]   [...        ]

Notes:

SASL Mechanism Security Layer Channel Binding Description
GSSAPI Optional (negotiated) Yes Kerberos 5 (not other mechanisms) with GSSAPI
GSS2-* No No GSS-API mechanisms (without support for channel binding)
GSS2-*-PLUS No Yes GSS-API mechanisms (with support for channel binding)
OAUTHBEARER No No Oauth 2.0 Bearer token

GSSAPI

           [Kerberos] [MS-NLMP ]  [...    ]
[Kerberos] [SPNEGO  ] [SPNEGO  ]  [EAP    ]
[GSS-API ] [GSS-API ] [GSS-API ]  [GSS-API]
[SASL    ] [SASL    ] [SASL    ]  [SASL   ]
[...     ] [...     ] [...     ]  [...    ]
GSS-API    GSS-API    NTLM
with       with       with SNPEGO
Kerberos   SPNEGO     /SASL
/ SASL     /SASL
Protocol Description
GSSAPI (Generic Security Service API) GSSAPI defines a Mechanism-Independent Token Format which is required for the initial token but optional for the other tokens
SPNEGO (Simple and Protected Negotiation Mechanism) Negotiation of GSSAPI mechanism to use
Kerberos 5 for GSSAPI mechanism
GSS mechanism for EAP

Notes:

RADIUS and DIAMETER

                  [RADIUS]                       [Diameter] [Diameter]
[RADIUS] [RADIUS] [TLS   ] [Diameter] [Diameter] [TLS     ] [DTLS    ]
[UDP   ] [TCP   ] [TCP   ] [TCP     ] [SCTP    ] [TCP     ] [SCTP    ]
[IP    ] [IP    ] [IP    ] [IP      ] [IP      ] [IP      ] [IP      ]
RADIUS   RADIUS   RADIUS   Diameter   Diameter   Diameter   Diameter
/UDP     /TCP     /TLS     /TCP       /SCTP      /TLS       /DTLS
                  (RadSec)
Protocol Port SCTP PPID Description
RADIUS (authentication and authorization) UDP 1812, TCP 1812 -
RADIUS Accounting UDP 1813, TCP 1813 -
RADIUS DynAuth UDP 3799 - Disconnect and Change-of-Authorization (CoA) messages
RADIUS over TLS (RadSec) TCP 2083 -
Diameter TCP 3868, SCTP 3868 46
Diameter over TLS/TCP TCP 5658 -
Diameter over DTLS/SCTP SCTP 5658 47

NAT traversal

STUN and TURN

                [UDP app.    ]
[STUN        ]  [TURN        ] [TURN        ]   [TURN|app.]
[(DTLS / TLS)]  [(DTLS / TLS)] [(DTLS / TLS)]   [(TLS)    ]
[UDP   / TCP ]  [UDP   / TCP ] [UDP   / TCP ]   [TCP      ]
[IP          ]  [IP          ] [IP          ] → [IP       ]
    STUN        TURN (UDP)     TURN-TCP         TURN-TCP
                                                connection
Protocol Description
STUN (Session Traversal Utilities for NAT)
STUN with DTLS
TURN (Traversal Using Relays around NAT) Extension of STUN for relaying communications (UDP applications) over UDP or TCP.
TURN-TCP Extension of TURN for relaying TCP applications (over TCP). TCP connections are allocated over a control TURN channel. Each TCP connection is transported over a new dedicated connection after an initial ConnectionBind TURN request (and response).

ICE

                                 [SDP ]        
[STUN (+TURN)]   [SDP]           [HTTP]           [STUN|app.    ]
[(DTLS / TLS)]   [SIP]           [TLS ]           [(DTLS)/ (TLS)]
[UDP   / TCP ]   [TCP]           [TCP ]           [UDP   / TCP  ]
[IP          ]   [IP ]           [IP  ]           [IP           ]
STUN, TURN       ICE candidate   ICE candidates   ICE communications
(candidate       exchange        exchange         (direct)
 collection)     with SIP        with SDP/HTTPS
Protocol Description
ICE (Interactive Connectivity Establishment) Uses STUN, TURN and exchanges ICE candidates for establishing communications.
ICE-TCP Extends ICE for TCP streams.
STUN Used to help NAT traversal.
TURN Used for relaying communication when no direct communication are possible.
SDP May be used for exchanging ICE candidates (for example in SIP or WebRTC). Other methods may be used depending on the application (including non-SDP methods).

Note:

Example of ICE through TURN:

[STUN¦app ]<-------------------->[STUN¦app]
[TURN     ]<--->o[TURN]          [-       ]
[TLS      ]<--->o[TLS ]          [-       ]
[TCP      ]<--->o[TCP |UDP]<---->[UDP     ]
[IP       ]<---->[IP      ]<---->[IP      ]
Appl. Peer                       Appl. Peer
TURN client      TURN server

Ethernet (802.1)

       [...  ]  [IP|ARP|...  ]
       [EAP  ]  [SNAP        ]
[IP|ARP|EAPOL]  [LLC         ]
[(802.1Q    )]  [(802.1Q    )]
[(802.1ad   )]  [(802.1ad   )]
[Ethernet MAC]  [Ethernet MAC]
[Ethernet PHY]  [Ethernet PHY]
Ethernet II     802.1 with SNAP

Ethernet PHY sublayers (since Fast Ethernet):

[Ethernet PCS]  [Ethernet PCS]   (PHY)
[Ethernet PMA]  [Ethernet PMA]   (PHY)
[Ethernet PMD]  [Ethernet PMD]   (PHY)
Protocol EtherType Description
PMD (Physical Medium Dependent sublayer) - eg. 100BASE-FX, 10GBASE-E, 10GBASE-L, 10GBASE-S, 10GBASE-LX4
PMA (Physical Medium Attachment sublayer) - Framing, synchronization, etc.
PCS (Physical coding sublayer sublayer) - Negotiation, coding (error detection)
ARP (Address Resolution Protocol) 0x0806 Mapping between MAC addresses and IP addresses
801.1Q 0x8100 VLAN (Q-tag)
802.1ad (Q-in-Q) 0x88A8 VLAN in VLAN (outer 802.1ad tag is S-tag for service-tag; inner 802.1Q tag is c-tag for customer-tag)
802.1X (EAPOL) 0x888E Port Authentication, used for WPA-Entreprise as well
IPv4 0x0800
IPv6 0x86DD
LLC (Logical Link Control) (length ≤ 1500)
SNAP (Subnetwork Access Protocol) -

Wifi (802.11)

[...      ]
[EAP      ]
[EAPOL    ]    [IP                   |ARP]
[SNAP     ]    [SNAP                     ]  (Link)
[LLC      ]    [LLC                      ]  (Link)
               [(WEP / TKIP / CCMP / GCM)]  (Link)
[Wifi MAC ]    [Wifi MAC                 ]  (Link)
[Wifi PLCP]    [Wifi PLCP                ]  (Phy.)
[Wifi PMD ]    [Wifi PMD                 ]  (Phy.)
WPA-Entreprise
Authentication
(WPA-EAP)
Layer Description
PMD (Physical Medium Dependent sublayer) (eg. 802.11 FHSS, 802.11 DSSS, 802.11a OFDM, 802.11b HR/DSSS, 802.11g ERP)
PLCP (Physical Layer Convergence Protocol sublayer)
WEP (Wired Equivalent Privacy) Old encryption layer (based on RC4 and CRC-32)
TKIP (Temporal Key Integrity Protocol) Encryption layer of WPA1 (RC4 stream cipher with “Michael” MIC)
CCMP Encryption layer of WPA2 (AES with CCM mode)
GCMP-256 Encryption layer of WPA3 (56-bit Galois/Counter mode)
LLC (Logical Link Control)
SNAP (Subnetwork Access Protocol)

Access Point:

[app.    ]<--------------------------->[app.    ]
[TCP     ]<--------------------------->[TCP     ]
[IP      ]<--------------------------->[IP      ]
[SNAP    ]<--------------------------->[SNAP    ]
[LLC     ]<--------------------------->[LLC     ]
[sec. #1 ]<===>[sec. #1 | sec. #2]<===>[sec. #2 ]
[Wifi MAC]<--->[Wifi MAC         ]<--->[Wifi MAC]
[Wifi PHY]<--->[Wifi PHY         ]<--->[Wifi PHY]
Station 1         Access Point         Station 2

Ethernet/Wireless bridge:

[app.    ]<------------------------------->[app.    ]
[TCP     ]<------------------------------->[TCP     ]
[IP      ]<------------------------------->[IP      ]
[SNAP    ]<----[SNAP      ]
[LLC     ]<--->[LLC       ]
[security]<===>[security  ]
[Wifi MAC]<--->[Wifi MAC \-/ Eth. MAC]<--->[Eth. MAC]
[Wifi PHY]<--->[Wifi PHY  |  Eth. PHY]<--->[Eth. PHY]
Station 1      Ethernet/Wireless bridge     Station 2

ATM

        [...   /  ...]
        [NLPID / SNAP]
[... ]  [LLC         ]
[AAL5]  [AAL5        ]
[ATM ]  [ATM         ]
[phy. ] [phy.        ]
VC Mux  LLC Encap.

References:

PPP

Configuration:

              [...        ]
[LCP] [CCP]   [compression]
[PPP] [PPP]   [PPP        ]
[...] [...] → [...        ]
LCP   CCP and compression

Authentication:

             [...]
[PAP] [CHAP] [EAP]
[PPP] [PPP ] [PPP]
[...] [... ] [...]
PAP   CHAP   EAP

Applications:

[IPCP|IPv4] [IPv6CP|IPv6]
[PPP      ] [PPP        ]
[...      ] [...        ]
IPv4/PPP    IPv6/PPP

Transports:

                               [...   ]       
                               [PPP   ]        [...]
[...   ]   [... ]   [...     ] [(SNAP)] [... ] [PPP]
[PPP   ]   [PPP ]   [PPP     ] [LLC   ] [PPP ] [SSH]
[HDLC  ]   [HDLC]   [PPPoE   ] [AAL5  ] [L2TP] [TCP]
[RS-232]   [V.92]   [Ethernet] [ATM   ] [... ] [IP ]
PPP/RS-232 PPP/PSTN PPPoE      PPPoA    L2TP   PPP
                                               /SSH
Protocol PPP Protocol EtherType Description
PPP (Point-to-Point Protocol) -
LCP (Link Control Protocol) 0xc021 -
PAP (Password Authentication Protocol) 0xc023 - Cleartext login/password
CHAP (Challenge-Handshake Authentication Protocol) 0xc223 - Includes MC-CHAP and MS-CHAPv2 as well.
EAP (Extensible Authentication Protocol) 0xc227 -
IPCP (IP Configuration Protocol) 0x0021 - Configuration of the IPv4 address
IPv4 0x0021 -
IPv6CP (IPv6 Configuration Protocol) 0x8057 -
IPv6 0x0057 -
PPPoA, PPP-over-ATM (AAL5) - -
PPPoE, PPP-over-Ethernet - 0x8863 (discovery),
0x8864 (session)
L2TP (Layer Two Tunneling Protocol) - -
HDLC-like framing (RFC 1662) for PPP - -
CCP (Compression Control Protocol) - -
PPP over SSH - - It's not a standard thing but you can do it.

GPON (G.984)

Gigabit Passive Optical Network:

                                                 [PWE3          ]
                               [SIP |RTP      ]  [RTP           ]
                               [TCP |UDP      ]  [UDP           ]
                   [IP      ]  [IP            ]  [IP            ]  [MEF-8         ]
                   [VLAN    ]  [VLAN          ]  [VLAN          ]  [VLAN          ]
               [TDM|Eth. MAC]  [Eth. MAC      ]  [Eth. MAC      ]  [Eth. MAC      ]  [SDH           ]
[PLOAM|OMCI|ATM|GEM         ]  [GEM           ]  [GEM           ]  [GEM           ]  [GEM           ]
[GTC adaptation             ]  [GTC adaptation]  [GTC adaptation]  [GTC adaptation]  [GTC adaptation]
[GTC framing                ]  [GTC framing   ]  [GTC framing   ]  [GTC framing   ]  [GTC framing   ]
[GPM                        ]  [GPM           ]  [GPM           ]  [GPM           ]  [GPM           ]
General stack                  Voice (VoIP)      Voice with PWE3   Voice with MEF-8  Voice (TDM)
Protocol Description
GPM (GPON Physical Media Dependent layer)
GTC framing
PLOAM (Physical Layer Operations, Administration and Maintenance)
OMCI (ONU Management and Control Interface)
GEM (G-PON Encapsulation Mode)
TDM (Time Division Multiple Access) Emulation of any TDM-based circuit
PWE3, Pseudo Wire Emulation Edge-to-Edge Frame Relay/ATM/Ethernet/TDM/SONET/SDH over IP or MPLS
MEF-8 Emulation of PDH over Ethernet

References:

XG-PON (G.987)

                                                      [PWE3               ]
                               [SIP|RTP            ]  [RTP                ]
                               [TCP|UDP            ]  [UDP                ]
                  [IP  ]       [IP                 ]  [IP                 ]  [MEF-8              ]
           [802.1X|VLAN]       [VLAN               ]  [VLAN               ]  [VLAN               ]
           [Eth. MAC   |MPLS]  [Eth. MAC           ]  [Eth. MAC           ]  [Eth. MAC           ]
[PLOAM|OMCI|XGEM            ]  [XGEM               ]  [XGEM               ]  [XGEM               ]
[XGTC framing               ]  [XGTC framing       ]  [XGTC framing       ]  [XGTC framing       ]
[XGTC PHY adaptation        ]  [XGTC PHY adaptation]  [XGTC PHY adaptation]  [XGTC PHY adaptation]
[XGON PMD                   ]  [XGON PMD           ]  [XGON PMD           ]  [XGON PMD           ]
General stack                  Voice (voIP)           Voice with PWE3        Voice with MEF-8

References:

Phone

SS7

                [... ]  [... ]       [...  ]       [...    ]  [... ]
           [ISUP|TCAP]  [TCAP]       [TCAP ]       [TCAP   ]  [TCAP]
[TUP / ISUP|SCCP     ]  [SUA |ISUP]  [SCCP ]       [SCCP   ]  [SCCP|ISUP]
[MTP-3               ]  [-        ]  [MTP-3|ISUP]  [MTP-3  ]  [M3UA     ]
[MTP-2               ]  [-        ]  [M2PA      ]  [M2UA   ]  [  -      ]
[MTP-1               ]  [(DTLS)   ]  [(DTLS)    ]  [(DTLS) ]  [(DTLS)   ]
                        [SCTP     ]  [SCTP      ]  [SCTP   ]  [SCTP     ]
                        [(IPSec)  ]  [(IPSec)   ]  [(IPSec)]  [(IPSec)  ]
                        [IP       ]  [IP        ]  [IP     ]  [IP       ]
SS7                     SUA          M2PA          M2UA       M3UA        ...

Some application protocols:

                          [MAP  ]
                 [ISUP ]  [TCAP ]
[TUP  ] [ISUP ]  [SCCP ]  [SCCP ]
[MTP-3] [MTP-3]  [MTP-3]  [MTP-3]
[MTP-2] [MTP-2]  [MTP-2]  [MTP-2]
[MTP-1] [MTP-1]  [MTP-1]  [MTP-1]
TUP     ISUP     ISUP     MAP
                 /SCCP
Protocol SCTP PPID Description
MTP-1 (Message Transfer Part layer 1) Physical layer
MTP-2 (Message Transfer Part layer 2) Link layer
MTP-3 (Message Transfer Part layer 3) Nework layer
TUP (Telephone User Part) Signaling for classic PSTN, mostly replaced by ISUP
ISUP (ISDN User Part)
SCCP (Signalling Connection Control Part)
TCAP (Transaction Capabilities Application Part)
CAP (CAMEL Application Part)
MAP (Mobile Application Part) Transport layer on top of IP
SCTP (Stream Control Transmission Protocol) -
SUA (SCCP User Adaptation) 4 Replaces SCCP when used over SCTP/IP
M2UA (MTP2 User Adaptation Layer) 2
M2PA (MTP2 User Peer-to-Peer Adaptation Layer) 5
M3UA (MTP3 User Adaptation Layer) 3

References:

Mobile

User Equipment (i.e. the phone) stacks:

                        PDP contexts        PDP contexts            EPS bearers          PDU sessions
                         |   |                 |   |                   |    |               |    |
           [SM      ]    ↓   ↓                 |   |                   |    |               ↓    ↓
           [GMM     ] [IP / PPP]  [CM|SM   ]   ↓   ↓      [LTE NAS ]   ↓    ↓    [5G NAS ] [IP|Eth.]
[CM     ]  [SNDCP   ] [SNDCP   ]  [MM|GMM  ] [IP / PPP ]  [LTE RRC ] [IP / PPP]  [5G RRC ] [SDAP   ]
[MM     ]  [GPRS LLC] [GPRS LLC]  [UMTS RRC] [UMTS PDCP]  [LTE PDCP] [LTE PDCP]  [5G PDCP] [5G PDCP]
[RRM    ]  [GPRS RLC] [GPRS RLC]  [UMTS RLC] [UMTS RLC ]  [LTE RLC ] [LTE RLC ]  [5G RLC ] [5G RLC ]
[LAPDm  ]  [GPRS MAC] [GPRS MAC]  [UMTS MAC] [UMTS MAC ]  [LTE MAC ] [LTE MAC ]  [5G MAC ] [5G MAC ]
[GSM PHY]  [GSM PHY ] [GSM PHY ]  [UMTS PHY] [UMTS PHY ]  [LTE PHY ] [LTE PHY ]  [5G PHY ] [5G PHY ]
   CP         CP         UP          CP          UP          CP         UP          CP        UP
--------   ---------------------  ----------------------  ---------------------  -----------------
GSM (2G)   GPRS (2.5G)            UMTS (3G)               LTE (aka EPS) (4G)     5G NR (5G)

Authentication stacks at the user equipment:

                                                  [...     ]
                                                  [AVP     ]
                                        [mTLS   ] [TLS     ]
                   [EAP-AKA] [EAP-AKA'] [EAP-TLS] [EAP-TTLS]
[EPS-AKA] [5G-AKA] [EAP    ] [EAP     ] [EAP    ] [EAP     ]
[NAS    ] [NAS   ] [NAS    ] [NAS     ] [NAS    ] [NAS     ]
EPS-AKA   5G-AKA   EAP-AKA   EAP-AKA'   EAP-TLS   EAP-TTLS
(4G)      (5G)     (5G)      (5G)       (5G)      (5G)

Notes:

References:

Protocol Description
LAPDm (Link Access Procedures on the Dm channel) Link layer for GSM used between the mobile station (i.e. the phone) and the BSC
RR aka RMM (Radio Resource Management)
MM (Mobile Management)
CM (Connection Management)
RLC (Radio Link Control)
LLC (Logical Link Control) (This is not the 802.2 LLC protocol used with Ethernet, Wifi, etc.)
SNDCP (Subnetwork Dependent Convergence Protocol)
GMM (GPRS Mobility Management)
SM (Session Management)
PDCP (Packet Data Convergence Protocol)
RRC (Radio Resource Control)
NAS (Non-access stratum)
SDAP (Service Data Adaption Protocol)
SM (Session Management)
GMM (GPRS Mobile Management)

References:

Non-3GPP access

User equipment stacks for untrusted non-3GPP access (5G):

                                              PDU sessions
                                                 |   |
[EAP-AKA]                                        |   |
[EAP    / 5G-AKA]                                ↓   ↓
[NAS            ]  [NAS  ]                     [IP|Eth.]   ← Application IP (IMS, data)
[EAP-5G         ]  [TCP  ]                     [GRE    ]
[EAP            ]  [IP   ]                     [IP     ]   ← Inner IP (connect to the N3IWF)
[IKEv2          ]  [ESP  ]      [IKEv2]        [ESP    ]
[UDP            ]  [(UDP)]      [UDP  ]        [(UDP)  ]
[IP             ]  [IP   ]      [IP   ]        [IP     ]   ←  Non-3GPP Access Network
[L2             ]  [L2   ]      [L2   ]        [L2     ]
[L1             ]  [L1   ]      [L1   ]        [L1     ]
CP                 CP           UP             UP
(before SA)        (after SA)   establishment

Notes:

User equipment stacks for untrusted non-3GPP access with firewall traversal (5G):

                                             PDU sessions
                                                |   |
[EAP-AKA]                                       |   |
[EAP    / 5G-AKA]                               ↓   ↓
[NAS            ] [NAS]                       [IP|Eth.]   ← Application IP (IMS, data)
[EAP-5G         ] [TCP]                       [GRE    ]
[EAP            ] [IP ]                       [IP     ]   ← Inner IP (connect to the N3IWF)
[IKEv2          ] [ESP]       [IKEv2]         [ESP    ]
[TLS            ] [TLS]       [TLS  ]         [TLS    ]
[TCP            ] [TCP]       [TCP  ]         [TCP    ]
[IP             ] [IP ]       [IP   ]         [IP     ]   ←  Non-3GPP Access Network
[L2             ] [L2 ]       [L2   ]         [L2     ]
[L1             ] [L1 ]       [L1   ]         [L1     ]
CP                CP          UP              UP
(before SA)       (after SA)  establishment

References:

IMS

IMS (IP Multimedia Subsystem) is an SIP/IP based-service to transporting voice, SMS, video over 4G (VoLTE), 5G (VoNR) or non-3GPP access (VoWLAN/WoWifi).

User equipment stacks for stacks for IMS:

[SMS]     [SDP|A/V ]
[SIP]     [SIP|RTP |RTCP]
[TCP]     [TCP|UDP / TCP]
[IP ]     [IP           ]
SMS       Audio/Video calls
over IMS      over IMs

Notes:

References:

SMS

User equipment stacks for SMS:

[SM-AL  ]           [SMS   ]
[SM-TL  ]           [SIP   ]
[SM-RP  ]  [SMS]    [TCP   ]
[SM-CP  ]  [NAS]    [IP    ]
[CM     ]  [RRC]    [(SDAP)]
[MM     ]  [RLC]    [PDCP  ]
[RR     ]  [RLC]    [RLC   ]
[LDAPDm ]  [MAC]    [MAC   ]
[GSM PHY]  [PHY]    [PHY   ]
SMS/GSM    SMS/NAS  SMS/IMS
(2G)       (4G/5G)  (4G/5G)

WAP

User equipment stacks for WAP (including MMS):

[WML | WMLScript | MMS]
[WSP                  ]  [XHTML MP|WAP CSS|MMS]
[(WTP )               ]  [(WP-)HTTP           ]
[(WTLS)               ]  [TLS                 ]
[WDP   / UDP          ]  [(WP-)TCP            ]
[SMS   / IP           ]  [IP                  ]
[...   / ...          ]  [...                 ]
WAP 1                    WAP 2.0
Protocol Description
Wireless Session Protocol (WSP) Similar to HTTP
Wireless Transaction Protocol (WTP) Similar to TCP. Used for CO-WSP (Connection-oriented WSP), absent for CL-WSP (Connectionless WSP)
Wireless Transport Layer Security (WTLS) Protection (similar to TLS)
Wireless Datagram Protocol (WDP) Similar to UDP
WML (Wireless Markup Language) XML-based markup language, similar to HTML
WMLScript Scripting language based on ECMAScript but compiled to a bytecode
XHTML MP (Mobile Profile)
WP-TCP Profile of TCP
WP-HTTP Profile of HTTP

References:

Devices

BlueTooth

                   ACL                           SCO
 /--------------------------------------------\ /---\

         [IP ]  [IP |... ]                                                 [HID|...]
         [PPP|AT|Eth. MAC]                                                 [GATT   |GAP  ]
    [SDP |RFCOMM|BNEP    |OBEX|HIDP|AVCTP|AVDTP]         [...      ]       [ATT    |SM|- ]
    [L2CAP                                     |voice]   [L2CAP    ]    [L2CAP        |- ]        ↑Host
------------------(HCI)-------------------------------   ---(HCI)---    ---(HCI)------------------
[LMP|-                                               ]   [Wifi PAL ]                              ↓Controler
[LCP                                                 ]   [Wifi MAC ]    [LE LL                   ]
[BR / EDR                                            ]   [Wifi PHY ]    [LE 1M / LE 2M / LE Coded]
Bluetooth Classic                                        Bluetooth HS   Bluetooth Low Energy (BLE)
                                                         (High Speed)

Host/Controler interface (HCI) example (over USB):

[RFCOMM ]<-------------------------------------->[RFCOMM  ]
[L2CAP  ]<-------------------------------------->[L2CAP   ]
[HCI    ]<--->[HCI    |LMP     ]<--------------->[LMP     ]
[USB    ]<--->[USB    |LCP     ]<--------------->[LCP     ]
[USB PHY]     [USB PHY|BR / EDR]<--------------->[BR / EDR]
Host          Bluetooth Controler                Device
Protocol Description
BR (Basic Rate)
EDR (Extended Data Rate)
LE (Low Energy) 1M
LE (Low Energy) 2M
LE (Low Energy) Coded
LCP
LMP (Link Manager Protocol)
LE LL (LE Link Layer)
L2CAP (Logical Link Control and Adaptation Protocol)
SDP (Service Discovering Protocol)
RFCOMM (Radio frequency communication) RS-232 port emulation
BNEP (Bluetooth Network Encapsulation Protocol) BNEP transports Ethernet traffic (but replaces the Ethernet header with its own header!)
OBEX
HIDP (Bluetooth HID Protocol)
AVCTP (Audio/video control transport protocol)
AVDTP (Audio/video data transport protocol)
SM (Security Manager)
GAP
ATT
GATT
AT Hayes Modem AT commands
HCI (Host Controller Interface) Communication between the host and the bluetooth controller

Radio link types:

USB

                                [Eth|...|MIDI1   |MIDI1|MIDI2]
[Std. Req.|HID|BOT|UAS|UASP|CCID|CDC    |USB-MIDI|USB-MIDI2  |IPP|...]
[USB Protocol layer                                                  ]
[USB PHysical                                                        ]
Device Classes Description
Standard Requests
HID (Human Interaction Device) Keyboard, Mouse, Baseball and Golf clubs, etc.
MSB (Mass Storage Device) USB stick, etc.
CDC (Commnication Device Class)
IPP (Internet Printing Protocol)
MTP (Media Transfer Protocol)
CCID (Chip Card Interface Device) Smartcard, Yubikeys, etc.
DFU (Device Firmware Upgrade)
BOT (Bulk Only Transfer)
UAS (USB Attached SCSI)
UASP (USB Attached SCSI Protocol) Not the same as UAS!

References:

Notations

[JSON \-/ CBOR]   JSON/CBOR conversion
[HTTP \-/ CoAP]   HTTP/CoAP proxy/interworking
[(TLS) |(DTLS)]   Optional layers
[TCP   |   UDP]   TCP and UDP layers
[IPv4  /  IPv6]   Either IPv4 or IPv6
[Eth. \-/ Wifi]   Ethernet/Wifi bridge

[STUN¦app     ]   STUN and and some application protocol used together between the same peers

[HTTP+WebDAV  ]   HTTP with WebDAV
[TLS + PSK    ]   TLS with PSK key exchange

[ -           ]   Empty layer, not a protocol layer

[app.  ]  Some undefined application layer
[...   ]  Some protocol layer(s)

<----->   Bidirectional communications
<----->o  Client/server relation, etc.
------>   One-way communications
<=====>   Protected communications (usually both confidentiality and integrity)
<=-=-=>   Integrity-protected communications (possibly with anti-replay protection)
   K      Interface name

References

Assignments:

DNS:

Samples:

Misc: