Commit f392a184 authored by Russell King (Oracle)'s avatar Russell King (Oracle) Committed by David S. Miller

net: phylink: provide phylink_validate_mask_caps() helper

Provide a helper that restricts the link modes according to the
phylink capabilities.
Signed-off-by: default avatarRussell King (Oracle) <rmk+kernel@armlinux.org.uk>
[rebased on net-next/master and added documentation]
Signed-off-by: default avatarSean Anderson <sean.anderson@seco.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 045d0501
...@@ -562,31 +562,48 @@ unsigned long phylink_get_capabilities(phy_interface_t interface, ...@@ -562,31 +562,48 @@ unsigned long phylink_get_capabilities(phy_interface_t interface,
EXPORT_SYMBOL_GPL(phylink_get_capabilities); EXPORT_SYMBOL_GPL(phylink_get_capabilities);
/** /**
* phylink_generic_validate() - generic validate() callback implementation * phylink_validate_mask_caps() - Restrict link modes based on caps
* @config: a pointer to a &struct phylink_config.
* @supported: ethtool bitmask for supported link modes. * @supported: ethtool bitmask for supported link modes.
* @state: a pointer to a &struct phylink_link_state. * @state: an (optional) pointer to a &struct phylink_link_state.
* @mac_capabilities: bitmask of MAC capabilities
* *
* Generic implementation of the validate() callback that MAC drivers can * Calculate the supported link modes based on @mac_capabilities, and restrict
* use when they pass the range of supported interfaces and MAC capabilities. * @supported and @state based on that. Use this function if your capabiliies
* This makes use of phylink_get_linkmodes(). * aren't constant, such as if they vary depending on the interface.
*/ */
void phylink_generic_validate(struct phylink_config *config, void phylink_validate_mask_caps(unsigned long *supported,
unsigned long *supported, struct phylink_link_state *state,
struct phylink_link_state *state) unsigned long mac_capabilities)
{ {
__ETHTOOL_DECLARE_LINK_MODE_MASK(mask) = { 0, }; __ETHTOOL_DECLARE_LINK_MODE_MASK(mask) = { 0, };
unsigned long caps; unsigned long caps;
phylink_set_port_modes(mask); phylink_set_port_modes(mask);
phylink_set(mask, Autoneg); phylink_set(mask, Autoneg);
caps = phylink_get_capabilities(state->interface, caps = phylink_get_capabilities(state->interface, mac_capabilities,
config->mac_capabilities,
state->rate_matching); state->rate_matching);
phylink_caps_to_linkmodes(mask, caps); phylink_caps_to_linkmodes(mask, caps);
linkmode_and(supported, supported, mask); linkmode_and(supported, supported, mask);
linkmode_and(state->advertising, state->advertising, mask); if (state)
linkmode_and(state->advertising, state->advertising, mask);
}
EXPORT_SYMBOL_GPL(phylink_validate_mask_caps);
/**
* phylink_generic_validate() - generic validate() callback implementation
* @config: a pointer to a &struct phylink_config.
* @supported: ethtool bitmask for supported link modes.
* @state: a pointer to a &struct phylink_link_state.
*
* Generic implementation of the validate() callback that MAC drivers can
* use when they pass the range of supported interfaces and MAC capabilities.
*/
void phylink_generic_validate(struct phylink_config *config,
unsigned long *supported,
struct phylink_link_state *state)
{
phylink_validate_mask_caps(supported, state, config->mac_capabilities);
} }
EXPORT_SYMBOL_GPL(phylink_generic_validate); EXPORT_SYMBOL_GPL(phylink_generic_validate);
......
...@@ -556,6 +556,9 @@ void phylink_caps_to_linkmodes(unsigned long *linkmodes, unsigned long caps); ...@@ -556,6 +556,9 @@ void phylink_caps_to_linkmodes(unsigned long *linkmodes, unsigned long caps);
unsigned long phylink_get_capabilities(phy_interface_t interface, unsigned long phylink_get_capabilities(phy_interface_t interface,
unsigned long mac_capabilities, unsigned long mac_capabilities,
int rate_matching); int rate_matching);
void phylink_validate_mask_caps(unsigned long *supported,
struct phylink_link_state *state,
unsigned long caps);
void phylink_generic_validate(struct phylink_config *config, void phylink_generic_validate(struct phylink_config *config,
unsigned long *supported, unsigned long *supported,
struct phylink_link_state *state); struct phylink_link_state *state);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment