mirror of
https://github.com/flatcar/scripts.git
synced 2025-08-17 18:06:59 +02:00
sys-block/open-iscsi: Clean slate to reapply our changes
This commit is contained in:
parent
d21dfd4f93
commit
926b66861c
@ -11,7 +11,7 @@ SRC_URI="https://github.com/${PN}/${PN}/archive/${PV}.tar.gz -> ${P}.tar.gz"
|
|||||||
|
|
||||||
LICENSE="GPL-2"
|
LICENSE="GPL-2"
|
||||||
SLOT="0/0.2"
|
SLOT="0/0.2"
|
||||||
KEYWORDS="~alpha amd64 arm arm64 ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86"
|
KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86"
|
||||||
IUSE="debug infiniband libressl +tcp rdma systemd"
|
IUSE="debug infiniband libressl +tcp rdma systemd"
|
||||||
|
|
||||||
DEPEND="
|
DEPEND="
|
||||||
@ -37,9 +37,8 @@ PATCHES=(
|
|||||||
pkg_setup() {
|
pkg_setup() {
|
||||||
linux-info_pkg_setup
|
linux-info_pkg_setup
|
||||||
|
|
||||||
# Flatcar: use ewarn instead of die
|
|
||||||
if kernel_is -lt 2 6 16; then
|
if kernel_is -lt 2 6 16; then
|
||||||
ewarn "Sorry, your kernel must be 2.6.16-rc5 or newer!"
|
die "Sorry, your kernel must be 2.6.16-rc5 or newer!"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Needs to be done, as iscsid currently only starts, when having the iSCSI
|
# Needs to be done, as iscsid currently only starts, when having the iSCSI
|
||||||
@ -47,19 +46,34 @@ pkg_setup() {
|
|||||||
# more information:
|
# more information:
|
||||||
# https://groups.google.com/group/open-iscsi/browse_thread/thread/cc10498655b40507/fd6a4ba0c8e91966
|
# https://groups.google.com/group/open-iscsi/browse_thread/thread/cc10498655b40507/fd6a4ba0c8e91966
|
||||||
# If there's a new release, check whether this is still valid!
|
# If there's a new release, check whether this is still valid!
|
||||||
CONFIG_MODULES="SCSI_ISCSI_ATTRS ISCSI_TCP"
|
TCP_MODULES="SCSI_ISCSI_ATTRS ISCSI_TCP"
|
||||||
|
RDMA_MODULES="INFINIBAND_ISER"
|
||||||
|
INFINIBAND_MODULES="INFINIBAND_IPOIB INIBAND_USER_MAD INFINIBAND_USER_ACCESS"
|
||||||
|
CONFIG_CHECK_MODULES="tcp? ( ${TCP_MODULES} ) rdma? ( ${RDMA_MODULES} ) infiniband? ( ${INFINIBAND_MODULES} )"
|
||||||
if linux_config_exists; then
|
if linux_config_exists; then
|
||||||
for module in ${CONFIG_CHECK_MODULES}; do
|
if use tcp; then
|
||||||
|
for module in ${TCP_MODULES}; do
|
||||||
linux_chkconfig_module ${module} || ewarn "${module} needs to be built as module (builtin doesn't work)"
|
linux_chkconfig_module ${module} || ewarn "${module} needs to be built as module (builtin doesn't work)"
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
if use infiniband; then
|
||||||
|
for module in ${INFINIBAND_MODULES}; do
|
||||||
|
linux_chkconfig_module ${module} || ewarn "${module} needs to be built as module (builtin doesn't work)"
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
if use rdma; then
|
||||||
|
for module in ${RDMA_MODULES}; do
|
||||||
|
linux_chkconfig_module ${module} || ewarn "${module} needs to be built as module (builtin doesn't work)"$
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
src_prepare() {
|
src_prepare() {
|
||||||
sed -e 's:^\(iscsid.startup\)\s*=.*:\1 = /usr/sbin/iscsid:' \
|
sed -e 's:^\(iscsid.startup\)\s*=.*:\1 = /usr/sbin/iscsid:' \
|
||||||
-i etc/iscsid.conf || die
|
-i etc/iscsid.conf || die
|
||||||
sed -e 's:^node.startup = manual:node.startup = automatic:' \
|
sed -e '/[^usr]\/sbin/s@\(/sbin/\)@/usr\1@' \
|
||||||
-i etc/iscsid.conf || die
|
-i etc/systemd/iscsi* || die
|
||||||
default
|
default
|
||||||
|
|
||||||
pushd iscsiuio >/dev/null || die
|
pushd iscsiuio >/dev/null || die
|
||||||
@ -73,9 +87,9 @@ src_configure() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
src_compile() {
|
src_compile() {
|
||||||
use debug && append-flags -DDEBUG_TCP -DDEBUG_SCSI
|
# Stuffing CPPFLAGS into CFLAGS isn't entirely correct, but the build
|
||||||
|
# is messed up already here, so it's not making it that much worse.
|
||||||
CFLAGS="" \
|
KSRC="${KV_DIR}" CFLAGS="" \
|
||||||
emake \
|
emake \
|
||||||
OPTFLAGS="${CFLAGS} ${CPPFLAGS} $(usex systemd '' -DNO_SYSTEMD)" \
|
OPTFLAGS="${CFLAGS} ${CPPFLAGS} $(usex systemd '' -DNO_SYSTEMD)" \
|
||||||
AR="$(tc-getAR)" CC="$(tc-getCC)" \
|
AR="$(tc-getAR)" CC="$(tc-getCC)" \
|
||||||
@ -84,28 +98,43 @@ src_compile() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
src_install() {
|
src_install() {
|
||||||
emake DESTDIR="${D}" sbindir="/usr/sbin" install
|
emake DESTDIR="${ED}" sbindir="/usr/sbin" install
|
||||||
# Upstream make is not deterministic, per bug #601514
|
# Upstream make is not deterministic, per bug #601514
|
||||||
rm -f "${D}"/etc/initiatorname.iscsi
|
rm -f "${ED}"/etc/initiatorname.iscsi
|
||||||
|
|
||||||
dodoc README THANKS
|
dodoc README THANKS
|
||||||
|
|
||||||
docinto test/
|
docinto test/
|
||||||
dodoc $(find test -maxdepth 1 -type f ! -name ".*")
|
dodoc $(find test -maxdepth 1 -type f ! -name ".*")
|
||||||
|
|
||||||
|
insinto /etc/iscsi
|
||||||
|
newins "${FILESDIR}"/initiatorname.iscsi initiatorname.iscsi.example
|
||||||
|
|
||||||
|
newconfd "${FILESDIR}"/iscsid-conf.d iscsid
|
||||||
|
newinitd "${FILESDIR}"/iscsid-init.d iscsid
|
||||||
|
|
||||||
local unit
|
local unit
|
||||||
local units=(
|
local units=(
|
||||||
iscsi.service
|
iscsi{,-init}.service
|
||||||
iscsid.{service,socket}
|
iscsid.{service,socket}
|
||||||
iscsiuio.{service,socket}
|
iscsiuio.{service,socket}
|
||||||
)
|
)
|
||||||
for unit in ${units[@]} ; do
|
for unit in ${units[@]} ; do
|
||||||
systemd_dounit etc/systemd/${unit}
|
systemd_dounit etc/systemd/${unit}
|
||||||
done
|
done
|
||||||
systemd_dounit "${FILESDIR}"/iscsi-init.service
|
|
||||||
systemd_dotmpfilesd "${FILESDIR}"/open-iscsi.conf
|
|
||||||
|
|
||||||
|
keepdir /var/db/iscsi
|
||||||
|
fperms 700 /var/db/iscsi
|
||||||
fperms 600 /etc/iscsi/iscsid.conf
|
fperms 600 /etc/iscsi/iscsid.conf
|
||||||
rm "${D}"/etc/iscsi/initiatorname.iscsi
|
}
|
||||||
mv "${D}"/etc/iscsi "${D}"/usr/share/iscsi
|
|
||||||
|
pkg_postinst() {
|
||||||
|
in='/etc/iscsi/initiatorname.iscsi'
|
||||||
|
if [[ ! -f "${EROOT}${in}" ]] && [[ -f "${EROOT}${in}.example" ]] ; then
|
||||||
|
{
|
||||||
|
cat "${EROOT}${in}.example"
|
||||||
|
echo "# InitiatorName generated by ${CATEGORY}/${PF} at $(date -uR)"
|
||||||
|
echo "InitiatorName=$(${ROOT}/usr/sbin/iscsi-iname)"
|
||||||
|
} >> "${EROOT}${in}.tmp" && mv -f "${EROOT}${in}.tmp" "${EROOT}${in}"
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user