Logo of The Linux Kernel

The Linux Kernel

next-20251209

Quick search

Contents

  • Development process
  • Submitting patches
  • Code of conduct
  • Maintainer handbook
  • All development-process docs
  • Core API
  • Driver APIs
  • Subsystems
    • Core subsystems
    • Human interfaces
    • Networking interfaces
      • Networking
      • NetLabel
      • InfiniBand
      • ISDN
      • MHI
    • Storage interfaces
    • Other subsystems
  • Locking
  • Licensing rules
  • Writing documentation
  • Development tools
  • Testing guide
  • Hacking guide
  • Tracing
  • Fault injection
  • Livepatching
  • Rust
  • Administration
  • Build system
  • Reporting issues
  • Userspace tools
  • Userspace API
  • Firmware
  • Firmware and Devicetree
  • CPU architectures
  • Unsorted documentation
  • Translations

This Page

  • Show Source

Family wireguard netlink specification¶

Contents

  • Family wireguard netlink specification

    • Summary

    • Operations

      • get-device

      • set-device

    • Definitions

      • key-len

      • --kernel-timespec

      • wgdevice-flags

      • wgpeer-flags

      • wgallowedip-flags

    • Attribute sets

      • wgdevice

      • wgpeer

      • wgallowedip

Summary¶

Netlink protocol to control WireGuard network devices.

The below enums and macros are for interfacing with WireGuard, using generic netlink, with family WG_GENL_NAME and version WG_GENL_VERSION. It defines two commands: get and set. Note that while they share many common attributes, these two commands actually accept a slightly different set of inputs and outputs. These differences are noted under the individual attributes.

Operations¶

get-device¶

Retrieve WireGuard device¶

The command should be called with one but not both of:

  • WGDEVICE_A_IFINDEX

  • WGDEVICE_A_IFNAME

The kernel will then return several messages (NLM_F_MULTI). It is possible that all of the allowed IPs of a single peer will not fit within a single netlink message. In that case, the same peer will be written in the following message, except it will only contain WGPEER_A_PUBLIC_KEY and WGPEER_A_ALLOWEDIPS. This may occur several times in a row for the same peer. It is then up to the receiver to coalesce adjacent peers. Likewise, it is possible that all peers will not fit within a single message. So, subsequent peers will be sent in following messages, except those will only contain WGDEVICE_A_IFNAME and WGDEVICE_A_PEERS. It is then up to the receiver to coalesce these messages to form the complete list of peers.

Since this is an NLA_F_DUMP command, the final message will always be NLMSG_DONE, even if an error occurs. However, this NLMSG_DONE message contains an integer error code. It is either zero or a negative error code corresponding to the errno.

value:

0

attribute-set:

wgdevice

flags:

[uns-admin-perm]

dump:
pre

wg-get-device-start

post

wg-get-device-done

request
attributes:

[ifindex, ifname]

reply
attributes:

[ifindex, ifname, private-key, public-key, flags, listen-port, fwmark, peers]

set-device¶

Set WireGuard device¶

This command should be called with a wgdevice set, containing one but not both of WGDEVICE_A_IFINDEX and WGDEVICE_A_IFNAME.

It is possible that the amount of configuration data exceeds that of the maximum message length accepted by the kernel. In that case, several messages should be sent one after another, with each successive one filling in information not contained in the prior. Note that if WGDEVICE_F_REPLACE_PEERS is specified in the first message, it probably should not be specified in fragments that come after, so that the list of peers is only cleared the first time but appended after. Likewise for peers, if WGPEER_F_REPLACE_ALLOWEDIPS is specified in the first message of a peer, it likely should not be specified in subsequent fragments.

If an error occurs, NLMSG_ERROR will reply containing an errno.

value:

1

attribute-set:

wgdevice

flags:

[uns-admin-perm]

do:
request
attributes:

[ifindex, ifname, private-key, public-key, flags, listen-port, fwmark, peers]

Definitions¶

key-len¶

name-prefix:

wg-

type:

const

value:

32

--kernel-timespec¶

type:

struct

header:

linux/time_types.h

members:
sec (u64):

Number of seconds, since UNIX epoch.

nsec (u64):

Number of nanoseconds, after the second began.

wgdevice-flags¶

name-prefix:

wgdevice-f-

enum-name:

wgdevice-flag

type:

flags

entries:
  • replace-peers

wgpeer-flags¶

name-prefix:

wgpeer-f-

enum-name:

wgpeer-flag

type:

flags

entries:
  • remove-me

  • replace-allowedips

  • update-only

wgallowedip-flags¶

name-prefix:

wgallowedip-f-

enum-name:

wgallowedip-flag

type:

flags

entries:
  • remove-me

Attribute sets¶

wgdevice¶

unspec (unused)¶

value:

0

ifindex (u32)¶

ifname (string)¶

private-key (binary)¶

doc:

Set to all zeros to remove.

display-hint:

hex

public-key (binary)¶

display-hint:

hex

flags (u32)¶

doc:

0 or WGDEVICE_F_REPLACE_PEERS if all current peers should be removed prior to adding the list below.

enum:

wgdevice-flags

listen-port (u16)¶

doc:

Set as 0 to choose randomly.

fwmark (u32)¶

doc:

Set as 0 to disable.

peers (indexed-array)¶

sub-type:

nest

nested-attributes:

wgpeer

doc:

The index/type parameter is unused on SET_DEVICE operations and is zero on GET_DEVICE operations.

wgpeer¶

unspec (unused)¶

value:

0

public-key (binary)¶

display-hint:

hex

preshared-key (binary)¶

doc:

Set as all zeros to remove.

display-hint:

hex

flags (u32)¶

doc:

0 and/or WGPEER_F_REMOVE_ME if the specified peer should not exist at the end of the operation, rather than added/updated and/or WGPEER_F_REPLACE_ALLOWEDIPS if all current allowed IPs of this peer should be removed prior to adding the list below and/or WGPEER_F_UPDATE_ONLY if the peer should only be set if it already exists.

enum:

wgpeer-flags

endpoint (binary)¶

doc:

struct sockaddr_in or struct sockaddr_in6

persistent-keepalive-interval (u16)¶

doc:

Set as 0 to disable.

last-handshake-time (binary)¶

struct:

--kernel-timespec

rx-bytes (u64)¶

tx-bytes (u64)¶

allowedips (indexed-array)¶

sub-type:

nest

nested-attributes:

wgallowedip

doc:

The index/type parameter is unused on SET_DEVICE operations and is zero on GET_DEVICE operations.

protocol-version (u32)¶

doc:

Should not be set or used at all by most users of this API, as the most recent protocol will be used when this is unset. Otherwise, must be set to 1.

wgallowedip¶

unspec (unused)¶

value:

0

family (u16)¶

doc:

IP family, either AF_INET or AF_INET6.

ipaddr (binary)¶

doc:

Either struct in_addr or struct in6_addr.

display-hint:

ipv4-or-v6

cidr-mask (u8)¶

flags (u32)¶

doc:

WGALLOWEDIP_F_REMOVE_ME if the specified IP should be removed; otherwise, this IP will be added if it is not already present.

enum:

wgallowedip-flags

©The kernel development community. | Powered by Sphinx 7.4.7 & Alabaster 0.7.16 | Page source