[2.6.19 PATCH 4/7] ehea: ethtool interface

2006-09-06 Thread Jan-Bernd Themann
Signed-off-by: Jan-Bernd Themann [EMAIL PROTECTED] 


 drivers/net/ehea/ehea_ethtool.c |  294 
 1 file changed, 294 insertions(+)



--- linux-2.6.18-rc6-orig/drivers/net/ehea/ehea_ethtool.c   1970-01-01 
01:00:00.0 +0100
+++ kernel/drivers/net/ehea/ehea_ethtool.c  2006-09-06 15:53:43.0 
+0200
@@ -0,0 +1,294 @@
+/*
+ *  linux/drivers/net/ehea/ehea_ethtool.c
+ *
+ *  eHEA ethernet device driver for IBM eServer System p
+ *
+ *  (C) Copyright IBM Corp. 2006
+ *
+ *  Authors:
+ *   Christoph Raisch [EMAIL PROTECTED]
+ *   Jan-Bernd Themann [EMAIL PROTECTED]
+ *   Thomas Klein [EMAIL PROTECTED]
+ *
+ *
+ * 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, or (at your option)
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#include ehea.h
+#include ehea_phyp.h
+
+static int ehea_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
+{
+   struct ehea_port *port = netdev_priv(dev);
+   int ret;
+
+   ret = ehea_sense_port_attr(port);
+
+   if (ret)
+   return ret;
+
+   if (netif_carrier_ok(dev)) {
+   switch(port-port_speed) {
+   case EHEA_SPEED_10M: cmd-speed = SPEED_10; break;
+   case EHEA_SPEED_100M: cmd-speed = SPEED_100; break;
+   case EHEA_SPEED_1G: cmd-speed = SPEED_1000; break;
+   case EHEA_SPEED_10G: cmd-speed = SPEED_1; break;
+   }
+   cmd-duplex = port-full_duplex == 1 ?
+DUPLEX_FULL : DUPLEX_HALF;
+   } else {
+   cmd-speed = -1;
+   cmd-duplex = -1;
+   }
+
+   cmd-supported = (SUPPORTED_1baseT_Full | SUPPORTED_1000baseT_Full
+  | SUPPORTED_100baseT_Full |  SUPPORTED_100baseT_Half
+  | SUPPORTED_10baseT_Full | SUPPORTED_10baseT_Half
+  | SUPPORTED_Autoneg | SUPPORTED_FIBRE);
+
+   cmd-advertising = (ADVERTISED_1baseT_Full | ADVERTISED_Autoneg
+| ADVERTISED_FIBRE);
+
+   cmd-port = PORT_FIBRE;
+   cmd-autoneg = port-autoneg == 1 ? AUTONEG_ENABLE : AUTONEG_DISABLE;
+
+   return 0;
+}
+
+static int ehea_set_settings(struct net_device *dev, struct ethtool_cmd *cmd)
+{
+   struct ehea_port *port = netdev_priv(dev);
+   int ret = 0;
+   u32 sp;
+
+   if (cmd-autoneg == AUTONEG_ENABLE) {
+   sp = EHEA_SPEED_AUTONEG;
+   goto doit;
+   }
+
+   switch(cmd-speed) {
+   case SPEED_10:
+   if (cmd-duplex == DUPLEX_FULL)
+   sp = H_SPEED_10M_F;
+   else
+   sp = H_SPEED_10M_H;
+   break;
+
+   case SPEED_100:
+   if (cmd-duplex == DUPLEX_FULL)
+   sp = H_SPEED_100M_F;
+   else
+   sp = H_SPEED_100M_H;
+   break;
+
+   case SPEED_1000:
+   if (cmd-duplex == DUPLEX_FULL)
+   sp = H_SPEED_1G_F;
+   else
+   ret = -EINVAL;
+   break;
+
+   case SPEED_1:
+   if (cmd-duplex == DUPLEX_FULL)
+   sp = H_SPEED_10G_F;
+   else
+   ret = -EINVAL;
+   break;
+
+   default:
+   ret = -EINVAL;
+   break;
+   }
+
+   if (ret)
+   goto out;
+doit:
+   ret = ehea_set_portspeed(port, sp);
+
+   if (!ret)
+   ehea_info(%s: Port speed succesfully set: %dMbps 
+ %s Duplex,
+ port-netdev-name, port-port_speed,
+ port-full_duplex == 1 ? Full : Half);
+out:
+   return ret;
+}
+
+static int ehea_nway_reset(struct net_device *dev)
+{
+   struct ehea_port *port = netdev_priv(dev);
+   int ret;
+
+   ret = ehea_set_portspeed(port, EHEA_SPEED_AUTONEG);
+
+   if (!ret)
+   ehea_info(%s: Port speed succesfully set: %dMbps 
+ %s Duplex,
+ port-netdev-name, port-port_speed,
+ port-full_duplex == 1 ? Full : Half);
+   return ret;
+}
+
+static void ehea_get_drvinfo(struct net_device *dev,
+  struct ethtool_drvinfo *info)
+{
+

[2.6.19 PATCH 4/7] ehea: ethtool interface

2006-08-23 Thread Jan-Bernd Themann
Signed-off-by: Jan-Bernd Themann [EMAIL PROTECTED] 


 drivers/net/ehea/ehea_ethtool.c |  244 
 1 file changed, 244 insertions(+)



--- linux-2.6.18-rc4-git1-orig/drivers/net/ehea/ehea_ethtool.c  1969-12-31 
16:00:00.0 -0800
+++ kernel/drivers/net/ehea/ehea_ethtool.c  2006-08-23 02:01:00.363230269 
-0700
@@ -0,0 +1,244 @@
+/*
+ *  linux/drivers/net/ehea/ehea_ethtool.c
+ *
+ *  eHEA ethernet device driver for IBM eServer System p
+ *
+ *  (C) Copyright IBM Corp. 2006
+ *
+ *  Authors:
+ *   Christoph Raisch [EMAIL PROTECTED]
+ *   Jan-Bernd Themann [EMAIL PROTECTED]
+ *   Thomas Klein [EMAIL PROTECTED]
+ *
+ *
+ * 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, or (at your option)
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#include ehea.h
+#include ehea_phyp.h
+
+
+static int netdev_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
+{
+   u64 hret;
+   struct ehea_port *port = netdev_priv(dev);
+   struct ehea_adapter *adapter = port-adapter;
+   struct hcp_ehea_port_cb4 *cb4;
+
+   cb4 = kzalloc(H_CB_ALIGNMENT, GFP_KERNEL);
+   if (!cb4) {
+   ehea_error(no mem for cb4);
+   return -ENOMEM;
+   }
+
+   hret = ehea_h_query_ehea_port(adapter-handle, port-logical_port_id,
+ H_PORT_CB4, H_PORT_CB4_ALL, cb4);
+   if (hret != H_SUCCESS) {
+   ehea_error(query_ehea_port failed);
+   kfree(cb4);
+   return -EIO;
+   }
+
+   if (netif_msg_hw(port))
+   ehea_dump(cb4, sizeof(*cb4), netdev_get_settings);
+
+   if (netif_carrier_ok(dev)) {
+   switch(cb4-port_speed){
+   case H_PORT_SPEED_10M_H:
+   cmd-speed = SPEED_10;
+   cmd-duplex = DUPLEX_HALF;
+   break;
+   case H_PORT_SPEED_10M_F:
+   cmd-speed = SPEED_10;
+   cmd-duplex = DUPLEX_FULL;
+   break;
+   case H_PORT_SPEED_100M_H:
+   cmd-speed = SPEED_100;
+   cmd-duplex = DUPLEX_HALF;
+   break;
+   case H_PORT_SPEED_100M_F:
+   cmd-speed = SPEED_100;
+   cmd-duplex = DUPLEX_FULL;
+   break;
+   case H_PORT_SPEED_1G_F:
+   cmd-speed = SPEED_1000;
+   cmd-duplex = DUPLEX_FULL;
+   break;
+   case H_PORT_SPEED_10G_F:
+   cmd-speed = SPEED_1;
+   cmd-duplex = DUPLEX_FULL;
+   break;
+   }
+   } else {
+   cmd-speed = -1;
+   cmd-duplex = -1;
+   }
+
+   cmd-supported = (SUPPORTED_1baseT_Full | SUPPORTED_1000baseT_Full
+  | SUPPORTED_100baseT_Full |  SUPPORTED_100baseT_Half
+  | SUPPORTED_10baseT_Full | SUPPORTED_10baseT_Half
+  | SUPPORTED_Autoneg | SUPPORTED_FIBRE);
+
+   cmd-advertising = (ADVERTISED_1baseT_Full | ADVERTISED_Autoneg
+| ADVERTISED_FIBRE);
+
+   cmd-port = PORT_FIBRE;
+   cmd-autoneg = AUTONEG_ENABLE;
+
+   kfree(cb4);
+   return 0;
+}
+
+static void netdev_get_drvinfo(struct net_device *dev,
+  struct ethtool_drvinfo *info)
+{
+   strlcpy(info-driver, DRV_NAME, sizeof(info-driver) - 1);
+   strlcpy(info-version, DRV_VERSION, sizeof(info-version) - 1);
+}
+
+static u32 netdev_get_msglevel(struct net_device *dev)
+{
+   struct ehea_port *port = netdev_priv(dev);
+   return port-msg_enable;
+}
+
+static void netdev_set_msglevel(struct net_device *dev, u32 value)
+{
+   struct ehea_port *port = netdev_priv(dev);
+   port-msg_enable = value;
+}
+
+static char ehea_ethtool_stats_keys[][ETH_GSTRING_LEN] = {
+   {poll_max_processed},
+   {queue_stopped},
+   {min_swqe_avail},
+   {poll_receive_err},
+   {pkt_send},
+   {pkt_xmit},
+   {send_tasklet},
+   {ehea_poll},
+   {nwqe},
+   {swqe_available_0},
+   {sig_comp_iv},
+   {rxo},
+   {rx64},
+   {rx65},
+   {rx128},
+   {rx256},
+   {rx512},
+   {rx1024},
+   {txo},
+  

[2.6.19 PATCH 4/7] ehea: ethtool interface

2006-08-22 Thread Jan-Bernd Themann
Signed-off-by: Jan-Bernd Themann [EMAIL PROTECTED] 


 drivers/net/ehea/ehea_ethtool.c |  244 
 1 file changed, 244 insertions(+)



--- linux-2.6.18-rc4-git1-orig/drivers/net/ehea/ehea_ethtool.c  1969-12-31 
16:00:00.0 -0800
+++ kernel/drivers/net/ehea/ehea_ethtool.c  2006-08-22 06:05:29.197373636 
-0700
@@ -0,0 +1,244 @@
+/*
+ *  linux/drivers/net/ehea/ehea_ethtool.c
+ *
+ *  eHEA ethernet device driver for IBM eServer System p
+ *
+ *  (C) Copyright IBM Corp. 2006
+ *
+ *  Authors:
+ *   Christoph Raisch [EMAIL PROTECTED]
+ *   Jan-Bernd Themann [EMAIL PROTECTED]
+ *   Thomas Klein [EMAIL PROTECTED]
+ *
+ *
+ * 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, or (at your option)
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#include ehea.h
+#include ehea_phyp.h
+
+
+static int netdev_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
+{
+   u64 hret;
+   struct ehea_port *port = netdev_priv(dev);
+   struct ehea_adapter *adapter = port-adapter;
+   struct hcp_ehea_port_cb4 *cb4;
+
+   cb4 = kzalloc(H_CB_ALIGNMENT, GFP_KERNEL);
+   if (!cb4) {
+   ehea_error(no mem for cb4);
+   return -ENOMEM;
+   }
+
+   hret = ehea_h_query_ehea_port(adapter-handle, port-logical_port_id,
+ H_PORT_CB4, H_PORT_CB4_ALL, cb4);
+   if (hret != H_SUCCESS) {
+   ehea_error(query_ehea_port failed);
+   kfree(cb4);
+   return -EIO;
+   }
+
+   if (netif_msg_hw(port))
+   ehea_dump(cb4, sizeof(*cb4), netdev_get_settings);
+
+   if (netif_carrier_ok(dev)) {
+   switch(cb4-port_speed){
+   case H_PORT_SPEED_10M_H:
+   cmd-speed = SPEED_10;
+   cmd-duplex = DUPLEX_HALF;
+   break;
+   case H_PORT_SPEED_10M_F:
+   cmd-speed = SPEED_10;
+   cmd-duplex = DUPLEX_FULL;
+   break;
+   case H_PORT_SPEED_100M_H:
+   cmd-speed = SPEED_100;
+   cmd-duplex = DUPLEX_HALF;
+   break;
+   case H_PORT_SPEED_100M_F:
+   cmd-speed = SPEED_100;
+   cmd-duplex = DUPLEX_FULL;
+   break;
+   case H_PORT_SPEED_1G_F:
+   cmd-speed = SPEED_1000;
+   cmd-duplex = DUPLEX_FULL;
+   break;
+   case H_PORT_SPEED_10G_F:
+   cmd-speed = SPEED_1;
+   cmd-duplex = DUPLEX_FULL;
+   break;
+   }
+   } else {
+   cmd-speed = -1;
+   cmd-duplex = -1;
+   }
+
+   cmd-supported = (SUPPORTED_1baseT_Full | SUPPORTED_1000baseT_Full
+  | SUPPORTED_100baseT_Full |  SUPPORTED_100baseT_Half
+  | SUPPORTED_10baseT_Full | SUPPORTED_10baseT_Half
+  | SUPPORTED_Autoneg | SUPPORTED_FIBRE);
+
+   cmd-advertising = (ADVERTISED_1baseT_Full | ADVERTISED_Autoneg
+| ADVERTISED_FIBRE);
+
+   cmd-port = PORT_FIBRE;
+   cmd-autoneg = AUTONEG_ENABLE;
+
+   kfree(cb4);
+   return 0;
+}
+
+static void netdev_get_drvinfo(struct net_device *dev,
+  struct ethtool_drvinfo *info)
+{
+   strlcpy(info-driver, DRV_NAME, sizeof(info-driver) - 1);
+   strlcpy(info-version, DRV_VERSION, sizeof(info-version) - 1);
+}
+
+static u32 netdev_get_msglevel(struct net_device *dev)
+{
+   struct ehea_port *port = netdev_priv(dev);
+   return port-msg_enable;
+}
+
+static void netdev_set_msglevel(struct net_device *dev, u32 value)
+{
+   struct ehea_port *port = netdev_priv(dev);
+   port-msg_enable = value;
+}
+
+static char ehea_ethtool_stats_keys[][ETH_GSTRING_LEN] = {
+   {poll_max_processed},
+   {queue_stopped},
+   {min_swqe_avail},
+   {poll_receive_err},
+   {pkt_send},
+   {pkt_xmit},
+   {send_tasklet},
+   {ehea_poll},
+   {nwqe},
+   {swqe_available_0},
+   {sig_comp_iv},
+   {rxo},
+   {rx64},
+   {rx65},
+   {rx128},
+   {rx256},
+   {rx512},
+   {rx1024},
+   {txo},
+  

Re: [2.6.19 PATCH 4/7] ehea: ethtool interface

2006-08-21 Thread Thomas Klein

Stephen Hemminger wrote:

On Fri, 18 Aug 2006 17:41:26 +0200
Thomas Klein [EMAIL PROTECTED] wrote:


Hi Alexey,

first of all thanks a lot for the extensive review.


Alexey Dobriyan wrote:

+   u64 hret = H_HARDWARE;

Useless assignment here and everywhere.


Initializing returncodes to errorstate is a cheap way to prevent
accidentally returning (uninitalized) success returncodes which
can lead to catastrophic misbehaviour.


That is old thinking. Current compilers do live/dead analysis
and tell you about this at compile time which is better than relying
on default behavior at runtime.


Understood. I reworked the returncode handling and removed the
unnecessary initializations.

Thanks for pointing this out.

Thomas
-
To unsubscribe from this list: send the line unsubscribe netdev in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [2.6.19 PATCH 4/7] ehea: ethtool interface

2006-08-21 Thread Thomas Klein


Alexey Dobriyan wrote:
 On Fri, Aug 18, 2006 at 01:33:22PM +0200, Jan-Bernd Themann wrote:
 --- linux-2.6.18-rc4-orig/drivers/net/ehea/ehea_ethtool.c
 +++ kernel/drivers/net/ehea/ehea_ethtool.c
 +{
 +strncpy(info-driver, DRV_NAME, sizeof(info-driver) - 1);
 +strncpy(info-version, DRV_VERSION, sizeof(info-version) - 1);

 Use strlcpy() to not forget -1 accidently.

Done.


 +static u32 netdev_get_msglevel(struct net_device *dev)

 +{
 +struct ehea_port *port = netdev_priv(dev);
 +return port-msg_enable;
^^

 Something is mis-named here.

The kernel requires a structure member of that name.

 +struct ethtool_ops ehea_ethtool_ops = {
 +.get_settings = netdev_get_settings,
 +.get_drvinfo = netdev_get_drvinfo,
 +.get_msglevel = netdev_get_msglevel,
 +.set_msglevel = netdev_set_msglevel,
 +.get_link = ethtool_op_get_link,
 +.get_tx_csum = ethtool_op_get_tx_csum,

 Whitespace breakage.

Fixed.

 +.set_settings = NULL,
 +.nway_reset = NULL,
 +.get_pauseparam = NULL,
 +.set_pauseparam = NULL,
 +.get_rx_csum = NULL,
 +.set_rx_csum = NULL,
 +.phys_id = NULL,
 +.self_test = NULL,
 +.self_test_count = NULL

 If you don't use them, don't mention them at all. Compiler will DTRT.

Agreed. Assignments removed.

Thanks again :-)
Thomas


-
To unsubscribe from this list: send the line unsubscribe netdev in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [2.6.19 PATCH 4/7] ehea: ethtool interface

2006-08-19 Thread Michael Ellerman
On Fri, 2006-08-18 at 17:41 +0200, Thomas Klein wrote:
 Hi Alexey,
 
 first of all thanks a lot for the extensive review.
 
 
 Alexey Dobriyan wrote:
  +  u64 hret = H_HARDWARE;
  
  Useless assignment here and everywhere.
  
 
 Initializing returncodes to errorstate is a cheap way to prevent
 accidentally returning (uninitalized) success returncodes which
 can lead to catastrophic misbehaviour.

If you try to return an uninitialized value the compiler will warn you,
you'll then look at the code and realise you missed a case, you might
save yourself a bug. By unconditionally initialising you are lying to
the compiler, and it can no longer help you.

cheers

-- 
Michael Ellerman
IBM OzLabs

wwweb: http://michael.ellerman.id.au
phone: +61 2 6212 1183 (tie line 70 21183)

We do not inherit the earth from our ancestors,
we borrow it from our children. - S.M.A.R.T Person


signature.asc
Description: This is a digitally signed message part


Re: [2.6.19 PATCH 4/7] ehea: ethtool interface

2006-08-19 Thread Andy Gay
On Sat, 2006-08-19 at 16:18 +1000, Michael Ellerman wrote:

 
 If you try to return an uninitialized value the compiler will warn you,
 you'll then look at the code and realise you missed a case, you might
 save yourself a bug. 

You *should* look at the code :)

So should we be reporting these as bugs?

[EMAIL PROTECTED]:~/linux/linux-2.6.17.6$ script make.script
Script started, file is make.script
[EMAIL PROTECTED]:~/linux/linux-2.6.17.6$ make

...

Script done, file is make.script
[EMAIL PROTECTED]:~/linux/linux-2.6.17.6$ fgrep warning make.script
arch/i386/kernel/cpu/transmeta.c:12: warning: 'cpu_freq' may be used 
uninitialized in this function
fs/bio.c:169: warning: 'idx' may be used uninitialized in this function
fs/eventpoll.c:500: warning: 'fd' may be used uninitialized in this function
fs/isofs/namei.c:162: warning: 'offset' may be used uninitialized in this 
function
fs/isofs/namei.c:162: warning: 'block' may be used uninitialized in this 
function
fs/nfsd/nfsctl.c:292: warning: 'maxsize' may be used uninitialized in this 
function
fs/udf/balloc.c:751: warning: 'goal_eloc.logicalBlockNum' may be used 
uninitialized in this function
fs/udf/super.c:1358: warning: 'ino.partitionReferenceNum' may be used 
uninitialized in this function
fs/xfs/xfs_alloc_btree.c:611: warning: 'nkey.ar_startblock' may be used 
uninitialized in this function
fs/xfs/xfs_alloc_btree.c:611: warning: 'nkey.ar_blockcount' may be used 
uninitialized in this function
fs/xfs/xfs_bmap.c:2498: warning: 'rtx' is used uninitialized in this function
fs/xfs/xfs_bmap_btree.c:753: warning: 'nkey.br_startoff' may be used 
uninitialized in this function
fs/xfs/xfs_da_btree.c:151: warning: 'action' may be used uninitialized in this 
function
fs/xfs/xfs_dir.c:363: warning: 'totallen' may be used uninitialized in this 
function
fs/xfs/xfs_dir.c:363: warning: 'count' may be used uninitialized in this 
function
fs/xfs/xfs_ialloc_btree.c:545: warning: 'nkey.ir_startino' may be used 
uninitialized in this function
fs/xfs/xfs_inode.c:1958: warning: 'last_dip' may be used uninitialized in this 
function
fs/xfs/xfs_inode.c:1960: warning: 'last_offset' may be used uninitialized in 
this function
fs/xfs/xfs_log.c:1749: warning: 'iclog' may be used uninitialized in this 
function
fs/xfs/xfs_log_recover.c:523: warning: 'first_blk' may be used uninitialized in 
this function
ipc/msg.c:338: warning: 'setbuf.qbytes' may be used uninitialized in this 
function
ipc/msg.c:338: warning: 'setbuf.uid' may be used uninitialized in this function
ipc/msg.c:338: warning: 'setbuf.gid' may be used uninitialized in this function
ipc/msg.c:338: warning: 'setbuf.mode' may be used uninitialized in this function
ipc/sem.c:810: warning: 'setbuf.uid' may be used uninitialized in this function
ipc/sem.c:810: warning: 'setbuf.gid' may be used uninitialized in this function
ipc/sem.c:810: warning: 'setbuf.mode' may be used uninitialized in this function
drivers/md/dm-table.c:431: warning: 'dev' may be used uninitialized in this 
function
drivers/md/dm-ioctl.c:1388: warning: 'param' may be used uninitialized in this 
function
net/sched/sch_cbq.c:409: warning: 'ret' may be used uninitialized in this 
function
lib/zlib_inflate/inftrees.c:121: warning: 'r.base' may be used uninitialized in 
this function


-
To unsubscribe from this list: send the line unsubscribe netdev in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [2.6.19 PATCH 4/7] ehea: ethtool interface

2006-08-19 Thread Michael Ellerman
On Sat, 2006-08-19 at 02:48 -0400, Andy Gay wrote:
 On Sat, 2006-08-19 at 16:18 +1000, Michael Ellerman wrote:
 
  
  If you try to return an uninitialized value the compiler will warn you,
  you'll then look at the code and realise you missed a case, you might
  save yourself a bug. 
 
 You *should* look at the code :)
 
 So should we be reporting these as bugs?

No you're better off sending patches ;)

A lot of these have started appearing recently, which I think is due to
GCC becoming more vocal. Unfortunately many of them are false positives
caused by GCC not seeming to grok that this is ok:

void foo(int *x) { *x = 1; }
...
int x;
foo(x);
return x;

It's a pity because it creates noise, but still it's beside the point.

New code going into the kernel should be 100% warning free, and so if
the eHEA guys had missed an error case they'd spot the warning before
they submitted it.

Doing the initialise-to-some-value trick means you only spot the bug
via testing.

cheers

-- 
Michael Ellerman
IBM OzLabs

wwweb: http://michael.ellerman.id.au
phone: +61 2 6212 1183 (tie line 70 21183)

We do not inherit the earth from our ancestors,
we borrow it from our children. - S.M.A.R.T Person


signature.asc
Description: This is a digitally signed message part


Re: [2.6.19 PATCH 4/7] ehea: ethtool interface

2006-08-19 Thread Arnd Bergmann
On Saturday 19 August 2006 10:41, Michael Ellerman wrote:
 A lot of these have started appearing recently, which I think is due to
 GCC becoming more vocal. Unfortunately many of them are false positives
 caused by GCC not seeming to grok that this is ok:
 
 void foo(int *x) { *x = 1; }
 ...
 int x;
 foo(x);
 return x;
 

It's more subtle than this, gcc only gets it wrong when multiple
things come together, the most common one seems to be:

- it tries to inline foo()
- foo has a path where it initializes *x and another one where it
  doesn't
- x is accessed after foo() returns, but only when foo indeed has
  initialized it.

The problem is that gcc now is more aggressive about inlining
functions. It used to assume that all functions initialize their
pointer arguments, now it does some more checking, but not enough,
so there are lots of false positives. Every gcc-4.x release seems
to fix some of these cases, but a few others remain.

Arnd 
-
To unsubscribe from this list: send the line unsubscribe netdev in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [2.6.19 PATCH 4/7] ehea: ethtool interface

2006-08-19 Thread Jeff Garzik

Andy Gay wrote:

fs/bio.c:169: warning: 'idx' may be used uninitialized in this function
fs/eventpoll.c:500: warning: 'fd' may be used uninitialized in this function
fs/isofs/namei.c:162: warning: 'offset' may be used uninitialized in this 
function
fs/isofs/namei.c:162: warning: 'block' may be used uninitialized in this 
function
fs/nfsd/nfsctl.c:292: warning: 'maxsize' may be used uninitialized in this 
function
fs/udf/balloc.c:751: warning: 'goal_eloc.logicalBlockNum' may be used 
uninitialized in this function
fs/udf/super.c:1358: warning: 'ino.partitionReferenceNum' may be used 
uninitialized in this function
fs/xfs/xfs_alloc_btree.c:611: warning: 'nkey.ar_startblock' may be used 
uninitialized in this function
fs/xfs/xfs_alloc_btree.c:611: warning: 'nkey.ar_blockcount' may be used 
uninitialized in this function
fs/xfs/xfs_bmap.c:2498: warning: 'rtx' is used uninitialized in this function
fs/xfs/xfs_bmap_btree.c:753: warning: 'nkey.br_startoff' may be used 
uninitialized in this function
fs/xfs/xfs_da_btree.c:151: warning: 'action' may be used uninitialized in this 
function
fs/xfs/xfs_dir.c:363: warning: 'totallen' may be used uninitialized in this 
function
fs/xfs/xfs_dir.c:363: warning: 'count' may be used uninitialized in this 
function
fs/xfs/xfs_ialloc_btree.c:545: warning: 'nkey.ir_startino' may be used 
uninitialized in this function
fs/xfs/xfs_inode.c:1958: warning: 'last_dip' may be used uninitialized in this 
function
fs/xfs/xfs_inode.c:1960: warning: 'last_offset' may be used uninitialized in 
this function
fs/xfs/xfs_log.c:1749: warning: 'iclog' may be used uninitialized in this 
function
fs/xfs/xfs_log_recover.c:523: warning: 'first_blk' may be used uninitialized in 
this function
ipc/msg.c:338: warning: 'setbuf.qbytes' may be used uninitialized in this 
function
ipc/msg.c:338: warning: 'setbuf.uid' may be used uninitialized in this function
ipc/msg.c:338: warning: 'setbuf.gid' may be used uninitialized in this function
ipc/msg.c:338: warning: 'setbuf.mode' may be used uninitialized in this function
ipc/sem.c:810: warning: 'setbuf.uid' may be used uninitialized in this function
ipc/sem.c:810: warning: 'setbuf.gid' may be used uninitialized in this function
ipc/sem.c:810: warning: 'setbuf.mode' may be used uninitialized in this function
drivers/md/dm-table.c:431: warning: 'dev' may be used uninitialized in this 
function
drivers/md/dm-ioctl.c:1388: warning: 'param' may be used uninitialized in this 
function
net/sched/sch_cbq.c:409: warning: 'ret' may be used uninitialized in this 
function
lib/zlib_inflate/inftrees.c:121: warning: 'r.base' may be used uninitialized in 
this function



These are gcc bugs.  We don't patch the kernel for gcc bugs.

Jeff


-
To unsubscribe from this list: send the line unsubscribe netdev in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[2.6.19 PATCH 4/7] ehea: ethtool interface

2006-08-18 Thread Jan-Bernd Themann
Signed-off-by: Jan-Bernd Themann [EMAIL PROTECTED] 


 drivers/net/ehea/ehea_ethtool.c |  264 
 1 file changed, 264 insertions(+)



--- linux-2.6.18-rc4-orig/drivers/net/ehea/ehea_ethtool.c   1969-12-31 
16:00:00.0 -0800
+++ kernel/drivers/net/ehea/ehea_ethtool.c  2006-08-18 00:01:02.841367875 
-0700
@@ -0,0 +1,264 @@
+/*
+ *  linux/drivers/net/ehea/ehea_ethtool.c
+ *
+ *  eHEA ethernet device driver for IBM eServer System p
+ *
+ *  (C) Copyright IBM Corp. 2006
+ *
+ *  Authors:
+ *   Christoph Raisch [EMAIL PROTECTED]
+ *   Jan-Bernd Themann [EMAIL PROTECTED]
+ *   Thomas Klein [EMAIL PROTECTED]
+ *
+ *
+ * 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, or (at your option)
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#include ehea.h
+#include ehea_phyp.h
+
+
+static int netdev_get_settings(struct net_device *dev, struct ethtool_cmd *cmd)
+{
+   u64 hret = H_HARDWARE;
+   struct ehea_port *port = netdev_priv(dev);
+   struct ehea_adapter *adapter = port-adapter;
+   struct hcp_query_ehea_port_cb_4 *cb4 = NULL;
+
+   cb4 = kzalloc(H_CB_ALIGNMENT, GFP_KERNEL);
+   if(!cb4) {
+   ehea_error(no mem for cb4);
+   goto get_settings_exit;
+   }
+
+   hret = ehea_h_query_ehea_port(adapter-handle,
+ port-logical_port_id,
+ H_PORT_CB4,
+ H_PORT_CB4_ALL,
+ cb4);
+
+   if (hret != H_SUCCESS) {
+   ehea_error(query_ehea_port failed);
+   kfree(cb4);
+   goto get_settings_exit;
+   }
+
+   if (netif_msg_hw(port))
+   ehea_dump(cb4, sizeof(struct hcp_query_ehea_port_cb_4),
+ netdev_get_settings);
+
+   if (netif_carrier_ok(dev)) {
+   switch(cb4-port_speed){
+   case H_PORT_SPEED_10M_H:
+   cmd-speed = SPEED_10;
+   cmd-duplex = DUPLEX_HALF;
+   break;
+   case H_PORT_SPEED_10M_F:
+   cmd-speed = SPEED_10;
+   cmd-duplex = DUPLEX_FULL;
+   break;
+   case H_PORT_SPEED_100M_H:
+   cmd-speed = SPEED_100;
+   cmd-duplex = DUPLEX_HALF;
+   break;
+   case H_PORT_SPEED_100M_F:
+   cmd-speed = SPEED_100;
+   cmd-duplex = DUPLEX_FULL;
+   break;
+   case H_PORT_SPEED_1G_F:
+   cmd-speed = SPEED_1000;
+   cmd-duplex = DUPLEX_FULL;
+   break;
+   case H_PORT_SPEED_10G_F:
+   cmd-speed = SPEED_1;
+   cmd-duplex = DUPLEX_FULL;
+   break;
+   }
+   } else {
+   cmd-speed = -1;
+   cmd-duplex = -1;
+   }
+
+   cmd-supported = (SUPPORTED_1baseT_Full | SUPPORTED_1000baseT_Full
+  | SUPPORTED_100baseT_Full |  SUPPORTED_100baseT_Half
+  | SUPPORTED_10baseT_Full | SUPPORTED_10baseT_Half
+  | SUPPORTED_Autoneg | SUPPORTED_FIBRE);
+
+   cmd-advertising = (ADVERTISED_1baseT_Full | ADVERTISED_Autoneg
+| ADVERTISED_FIBRE);
+
+   cmd-port = PORT_FIBRE;
+   cmd-autoneg = AUTONEG_ENABLE;
+
+   kfree(cb4);
+   return 0;
+
+get_settings_exit:
+   return 1;
+}
+
+static void netdev_get_drvinfo(struct net_device *dev,
+  struct ethtool_drvinfo *info)
+{
+   strncpy(info-driver, DRV_NAME, sizeof(info-driver) - 1);
+   strncpy(info-version, DRV_VERSION, sizeof(info-version) - 1);
+}
+
+static u32 netdev_get_msglevel(struct net_device *dev)
+{
+   struct ehea_port *port = netdev_priv(dev);
+   return port-msg_enable;
+}
+
+static void netdev_set_msglevel(struct net_device *dev, u32 value)
+{
+   struct ehea_port *port = netdev_priv(dev);
+   port-msg_enable = value;
+}
+
+static char ehea_ethtool_stats_keys[][ETH_GSTRING_LEN] = {
+   {poll_max_processed},
+   {queue_stopped},
+   {min_swqe_avail},
+   {poll_receive_err},
+   {pkt_send},
+   

Re: [2.6.19 PATCH 4/7] ehea: ethtool interface

2006-08-18 Thread Alexey Dobriyan
On Fri, Aug 18, 2006 at 01:33:22PM +0200, Jan-Bernd Themann wrote:
 --- linux-2.6.18-rc4-orig/drivers/net/ehea/ehea_ethtool.c
 +++ kernel/drivers/net/ehea/ehea_ethtool.c
 +static int netdev_get_settings(struct net_device *dev, struct ethtool_cmd 
 *cmd)
 +{
 + u64 hret = H_HARDWARE;

useless assignment;

 + struct ehea_port *port = netdev_priv(dev);
 + struct ehea_adapter *adapter = port-adapter;
 + struct hcp_query_ehea_port_cb_4 *cb4 = NULL;
 +
 + cb4 = kzalloc(H_CB_ALIGNMENT, GFP_KERNEL);
 + if(!cb4) {
 + ehea_error(no mem for cb4);
 + goto get_settings_exit;
 + }
 +
 + hret = ehea_h_query_ehea_port(adapter-handle,
 +   port-logical_port_id,
 +   H_PORT_CB4,
 +   H_PORT_CB4_ALL,
 +   cb4);

 +static void netdev_get_drvinfo(struct net_device *dev,
 +struct ethtool_drvinfo *info)
 +{
 + strncpy(info-driver, DRV_NAME, sizeof(info-driver) - 1);
 + strncpy(info-version, DRV_VERSION, sizeof(info-version) - 1);

Use strlcpy() to not forget -1 accidently.

 +static u32 netdev_get_msglevel(struct net_device *dev)
 
 +{
 + struct ehea_port *port = netdev_priv(dev);
 + return port-msg_enable;
 ^^

Something is mis-named here.

 +}
 +
 +static void netdev_set_msglevel(struct net_device *dev, u32 value)
 +{
 + struct ehea_port *port = netdev_priv(dev);
 + port-msg_enable = value;
 +}

And here.

 +static void netdev_get_ethtool_stats(struct net_device *dev,
 +  struct ethtool_stats *stats, u64 *data)
 +{
 + int i = 0;
 + u64 hret = H_HARDWARE;

Useless assignment.

 + struct ehea_port *port = netdev_priv(dev);
 + struct ehea_adapter *adapter = port-adapter;
 + struct ehea_port_res *pr = port-port_res[0];
 + struct port_state *p_state = pr-p_state;
 + struct hcp_query_ehea_port_cb_6 *cb6 = NULL;

Ditto.

 + cb6 = kzalloc(H_CB_ALIGNMENT, GFP_KERNEL);
 + if(!cb6) {
 + ehea_error(no mem for cb6);
 + goto stats_exit;
 + }
 +
 + hret = ehea_h_query_ehea_port(adapter-handle,
 +   port-logical_port_id,
 +   H_PORT_CB6,
 +   H_PORT_CB6_ALL,
 +   cb6);

 +struct ethtool_ops ehea_ethtool_ops = {
 + .get_settings = netdev_get_settings,
 + .get_drvinfo = netdev_get_drvinfo,
 + .get_msglevel = netdev_get_msglevel,
 + .set_msglevel = netdev_set_msglevel,
 +.get_link = ethtool_op_get_link,
 +.get_tx_csum = ethtool_op_get_tx_csum,

Whitespace breakage.

 + .set_tx_csum = ethtool_op_set_tx_csum,
 + .get_sg = ethtool_op_get_sg,
 + .set_sg = ethtool_op_set_sg,
 + .get_tso = ethtool_op_get_tso,
 + .set_tso = ethtool_op_set_tso,
 + .get_strings = netdev_get_strings,
 + .get_stats_count = netdev_get_stats_count,
 + .get_ethtool_stats = netdev_get_ethtool_stats,



 + .set_settings = NULL,
 + .nway_reset = NULL,
 + .get_pauseparam = NULL,
 + .set_pauseparam = NULL,
 + .get_rx_csum = NULL,
 + .set_rx_csum = NULL,
 + .phys_id = NULL,
 + .self_test = NULL,
 + .self_test_count = NULL

If you don't use them, don't mention them at all. Compiler will DTRT.

-
To unsubscribe from this list: send the line unsubscribe netdev in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [2.6.19 PATCH 4/7] ehea: ethtool interface

2006-08-18 Thread Thomas Klein

Hi Alexey,

first of all thanks a lot for the extensive review.


Alexey Dobriyan wrote:

+   u64 hret = H_HARDWARE;


Useless assignment here and everywhere.



Initializing returncodes to errorstate is a cheap way to prevent
accidentally returning (uninitalized) success returncodes which
can lead to catastrophic misbehaviour.


+static void netdev_get_drvinfo(struct net_device *dev,
+  struct ethtool_drvinfo *info)
+{
+   strncpy(info-driver, DRV_NAME, sizeof(info-driver) - 1);
+   strncpy(info-version, DRV_VERSION, sizeof(info-version) - 1);


Use strlcpy() to not forget -1 accidently.


I agree.

Kind regards
Thomas
-
To unsubscribe from this list: send the line unsubscribe netdev in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [2.6.19 PATCH 4/7] ehea: ethtool interface

2006-08-18 Thread Stephen Hemminger
On Fri, 18 Aug 2006 17:41:26 +0200
Thomas Klein [EMAIL PROTECTED] wrote:

 Hi Alexey,
 
 first of all thanks a lot for the extensive review.
 
 
 Alexey Dobriyan wrote:
  +  u64 hret = H_HARDWARE;
  
  Useless assignment here and everywhere.
  
 
 Initializing returncodes to errorstate is a cheap way to prevent
 accidentally returning (uninitalized) success returncodes which
 can lead to catastrophic misbehaviour.

That is old thinking. Current compilers do live/dead analysis
and tell you about this at compile time which is better than relying
on default behavior at runtime.
-
To unsubscribe from this list: send the line unsubscribe netdev in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html