* [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).