diff options
Diffstat (limited to 'include/uapi/linux/wimax.h')
| -rw-r--r-- | include/uapi/linux/wimax.h | 239 | 
1 files changed, 239 insertions, 0 deletions
diff --git a/include/uapi/linux/wimax.h b/include/uapi/linux/wimax.h new file mode 100644 index 00000000000..9f6b77af2f6 --- /dev/null +++ b/include/uapi/linux/wimax.h @@ -0,0 +1,239 @@ +/* + * Linux WiMax + * API for user space + * + * + * Copyright (C) 2007-2008 Intel Corporation. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + *   * Redistributions of source code must retain the above copyright + *     notice, this list of conditions and the following disclaimer. + *   * Redistributions in binary form must reproduce the above copyright + *     notice, this list of conditions and the following disclaimer in + *     the documentation and/or other materials provided with the + *     distribution. + *   * Neither the name of Intel Corporation nor the names of its + *     contributors may be used to endorse or promote products derived + *     from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + * + * + * Intel Corporation <linux-wimax@intel.com> + * Inaky Perez-Gonzalez <inaky.perez-gonzalez@intel.com> + *  - Initial implementation + * + * + * This file declares the user/kernel protocol that is spoken over + * Generic Netlink, as well as any type declaration that is to be used + * by kernel and user space. + * + * It is intended for user space to clone it verbatim to use it as a + * primary reference for definitions. + * + * Stuff intended for kernel usage as well as full protocol and stack + * documentation is rooted in include/net/wimax.h. + */ + +#ifndef __LINUX__WIMAX_H__ +#define __LINUX__WIMAX_H__ + +#include <linux/types.h> + +enum { +	/** +	 * Version of the interface (unsigned decimal, MMm, max 25.5) +	 * M - Major: change if removing or modifying an existing call. +	 * m - minor: change when adding a new call +	 */ +	WIMAX_GNL_VERSION = 01, +	/* Generic NetLink attributes */ +	WIMAX_GNL_ATTR_INVALID = 0x00, +	WIMAX_GNL_ATTR_MAX = 10, +}; + + +/* + * Generic NetLink operations + * + * Most of these map to an API call; _OP_ stands for operation, _RP_ + * for reply and _RE_ for report (aka: signal). + */ +enum { +	WIMAX_GNL_OP_MSG_FROM_USER,	/* User to kernel message */ +	WIMAX_GNL_OP_MSG_TO_USER,	/* Kernel to user message */ +	WIMAX_GNL_OP_RFKILL,	/* Run wimax_rfkill() */ +	WIMAX_GNL_OP_RESET,	/* Run wimax_rfkill() */ +	WIMAX_GNL_RE_STATE_CHANGE,	/* Report: status change */ +	WIMAX_GNL_OP_STATE_GET,		/* Request for current state */ +}; + + +/* Message from user / to user */ +enum { +	WIMAX_GNL_MSG_IFIDX = 1, +	WIMAX_GNL_MSG_PIPE_NAME, +	WIMAX_GNL_MSG_DATA, +}; + + +/* + * wimax_rfkill() + * + * The state of the radio (ON/OFF) is mapped to the rfkill subsystem's + * switch state (DISABLED/ENABLED). + */ +enum wimax_rf_state { +	WIMAX_RF_OFF = 0,	/* Radio is off, rfkill on/enabled */ +	WIMAX_RF_ON = 1,	/* Radio is on, rfkill off/disabled */ +	WIMAX_RF_QUERY = 2, +}; + +/* Attributes */ +enum { +	WIMAX_GNL_RFKILL_IFIDX = 1, +	WIMAX_GNL_RFKILL_STATE, +}; + + +/* Attributes for wimax_reset() */ +enum { +	WIMAX_GNL_RESET_IFIDX = 1, +}; + +/* Attributes for wimax_state_get() */ +enum { +	WIMAX_GNL_STGET_IFIDX = 1, +}; + +/* + * Attributes for the Report State Change + * + * For now we just have the old and new states; new attributes might + * be added later on. + */ +enum { +	WIMAX_GNL_STCH_IFIDX = 1, +	WIMAX_GNL_STCH_STATE_OLD, +	WIMAX_GNL_STCH_STATE_NEW, +}; + + +/** + * enum wimax_st - The different states of a WiMAX device + * @__WIMAX_ST_NULL: The device structure has been allocated and zeroed, + *     but still wimax_dev_add() hasn't been called. There is no state. + * + * @WIMAX_ST_DOWN: The device has been registered with the WiMAX and + *     networking stacks, but it is not initialized (normally that is + *     done with 'ifconfig DEV up' [or equivalent], which can upload + *     firmware and enable communications with the device). + *     In this state, the device is powered down and using as less + *     power as possible. + *     This state is the default after a call to wimax_dev_add(). It + *     is ok to have drivers move directly to %WIMAX_ST_UNINITIALIZED + *     or %WIMAX_ST_RADIO_OFF in _probe() after the call to + *     wimax_dev_add(). + *     It is recommended that the driver leaves this state when + *     calling 'ifconfig DEV up' and enters it back on 'ifconfig DEV + *     down'. + * + * @__WIMAX_ST_QUIESCING: The device is being torn down, so no API + *     operations are allowed to proceed except the ones needed to + *     complete the device clean up process. + * + * @WIMAX_ST_UNINITIALIZED: [optional] Communication with the device + *     is setup, but the device still requires some configuration + *     before being operational. + *     Some WiMAX API calls might work. + * + * @WIMAX_ST_RADIO_OFF: The device is fully up; radio is off (wether + *     by hardware or software switches). + *     It is recommended to always leave the device in this state + *     after initialization. + * + * @WIMAX_ST_READY: The device is fully up and radio is on. + * + * @WIMAX_ST_SCANNING: [optional] The device has been instructed to + *     scan. In this state, the device cannot be actively connected to + *     a network. + * + * @WIMAX_ST_CONNECTING: The device is connecting to a network. This + *     state exists because in some devices, the connect process can + *     include a number of negotiations between user space, kernel + *     space and the device. User space needs to know what the device + *     is doing. If the connect sequence in a device is atomic and + *     fast, the device can transition directly to CONNECTED + * + * @WIMAX_ST_CONNECTED: The device is connected to a network. + * + * @__WIMAX_ST_INVALID: This is an invalid state used to mark the + *     maximum numeric value of states. + * + * Description: + * + * Transitions from one state to another one are atomic and can only + * be caused in kernel space with wimax_state_change(). To read the + * state, use wimax_state_get(). + * + * States starting with __ are internal and shall not be used or + * referred to by drivers or userspace. They look ugly, but that's the + * point -- if any use is made non-internal to the stack, it is easier + * to catch on review. + * + * All API operations [with well defined exceptions] will take the + * device mutex before starting and then check the state. If the state + * is %__WIMAX_ST_NULL, %WIMAX_ST_DOWN, %WIMAX_ST_UNINITIALIZED or + * %__WIMAX_ST_QUIESCING, it will drop the lock and quit with + * -%EINVAL, -%ENOMEDIUM, -%ENOTCONN or -%ESHUTDOWN. + * + * The order of the definitions is important, so we can do numerical + * comparisons (eg: < %WIMAX_ST_RADIO_OFF means the device is not ready + * to operate). + */ +/* + * The allowed state transitions are described in the table below + * (states in rows can go to states in columns where there is an X): + * + *                                  UNINI   RADIO READY SCAN CONNEC CONNEC + *             NULL DOWN QUIESCING TIALIZED  OFF        NING  TING   TED + * NULL         -    x + * DOWN              -      x        x       x + * QUIESCING         x      - + * UNINITIALIZED            x        -       x + * RADIO_OFF                x                -     x + * READY                    x                x     -     x     x      x + * SCANNING                 x                x     x     -     x      x + * CONNECTING               x                x     x     x     -      x + * CONNECTED                x                x     x                  - + * + * This table not available in kernel-doc because the formatting messes it up. + */ + enum wimax_st { +	__WIMAX_ST_NULL = 0, +	WIMAX_ST_DOWN, +	__WIMAX_ST_QUIESCING, +	WIMAX_ST_UNINITIALIZED, +	WIMAX_ST_RADIO_OFF, +	WIMAX_ST_READY, +	WIMAX_ST_SCANNING, +	WIMAX_ST_CONNECTING, +	WIMAX_ST_CONNECTED, +	__WIMAX_ST_INVALID			/* Always keep last */ +}; + + +#endif /* #ifndef __LINUX__WIMAX_H__ */  |