- don't use handcrafted Makefile, it produces useless shit
- add blacklist configuration for conflicting drivers
+++ /dev/null
---- wl-6.30.223.248/src/wl/sys/wl_linux.c~ 2014-06-26 12:42:08.000000000 +0200
-+++ wl-6.30.223.248/src/wl/sys/wl_linux.c 2014-11-09 16:29:09.494680214 +0100
-@@ -1307,7 +1307,11 @@
- dev->priv = priv_link;
- #else
-
-+#if (LINUX_VERSION_CODE < KERNEL_VERSION(3, 17, 0))
- dev = alloc_netdev(sizeof(priv_link_t), intf_name, ether_setup);
-+#else
-+ dev = alloc_netdev(sizeof(priv_link_t), intf_name, NET_NAME_UNKNOWN, ether_setup);
-+#endif
- if (!dev) {
- WL_ERROR(("wl%d: %s: alloc_netdev failed\n",
- (wl->pub)?wl->pub->unit:wlif->subunit, __FUNCTION__));
--- /dev/null
+# wl module from Broadcom conflicts with ssb
+# We must blacklist the following modules:
+blacklist b43
+blacklist b43legacy
+blacklist b44
+blacklist bcma
+blacklist brcm80211
+blacklist brcmsmac
+blacklist ssb
# nothing to be placed to debuginfo package
%define _enable_debug_packages 0
# nothing to be placed to debuginfo package
%define _enable_debug_packages 0
+%define _duplicate_files_terminate_build 0
+
+%define rel 1
%define pname wl
%define file_ver %(echo %{version} | tr . _)
Summary: Broadcom 802.11 a/b/g/n hybrid Linux networking device driver
Name: %{pname}%{?_pld_builder:%{?with_kernel:-kernel}}%{_alt_kernel}
%define pname wl
%define file_ver %(echo %{version} | tr . _)
Summary: Broadcom 802.11 a/b/g/n hybrid Linux networking device driver
Name: %{pname}%{?_pld_builder:%{?with_kernel:-kernel}}%{_alt_kernel}
Release: %{rel}%{?_pld_builder:%{?with_kernel:@%{_kernel_ver_str}}}
License: other
Group: Base/Kernel
Source0: http://www.broadcom.com/docs/linux_sta/hybrid-v35-nodebug-pcoem-%{file_ver}.tar.gz
Release: %{rel}%{?_pld_builder:%{?with_kernel:@%{_kernel_ver_str}}}
License: other
Group: Base/Kernel
Source0: http://www.broadcom.com/docs/linux_sta/hybrid-v35-nodebug-pcoem-%{file_ver}.tar.gz
-# Source0-md5: e048154b3f4c7ad6bee36cab5b37486d
+# Source0-md5: 4e75f4cb7d87f690f9659ffc478495f0
Source1: http://www.broadcom.com/docs/linux_sta/hybrid-v35_64-nodebug-pcoem-%{file_ver}.tar.gz
Source1: http://www.broadcom.com/docs/linux_sta/hybrid-v35_64-nodebug-pcoem-%{file_ver}.tar.gz
-# Source1-md5: 0237917f75d121589ec16a44eac5f5b0
+# Source1-md5: 115903050c41d466161784d4c843f4f9
Source2: http://www.broadcom.com/docs/linux_sta/README.txt
# Source2-md5: 8a6e8708a5e00ab6d841cde51d70eb1b
Source3: dkms.conf
Source2: http://www.broadcom.com/docs/linux_sta/README.txt
# Source2-md5: 8a6e8708a5e00ab6d841cde51d70eb1b
Source3: dkms.conf
-Patch0: linux-3.17.patch
Patch1: gcc-4.9.patch
Patch2: no-dead-code.patch
URL: http://www.broadcom.com/support/802.11/linux_sta.php
Patch1: gcc-4.9.patch
Patch2: no-dead-code.patch
URL: http://www.broadcom.com/support/802.11/linux_sta.php
\
%files -n kernel%{_alt_kernel}-net-wl\
%defattr(644,root,root,755)\
\
%files -n kernel%{_alt_kernel}-net-wl\
%defattr(644,root,root,755)\
-%doc lib/LICENSE.txt README.txt\
+%doc wl/lib/LICENSE.txt README.txt\
/lib/modules/%{_kernel_ver}/kernel/drivers/net/wireless/*.ko*\
/lib/modules/%{_kernel_ver}/kernel/drivers/net/wireless/*.ko*\
+%config(noreplace) %verify(not md5 mtime size) /etc/modprobe.d/%{pname}.conf\
\
%post -n kernel%{_alt_kernel}-net-wl\
%depmod %{_kernel_ver}\
\
%post -n kernel%{_alt_kernel}-net-wl\
%depmod %{_kernel_ver}\
%{nil}
%define build_kernel_pkg()\
%{nil}
%define build_kernel_pkg()\
-%build_kernel_modules -m wl\
-%install_kernel_modules -D installed -m wl -d kernel/drivers/net/wireless\
+%{__make} -C wl KERNELRELEASE=%{_kernel_ver} KBUILD_DIR=%{_kernelsrcdir} clean\
+%{__make} -C wl KERNELRELEASE=%{_kernel_ver} KBUILD_DIR=%{_kernelsrcdir}\
+%install_kernel_modules -D installed -m wl/wl -d kernel/drivers/net/wireless\
%{nil}
%{?with_kernel:%{expand:%create_kernel_packages}}
%{nil}
%{?with_kernel:%{expand:%create_kernel_packages}}
%define src 0
%endif
%setup -c -T -q -n %{pname}-%{version} -b%{src}
%define src 0
%endif
%setup -c -T -q -n %{pname}-%{version} -b%{src}
-# cleanup backups after patching
-find '(' -name '*~' -o -name '*.orig' ')' -print0 | xargs -0 -r -l512 rm -f
-
+mkdir wl
+mv lib src Makefile wl/
-cat > Makefile << 'EOF'
-obj-m += wl.o
-
-wl-objs += src/wl/sys/wl_linux.o
-wl-objs += src/wl/sys/wl_iw.o
-wl-objs += src/shared/linux_osl.o
-
-EXTRA_CFLAGS += -I$(KBUILD_EXTMOD)/src/include
-EXTRA_CFLAGS += -I$(KBUILD_EXTMOD)/src/common/include
-EXTRA_CFLAGS += -I$(KBUILD_EXTMOD)/src/wl/sys
-EXTRA_CFLAGS += -I$(KBUILD_EXTMOD)/src/shared/bcmwifi/include
-
-EXTRA_LDFLAGS := $(KBUILD_EXTMOD)/lib/wlc_hybrid.o_shipped
-EOF
+# cleanup backups after patching
+find '(' -name '*~' -o -name '*.orig' ')' -print0 | xargs -0 -r -l512 rm -f
%build
%{?with_kernel:%{expand:%build_kernel_packages}}
%install
rm -rf $RPM_BUILD_ROOT
%build
%{?with_kernel:%{expand:%build_kernel_packages}}
%install
rm -rf $RPM_BUILD_ROOT
+install -d $RPM_BUILD_ROOT/etc/modprobe.d
+
%if %{with kernel}
install -d $RPM_BUILD_ROOT
cp -a installed/* $RPM_BUILD_ROOT
%if %{with kernel}
install -d $RPM_BUILD_ROOT
cp -a installed/* $RPM_BUILD_ROOT
+cp -p %{SOURCE4} $RPM_BUILD_ROOT/etc/modprobe.d/%{pname}.conf
%endif
%if %{with dkms}
install -d $RPM_BUILD_ROOT%{_usrsrc}/%{pname}-%{version}-%{rel}
%endif
%if %{with dkms}
install -d $RPM_BUILD_ROOT%{_usrsrc}/%{pname}-%{version}-%{rel}
-cp -a Makefile lib src $RPM_BUILD_ROOT%{_usrsrc}/%{pname}-%{version}-%{rel}
+cp -a wl/Makefile wl/lib wl/src $RPM_BUILD_ROOT%{_usrsrc}/%{pname}-%{version}-%{rel}
sed -e 's|@pname@|%{pname}|g' -e 's|@MODVERSION@|%{version}-%{rel}|g' \
%{SOURCE3} > $RPM_BUILD_ROOT%{_usrsrc}/%{pname}-%{version}-%{rel}/dkms.conf
%endif
sed -e 's|@pname@|%{pname}|g' -e 's|@MODVERSION@|%{version}-%{rel}|g' \
%{SOURCE3} > $RPM_BUILD_ROOT%{_usrsrc}/%{pname}-%{version}-%{rel}/dkms.conf
%endif