2008-12-21 03:57:33 +03: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 11:41:11 +04:00
|
|
|
WIMAX_GNL_VERSION = 01,
|
2008-12-21 03:57:33 +03: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 17:20:29 +04:00
|
|
|
WIMAX_GNL_OP_STATE_GET, /* Request for current state */
|
2008-12-21 03:57:33 +03: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,
|
|
|
|
};
|
|
|
|
|
2009-05-13 17:20:29 +04:00
|
|
|
/* Atributes for wimax_state_get() */
|
|
|
|
enum {
|
|
|
|
WIMAX_GNL_STGET_IFIDX = 1,
|
|
|
|
};
|
2008-12-21 03:57:33 +03: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__ */
|