]> git.ipfire.org Git - thirdparty/util-linux.git/log
thirdparty/util-linux.git
5 years agolibblkid: improve identification of ISO9660 partition
Daniel Drake [Mon, 16 Dec 2019 06:16:48 +0000 (14:16 +0800)] 
libblkid: improve identification of ISO9660 partition

Recent changes to the iso9660 handler attempt to better handle the case
where the media has both an ordinary ISO9660 filesystem, and a partition
table with a partition entry pointing at the ISO9660 filesystem.

Rather than assuming the presence of a partition table means that there
is an ISO9660 partition, check that such a partition exists before
deciding upon which device the metadata should be presented. One real
world example of this is the grub-mkrescue image format; add a unit test
to cover that.

Secondly, even if we find an appropriate entry in the partition table,
verify that we actually have a device that corresponds to the partition
where we would then proceed to expose this metadata. In the case of a
CD/DVD (i.e. /dev/sr0) we would not normally expect to see devices
corresponding to the partitions, in that case the ISO metadata should be
presented on the whole disk (/dev/sr0).

Fixes: 7ef86a0891 ("libblkid: improve handling of ISO files with partition tables")
Link: https://bugzilla.redhat.com/show_bug.cgi?id=1783066
Signed-off-by: Daniel Drake <drake@endlessm.com>
5 years agoisosize: move ISO size functions into a shared header
Daniel Drake [Mon, 16 Dec 2019 05:48:56 +0000 (13:48 +0800)] 
isosize: move ISO size functions into a shared header

Move the helper functions that parse ISO data & sector size info into
a separate, shared header.

These will addtionally be used by libblkid's iso9660 parser.

Signed-off-by: Daniel Drake <drake@endlessm.com>
5 years agoMerge branch 'release-prep' of https://github.com/kerolasa/util-linux
Karel Zak [Thu, 12 Dec 2019 11:39:18 +0000 (12:39 +0100)] 
Merge branch 'release-prep' of https://github.com/kerolasa/util-linux

5 years agoagetty: return proper value if compiled without ISSUEDIR support
Patrick Steinhardt [Wed, 11 Dec 2019 13:44:22 +0000 (14:44 +0100)] 
agetty: return proper value if compiled without ISSUEDIR support

If agetty is compiled without support for ISSUEDIR, then it implements
a stub for `issuedir_read` that simply does nothing. In fact it does
too little, as it doesn't have a proper return statement even though the
function returns an integer.

Fix the issue by always returning `1` from `issuedir_read`. This
is the same error code that the real implementation of that function
returns in case it cannot open the directory and is thus a sensible
default to pretend that the directory doesn't exist.

Signed-off-by: Patrick Steinhardt <ps@pks.im>
5 years agoscript: fix typos [codespell]
Sami Kerola [Wed, 11 Dec 2019 19:50:06 +0000 (19:50 +0000)] 
script: fix typos [codespell]

Signed-off-by: Sami Kerola <kerolasa@iki.fi>
5 years agoman: improve script and scriptreplay formatting style
Sami Kerola [Wed, 11 Dec 2019 19:36:26 +0000 (19:36 +0000)] 
man: improve script and scriptreplay formatting style

Signed-off-by: Sami Kerola <kerolasa@iki.fi>
5 years agobash-completion: update script, scriptlive, and scriptreplay files
Sami Kerola [Wed, 11 Dec 2019 19:19:21 +0000 (19:19 +0000)] 
bash-completion: update script, scriptlive, and scriptreplay files

Signed-off-by: Sami Kerola <kerolasa@iki.fi>
5 years agobuild-sys: make scriptlive optional
Samuel Thibault [Wed, 11 Dec 2019 12:24:25 +0000 (13:24 +0100)] 
build-sys: make scriptlive optional

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agobuild-sys: release++ (v2.35-rc1) v2.35-rc1
Karel Zak [Wed, 11 Dec 2019 09:55:14 +0000 (10:55 +0100)] 
build-sys: release++ (v2.35-rc1)

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agodocs: add v2.35-ReleaseNotes
Karel Zak [Wed, 11 Dec 2019 09:52:51 +0000 (10:52 +0100)] 
docs: add v2.35-ReleaseNotes

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoMerge branch 'dmverity_options' of https://github.com/bluca/util-linux
Karel Zak [Tue, 10 Dec 2019 13:46:13 +0000 (14:46 +0100)] 
Merge branch 'dmverity_options' of https://github.com/bluca/util-linux

* 'dmverity_options' of https://github.com/bluca/util-linux:
  verity: add support for Forward Error Correction options
  verity: ensure that hash_device and root_hash[_file] are passed together or not at all
  verity: add new verity.roothashfile option

5 years agodocs: update AUTHORS file
Karel Zak [Tue, 10 Dec 2019 13:08:26 +0000 (14:08 +0100)] 
docs: update AUTHORS file

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agopo: merge changes
Karel Zak [Tue, 10 Dec 2019 13:04:50 +0000 (14:04 +0100)] 
po: merge changes

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agopo: add pt.po (from translationproject.org)
Pedro Albuquerque [Tue, 10 Dec 2019 12:57:19 +0000 (13:57 +0100)] 
po: add pt.po (from translationproject.org)

5 years agopo: update zh_CN.po (from translationproject.org)
Boyuan Yang [Tue, 10 Dec 2019 12:57:19 +0000 (13:57 +0100)] 
po: update zh_CN.po (from translationproject.org)

5 years agopo: update ja.po (from translationproject.org)
Takeshi Hamasaki [Tue, 10 Dec 2019 12:57:19 +0000 (13:57 +0100)] 
po: update ja.po (from translationproject.org)

5 years agopo: update de.po (from translationproject.org)
Mario Blättermann [Tue, 10 Dec 2019 12:57:19 +0000 (13:57 +0100)] 
po: update de.po (from translationproject.org)

5 years agoverity: add support for Forward Error Correction options
Luca Boccassi [Tue, 10 Dec 2019 12:26:07 +0000 (12:26 +0000)] 
verity: add support for Forward Error Correction options

Requires kernel built with CONFIG_DM_VERITY_FEC.

5 years agoverity: ensure that hash_device and root_hash[_file] are passed together or not at all
Luca Boccassi [Tue, 10 Dec 2019 11:21:43 +0000 (11:21 +0000)] 
verity: ensure that hash_device and root_hash[_file] are passed together or not at all

If a hash device or a roothash are passed for verity usage, both have to be present
or we cannot use them. Make it an error to pass only one of them.

5 years agoverity: add new verity.roothashfile option
Luca Boccassi [Tue, 10 Dec 2019 11:18:09 +0000 (11:18 +0000)] 
verity: add new verity.roothashfile option

Allow users to point mount to a file to read the roothash, in addition
to passing it inline.
Allows a volume managed by a systemd mount unit to be updated without
changing the mount unit content itself, for easier and more user friendly
servicing.

5 years agobuild-sys: remove duplicate includes
Karel Zak [Tue, 10 Dec 2019 12:50:18 +0000 (13:50 +0100)] 
build-sys: remove duplicate includes

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agobuild-sys: add missing header
Karel Zak [Tue, 10 Dec 2019 11:31:59 +0000 (12:31 +0100)] 
build-sys: add missing header

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agokill: add another ifdef
Karel Zak [Tue, 10 Dec 2019 10:07:30 +0000 (11:07 +0100)] 
kill: add another ifdef

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agokill: add missing ifdefs
Karel Zak [Mon, 9 Dec 2019 15:20:06 +0000 (16:20 +0100)] 
kill: add missing ifdefs

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoscript: document SIGUSR1
Karel Zak [Mon, 9 Dec 2019 15:10:02 +0000 (16:10 +0100)] 
script: document SIGUSR1

Based on pull request: https://github.com/karelzak/util-linux/pull/815

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoscript: listen to SIGUSR1, flush logs on the signal
Karel Zak [Mon, 9 Dec 2019 15:04:18 +0000 (16:04 +0100)] 
script: listen to SIGUSR1, flush logs on the signal

Based on pull request: https://github.com/karelzak/util-linux/pull/815

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agokill: deallocate follow_ups [assan]
Karel Zak [Mon, 9 Dec 2019 12:20:04 +0000 (13:20 +0100)] 
kill: deallocate follow_ups [assan]

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agokill: make man page more informative about --timeout
Karel Zak [Mon, 9 Dec 2019 12:11:16 +0000 (13:11 +0100)] 
kill: make man page more informative about --timeout

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agokill: report features on -V, add lish_header initialization
Karel Zak [Mon, 9 Dec 2019 11:40:53 +0000 (12:40 +0100)] 
kill: report features on -V, add lish_header initialization

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoinclude/pidfd-utils: small cleanup
Karel Zak [Mon, 9 Dec 2019 11:22:31 +0000 (12:22 +0100)] 
include/pidfd-utils: small cleanup

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoMerge branch 'kill-pidfd' of https://github.com/kerolasa/util-linux
Karel Zak [Mon, 9 Dec 2019 11:20:22 +0000 (12:20 +0100)] 
Merge branch 'kill-pidfd' of https://github.com/kerolasa/util-linux

* 'kill-pidfd' of https://github.com/kerolasa/util-linux:
  kill: use pidfd system calls to implement --timeout option
  build-sys: add missing NR underscore to UL_CHECK_SYSCALL()

5 years agoMerge branch 'make-manpage-of-su-clearer' of https://github.com/your-diary/util-linux
Karel Zak [Mon, 9 Dec 2019 11:18:38 +0000 (12:18 +0100)] 
Merge branch 'make-manpage-of-su-clearer' of https://github.com/your-diary/util-linux

* 'make-manpage-of-su-clearer' of https://github.com/your-diary/util-linux:
  Slight change in terms
  Make the manpage of su clearer

5 years agolib/randutils: re-licensing back to BSD
Karel Zak [Mon, 9 Dec 2019 10:30:55 +0000 (11:30 +0100)] 
lib/randutils: re-licensing back to BSD

The file is originally from libuuid, this library is under BSD
licence. Unfortunately, I have added LGPL header by accident to the
file (commit 0f23ee0c855d686b0c315af2c96b8835134cd9e3).

The file under LGPL was modified (in relevant way) by Sami,
Christopher and me. We all agree with re-licensing back to BSD.

Signed-off-by: Sami Kerola <kerolasa@iki.fi>
Signed-off-by: Christopher James Halse Rogers <chris@cooperteam.net>
Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoSlight change in terms
Manatsu Takahashi [Sun, 8 Dec 2019 13:26:26 +0000 (22:26 +0900)] 
Slight change in terms

5 years agoMake the manpage of su clearer
Manatsu Takahashi [Sun, 8 Dec 2019 13:20:53 +0000 (22:20 +0900)] 
Make the manpage of su clearer

5 years agodocs: Fix adjtime documentation
Pierre Labastie [Fri, 6 Dec 2019 11:50:46 +0000 (12:50 +0100)] 
docs: Fix adjtime documentation

The first line of the adjtime file is made of three numbers (see=20
hwclock.c):
- a drift factor as a decimal float
- the time of last adjust as a decimal integer
- a zero (for compatibility) as a decimal float.

but both man pages (hwclock.8 and adj_time.5) tell that the third
number is a decimal integer.

Of course this is harmless if somebody edits the adjtime file with
"0"=20 as the third number: it will be correctly read by hwclock
anyway.  But if for some reason, a program reads the adjtime file and
expects an integer, it will fail, because hwclock writes O.OOOO0O as
the third=20 number.

Signed-off-by:: Pierre Labastie <pierre.labastie@neuf.fr>
Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agosu: silence a useless warning
Jouke Witteveen [Fri, 6 Dec 2019 10:06:03 +0000 (11:06 +0100)] 
su: silence a useless warning

When the requested shell matches the restricted shell, there is no reason
to issue a warning, since we will be doing precisely as requested.

Signed-off-by: Jouke Witteveen <j.witteveen@gmail.com>
5 years agomount: add verity example to man page
Karel Zak [Thu, 5 Dec 2019 14:32:23 +0000 (15:32 +0100)] 
mount: add verity example to man page

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agobuild-sys: add --with-cryptsetup to config-gen.d/all.conf
Karel Zak [Thu, 5 Dec 2019 13:57:50 +0000 (14:57 +0100)] 
build-sys: add --with-cryptsetup to config-gen.d/all.conf

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibmount: add verity to mount -V output
Karel Zak [Thu, 5 Dec 2019 13:57:29 +0000 (14:57 +0100)] 
libmount: add verity to mount -V output

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agomount: (dm-verity) update man page
Karel Zak [Thu, 5 Dec 2019 12:40:42 +0000 (13:40 +0100)] 
mount: (dm-verity) update man page

* move to separate section (like we use for LOOP DEVICE support)
* explain what dm-verity + mount(8) does

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoMerge branch 'dmverity' of https://github.com/bluca/util-linux
Karel Zak [Thu, 5 Dec 2019 12:23:46 +0000 (13:23 +0100)] 
Merge branch 'dmverity' of https://github.com/bluca/util-linux

* 'dmverity' of https://github.com/bluca/util-linux:
  libmount: add support for verity devices via libcryptsetup

5 years agolibmount: add support for verity devices via libcryptsetup
Luca Boccassi [Fri, 8 Nov 2019 17:02:09 +0000 (17:02 +0000)] 
libmount: add support for verity devices via libcryptsetup

The following new options are added:

verity.hashdevice
verity.roothash
verity.hashoffset

The source path will be used as a dm-verity object, and will be
opened using libcryptsetup APIs.

A new --with-cryptsetup build-time option is added, which adds a
dependency on libcryptsetup. To ease bootstrapping, given libcryptsetup
build-depends on util-linux for libuuid, if --with-cryptsetup=yes but
libcryptsetup is not installed only a warning will be printed at
configure time rather than an error. This way stage0/first stage/ring0
builds can use the same configure options but avoid installing
cryptsetup to get a working base set, and then rebuild util-linux in
the next step of the boostrapping process.

If verity options are selected but cannot be fullfilled due to lack of
dependencies, mounting a volume will fail even if using a loop device
would work as a fallback, to avoid silently skipping integrity checks.

5 years agolsblk: add PARTTYPENAME column
Karel Zak [Wed, 4 Dec 2019 11:38:57 +0000 (12:38 +0100)] 
lsblk: add PARTTYPENAME column

Print also partition type in human-readable way.

Addresses: https://bugzilla.redhat.com/show_bug.cgi?id=1777261
Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibfdisk: move GPT partition types to include/
Karel Zak [Wed, 4 Dec 2019 11:37:22 +0000 (12:37 +0100)] 
libfdisk: move GPT partition types to include/

We need the array use in another tools too. Let's follow the way we
use for MBR and keep it in include/.

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoMerge branch 'mount-eperm'
Karel Zak [Tue, 3 Dec 2019 14:23:53 +0000 (15:23 +0100)] 
Merge branch 'mount-eperm'

* mount-eperm:
  mount: no exit on EPERM, continue without suid

5 years agounshare: cleanup capabilities code [lgtm scan]
Karel Zak [Tue, 3 Dec 2019 14:15:22 +0000 (15:15 +0100)] 
unshare: cleanup capabilities code [lgtm scan]

- remove C++isms
- remove unnecessary { }
- remove if-if
- remove unnecessary condition

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibfdisk: improve Sun partitions calculation [lgtm scan]
Karel Zak [Tue, 3 Dec 2019 14:07:58 +0000 (15:07 +0100)] 
libfdisk: improve Sun partitions calculation [lgtm scan]

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibblkid: improve MD I/O size calculation [lgtm scan]
Karel Zak [Tue, 3 Dec 2019 13:51:31 +0000 (14:51 +0100)] 
libblkid: improve MD I/O size calculation [lgtm scan]

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibblkid: improve vfat entries calculation [lgtm scan]
Karel Zak [Tue, 3 Dec 2019 13:49:16 +0000 (14:49 +0100)] 
libblkid: improve vfat entries calculation [lgtm scan]

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolscpu: make code more readable [lgtm scan]
Karel Zak [Tue, 3 Dec 2019 13:35:43 +0000 (14:35 +0100)] 
lscpu: make code more readable [lgtm scan]

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibmount: fix typo in mnt_context_prepare_helper() [lgtm scan]
Karel Zak [Tue, 3 Dec 2019 13:31:55 +0000 (14:31 +0100)] 
libmount: fix typo in mnt_context_prepare_helper() [lgtm scan]

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agotests: mark scriptlive as KNOWN_FAILED
Karel Zak [Tue, 26 Nov 2019 08:56:24 +0000 (09:56 +0100)] 
tests: mark scriptlive as KNOWN_FAILED

Not sure why, but on travis-ci the shell output is little bit
different, probably depends on shell version, etc.

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agokill: use pidfd system calls to implement --timeout option
Sami Kerola [Mon, 25 Nov 2019 20:31:20 +0000 (20:31 +0000)] 
kill: use pidfd system calls to implement --timeout option

At times there is need in scripts to send multiple signals to a process.
Often these cases require some amount of waiting before follow-up signal
should be sent.

One common case is process termination, where first script tries to kill
process gracefully but if that does not work SIGKILL is sent.  Functionality
like that is commonly done by periodically checking if signalled pid exist
or not, and if it does another signal is sent possibly to an unrelated
process that reused pid number.  That means polling a pid is prone to a data
race.  Also if the first signal immediately kills the process one polling
interval is lost in sleep.

Another example when multiple signal need to be sent is various daemon
process control situations, such as Upgrading Executable on the Fly (see
reference).  This happens to be the case that inspired change author to make
sequential signaling a little bit easier.

Reference: http://nginx.org/en/docs/control.html#upgrade
Pull-request: https://github.com/karelzak/util-linux/pull/902
Signed-off-by: Sami Kerola <kerolasa@iki.fi>
5 years agobuild-sys: add missing NR underscore to UL_CHECK_SYSCALL()
Sami Kerola [Mon, 25 Nov 2019 20:33:05 +0000 (20:33 +0000)] 
build-sys: add missing NR underscore to UL_CHECK_SYSCALL()

The unistd.h defines system call numbers with two leading underscores.

Signed-off-by: Sami Kerola <kerolasa@iki.fi>
5 years agotests: another prompt fix
Karel Zak [Mon, 25 Nov 2019 13:09:38 +0000 (14:09 +0100)] 
tests: another prompt fix

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agobuild-sys: fix out-of-tree build for hwclock
Karel Zak [Mon, 25 Nov 2019 12:55:18 +0000 (13:55 +0100)] 
build-sys: fix out-of-tree build for hwclock

The file sys-utils/hwclock-parse-date.c is generated from .y and
stored in the build directory and "#include hwclock.h" is interpreted
relatively to the build tree rather than to source tree. We need
explicit -I compiler option to point to $srcdir for hwclock.

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agobash-completion: update for new script tools
Karel Zak [Mon, 25 Nov 2019 11:49:48 +0000 (12:49 +0100)] 
bash-completion: update for new script tools

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoscriptreplay: fix typo
Karel Zak [Mon, 25 Nov 2019 11:49:41 +0000 (12:49 +0100)] 
scriptreplay: fix typo

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoscript: add --echo
Karel Zak [Mon, 25 Nov 2019 11:39:52 +0000 (12:39 +0100)] 
script: add --echo

It some cases it makes sense to disable ECHO flag also when script
used in pipe. This new option allows to keep full control in user's
hands.

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agotests: remove option --posix
Karel Zak [Mon, 25 Nov 2019 09:45:38 +0000 (10:45 +0100)] 
tests: remove option --posix

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agotests: make scriptlive output more portable
Karel Zak [Fri, 22 Nov 2019 13:21:20 +0000 (14:21 +0100)] 
tests: make scriptlive output more portable

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoscriptlive: keep ECHO flag, improve welcome message
Karel Zak [Fri, 22 Nov 2019 13:04:21 +0000 (14:04 +0100)] 
scriptlive: keep ECHO flag, improve welcome message

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agotests: upadet scriptlive output
Karel Zak [Fri, 22 Nov 2019 13:04:11 +0000 (14:04 +0100)] 
tests: upadet scriptlive output

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agotests: add script and scriptlive replay
Karel Zak [Fri, 22 Nov 2019 12:48:54 +0000 (13:48 +0100)] 
tests: add script and scriptlive replay

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoscriptlive: add --command, cleanup shell exec
Karel Zak [Fri, 22 Nov 2019 12:48:29 +0000 (13:48 +0100)] 
scriptlive: add --command, cleanup shell exec

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoscriptlive: terminate session at end of the log
Karel Zak [Fri, 22 Nov 2019 11:34:45 +0000 (12:34 +0100)] 
scriptlive: terminate session at end of the log

We need a proper way how to inform child (shell) that the game is
over. It seems the best is to send EOF to child rather than
immediately break PTY mainloop where we have poll(), because shell can
still produce data etc.

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolib/pty: make sure we not use closed FD
Karel Zak [Fri, 22 Nov 2019 10:56:04 +0000 (11:56 +0100)] 
lib/pty: make sure we not use closed FD

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoscript: fix ECHO use, improve shell exec
Karel Zak [Thu, 21 Nov 2019 11:28:51 +0000 (12:28 +0100)] 
script: fix ECHO use, improve shell exec

For tools like su(1) is ECHO flag unexpected for use-case like

echo 'date' | su - user

but script(1) need the echo to keep input recorded.

The patch also return execlp() use to script(1) code.

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolscpu: top-level DMI function refactoring
Karel Zak [Wed, 20 Nov 2019 10:25:32 +0000 (11:25 +0100)] 
lscpu: top-level DMI function refactoring

Let's keep /dev/mem code together and do not mix it with /sys firmware
stuff.

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agomount: no exit on EPERM, continue without suid
Karel Zak [Tue, 19 Nov 2019 13:58:20 +0000 (14:58 +0100)] 
mount: no exit on EPERM, continue without suid

The current libmount assumes that mount(8) and umount(8) are suid
binaries. For this reason it implements internal rules which
restrict what is allowed for non-root users. Unfortunately, it's
out of reality for some use-cases where root permissions are no
required. Nice example are fuse filesystems.

So, the current situation is to call exit() always when mount, umount or
libmount are unsure with non-root user rights. This patch removes the
exit() call and replaces it with suid permissions drop, after that it
continues as usually. It means after suid-drop all depend on kernel
and no another security rule is used by libmount (simply because any
rule is no more necessary).

Example:

old version:
   $ mount -t fuse.sshfs kzak@192.168.111.1:/home/kzak /home/kzak/mnt
   mount: only root can use "--types" option

new version:
   $ mount -t fuse.sshfs kzak@192.168.111.1:/home/kzak /home/kzak/mnt
   kzak@192.168.111.1's password:

   $ findmnt /home/kzak/mnt
   TARGET         SOURCE                        FSTYPE     OPTIONS
   /home/kzak/mnt kzak@192.168.111.1:/home/kzak fuse.sshfs rw,nosuid,nodev,relatime,user_id=1000,group_id=1000

   $ umount /home/kzak/mnt
   $ echo $?
   0

Note that fuse user umount is supported since v2.34 due to user_id= in
kernel mount table.

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibmount: don't access struct member, use API
Karel Zak [Mon, 18 Nov 2019 15:19:15 +0000 (16:19 +0100)] 
libmount: don't access struct member, use API

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agonologin: silently ignore well known shell command-line options
Sami Kerola [Sun, 17 Nov 2019 08:33:04 +0000 (08:33 +0000)] 
nologin: silently ignore well known shell command-line options

nologin is typically used in /etc/passwd as a shell replacement.  Hence it
is reasonable to ignore well known command-line options silently to avoid
unwanted ugly error messages.

Addresses: https://github.com/karelzak/util-linux/issues/895
Requested-by: Lennart Poettering <lennart@poettering.net>
Signed-off-by: Sami Kerola <kerolasa@iki.fi>
5 years agolsblk: add FSVER to --fs
Karel Zak [Fri, 15 Nov 2019 10:23:44 +0000 (11:23 +0100)] 
lsblk: add FSVER to --fs

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibfdisk: Space before first partition may not be aligned
Evan Green [Tue, 12 Nov 2019 22:17:37 +0000 (14:17 -0800)] 
libfdisk: Space before first partition may not be aligned

libfdisk chooses a grain of 1MB fairly arbitrarily, and this granule
may not be honored by other utilities. GPT disks formatted elsewhere
may have space before the first partition, AND a partition that exists
solely below 1MB. If this occurs, cfdisk ends up adding a free space
region where end < start, resulting in a 16 Exabyte free region.

That's too many exabytes.

This happens because the start gets rounded up to the granule size in
new_freespace() but the end is left alone. The logs show it best:

23274: libfdisk:      CXT: [0x572d878]: initialized:  last=34, grain=2048
23274: libfdisk:      CXT: [0x572d878]: partno=10, start=64
23274: libfdisk:      CXT: [0x572d878]: freespace analyze: partno=10, start=64, end=64
23274: libfdisk:      CXT: [0x572d878]: LBA           34 aligned-up           2048 [grain=2048s]
23274: libfdisk:      CXT: [0x572d878]: LBA           63 aligned-down            0 [grain=2048s]
23274: libfdisk:      CXT: [0x572d878]: LBA           34 aligned-near            0 [grain=2048s]
23274: libfdisk:      CXT: [0x572d878]: 0 in range <2048..0> aligned to 2048
23274: libfdisk:     PART: [0x574bb98]: alloc
23274: libfdisk:      TAB: [0x5749d58]: adding freespace
23274: libfdisk:      TAB: [0x5749d58]: insert entry 0x574bb98 pre=0x574a820 [start=2048, end=63, size=18446744073709549632, freespace  ]

Avoid this by aligning the last value like new_freespace() does.

Signed-off-by: Evan Green <evangreen86@gmail.com>
5 years agolsblk: add FSVER (filesystem version) column
Karel Zak [Tue, 12 Nov 2019 12:55:55 +0000 (13:55 +0100)] 
lsblk: add FSVER (filesystem version) column

Addresses: https://bugzilla.redhat.com/show_bug.cgi?id=1764523
Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoagetty: add --show-issue to review issue output
Karel Zak [Tue, 12 Nov 2019 10:15:38 +0000 (11:15 +0100)] 
agetty: add --show-issue to review issue output

Let's make life easier for admins and allow to review issue file
output on the current terminal without all full agetty execution. Use
case is pretty simple:

 # $EDITOR /etc/issue
 # agetty --show-issue

Addresses: https://github.com/karelzak/util-linux/issues/828
Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agoagetty: add support for /run/issue and /usr/lib/issue
Karel Zak [Tue, 12 Nov 2019 09:10:02 +0000 (10:10 +0100)] 
agetty: add support for /run/issue and /usr/lib/issue

Addresses: https://github.com/karelzak/util-linux/issues/828
Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agobuild-sys: introduce $sysconfstaticdir
Karel Zak [Mon, 11 Nov 2019 12:08:04 +0000 (13:08 +0100)] 
build-sys: introduce $sysconfstaticdir

The current situation is that distros differentiate between:

* host specific configuration -- usually /etc, maintained by admin

* distribution specific (static) configuration -- usually /usr/lib,
  maintained by ditro packages

Unfortunately autotools have clue about $sysconfdir (/etc) only. This
patch introduces $sysconfstaticdir (default $prefix/lib).

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agorenice: fix arguments description in --help
Karel Zak [Fri, 8 Nov 2019 10:32:18 +0000 (11:32 +0100)] 
renice: fix arguments description in --help

The --{pid,pgrp,user} options does not have arguments.

Reported-by: Stephane Chazelas <stephane.chazelas@gmail.com>
Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agorenice: fix --help text
Karel Zak [Fri, 8 Nov 2019 10:22:57 +0000 (11:22 +0100)] 
renice: fix --help text

The option [-n] in the code has no any meaning and the value is used
as priority, not incrementally.

Reported-by: Stephane Chazelas <stephane.chazelas@gmail.com>
Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agofallocate.1: List gfs2 as supporting punch-hole
Andrew Price [Thu, 31 Oct 2019 16:51:44 +0000 (16:51 +0000)] 
fallocate.1: List gfs2 as supporting punch-hole

Signed-off-by: Andrew Price <anprice@redhat.com>
5 years agohwclock: add SPDX-License-Identifier(s)
Karel Zak [Fri, 8 Nov 2019 10:12:13 +0000 (11:12 +0100)] 
hwclock: add SPDX-License-Identifier(s)

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agodocs: add GPLv3 text
Karel Zak [Fri, 8 Nov 2019 10:10:54 +0000 (11:10 +0100)] 
docs: add GPLv3 text

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolib/timeutils: add %Y-%m-%dT%H:%M:%S to parse_timestamp()
Karel Zak [Fri, 8 Nov 2019 09:42:03 +0000 (10:42 +0100)] 
lib/timeutils: add %Y-%m-%dT%H:%M:%S to parse_timestamp()

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolib: add missing license headers
Karel Zak [Fri, 8 Nov 2019 09:40:42 +0000 (10:40 +0100)] 
lib: add missing license headers

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agobuild-sys: .gitignore hwclock-parse-date.c
Karel Zak [Thu, 7 Nov 2019 09:43:46 +0000 (10:43 +0100)] 
build-sys: .gitignore hwclock-parse-date.c

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolib: add missing license headers
Karel Zak [Thu, 7 Nov 2019 08:38:06 +0000 (09:38 +0100)] 
lib: add missing license headers

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agobuild-sys: use parse-date() only for hwclock
Karel Zak [Thu, 7 Nov 2019 08:02:23 +0000 (09:02 +0100)] 
build-sys: use parse-date() only for hwclock

The parse-date.y is used only for hwclock, let's keep it together.
Note that the file (originally from gnulib) has GPLv3 license, so it's
better to make it obvious that we use it really only for hwclock (also
GPL).

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibblkid: open device in nonblock mode.
Michal Suchanek [Mon, 4 Nov 2019 20:23:15 +0000 (21:23 +0100)] 
libblkid: open device in nonblock mode.

When autoclose is set (kernel default but many distributions reverse the
setting) opening a CD-rom device causes the tray to close.

The function of blkid is to report the current state of the device and
not to change it. Hence it should use O_NONBLOCK when opening the
device to avoid closing a CD-rom tray.

blkid is used liberally in scripts so it can potentially interfere with
the user operating the CD-rom hardware.

[kzak@redhat.com: add O_NONBLOCK also to:
                  - wipefs
                  - blkid_new_probe_from_filename()
                  - blkid_evaluate_tag()]

Signed-off-by: Michal Suchanek <msuchanek@suse.de>
Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agotests: commit add missing file
Karel Zak [Tue, 5 Nov 2019 14:42:19 +0000 (15:42 +0100)] 
tests: commit add missing file

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agotests: add mount --all tests
Karel Zak [Tue, 5 Nov 2019 14:14:17 +0000 (15:14 +0100)] 
tests: add mount --all tests

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibmount: make sure optsmode is initialized
Karel Zak [Thu, 31 Oct 2019 12:51:29 +0000 (13:51 +0100)] 
libmount: make sure optsmode is initialized

Since 34333e5244167a8f6385faa350938ed5cb6d5c0a we apply fstab options
manually by mnt_context_apply_fs() on --all. The function does not
work correctly when optsmode is zero.

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agomount: (man) document --target-prefix
Karel Zak [Thu, 31 Oct 2019 11:24:17 +0000 (12:24 +0100)] 
mount: (man) document --target-prefix

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibmount: allow use -o together with --all
Karel Zak [Thu, 31 Oct 2019 11:10:03 +0000 (12:10 +0100)] 
libmount: allow use -o together with --all

For example:
# mount --verbose --all -t xfs -o ro

will mount all all XFS filesystems from fstab, but read-only.

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibmount: move context fs merge to separate function
Karel Zak [Thu, 31 Oct 2019 10:52:17 +0000 (11:52 +0100)] 
libmount: move context fs merge to separate function

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibmount: fix mnt_context_next_remount()
Karel Zak [Thu, 31 Oct 2019 09:34:12 +0000 (10:34 +0100)] 
libmount: fix mnt_context_next_remount()

The current implementation works, but the remount operation is done in
the cloned context and the original context (and calling application)
has no information about the final status/errors. This is mistake.

This new implementation works like mnt_context_next_mount(), it means
the same context (as used by application) is reused for all remounts.
The original setting is restored by mnt_context_apply_template().

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibmount: save current FS setting as template
Karel Zak [Thu, 31 Oct 2019 09:31:53 +0000 (10:31 +0100)] 
libmount: save current FS setting as template

This commit adds new functions to save and reuse the current FS
setting (mount options from command line, etc) after context reset.
It's usable for example in "mount --all" when we use the same context
for more times for more mount operations.

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibfdisk: consolidate strdup() use
Karel Zak [Wed, 23 Oct 2019 11:00:40 +0000 (13:00 +0200)] 
libfdisk: consolidate strdup() use

Signed-off-by: Karel Zak <kzak@redhat.com>
5 years agolibmount: use strdup_between_structs()
Karel Zak [Wed, 23 Oct 2019 10:30:19 +0000 (12:30 +0200)] 
libmount: use strdup_between_structs()

Signed-off-by: Karel Zak <kzak@redhat.com>