diff options
Diffstat (limited to 'libre/vhba-module')
-rw-r--r-- | libre/vhba-module/60-vhba.rules | 1 | ||||
-rw-r--r-- | libre/vhba-module/PKGBUILD | 93 | ||||
-rw-r--r-- | libre/vhba-module/kmod.install | 20 |
3 files changed, 114 insertions, 0 deletions
diff --git a/libre/vhba-module/60-vhba.rules b/libre/vhba-module/60-vhba.rules new file mode 100644 index 000000000..39ae3a4ec --- /dev/null +++ b/libre/vhba-module/60-vhba.rules @@ -0,0 +1 @@ +ACTION=="add", KERNEL=="vhba_ctl", NAME="vhba_ctl", MODE="0660", OWNER="root", GROUP="cdemu", TAG+="uaccess" diff --git a/libre/vhba-module/PKGBUILD b/libre/vhba-module/PKGBUILD new file mode 100644 index 000000000..d14218281 --- /dev/null +++ b/libre/vhba-module/PKGBUILD @@ -0,0 +1,93 @@ +# Maintainer (Arch): Ray Rashif <schiv@archlinux.org> +# Contributor (Arch): Mateusz Herych <heniekk@gmail.com> +# Contributor (Arch): Charles Lindsay <charles@chaoslizard.org> +# Maintainer: André Silva <emulatorman@parabola.nu> +# Contributor: Luke Shumaker <lukeshu@sbcglobal.net> +# Contributor: Márcio Silva <coadde@parabola.nu> + +_kernelname= +_basekernel=3.16 +_archrel=6 +_parabolarel=1 + +if [[ ${_kernelname} == "" ]]; then + _basekernel=${_basekernel} + _archrel=${_archrel} + _parabolarel=${_parabolarel} +elif [[ ${_kernelname} == -lts ]]; then + _basekernel=3.14 + _archrel=${_archrel} + _parabolarel=${_parabolarel} +elif [[ ${_kernelname} == -grsec ]]; then + _basekernel=3.15 + _archrel=${_archrel} + _parabolarel=${_parabolarel} +elif [[ ${_kernelname} == -lts-grsec ]]; then + _basekernel=3.14 + _archrel=${_archrel} + _parabolarel=${_parabolarel} +elif [[ ${_kernelname} == -lts-knock ]]; then + _basekernel=3.10 + _archrel=${_archrel} + _parabolarel=${_parabolarel} +elif [[ ${_kernelname} == -rt ]]; then + _basekernel=3.14 + _archrel=${_archrel} + _parabolarel=${_parabolarel} +elif [[ ${_kernelname} == -pae ]]; then + _basekernel=${_basekernel} + _archrel=${_archrel} + _parabolarel=${_parabolarel} +elif [[ ${_kernelname} == -xen ]]; then + _basekernel=${_basekernel} + _archrel=${_archrel} + _parabolarel=${_parabolarel} +fi + +_pkgname=vhba-module +pkgname=${_pkgname}${_kernelname} +pkgver=20140629 +pkgrel=${_archrel}.parabola${_parabolarel}.basekernel${_basekernel} +_extramodules=extramodules-${_basekernel}${_kernelname} +pkgdesc="Kernel module that emulates SCSI devices (built for the linux-libre${_kernelname} kernel package)" +arch=('i686' 'x86_64' 'mips64el') +url="http://cdemu.sourceforge.net/" +license=('GPL') + +# Generic (you shouldn't have to modify any of these variables) +_toohigh=$(IFS=. read a b <<<$_basekernel; echo $a.$((b+1))) +depends=("linux-libre${_kernelname}>=${_basekernel}" "linux-libre${_kernelname}<${_toohigh}") +makedepends=("linux-libre${_kernelname}-headers>=${_basekernel}" "linux-libre${_kernelname}-headers<${_toohigh}") + +replaces=("${_pkgname}-libre${_kernelname}" "${_pkgname}-parabola${_kernelname}") +conflicts=("${_pkgname}-libre${_kernelname}" "${_pkgname}-parabola${_kernelname}") + +options=(!makeflags) +install='kmod.install' +source=("http://downloads.sourceforge.net/cdemu/$_pkgname-$pkgver.tar.bz2" + '60-vhba.rules') +md5sums=('6b307a80df9c163768cc7ecb3ccebb71' + '4dc37dc348b5a2c83585829bde790dcc') + +build() { + cd "${srcdir}/${_pkgname}-${pkgver}" + + _kernver="$(cat /usr/lib/modules/${_extramodules}/version)" + + make KDIR=/usr/lib/modules/$_kernver/build +} + +package() { + cd "${srcdir}/${_pkgname}-${pkgver}" + + # Actually install + install -Dm644 vhba.ko "$pkgdir/usr/lib/modules/$_extramodules/vhba.ko" + install -Dm644 ../60-vhba.rules "$pkgdir/usr/lib/udev/rules.d/60-vhba.rules" + + # Set the correct extramodules directory for install + cp -f "${startdir}/${install}" "${startdir}/${install}.pkg" + true && install=${install}.pkg + sed -i "s/^_EXTRAMODULES=.*/_EXTRAMODULES="${_extramodules}"/" "${startdir}/${install}" +} + +# vim:set ts=2 sw=2 et: diff --git a/libre/vhba-module/kmod.install b/libre/vhba-module/kmod.install new file mode 100644 index 000000000..08ecfbfba --- /dev/null +++ b/libre/vhba-module/kmod.install @@ -0,0 +1,20 @@ +_EXTRAMODULES= + +_post_install() { + echo ">>> Updating module dependencies. Please wait ..." + depmod "$(cat /usr/lib/modules/$_EXTRAMODULES/version)" >/dev/null 2>&1 +} + +post_install() { + _post_install + getent group cdemu &>/dev/null || groupadd -r cdemu +} + +post_upgrade() { + post_install +} + +post_remove() { + _post_install + groupdel cdemu +} |