/* -------------------------- IOCTL LIST -------------------------- */

/* Wireless Identification */
#define SIOCSIWCOMMIT   0x8B00      /* Commit pending changes to driver */
#define SIOCGIWNAME 0x8B01      /* get name == wireless protocol */
/* SIOCGIWNAME is used to verify the presence of Wireless Extensions.
 * Common values : "IEEE 802.11-DS", "IEEE 802.11-FH", "IEEE 802.11b"...
 * Don't put the name of your driver there, it's useless. */

/* Basic operations */
#define SIOCSIWNWID 0x8B02      /* set network id (pre-802.11) */
#define SIOCGIWNWID 0x8B03      /* get network id (the cell) */
#define SIOCSIWFREQ 0x8B04      /* set channel/frequency (Hz) */
#define SIOCGIWFREQ 0x8B05      /* get channel/frequency (Hz) */
#define SIOCSIWMODE 0x8B06      /* set operation mode */
#define SIOCGIWMODE 0x8B07      /* get operation mode */
#define SIOCSIWSENS 0x8B08      /* set sensitivity (dBm) */
#define SIOCGIWSENS 0x8B09      /* get sensitivity (dBm) */

/* Informative stuff */
#define SIOCSIWRANGE    0x8B0A      /* Unused */
#define SIOCGIWRANGE    0x8B0B      /* Get range of parameters */
#define SIOCSIWPRIV 0x8B0C      /* Unused */
#define SIOCGIWPRIV 0x8B0D      /* get private ioctl interface info */
#define SIOCSIWSTATS    0x8B0E      /* Unused */
#define SIOCGIWSTATS    0x8B0F      /* Get /proc/net/wireless stats */
/* SIOCGIWSTATS is strictly used between user space and the kernel, and
 * is never passed to the driver (i.e. the driver will never see it). */

/* Spy support (statistics per MAC address - used for Mobile IP support) */
#define SIOCSIWSPY  0x8B10      /* set spy addresses */
#define SIOCGIWSPY  0x8B11      /* get spy info (quality of link) */
#define SIOCSIWTHRSPY   0x8B12      /* set spy threshold (spy event) */
#define SIOCGIWTHRSPY   0x8B13      /* get spy threshold */

/* Access Point manipulation */
#define SIOCSIWAP   0x8B14      /* set access point MAC addresses */
#define SIOCGIWAP   0x8B15      /* get access point MAC addresses */
#define SIOCGIWAPLIST   0x8B17      /* Deprecated in favor of scanning */
#define SIOCSIWSCAN 0x8B18      /* trigger scanning (list cells) */
#define SIOCGIWSCAN 0x8B19      /* get scanning results */

/* 802.11 specific support */
#define SIOCSIWESSID    0x8B1A      /* set ESSID (network name) */
#define SIOCGIWESSID    0x8B1B      /* get ESSID */
#define SIOCSIWNICKN    0x8B1C      /* set node name/nickname */
#define SIOCGIWNICKN    0x8B1D      /* get node name/nickname */
/* As the ESSID and NICKN are strings up to 32 bytes long, it doesn't fit
 * within the 'iwreq' structure, so we need to use the 'data' member to
 * point to a string in user space, like it is done for RANGE... */

/* Other parameters useful in 802.11 and some other devices */
#define SIOCSIWRATE 0x8B20      /* set default bit rate (bps) */
#define SIOCGIWRATE 0x8B21      /* get default bit rate (bps) */
#define SIOCSIWRTS  0x8B22      /* set RTS/CTS threshold (bytes) */
#define SIOCGIWRTS  0x8B23      /* get RTS/CTS threshold (bytes) */
#define SIOCSIWFRAG 0x8B24      /* set fragmentation thr (bytes) */
#define SIOCGIWFRAG 0x8B25      /* get fragmentation thr (bytes) */
#define SIOCSIWTXPOW    0x8B26      /* set transmit power (dBm) */
#define SIOCGIWTXPOW    0x8B27      /* get transmit power (dBm) */
#define SIOCSIWRETRY    0x8B28      /* set retry limits and lifetime */
#define SIOCGIWRETRY    0x8B29      /* get retry limits and lifetime */

/* Encoding stuff (scrambling, hardware security, WEP...) */
#define SIOCSIWENCODE   0x8B2A      /* set encoding token & mode */
#define SIOCGIWENCODE   0x8B2B      /* get encoding token & mode */
/* Power saving stuff (power management, unicast and multicast) */
#define SIOCSIWPOWER    0x8B2C      /* set Power Management settings */
#define SIOCGIWPOWER    0x8B2D      /* get Power Management settings */

/* WPA : Generic IEEE 802.11 informatiom element (e.g., for WPA/RSN/WMM).
 * This ioctl uses struct iw_point and data buffer that includes IE id and len
 * fields. More than one IE may be included in the request. Setting the generic
 * IE to empty buffer (len=0) removes the generic IE from the driver. Drivers
 * are allowed to generate their own WPA/RSN IEs, but in these cases, drivers
 * are required to report the used IE as a wireless event, e.g., when
 * associating with an AP. */
#define SIOCSIWGENIE    0x8B30      /* set generic IE */
#define SIOCGIWGENIE    0x8B31      /* get generic IE */

/* WPA : IEEE 802.11 MLME requests */
#define SIOCSIWMLME 0x8B16      /* request MLME operation; uses
                     * struct iw_mlme */
/* WPA : Authentication mode parameters */
#define SIOCSIWAUTH 0x8B32      /* set authentication mode params */
#define SIOCGIWAUTH 0x8B33      /* get authentication mode params */

/* WPA : Extended version of encoding configuration */
#define SIOCSIWENCODEEXT 0x8B34     /* set encoding token & mode */
#define SIOCGIWENCODEEXT 0x8B35     /* get encoding token & mode */

/* WPA2 : PMKSA cache management */
#define SIOCSIWPMKSA    0x8B36      /* PMKSA cache operation */

/* -------------------- DEV PRIVATE IOCTL LIST -------------------- */

/* These 32 ioctl are wireless device private, for 16 commands.
 * Each driver is free to use them for whatever purpose it chooses,
 * however the driver *must* export the description of those ioctls
 * with SIOCGIWPRIV and *must* use arguments as defined below.
 * If you don't follow those rules, DaveM is going to hate you (reason :
 * it make mixed 32/64bit operation impossible).
 */
#define SIOCIWFIRSTPRIV 0x8BE0
#define SIOCIWLASTPRIV  0x8BFF
/* Previously, we were using SIOCDEVPRIVATE, but we now have our
 * separate range because of collisions with other tools such as
 * 'mii-tool'.
 * We now have 32 commands, so a bit more space ;-).
 * Also, all 'odd' commands are only usable by root and don't return the
 * content of ifr/iwr to user (but you are not obliged to use the set/get
 * convention, just use every other two command). More details in iwpriv.c.
 * And I repeat : you are not forced to use them with iwpriv, but you
 * must be compliant with it.
 */

/* ------------------------- IOCTL STUFF ------------------------- */

/* The first and the last (range) */
#define SIOCIWFIRST 0x8B00
#define SIOCIWLAST  SIOCIWLASTPRIV      /* 0x8BFF */
#define IW_IOCTL_IDX(cmd)   ((cmd) - SIOCIWFIRST)
/* ----------------------- WIRELESS EVENTS ----------------------- */
/* Those are *NOT* ioctls, do not issue request on them !!! */
/* Most events use the same identifier as ioctl requests */

#define IWEVTXDROP  0x8C00      /* Packet dropped to excessive retry */
#define IWEVQUAL    0x8C01      /* Quality part of statistics (scan) */
#define IWEVCUSTOM  0x8C02      /* Driver specific ascii string */
#define IWEVREGISTERED  0x8C03      /* Discovered a new node (AP mode) */
#define IWEVEXPIRED 0x8C04      /* Expired a node (AP mode) */
#define IWEVGENIE   0x8C05      /* Generic IE (WPA, RSN, WMM, ..)
                     * (scan results); This includes id and
                     * length fields. One IWEVGENIE may
                     * contain more than one IE. Scan
                     * results may contain one or more
                     * IWEVGENIE events. */
#define IWEVMICHAELMICFAILURE 0x8C06    /* Michael MIC failure
                     * (struct iw_michaelmicfailure)
                     */
#define IWEVASSOCREQIE  0x8C07      /* IEs used in (Re)Association Request.
                     * The data includes id and length
                     * fields and may contain more than one
                     * IE. This event is required in
                     * Managed mode if the driver
                     * generates its own WPA/RSN IE. This
                     * should be sent just before
                     * IWEVREGISTERED event for the
                     * association. */
#define IWEVASSOCRESPIE 0x8C08      /* IEs used in (Re)Association
                     * Response. The data includes id and
                     * length fields and may contain more
                     * than one IE. This may be sent
                     * between IWEVASSOCREQIE and
                     * IWEVREGISTERED events for the
                     * association. */
#define IWEVPMKIDCAND   0x8C09      /* PMKID candidate for RSN
                     * pre-authentication
                     * (struct iw_pmkid_cand) */

#define IWEVFIRST   0x8C00
#define IW_EVENT_IDX(cmd)   ((cmd) - IWEVFIRST)

+ Recent posts