]> TLD Linux GIT Repositories - packages/mdadm.git/commitdiff
- updated to 4.1, partial merge from PLD
authorMarcin Krol <hawk@tld-linux.org>
Tue, 4 Dec 2018 08:26:17 +0000 (08:26 +0000)
committerMarcin Krol <hawk@tld-linux.org>
Tue, 4 Dec 2018 08:26:17 +0000 (08:26 +0000)
mdadm-udev-rules-paths.patch
mdadm.spec

index 439dc4dd28cfb29e9e52efcc5eb2a4a5aeacfe81..00d34c8d78edb1a85eb5b8d9141bbad4bad2f1f1 100644 (file)
@@ -1,5 +1,22 @@
---- udev-md-raid-arrays.rules.orig     2015-08-03 06:17:13.000000000 +0000
-+++ udev-md-raid-arrays.rules  2015-09-01 08:57:31.874593251 +0000
+diff -ur mdadm-4.1.orig/udev-md-clustered-confirm-device.rules mdadm-4.1/udev-md-clustered-confirm-device.rules
+--- mdadm-4.1.orig/udev-md-clustered-confirm-device.rules      2018-10-01 18:26:06.000000000 +0000
++++ mdadm-4.1/udev-md-clustered-confirm-device.rules   2018-12-04 08:16:15.690403000 +0000
+@@ -13,9 +13,9 @@
+ # Based on the received UUID, node confirms the device if
+ # it is found by blkid, otherwise the node reports it is
+ # missing.
+-PROGRAM="BINDIR/blkid -o device -t UUID_SUB=$env{DEVICE_UUID}", ENV{.md.newdevice} = "$result"
++PROGRAM="/sbin/blkid -o device -t UUID_SUB=$env{DEVICE_UUID}", ENV{.md.newdevice} = "$result"
+-ENV{.md.newdevice}!="", RUN+="BINDIR/mdadm --manage $env{DEVNAME} --cluster-confirm $env{RAID_DISK}:$env{.md.newdevice}"
+-ENV{.md.newdevice}=="", RUN+="BINDIR/mdadm --manage $env{DEVNAME} --cluster-confirm $env{RAID_DISK}:missing"
++ENV{.md.newdevice}!="", RUN+="/sbin/mdadm --manage $env{DEVNAME} --cluster-confirm $env{RAID_DISK}:$env{.md.newdevice}"
++ENV{.md.newdevice}=="", RUN+="/sbin/mdadm --manage $env{DEVNAME} --cluster-confirm $env{RAID_DISK}:missing"
+ LABEL="clustermd_end"
+diff -ur mdadm-4.1.orig/udev-md-raid-arrays.rules mdadm-4.1/udev-md-raid-arrays.rules
+--- mdadm-4.1.orig/udev-md-raid-arrays.rules   2018-10-01 18:26:06.000000000 +0000
++++ mdadm-4.1/udev-md-raid-arrays.rules        2018-12-04 08:16:51.490403000 +0000
 @@ -17,7 +17,7 @@
  ATTR{md/array_state}=="|clear|inactive", ENV{SYSTEMD_READY}="0", GOTO="md_end"
  LABEL="md_ignore_state"
 +ENV{MD_MON_THIS}=="?*", PROGRAM="/bin/basename $env{MD_MON_THIS}", ENV{SYSTEMD_WANTS}+="mdmon@%c.service"
  
  LABEL="md_end"
+diff -ur mdadm-4.1.orig/udev-md-raid-assembly.rules mdadm-4.1/udev-md-raid-assembly.rules
+--- mdadm-4.1.orig/udev-md-raid-assembly.rules 2018-10-01 18:26:06.000000000 +0000
++++ mdadm-4.1/udev-md-raid-assembly.rules      2018-12-04 08:17:07.490403000 +0000
+@@ -30,9 +30,9 @@
+ # remember you can limit what gets auto/incrementally assembled by
+ # mdadm.conf(5)'s 'AUTO' and selectively whitelist using 'ARRAY'
+-ACTION=="add|change", IMPORT{program}="BINDIR/mdadm --incremental --export $devnode --offroot $env{DEVLINKS}"
++ACTION=="add|change", IMPORT{program}="/sbin/mdadm --incremental --export $devnode --offroot $env{DEVLINKS}"
+ ACTION=="add|change", ENV{MD_STARTED}=="*unsafe*", ENV{MD_FOREIGN}=="no", ENV{SYSTEMD_WANTS}+="mdadm-last-resort@$env{MD_DEVICE}.timer"
+-ACTION=="remove", ENV{ID_PATH}=="?*", RUN+="BINDIR/mdadm -If $name --path $env{ID_PATH}"
+-ACTION=="remove", ENV{ID_PATH}!="?*", RUN+="BINDIR/mdadm -If $name"
++ACTION=="remove", ENV{ID_PATH}=="?*", RUN+="/sbin/mdadm -If $name --path $env{ID_PATH}"
++ACTION=="remove", ENV{ID_PATH}!="?*", RUN+="/sbin/mdadm -If $name"
+ LABEL="md_inc_end"
index 7f0b026189ea8dceab408f20fcfb5388b373aca4..b481aa644f56c80c18d3341efe51e866fc202708 100644 (file)
@@ -7,20 +7,23 @@
 Summary:       Tool for creating and maintaining software RAID devices
 Summary(pl.UTF-8):     Narzędzie do tworzenia i obsługi programowych macierzy RAID
 Name:          mdadm
-Version:       4.0
+Version:       4.1
 Release:       1
 License:       GPL v2+
 Group:         Base
 Source0:       https://www.kernel.org/pub/linux/utils/raid/mdadm/%{name}-%{version}.tar.xz
-# Source0-md5: 2cb4feffea9167ba71b5f346a0c0a40d
+# Source0-md5: 51bf3651bd73a06c413a2f964f299598
 Source1:       %{name}.init
 Source2:       %{name}.sysconfig
 Source3:       %{name}.cron
 Source4:       %{name}-checkarray
 Patch0:                %{name}-udev-rules-paths.patch
 URL:           https://www.kernel.org/pub/linux/utils/raid/mdadm/
+BuildRequires: dlm-devel
 BuildRequires: groff
-BuildRequires: rpmbuild(macros) >= 1.213
+BuildRequires: rpmbuild(macros) >= 1.671
+BuildRequires: tar >= 1:1.22
+BuildRequires: xz
 %if %{with initrd}
        %if %{with dietlibc}
 BuildRequires: dietlibc-static
@@ -28,13 +31,10 @@ BuildRequires:      dietlibc-static
 BuildRequires: glibc-static
        %endif
 %endif
-BuildRequires: rpmbuild(macros) >= 1.268
-BuildRequires: tar >= 1:1.22
-BuildRequires: xz
 Requires(post,preun):  /sbin/chkconfig
 Requires:      /sbin/chkconfig
 Requires:      rc-scripts >= 0.4.2.4-2
-Suggests:      crondaemon
+Suggests:      cronjobs
 %{!?with_initrd:Obsoletes:     mdadm-initrd < %{version}-%{release}}
 Obsoletes:     mdctl
 BuildRoot:     %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
@@ -67,7 +67,7 @@ skonsolidowane na potrzeby initrd.
 
 %prep
 %setup -q
-%patch0 -p0
+%patch0 -p1
 
 %build
 %if %{with initrd}
@@ -75,38 +75,17 @@ skonsolidowane na potrzeby initrd.
 %{__make} mdadm \
        CC="diet %{__cc} %{rpmcflags} %{rpmcppflags} %{rpmldflags} -Os -static" \
        CWFLAGS="-Wall"
-mv -f mdadm initrd-mdadm
-%{__make} clean
-diet %{__cc} -DUCLIBC -DMDASSEMBLE_AUTO -DMDASSEMBLE %{rpmcflags} %{rpmcppflags} %{rpmldflags} -Os -static \
-       -o initrd-mdassemble \
-       mdassemble.c Assemble.c Manage.c config.c policy.c dlink.c util.c lib.c \
-       super0.c super1.c super-ddf.c super-intel.c sha1.c crc32.c sg_io.c mdstat.c \
-       platform-intel.c probe_roms.c sysfs.c super-mbr.c super-gpt.c mdopen.c maps.c xmalloc.c
+%{__mv} mdadm initrd-mdadm
 %else
 %{__make} mdadm.static \
        CC="%{__cc}" \
        CFLAGS="%{rpmcflags} %{rpmcppflags}" \
        LDFLAGS="%{rpmldflags}"
-mv -f mdadm.static initrd-mdadm
-%{__make} clean
-%{__cc} -DMDASSEMBLE_AUTO -DMDASSEMBLE %{rpmcflags} %{rpmcppflags} %{rpmldflags} -DHAVE_STDINT_H -static \
-       -o initrd-mdassemble \
-       mdassemble.c Assemble.c Manage.c config.c policy.c dlink.c util.c lib.c \
-       super0.c super1.c super-ddf.c super-intel.c sha1.c crc32.c sg_io.c mdstat.c \
-       platform-intel.c probe_roms.c sysfs.c super-mbr.c super-gpt.c mdopen.c maps.c xmalloc.c
+%{__mv} mdadm.static initrd-mdadm
 %endif
 %{__make} clean
 %endif
 
-%{__make} mdassemble \
-       MDASSEMBLE_AUTO=1 \
-       CC="%{__cc}" \
-       CFLAGS="%{rpmcflags} %{rpmcppflags}" \
-       LDFLAGS="%{rpmldflags}" \
-       SYSCONFDIR="%{_sysconfdir}"
-mv mdassemble regular-mdassemble
-%{__make} clean
-
 %{__make} all mdadm mdadm.8 \
        CC="%{__cc}" \
        CFLAGS="%{rpmcflags} %{rpmcppflags}" \
@@ -117,21 +96,18 @@ mv mdassemble regular-mdassemble
 
 %install
 rm -rf $RPM_BUILD_ROOT
-install -d $RPM_BUILD_ROOT{%{_sbindir},%{_mandir}/man{5,8},/etc/{rc.d/init.d,sysconfig,cron.d},/lib/udev/rules.d}
+install -d $RPM_BUILD_ROOT{%{_sbindir},%{_mandir}/man{5,8}} \
+       $RPM_BUILD_ROOT/etc/{rc.d/init.d,sysconfig,cron.d}
+
+%{__make} install install-udev \
+       DESTDIR=$RPM_BUILD_ROOT
 
 %if %{with initrd}
 install -d $RPM_BUILD_ROOT%{_libdir}/initrd
 install -p initrd-mdadm $RPM_BUILD_ROOT%{_libdir}/initrd/mdadm
-install -p initrd-mdassemble $RPM_BUILD_ROOT%{_libdir}/initrd/mdassemble
 ln -s mdadm $RPM_BUILD_ROOT%{_libdir}/initrd/mdctl
 %endif
 
-install -p regular-mdassemble $RPM_BUILD_ROOT%{_sbindir}/mdassemble
-install -p mdadm $RPM_BUILD_ROOT%{_sbindir}
-
-cp -p md*.5 $RPM_BUILD_ROOT%{_mandir}/man5
-cp -p md*.8 $RPM_BUILD_ROOT%{_mandir}/man8
-
 cp -p mdadm.conf-example $RPM_BUILD_ROOT%{_sysconfdir}/mdadm.conf
 
 ln -s mdadm $RPM_BUILD_ROOT%{_sbindir}/mdctl
@@ -142,8 +118,6 @@ cp -p %{SOURCE2} $RPM_BUILD_ROOT/etc/sysconfig/%{name}
 cp -p %{SOURCE3} $RPM_BUILD_ROOT/etc/cron.d/mdadm-checkarray
 install -p %{SOURCE4} $RPM_BUILD_ROOT%{_sbindir}/mdadm-checkarray
 
-cp -p udev-md-raid-arrays.rules $RPM_BUILD_ROOT/lib/udev/rules.d/64-md-raid.rules
-
 %clean
 rm -rf $RPM_BUILD_ROOT
 
@@ -157,27 +131,32 @@ if [ "$1" = "0" ]; then
        /sbin/chkconfig --del mdadm
 fi
 
+%postun
+/sbin/ldconfig
+
 %files
 %defattr(644,root,root,755)
 %doc ANNOUNCE* ChangeLog TODO
 %attr(755,root,root) %{_sbindir}/mdadm
 %attr(755,root,root) %{_sbindir}/mdadm-checkarray
-%attr(755,root,root) %{_sbindir}/mdassemble
 %attr(755,root,root) %{_sbindir}/mdctl
+%attr(755,root,root) %{_sbindir}/mdmon
+/lib/udev/rules.d/01-md-raid-creating.rules
+/lib/udev/rules.d/63-md-raid-arrays.rules
+/lib/udev/rules.d/64-md-raid-assembly.rules
+/lib/udev/rules.d/69-md-clustered-confirm-device.rules
 %attr(640,root,root) %config(noreplace,missingok) %verify(not md5 mtime size) %{_sysconfdir}/mdadm.conf
+%{_mandir}/man4/md.4*
 %{_mandir}/man5/mdadm.conf.5*
 %{_mandir}/man8/mdadm.8*
-%{_mandir}/man8/mdassemble.8*
 %{_mandir}/man8/mdmon.8*
 %attr(754,root,root) /etc/rc.d/init.d/%{name}
 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/%{name}
 %config(noreplace) %attr(640,root,root) /etc/cron.d/mdadm-checkarray
-/lib/udev/rules.d/64-md-raid.rules
 
 %if %{with initrd}
 %files initrd
 %defattr(644,root,root,755)
 %attr(755,root,root) %{_libdir}/initrd/mdadm
-%attr(755,root,root) %{_libdir}/initrd/mdassemble
 %attr(755,root,root) %{_libdir}/initrd/mdctl
 %endif