| /* |
| * 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__ */ |