mirror of https://github.com/Qortal/Brooklyn
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
136 lines
4.7 KiB
136 lines
4.7 KiB
/* |
|
* Copyright Samuel Mendoza-Jonas, IBM Corporation 2018. |
|
* |
|
* This program is free software; you can redistribute it and/or modify |
|
* it under the terms of the GNU General Public License as published by |
|
* the Free Software Foundation; either version 2 of the License, or |
|
* (at your option) any later version. |
|
*/ |
|
|
|
#ifndef __UAPI_NCSI_NETLINK_H__ |
|
#define __UAPI_NCSI_NETLINK_H__ |
|
|
|
/** |
|
* enum ncsi_nl_commands - supported NCSI commands |
|
* |
|
* @NCSI_CMD_UNSPEC: unspecified command to catch errors |
|
* @NCSI_CMD_PKG_INFO: list package and channel attributes. Requires |
|
* NCSI_ATTR_IFINDEX. If NCSI_ATTR_PACKAGE_ID is specified returns the |
|
* specific package and its channels - otherwise a dump request returns |
|
* all packages and their associated channels. |
|
* @NCSI_CMD_SET_INTERFACE: set preferred package and channel combination. |
|
* Requires NCSI_ATTR_IFINDEX and the preferred NCSI_ATTR_PACKAGE_ID and |
|
* optionally the preferred NCSI_ATTR_CHANNEL_ID. |
|
* @NCSI_CMD_CLEAR_INTERFACE: clear any preferred package/channel combination. |
|
* Requires NCSI_ATTR_IFINDEX. |
|
* @NCSI_CMD_SEND_CMD: send NC-SI command to network card. |
|
* Requires NCSI_ATTR_IFINDEX, NCSI_ATTR_PACKAGE_ID |
|
* and NCSI_ATTR_CHANNEL_ID. |
|
* @NCSI_CMD_SET_PACKAGE_MASK: set a whitelist of allowed packages. |
|
* Requires NCSI_ATTR_IFINDEX and NCSI_ATTR_PACKAGE_MASK. |
|
* @NCSI_CMD_SET_CHANNEL_MASK: set a whitelist of allowed channels. |
|
* Requires NCSI_ATTR_IFINDEX, NCSI_ATTR_PACKAGE_ID, and |
|
* NCSI_ATTR_CHANNEL_MASK. If NCSI_ATTR_CHANNEL_ID is present it sets |
|
* the primary channel. |
|
* @NCSI_CMD_MAX: highest command number |
|
*/ |
|
enum ncsi_nl_commands { |
|
NCSI_CMD_UNSPEC, |
|
NCSI_CMD_PKG_INFO, |
|
NCSI_CMD_SET_INTERFACE, |
|
NCSI_CMD_CLEAR_INTERFACE, |
|
NCSI_CMD_SEND_CMD, |
|
NCSI_CMD_SET_PACKAGE_MASK, |
|
NCSI_CMD_SET_CHANNEL_MASK, |
|
|
|
__NCSI_CMD_AFTER_LAST, |
|
NCSI_CMD_MAX = __NCSI_CMD_AFTER_LAST - 1 |
|
}; |
|
|
|
/** |
|
* enum ncsi_nl_attrs - General NCSI netlink attributes |
|
* |
|
* @NCSI_ATTR_UNSPEC: unspecified attributes to catch errors |
|
* @NCSI_ATTR_IFINDEX: ifindex of network device using NCSI |
|
* @NCSI_ATTR_PACKAGE_LIST: nested array of NCSI_PKG_ATTR attributes |
|
* @NCSI_ATTR_PACKAGE_ID: package ID |
|
* @NCSI_ATTR_CHANNEL_ID: channel ID |
|
* @NCSI_ATTR_DATA: command payload |
|
* @NCSI_ATTR_MULTI_FLAG: flag to signal that multi-mode should be enabled with |
|
* NCSI_CMD_SET_PACKAGE_MASK or NCSI_CMD_SET_CHANNEL_MASK. |
|
* @NCSI_ATTR_PACKAGE_MASK: 32-bit mask of allowed packages. |
|
* @NCSI_ATTR_CHANNEL_MASK: 32-bit mask of allowed channels. |
|
* @NCSI_ATTR_MAX: highest attribute number |
|
*/ |
|
enum ncsi_nl_attrs { |
|
NCSI_ATTR_UNSPEC, |
|
NCSI_ATTR_IFINDEX, |
|
NCSI_ATTR_PACKAGE_LIST, |
|
NCSI_ATTR_PACKAGE_ID, |
|
NCSI_ATTR_CHANNEL_ID, |
|
NCSI_ATTR_DATA, |
|
NCSI_ATTR_MULTI_FLAG, |
|
NCSI_ATTR_PACKAGE_MASK, |
|
NCSI_ATTR_CHANNEL_MASK, |
|
|
|
__NCSI_ATTR_AFTER_LAST, |
|
NCSI_ATTR_MAX = __NCSI_ATTR_AFTER_LAST - 1 |
|
}; |
|
|
|
/** |
|
* enum ncsi_nl_pkg_attrs - NCSI netlink package-specific attributes |
|
* |
|
* @NCSI_PKG_ATTR_UNSPEC: unspecified attributes to catch errors |
|
* @NCSI_PKG_ATTR: nested array of package attributes |
|
* @NCSI_PKG_ATTR_ID: package ID |
|
* @NCSI_PKG_ATTR_FORCED: flag signifying a package has been set as preferred |
|
* @NCSI_PKG_ATTR_CHANNEL_LIST: nested array of NCSI_CHANNEL_ATTR attributes |
|
* @NCSI_PKG_ATTR_MAX: highest attribute number |
|
*/ |
|
enum ncsi_nl_pkg_attrs { |
|
NCSI_PKG_ATTR_UNSPEC, |
|
NCSI_PKG_ATTR, |
|
NCSI_PKG_ATTR_ID, |
|
NCSI_PKG_ATTR_FORCED, |
|
NCSI_PKG_ATTR_CHANNEL_LIST, |
|
|
|
__NCSI_PKG_ATTR_AFTER_LAST, |
|
NCSI_PKG_ATTR_MAX = __NCSI_PKG_ATTR_AFTER_LAST - 1 |
|
}; |
|
|
|
/** |
|
* enum ncsi_nl_channel_attrs - NCSI netlink channel-specific attributes |
|
* |
|
* @NCSI_CHANNEL_ATTR_UNSPEC: unspecified attributes to catch errors |
|
* @NCSI_CHANNEL_ATTR: nested array of channel attributes |
|
* @NCSI_CHANNEL_ATTR_ID: channel ID |
|
* @NCSI_CHANNEL_ATTR_VERSION_MAJOR: channel major version number |
|
* @NCSI_CHANNEL_ATTR_VERSION_MINOR: channel minor version number |
|
* @NCSI_CHANNEL_ATTR_VERSION_STR: channel version string |
|
* @NCSI_CHANNEL_ATTR_LINK_STATE: channel link state flags |
|
* @NCSI_CHANNEL_ATTR_ACTIVE: channels with this flag are in |
|
* NCSI_CHANNEL_ACTIVE state |
|
* @NCSI_CHANNEL_ATTR_FORCED: flag signifying a channel has been set as |
|
* preferred |
|
* @NCSI_CHANNEL_ATTR_VLAN_LIST: nested array of NCSI_CHANNEL_ATTR_VLAN_IDs |
|
* @NCSI_CHANNEL_ATTR_VLAN_ID: VLAN ID being filtered on this channel |
|
* @NCSI_CHANNEL_ATTR_MAX: highest attribute number |
|
*/ |
|
enum ncsi_nl_channel_attrs { |
|
NCSI_CHANNEL_ATTR_UNSPEC, |
|
NCSI_CHANNEL_ATTR, |
|
NCSI_CHANNEL_ATTR_ID, |
|
NCSI_CHANNEL_ATTR_VERSION_MAJOR, |
|
NCSI_CHANNEL_ATTR_VERSION_MINOR, |
|
NCSI_CHANNEL_ATTR_VERSION_STR, |
|
NCSI_CHANNEL_ATTR_LINK_STATE, |
|
NCSI_CHANNEL_ATTR_ACTIVE, |
|
NCSI_CHANNEL_ATTR_FORCED, |
|
NCSI_CHANNEL_ATTR_VLAN_LIST, |
|
NCSI_CHANNEL_ATTR_VLAN_ID, |
|
|
|
__NCSI_CHANNEL_ATTR_AFTER_LAST, |
|
NCSI_CHANNEL_ATTR_MAX = __NCSI_CHANNEL_ATTR_AFTER_LAST - 1 |
|
}; |
|
|
|
#endif /* __UAPI_NCSI_NETLINK_H__ */
|
|
|