linux-can.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 0/3] sparse fixes
@ 2012-06-19 20:05 Marc Kleine-Budde
  2012-06-19 20:05 ` [PATCH 1/3] can: cc770: fix sparse warning for cc770_interrupt Marc Kleine-Budde
                   ` (2 more replies)
  0 siblings, 3 replies; 9+ messages in thread
From: Marc Kleine-Budde @ 2012-06-19 20:05 UTC (permalink / raw)
  To: linux-can

Hello,

while testing Oliver's series I fixed the following sparse errors.

regards, Marc.


^ permalink raw reply	[flat|nested] 9+ messages in thread

* [PATCH 1/3] can: cc770: fix sparse warning for cc770_interrupt
  2012-06-19 20:05 [PATCH 0/3] sparse fixes Marc Kleine-Budde
@ 2012-06-19 20:05 ` Marc Kleine-Budde
  2012-06-19 20:05 ` [PATCH 2/3] can: dev: fix sparse warning for can_restart Marc Kleine-Budde
  2012-06-19 20:05 ` [PATCH 3/3] can: af_can: fix sparse warning for can_rx_alldev_list Marc Kleine-Budde
  2 siblings, 0 replies; 9+ messages in thread
From: Marc Kleine-Budde @ 2012-06-19 20:05 UTC (permalink / raw)
  To: linux-can; +Cc: Marc Kleine-Budde

Make cc770_interrupt static to fix the following sparse warning:
drivers/net/can/cc770/cc770.c:699:13: warning: symbol
'cc770_interrupt' was not declared. Should it be static?

Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
---
 drivers/net/can/cc770/cc770.c |    2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/net/can/cc770/cc770.c b/drivers/net/can/cc770/cc770.c
index d42a6a7..a138db1 100644
--- a/drivers/net/can/cc770/cc770.c
+++ b/drivers/net/can/cc770/cc770.c
@@ -695,7 +695,7 @@ static void cc770_tx_interrupt(struct net_device *dev, unsigned int o)
 	netif_wake_queue(dev);
 }
 
-irqreturn_t cc770_interrupt(int irq, void *dev_id)
+static irqreturn_t cc770_interrupt(int irq, void *dev_id)
 {
 	struct net_device *dev = (struct net_device *)dev_id;
 	struct cc770_priv *priv = netdev_priv(dev);
-- 
1.7.10


^ permalink raw reply related	[flat|nested] 9+ messages in thread

* [PATCH 2/3] can: dev: fix sparse warning for can_restart
  2012-06-19 20:05 [PATCH 0/3] sparse fixes Marc Kleine-Budde
  2012-06-19 20:05 ` [PATCH 1/3] can: cc770: fix sparse warning for cc770_interrupt Marc Kleine-Budde
@ 2012-06-19 20:05 ` Marc Kleine-Budde
  2012-06-19 20:05 ` [PATCH 3/3] can: af_can: fix sparse warning for can_rx_alldev_list Marc Kleine-Budde
  2 siblings, 0 replies; 9+ messages in thread
From: Marc Kleine-Budde @ 2012-06-19 20:05 UTC (permalink / raw)
  To: linux-can; +Cc: Marc Kleine-Budde

Make can_restart static to fix the following sparse warning:
drivers/net/can/dev.c:371:6: warning: symbol 'can_restart' was not
declared. Should it be static?

Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
---
 drivers/net/can/dev.c |    2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/net/can/dev.c b/drivers/net/can/dev.c
index 239e4dd..963e2cc 100644
--- a/drivers/net/can/dev.c
+++ b/drivers/net/can/dev.c
@@ -401,7 +401,7 @@ EXPORT_SYMBOL_GPL(can_free_echo_skb);
 /*
  * CAN device restart for bus-off recovery
  */
-void can_restart(unsigned long data)
+static void can_restart(unsigned long data)
 {
 	struct net_device *dev = (struct net_device *)data;
 	struct can_priv *priv = netdev_priv(dev);
-- 
1.7.10


^ permalink raw reply related	[flat|nested] 9+ messages in thread

* [PATCH 3/3] can: af_can: fix sparse warning for can_rx_alldev_list
  2012-06-19 20:05 [PATCH 0/3] sparse fixes Marc Kleine-Budde
  2012-06-19 20:05 ` [PATCH 1/3] can: cc770: fix sparse warning for cc770_interrupt Marc Kleine-Budde
  2012-06-19 20:05 ` [PATCH 2/3] can: dev: fix sparse warning for can_restart Marc Kleine-Budde
@ 2012-06-19 20:05 ` Marc Kleine-Budde
  2012-06-20  3:39   ` Oliver Hartkopp
  2 siblings, 1 reply; 9+ messages in thread
From: Marc Kleine-Budde @ 2012-06-19 20:05 UTC (permalink / raw)
  To: linux-can; +Cc: Marc Kleine-Budde

Make can_rx_alldev_list static to fix the following sparse warning:
net/can/af_can.c:80:22: warning: symbol 'can_rx_alldev_list' was not
declared. Should it be static?

Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
---
 net/can/af_can.c |    2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/net/can/af_can.c b/net/can/af_can.c
index 821022a..ccef846 100644
--- a/net/can/af_can.c
+++ b/net/can/af_can.c
@@ -78,7 +78,7 @@ module_param(stats_timer, int, S_IRUGO);
 MODULE_PARM_DESC(stats_timer, "enable timer for statistics (default:on)");
 
 /* receive filters subscribed for 'all' CAN devices */
-struct dev_rcv_lists can_rx_alldev_list;
+static struct dev_rcv_lists can_rx_alldev_list;
 static DEFINE_SPINLOCK(can_rcvlists_lock);
 
 static struct kmem_cache *rcv_cache __read_mostly;
-- 
1.7.10


^ permalink raw reply related	[flat|nested] 9+ messages in thread

* Re: [PATCH 3/3] can: af_can: fix sparse warning for can_rx_alldev_list
  2012-06-19 20:05 ` [PATCH 3/3] can: af_can: fix sparse warning for can_rx_alldev_list Marc Kleine-Budde
@ 2012-06-20  3:39   ` Oliver Hartkopp
  2012-06-20  8:00     ` Marc Kleine-Budde
  0 siblings, 1 reply; 9+ messages in thread
From: Oliver Hartkopp @ 2012-06-20  3:39 UTC (permalink / raw)
  To: Marc Kleine-Budde; +Cc: linux-can

On 19.06.2012 22:05, Marc Kleine-Budde wrote:

> Make can_rx_alldev_list static to fix the following sparse warning:
> net/can/af_can.c:80:22: warning: symbol 'can_rx_alldev_list' was not
> declared. Should it be static?
> 
> Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
> ---
>  net/can/af_can.c |    2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/net/can/af_can.c b/net/can/af_can.c
> index 821022a..ccef846 100644
> --- a/net/can/af_can.c
> +++ b/net/can/af_can.c
> @@ -78,7 +78,7 @@ module_param(stats_timer, int, S_IRUGO);
>  MODULE_PARM_DESC(stats_timer, "enable timer for statistics (default:on)");
>  
>  /* receive filters subscribed for 'all' CAN devices */
> -struct dev_rcv_lists can_rx_alldev_list;
> +static struct dev_rcv_lists can_rx_alldev_list;
>  static DEFINE_SPINLOCK(can_rcvlists_lock);
>  
>  static struct kmem_cache *rcv_cache __read_mostly;


Hello Marc,

did you already compile this?

can_rx_alldev_list is used in af_can.c and proc.c :

$ grep can_rx_alldev_list *.c
af_can.c:struct dev_rcv_lists can_rx_alldev_list;
af_can.c:		return &can_rx_alldev_list;
af_can.c:	matches = can_rcv_filter(&can_rx_alldev_list, skb);
af_can.c:	memset(&can_rx_alldev_list, 0, sizeof(can_rx_alldev_list));
proc.c:extern struct dev_rcv_lists can_rx_alldev_list;
proc.c:	d = &can_rx_alldev_list;
proc.c:	d = &can_rx_alldev_list;

So i wonder if making it static inside af_can.c is a good idea.

Is there no way to satisfy the sparse warning in another way?

Regards,
Oliver


^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH 3/3] can: af_can: fix sparse warning for can_rx_alldev_list
  2012-06-20  3:39   ` Oliver Hartkopp
@ 2012-06-20  8:00     ` Marc Kleine-Budde
  2012-06-20 15:46       ` Oliver Hartkopp
  0 siblings, 1 reply; 9+ messages in thread
From: Marc Kleine-Budde @ 2012-06-20  8:00 UTC (permalink / raw)
  To: Oliver Hartkopp; +Cc: linux-can

[-- Attachment #1: Type: text/plain, Size: 2033 bytes --]

On 06/20/2012 05:39 AM, Oliver Hartkopp wrote:
> On 19.06.2012 22:05, Marc Kleine-Budde wrote:
> 
>> Make can_rx_alldev_list static to fix the following sparse warning:
>> net/can/af_can.c:80:22: warning: symbol 'can_rx_alldev_list' was not
>> declared. Should it be static?
>>
>> Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
>> ---
>>  net/can/af_can.c |    2 +-
>>  1 file changed, 1 insertion(+), 1 deletion(-)
>>
>> diff --git a/net/can/af_can.c b/net/can/af_can.c
>> index 821022a..ccef846 100644
>> --- a/net/can/af_can.c
>> +++ b/net/can/af_can.c
>> @@ -78,7 +78,7 @@ module_param(stats_timer, int, S_IRUGO);
>>  MODULE_PARM_DESC(stats_timer, "enable timer for statistics (default:on)");
>>  
>>  /* receive filters subscribed for 'all' CAN devices */
>> -struct dev_rcv_lists can_rx_alldev_list;
>> +static struct dev_rcv_lists can_rx_alldev_list;
>>  static DEFINE_SPINLOCK(can_rcvlists_lock);
>>  
>>  static struct kmem_cache *rcv_cache __read_mostly;
> 
> 
> Hello Marc,
> 
> did you already compile this?

Compile yes, link no :D

> can_rx_alldev_list is used in af_can.c and proc.c :
> 
> $ grep can_rx_alldev_list *.c
> af_can.c:struct dev_rcv_lists can_rx_alldev_list;
> af_can.c:		return &can_rx_alldev_list;
> af_can.c:	matches = can_rcv_filter(&can_rx_alldev_list, skb);
> af_can.c:	memset(&can_rx_alldev_list, 0, sizeof(can_rx_alldev_list));
> proc.c:extern struct dev_rcv_lists can_rx_alldev_list;
         ^^^^^^

> proc.c:	d = &can_rx_alldev_list;
> proc.c:	d = &can_rx_alldev_list;
> 
> So i wonder if making it static inside af_can.c is a good idea.
> 
> Is there no way to satisfy the sparse warning in another way?

Yes, don't use extern, put it into af_can.h.

Marc

-- 
Pengutronix e.K.                  | Marc Kleine-Budde           |
Industrial Linux Solutions        | Phone: +49-231-2826-924     |
Vertretung West/Dortmund          | Fax:   +49-5121-206917-5555 |
Amtsgericht Hildesheim, HRA 2686  | http://www.pengutronix.de   |


[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 262 bytes --]

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH 3/3] can: af_can: fix sparse warning for can_rx_alldev_list
  2012-06-20  8:00     ` Marc Kleine-Budde
@ 2012-06-20 15:46       ` Oliver Hartkopp
  2012-06-20 16:05         ` Marc Kleine-Budde
  0 siblings, 1 reply; 9+ messages in thread
From: Oliver Hartkopp @ 2012-06-20 15:46 UTC (permalink / raw)
  To: Marc Kleine-Budde; +Cc: linux-can

On 20.06.2012 10:00, Marc Kleine-Budde wrote:

> On 06/20/2012 05:39 AM, Oliver Hartkopp wrote:
>> On 19.06.2012 22:05, Marc Kleine-Budde wrote:

>> Is there no way to satisfy the sparse warning in another way?
> 
> Yes, don't use extern, put it into af_can.h.
>


So this would fix the sparse warning then?

diff --git a/net/can/af_can.h b/net/can/af_can.h
index fd882db..1dccb4c 100644
--- a/net/can/af_can.h
+++ b/net/can/af_can.h
@@ -104,6 +104,9 @@ struct s_pstats {
 	unsigned long rcv_entries_max;
 };

+/* receive filters subscribed for 'all' CAN devices */
+extern struct dev_rcv_lists can_rx_alldev_list;
+
 /* function prototypes for the CAN networklayer procfs (proc.c) */
 extern void can_init_proc(void);
 extern void can_remove_proc(void);
diff --git a/net/can/proc.c b/net/can/proc.c
index ba873c3..3b6dd31 100644
--- a/net/can/proc.c
+++ b/net/can/proc.c
@@ -83,9 +83,6 @@ static const char rx_list_name[][8] = {
 	[RX_EFF] = "rx_eff",
 };

-/* receive filters subscribed for 'all' CAN devices */
-extern struct dev_rcv_lists can_rx_alldev_list;
-
 /*
  * af_can statistics stuff
  */




^ permalink raw reply related	[flat|nested] 9+ messages in thread

* Re: [PATCH 3/3] can: af_can: fix sparse warning for can_rx_alldev_list
  2012-06-20 15:46       ` Oliver Hartkopp
@ 2012-06-20 16:05         ` Marc Kleine-Budde
  2012-06-20 16:06           ` Oliver Hartkopp
  0 siblings, 1 reply; 9+ messages in thread
From: Marc Kleine-Budde @ 2012-06-20 16:05 UTC (permalink / raw)
  To: Oliver Hartkopp; +Cc: linux-can

[-- Attachment #1: Type: text/plain, Size: 415 bytes --]

On 06/20/2012 05:46 PM, Oliver Hartkopp wrote:
> So this would fix the sparse warning then?

Yes it does. Can I add your S-o-b?

Marc
-- 
Pengutronix e.K.                  | Marc Kleine-Budde           |
Industrial Linux Solutions        | Phone: +49-231-2826-924     |
Vertretung West/Dortmund          | Fax:   +49-5121-206917-5555 |
Amtsgericht Hildesheim, HRA 2686  | http://www.pengutronix.de   |


[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 262 bytes --]

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: [PATCH 3/3] can: af_can: fix sparse warning for can_rx_alldev_list
  2012-06-20 16:05         ` Marc Kleine-Budde
@ 2012-06-20 16:06           ` Oliver Hartkopp
  0 siblings, 0 replies; 9+ messages in thread
From: Oliver Hartkopp @ 2012-06-20 16:06 UTC (permalink / raw)
  To: Marc Kleine-Budde; +Cc: linux-can@vger.kernel.org

On 20.06.2012 18:05, Marc Kleine-Budde wrote:

> On 06/20/2012 05:46 PM, Oliver Hartkopp wrote:
>> So this would fix the sparse warning then?
> 
> Yes it does. Can I add your S-o-b?
> 


Yep.

Thanks!

^ permalink raw reply	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2012-06-20 16:06 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-06-19 20:05 [PATCH 0/3] sparse fixes Marc Kleine-Budde
2012-06-19 20:05 ` [PATCH 1/3] can: cc770: fix sparse warning for cc770_interrupt Marc Kleine-Budde
2012-06-19 20:05 ` [PATCH 2/3] can: dev: fix sparse warning for can_restart Marc Kleine-Budde
2012-06-19 20:05 ` [PATCH 3/3] can: af_can: fix sparse warning for can_rx_alldev_list Marc Kleine-Budde
2012-06-20  3:39   ` Oliver Hartkopp
2012-06-20  8:00     ` Marc Kleine-Budde
2012-06-20 15:46       ` Oliver Hartkopp
2012-06-20 16:05         ` Marc Kleine-Budde
2012-06-20 16:06           ` Oliver Hartkopp

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).