Re: [PATCH] net: rocker: use new api ethtool_{get|set}_link_ksettings

2017-03-06 Thread David Miller
From: Philippe Reynes 
Date: Sun, 26 Feb 2017 19:00:29 +0100

> The ethtool api {get|set}_settings is deprecated.
> We move this driver to new api {get|set}_link_ksettings.
> 
> As I don't have the hardware, I'd be very pleased if
> someone may test this patch.
> 
> Signed-off-by: Philippe Reynes 

Applied.


[PATCH] net: rocker: use new api ethtool_{get|set}_link_ksettings

2017-02-26 Thread Philippe Reynes
The ethtool api {get|set}_settings is deprecated.
We move this driver to new api {get|set}_link_ksettings.

As I don't have the hardware, I'd be very pleased if
someone may test this patch.

Signed-off-by: Philippe Reynes 
---
 drivers/net/ethernet/rocker/rocker_main.c |   55 +
 1 files changed, 32 insertions(+), 23 deletions(-)

diff --git a/drivers/net/ethernet/rocker/rocker_main.c 
b/drivers/net/ethernet/rocker/rocker_main.c
index 0f63a44..b712ec2 100644
--- a/drivers/net/ethernet/rocker/rocker_main.c
+++ b/drivers/net/ethernet/rocker/rocker_main.c
@@ -1115,7 +1115,7 @@ int rocker_cmd_exec(struct rocker_port *rocker_port, bool 
nowait,
  const struct rocker_desc_info 
*desc_info,
  void *priv)
 {
-   struct ethtool_cmd *ecmd = priv;
+   struct ethtool_link_ksettings *ecmd = priv;
const struct rocker_tlv *attrs[ROCKER_TLV_CMD_MAX + 1];
const struct rocker_tlv *info_attrs[ROCKER_TLV_CMD_PORT_SETTINGS_MAX + 
1];
u32 speed;
@@ -1137,13 +1137,14 @@ int rocker_cmd_exec(struct rocker_port *rocker_port, 
bool nowait,
duplex = 
rocker_tlv_get_u8(info_attrs[ROCKER_TLV_CMD_PORT_SETTINGS_DUPLEX]);
autoneg = 
rocker_tlv_get_u8(info_attrs[ROCKER_TLV_CMD_PORT_SETTINGS_AUTONEG]);
 
-   ecmd->transceiver = XCVR_INTERNAL;
-   ecmd->supported = SUPPORTED_TP;
-   ecmd->phy_address = 0xff;
-   ecmd->port = PORT_TP;
-   ethtool_cmd_speed_set(ecmd, speed);
-   ecmd->duplex = duplex ? DUPLEX_FULL : DUPLEX_HALF;
-   ecmd->autoneg = autoneg ? AUTONEG_ENABLE : AUTONEG_DISABLE;
+   ethtool_link_ksettings_zero_link_mode(ecmd, supported);
+   ethtool_link_ksettings_add_link_mode(ecmd, supported, TP);
+
+   ecmd->base.phy_address = 0xff;
+   ecmd->base.port = PORT_TP;
+   ecmd->base.speed = speed;
+   ecmd->base.duplex = duplex ? DUPLEX_FULL : DUPLEX_HALF;
+   ecmd->base.autoneg = autoneg ? AUTONEG_ENABLE : AUTONEG_DISABLE;
 
return 0;
 }
@@ -1250,7 +1251,7 @@ struct port_name {
  struct rocker_desc_info *desc_info,
  void *priv)
 {
-   struct ethtool_cmd *ecmd = priv;
+   struct ethtool_link_ksettings *ecmd = priv;
struct rocker_tlv *cmd_info;
 
if (rocker_tlv_put_u16(desc_info, ROCKER_TLV_CMD_TYPE,
@@ -1263,13 +1264,13 @@ struct port_name {
   rocker_port->pport))
return -EMSGSIZE;
if (rocker_tlv_put_u32(desc_info, ROCKER_TLV_CMD_PORT_SETTINGS_SPEED,
-  ethtool_cmd_speed(ecmd)))
+  ecmd->base.speed))
return -EMSGSIZE;
if (rocker_tlv_put_u8(desc_info, ROCKER_TLV_CMD_PORT_SETTINGS_DUPLEX,
- ecmd->duplex))
+ ecmd->base.duplex))
return -EMSGSIZE;
if (rocker_tlv_put_u8(desc_info, ROCKER_TLV_CMD_PORT_SETTINGS_AUTONEG,
- ecmd->autoneg))
+ ecmd->base.autoneg))
return -EMSGSIZE;
rocker_tlv_nest_end(desc_info, cmd_info);
return 0;
@@ -1347,8 +1348,9 @@ struct port_name {
return 0;
 }
 
-static int rocker_cmd_get_port_settings_ethtool(struct rocker_port 
*rocker_port,
-   struct ethtool_cmd *ecmd)
+static int
+rocker_cmd_get_port_settings_ethtool(struct rocker_port *rocker_port,
+struct ethtool_link_ksettings *ecmd)
 {
return rocker_cmd_exec(rocker_port, false,
   rocker_cmd_get_port_settings_prep, NULL,
@@ -1373,12 +1375,17 @@ static int rocker_cmd_get_port_settings_mode(struct 
rocker_port *rocker_port,
   rocker_cmd_get_port_settings_mode_proc, p_mode);
 }
 
-static int rocker_cmd_set_port_settings_ethtool(struct rocker_port 
*rocker_port,
-   struct ethtool_cmd *ecmd)
+static int
+rocker_cmd_set_port_settings_ethtool(struct rocker_port *rocker_port,
+const struct ethtool_link_ksettings *ecmd)
 {
+   struct ethtool_link_ksettings copy_ecmd;
+
+   memcpy(©_ecmd, ecmd, sizeof(copy_ecmd));
+
return rocker_cmd_exec(rocker_port, false,
   rocker_cmd_set_port_settings_ethtool_prep,
-  ecmd, NULL, NULL);
+  ©_ecmd, NULL, NULL);
 }
 
 static int rocker_cmd_set_port_settings_macaddr(struct rocker_port 
*rocker_port,
@@ -2237,16 +2244,18 @@ static int rocker_router_fib_event(struct 
notifier_block *nb,
  * ethtool interface
  /
 
-static int rocker_port_get_settings(struct net_device *dev,
-   struct ethtool_cmd *ecmd)
+static int
+rocker_port_get_link_ksetting