| 
									
										
										
										
											2008-12-20 16:57:33 -08:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * 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 | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2009-05-22 00:41:11 -07:00
										 |  |  | 	WIMAX_GNL_VERSION = 01, | 
					
						
							| 
									
										
										
										
											2008-12-20 16:57:33 -08:00
										 |  |  | 	/* 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 */ | 
					
						
							| 
									
										
										
										
											2009-05-13 06:20:29 -07:00
										 |  |  | 	WIMAX_GNL_OP_STATE_GET,		/* Request for current state */ | 
					
						
							| 
									
										
										
										
											2008-12-20 16:57:33 -08:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 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, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-30 22:57:33 -03:00
										 |  |  | /* Attributes for wimax_state_get() */ | 
					
						
							| 
									
										
										
										
											2009-05-13 06:20:29 -07:00
										 |  |  | enum { | 
					
						
							|  |  |  | 	WIMAX_GNL_STGET_IFIDX = 1, | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2008-12-20 16:57:33 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * 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__ */
 |