net/af_packet: append system error to error msgs

Message ID 20190704143905.8704-1-kkanas@marvell.com (mailing list archive)
State Superseded, archived
Delegated to: Ferruh Yigit
Headers
Series net/af_packet: append system error to error msgs |

Checks

Context Check Description
ci/checkpatch success coding style OK
ci/intel-Performance-Testing success Performance Testing PASS
ci/mellanox-Performance-Testing success Performance Testing PASS
ci/Intel-compilation success Compilation OK

Commit Message

Krzysztof Kanas July 4, 2019, 2:39 p.m. UTC
  From: Krzysztof Kanas <kkanas@marvell.com>

Print system error to make easier diagnosis of errors with af_packet.

Signed-off-by: Krzysztof Kanas <kkanas@marvell.com>
---
 drivers/net/af_packet/rte_eth_af_packet.c | 47 ++++++++++++-----------
 1 file changed, 24 insertions(+), 23 deletions(-)
  

Comments

Ferruh Yigit July 4, 2019, 6:59 p.m. UTC | #1
On 7/4/2019 3:39 PM, kkanas@marvell.com wrote:
> From: Krzysztof Kanas <kkanas@marvell.com>
> 
> Print system error to make easier diagnosis of errors with af_packet.
> 
> Signed-off-by: Krzysztof Kanas <kkanas@marvell.com>
> ---
>  drivers/net/af_packet/rte_eth_af_packet.c | 47 ++++++++++++-----------
>  1 file changed, 24 insertions(+), 23 deletions(-)
> 
> diff --git a/drivers/net/af_packet/rte_eth_af_packet.c b/drivers/net/af_packet/rte_eth_af_packet.c
> index f396f8b22a55..94ae4b13398d 100644
> --- a/drivers/net/af_packet/rte_eth_af_packet.c
> +++ b/drivers/net/af_packet/rte_eth_af_packet.c
> @@ -13,7 +13,9 @@
>  #include <rte_malloc.h>
>  #include <rte_kvargs.h>
>  #include <rte_bus_vdev.h>
> +#include <rte_errno.h>
>  
> +#include <errno.h>
>  #include <linux/if_ether.h>
>  #include <linux/if_packet.h>
>  #include <arpa/inet.h>
> @@ -605,8 +607,8 @@ rte_pmd_init_internals(struct rte_vdev_device *dev,
>  	}
>  	if (ioctl(sockfd, SIOCGIFINDEX, &ifr) == -1) {
>  		PMD_LOG(ERR,
> -			"%s: ioctl failed (SIOCGIFINDEX)",
> -		        name);
> +			"%s: ioctl failed (SIOCGIFINDEX):%s",
> +			name, rte_strerror(errno));

What do you think adding an new macro that adds ":%s, rte_strerror(errno)" part
automatically and just change the macro on selected logs?
  
Krzysztof Kanas July 5, 2019, 9:35 a.m. UTC | #2
On 19-07-04 19:59, Ferruh Yigit wrote:
> External Email
> 
> ----------------------------------------------------------------------
> On 7/4/2019 3:39 PM, kkanas@marvell.com wrote:
> > From: Krzysztof Kanas <kkanas@marvell.com>
> > 
> > Print system error to make easier diagnosis of errors with af_packet.
> > 
> > Signed-off-by: Krzysztof Kanas <kkanas@marvell.com>
> > ---
> >  drivers/net/af_packet/rte_eth_af_packet.c | 47 ++++++++++++-----------
> >  1 file changed, 24 insertions(+), 23 deletions(-)
> > 
> > diff --git a/drivers/net/af_packet/rte_eth_af_packet.c b/drivers/net/af_packet/rte_eth_af_packet.c
> > index f396f8b22a55..94ae4b13398d 100644
> > --- a/drivers/net/af_packet/rte_eth_af_packet.c
> > +++ b/drivers/net/af_packet/rte_eth_af_packet.c
> > @@ -13,7 +13,9 @@
> >  #include <rte_malloc.h>
> >  #include <rte_kvargs.h>
> >  #include <rte_bus_vdev.h>
> > +#include <rte_errno.h>
> >  
> > +#include <errno.h>
> >  #include <linux/if_ether.h>
> >  #include <linux/if_packet.h>
> >  #include <arpa/inet.h>
> > @@ -605,8 +607,8 @@ rte_pmd_init_internals(struct rte_vdev_device *dev,
> >  	}
> >  	if (ioctl(sockfd, SIOCGIFINDEX, &ifr) == -1) {
> >  		PMD_LOG(ERR,
> > -			"%s: ioctl failed (SIOCGIFINDEX)",
> > -		        name);
> > +			"%s: ioctl failed (SIOCGIFINDEX):%s",
> > +			name, rte_strerror(errno));
> 
> What do you think adding an new macro that adds ":%s, rte_strerror(errno)" part
> automatically and just change the macro on selected logs?
> 
I would rather not, as adding macro adds another indirection, and the 
purpose of rte_strerror(errno) was just to help debugging wrong 
arguments etc..

Also if in macro somebody uses function that changes errno, the 
rte_strerror would give bad result.

But no strong opinion on above.
  
Ferruh Yigit July 8, 2019, 6:04 p.m. UTC | #3
On 7/5/2019 10:35 AM, Krzysztof Kanas wrote:
> On 19-07-04 19:59, Ferruh Yigit wrote:
>> External Email
>>
>> ----------------------------------------------------------------------
>> On 7/4/2019 3:39 PM, kkanas@marvell.com wrote:
>>> From: Krzysztof Kanas <kkanas@marvell.com>
>>>
>>> Print system error to make easier diagnosis of errors with af_packet.
>>>
>>> Signed-off-by: Krzysztof Kanas <kkanas@marvell.com>
>>> ---
>>>  drivers/net/af_packet/rte_eth_af_packet.c | 47 ++++++++++++-----------
>>>  1 file changed, 24 insertions(+), 23 deletions(-)
>>>
>>> diff --git a/drivers/net/af_packet/rte_eth_af_packet.c b/drivers/net/af_packet/rte_eth_af_packet.c
>>> index f396f8b22a55..94ae4b13398d 100644
>>> --- a/drivers/net/af_packet/rte_eth_af_packet.c
>>> +++ b/drivers/net/af_packet/rte_eth_af_packet.c
>>> @@ -13,7 +13,9 @@
>>>  #include <rte_malloc.h>
>>>  #include <rte_kvargs.h>
>>>  #include <rte_bus_vdev.h>
>>> +#include <rte_errno.h>
>>>  
>>> +#include <errno.h>
>>>  #include <linux/if_ether.h>
>>>  #include <linux/if_packet.h>
>>>  #include <arpa/inet.h>
>>> @@ -605,8 +607,8 @@ rte_pmd_init_internals(struct rte_vdev_device *dev,
>>>  	}
>>>  	if (ioctl(sockfd, SIOCGIFINDEX, &ifr) == -1) {
>>>  		PMD_LOG(ERR,
>>> -			"%s: ioctl failed (SIOCGIFINDEX)",
>>> -		        name);
>>> +			"%s: ioctl failed (SIOCGIFINDEX):%s",
>>> +			name, rte_strerror(errno));
>>
>> What do you think adding an new macro that adds ":%s, rte_strerror(errno)" part
>> automatically and just change the macro on selected logs?
>>
> I would rather not, as adding macro adds another indirection, and the 
> purpose of rte_strerror(errno) was just to help debugging wrong 
> arguments etc..
> 
> Also if in macro somebody uses function that changes errno, the 
> rte_strerror would give bad result.

I am just talking about something like "PMD_LOG_ERRNO" which appends
"rte_strerror(errno)" additional to "PMD_LOG", so there is no additional
indirection or there is nothing that can change "errno", so still doesn't make
sense?


> 
> But no strong opinion on above.
>
  

Patch

diff --git a/drivers/net/af_packet/rte_eth_af_packet.c b/drivers/net/af_packet/rte_eth_af_packet.c
index f396f8b22a55..94ae4b13398d 100644
--- a/drivers/net/af_packet/rte_eth_af_packet.c
+++ b/drivers/net/af_packet/rte_eth_af_packet.c
@@ -13,7 +13,9 @@ 
 #include <rte_malloc.h>
 #include <rte_kvargs.h>
 #include <rte_bus_vdev.h>
+#include <rte_errno.h>
 
+#include <errno.h>
 #include <linux/if_ether.h>
 #include <linux/if_packet.h>
 #include <arpa/inet.h>
@@ -605,8 +607,8 @@  rte_pmd_init_internals(struct rte_vdev_device *dev,
 	}
 	if (ioctl(sockfd, SIOCGIFINDEX, &ifr) == -1) {
 		PMD_LOG(ERR,
-			"%s: ioctl failed (SIOCGIFINDEX)",
-		        name);
+			"%s: ioctl failed (SIOCGIFINDEX):%s",
+			name, rte_strerror(errno));
 		return -1;
 	}
 	(*internals)->if_name = strdup(pair->value);
@@ -616,8 +618,8 @@  rte_pmd_init_internals(struct rte_vdev_device *dev,
 
 	if (ioctl(sockfd, SIOCGIFHWADDR, &ifr) == -1) {
 		PMD_LOG(ERR,
-			"%s: ioctl failed (SIOCGIFHWADDR)",
-		        name);
+			"%s: ioctl failed (SIOCGIFHWADDR):%s",
+			name, rte_strerror(errno));
 		return -1;
 	}
 	memcpy(&(*internals)->eth_addr, ifr.ifr_hwaddr.sa_data, ETH_ALEN);
@@ -640,8 +642,8 @@  rte_pmd_init_internals(struct rte_vdev_device *dev,
 		qsockfd = socket(AF_PACKET, SOCK_RAW, htons(ETH_P_ALL));
 		if (qsockfd == -1) {
 			PMD_LOG(ERR,
-				"%s: could not open AF_PACKET socket",
-			        name);
+				"%s: could not open AF_PACKET socket: %s",
+				name, rte_strerror(errno));
 			return -1;
 		}
 
@@ -650,8 +652,8 @@  rte_pmd_init_internals(struct rte_vdev_device *dev,
 				&tpver, sizeof(tpver));
 		if (rc == -1) {
 			PMD_LOG(ERR,
-				"%s: could not set PACKET_VERSION on AF_PACKET socket for %s",
-				name, pair->value);
+				"%s: could not set PACKET_VERSION on AF_PACKET socket for %s:%s",
+				name, pair->value, rte_strerror(errno));
 			goto error;
 		}
 
@@ -660,8 +662,8 @@  rte_pmd_init_internals(struct rte_vdev_device *dev,
 				&discard, sizeof(discard));
 		if (rc == -1) {
 			PMD_LOG(ERR,
-				"%s: could not set PACKET_LOSS on AF_PACKET socket for %s",
-				name, pair->value);
+				"%s: could not set PACKET_LOSS on AF_PACKET socket for %s:%s",
+				name, pair->value, rte_strerror(errno));
 			goto error;
 		}
 
@@ -670,8 +672,8 @@  rte_pmd_init_internals(struct rte_vdev_device *dev,
 				&qdisc_bypass, sizeof(qdisc_bypass));
 		if (rc == -1) {
 			PMD_LOG(ERR,
-				"%s: could not set PACKET_QDISC_BYPASS on AF_PACKET socket for %s",
-				name, pair->value);
+				"%s: could not set PACKET_QDISC_BYPASS on AF_PACKET socket for %s:%s",
+				name, pair->value, rte_strerror(errno));
 			goto error;
 		}
 #else
@@ -681,8 +683,8 @@  rte_pmd_init_internals(struct rte_vdev_device *dev,
 		rc = setsockopt(qsockfd, SOL_PACKET, PACKET_RX_RING, req, sizeof(*req));
 		if (rc == -1) {
 			PMD_LOG(ERR,
-				"%s: could not set PACKET_RX_RING on AF_PACKET socket for %s",
-				name, pair->value);
+				"%s: could not set PACKET_RX_RING on AF_PACKE socket for %s:%s",
+				name, pair->value, rte_strerror(errno));
 			goto error;
 		}
 
@@ -690,7 +692,8 @@  rte_pmd_init_internals(struct rte_vdev_device *dev,
 		if (rc == -1) {
 			PMD_LOG(ERR,
 				"%s: could not set PACKET_TX_RING on AF_PACKET "
-				"socket for %s", name, pair->value);
+				"socket for %s:%s", name, pair->value,
+				rte_strerror(errno));
 			goto error;
 		}
 
@@ -702,8 +705,8 @@  rte_pmd_init_internals(struct rte_vdev_device *dev,
 				    qsockfd, 0);
 		if (rx_queue->map == MAP_FAILED) {
 			PMD_LOG(ERR,
-				"%s: call to mmap failed on AF_PACKET socket for %s",
-				name, pair->value);
+				"%s: call to mmap failed on AF_PACKET socket for %s:%s",
+				name, pair->value, rte_strerror(errno));
 			goto error;
 		}
 
@@ -738,9 +741,8 @@  rte_pmd_init_internals(struct rte_vdev_device *dev,
 
 		rc = bind(qsockfd, (const struct sockaddr*)&sockaddr, sizeof(sockaddr));
 		if (rc == -1) {
-			PMD_LOG(ERR,
-				"%s: could not bind AF_PACKET socket to %s",
-			        name, pair->value);
+			PMD_LOG(ERR, "%s: could not bind AF_PACKET socket to %s:%s",
+				name, pair->value, rte_strerror(errno));
 			goto error;
 		}
 
@@ -748,9 +750,8 @@  rte_pmd_init_internals(struct rte_vdev_device *dev,
 		rc = setsockopt(qsockfd, SOL_PACKET, PACKET_FANOUT,
 				&fanout_arg, sizeof(fanout_arg));
 		if (rc == -1) {
-			PMD_LOG(ERR,
-				"%s: could not set PACKET_FANOUT on AF_PACKET socket "
-				"for %s", name, pair->value);
+			PMD_LOG(ERR, "%s: could not set PACKET_FANOUT on AF_PACKET socket for %s:%s",
+				name, pair->value, rte_strerror(errno));
 			goto error;
 		}
 #endif