]> git.pld-linux.org Git - packages/eagle-usb.git/blobdiff - eagle-usb.spec
- converted to UTF-8
[packages/eagle-usb.git] / eagle-usb.spec
index a3990e6eb6820a7b923c05ed24411fb4f9c39abf..71fbf7f67cb0f8e67a99779f0c3ef75018280851 100644 (file)
 #
+# TODO:
+#              - utils/scripts, eagleconfig
+#
 # Conditional build:
-# _without_dist_kernel         without distribution kernel
+%bcond_without dist_kernel     # without distribution kernel
+%bcond_without kernel          # don't build kernel modules
+%bcond_without smp             # don't build SMP module
+%bcond_without up              # don't build UP module
+%bcond_without userspace       # don't build userspace tools
+%bcond_without cmvs
+%bcond_with    verbose         # verbose build (V=1)
+%bcond_with    grsec_kernel    # build for kernel-grsecurity
+#
+%if %{with kernel} && %{with dist_kernel} && %{with grsec_kernel}
+%define        alt_kernel      grsecurity
+%endif
 #
-%define                _orig_name      fast800
-Summary:       Linux driver for the Eagle 8051 Analog (sagem f@st 800...) modems
-Summary(pl):   Sterownik dla Linuksa do modemów Eagle 8051 Analog (sagem f@st 800...)
-Name:          eagle
-Version:       1.0.4
-%define        _rel    4
+%ifarch sparc
+# no USB in sparc(32) kernel; just build userspace to use with sparc64 kernel
+%undefine      with_kernel
+%endif
+%define                _rel    4
+Summary:       Linux driver for the Eagle 8051 Analog (sagem f@st 800/840/908/...) modems
+Summary(pl.UTF-8):   Sterownik dla Linuksa do modemów Eagle 8051 Analog (sagem f@st 800/840/908/...)
+Name:          eagle-usb
+Version:       2.3.3
 Release:       %{_rel}
-License:       GPL
+License:       GPL v2
 Group:         Base/Kernel
-Source0:       http://fast800.tuxfamily.org/pub/IMG/gz/%{name}-%{version}.tar.gz
-# Source0-md5: fc52cf1eff6ab9f20e9c2cb3e7e2f1e8
-Source2:    %{name}.init
-Patch0:                %{name}-Makefile.patch
-Patch1:                %{name}-firmware.patch
-URL:           http://fast800.tuxfamily.org/
-%{!?_without_dist_kernel:BuildRequires:        kernel-headers }
-BuildRequires: %{kgcc_package}
-BuildRequires: rpmbuild(macros) >= 1.118
-Requires(post,postun): /sbin/depmod
-Requires(post,postun): /sbin/update-usb.usermap
-Requires(post,postun): /sbin/chkconfig
+Source0:       http://download.gna.org/eagleusb/eagle-usb-2.3.0/%{name}-%{version}.tar.bz2
+# Source0-md5: 6c961a5022274aff870e49e2f0f922fc
+Patch1:                %{name}-eu_types.patch
+Patch2:                %{name}-vpivci-info.patch
+Patch3:                %{name}-opt.patch
+Patch4:                %{name}-signal.patch
+Patch5:                %{name}-usb_kill_urb.patch
+Patch6:                %{name}-kernel_sources_checking_hack.patch
+# Workaround for obsolete kernel API. To be removed...
+Patch7:                %{name}-spin_lock_unlocked.patch
+Patch8:                %{name}-kill_owner.patch
+Patch9:                %{name}-module_param.patch
+URL:           http://gna.org/projects/eagleusb/
+BuildRequires: autoconf
+BuildRequires: automake
+%if %{with kernel}
+%{?with_dist_kernel:BuildRequires:     kernel%{_alt_kernel}-module-build >= 3:2.6.7}
+BuildRequires: rpmbuild(macros) >= 1.330
+%endif
+BuildRequires: SysVinit
+BuildRequires: net-tools
 Requires:      ppp >= 2.4.1
-Requires:      hotplug
+Obsoletes:     eagle-utils
+Conflicts:     eagle-usb24
 BuildRoot:     %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
 
 %description
-Linux driver for the Eagle 8051 Analog (sagem f@st 800...) modems.
+Linux driver for the Eagle 8051 Analog (sagem f@st 800/840/908/...)
+modems.
 
-%description -l pl
-Sterownik dla Linuksa do modemów Eagle 8051 Analog (sagem f@st
-800...).
+%description -l pl.UTF-8
+Sterownik dla Linuksa do modemów Eagle 8051 Analog (sagem f@st
+800/840/908/...).
 
-%package -n kernel-usb-%{_orig_name}
-Summary:       Linux driver for the Eagle 8051 Analog (sagem f@st 800...) modems
-Summary(pl):   Sterownik dla Linuksa do modemów Eagle 8051 Analog (sagem f@st 800...)
+%package -n kernel%{_alt_kernel}-usb-eagle
+Summary:       Linux driver for the Eagle 8051 Analog (sagem f@st 800/840/908/...) modems
+Summary(pl.UTF-8):   Sterownik dla Linuksa do modemów Eagle 8051 Analog (sagem f@st 800/840/908/...)
 Release:       %{_rel}@%{_kernel_ver_str}
 Group:         Base/Kernel
-%{!?_without_dist_kernel:%requires_releq_kernel_up}
+%{?with_dist_kernel:%requires_releq_kernel_up}
 Requires(post,postun): /sbin/depmod
-Requires(post,postun): /sbin/update-usb.usermap
-
-%description -n kernel-usb-%{_orig_name}
-Linux driver for the Eagle 8051 Analog (sagem f@st 800...) modems.
-
-%description -n kernel-usb-%{_orig_name} -l pl
-Sterownik dla Linuksa do modemów Eagle 8051 Analog (sagem f@st
-800...).
-
-%package -n kernel-smp-usb-%{_orig_name}
-Summary:       Linux SMP driver for the Eagle 8051 Analog (sagem f@st 800...) modems
-Summary(pl):   Sterownik dla Linuksa SMP do modemów Eagle 8051 Analog (sagem f@st 800...)
+Provides:      kernel-usb(eagle) = %{version}-%{_rel}
+%if "%{_alt_kernel}" == "%{_nil}"
+Obsoletes:     kernel-usb-fast800
+%endif
+
+%description -n kernel%{_alt_kernel}-usb-eagle
+Linux driver for the Eagle 8051 Analog (sagem f@st 800/840/908/...)
+modems.
+
+%description -n kernel%{_alt_kernel}-usb-eagle -l pl.UTF-8
+Sterownik dla Linuksa do modemów Eagle 8051 Analog (sagem f@st
+800/840/908/...).
+
+%package -n kernel%{_alt_kernel}-smp-usb-eagle
+Summary:       Linux SMP driver for the Eagle 8051 Analog (sagem f@st 800/840/908/...) modems
+Summary(pl.UTF-8):   Sterownik dla Linuksa SMP do modemów Eagle 8051 Analog (sagem f@st 800/840/908/...)
 Release:       %{_rel}@%{_kernel_ver_str}
 Group:         Base/Kernel
-%{!?_without_dist_kernel:%requires_releq_kernel_smp}
+%{?with_dist_kernel:%requires_releq_kernel_smp}
 Requires(post,postun): /sbin/depmod
-Requires(post,postun): /sbin/update-usb.usermap
+Provides:      kernel-usb(eagle) = %{version}-%{_rel}
+%if "%{_alt_kernel}" == "%{_nil}"
+Obsoletes:     kernel-smp-usb-fast800
+%endif
 
-%description -n kernel-smp-usb-%{_orig_name}
-Linux SMP driver for the Eagle 8051 Analog (sagem f@st 800...) modems.
+%description -n kernel%{_alt_kernel}-smp-usb-eagle
+Linux SMP driver for the Eagle 8051 Analog (sagem f@st
+800/840/908/...) modems.
 
-%description -n kernel-smp-usb-%{_orig_name} -l pl
-Sterownik dla Linuksa SMP do modemów Eagle 8051 Analog (sagem f@st
-800...).
+%description -n kernel%{_alt_kernel}-smp-usb-eagle -l pl.UTF-8
+Sterownik dla Linuksa SMP do modemów Eagle 8051 Analog (sagem f@st
+800/840/908/...).
 
 %prep
 %setup -q
-%patch0 -p1
 %patch1 -p1
+%patch2 -p1
+%patch3 -p1
+%patch4 -p1
+%patch5 -p1
+%patch6 -p1
+%patch7 -p1
+%patch8 -p1
+%patch9 -p1
+
+%ifnarch %{ix86}
+# invalid not only for ppc
+sed -i 's/-mpreferred-stack-boundary=2//' driver/Makefile
+%endif
 
 %build
-install -d kernel-{up,smp}
-
-# UP
-%{__make} clean
-%{__make} -C driver \
-       CC=%{kgcc} \
-       KERNELSRC="%{_kernelsrcdir}"
-install driver/adiusbadsl.o kernel-up
-
-# SMP
-CONFIG_SMP=y; export CONFIG_SMP
-%{__make} -C driver clean
-%{__make} -e -C driver \
-       CC=%{kgcc} \
-       KERNELSRC="%{_kernelsrcdir}"
-install driver/adiusbadsl.o kernel-smp/
-
-# Rest
-%{__make} \
-       KERNELSRC="%{_kernelsrcdir}"
+%if %{with kernel}
+%build_kernel_modules -C driver -m eagle-usb \
+       USE_CMVS=%{?with_cmvs:1}%{!?with_cmvs:0}
+%endif
+
+%if %{with userspace}
+%{__aclocal} -I .
+%{__autoconf}
+%configure \
+       %{!?with_cmvs:--disable-cmvs} \
+       --with-dsp-dir=%{_datadir}/misc
+
+%{__make} -C driver/firmware \
+       CC="%{__cc}" \
+       OPT="%{rpmcflags}"
+%{__make} -C driver/user \
+       CC="%{__cc}" \
+       OPT="%{rpmcflags}"
+%{__make} -C pppoa \
+       CC="%{__cc}" \
+       OPT="%{rpmcflags}"
+%endif
 
 %install
 rm -rf $RPM_BUILD_ROOT
-install -d $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}/kernel/drivers/usb
-install -d $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}smp/kernel/drivers/usb
-install -d $RPM_BUILD_ROOT/etc/{analog,hotplug,ppp,rc.d/init.d}
-install -d $RPM_BUILD_ROOT{%{_sbindir},%{_libdir}/hotplug/%{name}}
-
-install kernel-up/*.o $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}/kernel/drivers/usb
-install kernel-smp/*.o $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}smp/kernel/drivers/usb
 
-install scripts/hotplug/usb.usermap $RPM_BUILD_ROOT%{_libdir}/hotplug/%{name}
+%if %{with kernel}
+%install_kernel_modules -m driver/eagle-usb -d kernel/drivers/usb/net
+%endif
 
+%if %{with userspace}
+install -d $RPM_BUILD_ROOT%{_sysconfdir}/{analog,hotplug,ppp} \
+       $RPM_BUILD_ROOT{%{_sbindir},%{_libdir}/hotplug/eagle}
 %{__make} -C driver/firmware install \
-       CONFIGDIR=$RPM_BUILD_ROOT/etc/analog \
-       DESTDIR=$RPM_BUILD_ROOT
+       EU_DSP_DIR=$RPM_BUILD_ROOT%{_datadir}/misc
 %{__make} -C driver/user install \
-       INSTALLDIR=%{_sbindir} \
-       CONFIGDIR=/etc/analog \
-       DESTDIR=$RPM_BUILD_ROOT
-install pppoa/pppoa $RPM_BUILD_ROOT%{_sbindir}
-echo 'n
-
-
-n
-n
-' | %{__make} -C scripts install \
-       INSTALLDIR=%{_sbindir} \
-       CONFIGDIR=/etc/analog \
-       HOTPLUGDIR=/etc/hotplug \
-       PPPDIR=/etc/ppp \
-       DESTDIR=$RPM_BUILD_ROOT
-
-install %{SOURCE2}  $RPM_BUILD_ROOT/etc/rc.d/init.d/%{name}    
+       EU_DIR=$RPM_BUILD_ROOT%{_sysconfdir}/eagle-usb \
+       EU_SCRIPT_DIR=$RPM_BUILD_ROOT%{_sysconfdir}/eagle-usb \
+       SBINDIR=$RPM_BUILD_ROOT%{_sbindir}
+mv $RPM_BUILD_ROOT%{_sysconfdir}/eagle-usb/eagle-usb.conf{.template,}
+%{__make} -C pppoa install \
+       SBINDIR=$RPM_BUILD_ROOT%{_sbindir}
+%endif
 
 %clean
 rm -rf $RPM_BUILD_ROOT
 
-%post
-[ -x /sbin/update-usb.usermap ] && /sbin/update-usb.usermap
-/sbin/chkconfig --add %{name}
-if [ -f /var/lock/subsys/%{name} ]; then
-    /etc/rc.d/init.d/%{name} restart 1>&2
-    else
-        echo \
-        "Run \"/etc/rc.d/init.d/%{name} start\" to start internet connection."
-fi
-
-%postun
-[ -x /sbin/update-usb.usermap ] && /sbin/update-usb.usermap
-if [ "$1" = "0" ]; then
-    if [ -f /var/lock/subsys/%{name} ]; then
-        /etc/rc.d/init.d/%{name} stop 1>&2
-    fi
-    /sbin/chkconfig --del %{name}
-fi
-
-%post -n kernel-usb-%{_orig_name}
+%post -n kernel%{_alt_kernel}-usb-eagle
 %depmod %{_kernel_ver}
-[ -x /sbin/update-usb.usermap ] && /sbin/update-usb.usermap
 
-%postun -n kernel-usb-%{_orig_name}
+%postun -n kernel%{_alt_kernel}-usb-eagle
 %depmod %{_kernel_ver}
-[ -x /sbin/update-usb.usermap ] && /sbin/update-usb.usermap
 
-%post  -n kernel-smp-usb-%{_orig_name}
+%post -n kernel%{_alt_kernel}-smp-usb-eagle
 %depmod %{_kernel_ver}smp
-[ -x /sbin/update-usb.usermap ] && /sbin/update-usb.usermap
 
-%postun -n kernel-smp-usb-%{_orig_name}
+%postun -n kernel%{_alt_kernel}-smp-usb-eagle
 %depmod %{_kernel_ver}smp
-[ -x /sbin/update-usb.usermap ] && /sbin/update-usb.usermap
 
+%if %{with userspace}
 %files
 %defattr(644,root,root,755)
-%doc BUGS Changelog FAQ TODO readme.txt
-%dir %{_sysconfdir}/analog
-%config(noreplace) %verify(not size mtime md5) %{_sysconfdir}/analog/adiusbadsl.conf
-%{_sysconfdir}/analog/CMV*
-%attr(755,root,root) %{_sysconfdir}/hotplug/usb/*
-%{_libdir}/hotplug/%{name}
-%config(noreplace) %verify(not size mtime md5) %{_sysconfdir}/ppp/*.adsl
+%doc README
+%dir %{_sysconfdir}/eagle-usb
+%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/eagle-usb/eagle-usb.conf
+%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/eagle-usb/*.txt
 %attr(755,root,root) %{_sbindir}/*
 %{_datadir}/misc/*.bin
-%attr(754,root,root) /etc/rc.d/init.d/%{name}
+%endif
 
-%files -n kernel-usb-%{_orig_name}
+%if %{with kernel}
+%files -n kernel%{_alt_kernel}-usb-eagle
 %defattr(644,root,root,755)
-%doc readme.txt
-/lib/modules/%{_kernel_ver}/kernel/drivers/usb/*
+/lib/modules/%{_kernel_ver}/kernel/drivers/usb/net/*.ko*
 
-%files -n kernel-smp-usb-%{_orig_name}
+%if %{with smp} && %{with dist_kernel}
+%files -n kernel%{_alt_kernel}-smp-usb-eagle
 %defattr(644,root,root,755)
-%doc readme.txt
-/lib/modules/%{_kernel_ver}smp/kernel/drivers/usb/*
+/lib/modules/%{_kernel_ver}smp/kernel/drivers/usb/net/*.ko*
+%endif
+%endif
This page took 0.119136 seconds and 4 git commands to generate.