Re: Backport issue net/mac80211/iface.c

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, Jul 16, 2014 at 04:29:50PM -0400, C. McPherson wrote:
> When I build backports-3.15-rc1-1 I get the following warnings (my linux
> kernel version is 3.13.0-24) Mint 17:
> 
> Here is my version information:
> linuxbox backports-3.15-rc1-1 # uname -r
> 3.13.0-24-generic
> linuxbox backports-3.15-rc1-1 # uname -a
> Linux linuxbox 3.13.0-24-generic #47-Ubuntu SMP Fri May 2 23:30:00 UTC 2014
> x86_64 x86_64 x86_64 GNU/Linux
> linuxbox backports-3.15-rc1-1 #
> 
> 
> 
> CC [M] /usr/src/backports-3.15-rc1-1/net/mac80211/vht.o
> CC [M] /usr/src/backports-3.15-rc1-1/net/mac80211/ibss.o
> CC [M] /usr/src/backports-3.15-rc1-1/net/mac80211/iface.o
> /usr/src/backports-3.15-rc1-1/net/mac80211/iface.c:1080:2: warning:
> initialization from incompatible pointer type [enabled by default]
> .ndo_select_queue = ieee80211_netdev_select_queue,
> ^
> /usr/src/backports-3.15-rc1-1/net/mac80211/iface.c:1080:2: warning: (near
> initialization for ‘ieee80211_dataif_ops.ndo_select_queue’) [enabled by
> default]
> /usr/src/backports-3.15-rc1-1/net/mac80211/iface.c:1122:2: warning:
> initialization from incompatible pointer type [enabled by default]
> .ndo_select_queue = ieee80211_monitor_select_queue,
> ^
> /usr/src/backports-3.15-rc1-1/net/mac80211/iface.c:1122:2: warning: (near
> initialization for ‘ieee80211_monitorif_ops.ndo_select_queue’) [enabled by
> default]
> CC [M] /usr/src/backports-3.15-rc1-1/net/mac80211/rate.o
> CC [M] /usr/src/backports-3.15-rc1-1/net/mac80211/michael.o
> CC [M] /usr/src/backports-3.15-rc1-1/net/mac80211/tkip.o
> CC [M] /usr/src/backports-3.15-rc1-1/net/mac80211/aes_ccm.o
> CC [M] /usr/src/backports-3.15-rc1-1/net/mac80211/aes_cmac.o
> 
> 
> When I use backports-3.16-rc1 I get the same warnings:
> 
> CC [M] /usr/src/backports-3.16-rc1-1/net/mac80211/agg-rx.o
> CC [M] /usr/src/backports-3.16-rc1-1/net/mac80211/vht.o
> CC [M] /usr/src/backports-3.16-rc1-1/net/mac80211/ibss.o
> CC [M] /usr/src/backports-3.16-rc1-1/net/mac80211/iface.o
> /usr/src/backports-3.16-rc1-1/net/mac80211/iface.c:1099:2: warning:
> initialization from incompatible pointer type [enabled by default]
> .ndo_select_queue = ieee80211_netdev_select_queue,
> ^
> /usr/src/backports-3.16-rc1-1/net/mac80211/iface.c:1099:2: warning: (near
> initialization for ‘ieee80211_dataif_ops.ndo_select_queue’) [enabled by
> default]
> /usr/src/backports-3.16-rc1-1/net/mac80211/iface.c:1141:2: warning:
> initialization from incompatible pointer type [enabled by default]
> .ndo_select_queue = ieee80211_monitor_select_queue,
> ^
> /usr/src/backports-3.16-rc1-1/net/mac80211/iface.c:1141:2: warning: (near
> initialization for ‘ieee80211_monitorif_ops.ndo_select_queue’) [enabled by
> default]
> CC [M] /usr/src/backports-3.16-rc1-1/net/mac80211/rate.o
> CC [M] /usr/src/backports-3.16-rc1-1/net/mac80211/michael.o
> CC [M] /usr/src/backports-3.16-rc1-1/net/mac80211/tkip.o
> CC [M] /usr/src/backports-3.16-rc1-1/net/mac80211/aes_ccm.o
> ^Cmake[6]: *** [/usr/src/backports-3.16-rc1-1/net/mac80211/aes_ccm.o]
> Interrupt
> make[5]: *** [/usr/src/backports-3.16-rc1-1/net/mac80211] Interrupt
> make[4]: *** [_module_/usr/src/backports-3.16-rc1-1] Interrupt
> 
> 
> The reference in iface.c contains:
> #if LINUX_VERSION_CODE >= KERNEL_VERSION(3,15,0)
> static u16 ieee80211_netdev_select_queue(struct net_device *dev,
> struct sk_buff *skb,
> void *accel_priv,
> select_queue_fallback_t fallback)
> #elif LINUX_VERSION_CODE >= KERNEL_VERSION(3,13,0)
> static u16 ieee80211_netdev_select_queue(struct net_device *dev,
> struct sk_buff *skb,
> void *accel_priv)
> #else
> static u16 ieee80211_netdev_select_queue(struct net_device *dev,
> struct sk_buff *skb)
> #endif
> 
> The linux 3.13 net_device_ops structure has the following arguments for
> ndo_select_queue:
> struct net_device_ops {
> int (*ndo_init)(struct net_device *dev);
> void (*ndo_uninit)(struct net_device *dev);
> int (*ndo_open)(struct net_device *dev);
> int (*ndo_stop)(struct net_device *dev);
> netdev_tx_t (*ndo_start_xmit) (struct sk_buff *skb,
> struct net_device *dev);
> u16 (*ndo_select_queue)(struct net_device *dev,
> struct sk_buff *skb,
> void *accel_priv,
> select_queue_fallback_t fallback);
> 
> When I modify the ifdefs for the function to include the fallback argument,
> iface.c compiles without warnings. I accomplish this by changing the ifdef:
> 
> #if LINUX_VERSION_CODE >= KERNEL_VERSION(3,15,0)
> to
> 
> #if LINUX_VERSION_CODE >= KERNEL_VERSION(3,13,0)
> 
> 
> and the original select_queue function I modify the ifdef to:
> #if LINUX_VERSION_CODE >= KERNEL_VERSION(3,15,0)
> 
> 
> I also do this for the ieee80211_monitor_select_queue function definiations.
> 
> It looks like these conditionals are not aligned properly to the kernel
> versions.

No linux-3.13 has:

	u16                     (*ndo_select_queue)(struct net_device *dev,
						    struct sk_buff *skb,        
						    void *accel_priv);  

Now if Mint decided to cherry pick the commit that added the 
select_queue_fallback_t fallback argument that's on a distribution
specific kernel ABI change. We're try to help distributions do stupid
things like this by always overriding a routine with a backports prefix
but for data structures and functions like these its a bit harder so
the only to fix this is to have a Mint specific check and add that
as an exclusion here. You're welcome to add a patch if you can figure
out how to do that. RHEL has specific checks, look for RHEL_RELEASE_CODE
usage on backports as an example.

  Luis
--
To unsubscribe from this list: send the line "unsubscribe backports" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux]     [Linux OMAP]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux