openSUSE Commits
Threads by month
- ----- 2025 -----
- January
- ----- 2024 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2023 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2022 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2021 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2020 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2019 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2018 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2017 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2016 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2015 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2014 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2013 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2012 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2011 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2010 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2009 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2008 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2007 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2006 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
March 2020
- 1 participants
- 5800 discussions
Hello community,
here is the log from the commit of package skelcd-control-openSUSE for openSUSE:Factory checked in at 2020-03-31 17:31:49
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/skelcd-control-openSUSE (Old)
and /work/SRC/openSUSE:Factory/.skelcd-control-openSUSE.new.3160 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "skelcd-control-openSUSE"
Tue Mar 31 17:31:49 2020 rev:212 rq:788900 version:20200326
Changes:
--------
--- /work/SRC/openSUSE:Factory/skelcd-control-openSUSE/skelcd-control-openSUSE-promo.changes 2020-03-22 14:16:24.094027224 +0100
+++ /work/SRC/openSUSE:Factory/.skelcd-control-openSUSE.new.3160/skelcd-control-openSUSE-promo.changes 2020-03-31 17:31:55.748249377 +0200
@@ -1,0 +2,5 @@
+Thu Mar 26 21:00:00 UTC 2020 - Sergio Lindo <sergiolindo.empresa(a)gmail.com>
+
+- Fix %s390x links (boo#1165922)
+
+-------------------------------------------------------------------
skelcd-control-openSUSE.changes: same change
Old:
----
skelcd-control-openSUSE-20200320.tar.bz2
New:
----
skelcd-control-openSUSE-20200326.tar.bz2
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Other differences:
------------------
++++++ skelcd-control-openSUSE-promo.spec ++++++
--- /var/tmp/diff_new_pack.zdsUSz/_old 2020-03-31 17:31:56.516249827 +0200
+++ /var/tmp/diff_new_pack.zdsUSz/_new 2020-03-31 17:31:56.516249827 +0200
@@ -27,7 +27,7 @@
#
######################################################################
Name: skelcd-control-openSUSE-promo
-Version: 20200320
+Version: 20200326
Release: 0
Summary: The openSUSE Installation Control file
License: MIT
@@ -121,7 +121,7 @@
mkdir -p $RPM_BUILD_ROOT%{?skelcdpath}/CD1
install -m 644 control/${CONTROL_FILE} $RPM_BUILD_ROOT%{?skelcdpath}/CD1/control.xml
-%ifarch aarch64 %arm ppc ppc64 ppc64le
+%ifarch aarch64 %arm ppc ppc64 ppc64le s390x
ports_arch="%{_arch}"
%ifarch ppc ppc64 ppc64le
ports_arch="ppc"
@@ -132,6 +132,9 @@
%ifarch armv7l armv7hl
ports_arch="armv7hl"
%endif
+ %ifarch s390x
+ ports_arch="zsystems"
+ %endif
sed -i -e "s,http://download.opensuse.org/distribution/,http://download.opensuse.org/p…," %{buildroot}%{?skelcdpath}/CD1/control.xml
sed -i -e "s,http://download.opensuse.org/tumbleweed/,http://download.opensuse.org/por…," %{buildroot}%{?skelcdpath}/CD1/control.xml
# Leap debug repo (from :Update) has a different path since all 'ports' (ARM and PPC) are in the same repo
skelcd-control-openSUSE.spec: same change
++++++ skelcd-control-openSUSE-20200320.tar.bz2 -> skelcd-control-openSUSE-20200326.tar.bz2 ++++++
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' old/skelcd-control-openSUSE-20200320/package/skelcd-control-openSUSE.changes new/skelcd-control-openSUSE-20200326/package/skelcd-control-openSUSE.changes
--- old/skelcd-control-openSUSE-20200320/package/skelcd-control-openSUSE.changes 2020-03-20 09:51:23.000000000 +0100
+++ new/skelcd-control-openSUSE-20200326/package/skelcd-control-openSUSE.changes 2020-03-27 09:11:21.000000000 +0100
@@ -1,4 +1,9 @@
-------------------------------------------------------------------
+Thu Mar 26 21:00:00 UTC 2020 - Sergio Lindo <sergiolindo.empresa(a)gmail.com>
+
+- Fix %s390x links (boo#1165922)
+
+-------------------------------------------------------------------
Fri Mar 20 08:23:19 UTC 2020 - Guillaume GARDET <guillaume.gardet(a)opensuse.org>
- Update external link for non-x86 on Leap (bsc#1120938)
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' old/skelcd-control-openSUSE-20200320/package/skelcd-control-openSUSE.spec new/skelcd-control-openSUSE-20200326/package/skelcd-control-openSUSE.spec
--- old/skelcd-control-openSUSE-20200320/package/skelcd-control-openSUSE.spec 2020-03-20 09:51:23.000000000 +0100
+++ new/skelcd-control-openSUSE-20200326/package/skelcd-control-openSUSE.spec 2020-03-27 09:11:21.000000000 +0100
@@ -1,7 +1,7 @@
#
# spec file for package skelcd-control-openSUSE
#
-# Copyright (c) 2017 SUSE LINUX GmbH, Nuernberg, Germany.
+# Copyright (c) 2017-2020 SUSE LINUX GmbH, Nuernberg, Germany.
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
@@ -27,7 +27,7 @@
#
######################################################################
Name: skelcd-control-openSUSE
-Version: 20200320
+Version: 20200326
Release: 0
Summary: The openSUSE Installation Control file
License: MIT
@@ -121,7 +121,7 @@
mkdir -p $RPM_BUILD_ROOT%{?skelcdpath}/CD1
install -m 644 control/${CONTROL_FILE} $RPM_BUILD_ROOT%{?skelcdpath}/CD1/control.xml
-%ifarch aarch64 %arm ppc ppc64 ppc64le
+%ifarch aarch64 %arm ppc ppc64 ppc64le s390x
ports_arch="%{_arch}"
%ifarch ppc ppc64 ppc64le
ports_arch="ppc"
@@ -132,6 +132,9 @@
%ifarch armv7l armv7hl
ports_arch="armv7hl"
%endif
+ %ifarch s390x
+ ports_arch="zsystems"
+ %endif
sed -i -e "s,http://download.opensuse.org/distribution/,http://download.opensuse.org/p…," %{buildroot}%{?skelcdpath}/CD1/control.xml
sed -i -e "s,http://download.opensuse.org/tumbleweed/,http://download.opensuse.org/por…," %{buildroot}%{?skelcdpath}/CD1/control.xml
# Leap debug repo (from :Update) has a different path since all 'ports' (ARM and PPC) are in the same repo
1
0
Hello community,
here is the log from the commit of package nfs-utils for openSUSE:Factory checked in at 2020-03-31 17:31:47
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/nfs-utils (Old)
and /work/SRC/openSUSE:Factory/.nfs-utils.new.3160 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "nfs-utils"
Tue Mar 31 17:31:47 2020 rev:153 rq:788739 version:unknown
Changes:
--------
--- /work/SRC/openSUSE:Factory/nfs-utils/nfs-utils.changes 2020-03-16 10:16:27.819541420 +0100
+++ /work/SRC/openSUSE:Factory/.nfs-utils.new.3160/nfs-utils.changes 2020-03-31 17:31:53.684248169 +0200
@@ -1,0 +2,23 @@
+Fri Mar 27 05:29:36 UTC 2020 - Neil Brown <nfbrown(a)suse.com>
+
+- Improve the hack to avoid python dependencies.
+ A new python script had been added since that hack was written.
+ (boo#1166067)
+
+-------------------------------------------------------------------
+Fri Mar 27 05:06:12 UTC 2020 - Neil Brown <nfbrown(a)suse.com>
+
+- 0001-conffile-Don-t-give-warning-for-optional-config-file.patch
+ Support optional include files correctly
+ (boo#1164619)
+
+-------------------------------------------------------------------
+Tue Mar 24 10:13:53 UTC 2020 - Petr Vorel <pvorel(a)suse.cz>
+
+- Update nfs.conf
+ - change value: udp=n (disabled in 2.2.1.)
+ - update name: manage-gids
+ - new: verbosity=0, rpc-verbosity=0, use-gss-proxy=0, rdma-port=20049,
+ no-notify=0, force=0, lift-grace=y
+
+-------------------------------------------------------------------
New:
----
0001-conffile-Don-t-give-warning-for-optional-config-file.patch
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Other differences:
------------------
++++++ nfs-utils.spec ++++++
--- /var/tmp/diff_new_pack.xklr0N/_old 2020-03-31 17:31:55.136249019 +0200
+++ /var/tmp/diff_new_pack.xklr0N/_new 2020-03-31 17:31:55.144249024 +0200
@@ -46,6 +46,7 @@
Source26: nfs.conf
Source27: nfs-kernel-server.tmpfiles.conf
Patch0: nfs-utils-1.0.7-bind-syntax.patch
+Patch1: 0001-conffile-Don-t-give-warning-for-optional-config-file.patch
BuildRequires: e2fsprogs-devel
BuildRequires: fedfs-utils-devel
@@ -144,6 +145,7 @@
%prep
%setup -q -a 1
%patch0 -p1
+%patch1 -p1
cp %{SOURCE6} .
@@ -202,7 +204,7 @@
install -m 644 utils/mount/nfsmount.conf %{buildroot}%{_sysconfdir}/nfsmount.conf
#
# hack to avoid automatic python dependency
-chmod 644 %{buildroot}%{_sbindir}/{mountstats,nfsiostat}
+chmod 644 `grep -l -r '^#!/usr/bin/python' %{buildroot}%{_sbindir}`
# Install sysusers.d template
mkdir -p %{buildroot}%{_sysusersdir}
install -m 644 %{SOURCE12} %{buildroot}%{_sysusersdir}/
++++++ 0001-conffile-Don-t-give-warning-for-optional-config-file.patch ++++++
>From 1c20fcd0a315f3c692a465159985e6125289f4e4 Mon Sep 17 00:00:00 2001
From: NeilBrown <neilb(a)suse.de>
Date: Fri, 27 Mar 2020 15:58:24 +1100
Subject: [PATCH] conffile: Don't give warning for optional config files.
A recent commit added the possibility of optional config files for which
warning messages would be suppressed.
Unfortunately only one of the possible warning messages - the least
likely one - was suppressed.
This patch suppresses the other.
Fixes: c6fdcbe0a5cf ("conffile: allow optional include files")
Signed-off-by: NeilBrown <neilb(a)suse.de>
---
support/nfs/conffile.c | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
--- a/support/nfs/conffile.c
+++ b/support/nfs/conffile.c
@@ -429,9 +429,9 @@ conf_parse_line(int trans, char *line, c
subconf = conf_readfile(relpath);
if (subconf == NULL) {
- xlog_warn("config error at %s:%d: "
- "error loading included config",
- filename, lineno);
+ if (!optional)
+ xlog_warn("config error at %s:%d: error loading included config",
+ filename, lineno);
if (relpath)
free(relpath);
return;
++++++ nfs.conf ++++++
--- /var/tmp/diff_new_pack.xklr0N/_old 2020-03-31 17:31:55.312249122 +0200
+++ /var/tmp/diff_new_pack.xklr0N/_new 2020-03-31 17:31:55.312249122 +0200
@@ -17,8 +17,11 @@
# debug=0
#
#[gssd]
+# verbosity=0
+# rpc-verbosity=0
# use-memcache=0
# use-machine-creds=1
+# use-gss-proxy=0
avoid-dns=$NFS_GSSD_AVOID_DNS
# limit-to-legacy-enctypes=0
# context-timeout=0
@@ -33,7 +36,7 @@
#
[mountd]
# debug=0
-# manage_gids=n
+# manage-gids=n
# descriptors=0
port= $MOUNTD_PORT
# threads=1
@@ -52,7 +55,7 @@
# port=0
# grace-time=90
lease-time=$NFSV4LEASETIME
-# udp=y
+# udp=n
# tcp=y
# vers2=n
vers3=$NFS3_SERVER_SUPPORT
@@ -61,6 +64,7 @@
# vers4.1=y
# vers4.2=y
# rdma=n
+# rdma-port=20049
#
[statd]
# debug=0
@@ -69,12 +73,15 @@
name=$STATD_HOSTNAME
# state-directory-path=/var/lib/nfs/statd
# ha-callout=
+# no-notify=0
#
#[sm-notify]
# debug=0
+# force=0
# retry-time=900
# outgoing-port=
# outgoing-addr=
+# lift-grace=y
#
#[svcgssd]
# principal=
1
0
Hello community,
here is the log from the commit of package mdadm for openSUSE:Factory checked in at 2020-03-31 17:31:45
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/mdadm (Old)
and /work/SRC/openSUSE:Factory/.mdadm.new.3160 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "mdadm"
Tue Mar 31 17:31:45 2020 rev:121 rq:788735 version:4.1
Changes:
--------
--- /work/SRC/openSUSE:Factory/mdadm/mdadm.changes 2020-02-15 22:24:48.263289744 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/mdadm.changes 2020-03-31 17:31:51.988247175 +0200
@@ -1,0 +2,228 @@
+Fri Mar 27 03:52:47 UTC 2020 - Neil Brown <nfbrown(a)suse.com>
+
+- Don't list XX@.services even for sevice_del_preun
+ They cannot be stopped without an instance name,
+ so there is no value in listing them, and it causes
+ and error with "rpm -e mdadm --nodeps".
+ (bsc#1093163)
+
+-------------------------------------------------------------------
+Tue Mar 3 05:32:58 UTC 2020 - Coly Li <colyli(a)suse.com>
+
+- Update for latest mdadm-4.1+ patches, this is required by
+ jsc#SLE-10078 and jsc#SLE-9348. Mostly the purpose is for
+ latest Intel IMSM raid support.
+ The following patches also include previous patches with
+ new re-ordered prefix numbers.
+
+- Makefile: install mdadm_env.sh to /usr/lib/mdadm (bsc#1111960)
+ 0000-Makefile-install-mdadm_env.sh-to-usr-lib-mdadm.patch
+- Assemble: keep MD_DISK_FAILFAST and MD_DISK_WRITEMOSTLY flag
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0001-Assemble-keep-MD_DISK_FAILFAST-and-MD_DISK_WRITEMOST.patch
+- Document PART-POLICY lines (jsc#SLE-10078, jsc#SLE-9348)
+ 0002-Document-PART-POLICY-lines.patch
+- policy: support devices with multiple paths.
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0003-policy-support-devices-with-multiple-paths.patch
+- mdcheck: add systemd unit files to run mdcheck. (bsc#1115407)
+ 0004-mdcheck-add-systemd-unit-files-to-run-mdcheck.patch
+- Monitor: add system timer to run --oneshot periodically (bsc#1115407)
+ 0005-Monitor-add-system-timer-to-run-oneshot-periodically.patch
+- imsm: update metadata correctly while raid10 double
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0006-imsm-update-metadata-correctly-while-raid10-double-d.patch
+- Assemble: mask FAILFAST and WRITEMOSTLY flags when finding
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0007-Assemble-mask-FAILFAST-and-WRITEMOSTLY-flags-when-fi.patch
+- Grow: avoid overflow in compute_backup_blocks()
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0008-Grow-avoid-overflow-in-compute_backup_blocks.patch
+- Grow: report correct new chunk size. (jsc#SLE-10078, jsc#SLE-9348)
+ 0009-Grow-report-correct-new-chunk-size.patch
+- policy.c: prevent NULL pointer referencing (bsc#1106078)
+ 0010-policy.c-prevent-NULL-pointer-referencing.patch
+- policy.c: Fix for compiler error (jsc#SLE-10078, jsc#SLE-9348)
+ 0012-policy.c-Fix-for-compiler-error.patch
+- imsm: finish recovery when drive with rebuild fails (bsc#1126975)
+ 0013-imsm-finish-recovery-when-drive-with-rebuild-fails.patch
+- imsm: fix reshape for >2TB drives (jsc#SLE-10078, jsc#SLE-9348)
+ 0014-imsm-fix-reshape-for-2TB-drives.patch
+- Fix spelling typos. (jsc#SLE-10078, jsc#SLE-9348)
+ 0015-Fix-spelling-typos.patch
+- Detail.c: do not skip first character when calling xstrdup in
+ Detail() (bsc#1123814)
+ 0016-Detail.c-do-not-skip-first-character-when-calling-xs.patch
+- Fix reshape for decreasing data offset (jsc#SLE-10078, jsc#SLE-9348)
+ 0018-Fix-reshape-for-decreasing-data-offset.patch
+- mdadm/tests: add one test case for failfast of raid1
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0019-mdadm-tests-add-one-test-case-for-failfast-of-raid1.patch
+- mdmon: don't attempt to manage new arrays when terminating
+ (bsc#1127526)
+ 0020-mdmon-don-t-attempt-to-manage-new-arrays-when-termin.patch
+- mdmon: wait for previous mdmon to exit during takeover
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0021-mdmon-wait-for-previous-mdmon-to-exit-during-takeove.patch
+- Assemble: Fix starting array with initial reshape checkpoint
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0022-Assemble-Fix-starting-array-with-initial-reshape-che.patch
+- add missing units to --examine (jsc#SLE-10078, jsc#SLE-9348)
+ 0023-add-missing-units-to-examine.patch
+- imsm: fix spare activation for old matrix arrays
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0024-imsm-fix-spare-activation-for-old-matrix-arrays.patch
+- Create: Block rounding size to max (jsc#SLE-10078, jsc#SLE-9348)
+ 0025-Create-Block-rounding-size-to-max.patch
+- udev: Add udev rules to create by-partuuid for md device
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0026-udev-Add-udev-rules-to-create-by-partuuid-for-md-dev.patch
+- mdmon: fix wrong array state when disk fails during mdmon
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0027-mdmon-fix-wrong-array-state-when-disk-fails-during-m.patch
+- Enable probe_roms to scan more than 6 roms. (bsc#1156040)
+ 0028-Enable-probe_roms-to-scan-more-than-6-roms.patch
+- super-intel: Fix issue with abs() being irrelevant
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0029-super-intel-Fix-issue-with-abs-being-irrelevant.patch
+- mdadm.h: Introduced unaligned {get,put}_unaligned{16,32}()
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0030-mdadm.h-Introduced-unaligned-get-put-_unaligned-16-3.patch
+- super-intel: Use put_unaligned in split_ull
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0031-super-intel-Use-put_unaligned-in-split_ull.patch
+- mdadm: load default sysfs attributes after assemblation
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0032-mdadm-load-default-sysfs-attributes-after-assemblati.patch
+- mdadm.h: include sysmacros.h unconditionally
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0033-mdadm.h-include-sysmacros.h-unconditionally.patch
+- mdadm: add --no-devices to avoid component devices detail
+ (bsc#1139709)
+ 0034-mdadm-add-no-devices-to-avoid-component-devices-deta.patch
+- udev: add --no-devices option for calling 'mdadm (bsc#1139709)
+ 0035-udev-add-no-devices-option-for-calling-mdadm-detail.patch
+- imsm: close removed drive fd. (jsc#SLE-10078, jsc#SLE-9348)
+ 0036-imsm-close-removed-drive-fd.patch
+- mdadm: check value returned by snprintf against errors
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0037-mdadm-check-value-returned-by-snprintf-against-error.patch
+- mdadm: Introduce new array state 'broken' for raid0/linear
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0038-mdadm-Introduce-new-array-state-broken-for-raid0-lin.patch
+- mdadm: force a uuid swap on big endian (jsc#SLE-10078, jsc#SLE-9348)
+ 0039-mdadm-force-a-uuid-swap-on-big-endian.patch
+- mdadm/md.4: add the descriptions for bitmap sysfs nodes
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0040-mdadm-md.4-add-the-descriptions-for-bitmap-sysfs-nod.patch
+- Init devlist as an array (jsc#SLE-10078, jsc#SLE-9348)
+ 0041-Init-devlist-as-an-array.patch
+- Don't need to check recovery after re-add when no I/O writes
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0042-Don-t-need-to-check-recovery-after-re-add-when-no-I-.patch
+- udev: allow for udev attribute reading bug.
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0043-udev-allow-for-udev-attribute-reading-bug.patch
+- imsm: save current_vol number (jsc#SLE-10078, jsc#SLE-9348)
+ 0044-imsm-save-current_vol-number.patch
+- imsm: allow to specify second volume size
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0045-imsm-allow-to-specify-second-volume-size.patch
+- mdcheck: when mdcheck_start is enabled, enable (bsc#1153258)
+ 0046-mdcheck-when-mdcheck_start-is-enabled-enable-mdcheck.patch
+- mdcheck: use ${} to pass variable to mdcheck (bsc#1153258)
+ 0050-mdcheck-use-to-pass-variable-to-mdcheck.patch
+- SUSE-mdadm_env.sh: handle MDADM_CHECK_DURATION (bsc#1153258)
+ 0051-SUSE-mdadm_env.sh-handle-MDADM_CHECK_DURATION.patch
+- super-intel: don't mark structs 'packed' unnecessarily
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0052-super-intel-don-t-mark-structs-packed-unnecessarily.patch
+- Manage: Remove the legacy code for md driver prior to 0.90.03
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0053-Manage-Remove-the-legacy-code-for-md-driver-prior-to.patch
+- Remove last traces of HOT_ADD_DISK (jsc#SLE-10078, jsc#SLE-9348)
+ 0054-Remove-last-traces-of-HOT_ADD_DISK.patch
+- Fix up a few formatting issues (jsc#SLE-10078, jsc#SLE-9348)
+ 0055-Fix-up-a-few-formatting-issues.patch
+- Remove unused code (jsc#SLE-10078, jsc#SLE-9348)
+ 0056-Remove-unused-code.patch
+- imsm: return correct uuid for volume in detail
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0057-imsm-return-correct-uuid-for-volume-in-detail.patch
+- imsm: Change the way of printing nvme drives in
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0058-imsm-Change-the-way-of-printing-nvme-drives-in-detai.patch
+- Create: add support for RAID0 layouts. (bsc#1162479)
+ 0059-Create-add-support-for-RAID0-layouts.patch
+- Assemble: add support for RAID0 layouts. (bsc#1162479)
+ 0060-Assemble-add-support-for-RAID0-layouts.patch
+- Respect $(CROSS_COMPILE) when $(CC) is the default
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0061-Respect-CROSS_COMPILE-when-CC-is-the-default.patch
+- Change warning message (jsc#SLE-10078, jsc#SLE-9348)
+ 0062-Change-warning-message.patch
+- mdcheck service can't start succesfully because of syntax
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0063-mdcheck-service-can-t-start-succesfully-because-of-s.patch
+- imsm: Update grow manual. (jsc#SLE-10078, jsc#SLE-9348)
+ 0064-imsm-Update-grow-manual.patch
+- Add support for Tebibytes (jsc#SLE-10078, jsc#SLE-9348)
+ 0065-Add-support-for-Tebibytes.patch
+- imsm: fill working_disks according to metadata.
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0066-imsm-fill-working_disks-according-to-metadata.patch
+- mdadm.8: add note information for raid0 growing operation
+ (bsc#1129900)
+ 0067-mdadm.8-add-note-information-for-raid0-growing-opera.patch
+- Remove the legacy whitespace (jsc#SLE-10078, jsc#SLE-9348)
+ 0068-Remove-the-legacy-whitespace.patch
+- imsm: pass subarray id to kill_subarray function
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0069-imsm-pass-subarray-id-to-kill_subarray-function.patch
+- imsm: Remove --dump/--restore implementation
+ (jsc#SLE-10078, jsc#SLE-9348)
+ 0070-imsm-Remove-dump-restore-implementation.patch
+
+-------------------------------------------------------------------
+Tue Mar 3 05:31:39 UTC 2020 - Coly Li <colyli(a)suse.com>
+
+- Rename the following patches, they will be listed with new
+ re-ordered prefix number in following commit,
+ 0001-Document-PART-POLICY-lines.patch
+ 0001-Makefile-install-mdadm_env.sh-to-usr-lib-mdadm.patch
+ 0002-policy-support-devices-with-multiple-paths.patch
+ 0003-mdcheck-add-systemd-unit-files-to-run-mdcheck.patch
+ 0004-Monitor-add-system-timer-to-run-oneshot-periodically.patch
+ 0005-imsm-update-metadata-correctly-while-raid10-double-d.patch
+ 0006-Grow-avoid-overflow-in-compute_backup_blocks.patch
++++ 31 more lines (skipped)
++++ between /work/SRC/openSUSE:Factory/mdadm/mdadm.changes
++++ and /work/SRC/openSUSE:Factory/.mdadm.new.3160/mdadm.changes
Old:
----
0001-Document-PART-POLICY-lines.patch
0001-Makefile-install-mdadm_env.sh-to-usr-lib-mdadm.patch
0002-policy-support-devices-with-multiple-paths.patch
0003-mdcheck-add-systemd-unit-files-to-run-mdcheck.patch
0004-Monitor-add-system-timer-to-run-oneshot-periodically.patch
0005-imsm-update-metadata-correctly-while-raid10-double-d.patch
0006-Grow-avoid-overflow-in-compute_backup_blocks.patch
0007-Grow-report-correct-new-chunk-size.patch
0008-policy.c-prevent-NULL-pointer-referencing.patch
0009-Detail.c-do-not-skip-first-character-when-calling-xs.patch
0010-imsm-finish-recovery-when-drive-with-rebuild-fails.patch
0011-mdmon-don-t-attempt-to-manage-new-arrays-when-termin.patch
0012-mdcheck-when-mdcheck_start-is-enabled-enable-mdcheck.patch
0013-mdcheck-use-to-pass-variable-to-mdcheck.patch
0014-SUSE-mdadm_env.sh-handle-MDADM_CHECK_DURATION.patch
0015-Create-add-support-for-RAID0-layouts.patch
0016-Assemble-add-support-for-RAID0-layouts.patch
1002-mdadm.8-add-note-information-for-raid0-growing-opera.patch
New:
----
0000-Makefile-install-mdadm_env.sh-to-usr-lib-mdadm.patch
0001-Assemble-keep-MD_DISK_FAILFAST-and-MD_DISK_WRITEMOST.patch
0002-Document-PART-POLICY-lines.patch
0003-policy-support-devices-with-multiple-paths.patch
0004-mdcheck-add-systemd-unit-files-to-run-mdcheck.patch
0005-Monitor-add-system-timer-to-run-oneshot-periodically.patch
0006-imsm-update-metadata-correctly-while-raid10-double-d.patch
0007-Assemble-mask-FAILFAST-and-WRITEMOSTLY-flags-when-fi.patch
0008-Grow-avoid-overflow-in-compute_backup_blocks.patch
0009-Grow-report-correct-new-chunk-size.patch
0010-policy.c-prevent-NULL-pointer-referencing.patch
0012-policy.c-Fix-for-compiler-error.patch
0013-imsm-finish-recovery-when-drive-with-rebuild-fails.patch
0014-imsm-fix-reshape-for-2TB-drives.patch
0015-Fix-spelling-typos.patch
0016-Detail.c-do-not-skip-first-character-when-calling-xs.patch
0018-Fix-reshape-for-decreasing-data-offset.patch
0019-mdadm-tests-add-one-test-case-for-failfast-of-raid1.patch
0020-mdmon-don-t-attempt-to-manage-new-arrays-when-termin.patch
0021-mdmon-wait-for-previous-mdmon-to-exit-during-takeove.patch
0022-Assemble-Fix-starting-array-with-initial-reshape-che.patch
0023-add-missing-units-to-examine.patch
0024-imsm-fix-spare-activation-for-old-matrix-arrays.patch
0025-Create-Block-rounding-size-to-max.patch
0026-udev-Add-udev-rules-to-create-by-partuuid-for-md-dev.patch
0027-mdmon-fix-wrong-array-state-when-disk-fails-during-m.patch
0028-Enable-probe_roms-to-scan-more-than-6-roms.patch
0029-super-intel-Fix-issue-with-abs-being-irrelevant.patch
0030-mdadm.h-Introduced-unaligned-get-put-_unaligned-16-3.patch
0031-super-intel-Use-put_unaligned-in-split_ull.patch
0032-mdadm-load-default-sysfs-attributes-after-assemblati.patch
0033-mdadm.h-include-sysmacros.h-unconditionally.patch
0034-mdadm-add-no-devices-to-avoid-component-devices-deta.patch
0035-udev-add-no-devices-option-for-calling-mdadm-detail.patch
0036-imsm-close-removed-drive-fd.patch
0037-mdadm-check-value-returned-by-snprintf-against-error.patch
0038-mdadm-Introduce-new-array-state-broken-for-raid0-lin.patch
0039-mdadm-force-a-uuid-swap-on-big-endian.patch
0040-mdadm-md.4-add-the-descriptions-for-bitmap-sysfs-nod.patch
0041-Init-devlist-as-an-array.patch
0042-Don-t-need-to-check-recovery-after-re-add-when-no-I-.patch
0043-udev-allow-for-udev-attribute-reading-bug.patch
0044-imsm-save-current_vol-number.patch
0045-imsm-allow-to-specify-second-volume-size.patch
0046-mdcheck-when-mdcheck_start-is-enabled-enable-mdcheck.patch
0050-mdcheck-use-to-pass-variable-to-mdcheck.patch
0051-SUSE-mdadm_env.sh-handle-MDADM_CHECK_DURATION.patch
0052-super-intel-don-t-mark-structs-packed-unnecessarily.patch
0053-Manage-Remove-the-legacy-code-for-md-driver-prior-to.patch
0054-Remove-last-traces-of-HOT_ADD_DISK.patch
0055-Fix-up-a-few-formatting-issues.patch
0056-Remove-unused-code.patch
0057-imsm-return-correct-uuid-for-volume-in-detail.patch
0058-imsm-Change-the-way-of-printing-nvme-drives-in-detai.patch
0059-Create-add-support-for-RAID0-layouts.patch
0060-Assemble-add-support-for-RAID0-layouts.patch
0061-Respect-CROSS_COMPILE-when-CC-is-the-default.patch
0062-Change-warning-message.patch
0063-mdcheck-service-can-t-start-succesfully-because-of-s.patch
0064-imsm-Update-grow-manual.patch
0065-Add-support-for-Tebibytes.patch
0066-imsm-fill-working_disks-according-to-metadata.patch
0067-mdadm.8-add-note-information-for-raid0-growing-opera.patch
0068-Remove-the-legacy-whitespace.patch
0069-imsm-pass-subarray-id-to-kill_subarray-function.patch
0070-imsm-Remove-dump-restore-implementation.patch
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Other differences:
------------------
++++++ mdadm.spec ++++++
--- /var/tmp/diff_new_pack.xiKuqP/_old 2020-03-31 17:31:52.980247756 +0200
+++ /var/tmp/diff_new_pack.xiKuqP/_new 2020-03-31 17:31:52.984247759 +0200
@@ -1,7 +1,7 @@
#
# spec file for package mdadm
#
-# Copyright (c) 2020 SUSE LINUX GmbH, Nuernberg, Germany.
+# Copyright (c) 2020 SUSE LLC
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
@@ -33,7 +33,7 @@
BuildRequires: pkgconfig(udev)
PreReq: %fillup_prereq /sbin/mkinitrd coreutils
Recommends: smtp_daemon
-Url: http://www.kernel.org/pub/linux/utils/raid/mdadm/
+URL: http://www.kernel.org/pub/linux/utils/raid/mdadm/
Summary: Utility for configuring "MD" software RAID devices
License: GPL-2.0-only
Group: System/Base
@@ -41,25 +41,73 @@
Source: https://www.kernel.org/pub/linux/utils/raid/mdadm/%{name}-%{version}.tar.xz
Source1: Software-RAID.HOWTO.tar.bz2
Source2: sysconfig.mdadm
-Patch1: 0001-Makefile-install-mdadm_env.sh-to-usr-lib-mdadm.patch
-Patch11: 0001-Document-PART-POLICY-lines.patch
-Patch12: 0002-policy-support-devices-with-multiple-paths.patch
-Patch13: 0003-mdcheck-add-systemd-unit-files-to-run-mdcheck.patch
-Patch14: 0004-Monitor-add-system-timer-to-run-oneshot-periodically.patch
-Patch15: 0005-imsm-update-metadata-correctly-while-raid10-double-d.patch
-Patch16: 0006-Grow-avoid-overflow-in-compute_backup_blocks.patch
-Patch17: 0007-Grow-report-correct-new-chunk-size.patch
-Patch18: 0008-policy.c-prevent-NULL-pointer-referencing.patch
-Patch19: 0009-Detail.c-do-not-skip-first-character-when-calling-xs.patch
-Patch20: 0010-imsm-finish-recovery-when-drive-with-rebuild-fails.patch
-Patch21: 0011-mdmon-don-t-attempt-to-manage-new-arrays-when-termin.patch
-Patch22: 0012-mdcheck-when-mdcheck_start-is-enabled-enable-mdcheck.patch
-Patch23: 0013-mdcheck-use-to-pass-variable-to-mdcheck.patch
-Patch24: 0014-SUSE-mdadm_env.sh-handle-MDADM_CHECK_DURATION.patch
-Patch25: 0015-Create-add-support-for-RAID0-layouts.patch
-Patch26: 0016-Assemble-add-support-for-RAID0-layouts.patch
+Patch0: 0000-Makefile-install-mdadm_env.sh-to-usr-lib-mdadm.patch
+Patch1: 0001-Assemble-keep-MD_DISK_FAILFAST-and-MD_DISK_WRITEMOST.patch
+Patch2: 0002-Document-PART-POLICY-lines.patch
+Patch3: 0003-policy-support-devices-with-multiple-paths.patch
+Patch4: 0004-mdcheck-add-systemd-unit-files-to-run-mdcheck.patch
+Patch5: 0005-Monitor-add-system-timer-to-run-oneshot-periodically.patch
+Patch6: 0006-imsm-update-metadata-correctly-while-raid10-double-d.patch
+Patch7: 0007-Assemble-mask-FAILFAST-and-WRITEMOSTLY-flags-when-fi.patch
+Patch8: 0008-Grow-avoid-overflow-in-compute_backup_blocks.patch
+Patch9: 0009-Grow-report-correct-new-chunk-size.patch
+Patch10: 0010-policy.c-prevent-NULL-pointer-referencing.patch
+Patch11: 0012-policy.c-Fix-for-compiler-error.patch
+Patch12: 0013-imsm-finish-recovery-when-drive-with-rebuild-fails.patch
+Patch13: 0014-imsm-fix-reshape-for-2TB-drives.patch
+Patch14: 0015-Fix-spelling-typos.patch
+Patch15: 0016-Detail.c-do-not-skip-first-character-when-calling-xs.patch
+Patch16: 0018-Fix-reshape-for-decreasing-data-offset.patch
+Patch17: 0019-mdadm-tests-add-one-test-case-for-failfast-of-raid1.patch
+Patch18: 0020-mdmon-don-t-attempt-to-manage-new-arrays-when-termin.patch
+Patch19: 0021-mdmon-wait-for-previous-mdmon-to-exit-during-takeove.patch
+Patch20: 0022-Assemble-Fix-starting-array-with-initial-reshape-che.patch
+Patch21: 0023-add-missing-units-to-examine.patch
+Patch22: 0024-imsm-fix-spare-activation-for-old-matrix-arrays.patch
+Patch23: 0025-Create-Block-rounding-size-to-max.patch
+Patch24: 0026-udev-Add-udev-rules-to-create-by-partuuid-for-md-dev.patch
+Patch25: 0027-mdmon-fix-wrong-array-state-when-disk-fails-during-m.patch
+Patch26: 0028-Enable-probe_roms-to-scan-more-than-6-roms.patch
+Patch27: 0029-super-intel-Fix-issue-with-abs-being-irrelevant.patch
+Patch28: 0030-mdadm.h-Introduced-unaligned-get-put-_unaligned-16-3.patch
+Patch29: 0031-super-intel-Use-put_unaligned-in-split_ull.patch
+Patch30: 0032-mdadm-load-default-sysfs-attributes-after-assemblati.patch
+Patch31: 0033-mdadm.h-include-sysmacros.h-unconditionally.patch
+Patch32: 0034-mdadm-add-no-devices-to-avoid-component-devices-deta.patch
+Patch33: 0035-udev-add-no-devices-option-for-calling-mdadm-detail.patch
+Patch34: 0036-imsm-close-removed-drive-fd.patch
+Patch35: 0037-mdadm-check-value-returned-by-snprintf-against-error.patch
+Patch36: 0038-mdadm-Introduce-new-array-state-broken-for-raid0-lin.patch
+Patch37: 0039-mdadm-force-a-uuid-swap-on-big-endian.patch
+Patch38: 0040-mdadm-md.4-add-the-descriptions-for-bitmap-sysfs-nod.patch
+Patch39: 0041-Init-devlist-as-an-array.patch
+Patch40: 0042-Don-t-need-to-check-recovery-after-re-add-when-no-I-.patch
+Patch41: 0043-udev-allow-for-udev-attribute-reading-bug.patch
+Patch42: 0044-imsm-save-current_vol-number.patch
+Patch43: 0045-imsm-allow-to-specify-second-volume-size.patch
+Patch44: 0046-mdcheck-when-mdcheck_start-is-enabled-enable-mdcheck.patch
+Patch45: 0050-mdcheck-use-to-pass-variable-to-mdcheck.patch
+Patch46: 0051-SUSE-mdadm_env.sh-handle-MDADM_CHECK_DURATION.patch
+Patch47: 0052-super-intel-don-t-mark-structs-packed-unnecessarily.patch
+Patch48: 0053-Manage-Remove-the-legacy-code-for-md-driver-prior-to.patch
+Patch49: 0054-Remove-last-traces-of-HOT_ADD_DISK.patch
+Patch50: 0055-Fix-up-a-few-formatting-issues.patch
+Patch51: 0056-Remove-unused-code.patch
+Patch52: 0057-imsm-return-correct-uuid-for-volume-in-detail.patch
+Patch53: 0058-imsm-Change-the-way-of-printing-nvme-drives-in-detai.patch
+Patch54: 0059-Create-add-support-for-RAID0-layouts.patch
+Patch55: 0060-Assemble-add-support-for-RAID0-layouts.patch
+Patch56: 0061-Respect-CROSS_COMPILE-when-CC-is-the-default.patch
+Patch57: 0062-Change-warning-message.patch
+Patch58: 0063-mdcheck-service-can-t-start-succesfully-because-of-s.patch
+Patch59: 0064-imsm-Update-grow-manual.patch
+Patch60: 0065-Add-support-for-Tebibytes.patch
+Patch61: 0066-imsm-fill-working_disks-according-to-metadata.patch
+Patch62: 0067-mdadm.8-add-note-information-for-raid0-growing-opera.patch
+Patch63: 0068-Remove-the-legacy-whitespace.patch
+Patch64: 0069-imsm-pass-subarray-id-to-kill_subarray-function.patch
+Patch65: 0070-imsm-Remove-dump-restore-implementation.patch
Patch1001: 1001-display-timeout-status.patch
-Patch1002: 1002-mdadm.8-add-note-information-for-raid0-growing-opera.patch
%define _udevdir %(pkg-config --variable=udevdir udev)
%define _systemdshutdowndir %{_unitdir}/../system-shutdown
@@ -68,7 +116,17 @@
%prep
%setup -q -a1
+%patch0 -p1
%patch1 -p1
+%patch2 -p1
+%patch3 -p1
+%patch4 -p1
+%patch5 -p1
+%patch6 -p1
+%patch7 -p1
+%patch8 -p1
+%patch9 -p1
+%patch10 -p1
%patch11 -p1
%patch12 -p1
%patch13 -p1
@@ -85,8 +143,46 @@
%patch24 -p1
%patch25 -p1
%patch26 -p1
+%patch27 -p1
+%patch28 -p1
+%patch29 -p1
+%patch30 -p1
+%patch31 -p1
+%patch32 -p1
+%patch33 -p1
+%patch34 -p1
+%patch35 -p1
+%patch36 -p1
+%patch37 -p1
+%patch38 -p1
+%patch39 -p1
+%patch40 -p1
+%patch41 -p1
+%patch42 -p1
+%patch43 -p1
+%patch44 -p1
+%patch45 -p1
+%patch46 -p1
+%patch47 -p1
+%patch48 -p1
+%patch49 -p1
+%patch50 -p1
+%patch51 -p1
+%patch52 -p1
+%patch53 -p1
+%patch54 -p1
+%patch55 -p1
+%patch56 -p1
+%patch57 -p1
+%patch58 -p1
+%patch59 -p1
+%patch60 -p1
+%patch61 -p1
+%patch62 -p1
+%patch63 -p1
+%patch64 -p1
+%patch65 -p1
%patch1001 -p1
-%patch1002 -p1
%build
make %{?_smp_mflags} CC="%__cc" CXFLAGS="%{optflags} -Wno-error" SUSE=yes
@@ -116,7 +212,7 @@
%fillup_only
%preun
-%service_del_preun %services mdmon@.service mdadm-last-resort@.service mdadm-grow-continue@.service
+%service_del_preun %services
%postun
%service_del_postun %services
++++++ 0001-Makefile-install-mdadm_env.sh-to-usr-lib-mdadm.patch -> 0000-Makefile-install-mdadm_env.sh-to-usr-lib-mdadm.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/0001-Makefile-install-mdadm_env.sh-to-usr-lib-mdadm.patch 2018-12-19 13:25:28.185231795 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0000-Makefile-install-mdadm_env.sh-to-usr-lib-mdadm.patch 2020-03-31 17:31:47.276244416 +0200
@@ -2,6 +2,7 @@
From: colyli <colyli(a)suse.coly>
Date: Wed, 17 Oct 2018 11:08:39 +0800
Subject: [PATCH] Makefile: install mdadm_env.sh to /usr/lib/mdadm
+References: bsc#1111960
Current Makefile installs mdadm_env.sh to /usr/libexec/mdadm but calls it
from /usr/lib/mdadm. This patch changes the installation directory to
++++++ 0001-Assemble-keep-MD_DISK_FAILFAST-and-MD_DISK_WRITEMOST.patch ++++++
>From 0833f9c3dbaaee202b92ea956f9e2decc7b9593a Mon Sep 17 00:00:00 2001
From: Gioh Kim <gi-oh.kim(a)profitbricks.com>
Date: Tue, 6 Nov 2018 15:27:42 +0100
Subject: [PATCH] Assemble: keep MD_DISK_FAILFAST and MD_DISK_WRITEMOSTLY flag
Git-commit: 0833f9c3dbaaee202b92ea956f9e2decc7b9593a
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Before updating superblock of slave disks, desired_state value
is set for the target state of the slave disks. But it forgets
to check MD_DISK_FAILFAST and MD_DISK_WRITEMOSTLY flags. Then
start_arrays() calls ADD_NEW_DISK ioctl-call and pass the state
without MD_DISK_FAILFAST and MD_DISK_WRITEMOSTLY.
Currenlty it does not generate any problem because kernel does not
care MD_DISK_FAILFAST or MD_DISK_WRITEMOSTLY flags.
Reviewed-by: NeilBrown <neilb(a)suse.com>
Signed-off-by: Gioh Kim <gi-oh.kim(a)profitbricks.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
Assemble.c | 3 +++
1 file changed, 3 insertions(+)
diff --git a/Assemble.c b/Assemble.c
index a79466c..f39c9e1 100644
--- a/Assemble.c
+++ b/Assemble.c
@@ -1704,6 +1704,9 @@ try_again:
else
desired_state = (1<<MD_DISK_ACTIVE) | (1<<MD_DISK_SYNC);
+ desired_state |= devices[j].i.disk.state & ((1<<MD_DISK_FAILFAST) |
+ (1<<MD_DISK_WRITEMOSTLY));
+
if (!devices[j].uptodate)
continue;
--
2.25.0
++++++ 0001-Document-PART-POLICY-lines.patch -> 0002-Document-PART-POLICY-lines.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/0001-Document-PART-POLICY-lines.patch 2018-12-19 13:25:26.997233241 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0002-Document-PART-POLICY-lines.patch 2020-03-31 17:31:47.492244543 +0200
@@ -2,6 +2,9 @@
From: NeilBrown <neilb(a)suse.com>
Date: Fri, 9 Nov 2018 17:12:33 +1100
Subject: [PATCH 1/5] Document PART-POLICY lines
+Git-commit: 6b6112842030309c297a521918d1a2e982426fa3
+Patch-mainline: mdadm-4.1+
+References: jsc#SLE-10078, jsc#SLE-9348
PART-POLICY has been accepted in mdadm.conf since the same
time that POLICY was accepted, but it was never documented.
@@ -12,6 +15,8 @@
Signed-off-by: NeilBrown <neilb(a)suse.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
+Signed-off-by: Coly Li <colyli(a)suse.de>
+
---
mdadm.conf.5 | 24 +++++++++++++++++++++++-
policy.c | 2 +-
++++++ 0002-policy-support-devices-with-multiple-paths.patch -> 0003-policy-support-devices-with-multiple-paths.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/0002-policy-support-devices-with-multiple-paths.patch 2018-12-19 13:25:28.441231483 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0003-policy-support-devices-with-multiple-paths.patch 2020-03-31 17:31:47.588244599 +0200
@@ -2,6 +2,9 @@
From: NeilBrown <neilb(a)suse.com>
Date: Fri, 9 Nov 2018 17:12:33 +1100
Subject: [PATCH 2/5] policy: support devices with multiple paths.
+Git-commit: cd72f9d114da206baa01fd56ff2d8ffcc08f3239
+Patch-mainline: mdadm-4.1+
+References: jsc#SLE-10078, jsc#SLE-9348
As new releases of Linux some time change the name of
a path, some distros keep "legacy" names as well. This
@@ -15,6 +18,8 @@
Reported-and-tested-by: Mariusz Tkaczyk <mariusz.tkaczyk(a)intel.com>
Signed-off-by: NeilBrown <neilb(a)suse.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
+Signed-off-by: Coly Li <colyli(a)suse.de>
+
---
Incremental.c | 5 +-
mdadm.h | 2 +-
++++++ 0003-mdcheck-add-systemd-unit-files-to-run-mdcheck.patch -> 0004-mdcheck-add-systemd-unit-files-to-run-mdcheck.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/0003-mdcheck-add-systemd-unit-files-to-run-mdcheck.patch 2018-12-19 13:25:28.521231386 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0004-mdcheck-add-systemd-unit-files-to-run-mdcheck.patch 2020-03-31 17:31:47.636244627 +0200
@@ -2,6 +2,9 @@
From: NeilBrown <neilb(a)suse.com>
Date: Wed, 5 Dec 2018 16:35:00 +1100
Subject: [PATCH 3/5] mdcheck: add systemd unit files to run mdcheck.
+Git-commit: 4199d3c629c14866505923d19fa50017ee92d2e1
+Patch-mainline: mdadm-4.1+
+References: bsc#1115407
Having the mdcheck script is not use if is never run.
This patch adds systemd unit files so that it can easily
++++++ 0004-Monitor-add-system-timer-to-run-oneshot-periodically.patch -> 0005-Monitor-add-system-timer-to-run-oneshot-periodically.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/0004-Monitor-add-system-timer-to-run-oneshot-periodically.patch 2018-12-19 13:25:28.561231337 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0005-Monitor-add-system-timer-to-run-oneshot-periodically.patch 2020-03-31 17:31:47.668244646 +0200
@@ -2,6 +2,9 @@
From: NeilBrown <neilb(a)suse.com>
Date: Wed, 5 Dec 2018 16:35:00 +1100
Subject: [PATCH 4/5] Monitor: add system timer to run --oneshot periodically
+Git-commit: 7cd7e91ab3de5aa75dc963cb08b0618c1885cf0d
+Patch-mainline: mdadm-4.1+
+References: bsc#1115407
"mdadm --monitor --oneshot" can be used to get a warning
if there are any degraded arrays. It can be helpful to get
++++++ 0005-imsm-update-metadata-correctly-while-raid10-double-d.patch -> 0006-imsm-update-metadata-correctly-while-raid10-double-d.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/0005-imsm-update-metadata-correctly-while-raid10-double-d.patch 2018-12-19 13:25:28.589231303 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0006-imsm-update-metadata-correctly-while-raid10-double-d.patch 2020-03-31 17:31:47.696244662 +0200
@@ -3,6 +3,9 @@
Date: Wed, 17 Oct 2018 12:11:41 +0200
Subject: [PATCH 5/5] imsm: update metadata correctly while raid10 double
degradation
+Git-commit: d7a1fda2769ba272d89de6caeab35d52b73a9c3c
+Patch-mainline: mdadm-4.1+
+References: jsc#SLE-10078, jsc#SLE-9348
Mdmon calls end_migration() when map state changes from normal to
degraded. It is not valid because in raid 10 double degradation case
@@ -21,6 +24,8 @@
Signed-off-by: Mariusz Tkaczyk <mariusz.tkaczyk(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
+Signed-off-by: Coly Li <colyli(a)suse.de>
+
---
super-intel.c | 25 +++++++++++++++++++------
1 file changed, 19 insertions(+), 6 deletions(-)
++++++ 0007-Assemble-mask-FAILFAST-and-WRITEMOSTLY-flags-when-fi.patch ++++++
>From 563ac108659980b3d1e226fe416254a86656235f Mon Sep 17 00:00:00 2001
From: Gioh Kim <gi-oh.kim(a)cloud.ionos.com>
Date: Tue, 6 Nov 2018 16:20:17 +0100
Subject: [PATCH] Assemble: mask FAILFAST and WRITEMOSTLY flags when finding
the most recent device
Git-commit: 563ac108659980b3d1e226fe416254a86656235f
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
If devices[].i.disk.state has MD_DISK_FAILFAST or MD_DISK_WRITEMOSTLY
flag, it cannot be the most recent device. Both flags should be masked
before checking the state.
Reviewed-by: NeilBrown <neilb(a)suse.com>
Signed-off-by: Gioh Kim <gi-oh.kim(a)cloud.ionos.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
Assemble.c | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/Assemble.c b/Assemble.c
index f39c9e1..9f75c68 100644
--- a/Assemble.c
+++ b/Assemble.c
@@ -578,6 +578,7 @@ static int load_devices(struct devs *devices, char *devmap,
struct supertype *tst;
int i;
int dfd;
+ int disk_state;
if (tmpdev->used != 1)
continue;
@@ -711,7 +712,9 @@ static int load_devices(struct devs *devices, char *devmap,
devices[devcnt].i.disk.major = major(stb.st_rdev);
devices[devcnt].i.disk.minor = minor(stb.st_rdev);
- if (devices[devcnt].i.disk.state == 6) {
+ disk_state = devices[devcnt].i.disk.state & ~((1<<MD_DISK_FAILFAST) |
+ (1<<MD_DISK_WRITEMOSTLY));
+ if (disk_state == ((1<<MD_DISK_ACTIVE) | (1<<MD_DISK_SYNC))) {
if (most_recent < 0 ||
devices[devcnt].i.events
> devices[most_recent].i.events) {
--
2.25.0
++++++ 0006-Grow-avoid-overflow-in-compute_backup_blocks.patch -> 0008-Grow-avoid-overflow-in-compute_backup_blocks.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/0006-Grow-avoid-overflow-in-compute_backup_blocks.patch 2018-12-19 13:25:28.609231279 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0008-Grow-avoid-overflow-in-compute_backup_blocks.patch 2020-03-31 17:31:47.756244697 +0200
@@ -2,6 +2,9 @@
From: NeilBrown <neilb(a)suse.com>
Date: Thu, 6 Dec 2018 10:35:41 +1100
Subject: [PATCH] Grow: avoid overflow in compute_backup_blocks()
+Git-commit: 085df42259cba7863cd6ebe5cd0d8492ac5b869e
+Patch-mainline: mdadm-4.1+
+References: jsc#SLE-10078, jsc#SLE-9348
With a chunk size of 16Meg and data drive count of 8,
this calculate can easily overflow the 'int' type that
@@ -11,6 +14,8 @@
Reported-and-tested-by: Ed Spiridonov <edo.rus(a)gmail.com>
Signed-off-by: NeilBrown <neilb(a)suse.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
+Signed-off-by: Coly Li <colyli(a)suse.de>
+
---
Grow.c | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
++++++ 0007-Grow-report-correct-new-chunk-size.patch -> 0009-Grow-report-correct-new-chunk-size.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/0007-Grow-report-correct-new-chunk-size.patch 2018-12-19 13:25:28.629231254 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0009-Grow-report-correct-new-chunk-size.patch 2020-03-31 17:31:47.800244723 +0200
@@ -2,12 +2,17 @@
From: NeilBrown <neilb(a)suse.com>
Date: Thu, 6 Dec 2018 10:36:28 +1100
Subject: [PATCH] Grow: report correct new chunk size.
+Git-commit: 76d505dec6c9f92564553596fc8350324be82463
+Patch-mainline: mdadm-4.1+
+References: jsc#SLE-10078, jsc#SLE-9348
When using "--grow --chunk=" to change chunk
size, the old chunksize is reported instead of the new.
Signed-off-by: NeilBrown <neilb(a)suse.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
+Signed-off-by: Coly Li <colyli(a)suse.de>
+
---
Grow.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
++++++ 0008-policy.c-prevent-NULL-pointer-referencing.patch -> 0010-policy.c-prevent-NULL-pointer-referencing.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/0008-policy.c-prevent-NULL-pointer-referencing.patch 2018-12-19 13:25:28.645231235 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0010-policy.c-prevent-NULL-pointer-referencing.patch 2020-03-31 17:31:47.820244735 +0200
@@ -1,18 +1,23 @@
-From 179cab343006df996f0a85a542b40e44db0c2e2f Mon Sep 17 00:00:00 2001
+From 467e6a1b4ece8e552ee638dab7f44a4d235ece1a Mon Sep 17 00:00:00 2001
From: Gioh Kim <gi-oh.kim(a)cloud.ionos.com>
Date: Fri, 7 Dec 2018 12:04:44 +0100
Subject: [PATCH] policy.c: prevent NULL pointer referencing
+Git-commit: 467e6a1b4ece8e552ee638dab7f44a4d235ece1a
+Patch-mainline: mdadm-4.1
+References: bsc#1106078
paths could be NULL and paths[0] should be followed by NULL pointer
checking.
+Reviewed-by: NeilBrown <neilb(a)suse.com>
Signed-off-by: Gioh Kim <gi-oh.kim(a)cloud.ionos.com>
+Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
---
policy.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/policy.c b/policy.c
-index fa67d5594c04..e3a0671f3a3a 100644
+index fa67d55..e3a0671 100644
--- a/policy.c
+++ b/policy.c
@@ -383,7 +383,7 @@ struct dev_policy *path_policy(char **paths, char *type)
@@ -25,5 +30,5 @@
const char *d =
superlist[i]->get_disk_controller_domain(
--
-2.14.0.rc0.dirty
+2.25.0
++++++ 0012-policy.c-Fix-for-compiler-error.patch ++++++
>From 757e55435997e355ee9b03e5d913b5496a3c39a8 Mon Sep 17 00:00:00 2001
From: Mariusz Tkaczyk <mariusz.tkaczyk(a)intel.com>
Date: Tue, 11 Dec 2018 15:04:07 +0100
Subject: [PATCH] policy.c: Fix for compiler error
Git-commit: 757e55435997e355ee9b03e5d913b5496a3c39a8
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
After cd72f9d(policy: support devices with multiple paths.) compilation
on old compilers fails because "‘p’ may be used uninitialized
in this function".
Initialize it with NULL to prevent this.
Signed-off-by: Mariusz Tkaczyk <mariusz.tkaczyk(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
policy.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/policy.c b/policy.c
index e3a0671..3c53bd3 100644
--- a/policy.c
+++ b/policy.c
@@ -268,7 +268,7 @@ static int pol_match(struct rule *rule, char **paths, char *type, char **part)
for (; rule; rule = rule->next) {
if (rule->name == rule_path) {
- char *p;
+ char *p = NULL;
int i;
if (pathok == 0)
pathok = -1;
--
2.25.0
++++++ 0010-imsm-finish-recovery-when-drive-with-rebuild-fails.patch -> 0013-imsm-finish-recovery-when-drive-with-rebuild-fails.patch ++++++
++++++ 0014-imsm-fix-reshape-for-2TB-drives.patch ++++++
>From 9f4218274cd4a1e1f356a1617f9a1d09960cf255 Mon Sep 17 00:00:00 2001
From: Pawel Baldysiak <pawel.baldysiak(a)intel.com>
Date: Mon, 28 Jan 2019 17:10:41 +0100
Subject: [PATCH] imsm: fix reshape for >2TB drives
Git-commit: 9f4218274cd4a1e1f356a1617f9a1d09960cf255
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
If reshape is performed on drives larger then 2 TB,
migration checkpoint area that is calculated exeeds 32-bit value.
This checkpoint area is a reserved space threated as backup
during reshape - at the end of the drive, right before metadata.
As a result - wrong space is used and the data that may exists there
is overwritten.
Adding additional field to migration record to track high order 32-bits
of pba of this area. Three other fields that may exceed 32-bit value
for large drives are added as well.
Signed-off-by: Pawel Baldysiak <pawel.baldysiak(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
super-intel.c | 149 ++++++++++++++++++++++++++++++++++++--------------
1 file changed, 107 insertions(+), 42 deletions(-)
diff --git a/super-intel.c b/super-intel.c
index 38a1b6c..1cc7d5f 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -296,7 +296,7 @@ struct migr_record {
__u32 rec_status; /* Status used to determine how to restart
* migration in case it aborts
* in some fashion */
- __u32 curr_migr_unit; /* 0..numMigrUnits-1 */
+ __u32 curr_migr_unit_lo; /* 0..numMigrUnits-1 */
__u32 family_num; /* Family number of MPB
* containing the RaidDev
* that is migrating */
@@ -306,16 +306,23 @@ struct migr_record {
__u32 dest_depth_per_unit; /* Num member blocks each destMap
* member disk
* advances per unit-of-operation */
- __u32 ckpt_area_pba; /* Pba of first block of ckpt copy area */
- __u32 dest_1st_member_lba; /* First member lba on first
- * stripe of destination */
- __u32 num_migr_units; /* Total num migration units-of-op */
+ __u32 ckpt_area_pba_lo; /* Pba of first block of ckpt copy area */
+ __u32 dest_1st_member_lba_lo; /* First member lba on first
+ * stripe of destination */
+ __u32 num_migr_units_lo; /* Total num migration units-of-op */
__u32 post_migr_vol_cap; /* Size of volume after
* migration completes */
__u32 post_migr_vol_cap_hi; /* Expansion space for LBA64 */
__u32 ckpt_read_disk_num; /* Which member disk in destSubMap[0] the
* migration ckpt record was read from
* (for recovered migrations) */
+ __u32 curr_migr_unit_hi; /* 0..numMigrUnits-1 high order 32 bits */
+ __u32 ckpt_area_pba_hi; /* Pba of first block of ckpt copy area
+ * high order 32 bits */
+ __u32 dest_1st_member_lba_hi; /* First member lba on first stripe of
+ * destination - high order 32 bits */
+ __u32 num_migr_units_hi; /* Total num migration units-of-op
+ * high order 32 bits */
} __attribute__ ((__packed__));
struct md_list {
@@ -1208,6 +1215,38 @@ static unsigned long long imsm_dev_size(struct imsm_dev *dev)
return join_u32(dev->size_low, dev->size_high);
}
+static unsigned long long migr_chkp_area_pba(struct migr_record *migr_rec)
+{
+ if (migr_rec == NULL)
+ return 0;
+ return join_u32(migr_rec->ckpt_area_pba_lo,
+ migr_rec->ckpt_area_pba_hi);
+}
+
+static unsigned long long current_migr_unit(struct migr_record *migr_rec)
+{
+ if (migr_rec == NULL)
+ return 0;
+ return join_u32(migr_rec->curr_migr_unit_lo,
+ migr_rec->curr_migr_unit_hi);
+}
+
+static unsigned long long migr_dest_1st_member_lba(struct migr_record *migr_rec)
+{
+ if (migr_rec == NULL)
+ return 0;
+ return join_u32(migr_rec->dest_1st_member_lba_lo,
+ migr_rec->dest_1st_member_lba_hi);
+}
+
+static unsigned long long get_num_migr_units(struct migr_record *migr_rec)
+{
+ if (migr_rec == NULL)
+ return 0;
+ return join_u32(migr_rec->num_migr_units_lo,
+ migr_rec->num_migr_units_hi);
+}
+
static void set_total_blocks(struct imsm_disk *disk, unsigned long long n)
{
split_ull(n, &disk->total_blocks_lo, &disk->total_blocks_hi);
@@ -1233,6 +1272,33 @@ static void set_imsm_dev_size(struct imsm_dev *dev, unsigned long long n)
split_ull(n, &dev->size_low, &dev->size_high);
}
+static void set_migr_chkp_area_pba(struct migr_record *migr_rec,
+ unsigned long long n)
+{
+ split_ull(n, &migr_rec->ckpt_area_pba_lo, &migr_rec->ckpt_area_pba_hi);
+}
+
+static void set_current_migr_unit(struct migr_record *migr_rec,
+ unsigned long long n)
+{
+ split_ull(n, &migr_rec->curr_migr_unit_lo,
+ &migr_rec->curr_migr_unit_hi);
+}
+
+static void set_migr_dest_1st_member_lba(struct migr_record *migr_rec,
+ unsigned long long n)
+{
+ split_ull(n, &migr_rec->dest_1st_member_lba_lo,
+ &migr_rec->dest_1st_member_lba_hi);
+}
+
+static void set_num_migr_units(struct migr_record *migr_rec,
+ unsigned long long n)
+{
+ split_ull(n, &migr_rec->num_migr_units_lo,
+ &migr_rec->num_migr_units_hi);
+}
+
static unsigned long long per_dev_array_size(struct imsm_map *map)
{
unsigned long long array_size = 0;
@@ -1629,12 +1695,14 @@ void convert_to_4k_imsm_migr_rec(struct intel_super *super)
struct migr_record *migr_rec = super->migr_rec;
migr_rec->blocks_per_unit /= IMSM_4K_DIV;
- migr_rec->ckpt_area_pba /= IMSM_4K_DIV;
- migr_rec->dest_1st_member_lba /= IMSM_4K_DIV;
migr_rec->dest_depth_per_unit /= IMSM_4K_DIV;
split_ull((join_u32(migr_rec->post_migr_vol_cap,
migr_rec->post_migr_vol_cap_hi) / IMSM_4K_DIV),
&migr_rec->post_migr_vol_cap, &migr_rec->post_migr_vol_cap_hi);
+ set_migr_chkp_area_pba(migr_rec,
+ migr_chkp_area_pba(migr_rec) / IMSM_4K_DIV);
+ set_migr_dest_1st_member_lba(migr_rec,
+ migr_dest_1st_member_lba(migr_rec) / IMSM_4K_DIV);
}
void convert_to_4k_imsm_disk(struct imsm_disk *disk)
@@ -1727,8 +1795,8 @@ void examine_migr_rec_imsm(struct intel_super *super)
printf("Normal\n");
else
printf("Contains Data\n");
- printf(" Current Unit : %u\n",
- __le32_to_cpu(migr_rec->curr_migr_unit));
+ printf(" Current Unit : %llu\n",
+ current_migr_unit(migr_rec));
printf(" Family : %u\n",
__le32_to_cpu(migr_rec->family_num));
printf(" Ascending : %u\n",
@@ -1737,16 +1805,15 @@ void examine_migr_rec_imsm(struct intel_super *super)
__le32_to_cpu(migr_rec->blocks_per_unit));
printf(" Dest. Depth Per Unit : %u\n",
__le32_to_cpu(migr_rec->dest_depth_per_unit));
- printf(" Checkpoint Area pba : %u\n",
- __le32_to_cpu(migr_rec->ckpt_area_pba));
- printf(" First member lba : %u\n",
- __le32_to_cpu(migr_rec->dest_1st_member_lba));
- printf(" Total Number of Units : %u\n",
- __le32_to_cpu(migr_rec->num_migr_units));
- printf(" Size of volume : %u\n",
- __le32_to_cpu(migr_rec->post_migr_vol_cap));
- printf(" Expansion space for LBA64 : %u\n",
- __le32_to_cpu(migr_rec->post_migr_vol_cap_hi));
+ printf(" Checkpoint Area pba : %llu\n",
+ migr_chkp_area_pba(migr_rec));
+ printf(" First member lba : %llu\n",
+ migr_dest_1st_member_lba(migr_rec));
+ printf(" Total Number of Units : %llu\n",
+ get_num_migr_units(migr_rec));
+ printf(" Size of volume : %llu\n",
+ join_u32(migr_rec->post_migr_vol_cap,
+ migr_rec->post_migr_vol_cap_hi));
printf(" Record was read from : %u\n",
__le32_to_cpu(migr_rec->ckpt_read_disk_num));
@@ -1759,13 +1826,15 @@ void convert_from_4k_imsm_migr_rec(struct intel_super *super)
struct migr_record *migr_rec = super->migr_rec;
migr_rec->blocks_per_unit *= IMSM_4K_DIV;
- migr_rec->ckpt_area_pba *= IMSM_4K_DIV;
- migr_rec->dest_1st_member_lba *= IMSM_4K_DIV;
migr_rec->dest_depth_per_unit *= IMSM_4K_DIV;
split_ull((join_u32(migr_rec->post_migr_vol_cap,
migr_rec->post_migr_vol_cap_hi) * IMSM_4K_DIV),
&migr_rec->post_migr_vol_cap,
&migr_rec->post_migr_vol_cap_hi);
+ set_migr_chkp_area_pba(migr_rec,
+ migr_chkp_area_pba(migr_rec) * IMSM_4K_DIV);
+ set_migr_dest_1st_member_lba(migr_rec,
+ migr_dest_1st_member_lba(migr_rec) * IMSM_4K_DIV);
}
void convert_from_4k(struct intel_super *super)
@@ -3096,7 +3165,7 @@ static int imsm_create_metadata_checkpoint_update(
return 0;
}
(*u)->type = update_general_migration_checkpoint;
- (*u)->curr_migr_unit = __le32_to_cpu(super->migr_rec->curr_migr_unit);
+ (*u)->curr_migr_unit = current_migr_unit(super->migr_rec);
dprintf("prepared for %u\n", (*u)->curr_migr_unit);
return update_memory_size;
@@ -3397,13 +3466,13 @@ static void getinfo_super_imsm_volume(struct supertype *st, struct mdinfo *info,
case MIGR_GEN_MIGR: {
__u64 blocks_per_unit = blocks_per_migr_unit(super,
dev);
- __u64 units = __le32_to_cpu(migr_rec->curr_migr_unit);
+ __u64 units = current_migr_unit(migr_rec);
unsigned long long array_blocks;
int used_disks;
if (__le32_to_cpu(migr_rec->ascending_migr) &&
(units <
- (__le32_to_cpu(migr_rec->num_migr_units)-1)) &&
+ (get_num_migr_units(migr_rec)-1)) &&
(super->migr_rec->rec_status ==
__cpu_to_le32(UNIT_SRC_IN_CP_AREA)))
units++;
@@ -10697,7 +10766,7 @@ void init_migr_record_imsm(struct supertype *st, struct imsm_dev *dev,
if (array_blocks % __le32_to_cpu(migr_rec->blocks_per_unit))
num_migr_units++;
- migr_rec->num_migr_units = __cpu_to_le32(num_migr_units);
+ set_num_migr_units(migr_rec, num_migr_units);
migr_rec->post_migr_vol_cap = dev->size_low;
migr_rec->post_migr_vol_cap_hi = dev->size_high;
@@ -10714,7 +10783,7 @@ void init_migr_record_imsm(struct supertype *st, struct imsm_dev *dev,
min_dev_sectors = dev_sectors;
close(fd);
}
- migr_rec->ckpt_area_pba = __cpu_to_le32(min_dev_sectors -
+ set_migr_chkp_area_pba(migr_rec, min_dev_sectors -
RAID_DISK_RESERVED_BLOCKS_IMSM_HI);
write_imsm_migr_rec(st);
@@ -10765,8 +10834,7 @@ int save_backup_imsm(struct supertype *st,
start = info->reshape_progress * 512;
for (i = 0; i < new_disks; i++) {
- target_offsets[i] = (unsigned long long)
- __le32_to_cpu(super->migr_rec->ckpt_area_pba) * 512;
+ target_offsets[i] = migr_chkp_area_pba(super->migr_rec) * 512;
/* move back copy area adderss, it will be moved forward
* in restore_stripes() using start input variable
*/
@@ -10845,12 +10913,11 @@ int save_checkpoint_imsm(struct supertype *st, struct mdinfo *info, int state)
if (info->reshape_progress % blocks_per_unit)
curr_migr_unit++;
- super->migr_rec->curr_migr_unit =
- __cpu_to_le32(curr_migr_unit);
+ set_current_migr_unit(super->migr_rec, curr_migr_unit);
super->migr_rec->rec_status = __cpu_to_le32(state);
- super->migr_rec->dest_1st_member_lba =
- __cpu_to_le32(curr_migr_unit *
- __le32_to_cpu(super->migr_rec->dest_depth_per_unit));
+ set_migr_dest_1st_member_lba(super->migr_rec,
+ super->migr_rec->dest_depth_per_unit * curr_migr_unit);
+
if (write_imsm_migr_rec(st) < 0) {
dprintf("imsm: Cannot write migration record outside backup area\n");
return 1;
@@ -10884,8 +10951,8 @@ int recover_backup_imsm(struct supertype *st, struct mdinfo *info)
char *buf = NULL;
int retval = 1;
unsigned int sector_size = super->sector_size;
- unsigned long curr_migr_unit = __le32_to_cpu(migr_rec->curr_migr_unit);
- unsigned long num_migr_units = __le32_to_cpu(migr_rec->num_migr_units);
+ unsigned long curr_migr_unit = current_migr_unit(migr_rec);
+ unsigned long num_migr_units = get_num_migr_units(migr_rec);
char buffer[20];
int skipped_disks = 0;
@@ -10912,11 +10979,9 @@ int recover_backup_imsm(struct supertype *st, struct mdinfo *info)
map_dest = get_imsm_map(id->dev, MAP_0);
new_disks = map_dest->num_members;
- read_offset = (unsigned long long)
- __le32_to_cpu(migr_rec->ckpt_area_pba) * 512;
+ read_offset = migr_chkp_area_pba(migr_rec) * 512;
- write_offset = ((unsigned long long)
- __le32_to_cpu(migr_rec->dest_1st_member_lba) +
+ write_offset = (migr_dest_1st_member_lba(migr_rec) +
pba_of_lba0(map_dest)) * 512;
unit_len = __le32_to_cpu(migr_rec->dest_depth_per_unit) * 512;
@@ -12019,12 +12084,12 @@ static int imsm_manage_reshape(
max_position = sra->component_size * ndata;
source_layout = imsm_level_to_layout(map_src->raid_level);
- while (__le32_to_cpu(migr_rec->curr_migr_unit) <
- __le32_to_cpu(migr_rec->num_migr_units)) {
+ while (current_migr_unit(migr_rec) <
+ get_num_migr_units(migr_rec)) {
/* current reshape position [blocks] */
unsigned long long current_position =
__le32_to_cpu(migr_rec->blocks_per_unit)
- * __le32_to_cpu(migr_rec->curr_migr_unit);
+ * current_migr_unit(migr_rec);
unsigned long long border;
/* Check that array hasn't become failed.
--
2.25.0
++++++ 0015-Fix-spelling-typos.patch ++++++
>From ebf3be9931f31df54df52b1821479e6a80a4d9c6 Mon Sep 17 00:00:00 2001
From: Dimitri John Ledkov <xnox(a)ubuntu.com>
Date: Tue, 15 Jan 2019 19:08:37 +0000
Subject: [PATCH] Fix spelling typos.
Git-commit: ebf3be9931f31df54df52b1821479e6a80a4d9c6
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Signed-off-by: Dimitri John Ledkov <xnox(a)ubuntu.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
Assemble.c | 2 +-
Create.c | 2 +-
Grow.c | 6 +++---
super-ddf.c | 2 +-
super-intel.c | 2 +-
5 files changed, 7 insertions(+), 7 deletions(-)
diff --git a/Assemble.c b/Assemble.c
index 9f75c68..9f050c1 100644
--- a/Assemble.c
+++ b/Assemble.c
@@ -879,7 +879,7 @@ static int force_array(struct mdinfo *content,
current_events = devices[chosen_drive].i.events;
add_another:
if (c->verbose >= 0)
- pr_err("forcing event count in %s(%d) from %d upto %d\n",
+ pr_err("forcing event count in %s(%d) from %d up to %d\n",
devices[chosen_drive].devname,
devices[chosen_drive].i.disk.raid_disk,
(int)(devices[chosen_drive].i.events),
diff --git a/Create.c b/Create.c
index 04b1dfc..6f1b228 100644
--- a/Create.c
+++ b/Create.c
@@ -823,7 +823,7 @@ int Create(struct supertype *st, char *mddev,
}
bitmap_fd = open(s->bitmap_file, O_RDWR);
if (bitmap_fd < 0) {
- pr_err("weird: %s cannot be openned\n",
+ pr_err("weird: %s cannot be opened\n",
s->bitmap_file);
goto abort_locked;
}
diff --git a/Grow.c b/Grow.c
index 363b209..6d32661 100644
--- a/Grow.c
+++ b/Grow.c
@@ -446,7 +446,7 @@ int Grow_addbitmap(char *devname, int fd, struct context *c, struct shape *s)
if (offset_setable) {
st->ss->getinfo_super(st, mdi, NULL);
if (sysfs_init(mdi, fd, NULL)) {
- pr_err("failed to intialize sysfs.\n");
+ pr_err("failed to initialize sysfs.\n");
free(mdi);
}
rv = sysfs_set_num_signed(mdi, NULL, "bitmap/location",
@@ -2178,7 +2178,7 @@ size_change_error:
memset(&info, 0, sizeof(info));
info.array = array;
if (sysfs_init(&info, fd, NULL)) {
- pr_err("failed to intialize sysfs.\n");
+ pr_err("failed to initialize sysfs.\n");
rv = 1;
goto release;
}
@@ -2903,7 +2903,7 @@ static int impose_level(int fd, int level, char *devname, int verbose)
struct mdinfo info;
if (sysfs_init(&info, fd, NULL)) {
- pr_err("failed to intialize sysfs.\n");
+ pr_err("failed to initialize sysfs.\n");
return 1;
}
diff --git a/super-ddf.c b/super-ddf.c
index 618542c..c095e8a 100644
--- a/super-ddf.c
+++ b/super-ddf.c
@@ -1900,7 +1900,7 @@ static struct vd_config *find_vdcr(struct ddf_super *ddf, unsigned int inst,
return conf;
}
bad:
- pr_err("Could't find disk %d in array %u\n", n, inst);
+ pr_err("Couldn't find disk %d in array %u\n", n, inst);
return NULL;
}
diff --git a/super-intel.c b/super-intel.c
index 1cc7d5f..c399433 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -10034,7 +10034,7 @@ static void imsm_process_update(struct supertype *st,
break;
}
default:
- pr_err("error: unsuported process update type:(type: %d)\n", type);
+ pr_err("error: unsupported process update type:(type: %d)\n", type);
}
}
--
2.25.0
++++++ 0009-Detail.c-do-not-skip-first-character-when-calling-xs.patch -> 0016-Detail.c-do-not-skip-first-character-when-calling-xs.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/0009-Detail.c-do-not-skip-first-character-when-calling-xs.patch 2019-02-24 17:04:56.996636100 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0016-Detail.c-do-not-skip-first-character-when-calling-xs.patch 2020-03-31 17:31:48.084244890 +0200
@@ -1,9 +1,10 @@
-From 02acb5718a68b16def418699c6afcc84223f52c7 Mon Sep 17 00:00:00 2001
+From e3615ecb5b6ad8eb408296878aad5628e0e27166 Mon Sep 17 00:00:00 2001
From: Coly Li <colyli(a)suse.de>
-Date: Tue, 12 Feb 2019 12:43:40 +0800
+Date: Tue, 12 Feb 2019 12:53:18 +0800
Subject: [PATCH] Detail.c: do not skip first character when calling xstrdup in
Detail()
-Git-commit: Posted but not upstreamed yet
+Git-commit: e3615ecb5b6ad8eb408296878aad5628e0e27166
+Patch-mainline: mdadm-4.1+
References: bsc#1123814
'Commit b9c9bd9bacaa ("Detail: ensure --export names are acceptable as
@@ -25,6 +26,7 @@
Fixes: b9c9bd9bacaa ("Detail: ensure --export names are acceptable as 4 shell variables")
Signed-off-by: Coly Li <colyli(a)suse.de>
Cc: NeilBrown <neilb(a)suse.com>
+Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
---
Detail.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
@@ -43,5 +45,5 @@
path = map_dev(mdi->disk.major,
--
-2.16.4
+2.25.0
++++++ 0018-Fix-reshape-for-decreasing-data-offset.patch ++++++
>From cab114c5ca870e5f1b57fb2602cd9a038271c2e0 Mon Sep 17 00:00:00 2001
From: Corey Hickey <bugfood-c(a)fatooh.org>
Date: Mon, 11 Feb 2019 17:18:38 -0800
Subject: [PATCH] Fix reshape for decreasing data offset
Git-commit: cab114c5ca870e5f1b57fb2602cd9a038271c2e0
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
...when not changing the number of disks.
This patch needs context to explain. These are the relevant parts of
the original code (condensed and annotated):
if (dir > 0) {
/* Increase data offset (reshape backwards) */
if (data_offset < sd->data_offset + min) {
pr_err("--data-offset too small on %s\n",
dn);
goto release;
}
} else {
/* Decrease data offset (reshape forwards) */
if (data_offset < sd->data_offset - min) {
pr_err("--data-offset too small on %s\n",
dn);
goto release;
}
}
When this code is reached, mdadm has already decided on a reshape
direction. When increasing the data offset, the reshape runs backwards
(dir==1); when decreasing the data offset, the reshape runs forwards
(dir==-1).
The conditional within the backwards reshape is correct: the requested
offset must be larger than the old offset plus a minimum delta; thus the
reshape has room to work.
For the forwards reshape, the requested offset needs to be smaller than
the old offset minus a minimum delta; to do this correctly, the
comparison must be reversed.
Also update the error message.
Note: I have tested this change on a RAID 5 on Linux 4.18.0 and verified
that there were no errors from the kernel and that the device data
remained intact. I do not know if there are considerations for different
RAID levels.
Signed-off-by: Corey Hickey <bugfood-c(a)fatooh.org>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
Grow.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/Grow.c b/Grow.c
index 6d32661..764374f 100644
--- a/Grow.c
+++ b/Grow.c
@@ -2613,8 +2613,8 @@ static int set_new_data_offset(struct mdinfo *sra, struct supertype *st,
goto release;
}
if (data_offset != INVALID_SECTORS &&
- data_offset < sd->data_offset - min) {
- pr_err("--data-offset too small on %s\n",
+ data_offset > sd->data_offset - min) {
+ pr_err("--data-offset too large on %s\n",
dn);
goto release;
}
--
2.25.0
++++++ 0019-mdadm-tests-add-one-test-case-for-failfast-of-raid1.patch ++++++
>From 76b906d2406cdf136f64de77e881eb2d180108d9 Mon Sep 17 00:00:00 2001
From: Gioh Kim <gi-oh.kim(a)cloud.ionos.com>
Date: Fri, 7 Dec 2018 14:30:09 +0100
Subject: [PATCH] mdadm/tests: add one test case for failfast of raid1
Git-commit: 76b906d2406cdf136f64de77e881eb2d180108d9
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
This creates raid1 device with the failfast option and check all
slaves have the failfast flag. And it does assembling and growing
the raid1 device and check the failfast works fine.
Signed-off-by: Gioh Kim <gi-oh.kim(a)cloud.ionos.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
tests/05r1-failfast | 74 +++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 74 insertions(+)
create mode 100644 tests/05r1-failfast
diff --git a/tests/05r1-failfast b/tests/05r1-failfast
new file mode 100644
index 0000000..823dd6f
--- /dev/null
+++ b/tests/05r1-failfast
@@ -0,0 +1,74 @@
+
+# create a simple mirror and check failfast flag works
+mdadm -CR $md0 -e1.2 --level=raid1 --failfast -n2 $dev0 $dev1
+check raid1
+if grep -v failfast /sys/block/md0/md/rd*/state > /dev/null
+then
+ die "failfast missing"
+fi
+
+# Removing works with the failfast flag
+mdadm $md0 -f $dev0
+mdadm $md0 -r $dev0
+if grep -v failfast /sys/block/md0/md/rd1/state > /dev/null
+then
+ die "failfast missing"
+fi
+
+# Adding works with the failfast flag
+mdadm $md0 -a --failfast $dev0
+check wait
+if grep -v failfast /sys/block/md0/md/rd0/state > /dev/null
+then
+ die "failfast missing"
+fi
+
+mdadm -S $md0
+
+# Assembling works with the failfast flag
+mdadm -A $md0 $dev0 $dev1
+check raid1
+if grep -v failfast /sys/block/md0/md/rd*/state > /dev/null
+then
+ die "failfast missing"
+fi
+
+# Adding works with the nofailfast flag
+mdadm $md0 -f $dev0
+mdadm $md0 -r $dev0
+mdadm $md0 -a --nofailfast $dev0
+check wait
+if grep failfast /sys/block/md0/md/rd0/state > /dev/null
+then
+ die "failfast should be missing"
+fi
+
+# Assembling with one faulty slave works with the failfast flag
+mdadm $md0 -f $dev0
+mdadm $md0 -r $dev0
+mdadm -S $md0
+mdadm -A $md0 $dev0 $dev1
+check raid1
+mdadm -S $md0
+
+# Spare works with the failfast flag
+mdadm -CR $md0 -e1.2 --level=raid1 --failfast -n2 $dev0 $dev1
+check raid1
+mdadm $md0 -a --failfast $dev2
+check wait
+check spares 1
+if grep -v failfast /sys/block/md0/md/rd*/state > /dev/null
+then
+ die "failfast missing"
+fi
+
+# Grow works with the failfast flag
+mdadm -G $md0 --raid-devices=3
+check wait
+if grep -v failfast /sys/block/md0/md/rd*/state > /dev/null
+then
+ die "failfast missing"
+fi
+mdadm -S $md0
+
+exit 0
--
2.25.0
++++++ 0011-mdmon-don-t-attempt-to-manage-new-arrays-when-termin.patch -> 0020-mdmon-don-t-attempt-to-manage-new-arrays-when-termin.patch ++++++
++++++ 0021-mdmon-wait-for-previous-mdmon-to-exit-during-takeove.patch ++++++
>From d2e11da4b7fd0453e942f43e4196dc63b3dbd708 Mon Sep 17 00:00:00 2001
From: Pawel Baldysiak <pawel.baldysiak(a)intel.com>
Date: Fri, 22 Feb 2019 13:30:27 +0100
Subject: [PATCH] mdmon: wait for previous mdmon to exit during takeover
Git-commit: d2e11da4b7fd0453e942f43e4196dc63b3dbd708
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Since the patch c76242c5("mdmon: get safe mode delay file descriptor
early"), safe_mode_dalay is set properly by initrd mdmon. But in some
cases with filesystem traffic since the very start of the system, it
might take a while to transit to clean state. Due to fact that new
mdmon does not wait for the old one to exit - it might happen that the
new one switches safe_mode_delay back to seconds, before old one exits.
As the result two mdmons are running concurrently on same array.
Wait for the old mdmon to exit by pinging it with SIGUSR1 signal, just
in case it is sleeping.
Signed-off-by: Pawel Baldysiak <pawel.baldysiak(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
mdmon.c | 14 +++++++++++---
1 file changed, 11 insertions(+), 3 deletions(-)
diff --git a/mdmon.c b/mdmon.c
index 0955fcc..ff985d2 100644
--- a/mdmon.c
+++ b/mdmon.c
@@ -171,6 +171,7 @@ static void try_kill_monitor(pid_t pid, char *devname, int sock)
int fd;
int n;
long fl;
+ int rv;
/* first rule of survival... don't off yourself */
if (pid == getpid())
@@ -201,9 +202,16 @@ static void try_kill_monitor(pid_t pid, char *devname, int sock)
fl &= ~O_NONBLOCK;
fcntl(sock, F_SETFL, fl);
n = read(sock, buf, 100);
- /* Ignore result, it is just the wait that
- * matters
- */
+
+ /* If there is I/O going on it might took some time to get to
+ * clean state. Wait for monitor to exit fully to avoid races.
+ * Ping it with SIGUSR1 in case that it is sleeping */
+ for (n = 0; n < 25; n++) {
+ rv = kill(pid, SIGUSR1);
+ if (rv < 0)
+ break;
+ usleep(200000);
+ }
}
void remove_pidfile(char *devname)
--
2.25.0
++++++ 0022-Assemble-Fix-starting-array-with-initial-reshape-che.patch ++++++
>From 2b57e4fe041d52ae29866c93a878a11c07223cff Mon Sep 17 00:00:00 2001
From: Pawel Baldysiak <pawel.baldysiak(a)intel.com>
Date: Fri, 22 Feb 2019 12:56:27 +0100
Subject: [PATCH] Assemble: Fix starting array with initial reshape checkpoint
Git-commit: 2b57e4fe041d52ae29866c93a878a11c07223cff
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
If array was stopped during reshape initialization,
there might be a "0" checkpoint recorded in metadata.
If array with such condition (reshape with position 0)
is passed to kernel - it will refuse to start such array.
Treat such array as normal during assemble, Grow_continue() will
reinitialize and start the reshape.
Signed-off-by: Pawel Baldysiak <pawel.baldysiak(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
Assemble.c | 18 ++++++++++++++++--
1 file changed, 16 insertions(+), 2 deletions(-)
diff --git a/Assemble.c b/Assemble.c
index 9f050c1..420c7b3 100644
--- a/Assemble.c
+++ b/Assemble.c
@@ -2061,8 +2061,22 @@ int assemble_container_content(struct supertype *st, int mdfd,
spare, &c->backup_file, c->verbose) == 1)
return 1;
- err = sysfs_set_str(content, NULL,
- "array_state", "readonly");
+ if (content->reshape_progress == 0) {
+ /* If reshape progress is 0 - we are assembling the
+ * array that was stopped, before reshape has started.
+ * Array needs to be started as active, Grow_continue()
+ * will start the reshape.
+ */
+ sysfs_set_num(content, NULL, "reshape_position",
+ MaxSector);
+ err = sysfs_set_str(content, NULL,
+ "array_state", "active");
+ sysfs_set_num(content, NULL, "reshape_position", 0);
+ } else {
+ err = sysfs_set_str(content, NULL,
+ "array_state", "readonly");
+ }
+
if (err)
return 1;
--
2.25.0
++++++ 0023-add-missing-units-to-examine.patch ++++++
>From 227aeaa872d4898273cf87a4253898823d556c43 Mon Sep 17 00:00:00 2001
From: Corey Hickey <bugfood-c(a)fatooh.org>
Date: Mon, 11 Feb 2019 17:42:27 -0800
Subject: [PATCH] add missing units to --examine
Git-commit: 227aeaa872d4898273cf87a4253898823d556c43
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Within the output of "mdadm --examine", there are three sizes reported
on adjacent lines. For example:
$ sudo mdadm --examine /dev/md3
[...]
Avail Dev Size : 17580545024 (8383.06 GiB 9001.24 GB)
Array Size : 17580417024 (16765.99 GiB 18002.35 GB)
Used Dev Size : 11720278016 (5588.66 GiB 6000.78 GB)
[...]
This can be confusing, since the first and third line are in 512-byte
sectors, and the second is in KiB.
Add units to avoid ambiguity.
(I don't particularly like the "KiB" notation, but it is at least
unambiguous.)
Signed-off-by: Corey Hickey <bugfood-c(a)fatooh.org>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
super1.c | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/super1.c b/super1.c
index 636a286..b85dc20 100644
--- a/super1.c
+++ b/super1.c
@@ -360,7 +360,7 @@ static void examine_super1(struct supertype *st, char *homehost)
printf(" Raid Level : %s\n", c?c:"-unknown-");
printf(" Raid Devices : %d\n", __le32_to_cpu(sb->raid_disks));
printf("\n");
- printf(" Avail Dev Size : %llu%s\n",
+ printf(" Avail Dev Size : %llu sectors%s\n",
(unsigned long long)__le64_to_cpu(sb->data_size),
human_size(__le64_to_cpu(sb->data_size)<<9));
if (__le32_to_cpu(sb->level) > 0) {
@@ -378,11 +378,11 @@ static void examine_super1(struct supertype *st, char *homehost)
if (ddsks) {
long long asize = __le64_to_cpu(sb->size);
asize = (asize << 9) * ddsks / ddsks_denom;
- printf(" Array Size : %llu%s\n",
+ printf(" Array Size : %llu KiB%s\n",
asize >> 10, human_size(asize));
}
if (sb->size != sb->data_size)
- printf(" Used Dev Size : %llu%s\n",
+ printf(" Used Dev Size : %llu sectors%s\n",
(unsigned long long)__le64_to_cpu(sb->size),
human_size(__le64_to_cpu(sb->size)<<9));
}
--
2.25.0
++++++ 0024-imsm-fix-spare-activation-for-old-matrix-arrays.patch ++++++
>From 05501181f18cdccdb0b3cec1d8cf59f0995504d7 Mon Sep 17 00:00:00 2001
From: Pawel Baldysiak <pawel.baldysiak(a)intel.com>
Date: Fri, 8 Mar 2019 12:19:11 +0100
Subject: [PATCH] imsm: fix spare activation for old matrix arrays
Git-commit: 05501181f18cdccdb0b3cec1d8cf59f0995504d7
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
During spare activation get_extents() calculates metadata reserved space based
on smallest active RAID member or it will take the defaults. Since patch
611d9529("imsm: change reserved space to 4MB") default is extended. If array
was created prior that patch, reserved space is smaller. In case of matrix
RAID - spare is activated in each array one-by-one, so it is spare for first
activation, but treated as "active" during second one.
In case of adding spare drive to old matrix RAID with the size the same as
already existing member drive the routine will take the defaults during second
run and mdmon will refuse to rebuild second volume, claiming that the drive
does not have enough free space.
Add parameter to get_extents(), so the during spare activation reserved space
is always based on smallest active drive - even if given drive is already
active in some other array of matrix RAID.
Signed-off-by: Pawel Baldysiak <pawel.baldysiak(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
super-intel.c | 19 ++++++++++---------
1 file changed, 10 insertions(+), 9 deletions(-)
diff --git a/super-intel.c b/super-intel.c
index c399433..5a7c9f8 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -1313,7 +1313,8 @@ static unsigned long long per_dev_array_size(struct imsm_map *map)
return array_size;
}
-static struct extent *get_extents(struct intel_super *super, struct dl *dl)
+static struct extent *get_extents(struct intel_super *super, struct dl *dl,
+ int get_minimal_reservation)
{
/* find a list of used extents on the given physical device */
struct extent *rv, *e;
@@ -1325,7 +1326,7 @@ static struct extent *get_extents(struct intel_super *super, struct dl *dl)
* regardless of whether the OROM has assigned sectors from the
* IMSM_RESERVED_SECTORS region
*/
- if (dl->index == -1)
+ if (dl->index == -1 || get_minimal_reservation)
reservation = imsm_min_reserved_sectors(super);
else
reservation = MPB_SECTOR_CNT + IMSM_RESERVED_SECTORS;
@@ -1386,7 +1387,7 @@ static __u32 imsm_reserved_sectors(struct intel_super *super, struct dl *dl)
if (dl->index == -1)
return MPB_SECTOR_CNT;
- e = get_extents(super, dl);
+ e = get_extents(super, dl, 0);
if (!e)
return MPB_SECTOR_CNT + IMSM_RESERVED_SECTORS;
@@ -1478,7 +1479,7 @@ static __u32 imsm_min_reserved_sectors(struct intel_super *super)
return rv;
/* find last lba used by subarrays on the smallest active disk */
- e = get_extents(super, dl_min);
+ e = get_extents(super, dl_min, 0);
if (!e)
return rv;
for (i = 0; e[i].size; i++)
@@ -1519,7 +1520,7 @@ int get_spare_criteria_imsm(struct supertype *st, struct spare_criteria *c)
if (!dl)
return -EINVAL;
/* find last lba used by subarrays */
- e = get_extents(super, dl);
+ e = get_extents(super, dl, 0);
if (!e)
return -EINVAL;
for (i = 0; e[i].size; i++)
@@ -7203,7 +7204,7 @@ static int validate_geometry_imsm_volume(struct supertype *st, int level,
pos = 0;
i = 0;
- e = get_extents(super, dl);
+ e = get_extents(super, dl, 0);
if (!e) continue;
do {
unsigned long long esize;
@@ -7261,7 +7262,7 @@ static int validate_geometry_imsm_volume(struct supertype *st, int level,
}
/* retrieve the largest free space block */
- e = get_extents(super, dl);
+ e = get_extents(super, dl, 0);
maxsize = 0;
i = 0;
if (e) {
@@ -7359,7 +7360,7 @@ static int imsm_get_free_size(struct supertype *st, int raiddisks,
if (super->orom && dl->index < 0 && mpb->num_raid_devs)
continue;
- e = get_extents(super, dl);
+ e = get_extents(super, dl, 0);
if (!e)
continue;
for (i = 1; e[i-1].size; i++)
@@ -8846,7 +8847,7 @@ static struct dl *imsm_add_spare(struct intel_super *super, int slot,
/* Does this unused device have the requisite free space?
* It needs to be able to cover all member volumes
*/
- ex = get_extents(super, dl);
+ ex = get_extents(super, dl, 1);
if (!ex) {
dprintf("cannot get extents\n");
continue;
--
2.25.0
++++++ 0025-Create-Block-rounding-size-to-max.patch ++++++
>From 22dc741f63e6403d59c2c14f56fd4791265f9bbb Mon Sep 17 00:00:00 2001
From: Mariusz Tkaczyk <mariusz.tkaczyk(a)intel.com>
Date: Mon, 1 Apr 2019 16:53:41 +0200
Subject: [PATCH] Create: Block rounding size to max
Git-commit: 22dc741f63e6403d59c2c14f56fd4791265f9bbb
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
When passed size is smaller than chunk, mdadm rounds it to 0 but 0 there
means max available space.
Block it for every metadata. Remove the same check from imsm routine.
Signed-off-by: Mariusz Tkaczyk <mariusz.tkaczyk(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
Create.c | 23 ++++++++++++++++++++---
super-intel.c | 5 ++---
2 files changed, 22 insertions(+), 6 deletions(-)
diff --git a/Create.c b/Create.c
index 6f1b228..292f92a 100644
--- a/Create.c
+++ b/Create.c
@@ -27,6 +27,18 @@
#include "md_p.h"
#include <ctype.h>
+static int round_size_and_verify(unsigned long long *size, int chunk)
+{
+ if (*size == 0)
+ return 0;
+ *size &= ~(unsigned long long)(chunk - 1);
+ if (*size == 0) {
+ pr_err("Size cannot be smaller than chunk.\n");
+ return 1;
+ }
+ return 0;
+}
+
static int default_layout(struct supertype *st, int level, int verbose)
{
int layout = UnSet;
@@ -248,11 +260,14 @@ int Create(struct supertype *st, char *mddev,
pr_err("unknown level %d\n", s->level);
return 1;
}
+
if (s->size == MAX_SIZE)
/* use '0' to mean 'max' now... */
s->size = 0;
if (s->size && s->chunk && s->chunk != UnSet)
- s->size &= ~(unsigned long long)(s->chunk - 1);
+ if (round_size_and_verify(&s->size, s->chunk))
+ return 1;
+
newsize = s->size * 2;
if (st && ! st->ss->validate_geometry(st, s->level, s->layout, s->raiddisks,
&s->chunk, s->size*2,
@@ -267,7 +282,8 @@ int Create(struct supertype *st, char *mddev,
/* default chunk was just set */
if (c->verbose > 0)
pr_err("chunk size defaults to %dK\n", s->chunk);
- s->size &= ~(unsigned long long)(s->chunk - 1);
+ if (round_size_and_verify(&s->size, s->chunk))
+ return 1;
do_default_chunk = 0;
}
}
@@ -413,7 +429,8 @@ int Create(struct supertype *st, char *mddev,
/* default chunk was just set */
if (c->verbose > 0)
pr_err("chunk size defaults to %dK\n", s->chunk);
- s->size &= ~(unsigned long long)(s->chunk - 1);
+ if (round_size_and_verify(&s->size, s->chunk))
+ return 1;
do_default_chunk = 0;
}
}
diff --git a/super-intel.c b/super-intel.c
index 5a7c9f8..2ba045a 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -7455,9 +7455,8 @@ static int validate_geometry_imsm(struct supertype *st, int level, int layout,
verbose);
}
- if (size && ((size < 1024) || (*chunk != UnSet &&
- size < (unsigned long long) *chunk))) {
- pr_err("Given size must be greater than 1M and chunk size.\n");
+ if (size && (size < 1024)) {
+ pr_err("Given size must be greater than 1M.\n");
/* Depends on algorithm in Create.c :
* if container was given (dev == NULL) return -1,
* if block device was given ( dev != NULL) return 0.
--
2.25.0
++++++ 0026-udev-Add-udev-rules-to-create-by-partuuid-for-md-dev.patch ++++++
>From 3c9b46cf9ae15a9be98fc47e2080bd9494496246 Mon Sep 17 00:00:00 2001
From: Liwei Song <liwei.song(a)windriver.com>
Date: Tue, 19 Mar 2019 23:51:05 -0400
Subject: [PATCH] udev: Add udev rules to create by-partuuid for md device
Git-commit: 3c9b46cf9ae15a9be98fc47e2080bd9494496246
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
This rules will create link under /dev/disk/by-partuuid/ for
MD devices partition, with which will support specify
root=PARTUUID=XXX to boot rootfs.
Signed-off-by: Liwei Song <liwei.song(a)windriver.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
udev-md-raid-arrays.rules | 1 +
1 file changed, 1 insertion(+)
diff --git a/udev-md-raid-arrays.rules b/udev-md-raid-arrays.rules
index c95ec7b..5b99d58 100644
--- a/udev-md-raid-arrays.rules
+++ b/udev-md-raid-arrays.rules
@@ -30,6 +30,7 @@ IMPORT{builtin}="blkid"
OPTIONS+="link_priority=100"
OPTIONS+="watch"
ENV{ID_FS_USAGE}=="filesystem|other|crypto", ENV{ID_FS_UUID_ENC}=="?*", SYMLINK+="disk/by-uuid/$env{ID_FS_UUID_ENC}"
+ENV{ID_FS_USAGE}=="filesystem|other", ENV{ID_PART_ENTRY_UUID}=="?*", SYMLINK+="disk/by-partuuid/$env{ID_PART_ENTRY_UUID}"
ENV{ID_FS_USAGE}=="filesystem|other", ENV{ID_FS_LABEL_ENC}=="?*", SYMLINK+="disk/by-label/$env{ID_FS_LABEL_ENC}"
ENV{MD_LEVEL}=="raid[1-9]*", ENV{SYSTEMD_WANTS}+="mdmonitor.service"
--
2.25.0
++++++ 0027-mdmon-fix-wrong-array-state-when-disk-fails-during-m.patch ++++++
>From ae7d61e35ec2ab6361c3e509a8db00698ef3396f Mon Sep 17 00:00:00 2001
From: Artur Paszkiewicz <artur.paszkiewicz(a)intel.com>
Date: Tue, 7 May 2019 16:08:47 +0200
Subject: [PATCH] mdmon: fix wrong array state when disk fails during mdmon
startup
Git-commit: ae7d61e35ec2ab6361c3e509a8db00698ef3396f
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
If a member drive disappears and is set faulty by the kernel during
mdmon startup, after ss->load_container() but before manage_new(), mdmon
will try to readd the faulty drive to the array and start rebuilding.
Metadata on the active drive is updated, but the faulty drive is not
removed from the array and is left in a "blocked" state and any write
request to the array will block. If the faulty drive reappears in the
system e.g. after a reboot, the array will not assemble because metadata
on the drives will be incompatible (at least on imsm).
Fix this by adding a new option for sysfs_read(): "GET_DEVS_ALL". This
is an extension for the "GET_DEVS" option and causes all member devices
to be returned, even if the associated block device has been removed.
Use this option in manage_new() to include the faulty device on the
active_array's devices list. Mdmon will then properly remove the faulty
device from the array and update the metadata to reflect the degraded
state.
Signed-off-by: Artur Paszkiewicz <artur.paszkiewicz(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
managemon.c | 2 +-
mdadm.h | 1 +
super-intel.c | 2 +-
sysfs.c | 23 ++++++++++++++---------
4 files changed, 17 insertions(+), 11 deletions(-)
diff --git a/managemon.c b/managemon.c
index 29b91ba..200cf83 100644
--- a/managemon.c
+++ b/managemon.c
@@ -678,7 +678,7 @@ static void manage_new(struct mdstat_ent *mdstat,
mdi = sysfs_read(-1, mdstat->devnm,
GET_LEVEL|GET_CHUNK|GET_DISKS|GET_COMPONENT|
GET_SAFEMODE|GET_DEVS|GET_OFFSET|GET_SIZE|GET_STATE|
- GET_LAYOUT);
+ GET_LAYOUT|GET_DEVS_ALL);
if (!mdi)
return;
diff --git a/mdadm.h b/mdadm.h
index 705bd9b..427cc52 100644
--- a/mdadm.h
+++ b/mdadm.h
@@ -647,6 +647,7 @@ enum sysfs_read_flags {
GET_ERROR = (1 << 24),
GET_ARRAY_STATE = (1 << 25),
GET_CONSISTENCY_POLICY = (1 << 26),
+ GET_DEVS_ALL = (1 << 27),
};
/* If fd >= 0, get the array it is open on,
diff --git a/super-intel.c b/super-intel.c
index 2ba045a..4fd5e84 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -8560,7 +8560,7 @@ static void imsm_set_disk(struct active_array *a, int n, int state)
disk = get_imsm_disk(super, ord_to_idx(ord));
/* check for new failures */
- if (state & DS_FAULTY) {
+ if (disk && (state & DS_FAULTY)) {
if (mark_failure(super, dev, disk, ord_to_idx(ord)))
super->updates_pending++;
}
diff --git a/sysfs.c b/sysfs.c
index df6fdda..2dd9ab6 100644
--- a/sysfs.c
+++ b/sysfs.c
@@ -313,17 +313,22 @@ struct mdinfo *sysfs_read(int fd, char *devnm, unsigned long options)
/* assume this is a stale reference to a hot
* removed device
*/
- free(dev);
- continue;
+ if (!(options & GET_DEVS_ALL)) {
+ free(dev);
+ continue;
+ }
+ } else {
+ sscanf(buf, "%d:%d", &dev->disk.major, &dev->disk.minor);
}
- sscanf(buf, "%d:%d", &dev->disk.major, &dev->disk.minor);
- /* special case check for block devices that can go 'offline' */
- strcpy(dbase, "block/device/state");
- if (load_sys(fname, buf, sizeof(buf)) == 0 &&
- strncmp(buf, "offline", 7) == 0) {
- free(dev);
- continue;
+ if (!(options & GET_DEVS_ALL)) {
+ /* special case check for block devices that can go 'offline' */
+ strcpy(dbase, "block/device/state");
+ if (load_sys(fname, buf, sizeof(buf)) == 0 &&
+ strncmp(buf, "offline", 7) == 0) {
+ free(dev);
+ continue;
+ }
}
/* finally add this disk to the array */
--
2.25.0
++++++ 0028-Enable-probe_roms-to-scan-more-than-6-roms.patch ++++++
>From 4ec389e3f0c1233f5aa2d5b4e63d96e33d2a37f0 Mon Sep 17 00:00:00 2001
From: Roman Sobanski <roman.sobanski(a)intel.com>
Date: Tue, 2 Jul 2019 13:29:27 +0200
Subject: [PATCH] Enable probe_roms to scan more than 6 roms.
Git-commit: 4ec389e3f0c1233f5aa2d5b4e63d96e33d2a37f0
Patch-mainline: mdadm-4.1+
References: bsc#1156040
In some cases if more than 6 oroms exist, resource for particular
controller may not be found. Change method for storing
adapter_rom_resources from array to list.
Signed-off-by: Roman Sobanski <roman.sobanski(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Acked-by: Coly Li <colyli(a)suse.de>
---
probe_roms.c | 98 ++++++++++++++++++++++++++++++++++--------------------------
1 file changed, 56 insertions(+), 42 deletions(-)
diff --git a/probe_roms.c b/probe_roms.c
index b0b0883..7ea04c7 100644
--- a/probe_roms.c
+++ b/probe_roms.c
@@ -35,6 +35,9 @@ static const int rom_len = 0xf0000 - 0xc0000; /* option-rom memory region */
static int _sigbus;
static unsigned long rom_align;
+static void roms_deinit(void);
+static int roms_init(void);
+
static void sigbus(int sig)
{
_sigbus = 1;
@@ -75,6 +78,7 @@ void probe_roms_exit(void)
munmap(rom_mem, rom_len);
rom_mem = MAP_FAILED;
}
+ roms_deinit();
}
int probe_roms_init(unsigned long align)
@@ -91,6 +95,9 @@ int probe_roms_init(unsigned long align)
else
return -1;
+ if (roms_init())
+ return -1;
+
if (signal(SIGBUS, sigbus) == SIG_ERR)
rc = -1;
if (rc == 0) {
@@ -131,6 +138,7 @@ struct resource {
unsigned long end;
unsigned long data;
const char *name;
+ struct resource *next;
};
static struct resource system_rom_resource = {
@@ -147,37 +155,7 @@ static struct resource extension_rom_resource = {
.end = 0xeffff,
};
-static struct resource adapter_rom_resources[] = { {
- .name = "Adapter ROM",
- .start = 0xc8000,
- .data = 0,
- .end = 0,
-}, {
- .name = "Adapter ROM",
- .start = 0,
- .data = 0,
- .end = 0,
-}, {
- .name = "Adapter ROM",
- .start = 0,
- .data = 0,
- .end = 0,
-}, {
- .name = "Adapter ROM",
- .start = 0,
- .data = 0,
- .end = 0,
-}, {
- .name = "Adapter ROM",
- .start = 0,
- .data = 0,
- .end = 0,
-}, {
- .name = "Adapter ROM",
- .start = 0,
- .data = 0,
- .end = 0,
-} };
+static struct resource *adapter_rom_resources;
static struct resource video_rom_resource = {
.name = "Video ROM",
@@ -186,8 +164,35 @@ static struct resource video_rom_resource = {
.end = 0xc7fff,
};
+static int roms_init(void)
+{
+ adapter_rom_resources = malloc(sizeof(struct resource));
+ if (adapter_rom_resources == NULL)
+ return 1;
+ adapter_rom_resources->name = "Adapter ROM";
+ adapter_rom_resources->start = 0xc8000;
+ adapter_rom_resources->data = 0;
+ adapter_rom_resources->end = 0;
+ adapter_rom_resources->next = NULL;
+ return 0;
+}
+
+static void roms_deinit(void)
+{
+ struct resource *res;
+
+ res = adapter_rom_resources;
+ while (res) {
+ struct resource *tmp = res;
+
+ res = res->next;
+ free(tmp);
+ }
+}
+
#define ROMSIGNATURE 0xaa55
+
static int romsignature(const unsigned char *rom)
{
const unsigned short * const ptr = (const unsigned short *)rom;
@@ -208,16 +213,14 @@ static int romchecksum(const unsigned char *rom, unsigned long length)
int scan_adapter_roms(scan_fn fn)
{
/* let scan_fn examing each of the adapter roms found by probe_roms */
- unsigned int i;
+ struct resource *res = adapter_rom_resources;
int found;
if (rom_fd < 0)
return 0;
found = 0;
- for (i = 0; i < ARRAY_SIZE(adapter_rom_resources); i++) {
- struct resource *res = &adapter_rom_resources[i];
-
+ while (res) {
if (res->start) {
found = fn(isa_bus_to_virt(res->start),
isa_bus_to_virt(res->end),
@@ -226,6 +229,7 @@ int scan_adapter_roms(scan_fn fn)
break;
} else
break;
+ res = res->next;
}
return found;
@@ -241,14 +245,14 @@ void probe_roms(void)
const void *rom;
unsigned long start, length, upper;
unsigned char c;
- unsigned int i;
+ struct resource *res = adapter_rom_resources;
__u16 val=0;
if (rom_fd < 0)
return;
/* video rom */
- upper = adapter_rom_resources[0].start;
+ upper = res->start;
for (start = video_rom_resource.start; start < upper; start += rom_align) {
rom = isa_bus_to_virt(start);
if (!romsignature(rom))
@@ -283,8 +287,9 @@ void probe_roms(void)
upper = extension_rom_resource.start;
}
+ struct resource *prev_res = res;
/* check for adapter roms on 2k boundaries */
- for (i = 0; i < ARRAY_SIZE(adapter_rom_resources) && start < upper; start += rom_align) {
+ for (; start < upper; start += rom_align) {
rom = isa_bus_to_virt(start);
if (!romsignature(rom))
continue;
@@ -308,10 +313,19 @@ void probe_roms(void)
if (!length || start + length > upper || !romchecksum(rom, length))
continue;
- adapter_rom_resources[i].start = start;
- adapter_rom_resources[i].data = start + (unsigned long) val;
- adapter_rom_resources[i].end = start + length - 1;
+ if (res == NULL) {
+ res = calloc(1, sizeof(struct resource));
+ if (res == NULL)
+ return;
+ prev_res->next = res;
+ }
+
+ res->start = start;
+ res->data = start + (unsigned long)val;
+ res->end = start + length - 1;
- start = adapter_rom_resources[i++].end & ~(rom_align - 1);
+ start = res->end & ~(rom_align - 1);
+ prev_res = res;
+ res = res->next;
}
}
--
2.16.4
++++++ 0029-super-intel-Fix-issue-with-abs-being-irrelevant.patch ++++++
>From a4f7290c20c2ff78328c9db0b18029165cfb05b2 Mon Sep 17 00:00:00 2001
From: Jes Sorensen <jsorensen(a)fb.com>
Date: Tue, 9 Jul 2019 13:26:08 -0400
Subject: [PATCH] super-intel: Fix issue with abs() being irrelevant
Git-commit: a4f7290c20c2ff78328c9db0b18029165cfb05b2
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
gcc9 complains about subtracting unsigned from unsigned and code
assuming the result can be negative.
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
super-intel.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/super-intel.c b/super-intel.c
index 4fd5e84..230e164 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -2875,7 +2875,7 @@ static unsigned long long calc_component_size(struct imsm_map *map,
{
unsigned long long component_size;
unsigned long long dev_size = imsm_dev_size(dev);
- unsigned long long calc_dev_size = 0;
+ long long calc_dev_size = 0;
unsigned int member_disks = imsm_num_data_members(map);
if (member_disks == 0)
@@ -2889,7 +2889,7 @@ static unsigned long long calc_component_size(struct imsm_map *map,
* 2048 blocks per each device. If the difference is higher it means
* that array size was expanded and num_data_stripes was not updated.
*/
- if ((unsigned int)abs(calc_dev_size - dev_size) >
+ if (llabs(calc_dev_size - (long long)dev_size) >
(1 << SECT_PER_MB_SHIFT) * member_disks) {
component_size = dev_size / member_disks;
dprintf("Invalid num_data_stripes in metadata; expected=%llu, found=%llu\n",
--
2.25.0
++++++ 0030-mdadm.h-Introduced-unaligned-get-put-_unaligned-16-3.patch ++++++
>From 7039d1f8200b9599b23db5953934fdb43b0442e0 Mon Sep 17 00:00:00 2001
From: Jes Sorensen <jsorensen(a)fb.com>
Date: Tue, 9 Jul 2019 14:15:38 -0400
Subject: [PATCH] mdadm.h: Introduced unaligned {get,put}_unaligned{16,32}()
Git-commit: 7039d1f8200b9599b23db5953934fdb43b0442e0
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
We need these to avoid gcc9 going all crazy on us.
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
mdadm.h | 30 ++++++++++++++++++++++++++++++
1 file changed, 30 insertions(+)
diff --git a/mdadm.h b/mdadm.h
index 427cc52..0fa9e1b 100644
--- a/mdadm.h
+++ b/mdadm.h
@@ -191,6 +191,36 @@ struct dlm_lksb {
#endif
#endif /* __KLIBC__ */
+/*
+ * Partially stolen from include/linux/unaligned/packed_struct.h
+ */
+struct __una_u16 { __u16 x; } __attribute__ ((packed));
+struct __una_u32 { __u32 x; } __attribute__ ((packed));
+
+static inline __u16 __get_unaligned16(const void *p)
+{
+ const struct __una_u16 *ptr = (const struct __una_u16 *)p;
+ return ptr->x;
+}
+
+static inline __u32 __get_unaligned32(const void *p)
+{
+ const struct __una_u32 *ptr = (const struct __una_u32 *)p;
+ return ptr->x;
+}
+
+static inline void __put_unaligned16(__u16 val, void *p)
+{
+ struct __una_u16 *ptr = (struct __una_u16 *)p;
+ ptr->x = val;
+}
+
+static inline void __put_unaligned32(__u32 val, void *p)
+{
+ struct __una_u32 *ptr = (struct __una_u32 *)p;
+ ptr->x = val;
+}
+
/*
* Check at compile time that something is of a particular type.
* Always evaluates to 1 so you may use it easily in comparisons.
--
2.25.0
++++++ 0031-super-intel-Use-put_unaligned-in-split_ull.patch ++++++
>From 486720e0c2418e7e2e0a16221f7c42a308622254 Mon Sep 17 00:00:00 2001
From: Jes Sorensen <jsorensen(a)fb.com>
Date: Tue, 9 Jul 2019 14:49:22 -0400
Subject: [PATCH] super-intel: Use put_unaligned in split_ull
Git-commit: 486720e0c2418e7e2e0a16221f7c42a308622254
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Shut up some gcc9 errors by using put_unaligned() accessors. Not pretty,
but better than it was.
Also correct to the correct swap macros.
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
super-intel.c | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/super-intel.c b/super-intel.c
index 230e164..d7e8a65 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -1165,12 +1165,12 @@ static int count_memberships(struct dl *dl, struct intel_super *super)
static __u32 imsm_min_reserved_sectors(struct intel_super *super);
-static int split_ull(unsigned long long n, __u32 *lo, __u32 *hi)
+static int split_ull(unsigned long long n, void *lo, void *hi)
{
if (lo == 0 || hi == 0)
return 1;
- *lo = __le32_to_cpu((unsigned)n);
- *hi = __le32_to_cpu((unsigned)(n >> 32));
+ __put_unaligned32(__cpu_to_le32((__u32)n), lo);
+ __put_unaligned32(__cpu_to_le32((n >> 32)), hi);
return 0;
}
--
2.25.0
++++++ 0032-mdadm-load-default-sysfs-attributes-after-assemblati.patch ++++++
>From b06815989179e0f153e44e4336290e655edce9a1 Mon Sep 17 00:00:00 2001
From: Mariusz Dabrowski <mariusz.dabrowski(a)intel.com>
Date: Wed, 10 Jul 2019 13:38:53 +0200
Subject: [PATCH] mdadm: load default sysfs attributes after assemblation
Git-commit: b06815989179e0f153e44e4336290e655edce9a1
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Added new type of line to mdadm.conf which allows to specify values of
sysfs attributes for MD devices that should be loaded after the array is
assembled. Each line is interpreted as list of structures containing
sysname of MD device (md126 etc.) and list of sysfs attributes and their
values.
Signed-off-by: Mariusz Dabrowski <mariusz.dabrowski(a)intel.com>
Signed-off-by: Krzysztof Smolinski <krzysztof.smolinski(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
Assemble.c | 12 +++-
Incremental.c | 1 +
config.c | 7 ++-
mdadm.conf.5 | 25 ++++++++
mdadm.h | 3 +
sysfs.c | 158 ++++++++++++++++++++++++++++++++++++++++++++++++++
6 files changed, 202 insertions(+), 4 deletions(-)
diff --git a/Assemble.c b/Assemble.c
index 420c7b3..b2e6914 100644
--- a/Assemble.c
+++ b/Assemble.c
@@ -1063,9 +1063,12 @@ static int start_array(int mdfd,
mddev, okcnt + sparecnt + journalcnt,
okcnt + sparecnt + journalcnt == 1 ? "" : "s");
if (okcnt < (unsigned)content->array.raid_disks)
- fprintf(stderr, " (out of %d)",
+ fprintf(stderr, " (out of %d)\n",
content->array.raid_disks);
- fprintf(stderr, "\n");
+ else {
+ fprintf(stderr, "\n");
+ sysfs_rules_apply(mddev, content);
+ }
}
if (st->ss->validate_container) {
@@ -1139,6 +1142,7 @@ static int start_array(int mdfd,
rv = ioctl(mdfd, RUN_ARRAY, NULL);
reopen_mddev(mdfd); /* drop O_EXCL */
if (rv == 0) {
+ sysfs_rules_apply(mddev, content);
if (c->verbose >= 0) {
pr_err("%s has been started with %d drive%s",
mddev, okcnt, okcnt==1?"":"s");
@@ -2130,10 +2134,12 @@ int assemble_container_content(struct supertype *st, int mdfd,
pr_err("array %s now has %d device%s",
chosen_name, working + preexist,
working + preexist == 1 ? "":"s");
- else
+ else {
+ sysfs_rules_apply(chosen_name, content);
pr_err("Started %s with %d device%s",
chosen_name, working + preexist,
working + preexist == 1 ? "":"s");
+ }
if (preexist)
fprintf(stderr, " (%d new)", working);
if (expansion)
diff --git a/Incremental.c b/Incremental.c
index d4d3c35..98dbcd9 100644
--- a/Incremental.c
+++ b/Incremental.c
@@ -480,6 +480,7 @@ int Incremental(struct mddev_dev *devlist, struct context *c,
pr_err("container %s now has %d device%s\n",
chosen_name, info.array.working_disks,
info.array.working_disks == 1?"":"s");
+ sysfs_rules_apply(chosen_name, &info);
wait_for(chosen_name, mdfd);
if (st->ss->external)
strcpy(devnm, fd2devnm(mdfd));
diff --git a/config.c b/config.c
index e14eae0..7592b2d 100644
--- a/config.c
+++ b/config.c
@@ -80,7 +80,8 @@ char DefaultAltConfFile[] = CONFFILE2;
char DefaultAltConfDir[] = CONFFILE2 ".d";
enum linetype { Devices, Array, Mailaddr, Mailfrom, Program, CreateDev,
- Homehost, HomeCluster, AutoMode, Policy, PartPolicy, LTEnd };
+ Homehost, HomeCluster, AutoMode, Policy, PartPolicy, Sysfs,
+ LTEnd };
char *keywords[] = {
[Devices] = "devices",
[Array] = "array",
@@ -93,6 +94,7 @@ char *keywords[] = {
[AutoMode] = "auto",
[Policy] = "policy",
[PartPolicy]="part-policy",
+ [Sysfs] = "sysfs",
[LTEnd] = NULL
};
@@ -764,6 +766,9 @@ void conf_file(FILE *f)
case PartPolicy:
policyline(line, rule_part);
break;
+ case Sysfs:
+ sysfsline(line);
+ break;
default:
pr_err("Unknown keyword %s\n", line);
}
diff --git a/mdadm.conf.5 b/mdadm.conf.5
index 47c962a..27dbab1 100644
--- a/mdadm.conf.5
+++ b/mdadm.conf.5
@@ -587,6 +587,26 @@ be based on the domain, but with
appended, when N is the partition number for the partition that was
found.
+.TP
+.B SYSFS
+The SYSFS line lists custom values of MD device's sysfs attributes which will be
+stored in sysfs after the array is assembled. Multiple lines are allowed and each
+line has to contain the uuid or the name of the device to which it relates.
+.RS 4
+.TP
+.B uuid=
+hexadecimal identifier of MD device. This has to match the uuid stored in the
+superblock.
+.TP
+.B name=
+name of the MD device as was given to
+.I mdadm
+when the array was created. It will be ignored if
+.B uuid
+is not empty.
+.TP
+.RS 7
+
.SH EXAMPLE
DEVICE /dev/sd[bcdjkl]1
.br
@@ -657,6 +677,11 @@ CREATE group=system mode=0640 auto=part\-8
HOMEHOST <system>
.br
AUTO +1.x homehost \-all
+.br
+SYSFS name=/dev/md/raid5 group_thread_cnt=4 sync_speed_max=1000000
+.br
+SYSFS uuid=bead5eb6:31c17a27:da120ba2:7dfda40d group_thread_cnt=4
+sync_speed_max=1000000
.SH SEE ALSO
.BR mdadm (8),
diff --git a/mdadm.h b/mdadm.h
index 0fa9e1b..c36d7fd 100644
--- a/mdadm.h
+++ b/mdadm.h
@@ -1322,6 +1322,9 @@ void domain_add(struct domainlist **domp, char *domain);
extern void policy_save_path(char *id_path, struct map_ent *array);
extern int policy_check_path(struct mdinfo *disk, struct map_ent *array);
+extern void sysfs_rules_apply(char *devnm, struct mdinfo *dev);
+extern void sysfsline(char *line);
+
#if __GNUC__ < 3
struct stat64;
#endif
diff --git a/sysfs.c b/sysfs.c
index 2dd9ab6..c313781 100644
--- a/sysfs.c
+++ b/sysfs.c
@@ -26,9 +26,22 @@
#include "mdadm.h"
#include <dirent.h>
#include <ctype.h>
+#include "dlink.h"
#define MAX_SYSFS_PATH_LEN 120
+struct dev_sysfs_rule {
+ struct dev_sysfs_rule *next;
+ char *devname;
+ int uuid[4];
+ int uuid_set;
+ struct sysfs_entry {
+ struct sysfs_entry *next;
+ char *name;
+ char *value;
+ } *entry;
+};
+
int load_sys(char *path, char *buf, int len)
{
int fd = open(path, O_RDONLY);
@@ -999,3 +1012,148 @@ int sysfs_wait(int fd, int *msec)
}
return n;
}
+
+int sysfs_rules_apply_check(const struct mdinfo *sra,
+ const struct sysfs_entry *ent)
+{
+ /* Check whether parameter is regular file,
+ * exists and is under specified directory.
+ */
+ char fname[MAX_SYSFS_PATH_LEN];
+ char dname[MAX_SYSFS_PATH_LEN];
+ char resolved_path[PATH_MAX];
+ char resolved_dir[PATH_MAX];
+
+ if (sra == NULL || ent == NULL)
+ return -1;
+
+ snprintf(dname, MAX_SYSFS_PATH_LEN, "/sys/block/%s/md/", sra->sys_name);
+ snprintf(fname, MAX_SYSFS_PATH_LEN, "%s/%s", dname, ent->name);
+
+ if (realpath(fname, resolved_path) == NULL ||
+ realpath(dname, resolved_dir) == NULL)
+ return -1;
+
+ if (strncmp(resolved_dir, resolved_path,
+ strnlen(resolved_dir, PATH_MAX)) != 0)
+ return -1;
+
+ return 0;
+}
+
+static struct dev_sysfs_rule *sysfs_rules;
+
+void sysfs_rules_apply(char *devnm, struct mdinfo *dev)
+{
+ struct dev_sysfs_rule *rules = sysfs_rules;
+
+ while (rules) {
+ struct sysfs_entry *ent = rules->entry;
+ int match = 0;
+
+ if (!rules->uuid_set) {
+ if (rules->devname)
+ match = strcmp(devnm, rules->devname) == 0;
+ } else {
+ match = memcmp(dev->uuid, rules->uuid,
+ sizeof(int[4])) == 0;
+ }
+
+ while (match && ent) {
+ if (sysfs_rules_apply_check(dev, ent) < 0)
+ pr_err("SYSFS: failed to write '%s' to '%s'\n",
+ ent->value, ent->name);
+ else
+ sysfs_set_str(dev, NULL, ent->name, ent->value);
+ ent = ent->next;
+ }
+ rules = rules->next;
+ }
+}
+
+static void sysfs_rule_free(struct dev_sysfs_rule *rule)
+{
+ struct sysfs_entry *entry;
+
+ while (rule) {
+ struct dev_sysfs_rule *tmp = rule->next;
+
+ entry = rule->entry;
+ while (entry) {
+ struct sysfs_entry *tmp = entry->next;
+
+ free(entry->name);
+ free(entry->value);
+ free(entry);
+ entry = tmp;
+ }
+
+ if (rule->devname)
+ free(rule->devname);
+ free(rule);
+ rule = tmp;
+ }
+}
+
+void sysfsline(char *line)
+{
+ struct dev_sysfs_rule *sr;
+ char *w;
+
+ sr = xcalloc(1, sizeof(*sr));
+ for (w = dl_next(line); w != line ; w = dl_next(w)) {
+ if (strncasecmp(w, "name=", 5) == 0) {
+ char *devname = w + 5;
+
+ if (strncmp(devname, "/dev/md/", 8) == 0) {
+ if (sr->devname)
+ pr_err("Only give one device per SYSFS line: %s\n",
+ devname);
+ else
+ sr->devname = xstrdup(devname);
+ } else {
+ pr_err("%s is an invalid name for an md device - ignored.\n",
+ devname);
+ }
+ } else if (strncasecmp(w, "uuid=", 5) == 0) {
+ char *uuid = w + 5;
+
+ if (sr->uuid_set) {
+ pr_err("Only give one uuid per SYSFS line: %s\n",
+ uuid);
+ } else {
+ if (parse_uuid(w + 5, sr->uuid) &&
+ memcmp(sr->uuid, uuid_zero,
+ sizeof(int[4])) != 0)
+ sr->uuid_set = 1;
+ else
+ pr_err("Invalid uuid: %s\n", uuid);
+ }
+ } else {
+ struct sysfs_entry *prop;
+
+ char *sep = strchr(w, '=');
+
+ if (sep == NULL || *(sep + 1) == 0) {
+ pr_err("Cannot parse \"%s\" - ignoring.\n", w);
+ continue;
+ }
+
+ prop = xmalloc(sizeof(*prop));
+ prop->value = xstrdup(sep + 1);
+ *sep = 0;
+ prop->name = xstrdup(w);
+ prop->next = sr->entry;
+ sr->entry = prop;
+ }
+ }
+
+ if (!sr->devname && !sr->uuid_set) {
+ pr_err("Device name not found in sysfs config entry - ignoring.\n");
+ sysfs_rule_free(sr);
+ return;
+ }
+
+ sr->next = sysfs_rules;
+ sysfs_rules = sr;
+}
--
2.25.0
++++++ 0033-mdadm.h-include-sysmacros.h-unconditionally.patch ++++++
>From 452dc4d13a012cdcb05088c0dbc699959c4d6c73 Mon Sep 17 00:00:00 2001
From: Baruch Siach <baruch(a)tkos.co.il>
Date: Tue, 6 Aug 2019 16:05:23 +0300
Subject: [PATCH] mdadm.h: include sysmacros.h unconditionally
Git-commit: 452dc4d13a012cdcb05088c0dbc699959c4d6c73
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
musl libc now also requires sys/sysmacros.h for the major/minor macros.
All supported libc implementations carry sys/sysmacros.h, including
diet-libc, klibc, and uclibc-ng.
Cc: Hauke Mehrtens <hauke(a)hauke-m.de>
Signed-off-by: Baruch Siach <baruch(a)tkos.co.il>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
mdadm.h | 2 --
1 file changed, 2 deletions(-)
diff --git a/mdadm.h b/mdadm.h
index c36d7fd..d61a9ca 100644
--- a/mdadm.h
+++ b/mdadm.h
@@ -45,10 +45,8 @@ extern __off64_t lseek64 __P ((int __fd, __off64_t __offset, int __whence));
#include <errno.h>
#include <string.h>
#include <syslog.h>
-#ifdef __GLIBC__
/* Newer glibc requires sys/sysmacros.h directly for makedev() */
#include <sys/sysmacros.h>
-#endif
#ifdef __dietlibc__
#include <strings.h>
/* dietlibc has deprecated random and srandom!! */
--
2.25.0
++++++ 0034-mdadm-add-no-devices-to-avoid-component-devices-deta.patch ++++++
>From d11abe4bd5cad39803726ddff1888674e417bda5 Mon Sep 17 00:00:00 2001
From: Coly Li <colyli(a)suse.de>
Date: Wed, 31 Jul 2019 13:29:29 +0800
Subject: [PATCH 1/2] mdadm: add --no-devices to avoid component devices detail
information
Git-commit: d11abe4bd5cad39803726ddff1888674e417bda5
Patch-mainline: mdadm-4.1+
References: bsc#1139709
When people assemble a md raid device with a large number of
component deivces (e.g. 1500 DASD disks), the raid device detail
information generated by 'mdadm --detail --export $devnode' is very
large. It is because the detail information contains information of
all the component disks (even the missing/failed ones).
In such condition, when udev-md-raid-arrays.rules is triggered and
internally calls "mdadm --detail --no-devices --export $devnode",
user may observe systemd error message ""invalid message length". It
is because the following on-stack raw message buffer in systemd code
is not big enough,
systemd/src/libudev/libudev-monitor.c
_public_ struct udev_device *udev_monito ...
struct ucred *cred;
union {
struct udev_monitor_netlink_header nlh;
char raw[8192];
} buf;
Even change size of raw[] from 8KB to larger size, it may still be not
enough for detail message of a md raid device with much larger number of
component devices.
To fix this problem, an extra option '--no-devices' is added (the
original idea is proposed by Neil Brown). When printing detailed
information of a md raid device, if '--no-devices' is specified, then
all component devices information will not be printed, then the output
message size can be restricted to a small number, even with the systemd
only has 8KB on-disk raw buffer, the md raid array udev rules can work
correctly without failure message.
Signed-off-by: Coly Li <colyli(a)suse.de>
Reviewed-by: NeilBrown <neilb(a)suse.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
---
Detail.c | 24 ++++++++++++++++--------
ReadMe.c | 1 +
mdadm.c | 4 ++++
mdadm.h | 2 ++
4 files changed, 23 insertions(+), 8 deletions(-)
Index: mdadm-4.1/Detail.c
===================================================================
--- mdadm-4.1.orig/Detail.c
+++ mdadm-4.1/Detail.c
@@ -56,7 +56,7 @@ int Detail(char *dev, struct context *c)
*/
int fd = open(dev, O_RDONLY);
mdu_array_info_t array;
- mdu_disk_info_t *disks;
+ mdu_disk_info_t *disks = NULL;
int next;
int d;
time_t atime;
@@ -280,7 +280,7 @@ int Detail(char *dev, struct context *c)
}
map_free(map);
}
- if (sra) {
+ if (!c->no_devices && sra) {
struct mdinfo *mdi;
for (mdi = sra->devs; mdi; mdi = mdi->next) {
char *path;
@@ -655,12 +655,17 @@ This is pretty boring
printf("\n\n");
}
- if (array.raid_disks)
- printf(" Number Major Minor RaidDevice State\n");
- else
- printf(" Number Major Minor RaidDevice\n");
+ if (!c->no_devices) {
+ if (array.raid_disks)
+ printf(" Number Major Minor RaidDevice State\n");
+ else
+ printf(" Number Major Minor RaidDevice\n");
+ }
}
- free(info);
+
+ /* if --no_devices specified, not print component devices info */
+ if (c->no_devices)
+ goto skip_devices_state;
for (d = 0; d < max_disks * 2; d++) {
char *dv;
@@ -747,6 +752,8 @@ This is pretty boring
if (!c->brief)
printf("\n");
}
+
+skip_devices_state:
if (spares && c->brief && array.raid_disks)
printf(" spares=%d", spares);
if (c->brief && st && st->sb)
@@ -766,8 +773,9 @@ This is pretty boring
!enough(array.level, array.raid_disks, array.layout, 1, avail))
rv = 2;
- free(disks);
out:
+ free(info);
+ free(disks);
close(fd);
free(subarray);
free(avail);
Index: mdadm-4.1/ReadMe.c
===================================================================
--- mdadm-4.1.orig/ReadMe.c
+++ mdadm-4.1/ReadMe.c
@@ -181,6 +181,7 @@ struct option long_options[] = {
/* For Detail/Examine */
{"brief", 0, 0, Brief},
+ {"no-devices",0, 0, NoDevices},
{"export", 0, 0, 'Y'},
{"sparc2.2", 0, 0, Sparc22},
{"test", 0, 0, 't'},
Index: mdadm-4.1/mdadm.c
===================================================================
--- mdadm-4.1.orig/mdadm.c
+++ mdadm-4.1/mdadm.c
@@ -159,6 +159,10 @@ int main(int argc, char *argv[])
c.brief = 1;
continue;
+ case NoDevices:
+ c.no_devices = 1;
+ continue;
+
case 'Y': c.export++;
continue;
Index: mdadm-4.1/mdadm.h
===================================================================
--- mdadm-4.1.orig/mdadm.h
+++ mdadm-4.1/mdadm.h
@@ -412,6 +412,7 @@ enum special_options {
NoSharing,
HelpOptions,
Brief,
+ NoDevices,
ManageOpt,
Add,
AddSpare,
@@ -522,6 +523,7 @@ struct context {
int runstop;
int verbose;
int brief;
+ int no_devices;
int force;
char *homehost;
int require_homehost;
++++++ 0035-udev-add-no-devices-option-for-calling-mdadm-detail.patch ++++++
>From 1a52f1fc0266d438c996789d4addbfac999a6139 Mon Sep 17 00:00:00 2001
From: Coly Li <colyli(a)suse.de>
Date: Wed, 31 Jul 2019 13:29:30 +0800
Subject: [PATCH 2/2] udev: add --no-devices option for calling 'mdadm
--detail'
Git-commit: 1a52f1fc0266d438c996789d4addbfac999a6139
Patch-mainline: mdadm-4.1+
References: bsc#1139709
When creating symlink of a md raid device, the detailed information of
component disks are unnecessary for rule udev-md-raid-arrays.rules. For
md raid devices with huge number of component disks (e.g. 1500 DASD
disks), the detail information of component devices can be very large
and exceed udev monitor's on-stack message buffer.
This patch adds '--no-devices' option when calling mdadm by,
IMPORT{program}="BINDIR/mdadm --detail --no-devices --export $devnode"
Now the detailed output won't include component disks information,
and the error message "invalid message length" reported by systemd can
be removed.
Signed-off-by: Coly Li <colyli(a)suse.de>
Reviewed-by: NeilBrown <neilb(a)suse.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
---
udev-md-raid-arrays.rules | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/udev-md-raid-arrays.rules b/udev-md-raid-arrays.rules
index 5b99d58..d391665 100644
--- a/udev-md-raid-arrays.rules
+++ b/udev-md-raid-arrays.rules
@@ -17,7 +17,7 @@ TEST!="md/array_state", ENV{SYSTEMD_READY}="0", GOTO="md_end"
ATTR{md/array_state}=="|clear|inactive", ENV{SYSTEMD_READY}="0", GOTO="md_end"
LABEL="md_ignore_state"
-IMPORT{program}="BINDIR/mdadm --detail --export $devnode"
+IMPORT{program}="BINDIR/mdadm --detail --no-devices --export $devnode"
ENV{DEVTYPE}=="disk", ENV{MD_NAME}=="?*", SYMLINK+="disk/by-id/md-name-$env{MD_NAME}", OPTIONS+="string_escape=replace"
ENV{DEVTYPE}=="disk", ENV{MD_UUID}=="?*", SYMLINK+="disk/by-id/md-uuid-$env{MD_UUID}"
ENV{DEVTYPE}=="disk", ENV{MD_DEVNAME}=="?*", SYMLINK+="md/$env{MD_DEVNAME}"
--
2.16.4
++++++ 0036-imsm-close-removed-drive-fd.patch ++++++
>From 91c97c5432028875db5f8abeddb5cb5f31902001 Mon Sep 17 00:00:00 2001
From: Mariusz Tkaczyk <mariusz.tkaczyk(a)intel.com>
Date: Mon, 15 Jul 2019 09:25:35 +0200
Subject: [PATCH] imsm: close removed drive fd.
Git-commit: 91c97c5432028875db5f8abeddb5cb5f31902001
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
When member drive fails, managemon prepares metadata update and adds
the drive to disk_mgmt_list with DISK_REMOVE flag. It fills only
minor and major. It is enough to recognize the device later.
Monitor thread while processing this update will remove the drive from
super only if it is a spare. It never removes failed member from
disks list. As a result, it still keeps opened descriptor to
non-existing device.
If removed drive is not a spare fill fd in disk_cfg structure
(prepared by managemon), monitor will close fd during freeing it.
Also set this drive fd to -1 in super to avoid double closing because
monitor will close the fd (if needed) while replacing removed drive
in array.
Signed-off-by: Mariusz Tkaczyk <mariusz.tkaczyk(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
super-intel.c | 3 +++
1 file changed, 3 insertions(+)
diff --git a/super-intel.c b/super-intel.c
index d7e8a65..a103a3f 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -9200,6 +9200,9 @@ static int add_remove_disk_update(struct intel_super *super)
remove_disk_super(super,
disk_cfg->major,
disk_cfg->minor);
+ } else {
+ disk_cfg->fd = disk->fd;
+ disk->fd = -1;
}
}
/* release allocate disk structure */
--
2.25.0
++++++ 0037-mdadm-check-value-returned-by-snprintf-against-error.patch ++++++
>From fd5b09c9a9107f0393ce194c4aac6e7b8f163e85 Mon Sep 17 00:00:00 2001
From: Krzysztof Smolinski <krzysztof.smolinski(a)intel.com>
Date: Fri, 16 Aug 2019 11:06:17 +0200
Subject: [PATCH] mdadm: check value returned by snprintf against errors
Git-commit: fd5b09c9a9107f0393ce194c4aac6e7b8f163e85
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
GCC 8 checks possible truncation during snprintf more strictly
than GCC 7 which result in compilation errors. To fix this
problem checking result of snprintf against errors has been added.
Signed-off-by: Krzysztof Smolinski <krzysztof.smolinski(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
sysfs.c | 12 ++++++++++--
1 file changed, 10 insertions(+), 2 deletions(-)
diff --git a/sysfs.c b/sysfs.c
index c313781..2995713 100644
--- a/sysfs.c
+++ b/sysfs.c
@@ -1023,12 +1023,20 @@ int sysfs_rules_apply_check(const struct mdinfo *sra,
char dname[MAX_SYSFS_PATH_LEN];
char resolved_path[PATH_MAX];
char resolved_dir[PATH_MAX];
+ int result;
if (sra == NULL || ent == NULL)
return -1;
- snprintf(dname, MAX_SYSFS_PATH_LEN, "/sys/block/%s/md/", sra->sys_name);
- snprintf(fname, MAX_SYSFS_PATH_LEN, "%s/%s", dname, ent->name);
+ result = snprintf(dname, MAX_SYSFS_PATH_LEN,
+ "/sys/block/%s/md/", sra->sys_name);
+ if (result < 0 || result >= MAX_SYSFS_PATH_LEN)
+ return -1;
+
+ result = snprintf(fname, MAX_SYSFS_PATH_LEN,
+ "%s/%s", dname, ent->name);
+ if (result < 0 || result >= MAX_SYSFS_PATH_LEN)
+ return -1;
if (realpath(fname, resolved_path) == NULL ||
realpath(dname, resolved_dir) == NULL)
--
2.25.0
++++++ 0038-mdadm-Introduce-new-array-state-broken-for-raid0-lin.patch ++++++
>From 43ebc9105e9dafe5145b3e801c05da4736bf6e02 Mon Sep 17 00:00:00 2001
From: "Guilherme G. Piccoli" <gpiccoli(a)canonical.com>
Date: Tue, 3 Sep 2019 16:49:01 -0300
Subject: [PATCH] mdadm: Introduce new array state 'broken' for raid0/linear
Git-commit: 43ebc9105e9dafe5145b3e801c05da4736bf6e02
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Currently if a md raid0/linear array gets one or more members removed while
being mounted, kernel keeps showing state 'clean' in the 'array_state'
sysfs attribute. Despite udev signaling the member device is gone, 'mdadm'
cannot issue the STOP_ARRAY ioctl successfully, given the array is mounted.
Nothing else hints that something is wrong (except that the removed devices
don't show properly in the output of mdadm 'detail' command). There is no
other property to be checked, and if user is not performing reads/writes
to the array, even kernel log is quiet and doesn't give a clue about the
missing member.
This patch is the mdadm counterpart of kernel new array state 'broken'.
The 'broken' state mimics the state 'clean' in every aspect, being useful
only to distinguish if an array has some member missing. All necessary
paths in mdadm were changed to deal with 'broken' state, and in case the
tool runs in a kernel that is not updated, it'll work normally, i.e., it
doesn't require the 'broken' state in order to work.
Also, this patch changes the way the array state is showed in the 'detail'
command (for raid0/linear only) - now it takes the 'array_state' sysfs
attribute into account instead of only rely in the MD_SB_CLEAN flag.
Cc: Jes Sorensen <jes.sorensen(a)gmail.com>
Cc: NeilBrown <neilb(a)suse.de>
Cc: Song Liu <songliubraving(a)fb.com>
Signed-off-by: Guilherme G. Piccoli <gpiccoli(a)canonical.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
Detail.c | 14 ++++++++++++--
Monitor.c | 8 ++++++--
maps.c | 1 +
mdadm.h | 1 +
mdmon.h | 2 +-
monitor.c | 4 ++--
6 files changed, 23 insertions(+), 7 deletions(-)
diff --git a/Detail.c b/Detail.c
index ad60434..3e61e37 100644
--- a/Detail.c
+++ b/Detail.c
@@ -81,6 +81,7 @@ int Detail(char *dev, struct context *c)
int external;
int inactive;
int is_container = 0;
+ char *arrayst;
if (fd < 0) {
pr_err("cannot open %s: %s\n",
@@ -485,9 +486,18 @@ int Detail(char *dev, struct context *c)
else
st = ", degraded";
+ if (array.state & (1 << MD_SB_CLEAN)) {
+ if ((array.level == 0) ||
+ (array.level == LEVEL_LINEAR))
+ arrayst = map_num(sysfs_array_states,
+ sra->array_state);
+ else
+ arrayst = "clean";
+ } else
+ arrayst = "active";
+
printf(" State : %s%s%s%s%s%s \n",
- (array.state & (1 << MD_SB_CLEAN)) ?
- "clean" : "active", st,
+ arrayst, st,
(!e || (e->percent < 0 &&
e->percent != RESYNC_PENDING &&
e->percent != RESYNC_DELAYED)) ?
diff --git a/Monitor.c b/Monitor.c
index 036103f..b527165 100644
--- a/Monitor.c
+++ b/Monitor.c
@@ -1055,8 +1055,11 @@ int Wait(char *dev)
}
}
+/* The state "broken" is used only for RAID0/LINEAR - it's the same as
+ * "clean", but used in case the array has one or more members missing.
+ */
static char *clean_states[] = {
- "clear", "inactive", "readonly", "read-auto", "clean", NULL };
+ "clear", "inactive", "readonly", "read-auto", "clean", "broken", NULL };
int WaitClean(char *dev, int verbose)
{
@@ -1116,7 +1119,8 @@ int WaitClean(char *dev, int verbose)
rv = read(state_fd, buf, sizeof(buf));
if (rv < 0)
break;
- if (sysfs_match_word(buf, clean_states) <= 4)
+ if (sysfs_match_word(buf, clean_states) <
+ (int)ARRAY_SIZE(clean_states) - 1)
break;
rv = sysfs_wait(state_fd, &delay);
if (rv < 0 && errno != EINTR)
diff --git a/maps.c b/maps.c
index 02a0474..49b7f2c 100644
--- a/maps.c
+++ b/maps.c
@@ -150,6 +150,7 @@ mapping_t sysfs_array_states[] = {
{ "read-auto", ARRAY_READ_AUTO },
{ "clean", ARRAY_CLEAN },
{ "write-pending", ARRAY_WRITE_PENDING },
+ { "broken", ARRAY_BROKEN },
{ NULL, ARRAY_UNKNOWN_STATE }
};
diff --git a/mdadm.h b/mdadm.h
index 43b07d5..c88ceab 100644
--- a/mdadm.h
+++ b/mdadm.h
@@ -373,6 +373,7 @@ struct mdinfo {
ARRAY_ACTIVE,
ARRAY_WRITE_PENDING,
ARRAY_ACTIVE_IDLE,
+ ARRAY_BROKEN,
ARRAY_UNKNOWN_STATE,
} array_state;
struct md_bb bb;
diff --git a/mdmon.h b/mdmon.h
index 818367c..b3d72ac 100644
--- a/mdmon.h
+++ b/mdmon.h
@@ -21,7 +21,7 @@
extern const char Name[];
enum array_state { clear, inactive, suspended, readonly, read_auto,
- clean, active, write_pending, active_idle, bad_word};
+ clean, active, write_pending, active_idle, broken, bad_word};
enum sync_action { idle, reshape, resync, recover, check, repair, bad_action };
diff --git a/monitor.c b/monitor.c
index 81537ed..e0d3be6 100644
--- a/monitor.c
+++ b/monitor.c
@@ -26,7 +26,7 @@
static char *array_states[] = {
"clear", "inactive", "suspended", "readonly", "read-auto",
- "clean", "active", "write-pending", "active-idle", NULL };
+ "clean", "active", "write-pending", "active-idle", "broken", NULL };
static char *sync_actions[] = {
"idle", "reshape", "resync", "recover", "check", "repair", NULL
};
@@ -476,7 +476,7 @@ static int read_and_act(struct active_array *a, fd_set *fds)
a->next_state = clean;
ret |= ARRAY_DIRTY;
}
- if (a->curr_state == clean) {
+ if ((a->curr_state == clean) || (a->curr_state == broken)) {
a->container->ss->set_array_state(a, 1);
}
if (a->curr_state == active ||
--
2.25.0
++++++ 0039-mdadm-force-a-uuid-swap-on-big-endian.patch ++++++
>From 2c2d9c48d2daf0d78d20494c3779c0f6dc4bfa75 Mon Sep 17 00:00:00 2001
From: Nigel Croxon <ncroxon(a)redhat.com>
Date: Tue, 24 Sep 2019 11:39:24 -0400
Subject: [PATCH] mdadm: force a uuid swap on big endian
Git-commit: 2c2d9c48d2daf0d78d20494c3779c0f6dc4bfa75
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
The code path for metadata 0.90 calls a common routine
fname_from_uuid that uses metadata 1.2. The code expects member
swapuuid to be setup and usable. But it is only setup when using
metadata 1.2. Since the metadata 0.90 did not create swapuuid
and set it. The test (st->ss == &super1) ? 1 : st->ss->swapuuid
fails. The swapuuid is set at compile time based on byte order.
Any call based on metadata 0.90 and on big endian processors,
the --export uuid will be incorrect.
Signed-off-by: Nigel Croxon <ncroxon(a)redhat.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
util.c | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/util.c b/util.c
index c26cf5f..64dd409 100644
--- a/util.c
+++ b/util.c
@@ -685,8 +685,12 @@ char *fname_from_uuid(struct supertype *st, struct mdinfo *info,
// work, but can't have it set if we want this printout to match
// all the other uuid printouts in super1.c, so we force swapuuid
// to 1 to make our printout match the rest of super1
+#if __BYTE_ORDER == BIG_ENDIAN
+ return __fname_from_uuid(info->uuid, 1, buf, sep);
+#else
return __fname_from_uuid(info->uuid, (st->ss == &super1) ? 1 :
st->ss->swapuuid, buf, sep);
+#endif
}
int check_ext2(int fd, char *name)
--
2.25.0
++++++ 0040-mdadm-md.4-add-the-descriptions-for-bitmap-sysfs-nod.patch ++++++
>From e53cb968691d9e40d83caf5570da3bb7b83c64e1 Mon Sep 17 00:00:00 2001
From: Guoqing Jiang <gqjiang(a)suse.com>
Date: Fri, 31 May 2019 10:10:00 +0800
Subject: [PATCH] mdadm/md.4: add the descriptions for bitmap sysfs nodes
Git-commit: e53cb968691d9e40d83caf5570da3bb7b83c64e1
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
The sysfs nodes under bitmap are not recorded in md.4,
add them based on md.rst and kernel source code.
Cc: NeilBrown <neilb(a)suse.com>
Signed-off-by: Guoqing Jiang <gqjiang(a)suse.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
md.4 | 69 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 69 insertions(+)
diff --git a/md.4 b/md.4
index 3a1d677..e86707a 100644
--- a/md.4
+++ b/md.4
@@ -1101,6 +1101,75 @@ stripe that requires some "prereading". For fairness this defaults to
maximizes sequential-write throughput at the cost of fairness to threads
doing small or random writes.
+.TP
+.B md/bitmap/backlog
+The value stored in the file only has any effect on RAID1 when write-mostly
+devices are active, and write requests to those devices are proceed in the
+background.
+
+This variable sets a limit on the number of concurrent background writes,
+the valid values are 0 to 16383, 0 means that write-behind is not allowed,
+while any other number means it can happen. If there are more write requests
+than the number, new writes will by synchronous.
+
+.TP
+.B md/bitmap/can_clear
+This is for externally managed bitmaps, where the kernel writes the bitmap
+itself, but metadata describing the bitmap is managed by mdmon or similar.
+
+When the array is degraded, bits mustn't be cleared. When the array becomes
+optimal again, bit can be cleared, but first the metadata needs to record
+the current event count. So md sets this to 'false' and notifies mdmon,
+then mdmon updates the metadata and writes 'true'.
+
+There is no code in mdmon to actually do this, so maybe it doesn't even
+work.
+
+.TP
+.B md/bitmap/chunksize
+The bitmap chunksize can only be changed when no bitmap is active, and
+the value should be power of 2 and at least 512.
+
+.TP
+.B md/bitmap/location
+This indicates where the write-intent bitmap for the array is stored.
+It can be "none" or "file" or a signed offset from the array metadata
+- measured in sectors. You cannot set a file by writing here - that can
+only be done with the SET_BITMAP_FILE ioctl.
+
+Write 'none' to 'bitmap/location' will clear bitmap, and the previous
+location value must be write to it to restore bitmap.
+
+.TP
+.B md/bitmap/max_backlog_used
+This keeps track of the maximum number of concurrent write-behind requests
+for an md array, writing any value to this file will clear it.
+
+.TP
+.B md/bitmap/metadata
+This can be 'internal' or 'clustered' or 'external'. 'internal' is set
+by default, which means the metadata for bitmap is stored in the first 256
+bytes of the bitmap space. 'clustered' means separate bitmap metadata are
+used for each cluster node. 'external' means that bitmap metadata is managed
+externally to the kernel.
+
+.TP
+.B md/bitmap/space
+This shows the space (in sectors) which is available at md/bitmap/location,
+and allows the kernel to know when it is safe to resize the bitmap to match
+a resized array. It should big enough to contain the total bytes in the bitmap.
+
+For 1.0 metadata, assume we can use up to the superblock if before, else
+to 4K beyond superblock. For other metadata versions, assume no change is
+possible.
+
+.TP
+.B md/bitmap/time_base
+This shows the time (in seconds) between disk flushes, and is used to looking
+for bits in the bitmap to be cleared.
+
+The default value is 5 seconds, and it should be an unsigned long value.
+
.SS KERNEL PARAMETERS
The md driver recognised several different kernel parameters.
--
2.25.0
++++++ 0041-Init-devlist-as-an-array.patch ++++++
>From 8063fd0f9e8abd718bd65928c19bc607cee5acd8 Mon Sep 17 00:00:00 2001
From: Xiao Ni <xni(a)redhat.com>
Date: Mon, 30 Sep 2019 19:47:59 +0800
Subject: [PATCH] Init devlist as an array
Git-commit: 8063fd0f9e8abd718bd65928c19bc607cee5acd8
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
devlist is an string. It will change to an array if there is disk that
is sbd disk. If one device is sbd, it runs devlist=().
This line code changes devlist from a string to an array. If there is
no sbd device, it can't run this line code. So it will still be a string.
The later codes need an array, rather than an string. So init devlist
as an array to fix this problem.
Signed-off-by: Xiao Ni <xni(a)redhat.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
clustermd_tests/func.sh | 3 +++
1 file changed, 3 insertions(+)
diff --git a/clustermd_tests/func.sh b/clustermd_tests/func.sh
index 642cc96..801d604 100644
--- a/clustermd_tests/func.sh
+++ b/clustermd_tests/func.sh
@@ -39,6 +39,9 @@ fetch_devlist()
devlist=($(ls /dev/disk/by-path/*$ISCSI_ID*))
fi
# sbd disk cannot use in testing
+ # Init devlist as an array
+ i=''
+ devlist=(${devlist[@]#$i})
for i in ${devlist[@]}
do
sbd -d $i dump &> /dev/null
--
2.25.0
++++++ 0042-Don-t-need-to-check-recovery-after-re-add-when-no-I-.patch ++++++
>From 611093148574164fcf4f24f8c076d09473f655d7 Mon Sep 17 00:00:00 2001
From: Xiao Ni <xni(a)redhat.com>
Date: Mon, 30 Sep 2019 19:48:00 +0800
Subject: [PATCH] Don't need to check recovery after re-add when no I/O writes
to raid
Git-commit: 611093148574164fcf4f24f8c076d09473f655d7
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
If there is no write I/O between removing member disk and re-add it, there is no
recovery after re-adding member disk.
Signed-off-by: Xiao Ni <xni(a)redhat.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
clustermd_tests/02r1_Manage_re-add | 2 --
1 file changed, 2 deletions(-)
diff --git a/clustermd_tests/02r1_Manage_re-add b/clustermd_tests/02r1_Manage_re-add
index dd9c416..d0d13e5 100644
--- a/clustermd_tests/02r1_Manage_re-add
+++ b/clustermd_tests/02r1_Manage_re-add
@@ -9,8 +9,6 @@ check all state UU
check all dmesg
mdadm --manage $md0 --fail $dev0 --remove $dev0
mdadm --manage $md0 --re-add $dev0
-check $NODE1 recovery
-check all wait
check all state UU
check all dmesg
stop_md all $md0
--
2.25.0
++++++ 0043-udev-allow-for-udev-attribute-reading-bug.patch ++++++
>From 7bd59e7926c6921121087eb067befaa896c900a4 Mon Sep 17 00:00:00 2001
From: NeilBrown <neilb(a)suse.de>
Date: Wed, 18 Sep 2019 15:12:55 +1000
Subject: [PATCH] udev: allow for udev attribute reading bug.
Git-commit: 7bd59e7926c6921121087eb067befaa896c900a4
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
There is a bug in udev (which will hopefully get fixed, but
we should allow for it anways).
When reading a sysfs attribute, it first reads the whole
value of the attribute, then reads again expecting to get
a read of 0 bytes, like you would with an ordinary file.
If the sysfs attribute changed between these two reads, it can
get a mixture of two values.
In particular, if it reads when 'array_state' is changing from
'clear' to 'inactive', it can find the value as "clear\nve".
This causes the test for "|clear|active" to fail, so systemd is allowed
to think that the array is ready - when it isn't.
So change the pattern to allow for this but adding a wildcard at
the end.
Also don't allow for an empty string - reading array_state will
never return an empty string - if it exists at all, it will be
non-empty.
Signed-off-by: NeilBrown <neilb(a)suse.de>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
udev-md-raid-arrays.rules | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/udev-md-raid-arrays.rules b/udev-md-raid-arrays.rules
index d391665..c8fa8e8 100644
--- a/udev-md-raid-arrays.rules
+++ b/udev-md-raid-arrays.rules
@@ -14,7 +14,7 @@ ENV{DEVTYPE}=="partition", GOTO="md_ignore_state"
# never leave state 'inactive'
ATTR{md/metadata_version}=="external:[A-Za-z]*", ATTR{md/array_state}=="inactive", GOTO="md_ignore_state"
TEST!="md/array_state", ENV{SYSTEMD_READY}="0", GOTO="md_end"
-ATTR{md/array_state}=="|clear|inactive", ENV{SYSTEMD_READY}="0", GOTO="md_end"
+ATTR{md/array_state}=="clear*|inactive", ENV{SYSTEMD_READY}="0", GOTO="md_end"
LABEL="md_ignore_state"
IMPORT{program}="BINDIR/mdadm --detail --no-devices --export $devnode"
--
2.25.0
++++++ 0044-imsm-save-current_vol-number.patch ++++++
>From b6180160f78f0182b296bdceed6419b26a6fccc7 Mon Sep 17 00:00:00 2001
From: Mariusz Tkaczyk <mariusz.tkaczyk(a)intel.com>
Date: Fri, 4 Oct 2019 12:07:28 +0200
Subject: [PATCH] imsm: save current_vol number
Git-commit: b6180160f78f0182b296bdceed6419b26a6fccc7
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
The imsm container_content routine will set curr_volume index in super
for getting volume information. This flag has never been restored to
original value, later other function may rely on it.
Restore this flag to original value.
Signed-off-by: Mariusz Tkaczyk <mariusz.tkaczyk(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
super-intel.c | 2 ++
1 file changed, 2 insertions(+)
diff --git a/super-intel.c b/super-intel.c
index a103a3f..e02bbd7 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -7826,6 +7826,7 @@ static struct mdinfo *container_content_imsm(struct supertype *st, char *subarra
int sb_errors = 0;
struct dl *d;
int spare_disks = 0;
+ int current_vol = super->current_vol;
/* do not assemble arrays when not all attributes are supported */
if (imsm_check_attributes(mpb->attributes) == 0) {
@@ -7993,6 +7994,7 @@ static struct mdinfo *container_content_imsm(struct supertype *st, char *subarra
rest = this;
}
+ super->current_vol = current_vol;
return rest;
}
--
2.25.0
++++++ 0045-imsm-allow-to-specify-second-volume-size.patch ++++++
>From 1a1ced1e2e64a6b4b349a3fb559f6b39e4cf7103 Mon Sep 17 00:00:00 2001
From: Krzysztof Smolinski <krzysztof.smolinski(a)intel.com>
Date: Fri, 8 Nov 2019 11:59:11 +0100
Subject: [PATCH] imsm: allow to specify second volume size
Git-commit: 1a1ced1e2e64a6b4b349a3fb559f6b39e4cf7103
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Removed checks which limited second volume size only to max value (the
largest size that fits on all current drives). It is now permitted
to create second volume with size lower then maximum possible.
Signed-off-by: Krzysztof Smolinski <krzysztof.smolinski(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
super-intel.c | 14 ++++----------
1 file changed, 4 insertions(+), 10 deletions(-)
diff --git a/super-intel.c b/super-intel.c
index e02bbd7..713058c 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -7298,11 +7298,8 @@ static int validate_geometry_imsm_volume(struct supertype *st, int level,
maxsize = merge_extents(super, i);
- if (!check_env("IMSM_NO_PLATFORM") &&
- mpb->num_raid_devs > 0 && size && size != maxsize) {
- pr_err("attempting to create a second volume with size less then remaining space. Aborting...\n");
- return 0;
- }
+ if (mpb->num_raid_devs > 0 && size && size != maxsize)
+ pr_err("attempting to create a second volume with size less then remaining space.\n");
if (maxsize < size || maxsize == 0) {
if (verbose) {
@@ -7393,11 +7390,8 @@ static int imsm_get_free_size(struct supertype *st, int raiddisks,
}
maxsize = size;
}
- if (!check_env("IMSM_NO_PLATFORM") &&
- mpb->num_raid_devs > 0 && size && size != maxsize) {
- pr_err("attempting to create a second volume with size less then remaining space. Aborting...\n");
- return 0;
- }
+ if (mpb->num_raid_devs > 0 && size && size != maxsize)
+ pr_err("attempting to create a second volume with size less then remaining space.\n");
cnt = 0;
for (dl = super->disks; dl; dl = dl->next)
if (dl->e)
--
2.25.0
++++++ 0012-mdcheck-when-mdcheck_start-is-enabled-enable-mdcheck.patch -> 0046-mdcheck-when-mdcheck_start-is-enabled-enable-mdcheck.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/0012-mdcheck-when-mdcheck_start-is-enabled-enable-mdcheck.patch 2019-11-03 11:20:31.480581142 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0046-mdcheck-when-mdcheck_start-is-enabled-enable-mdcheck.patch 2020-03-31 17:31:50.416246256 +0200
@@ -1,8 +1,11 @@
-From 751090e03c584ae2e4badd8823bd68d8d0c4c298 Mon Sep 17 00:00:00 2001
+From 6636788aaf4ec0cacaefb6e77592e4a68e70a957 Mon Sep 17 00:00:00 2001
From: NeilBrown <neilb(a)suse.de>
Date: Fri, 18 Oct 2019 11:10:34 +1100
Subject: [PATCH] mdcheck: when mdcheck_start is enabled, enable
mdcheck_continue too.
+Git-commit: 6636788aaf4ec0cacaefb6e77592e4a68e70a957
+Patch-mainline: mdadm-4.1+
+References: bsc#1153258
mdcheck_continue continues a regular array scan that was started by
mdcheck_start.
++++++ 0013-mdcheck-use-to-pass-variable-to-mdcheck.patch -> 0050-mdcheck-use-to-pass-variable-to-mdcheck.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/0013-mdcheck-use-to-pass-variable-to-mdcheck.patch 2019-11-03 11:20:31.520581193 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0050-mdcheck-use-to-pass-variable-to-mdcheck.patch 2020-03-31 17:31:50.684246412 +0200
@@ -1,7 +1,10 @@
-From fde9606a9780cf2701fa903eeb528b9f4400282e Mon Sep 17 00:00:00 2001
+From 4ca799c581703d4d0ad840833c037c2fff088ca7 Mon Sep 17 00:00:00 2001
From: NeilBrown <neilb(a)suse.de>
-Date: Wed, 30 Oct 2019 09:25:00 +1100
+Date: Wed, 30 Oct 2019 10:32:41 +1100
Subject: [PATCH] mdcheck: use ${} to pass variable to mdcheck
+Git-commit: 4ca799c581703d4d0ad840833c037c2fff088ca7
+Patch-mainline: mdadm-4.1+
+References: bsc#1153258
$MDADM_CHECK_DURATION allows the value to be split on spaces.
${MDADM_CHECK_DURATION} avoids such splitting.
@@ -11,13 +14,14 @@
in the EnvironmentFile.
Signed-off-by: NeilBrown <neilb(a)suse.de>
+Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
---
systemd/mdcheck_continue.service | 5 ++---
systemd/mdcheck_start.service | 4 ++--
2 files changed, 4 insertions(+), 5 deletions(-)
diff --git a/systemd/mdcheck_continue.service b/systemd/mdcheck_continue.service
-index 592c60798f82..deac695485b0 100644
+index 592c607..deac695 100644
--- a/systemd/mdcheck_continue.service
+++ b/systemd/mdcheck_continue.service
@@ -11,8 +11,7 @@ ConditionPathExistsGlob = /var/lib/mdcheck/MD_UUID_*
@@ -32,7 +36,7 @@
-
+ExecStart=/usr/share/mdadm/mdcheck --continue --duration ${MDADM_CHECK_DURATION}
diff --git a/systemd/mdcheck_start.service b/systemd/mdcheck_start.service
-index 812141bb5c9a..f17f1aaec217 100644
+index 812141b..f17f1aa 100644
--- a/systemd/mdcheck_start.service
+++ b/systemd/mdcheck_start.service
@@ -11,7 +11,7 @@ Wants=mdcheck_continue.timer
@@ -46,5 +50,5 @@
-ExecStart=/usr/share/mdadm/mdcheck --duration $MDADM_CHECK_DURATION
+ExecStart=/usr/share/mdadm/mdcheck --duration ${MDADM_CHECK_DURATION}
--
-2.23.0
+2.25.0
++++++ 0014-SUSE-mdadm_env.sh-handle-MDADM_CHECK_DURATION.patch -> 0051-SUSE-mdadm_env.sh-handle-MDADM_CHECK_DURATION.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/0014-SUSE-mdadm_env.sh-handle-MDADM_CHECK_DURATION.patch 2019-11-03 11:20:31.536581214 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0051-SUSE-mdadm_env.sh-handle-MDADM_CHECK_DURATION.patch 2020-03-31 17:31:50.824246495 +0200
@@ -1,18 +1,22 @@
-From e76aa254a99cca27715d65aa5188c9b47b1c4f8e Mon Sep 17 00:00:00 2001
+From 85b83a7920bca5b93d2458f093f2c640a130614c Mon Sep 17 00:00:00 2001
From: NeilBrown <neilb(a)suse.de>
-Date: Wed, 30 Oct 2019 09:27:34 +1100
+Date: Wed, 30 Oct 2019 10:32:41 +1100
Subject: [PATCH] SUSE-mdadm_env.sh: handle MDADM_CHECK_DURATION
+Git-commit: 85b83a7920bca5b93d2458f093f2c640a130614c
+Patch-mainline: mdadm-4.1+
+References: bsc#1153258
The suse sysconfig/mdadm allows MDADM_CHECK_DURATION
to be set, but it is currently ignored.
Signed-off-by: NeilBrown <neilb(a)suse.de>
+Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
---
systemd/SUSE-mdadm_env.sh | 3 +++
1 file changed, 3 insertions(+)
diff --git a/systemd/SUSE-mdadm_env.sh b/systemd/SUSE-mdadm_env.sh
-index 10b2e749921c..c13b48ab3cb1 100644
+index 10b2e74..c13b48a 100644
--- a/systemd/SUSE-mdadm_env.sh
+++ b/systemd/SUSE-mdadm_env.sh
@@ -43,3 +43,6 @@ fi
@@ -23,5 +27,5 @@
+ echo "MDADM_CHECK_DURATION=$MDADM_CHECK_DURATION" >> /run/sysconfig/mdadm
+fi
--
-2.23.0
+2.25.0
++++++ 0052-super-intel-don-t-mark-structs-packed-unnecessarily.patch ++++++
>From 761e3bd9f5e3aafa95ad3ae50a637dc67c8774f0 Mon Sep 17 00:00:00 2001
From: NeilBrown <neilb(a)suse.de>
Date: Thu, 31 Oct 2019 15:15:38 +1100
Subject: [PATCH] super-intel: don't mark structs 'packed' unnecessarily
Git-commit: 761e3bd9f5e3aafa95ad3ae50a637dc67c8774f0
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
super-intel marks a number of structures 'packed', but this
doesn't change the layout - they are already well organized.
This is a problem a gcc warns when code takes the address
of a field in a packet struct - as super-intel sometimes does.
So remove the marking where isn't needed.
Do ensure this does introduce a regression, add a compile-time
assertion that the size of the structure is exactly the value
it had before the 'packed' notation was removed.
Note that a couple of structure do need to be packed.
As the address of fields is never taken, that is safe.
Signed-off-by: NeilBrown <neilb(a)suse.de>
Acked-by: Artur Paszkiewicz <artur.paszkiewicz(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
super-intel.c | 32 ++++++++++++++++++++++++++------
1 file changed, 26 insertions(+), 6 deletions(-)
diff --git a/super-intel.c b/super-intel.c
index 713058c..a7fbed4 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -96,6 +96,19 @@
* mutliple PPL area
*/
+/*
+ * This macro let's us ensure that no-one accidentally
+ * changes the size of a struct
+ */
+#define ASSERT_SIZE(_struct, size) \
+static inline void __assert_size_##_struct(void) \
+{ \
+ switch (0) { \
+ case 0: break; \
+ case (sizeof(struct _struct) == size): break; \
+ } \
+}
+
/* Disk configuration info. */
#define IMSM_MAX_DEVICES 255
struct imsm_disk {
@@ -112,6 +125,7 @@ struct imsm_disk {
#define IMSM_DISK_FILLERS 3
__u32 filler[IMSM_DISK_FILLERS]; /* 0xF5 - 0x107 MPB_DISK_FILLERS for future expansion */
};
+ASSERT_SIZE(imsm_disk, 48)
/* map selector for map managment
*/
@@ -146,7 +160,8 @@ struct imsm_map {
__u32 disk_ord_tbl[1]; /* disk_ord_tbl[num_members],
* top byte contains some flags
*/
-} __attribute__ ((packed));
+};
+ASSERT_SIZE(imsm_map, 52)
struct imsm_vol {
__u32 curr_migr_unit;
@@ -169,7 +184,8 @@ struct imsm_vol {
__u32 filler[4];
struct imsm_map map[1];
/* here comes another one if migr_state */
-} __attribute__ ((packed));
+};
+ASSERT_SIZE(imsm_vol, 84)
struct imsm_dev {
__u8 volume[MAX_RAID_SERIAL_LEN];
@@ -220,7 +236,8 @@ struct imsm_dev {
#define IMSM_DEV_FILLERS 3
__u32 filler[IMSM_DEV_FILLERS];
struct imsm_vol vol;
-} __attribute__ ((packed));
+};
+ASSERT_SIZE(imsm_dev, 164)
struct imsm_super {
__u8 sig[MAX_SIGNATURE_LENGTH]; /* 0x00 - 0x1F */
@@ -248,7 +265,8 @@ struct imsm_super {
struct imsm_disk disk[1]; /* 0xD8 diskTbl[numDisks] */
/* here comes imsm_dev[num_raid_devs] */
/* here comes BBM logs */
-} __attribute__ ((packed));
+};
+ASSERT_SIZE(imsm_super, 264)
#define BBM_LOG_MAX_ENTRIES 254
#define BBM_LOG_MAX_LBA_ENTRY_VAL 256 /* Represents 256 LBAs */
@@ -269,7 +287,8 @@ struct bbm_log {
__u32 signature; /* 0xABADB10C */
__u32 entry_count;
struct bbm_log_entry marked_block_entries[BBM_LOG_MAX_ENTRIES];
-} __attribute__ ((__packed__));
+};
+ASSERT_SIZE(bbm_log, 2040)
static char *map_state_str[] = { "normal", "uninitialized", "degraded", "failed" };
@@ -323,7 +342,8 @@ struct migr_record {
* destination - high order 32 bits */
__u32 num_migr_units_hi; /* Total num migration units-of-op
* high order 32 bits */
-} __attribute__ ((__packed__));
+};
+ASSERT_SIZE(migr_record, 64)
struct md_list {
/* usage marker:
--
2.25.0
++++++ 0053-Manage-Remove-the-legacy-code-for-md-driver-prior-to.patch ++++++
>From 1cc3965d48deb0fb3e0657159c608ffb124643c1 Mon Sep 17 00:00:00 2001
From: Xiao Yang <ice_yangxiao(a)163.com>
Date: Wed, 27 Nov 2019 11:59:24 +0800
Subject: [PATCH] Manage: Remove the legacy code for md driver prior to 0.90.03
Git-commit: 1cc3965d48deb0fb3e0657159c608ffb124643c1
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Previous re-add operation only calls ioctl(HOT_ADD_DISK) for array without
metadata(e.g. mdadm -B/--build) when md driver is less than 0.90.02, but
commit 091e8e6 breaks the logic and current re-add operation can call
ioctl(HOT_ADD_DISK) even if md driver is 0.90.03.
This issue is reproduced by 05r1-re-add-nosuper:
Signed-off-by: Coly Li <colyli(a)suse.de>
------------------------------------------------
++ die 'resync or recovery is happening!'
++ echo -e '\n\tERROR: resync or recovery is happening! \n'
ERROR: resync or recovery is happening!
------------------------------------------------
Fixes: 091e8e6("Manage: Remove all references to md_get_version()")
Reported-by: kernel test robot <lkp(a)intel.com>
Signed-off-by: Xiao Yang <ice_yangxiao(a)163.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
---
Manage.c | 12 ------------
1 file changed, 12 deletions(-)
diff --git a/Manage.c b/Manage.c
index 21536f5..ffe55f8 100644
--- a/Manage.c
+++ b/Manage.c
@@ -741,18 +741,6 @@ int Manage_add(int fd, int tfd, struct mddev_dev *dv,
" Adding anyway as --force was given.\n",
dv->devname, devname);
}
- if (!tst->ss->external && array->major_version == 0) {
- if (ioctl(fd, HOT_ADD_DISK, rdev)==0) {
- if (verbose >= 0)
- pr_err("hot added %s\n",
- dv->devname);
- return 1;
- }
-
- pr_err("hot add failed for %s: %s\n",
- dv->devname, strerror(errno));
- return -1;
- }
if (array->not_persistent == 0 || tst->ss->external) {
--
2.25.0
++++++ 0054-Remove-last-traces-of-HOT_ADD_DISK.patch ++++++
>From 02af379337c73e751ad97c0fed9123121f8b4289 Mon Sep 17 00:00:00 2001
From: Jes Sorensen <jsorensen(a)fb.com>
Date: Wed, 27 Nov 2019 10:19:54 -0500
Subject: [PATCH] Remove last traces of HOT_ADD_DISK
Git-commit: 02af379337c73e751ad97c0fed9123121f8b4289
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
This ioctl is no longer used, so remove all references to it.
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
Manage.c | 2 --
md_u.h | 1 -
2 files changed, 3 deletions(-)
diff --git a/Manage.c b/Manage.c
index ffe55f8..deeba2b 100644
--- a/Manage.c
+++ b/Manage.c
@@ -1289,8 +1289,6 @@ int Manage_subdevs(char *devname, int fd,
/* Do something to each dev.
* devmode can be
* 'a' - add the device
- * try HOT_ADD_DISK
- * If that fails EINVAL, try ADD_NEW_DISK
* 'S' - add the device as a spare - don't try re-add
* 'j' - add the device as a journal device
* 'A' - re-add the device
diff --git a/md_u.h b/md_u.h
index 2d66d52..b30893c 100644
--- a/md_u.h
+++ b/md_u.h
@@ -28,7 +28,6 @@
#define ADD_NEW_DISK _IOW (MD_MAJOR, 0x21, mdu_disk_info_t)
#define HOT_REMOVE_DISK _IO (MD_MAJOR, 0x22)
#define SET_ARRAY_INFO _IOW (MD_MAJOR, 0x23, mdu_array_info_t)
-#define HOT_ADD_DISK _IO (MD_MAJOR, 0x28)
#define SET_DISK_FAULTY _IO (MD_MAJOR, 0x29)
#define SET_BITMAP_FILE _IOW (MD_MAJOR, 0x2b, int)
--
2.25.0
++++++ 0055-Fix-up-a-few-formatting-issues.patch ++++++
>From 9cf361f8791d86aaced821c19af556819bc03732 Mon Sep 17 00:00:00 2001
From: Jes Sorensen <jsorensen(a)fb.com>
Date: Wed, 27 Nov 2019 11:33:15 -0500
Subject: [PATCH] Fix up a few formatting issues
Git-commit: 9cf361f8791d86aaced821c19af556819bc03732
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
Manage.c | 13 +++++++++----
1 file changed, 9 insertions(+), 4 deletions(-)
diff --git a/Manage.c b/Manage.c
index deeba2b..b22c396 100644
--- a/Manage.c
+++ b/Manage.c
@@ -1728,8 +1728,10 @@ int move_spare(char *from_devname, char *to_devname, dev_t devid)
int fd2 = open(from_devname, O_RDONLY);
if (fd1 < 0 || fd2 < 0) {
- if (fd1>=0) close(fd1);
- if (fd2>=0) close(fd2);
+ if (fd1 >= 0)
+ close(fd1);
+ if (fd2 >= 0)
+ close(fd2);
return 0;
}
@@ -1743,7 +1745,8 @@ int move_spare(char *from_devname, char *to_devname, dev_t devid)
devlist.disposition = 'r';
if (Manage_subdevs(from_devname, fd2, &devlist, -1, 0, NULL, 0) == 0) {
devlist.disposition = 'a';
- if (Manage_subdevs(to_devname, fd1, &devlist, -1, 0, NULL, 0) == 0) {
+ if (Manage_subdevs(to_devname, fd1, &devlist, -1, 0,
+ NULL, 0) == 0) {
/* make sure manager is aware of changes */
ping_manager(to_devname);
ping_manager(from_devname);
@@ -1751,7 +1754,9 @@ int move_spare(char *from_devname, char *to_devname, dev_t devid)
close(fd2);
return 1;
}
- else Manage_subdevs(from_devname, fd2, &devlist, -1, 0, NULL, 0);
+ else
+ Manage_subdevs(from_devname, fd2, &devlist,
+ -1, 0, NULL, 0);
}
close(fd1);
close(fd2);
--
2.25.0
++++++ 0056-Remove-unused-code.patch ++++++
>From 4b31846f3f90aa24f883ceed80e91f204c0a9389 Mon Sep 17 00:00:00 2001
From: Xiao Ni <xni(a)redhat.com>
Date: Fri, 29 Nov 2019 17:14:47 +0800
Subject: [PATCH] Remove unused code
Git-commit: 4b31846f3f90aa24f883ceed80e91f204c0a9389
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Signed-off-by: Xiao Ni <xni(a)redhat.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
platform-intel.h | 1 -
1 file changed, 1 deletion(-)
diff --git a/platform-intel.h b/platform-intel.h
index 29c85f1..7cb370e 100644
--- a/platform-intel.h
+++ b/platform-intel.h
@@ -169,7 +169,6 @@ static inline int fls(int x)
r -= 2;
}
if (!(x & 0x80000000u)) {
- x <<= 1;
r -= 1;
}
return r;
--
2.25.0
++++++ 0057-imsm-return-correct-uuid-for-volume-in-detail.patch ++++++
>From b771faef931c798a4553db0a8c1366aff90079c6 Mon Sep 17 00:00:00 2001
From: Blazej Kucman <blazej.kucman(a)intel.com>
Date: Fri, 29 Nov 2019 15:21:08 +0100
Subject: [PATCH] imsm: return correct uuid for volume in detail
Git-commit: b771faef931c798a4553db0a8c1366aff90079c6
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Fixes the side effect of the patch b6180160f ("imsm: save current_vol number")
- wrong UUID is printed in detail for each volume.
New parameter "subarray" is added to determine what info should be extracted
from metadata (subarray or container).
The parameter affects only IMSM metadata.
Signed-off-by: Blazej Kucman <blazej.kucman(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
Detail.c | 4 ++--
mdadm.h | 5 +++--
super-ddf.c | 5 +++--
super-intel.c | 20 ++++++++++++++++++--
super0.c | 4 ++--
super1.c | 4 ++--
6 files changed, 30 insertions(+), 12 deletions(-)
diff --git a/Detail.c b/Detail.c
index 3e61e37..24fa462 100644
--- a/Detail.c
+++ b/Detail.c
@@ -623,7 +623,7 @@ This is pretty boring
free_mdstat(ms);
if (st && st->sb)
- st->ss->detail_super(st, c->homehost);
+ st->ss->detail_super(st, c->homehost, subarray);
if (array.raid_disks == 0 && sra &&
sra->array.major_version == -1 &&
@@ -767,7 +767,7 @@ skip_devices_state:
if (spares && c->brief && array.raid_disks)
printf(" spares=%d", spares);
if (c->brief && st && st->sb)
- st->ss->brief_detail_super(st);
+ st->ss->brief_detail_super(st, subarray);
if (st)
st->ss->free_super(st);
diff --git a/mdadm.h b/mdadm.h
index c88ceab..91f1338 100644
--- a/mdadm.h
+++ b/mdadm.h
@@ -847,8 +847,9 @@ extern struct superswitch {
/* Used to report details of an active array.
* ->load_super was possibly given a 'component' string.
*/
- void (*detail_super)(struct supertype *st, char *homehost);
- void (*brief_detail_super)(struct supertype *st);
+ void (*detail_super)(struct supertype *st, char *homehost,
+ char *subarray);
+ void (*brief_detail_super)(struct supertype *st, char *subarray);
void (*export_detail_super)(struct supertype *st);
/* Optional: platform hardware / firmware details */
diff --git a/super-ddf.c b/super-ddf.c
index c095e8a..7802063 100644
--- a/super-ddf.c
+++ b/super-ddf.c
@@ -1730,7 +1730,8 @@ err:
return 1;
}
-static void detail_super_ddf(struct supertype *st, char *homehost)
+static void detail_super_ddf(struct supertype *st, char *homehost,
+ char *subarray)
{
struct ddf_super *sb = st->sb;
int cnt = be16_to_cpu(sb->virt->populated_vdes);
@@ -1787,7 +1788,7 @@ static void uuid_of_ddf_subarray(const struct ddf_super *ddf,
memcpy(uuid, sha, 4*4);
}
-static void brief_detail_super_ddf(struct supertype *st)
+static void brief_detail_super_ddf(struct supertype *st, char *subarray)
{
struct mdinfo info;
char nbuf[64];
diff --git a/super-intel.c b/super-intel.c
index a7fbed4..86dcb69 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -2183,23 +2183,39 @@ err:
return 1;
}
-static void detail_super_imsm(struct supertype *st, char *homehost)
+static void detail_super_imsm(struct supertype *st, char *homehost,
+ char *subarray)
{
struct mdinfo info;
char nbuf[64];
+ struct intel_super *super = st->sb;
+ int temp_vol = super->current_vol;
+
+ if (subarray)
+ super->current_vol = strtoul(subarray, NULL, 10);
getinfo_super_imsm(st, &info, NULL);
fname_from_uuid(st, &info, nbuf, ':');
printf("\n UUID : %s\n", nbuf + 5);
+
+ super->current_vol = temp_vol;
}
-static void brief_detail_super_imsm(struct supertype *st)
+static void brief_detail_super_imsm(struct supertype *st, char *subarray)
{
struct mdinfo info;
char nbuf[64];
+ struct intel_super *super = st->sb;
+ int temp_vol = super->current_vol;
+
+ if (subarray)
+ super->current_vol = strtoul(subarray, NULL, 10);
+
getinfo_super_imsm(st, &info, NULL);
fname_from_uuid(st, &info, nbuf, ':');
printf(" UUID=%s", nbuf + 5);
+
+ super->current_vol = temp_vol;
}
static int imsm_read_serial(int fd, char *devname, __u8 *serial);
diff --git a/super0.c b/super0.c
index 42989b9..6b7c0e3 100644
--- a/super0.c
+++ b/super0.c
@@ -348,7 +348,7 @@ err:
return 1;
}
-static void detail_super0(struct supertype *st, char *homehost)
+static void detail_super0(struct supertype *st, char *homehost, char *subarray)
{
mdp_super_t *sb = st->sb;
printf(" UUID : ");
@@ -368,7 +368,7 @@ static void detail_super0(struct supertype *st, char *homehost)
printf("\n Events : %d.%d\n\n", sb->events_hi, sb->events_lo);
}
-static void brief_detail_super0(struct supertype *st)
+static void brief_detail_super0(struct supertype *st, char *subarray)
{
mdp_super_t *sb = st->sb;
printf(" UUID=");
diff --git a/super1.c b/super1.c
index b85dc20..929466d 100644
--- a/super1.c
+++ b/super1.c
@@ -833,7 +833,7 @@ err:
return 1;
}
-static void detail_super1(struct supertype *st, char *homehost)
+static void detail_super1(struct supertype *st, char *homehost, char *subarray)
{
struct mdp_superblock_1 *sb = st->sb;
bitmap_super_t *bms = (bitmap_super_t*)(((char*)sb) + MAX_SB_SIZE);
@@ -857,7 +857,7 @@ static void detail_super1(struct supertype *st, char *homehost)
(unsigned long long)__le64_to_cpu(sb->events));
}
-static void brief_detail_super1(struct supertype *st)
+static void brief_detail_super1(struct supertype *st, char *subarray)
{
struct mdp_superblock_1 *sb = st->sb;
int i;
--
2.25.0
++++++ 0058-imsm-Change-the-way-of-printing-nvme-drives-in-detai.patch ++++++
>From 6da53c0e2aab200605722795798b1e4f2352cd64 Mon Sep 17 00:00:00 2001
From: Blazej Kucman <blazej.kucman(a)intel.com>
Date: Mon, 2 Dec 2019 10:52:05 +0100
Subject: [PATCH] imsm: Change the way of printing nvme drives in
detail-platform.
Git-commit: 6da53c0e2aab200605722795798b1e4f2352cd64
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Change NVMe controller path to device node path
in mdadm --detail-platform and print serial number.
The method imsm_read_serial always trimes serial to
MAX_RAID_SERIAL_LEN, added parameter 'serial_buf_len'
will be used to check the serial fit
to passed buffor, if not, will be trimed.
Signed-off-by: Blazej Kucman <blazej.kucman(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
super-intel.c | 97 ++++++++++++++++++++++++---------------------------
1 file changed, 46 insertions(+), 51 deletions(-)
diff --git a/super-intel.c b/super-intel.c
index 86dcb69..5c1f759 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -2218,7 +2218,8 @@ static void brief_detail_super_imsm(struct supertype *st, char *subarray)
super->current_vol = temp_vol;
}
-static int imsm_read_serial(int fd, char *devname, __u8 *serial);
+static int imsm_read_serial(int fd, char *devname, __u8 *serial,
+ size_t serial_buf_len);
static void fd2devname(int fd, char *name);
static int ahci_enumerate_ports(const char *hba_path, int port_count, int host_base, int verbose)
@@ -2364,8 +2365,9 @@ static int ahci_enumerate_ports(const char *hba_path, int port_count, int host_b
else {
fd2devname(fd, buf);
printf(" Port%d : %s", port, buf);
- if (imsm_read_serial(fd, NULL, (__u8 *) buf) == 0)
- printf(" (%.*s)\n", MAX_RAID_SERIAL_LEN, buf);
+ if (imsm_read_serial(fd, NULL, (__u8 *)buf,
+ sizeof(buf)) == 0)
+ printf(" (%s)\n", buf);
else
printf(" ()\n");
close(fd);
@@ -2388,52 +2390,45 @@ static int ahci_enumerate_ports(const char *hba_path, int port_count, int host_b
return err;
}
-static int print_vmd_attached_devs(struct sys_dev *hba)
+static int print_nvme_info(struct sys_dev *hba)
{
+ char buf[1024];
struct dirent *ent;
DIR *dir;
- char path[292];
- char link[256];
- char *c, *rp;
-
- if (hba->type != SYS_DEV_VMD)
- return 1;
+ char *rp;
+ int fd;
- /* scroll through /sys/dev/block looking for devices attached to
- * this hba
- */
- dir = opendir("/sys/bus/pci/drivers/nvme");
+ dir = opendir("/sys/block/");
if (!dir)
return 1;
for (ent = readdir(dir); ent; ent = readdir(dir)) {
- int n;
-
- /* is 'ent' a device? check that the 'subsystem' link exists and
- * that its target matches 'bus'
- */
- sprintf(path, "/sys/bus/pci/drivers/nvme/%s/subsystem",
- ent->d_name);
- n = readlink(path, link, sizeof(link));
- if (n < 0 || n >= (int)sizeof(link))
- continue;
- link[n] = '\0';
- c = strrchr(link, '/');
- if (!c)
- continue;
- if (strncmp("pci", c+1, strlen("pci")) != 0)
- continue;
-
- sprintf(path, "/sys/bus/pci/drivers/nvme/%s", ent->d_name);
-
- rp = realpath(path, NULL);
- if (!rp)
- continue;
+ if (strstr(ent->d_name, "nvme")) {
+ sprintf(buf, "/sys/block/%s", ent->d_name);
+ rp = realpath(buf, NULL);
+ if (!rp)
+ continue;
+ if (path_attached_to_hba(rp, hba->path)) {
+ fd = open_dev(ent->d_name);
+ if (fd < 0) {
+ free(rp);
+ continue;
+ }
- if (path_attached_to_hba(rp, hba->path)) {
- printf(" NVMe under VMD : %s\n", rp);
+ fd2devname(fd, buf);
+ if (hba->type == SYS_DEV_VMD)
+ printf(" NVMe under VMD : %s", buf);
+ else if (hba->type == SYS_DEV_NVME)
+ printf(" NVMe Device : %s", buf);
+ if (!imsm_read_serial(fd, NULL, (__u8 *)buf,
+ sizeof(buf)))
+ printf(" (%s)\n", buf);
+ else
+ printf("()\n");
+ close(fd);
+ }
+ free(rp);
}
- free(rp);
}
closedir(dir);
@@ -2648,7 +2643,7 @@ static int detail_platform_imsm(int verbose, int enumerate_only, char *controlle
char buf[PATH_MAX];
printf(" I/O Controller : %s (%s)\n",
vmd_domain_to_controller(hba, buf), get_sys_dev_type(hba->type));
- if (print_vmd_attached_devs(hba)) {
+ if (print_nvme_info(hba)) {
if (verbose > 0)
pr_err("failed to get devices attached to VMD domain.\n");
result |= 2;
@@ -2663,7 +2658,7 @@ static int detail_platform_imsm(int verbose, int enumerate_only, char *controlle
if (entry->type == SYS_DEV_NVME) {
for (hba = list; hba; hba = hba->next) {
if (hba->type == SYS_DEV_NVME)
- printf(" NVMe Device : %s\n", hba->path);
+ print_nvme_info(hba);
}
printf("\n");
continue;
@@ -4028,11 +4023,11 @@ static int nvme_get_serial(int fd, void *buf, size_t buf_len)
extern int scsi_get_serial(int fd, void *buf, size_t buf_len);
static int imsm_read_serial(int fd, char *devname,
- __u8 serial[MAX_RAID_SERIAL_LEN])
+ __u8 *serial, size_t serial_buf_len)
{
char buf[50];
int rv;
- int len;
+ size_t len;
char *dest;
char *src;
unsigned int i;
@@ -4075,13 +4070,13 @@ static int imsm_read_serial(int fd, char *devname,
len = dest - buf;
dest = buf;
- /* truncate leading characters */
- if (len > MAX_RAID_SERIAL_LEN) {
- dest += len - MAX_RAID_SERIAL_LEN;
- len = MAX_RAID_SERIAL_LEN;
+ if (len > serial_buf_len) {
+ /* truncate leading characters */
+ dest += len - serial_buf_len;
+ len = serial_buf_len;
}
- memset(serial, 0, MAX_RAID_SERIAL_LEN);
+ memset(serial, 0, serial_buf_len);
memcpy(serial, dest, len);
return 0;
@@ -4136,7 +4131,7 @@ load_imsm_disk(int fd, struct intel_super *super, char *devname, int keep_fd)
char name[40];
__u8 serial[MAX_RAID_SERIAL_LEN];
- rv = imsm_read_serial(fd, devname, serial);
+ rv = imsm_read_serial(fd, devname, serial, MAX_RAID_SERIAL_LEN);
if (rv != 0)
return 2;
@@ -5844,7 +5839,7 @@ int mark_spare(struct dl *disk)
return ret_val;
ret_val = 0;
- if (!imsm_read_serial(disk->fd, NULL, serial)) {
+ if (!imsm_read_serial(disk->fd, NULL, serial, MAX_RAID_SERIAL_LEN)) {
/* Restore disk serial number, because takeover marks disk
* as failed and adds to serial ':0' before it becomes
* a spare disk.
@@ -5895,7 +5890,7 @@ static int add_to_super_imsm(struct supertype *st, mdu_disk_info_t *dk,
dd->fd = fd;
dd->e = NULL;
dd->action = DISK_ADD;
- rv = imsm_read_serial(fd, devname, dd->serial);
+ rv = imsm_read_serial(fd, devname, dd->serial, MAX_RAID_SERIAL_LEN);
if (rv) {
pr_err("failed to retrieve scsi serial, aborting\n");
if (dd->devname)
--
2.25.0
++++++ 0015-Create-add-support-for-RAID0-layouts.patch -> 0059-Create-add-support-for-RAID0-layouts.patch ++++++
++++++ 0016-Assemble-add-support-for-RAID0-layouts.patch -> 0060-Assemble-add-support-for-RAID0-layouts.patch ++++++
++++++ 0061-Respect-CROSS_COMPILE-when-CC-is-the-default.patch ++++++
>From aced6fc9542077a69b00d05bc9cd66c12fc34950 Mon Sep 17 00:00:00 2001
From: dann frazier <dann.frazier(a)canonical.com>
Date: Mon, 9 Dec 2019 13:54:13 -0700
Subject: [PATCH] Respect $(CROSS_COMPILE) when $(CC) is the default
Git-commit: aced6fc9542077a69b00d05bc9cd66c12fc34950
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Commit 1180ed5 told make to only respect $(CROSS_COMPILE) when $(CC)
was unset. But that will never be the case, as make provides
a default value for $(CC). Change this logic to respect $(CROSS_COMPILE)
when $(CC) is the default. Patch originally by Helmet Grohne.
Fixes: 1180ed5 ("Makefile: make the CC definition conditional")
Signed-off-by: dann frazier <dann.frazier(a)canonical.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
Makefile | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/Makefile b/Makefile
index dfe00b0..a33319a 100644
--- a/Makefile
+++ b/Makefile
@@ -46,7 +46,9 @@ ifdef COVERITY
COVERITY_FLAGS=-include coverity-gcc-hack.h
endif
-CC ?= $(CROSS_COMPILE)gcc
+ifeq ($(origin CC),default)
+CC := $(CROSS_COMPILE)gcc
+endif
CXFLAGS ?= -ggdb
CWFLAGS = -Wall -Werror -Wstrict-prototypes -Wextra -Wno-unused-parameter
ifdef WARN_UNUSED
--
2.25.0
++++++ 0062-Change-warning-message.patch ++++++
>From 1a87493014050e3bd94000cd36122c3cadf21270 Mon Sep 17 00:00:00 2001
From: Kinga Tanska <kinga.tanska(a)intel.com>
Date: Tue, 10 Dec 2019 12:21:21 +0100
Subject: [PATCH] Change warning message
Git-commit: 1a87493014050e3bd94000cd36122c3cadf21270
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
In commit 039b7225e6 ("md: allow creation of mdNNN arrays via
md_mod/parameters/new_array") support for name like mdNNN
was added. Special warning, when kernel is unable to handle
request, was added in commit 7105228e19
("mdadm/mdopen: create new function create_named_array for
writing to new_array"), but it was not adequate enough,
because in this situation mdadm tries to do it in old way.
This commit changes warning to be more relevant when
creating RAID container with "/dev/mdNNN" name and mdadm
back to old approach.
Signed-off-by: Kinga Tanska <kinga.tanska(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
mdopen.c | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/mdopen.c b/mdopen.c
index 98c54e4..245be53 100644
--- a/mdopen.c
+++ b/mdopen.c
@@ -120,7 +120,8 @@ int create_named_array(char *devnm)
close(fd);
}
if (fd < 0 || n != (int)strlen(devnm)) {
- pr_err("Fail create %s when using %s\n", devnm, new_array_file);
+ pr_err("Fail to create %s when using %s, fallback to creation via node\n",
+ devnm, new_array_file);
return 0;
}
--
2.25.0
++++++ 0063-mdcheck-service-can-t-start-succesfully-because-of-s.patch ++++++
>From e1512e7b7d060f0346738b237ea34eac21b29a26 Mon Sep 17 00:00:00 2001
From: Xiao Ni <xni(a)redhat.com>
Date: Wed, 18 Dec 2019 14:46:21 +0800
Subject: [PATCH] mdcheck service can't start succesfully because of syntax
error
Git-commit: e1512e7b7d060f0346738b237ea34eac21b29a26
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
It reports error when starting mdcheck_start and mdcheck_continue service.
Invalid environment assignment, ignoring: MDADM_CHECK_DURATION="6 hours"
Signed-off-by: Xiao Ni <xni(a)redhat.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
systemd/mdcheck_continue.service | 2 +-
systemd/mdcheck_start.service | 2 +-
2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/systemd/mdcheck_continue.service b/systemd/mdcheck_continue.service
index deac695..aa02dde 100644
--- a/systemd/mdcheck_continue.service
+++ b/systemd/mdcheck_continue.service
@@ -11,7 +11,7 @@ ConditionPathExistsGlob = /var/lib/mdcheck/MD_UUID_*
[Service]
Type=oneshot
-Environment= MDADM_CHECK_DURATION="6 hours"
+Environment= "MDADM_CHECK_DURATION=6 hours"
EnvironmentFile=-/run/sysconfig/mdadm
ExecStartPre=-/usr/lib/mdadm/mdadm_env.sh
ExecStart=/usr/share/mdadm/mdcheck --continue --duration ${MDADM_CHECK_DURATION}
diff --git a/systemd/mdcheck_start.service b/systemd/mdcheck_start.service
index f17f1aa..da62d5f 100644
--- a/systemd/mdcheck_start.service
+++ b/systemd/mdcheck_start.service
@@ -11,7 +11,7 @@ Wants=mdcheck_continue.timer
[Service]
Type=oneshot
-Environment= MDADM_CHECK_DURATION="6 hours"
+Environment= "MDADM_CHECK_DURATION=6 hours"
EnvironmentFile=-/run/sysconfig/mdadm
ExecStartPre=-/usr/lib/mdadm/mdadm_env.sh
ExecStart=/usr/share/mdadm/mdcheck --duration ${MDADM_CHECK_DURATION}
--
2.25.0
++++++ 0064-imsm-Update-grow-manual.patch ++++++
>From 4431efebabd0dd39f33dc1dd8ada312b8da1c9d8 Mon Sep 17 00:00:00 2001
From: Blazej Kucman <blazej.kucman(a)intel.com>
Date: Thu, 16 Jan 2020 09:34:44 +0100
Subject: [PATCH] imsm: Update grow manual.
Git-commit: 4431efebabd0dd39f33dc1dd8ada312b8da1c9d8
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Update --grow option description in manual, according to
the supported grow operations by IMSM.
Signed-off-by: Blazej Kucman <blazej.kucman(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
mdadm.8.in | 8 ++------
1 file changed, 2 insertions(+), 6 deletions(-)
diff --git a/mdadm.8.in b/mdadm.8.in
index 6b63bb4..ca02a33 100644
--- a/mdadm.8.in
+++ b/mdadm.8.in
@@ -481,9 +481,7 @@ still be larger than any replacement.
This value can be set with
.B \-\-grow
for RAID level 1/4/5/6 though
-.B CONTAINER
-based arrays such as those with IMSM metadata may not be able to
-support this.
+DDF arrays may not be able to support this.
If the array was created with a size smaller than the currently
active drives, the extra space can be accessed using
.BR \-\-grow .
@@ -2759,9 +2757,7 @@ container format. The number of devices in a container can be
increased - which affects all arrays in the container - or an array
in a container can be converted between levels where those levels are
supported by the container, and the conversion is on of those listed
-above. Resizing arrays in an IMSM container with
-.B "--grow --size"
-is not yet supported.
+above.
.PP
Notes:
--
2.25.0
++++++ 0065-Add-support-for-Tebibytes.patch ++++++
>From 42e641abeb312a91b841f1b1ea73661e4bd5a31c Mon Sep 17 00:00:00 2001
From: Kinga Tanska <kinga.tanska(a)intel.com>
Date: Tue, 21 Jan 2020 10:38:52 +0100
Subject: [PATCH] Add support for Tebibytes
Git-commit: 42e641abeb312a91b841f1b1ea73661e4bd5a31c
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Adding support for Tebibytes enables display size of
volumes in Tebibytes and Terabytes when they are
bigger than 2048 GiB (or GB).
Signed-off-by: Kinga Tanska <kinga.tanska(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
mdadm.8.in | 20 ++++++++++----------
util.c | 47 +++++++++++++++++++++++++++++++++--------------
2 files changed, 43 insertions(+), 24 deletions(-)
diff --git a/mdadm.8.in b/mdadm.8.in
index ca02a33..5d00faf 100644
--- a/mdadm.8.in
+++ b/mdadm.8.in
@@ -467,8 +467,8 @@ If this is not specified
size, though if there is a variance among the drives of greater than 1%, a warning is
issued.
-A suffix of 'K', 'M' or 'G' can be given to indicate Kilobytes, Megabytes or
-Gigabytes respectively.
+A suffix of 'K', 'M', 'G' or 'T' can be given to indicate Kilobytes,
+Megabytes, Gigabytes or Terabytes respectively.
Sometimes a replacement drive can be a little smaller than the
original drives though this should be minimised by IDEMA standards.
@@ -532,8 +532,8 @@ problems the array can be made bigger again with no loss with another
.B "\-\-grow \-\-array\-size="
command.
-A suffix of 'K', 'M' or 'G' can be given to indicate Kilobytes, Megabytes or
-Gigabytes respectively.
+A suffix of 'K', 'M', 'G' or 'T' can be given to indicate Kilobytes,
+Megabytes, Gigabytes or Terabytes respectively.
A value of
.B max
restores the apparent size of the array to be whatever the real
@@ -551,8 +551,8 @@ This is only meaningful for RAID0, RAID4, RAID5, RAID6, and RAID10.
RAID4, RAID5, RAID6, and RAID10 require the chunk size to be a power
of 2. In any case it must be a multiple of 4KB.
-A suffix of 'K', 'M' or 'G' can be given to indicate Kilobytes, Megabytes or
-Gigabytes respectively.
+A suffix of 'K', 'M', 'G' or 'T' can be given to indicate Kilobytes,
+Megabytes, Gigabytes or Terabytes respectively.
.TP
.BR \-\-rounding=
@@ -767,8 +767,8 @@ When using an
bitmap, the chunksize defaults to 64Meg, or larger if necessary to
fit the bitmap into the available space.
-A suffix of 'K', 'M' or 'G' can be given to indicate Kilobytes, Megabytes or
-Gigabytes respectively.
+A suffix of 'K', 'M', 'G' or 'T' can be given to indicate Kilobytes,
+Megabytes, Gigabytes or Terabytes respectively.
.TP
.BR \-W ", " \-\-write\-mostly
@@ -857,8 +857,8 @@ an array which was originally created using a different version of
which computed a different offset.
Setting the offset explicitly over-rides the default. The value given
-is in Kilobytes unless a suffix of 'K', 'M' or 'G' is used to explicitly
-indicate Kilobytes, Megabytes or Gigabytes respectively.
+is in Kilobytes unless a suffix of 'K', 'M', 'G' or 'T' is used to explicitly
+indicate Kilobytes, Megabytes, Gigabytes or Terabytes respectively.
Since Linux 3.4,
.B \-\-data\-offset
diff --git a/util.c b/util.c
index 64dd409..07f9dc3 100644
--- a/util.c
+++ b/util.c
@@ -389,7 +389,7 @@ int mdadm_version(char *version)
unsigned long long parse_size(char *size)
{
/* parse 'size' which should be a number optionally
- * followed by 'K', 'M', or 'G'.
+ * followed by 'K', 'M'. 'G' or 'T'.
* Without a suffix, K is assumed.
* Number returned is in sectors (half-K)
* INVALID_SECTORS returned on error.
@@ -411,6 +411,10 @@ unsigned long long parse_size(char *size)
c++;
s *= 1024 * 1024 * 2;
break;
+ case 'T':
+ c++;
+ s *= 1024 * 1024 * 1024 * 2LL;
+ break;
case 's': /* sectors */
c++;
break;
@@ -893,13 +897,14 @@ char *human_size(long long bytes)
{
static char buf[47];
- /* We convert bytes to either centi-M{ega,ibi}bytes or
- * centi-G{igi,ibi}bytes, with appropriate rounding,
- * and then print 1/100th of those as a decimal.
+ /* We convert bytes to either centi-M{ega,ibi}bytes,
+ * centi-G{igi,ibi}bytes or centi-T{era,ebi}bytes
+ * with appropriate rounding, and then print
+ * 1/100th of those as a decimal.
* We allow upto 2048Megabytes before converting to
- * gigabytes, as that shows more precision and isn't
+ * gigabytes and 2048Gigabytes before converting to
+ * terabytes, as that shows more precision and isn't
* too large a number.
- * Terabytes are not yet handled.
*/
if (bytes < 5000*1024)
@@ -909,11 +914,16 @@ char *human_size(long long bytes)
long cMB = (bytes / ( 1000000LL / 200LL ) +1) /2;
snprintf(buf, sizeof(buf), " (%ld.%02ld MiB %ld.%02ld MB)",
cMiB/100, cMiB % 100, cMB/100, cMB % 100);
- } else {
+ } else if (bytes < 2*1024LL*1024LL*1024LL*1024LL) {
long cGiB = (bytes * 200LL / (1LL<<30) +1) / 2;
long cGB = (bytes / (1000000000LL/200LL ) +1) /2;
snprintf(buf, sizeof(buf), " (%ld.%02ld GiB %ld.%02ld GB)",
cGiB/100, cGiB % 100, cGB/100, cGB % 100);
+ } else {
+ long cTiB = (bytes * 200LL / (1LL<<40) + 1) / 2;
+ long cTB = (bytes / (1000000000000LL / 200LL) + 1) / 2;
+ snprintf(buf, sizeof(buf), " (%ld.%02ld TiB %ld.%02ld TB)",
+ cTiB/100, cTiB % 100, cTB/100, cTB % 100);
}
return buf;
}
@@ -922,13 +932,14 @@ char *human_size_brief(long long bytes, int prefix)
{
static char buf[30];
- /* We convert bytes to either centi-M{ega,ibi}bytes or
- * centi-G{igi,ibi}bytes, with appropriate rounding,
- * and then print 1/100th of those as a decimal.
+ /* We convert bytes to either centi-M{ega,ibi}bytes,
+ * centi-G{igi,ibi}bytes or centi-T{era,ebi}bytes
+ * with appropriate rounding, and then print
+ * 1/100th of those as a decimal.
* We allow upto 2048Megabytes before converting to
- * gigabytes, as that shows more precision and isn't
+ * gigabytes and 2048Gigabytes before converting to
+ * terabytes, as that shows more precision and isn't
* too large a number.
- * Terabytes are not yet handled.
*
* If prefix == IEC, we mean prefixes like kibi,mebi,gibi etc.
* If prefix == JEDEC, we mean prefixes like kilo,mega,giga etc.
@@ -941,10 +952,14 @@ char *human_size_brief(long long bytes, int prefix)
long cMiB = (bytes * 200LL / (1LL<<20) +1) /2;
snprintf(buf, sizeof(buf), "%ld.%02ldMiB",
cMiB/100, cMiB % 100);
- } else {
+ } else if (bytes < 2*1024LL*1024LL*1024LL*1024LL) {
long cGiB = (bytes * 200LL / (1LL<<30) +1) /2;
snprintf(buf, sizeof(buf), "%ld.%02ldGiB",
cGiB/100, cGiB % 100);
+ } else {
+ long cTiB = (bytes * 200LL / (1LL<<40) + 1) / 2;
+ snprintf(buf, sizeof(buf), "%ld.%02ldTiB",
+ cTiB/100, cTiB % 100);
}
}
else if (prefix == JEDEC) {
@@ -952,10 +967,14 @@ char *human_size_brief(long long bytes, int prefix)
long cMB = (bytes / ( 1000000LL / 200LL ) +1) /2;
snprintf(buf, sizeof(buf), "%ld.%02ldMB",
cMB/100, cMB % 100);
- } else {
+ } else if (bytes < 2*1024LL*1024LL*1024LL*1024LL) {
long cGB = (bytes / (1000000000LL/200LL ) +1) /2;
snprintf(buf, sizeof(buf), "%ld.%02ldGB",
cGB/100, cGB % 100);
+ } else {
+ long cTB = (bytes / (1000000000000LL / 200LL) + 1) / 2;
+ snprintf(buf, sizeof(buf), "%ld.%02ldTB",
+ cTB/100, cTB % 100);
}
}
else
--
2.25.0
++++++ 0066-imsm-fill-working_disks-according-to-metadata.patch ++++++
>From 1e93d0d15913c3fa6d0de5af3fb5e4e3b3f068da Mon Sep 17 00:00:00 2001
From: Blazej Kucman <blazej.kucman(a)intel.com>
Date: Fri, 17 Jan 2020 15:24:04 +0100
Subject: [PATCH] imsm: fill working_disks according to metadata.
Git-commit: 1e93d0d15913c3fa6d0de5af3fb5e4e3b3f068da
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Imsm tracks as "working_disk" each visible drive.
Assemble routine expects that the value will return count
of active member drives recorded in metadata.
As a side effect "--no-degraded" doesn't work correctly for imsm.
Align this field to others.
Added check, if the option --no-degraded is called with --scan.
Signed-off-by: Blazej Kucman <blazej.kucman(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
mdadm.c | 9 ++++++---
super-intel.c | 5 ++---
2 files changed, 8 insertions(+), 6 deletions(-)
diff --git a/mdadm.c b/mdadm.c
index 256a97e..13dc24e 100644
--- a/mdadm.c
+++ b/mdadm.c
@@ -1485,9 +1485,12 @@ int main(int argc, char *argv[])
rv = Manage_stop(devlist->devname, mdfd, c.verbose, 0);
break;
case ASSEMBLE:
- if (devs_found == 1 && ident.uuid_set == 0 &&
- ident.super_minor == UnSet && ident.name[0] == 0 &&
- !c.scan ) {
+ if (!c.scan && c.runstop == -1) {
+ pr_err("--no-degraded not meaningful without a --scan assembly.\n");
+ exit(1);
+ } else if (devs_found == 1 && ident.uuid_set == 0 &&
+ ident.super_minor == UnSet && ident.name[0] == 0 &&
+ !c.scan) {
/* Only a device has been given, so get details from config file */
struct mddev_ident *array_ident = conf_get_ident(devlist->devname);
if (array_ident == NULL) {
diff --git a/super-intel.c b/super-intel.c
index 5c1f759..47809bc 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -7946,7 +7946,8 @@ static struct mdinfo *container_content_imsm(struct supertype *st, char *subarra
skip = 1;
if (!skip && (ord & IMSM_ORD_REBUILD))
recovery_start = 0;
-
+ if (!(ord & IMSM_ORD_REBUILD))
+ this->array.working_disks++;
/*
* if we skip some disks the array will be assmebled degraded;
* reset resync start to avoid a dirty-degraded
@@ -7988,8 +7989,6 @@ static struct mdinfo *container_content_imsm(struct supertype *st, char *subarra
else
this->array.spare_disks++;
}
- if (info_d->recovery_start == MaxSector)
- this->array.working_disks++;
info_d->events = __le32_to_cpu(mpb->generation_num);
info_d->data_offset = pba_of_lba0(map);
--
2.25.0
++++++ 1002-mdadm.8-add-note-information-for-raid0-growing-opera.patch -> 0067-mdadm.8-add-note-information-for-raid0-growing-opera.patch ++++++
--- /work/SRC/openSUSE:Factory/mdadm/1002-mdadm.8-add-note-information-for-raid0-growing-opera.patch 2020-02-15 22:24:48.227289725 +0100
+++ /work/SRC/openSUSE:Factory/.mdadm.new.3160/0067-mdadm.8-add-note-information-for-raid0-growing-opera.patch 2020-03-31 17:31:51.288246765 +0200
@@ -1,15 +1,17 @@
-From 224228a2a4db8f433e4ae8fc827e231e095aca45 Mon Sep 17 00:00:00 2001
+From 2551061c253b8fd45ee93d1aab3e91d2c7ac9c20 Mon Sep 17 00:00:00 2001
From: Coly Li <colyli(a)suse.de>
-Date: Thu, 19 Dec 2019 18:08:05 +0800
-Subject: [PATCH v3] mdadm.8: add note information for raid0 growing operation
-Patch-mainline: Not yet, waiting for maintainer to merge
+Date: Mon, 24 Feb 2020 12:34:09 +0100
+Subject: [PATCH] mdadm.8: add note information for raid0 growing operation
+Git-commit: 2551061c253b8fd45ee93d1aab3e91d2c7ac9c20
+Patch-mainline: mdadm-4.1+
References: bsc#1129900
When growing a raid0 device, if the new component disk size is not
big enough, the grow operation may fail due to lack of backup space.
-The minimum backup space should be larger than
- LCM(old, new) * chunk-size * 2
+The minimum backup space should be larger than:
+ LCM(old, new) * chunk-size * 2
+
where LCM() is the least common multiple of the old and new count of
component disks, and "* 2" comes from the fact that mdadm refuses to
use more than half of a spare device for backup space.
@@ -17,25 +19,28 @@
There are users reporting such failure when they grew a raid0 array
with small component disk. Neil Brown points out this is not a bug
and how the failure comes. This patch adds note information into
-mdadm(8) man page in the Notes part of GROW MODE section, to explain
+mdadm(8) man page in the Notes part of GROW MODE section to explain
the minimum size requirement of new component disk size or external
backup size.
-Signed-off-by: Coly Li <colyli(a)suse.de>
+Reviewed-by: Petr Vorel <pvorel(a)suse.cz>
Cc: NeilBrown <neilb(a)suse.de>
Cc: Jes Sorensen <jsorensen(a)fb.com>
Cc: Paul Menzel <pmenzel(a)molgen.mpg.de>
Cc: Wols Lists <antlists(a)youngman.org.uk>
Cc: Nix <nix(a)esperi.org.uk>
+Signed-off-by: Coly Li <colyli(a)suse.de>
+Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
+
---
mdadm.8.in | 6 ++++++
1 file changed, 6 insertions(+)
diff --git a/mdadm.8.in b/mdadm.8.in
-index 6b63bb4..bba4e25 100644
+index 5d00faf..a3494a1 100644
--- a/mdadm.8.in
+++ b/mdadm.8.in
-@@ -2772,6 +2772,12 @@ option and it is transparent for assembly feature.
+@@ -2768,6 +2768,12 @@ option and it is transparent for assembly feature.
.IP \(bu 4
Roaming between Windows(R) and Linux systems for IMSM metadata is not
supported during grow process.
@@ -44,10 +49,10 @@
+backup size) should be larger than LCM(old, new) * chunk-size * 2,
+where LCM() is the least common multiple of the old and new count of
+component disks, and "* 2" comes from the fact that mdadm refuses to
-+use more than half of a spare device for backup space.
++use more than half of a spare device for backup space.
.SS SIZE CHANGES
Normally when an array is built the "size" is taken from the smallest
--
-2.16.4
+2.25.0
++++++ 0068-Remove-the-legacy-whitespace.patch ++++++
>From fd38b8ea80ff8e0317e12d1d70431148ceedd5fd Mon Sep 17 00:00:00 2001
From: Xiao Ni <xni(a)redhat.com>
Date: Tue, 11 Feb 2020 21:44:15 +0800
Subject: [PATCH] Remove the legacy whitespace
Git-commit: fd38b8ea80ff8e0317e12d1d70431148ceedd5fd
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
The whitespace between Environment= and the true value causes confusion.
To avoid confusing other people in future, remove the whitespace to keep
it a simple, unambiguous syntax
Signed-off-by: Xiao Ni <xni(a)redhat.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
systemd/mdcheck_continue.service | 2 +-
systemd/mdcheck_start.service | 2 +-
systemd/mdmonitor-oneshot.service | 2 +-
3 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/systemd/mdcheck_continue.service b/systemd/mdcheck_continue.service
index aa02dde..854317f 100644
--- a/systemd/mdcheck_continue.service
+++ b/systemd/mdcheck_continue.service
@@ -11,7 +11,7 @@ ConditionPathExistsGlob = /var/lib/mdcheck/MD_UUID_*
[Service]
Type=oneshot
-Environment= "MDADM_CHECK_DURATION=6 hours"
+Environment="MDADM_CHECK_DURATION=6 hours"
EnvironmentFile=-/run/sysconfig/mdadm
ExecStartPre=-/usr/lib/mdadm/mdadm_env.sh
ExecStart=/usr/share/mdadm/mdcheck --continue --duration ${MDADM_CHECK_DURATION}
diff --git a/systemd/mdcheck_start.service b/systemd/mdcheck_start.service
index da62d5f..3bb3d13 100644
--- a/systemd/mdcheck_start.service
+++ b/systemd/mdcheck_start.service
@@ -11,7 +11,7 @@ Wants=mdcheck_continue.timer
[Service]
Type=oneshot
-Environment= "MDADM_CHECK_DURATION=6 hours"
+Environment="MDADM_CHECK_DURATION=6 hours"
EnvironmentFile=-/run/sysconfig/mdadm
ExecStartPre=-/usr/lib/mdadm/mdadm_env.sh
ExecStart=/usr/share/mdadm/mdcheck --duration ${MDADM_CHECK_DURATION}
diff --git a/systemd/mdmonitor-oneshot.service b/systemd/mdmonitor-oneshot.service
index fd469b1..373955a 100644
--- a/systemd/mdmonitor-oneshot.service
+++ b/systemd/mdmonitor-oneshot.service
@@ -9,7 +9,7 @@
Description=Reminder for degraded MD arrays
[Service]
-Environment= MDADM_MONITOR_ARGS=--scan
+Environment=MDADM_MONITOR_ARGS=--scan
EnvironmentFile=-/run/sysconfig/mdadm
ExecStartPre=-/usr/lib/mdadm/mdadm_env.sh
ExecStart=BINDIR/mdadm --monitor --oneshot $MDADM_MONITOR_ARGS
--
2.25.0
++++++ 0069-imsm-pass-subarray-id-to-kill_subarray-function.patch ++++++
>From 3364781b929f571a3dc3a6afed09eb1b03ce607c Mon Sep 17 00:00:00 2001
From: Blazej Kucman <blazej.kucman(a)intel.com>
Date: Wed, 19 Feb 2020 10:54:49 +0100
Subject: [PATCH] imsm: pass subarray id to kill_subarray function
Git-commit: 3364781b929f571a3dc3a6afed09eb1b03ce607c
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
After patch b6180160f ("imsm: save current_vol number")
current_vol for imsm is not set and kill_subarray()
cannot determine which volume has to be deleted.
Volume has to be passed as "subarray_id".
The parameter affects only IMSM metadata.
Signed-off-by: Blazej Kucman <blazej.kucman(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
Kill.c | 2 +-
mdadm.h | 3 ++-
super-ddf.c | 2 +-
super-intel.c | 9 ++++-----
4 files changed, 8 insertions(+), 8 deletions(-)
diff --git a/Kill.c b/Kill.c
index d4767e2..bfd0efd 100644
--- a/Kill.c
+++ b/Kill.c
@@ -119,7 +119,7 @@ int Kill_subarray(char *dev, char *subarray, int verbose)
st->update_tail = &st->updates;
/* ok we've found our victim, drop the axe */
- rv = st->ss->kill_subarray(st);
+ rv = st->ss->kill_subarray(st, subarray);
if (rv) {
if (verbose >= 0)
pr_err("Failed to delete subarray-%s from %s\n",
diff --git a/mdadm.h b/mdadm.h
index 9e98778..d94569f 100644
--- a/mdadm.h
+++ b/mdadm.h
@@ -1038,7 +1038,8 @@ extern struct superswitch {
/* query the supertype for default geometry */
void (*default_geometry)(struct supertype *st, int *level, int *layout, int *chunk); /* optional */
/* Permit subarray's to be deleted from inactive containers */
- int (*kill_subarray)(struct supertype *st); /* optional */
+ int (*kill_subarray)(struct supertype *st,
+ char *subarray_id); /* optional */
/* Permit subarray's to be modified */
int (*update_subarray)(struct supertype *st, char *subarray,
char *update, struct mddev_ident *ident); /* optional */
diff --git a/super-ddf.c b/super-ddf.c
index 7802063..7cd5702 100644
--- a/super-ddf.c
+++ b/super-ddf.c
@@ -4446,7 +4446,7 @@ static int _kill_subarray_ddf(struct ddf_super *ddf, const char *guid)
return 0;
}
-static int kill_subarray_ddf(struct supertype *st)
+static int kill_subarray_ddf(struct supertype *st, char *subarray_id)
{
struct ddf_super *ddf = st->sb;
/*
diff --git a/super-intel.c b/super-intel.c
index 47809bc..e4d2122 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -7600,18 +7600,17 @@ static void default_geometry_imsm(struct supertype *st, int *level, int *layout,
static void handle_missing(struct intel_super *super, struct imsm_dev *dev);
-static int kill_subarray_imsm(struct supertype *st)
+static int kill_subarray_imsm(struct supertype *st, char *subarray_id)
{
- /* remove the subarray currently referenced by ->current_vol */
+ /* remove the subarray currently referenced by subarray_id */
__u8 i;
struct intel_dev **dp;
struct intel_super *super = st->sb;
- __u8 current_vol = super->current_vol;
+ __u8 current_vol = strtoul(subarray_id, NULL, 10);
struct imsm_super *mpb = super->anchor;
- if (super->current_vol < 0)
+ if (mpb->num_raid_devs == 0)
return 2;
- super->current_vol = -1; /* invalidate subarray cursor */
/* block deletions that would change the uuid of active subarrays
*
--
2.25.0
++++++ 0070-imsm-Remove-dump-restore-implementation.patch ++++++
>From 45c43276d02a32876c7e1f9f0d04580595141b3d Mon Sep 17 00:00:00 2001
From: Blazej Kucman <blazej.kucman(a)intel.com>
Date: Wed, 19 Feb 2020 11:13:17 +0100
Subject: [PATCH] imsm: Remove --dump/--restore implementation
Git-commit: 45c43276d02a32876c7e1f9f0d04580595141b3d
Patch-mainline: mdadm-4.1+
References: jsc#SLE-10078, jsc#SLE-9348
Functionalities --dump and --restore are not supported.
Remove dead code from imsm.
Signed-off-by: Blazej Kucman <blazej.kucman(a)intel.com>
Signed-off-by: Jes Sorensen <jsorensen(a)fb.com>
Signed-off-by: Coly Li <colyli(a)suse.de>
---
super-intel.c | 56 ---------------------------------------------------
1 file changed, 56 deletions(-)
diff --git a/super-intel.c b/super-intel.c
index e4d2122..c9a1af5 100644
--- a/super-intel.c
+++ b/super-intel.c
@@ -2128,61 +2128,6 @@ static void export_examine_super_imsm(struct supertype *st)
printf("MD_DEVICES=%u\n", mpb->num_disks);
}
-static int copy_metadata_imsm(struct supertype *st, int from, int to)
-{
- /* The second last sector of the device contains
- * the "struct imsm_super" metadata.
- * This contains mpb_size which is the size in bytes of the
- * extended metadata. This is located immediately before
- * the imsm_super.
- * We want to read all that, plus the last sector which
- * may contain a migration record, and write it all
- * to the target.
- */
- void *buf;
- unsigned long long dsize, offset;
- int sectors;
- struct imsm_super *sb;
- struct intel_super *super = st->sb;
- unsigned int sector_size = super->sector_size;
- unsigned int written = 0;
-
- if (posix_memalign(&buf, MAX_SECTOR_SIZE, MAX_SECTOR_SIZE) != 0)
- return 1;
-
- if (!get_dev_size(from, NULL, &dsize))
- goto err;
-
- if (lseek64(from, dsize-(2*sector_size), 0) < 0)
- goto err;
- if ((unsigned int)read(from, buf, sector_size) != sector_size)
- goto err;
- sb = buf;
- if (strncmp((char*)sb->sig, MPB_SIGNATURE, MPB_SIG_LEN) != 0)
- goto err;
-
- sectors = mpb_sectors(sb, sector_size) + 2;
- offset = dsize - sectors * sector_size;
- if (lseek64(from, offset, 0) < 0 ||
- lseek64(to, offset, 0) < 0)
- goto err;
- while (written < sectors * sector_size) {
- int n = sectors*sector_size - written;
- if (n > 4096)
- n = 4096;
- if (read(from, buf, n) != n)
- goto err;
- if (write(to, buf, n) != n)
- goto err;
- written += n;
- }
- free(buf);
- return 0;
-err:
- free(buf);
- return 1;
-}
-
static void detail_super_imsm(struct supertype *st, char *homehost,
char *subarray)
{
@@ -12270,7 +12215,6 @@ struct superswitch super_imsm = {
.reshape_super = imsm_reshape_super,
.manage_reshape = imsm_manage_reshape,
.recover_backup = recover_backup_imsm,
- .copy_metadata = copy_metadata_imsm,
.examine_badblocks = examine_badblocks_imsm,
.match_home = match_home_imsm,
.uuid_from_super= uuid_from_super_imsm,
--
2.25.0
1
0
Hello community,
here is the log from the commit of package open-iscsi for openSUSE:Factory checked in at 2020-03-31 17:31:39
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/open-iscsi (Old)
and /work/SRC/openSUSE:Factory/.open-iscsi.new.3160 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "open-iscsi"
Tue Mar 31 17:31:39 2020 rev:92 rq:788710 version:unknown
Changes:
--------
--- /work/SRC/openSUSE:Factory/open-iscsi/open-iscsi.changes 2020-03-06 21:25:40.325495004 +0100
+++ /work/SRC/openSUSE:Factory/.open-iscsi.new.3160/open-iscsi.changes 2020-03-31 17:31:42.608241682 +0200
@@ -1,0 +2,6 @@
+Thu Mar 26 16:56:38 UTC 2020 - Lee Duncan <lduncan(a)suse.com>
+
+- Update SPEC file to work around issue with installcheck
+ SUSE script. Update the SPEC file while there.
+
+-------------------------------------------------------------------
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Other differences:
------------------
++++++ open-iscsi.spec ++++++
--- /var/tmp/diff_new_pack.KAhK4B/_old 2020-03-31 17:31:44.072242540 +0200
+++ /var/tmp/diff_new_pack.KAhK4B/_new 2020-03-31 17:31:44.080242544 +0200
@@ -25,7 +25,7 @@
Summary: Linux iSCSI Software Initiator
License: GPL-2.0-or-later
Group: Productivity/Networking/Other
-URL: http://www.open-iscsi.com
+URL: https://www.open-iscsi.com
Source: %{name}-2.%{iscsi_minor_release}.%{iscsi_patch_release_suse}.tar.bz2
Patch1: %{name}-SUSE-latest.diff.bz2
BuildRequires: autoconf
@@ -101,6 +101,7 @@
Summary: The iSCSI User-level Library Development Library and Include files
Group: Development/Libraries/C and C++
Requires: %{name} = %{version}
+Conflicts: libopeniscsiusr0_1_0
%description devel
This development package contains the open-iscsi user-level library
1
0
Hello community,
here is the log from the commit of package spice-gtk for openSUSE:Factory checked in at 2020-03-31 17:31:32
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/spice-gtk (Old)
and /work/SRC/openSUSE:Factory/.spice-gtk.new.3160 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "spice-gtk"
Tue Mar 31 17:31:32 2020 rev:47 rq:788587 version:0.38
Changes:
--------
--- /work/SRC/openSUSE:Factory/spice-gtk/spice-gtk.changes 2020-03-25 23:42:02.735969053 +0100
+++ /work/SRC/openSUSE:Factory/.spice-gtk.new.3160/spice-gtk.changes 2020-03-31 17:31:36.608238169 +0200
@@ -1,0 +2,5 @@
+Thu Mar 19 13:39:11 UTC 2020 - Bruce Rogers <brogers(a)suse.com>
+
+- Remove unneeded Recommends for spice-gtk-lang from spec file
+
+-------------------------------------------------------------------
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Other differences:
------------------
++++++ spice-gtk.spec ++++++
--- /var/tmp/diff_new_pack.buDyWt/_old 2020-03-31 17:31:38.424239232 +0200
+++ /var/tmp/diff_new_pack.buDyWt/_new 2020-03-31 17:31:38.424239232 +0200
@@ -72,7 +72,6 @@
BuildRequires: pkgconfig(libdrm)
BuildRequires: pkgconfig(spice-protocol) >= 0.14.1
Requires(pre): permissions
-Recommends: %{name}-lang
BuildRequires: pkgconfig(libcacard) >= 2.5.1
BuildRequires: pkgconfig(liblz4) >= 1.7.3
1
0
Hello community,
here is the log from the commit of package post-build-checks for openSUSE:Factory checked in at 2020-03-31 17:31:30
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/post-build-checks (Old)
and /work/SRC/openSUSE:Factory/.post-build-checks.new.3160 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "post-build-checks"
Tue Mar 31 17:31:30 2020 rev:98 rq:788583 version:84.87+git20200323.45c6eba
Changes:
--------
--- /work/SRC/openSUSE:Factory/post-build-checks/post-build-checks.changes 2020-03-25 23:42:13.319972515 +0100
+++ /work/SRC/openSUSE:Factory/.post-build-checks.new.3160/post-build-checks.changes 2020-03-31 17:31:31.252235032 +0200
@@ -1,0 +2,6 @@
+Mon Mar 23 11:08:48 UTC 2020 - kukuk(a)suse.com
+
+- Update to version 84.87+git20200323.45c6eba:
+ * Don't remove find, gzip and cpio
+
+-------------------------------------------------------------------
Old:
----
post-build-checks-84.87+git20200319.57fe0e2.tar.xz
New:
----
post-build-checks-84.87+git20200323.45c6eba.tar.xz
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Other differences:
------------------
++++++ post-build-checks.spec ++++++
--- /var/tmp/diff_new_pack.D7FJ1x/_old 2020-03-31 17:31:31.980235459 +0200
+++ /var/tmp/diff_new_pack.D7FJ1x/_new 2020-03-31 17:31:31.984235461 +0200
@@ -16,13 +16,13 @@
#
-%define version_unconverted 84.87+git20200319.57fe0e2
+%define version_unconverted 84.87+git20200323.45c6eba
Name: post-build-checks
Summary: post checks for build after rpms have been created
License: GPL-2.0-or-later
Group: Development/Tools/Building
-Version: 84.87+git20200319.57fe0e2
+Version: 84.87+git20200323.45c6eba
Release: 0
PreReq: aaa_base permissions sed
Requires: aaa_base-malloccheck
++++++ _servicedata ++++++
--- /var/tmp/diff_new_pack.D7FJ1x/_old 2020-03-31 17:31:32.020235482 +0200
+++ /var/tmp/diff_new_pack.D7FJ1x/_new 2020-03-31 17:31:32.020235482 +0200
@@ -1,5 +1,5 @@
<servicedata>
<service name="tar_scm">
<param name="url">git://github.com/openSUSE/post-build-checks.git</param>
- <param name="changesrevision">8071190bb97aa9a3ed8f544d69acc7f8e33ebf0d</param></service>
+ <param name="changesrevision">cc927e6a40f1bb818af40f82cab534d97d2f1138</param></service>
</servicedata>
\ No newline at end of file
++++++ post-build-checks-84.87+git20200319.57fe0e2.tar.xz -> post-build-checks-84.87+git20200323.45c6eba.tar.xz ++++++
diff -urN '--exclude=CVS' '--exclude=.cvsignore' '--exclude=.svn' '--exclude=.svnignore' old/post-build-checks-84.87+git20200319.57fe0e2/checks/99-check-remove-rpms new/post-build-checks-84.87+git20200323.45c6eba/checks/99-check-remove-rpms
--- old/post-build-checks-84.87+git20200319.57fe0e2/checks/99-check-remove-rpms 2020-03-19 10:12:28.000000000 +0100
+++ new/post-build-checks-84.87+git20200323.45c6eba/checks/99-check-remove-rpms 2020-03-23 11:48:35.000000000 +0100
@@ -48,6 +48,9 @@
coreutils=`chroot $BUILD_ROOT rpm --qf '%{NAME}\n' -qf /usr/bin/{date,cat,rm,chown}|sort -u`
utillinux=`chroot $BUILD_ROOT rpm --qf '%{NAME}\n' -qf /usr/bin/su|sort -u`
+findutils=`chroot $BUILD_ROOT rpm --qf '%{NAME}\n' -qf /usr/bin/find|sort -u`
+gzip=`chroot $BUILD_ROOT rpm --qf '%{NAME}\n' -qf /usr/bin/gzip|sort -u`
+cpio=`chroot $BUILD_ROOT rpm --qf '%{NAME}\n' -qf /usr/bin/cpio|sort -u`
shell=`chroot $BUILD_ROOT rpm --qf '%{NAME}\n' -qf /usr/bin/sh|sort -u`
for RPM in `reorder "${RPM_FILE_LIST[@]}"`; do
@@ -73,7 +76,7 @@
case ${PKG} in
libgcc*|libgomp*|libstdc++*)
;;
- $coreutils|$utillinux|$shell)
+ $coreutils|$utillinux|$shell|$findutils|$gzip|$cpio)
;;
rpm|rpm-build|rpm-ndb)
;;
1
0
Hello community,
here is the log from the commit of package cmake for openSUSE:Factory checked in at 2020-03-31 17:31:25
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/cmake (Old)
and /work/SRC/openSUSE:Factory/.cmake.new.3160 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "cmake"
Tue Mar 31 17:31:25 2020 rev:171 rq:788575 version:3.17.0
Changes:
--------
--- /work/SRC/openSUSE:Factory/cmake/cmake.changes 2020-02-22 18:59:09.541490620 +0100
+++ /work/SRC/openSUSE:Factory/.cmake.new.3160/cmake.changes 2020-03-31 17:31:29.700234123 +0200
@@ -1,0 +2,27 @@
+Thu Mar 26 11:20:42 UTC 2020 - Simon Lees <sflees(a)suse.de>
+
+- Fix mistake in previous change.
+
+-------------------------------------------------------------------
+Mon Mar 23 09:46:17 UTC 2020 - Simon Lees <sflees(a)suse.de>
+
+- Many Leap packages don't build without -DCMAKE_SKIP_RPATH:BOOL=ON
+ so leave this change to the next major version of Leap / SLE
+
+-------------------------------------------------------------------
+Sun Mar 22 06:18:20 UTC 2020 - Christoph G <foss(a)grueninger.de>
+
+- update to 3.17.0
+ * cmake(1) gained a “Ninja Multi-Config” generator, which
+ can be used to build multiple configurations at once.
+ * cmake(1) gained a “–debug-find” command-line option to
+ enable additional human-readable output on where find
+ commands search.
+ * Target link properties are now transitive over
+ private dependencies on static libraries. See policy “CMP0099”.
+ * cmake(1) gained a “-E rm” command-line tool that can
+ be used to remove directories and files.
+ Full changelog see
+ https://blog.kitware.com/cmake-3-17-0-available-for-download/
+
+-------------------------------------------------------------------
Old:
----
cmake-3.16.2-SHA-256.txt
cmake-3.16.2-SHA-256.txt.asc
cmake-3.16.2.tar.gz
New:
----
cmake-3.17.0-SHA-256.txt
cmake-3.17.0-SHA-256.txt.asc
cmake-3.17.0.tar.gz
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Other differences:
------------------
++++++ cmake.spec ++++++
--- /var/tmp/diff_new_pack.EYk7D8/_old 2020-03-31 17:31:30.620234663 +0200
+++ /var/tmp/diff_new_pack.EYk7D8/_new 2020-03-31 17:31:30.620234663 +0200
@@ -36,9 +36,9 @@
%bcond_with full
%endif
-%define shortversion 3.16
+%define shortversion 3.17
Name: cmake%{?psuffix}
-Version: 3.16.2
+Version: 3.17.0
Release: 0
Summary: Cross-platform make system
License: BSD-3-Clause
++++++ cmake-3.16.2-SHA-256.txt -> cmake-3.17.0-SHA-256.txt ++++++
--- /work/SRC/openSUSE:Factory/cmake/cmake-3.16.2-SHA-256.txt 2020-01-01 14:57:43.637913203 +0100
+++ /work/SRC/openSUSE:Factory/.cmake.new.3160/cmake-3.17.0-SHA-256.txt 2020-03-31 17:31:28.632233498 +0200
@@ -1,10 +1,10 @@
-fbf7b6341b097828cf9d3a5a29e9b9279dda8688be4e2bc497ccba472f820d8b cmake-3.16.2-Darwin-x86_64.dmg
-9612a522f800674b99a816352340f7e07195c96c7d59cee9cd0057269fc439ea cmake-3.16.2-Darwin-x86_64.tar.gz
-0d3e583855322d14002ab7896841af051e221a853d98fd5124dc84fa2f9dcdb6 cmake-3.16.2-Linux-x86_64.sh
-0641046b4c35ac5119cd2f24f16246bfb242b47c89cbad19a9162ccbfb247d47 cmake-3.16.2-Linux-x86_64.tar.gz
-1563919b09a8794a40032619fb6a0b0ddbd3ba74c2125053983061b951f71c00 cmake-3.16.2-win32-x86.msi
-2e9b90dc913a2c49cda19fc09192f09460ce525316a9644251e0c5a0785920d6 cmake-3.16.2-win32-x86.zip
-52c230d229eac9e509321d4d43172af5e9303ecac3cc34a97d9da6094a7c1e7e cmake-3.16.2-win64-x64.msi
-c92f581bfd94718fd0bd18565206e795f2d4eb0347ba41504dfa9447bc1225c4 cmake-3.16.2-win64-x64.zip
-8c09786ec60ca2be354c29829072c38113de9184f29928eb9da8446a5f2ce6a9 cmake-3.16.2.tar.gz
-be25c4eb5e7fad504d555ac5ff0413ed9b46770bcb1b6da577a068ebd5a59dc8 cmake-3.16.2.zip
+3bed01c6535a75725d523785419122f2080f7ce943d2c180f5f3ade644504a44 cmake-3.17.0-Darwin-x86_64.dmg
+8234ffd447001f96646614017c12351ac3ee9f9825f971d10dc6ad4f7b47c391 cmake-3.17.0-Darwin-x86_64.tar.gz
+cf82affa1d497eae372c2412129a2f043f6868517c8a88a7f52d3751d1812eaf cmake-3.17.0-Linux-x86_64.sh
+b44685227b9f9be103e305efa2075a8ccf2415807fbcf1fc192da4d36aacc9f5 cmake-3.17.0-Linux-x86_64.tar.gz
+3780754d9cb80a1a93b4e2d8c21e6157acec7984abdcecd9ead06244ac2fe6ea cmake-3.17.0-win32-x86.msi
+3358e5af555bd720c41fe709b227c8179f661b41f86e1535018b5c6c3feb366a cmake-3.17.0-win32-x86.zip
+25d22d5a1e8a21bb068472c15e1e1bacde34c08bedadf49e1ed1e45464e56efb cmake-3.17.0-win64-x64.msi
+d29ac4cdd10b1c205ff77e23580b89edb5eead10520edbafdba63a69d92b725b cmake-3.17.0-win64-x64.zip
+b74c05b55115eacc4fa2b77a814981dbda05cdc95a53e279fe16b7b272f00847 cmake-3.17.0.tar.gz
+38afa7f27cc6788093158ab92188d9b8c30414de5c08094ed168773019427d5d cmake-3.17.0.zip
++++++ cmake-3.16.2.tar.gz -> cmake-3.17.0.tar.gz ++++++
/work/SRC/openSUSE:Factory/cmake/cmake-3.16.2.tar.gz /work/SRC/openSUSE:Factory/.cmake.new.3160/cmake-3.17.0.tar.gz differ: char 14, line 1
++++++ cmake.macros ++++++
--- /var/tmp/diff_new_pack.EYk7D8/_old 2020-03-31 17:31:30.748234737 +0200
+++ /var/tmp/diff_new_pack.EYk7D8/_new 2020-03-31 17:31:30.748234737 +0200
@@ -34,6 +34,9 @@
%if "%{?_lib}" == "lib64" \
-DLIB_SUFFIX=64 \\\
%endif \
+%if %suse_version <= 1500 \
+ -DCMAKE_SKIP_RPATH:BOOL=ON \\\
+%endif \
-DCMAKE_VERBOSE_MAKEFILE:BOOL=ON \\\
-DBUILD_SHARED_LIBS:BOOL=ON \\\
-DBUILD_STATIC_LIBS:BOOL=OFF \\\
1
0
Hello community,
here is the log from the commit of package xterm for openSUSE:Factory checked in at 2020-03-31 17:31:22
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/xterm (Old)
and /work/SRC/openSUSE:Factory/.xterm.new.3160 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "xterm"
Tue Mar 31 17:31:22 2020 rev:119 rq:788540 version:353
Changes:
--------
--- /work/SRC/openSUSE:Factory/xterm/xterm.changes 2019-07-28 10:17:27.624599733 +0200
+++ /work/SRC/openSUSE:Factory/.xterm.new.3160/xterm.changes 2020-03-31 17:31:22.752230055 +0200
@@ -1,0 +2,130 @@
+Thu Mar 26 12:15:08 UTC 2020 - Marcus Meissner <meissner(a)suse.com>
+
+- Patch #353 - 2020/02/01
+
+ - amend change in patch #352 for button-events to fix a case where some followup events were not processed soon enough (report/patch by Jimmy Aguilar Mena).
+ - handle MappingNotify X event, to improve recovery when switching keyboard configurations using xkbcomp (prompted by discussion with Frank Mosch, Debian #661295). There is more work needed here, possibly in the X libraries.
+ - improve discussion of mouse-mode in ctlseqs.ms (suggested by Igor van den Hoven).
+ - further improve checks for Xft max-advance-width to take into account fonts which use two cells for ambiguous width characters. Also improve the time used for these checks (reports by Yuri Pankov, Frank Mosch).
+ - fix a few spelling errors reported by codespell (report by Jens Schleusener).
+ - modify run-tic.sh to prefer development version of ncurses since changes to terminfo file in patch #345 rely upon bug-fixes in ncurses (prompted by discussion with Will Senn).
+
+- Patch #352 - 2020/01/16
+
+ - adjust fontsize data to handle a minor inconsistency from recent Xft versions (Debian #880407, adapted from patch by Vincent Lefevre).
+ - add a table to the manual page description of forceBoxChars to alert the reader to the special characters aside from “line-drawing” which are drawn directly when this resource is set (Debian #931305).
+ - improve checkXft logic which attempts to detect fonts whose max-advance-width is inconsistent with the actual glyph widths. For some fonts, it is necessary to check additional characters (report/analysis by Jan Engelhardt).
+ - improve configure-checks for X headers and libraries on recent MacOS, which has moved those files under /usr/X11.
+ - improve portability of iconify/deiconify feature by taking into account some window managers which manipulate the EWMH _NET_WM_STATE property, adding/removing _NET_WM_STATE_HIDDEN rather than actually minimizing the window (prompted by discussion with Jörg Breitbart).
+ - improve workaround from patch #287 for the -iconic option when configured with toolbar by postponing the extra request for minimizing the window to the end of menu-initialization.
+ - modify xevents special-case for mouse-events to include button-events so that the meta key by itself can generate button-events (report/analysis by Mattias Engdegård).
+ - amend SGR-stack change from patch #348 to not associate bold attribute with background color (report by Nicholas Marriott).
+ - fix copy/paste error in manual page (patch by Larry Hynes).
+ - add definitions in xterm_io.h so that GNU/Hurd will use posix_openpty (patch by Samuel Thibault).
+ - build-fix in debug-tracing, for esctest.
+ - updated autoconf macros
+ - update config.guess
+
+- Patch #351 - 2019/11/17
+
+ - correct logic in property_to_string for deciding when to fallback from UTF-8 decoding to ISO-8859-1 decoding, broken in xterm #350 (FreeBSD #241961).
+ - add -report-icons to help-message.
+ - improved autoconf macros:
+ - CF_ADD_LIBS: the change to filter out duplicates caused this to append rather than prepend. revise to fix that.
+ - CF_GCC_VERSION and CF_GCC_WARNINGS: move checks to distinguish icc/clang from gcc from the macro which handles the --enable-warnings option, to make this work without-warnings for the inline-checks.
+ - update config.guess, config.sub
+ - correct status in XTGETXRES replies when the resource was not found.
+ - fix some gcc, cppcheck, clang and coverity warnings.
+ - guard call to RequestResize from the struct-notify event handler to prevent recursion in the Xft+buffered workaround in some cases when doing manual resizing rather than resizing via escape sequences (reports by Stefan Assman, Mike Thornburg).
+ - amend the workaround for Xft+buffered blanking by moving the switch to bitmap-fonts to account for differences in font metrics between bitmap- and TrueType-fonts (report by Stefan Assmann).
+ - improve the note on the xterm-rep terminfo entry (prompted by discussion with Sven Joachim).
+
+- Patch #350 - 2019/11/02
+
+ - modify html/svg dump to not ignore zero'd/blank cells.
+ - align terminfo file with ncurses, e.g., add xterm+osc104 block.
+ - improve discussion of modifyOtherKeys in manual page and in ctlseqs.ms.
+ - add vttests/modify-keys.pl script to illustrate the modifyOtherKeys resource (prompted by discussion with Bram Moolenaar).
+ - various improvements to ctlseqs.ms, as part of autogenerating links for the website.
+ - update manual page default for saveLines resource default value (Branden Robinson, Debian #913815).
+ - add command-line option -report-xres to show the values of the VT100 widget X resources when initialization is complete.
+ - add a control sequence which, like tcap-query, allows an application to inspect most X resource settings of the VT100 widget.
+ - adjust some optional features to enable them in the imake configuration as they would be by default via the configure script.
+ - add null-pointer checks to improve error recovery when bitmap fonts are missing or corrupt (report by Jonne Ransijn).
+ - correct the condition for deleting the EWMH window-title property, i.e., if UTF-8 titles are disabled, rather than if an update to the EWHM property found no change (report by Sven Joachim).
+ - build-fix for the case when configure --enable-trace is used without --enable-warnings (report by Sven Joachim).
+ - fix a few minor bugs found with Coverity.
+ - add a check in property_to_string to avoid translating UTF8_STRING or COMPOUND_TEXT into Latin-1 when UTF-8 encoding is active, e.g., when pushing onto the title-stack while switching to the alternate screen.
+ - build-fix for the --disable-doublechars configure option (report by Brian Lindholm).
+
+- Patch #349 - 2019/09/22
+
+ - add graphic context to support bold+italics (patch by Quinn Strahl).
+ - document window properties in the manual page.
+ - improve title-string feature:
+ - if any of allowC1Printable, utf8Title or titleModes hint that an application might send a title-string encoded in UTF-8, check if that is the case, and if it is recodable into ISO-8859-1, use that for the ICCCM-style title.
+ - check if the title given by a control sequence happens to be already encoded in UTF-8, to avoid double-encoding (FreeBSD #240393).
+ - Make sameName resource work for the EWMH titles.
+ - Modify menu-state of utf8Title to be consistent with the utf8 source, i.e., setting the EWMH properties automatically when UTF-8 is active.
+ - reorganize text-drawing to make it possible to investigate using Xft to implement VT100-style double-sized characters. While doing this, made a workaround for apparent Xft bug which loses its drawable state when switching from 132 to 80 columns.
+ - improve font-warning messages by showing which are derived rather than directly from resource settings (suggested by Tomas Korbar). Also filter repeated font-warning messages, to accommodate broken X configurations.
+ - fix an inconsistency between failure to load derived wide font versus failure to load derived wide-bold font (Redhat #1679790). That relies upon the “:unscaled” property which is broken in some distributions (however, recent Debian and the BSDs such as MacOS work).
+ - updated autoconf-252 to check X11R7 include/lib directories found on some older configurations.
+ - set a graphic-context for border when double-buffering is active; to prevent the border color from changing when switching to reverse-video.
+ - build-fix for --disable-ziconbeep, which conflicted with the new double-buffer configuration (report by Brian Lindholm).
+ - fix loop-limit for lookup of fullscreen resource broken in xterm #347 (report by Scott Bertilson).
+
+- Patch #348 - 2019/07/22
+
+ - update window-manager hints when exiting Tek4014 mode (Debian #932569, patch by Jonathan Irwin).
+ - fix a misformatted printf in report-sgr.pl.
+ - add configure check for termios types, to improve compiler-warnings.
+ - ensure that when resetting margins, to also reset DECLRMM. This affects DECCOLM, DECALN (although DEC STD 070 mentions only top/bottom margins), and DECSTR.
+ - corrected order of reset/move when setting DECCOLM, and make it more consistent by always resetting margins, rather than only when the mode is changed (report by James Holderness).
+ - compile-in double-buffer support by default, changing the configure option to set the default resource value for buffered to true or false.
+ - take in account the reverse-video state when computing the filler-color used when clearing the screen in double-buffering configuration.
+ - correct logic for filtering scrollbar-updates when buffered resource is compiled-in but not enabled (report by Paul Lampert).
+ - improve state saved/restored for cursor-save and SGR stack features.
+ - improve description of 1006 and 1005 mouse modes, to avoid implying that they use character-parameters (report by Bryan Christ).
+ - explain in ctlseqs.ms that some of the numeric keypad keys were xterm extensions rather than VT100/VT220 terminal features (prompted by discussion with Thomas Wolff).
+ - explain in ctlseqs.ms how the DEC windowing extension is supported by xterm.
+ - add 28 rectangular editing to the primary response (suggested by Thomas Wolff).
+ - fix a typo, improve wording in ctlseqs.ms (Thomas Wolff).
+ - fix internal column-parameter when SL or SR is used with left/right margins (patch by Thomas Wolff).
+ - fix off-by-one in VT52 graphics character mapping (patch by Thomas Wolff).
+ - use _X_UNUSED, etc., when available as a fallback for GCC_UNUSED, etc., to reduce compiler warnings when building with imake.
+ - update config.sub
+
+- Patch #347 - 2019/06/30
+
+ - fix a few minor bugs found with Coverity.
+ - improve double-buffering for scrollbars combined with scrolled text; add bufferedFPS resource to control the maximum rate of screen updates (report by Mike Thornburg).
+ - improve fixes for DECCRA handling of double-width characters (patch by Martin Hostettler).
+ - improve discussion of ECMA-48's typographical error for SD in ctlseqs.ms (prompted by report by Martin Hostettler).
+ - correct off-by-one in parameter limit-check for DECCRA (report by Martin Hostettler).
+ - modify saveCellData to handle case where double-width character is partially copied; that should be blanked (report/testcase by Thomas Wolff).
+ - add resource buffered to allow enabling/disabling double-buffered mode.
+ - two fixes for the double-buffer configuration, prompted by MacPorts' switch to double-buffering (patch by Mike Thornburg, MacPorts #58313):
+ - ensure that the needSwap flag is set after drawing TrueType text
+ - corrected the drawable-parameter used for the bar-cursor
+ - modify ScrnRefresh to ignore a case where the left/right halves of a double-width character have been set to different video attributes. The attribute to use is in the left-half (report/testcase by Thomas Wolff).
+ - correct a limit-check for DECCRA in case the target lies off-screen (report/testcase by Thomas Wolff).
+ - documentation errata (report by Thomas Wolff).
+ - reset flags including wraparound and reverse-wrap when switching to VT52 mode, while noting that DEC's standard documentation leaves that behavior undefined (report by Thomas Wolff).
+ - ensure that italic font is turned off on hard/soft resets (report by Martin Hostettler).
+ - improve responsiveness to X events while processing HTML or SVG dumps (report by Martin Hostettler).
+ - replace logic in wcwidth.c for detecting double-width characters with binary-search table generated using updated uniset (report by Robert Ross).
+ - add test-driver for wcwidth.c to simplify comparison with system's wcwidth.
+ - ensure that window-manager name comparisons work when active-icon is enabled, since CSI13t uses the window-manager name (report by Glenn Golden, Arch #62818).
+ - trim a stray “experimental” in one of the comments about the tcap-query feature, which has been a supported feature since 2008 (see patch #238).
+
+- Patch #346 - 2019/05/27
+
+ - update description of the “default” setting for the renderFont resource to match the behavior in patch #261 (Debian #862042).
+ - account for internalBorder in useBorderClipping (report by Robert Ross).
+ - update table of unknown-width characters in wcwidth.c based on Unicode 12.1.0 (prompted by discussion with Robert Ross).
+ - improve description of DECSCL versus S7C1T and S8C1T in ctlseqs.ms.
+ - improve consistency between CSI3t and CSI13t, accounting for differences between some window managers' handling of EMWH extents (report by Bram Moolenaar).
+ - fix a sign-extension when reporting offscreen window position (report by Bram Moolenaar).
+
+-------------------------------------------------------------------
Old:
----
xterm-345.tgz
xterm-345.tgz.asc
New:
----
xterm-353.tgz
xterm-353.tgz.asc
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Other differences:
------------------
++++++ xterm.spec ++++++
--- /var/tmp/diff_new_pack.qTqCJ5/_old 2020-03-31 17:31:23.624230566 +0200
+++ /var/tmp/diff_new_pack.qTqCJ5/_new 2020-03-31 17:31:23.628230567 +0200
@@ -1,7 +1,7 @@
#
# spec file for package xterm
#
-# Copyright (c) 2019 SUSE LINUX GmbH, Nuernberg, Germany.
+# Copyright (c) 2020 SUSE LLC
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
@@ -12,19 +12,19 @@
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.
-# Please submit bugfixes or comments via http://bugs.opensuse.org/
+# Please submit bugfixes or comments via https://bugs.opensuse.org/
#
%define splitbin 0%{?suse_version} >= 1300
Name: xterm
-Version: 345
+Version: 353
Release: 0
Summary: The basic X terminal program
License: MIT
Group: System/X11/Utilities
-Url: http://invisible-island.net/xterm/
+URL: http://invisible-island.net/xterm/
Source: ftp://ftp.invisible-island.net/xterm/%{name}-%{version}.tgz
Source1: ftp://ftp.invisible-island.net/xterm/%{name}-%{version}.tgz.asc
Source2: luitx
++++++ xterm-345.tgz -> xterm-353.tgz ++++++
++++ 32697 lines of diff (skipped)
++++++ xterm-double_width_fonts.patch ++++++
--- /var/tmp/diff_new_pack.qTqCJ5/_old 2020-03-31 17:31:23.976230771 +0200
+++ /var/tmp/diff_new_pack.qTqCJ5/_new 2020-03-31 17:31:23.980230774 +0200
@@ -1,20 +1,16 @@
# HG changeset patch
# Parent 682df5267f4b25286ab78bfbbfd91fe664cbbd21
-diff --git a/fontutils.c b/fontutils.c
---- a/fontutils.c
-+++ b/fontutils.c
-@@ -755,77 +755,29 @@ is_double_width_font(XFontStruct *fs)
- {
- return ((2 * fs->min_bounds.width) == fs->max_bounds.width);
- }
- #else
- #define is_double_width_font(fs) 0
+Index: xterm-353/fontutils.c
+===================================================================
+--- xterm-353.orig/fontutils.c
++++ xterm-353/fontutils.c
+@@ -857,67 +857,19 @@ is_double_width_font(XFontStruct *fs)
#endif
#if OPT_WIDE_CHARS && OPT_RENDERFONT && defined(HAVE_TYPE_FCCHAR32)
-#define HALF_WIDTH_TEST_STRING "1234567890"
--
+
-/* '1234567890' in Chinese characters in UTF-8 */
-#define FULL_WIDTH_TEST_STRING "\xe4\xb8\x80\xe4\xba\x8c\xe4\xb8\x89" \
- "\xe5\x9b\x9b\xe4\xba\x94" \
@@ -29,7 +25,6 @@
-
-#define HALF_WIDTH_CHAR1 0x0031 /* '1' */
-#define HALF_WIDTH_CHAR2 0x0057 /* 'W' */
-+
#define FULL_WIDTH_CHAR1 0x4E00 /* CJK Ideograph 'number one' */
#define FULL_WIDTH_CHAR2 0xAC00 /* Korean script syllable 'Ka' */
@@ -84,8 +79,3 @@
}
#else
#define is_double_width_font_xft(dpy, xftfont) 0
- #endif
-
- #define EmptyFont(fs) (fs != 0 \
- && ((fs)->ascent + (fs)->descent == 0 \
- || (fs)->max_bounds.width == 0))
++++++ xterm-enable_libtinfo.patch ++++++
--- /var/tmp/diff_new_pack.qTqCJ5/_old 2020-03-31 17:31:23.988230778 +0200
+++ /var/tmp/diff_new_pack.qTqCJ5/_new 2020-03-31 17:31:23.992230781 +0200
@@ -2,15 +2,11 @@
# Parent d2d03d4f6634a54846af7503711ed356c87b1625
# check for libtinfo before falling back to ncurses
-diff --git a/aclocal.m4 b/aclocal.m4
---- a/aclocal.m4
-+++ b/aclocal.m4
-@@ -802,20 +802,20 @@ if test "$cf_full_tgetent" = yes ; then
- else
- cf_test_message="tgetent"
- fi
-
- AC_CACHE_CHECK(for $cf_test_message function,cf_cv_lib_tgetent,[
+Index: xterm-353/aclocal.m4
+===================================================================
+--- xterm-353.orig/aclocal.m4
++++ xterm-353/aclocal.m4
+@@ -885,10 +885,10 @@ AC_CACHE_CHECK(for $cf_test_message func
cf_save_LIBS="$LIBS"
cf_cv_lib_tgetent=no
if test "$cf_full_tgetent" = yes ; then
@@ -23,25 +19,16 @@
cf_TERMTST="0"
fi
for cf_termlib in '' $cf_TERMLIB ; do
- LIBS="$cf_save_LIBS"
- test -n "$cf_termlib" && { CF_ADD_LIB($cf_termlib) }
- AC_TRY_RUN([
- /* terminfo implementations ignore the buffer argument, making it useless for
- * the xterm application, which uses this information to make a new TERMCAP
-diff --git a/configure b/configure
---- a/configure
-+++ b/configure
-@@ -6141,20 +6141,20 @@ echo "$as_me:6140: checking for $cf_test
- echo $ECHO_N "checking for $cf_test_message function... $ECHO_C" >&6
- if test "${cf_cv_lib_tgetent+set}" = set; then
- echo $ECHO_N "(cached) $ECHO_C" >&6
- else
-
+Index: xterm-353/configure
+===================================================================
+--- xterm-353.orig/configure
++++ xterm-353/configure
+@@ -6449,10 +6449,10 @@ else
cf_save_LIBS="$LIBS"
cf_cv_lib_tgetent=no
if test "$cf_full_tgetent" = yes ; then
- cf_TERMLIB="otermcap termcap termlib ncurses curses"
-+ cf_TERMLIB="otermcap termcap termlib tinfo ncurses curses"
++ cf_TERMLIB="otermcap tinfo termcap termlib ncurses curses"
cf_TERMTST="buffer[0] == 0"
else
- cf_TERMLIB="termlib ncurses curses"
@@ -49,8 +36,3 @@
cf_TERMTST="0"
fi
for cf_termlib in '' $cf_TERMLIB ; do
- LIBS="$cf_save_LIBS"
- test -n "$cf_termlib" && {
- cf_add_libs="-l$cf_termlib"
- # Filter out duplicates - this happens with badly-designed ".pc" files...
- for cf_add_1lib in $LIBS
1
0
Hello community,
here is the log from the commit of package pam for openSUSE:Factory checked in at 2020-03-31 17:31:17
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/pam (Old)
and /work/SRC/openSUSE:Factory/.pam.new.3160 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "pam"
Tue Mar 31 17:31:17 2020 rev:100 rq:788480 version:1.3.1+git20190923.ea78d67
Changes:
--------
--- /work/SRC/openSUSE:Factory/pam/pam.changes 2020-03-18 12:22:25.220085241 +0100
+++ /work/SRC/openSUSE:Factory/.pam.new.3160/pam.changes 2020-03-31 17:31:21.468229303 +0200
@@ -1,0 +2,16 @@
+Tue Mar 24 07:09:55 UTC 2020 - Josef Möllers <josef.moellers(a)suse.com>
+
+- Listed all manual pages seperately as pam_userdb.8 has been moved
+ to pam-extra.
+ Also %exclude %{_defaultdocdir}/pam as the docs are in a separate
+ package.
+ [pam.spec]
+
+-------------------------------------------------------------------
+Mon Mar 16 13:26:27 UTC 2020 - Josef Möllers <josef.moellers(a)suse.com>
+
+- pam_userdb moved to a new package pam-extra as pam-modules
+ is obsolete and not part of SLE.
+ [bsc#1166510, pam.spec]
+
+-------------------------------------------------------------------
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Other differences:
------------------
++++++ pam.spec ++++++
--- /var/tmp/diff_new_pack.OV2Rac/_old 2020-03-31 17:31:22.132229691 +0200
+++ /var/tmp/diff_new_pack.OV2Rac/_new 2020-03-31 17:31:22.136229694 +0200
@@ -82,6 +82,21 @@
allows system administrators to set authentication policies without
having to recompile programs that do authentication.
+%package extra
+Summary: PAM module to authenticate against a separate database
+Group: System/Libraries%description
+BuildRequires: libdb-4_8-devel
+BuildRequires: pam-devel
+
+%description extra
+PAM (Pluggable Authentication Modules) is a system security tool that
+allows system administrators to set authentication policies without
+having to recompile programs that do authentication.
+
+This package contains useful extra modules eg pam_userdb which is
+used to verify a username/password pair against values stored in
+a Berkeley DB database.
+
%package doc
Summary: Documentation for Pluggable Authentication Modules
Group: Documentation/HTML
@@ -224,11 +239,11 @@
done
%files -f Linux-PAM.lang
+%exclude %{_defaultdocdir}/pam
%dir %{_sysconfdir}/pam.d
%dir %{_distconfdir}/pam.d
%dir %{_sysconfdir}/security
%dir %{_sysconfdir}/security/limits.d
-%dir %{_defaultdocdir}/pam
%if %{defined config_noreplace}
%config(noreplace) %{_sysconfdir}/pam.d/other
%config(noreplace) %{_sysconfdir}/pam.d/common-*
@@ -255,7 +270,54 @@
%{_mandir}/man5/environment.5%{?ext_man}
%{_mandir}/man5/*.conf.5%{?ext_man}
%{_mandir}/man5/pam.d.5%{?ext_man}
-%{_mandir}/man8/*
+%{_mandir}/man8/mkhomedir_helper.8.gz
+%{_mandir}/man8/pam.8.gz
+%{_mandir}/man8/PAM.8.gz
+%{_mandir}/man8/pam_access.8.gz
+%{_mandir}/man8/pam_cracklib.8.gz
+%{_mandir}/man8/pam_debug.8.gz
+%{_mandir}/man8/pam_deny.8.gz
+%{_mandir}/man8/pam_echo.8.gz
+%{_mandir}/man8/pam_env.8.gz
+%{_mandir}/man8/pam_exec.8.gz
+%{_mandir}/man8/pam_faildelay.8.gz
+%{_mandir}/man8/pam_filter.8.gz
+%{_mandir}/man8/pam_ftp.8.gz
+%{_mandir}/man8/pam_group.8.gz
+%{_mandir}/man8/pam_issue.8.gz
+%{_mandir}/man8/pam_keyinit.8.gz
+%{_mandir}/man8/pam_lastlog.8.gz
+%{_mandir}/man8/pam_limits.8.gz
+%{_mandir}/man8/pam_listfile.8.gz
+%{_mandir}/man8/pam_localuser.8.gz
+%{_mandir}/man8/pam_loginuid.8.gz
+%{_mandir}/man8/pam_mail.8.gz
+%{_mandir}/man8/pam_mkhomedir.8.gz
+%{_mandir}/man8/pam_motd.8.gz
+%{_mandir}/man8/pam_namespace.8.gz
+%{_mandir}/man8/pam_nologin.8.gz
+%{_mandir}/man8/pam_permit.8.gz
+%{_mandir}/man8/pam_pwhistory.8.gz
+%{_mandir}/man8/pam_rhosts.8.gz
+%{_mandir}/man8/pam_rootok.8.gz
+%{_mandir}/man8/pam_securetty.8.gz
+%{_mandir}/man8/pam_selinux.8.gz
+%{_mandir}/man8/pam_sepermit.8.gz
+%{_mandir}/man8/pam_shells.8.gz
+%{_mandir}/man8/pam_succeed_if.8.gz
+%{_mandir}/man8/pam_tally2.8.gz
+%{_mandir}/man8/pam_time.8.gz
+%{_mandir}/man8/pam_timestamp.8.gz
+%{_mandir}/man8/pam_timestamp_check.8.gz
+%{_mandir}/man8/pam_tty_audit.8.gz
+%{_mandir}/man8/pam_umask.8.gz
+%{_mandir}/man8/pam_unix.8.gz
+%{_mandir}/man8/pam_warn.8.gz
+%{_mandir}/man8/pam_wheel.8.gz
+%{_mandir}/man8/pam_xauth.8.gz
+%{_mandir}/man8/unix_chkpwd.8.gz
+%{_mandir}/man8/unix2_chkpwd.8.gz
+%{_mandir}/man8/unix_update.8.gz
/%{_lib}/libpam.so.0
/%{_lib}/libpam.so.%{libpam_so_version}
/%{_lib}/libpamc.so.0
@@ -320,6 +382,11 @@
%verify(not mode) %attr(4755,root,shadow) /sbin/unix2_chkpwd
%attr(0700,root,root) /sbin/unix_update
+%files extra
+%defattr(-,root,root,755)
+%attr(755,root,root) /%{_lib}/security/pam_userdb.so
+%attr(644,root,root) %doc %{_mandir}/man8/pam_userdb.8.gz
+
%files doc
%defattr(644,root,root,755)
%dir %{_defaultdocdir}/pam
1
0
Hello community,
here is the log from the commit of package libwacom for openSUSE:Factory checked in at 2020-03-31 17:31:15
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Comparing /work/SRC/openSUSE:Factory/libwacom (Old)
and /work/SRC/openSUSE:Factory/.libwacom.new.3160 (New)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "libwacom"
Tue Mar 31 17:31:15 2020 rev:29 rq:788382 version:1.3
Changes:
--------
--- /work/SRC/openSUSE:Factory/libwacom/libwacom.changes 2019-12-02 11:28:53.082628336 +0100
+++ /work/SRC/openSUSE:Factory/.libwacom.new.3160/libwacom.changes 2020-03-31 17:31:16.980226674 +0200
@@ -1,0 +2,8 @@
+Thu Mar 26 02:11:22 UTC 2020 - Stasiek Michalski <stasiek(a)michalski.cc>
+
+- Update to 1.3
+- Add a dependency on doxygen
+- Remove 174.patch
+ + The changes were merged upstream
+
+-------------------------------------------------------------------
Old:
----
174.patch
libwacom-1.1.tar.bz2
libwacom-1.1.tar.bz2.sig
New:
----
libwacom-1.3.tar.bz2
libwacom-1.3.tar.bz2.sig
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Other differences:
------------------
++++++ libwacom.spec ++++++
--- /var/tmp/diff_new_pack.kFVAls/_old 2020-03-31 17:31:17.672227080 +0200
+++ /var/tmp/diff_new_pack.kFVAls/_new 2020-03-31 17:31:17.676227082 +0200
@@ -22,7 +22,7 @@
%bcond_with meson
%endif
Name: libwacom
-Version: 1.1
+Version: 1.3
Release: 0
Summary: Library to identify wacom tablets
License: MIT
@@ -32,7 +32,6 @@
Source2: https://github.com/linuxwacom/libwacom/releases/download/%{name}-%{version}…
Source3: %{name}.keyring
Source99: baselibs.conf
-Patch0: https://patch-diff.githubusercontent.com/raw/linuxwacom/libwacom/pull/174.p…
%if %{with meson}
BuildRequires: meson >= 0.47.0
%endif
@@ -40,6 +39,7 @@
BuildRequires: pkgconfig(glib-2.0)
BuildRequires: pkgconfig(gudev-1.0)
BuildRequires: pkgconfig(libxml-2.0)
+BuildRequires: doxygen
%description
libwacom is a library to identify wacom tablets and their model-specific
@@ -86,7 +86,6 @@
%prep
%setup -q
-%patch0 -p1
%build
%if %{with meson}
++++++ libwacom-1.1.tar.bz2 -> libwacom-1.3.tar.bz2 ++++++
++++ 4463 lines of diff (skipped)
1
0