]> git.ipfire.org Git - thirdparty/util-linux.git/log
thirdparty/util-linux.git
7 weeks agonsenter: Support specifying namespace by ID
Xiao Liang [Sat, 14 Feb 2026 03:23:42 +0000 (11:23 +0800)] 
nsenter: Support specifying namespace by ID

Linux kernel v6.19 introduces listns() syscall that lists namespace IDs,
as well as the support for opening an nsfile by a file_handle of ns ID.

This patch allows specifying namespaces by ID for nsenter. For example:

  # nsenter --net=:7

enters init net namespace (7 for NET_NS_INIT_ID).

In the rare case that a ns file name starts with a colon, prepend "./"
for disambiguation.

Signed-off-by: Xiao Liang <shaw.leon@gmail.com>
7 weeks agolsblk: improve error reporting for invalid device paths
Sina Abroshan [Sun, 15 Feb 2026 08:34:17 +0000 (12:04 +0330)] 
lsblk: improve error reporting for invalid device paths

Differentiate stat() failures from non-block-device cases,
so users get accurate errno-based error messages.

Signed-off-by: Sina Abroshan <sina.abroshan@gmail.com>
7 weeks agoMerge branch 'master-branch-1' of https://github.com/Leefancy/util-linux
Karel Zak [Tue, 17 Feb 2026 10:17:50 +0000 (11:17 +0100)] 
Merge branch 'master-branch-1' of https://github.com/Leefancy/util-linux

* 'master-branch-1' of https://github.com/Leefancy/util-linux:
  blkdev: Correct zone report size calculation

7 weeks agoblkid: move error checks before JSON output initialization
Karel Zak [Tue, 17 Feb 2026 10:09:09 +0000 (11:09 +0100)] 
blkid: move error checks before JSON output initialization

Move the lowprobe and lookup error checks (missing device and missing
search type) before the JSON writer initialization. This prevents
partial JSON output being written to stdout before errx() terminates
the program.

Addresses: https://github.com/util-linux/util-linux/pull/4036
Signed-off-by: Karel Zak <kzak@redhat.com>
7 weeks agoMerge branch 'master' of https://github.com/aschnell/util-linux
Karel Zak [Tue, 17 Feb 2026 09:56:23 +0000 (10:56 +0100)] 
Merge branch 'master' of https://github.com/aschnell/util-linux

* 'master' of https://github.com/aschnell/util-linux:
  avoid repetitive code
  always use array with name in json output
  updated test case
  include device in json output and use json array when needed

7 weeks agoMerge branch 'PR/prlimit-nofile-error' of https://github.com/karelzak/util-linux...
Karel Zak [Tue, 17 Feb 2026 09:37:02 +0000 (10:37 +0100)] 
Merge branch 'PR/prlimit-nofile-error' of https://github.com/karelzak/util-linux-work

* 'PR/prlimit-nofile-error' of https://github.com/karelzak/util-linux-work:
  prlimit: raise a nicer error message when modifying NOFILE

7 weeks agopager: remove stale pager_redirect() declaration
Karel Zak [Tue, 17 Feb 2026 09:32:15 +0000 (10:32 +0100)] 
pager: remove stale pager_redirect() declaration

The pager_redirect() function was removed in the previous commit,
but its declaration in the header was left behind. Remove it.

Signed-off-by: Karel Zak <kzak@redhat.com>
7 weeks agolib/pager: Drop pager_redirect
Tobias Stoeckmann [Mon, 16 Feb 2026 20:54:24 +0000 (21:54 +0100)] 
lib/pager: Drop pager_redirect

The pager_redirect function was only used in dmesg. Since it is no
longer used there, drop it from lib/pager.c as well.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
7 weeks agodmesg: Keep error messages in parent's stderr
Tobias Stoeckmann [Mon, 16 Feb 2026 20:53:02 +0000 (21:53 +0100)] 
dmesg: Keep error messages in parent's stderr

If dmesg uses a pager, some of its error messages end up in the pager
output. Use the pager only for data that is supposed to be paged and
print error messages before the pager is started or after it is shut
down again.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
7 weeks agoavoid repetitive code
Arvin Schnell [Mon, 16 Feb 2026 15:34:04 +0000 (16:34 +0100)] 
avoid repetitive code

7 weeks agoalways use array with name in json output
Arvin Schnell [Mon, 16 Feb 2026 14:54:11 +0000 (15:54 +0100)] 
always use array with name in json output

7 weeks agoprlimit: raise a nicer error message when modifying NOFILE
Karel Zak [Mon, 16 Feb 2026 13:43:00 +0000 (14:43 +0100)] 
prlimit: raise a nicer error message when modifying NOFILE

When attempting to set RLIMIT_NOFILE to a value exceeding the kernel's
fs.nr_open limit, prlimit(2) returns EPERM. This can mislead users into
thinking they need elevated permissions, even when running as root.

Add a check to detect when the requested NOFILE limit exceeds
fs.nr_open and provide a clear error message indicating the actual
constraint. The check is optional: if /proc/sys/fs/nr_open cannot be
read (e.g., /proc not mounted), the validation is silently skipped to
avoid introducing a hard dependency on /proc.

The nr_open value is cached and read only once per prlimit invocation
for efficiency when setting multiple limits.

Addresses: https://github.com/util-linux/util-linux/issues/4017
Co-authored-by: krajpuro <krajpuro@akamai.com>
Signed-off-by: Karel Zak <kzak@redhat.com>
7 weeks agoMerge branch 'master' of https://github.com/add-uos/util-linux
Karel Zak [Mon, 16 Feb 2026 13:21:32 +0000 (14:21 +0100)] 
Merge branch 'master' of https://github.com/add-uos/util-linux

* 'master' of https://github.com/add-uos/util-linux:
  style: convert tabs to spaces in meson.build

7 weeks agolibuuid: reset initial cont-clock time on service start
Michael Trapp [Tue, 10 Feb 2026 14:39:21 +0000 (15:39 +0100)] 
libuuid: reset initial cont-clock time on service start

When uuidd starts with --cont-clock enabled and reads a stale timestamp
from the state file, the continuous clock logic would apply a backwards
offset (default 2 hours), causing generated UUIDs to have incorrect
timestamps in the past.

Fix this by resetting last_clock_reg to the current time when the saved
timestamp is older than the current clock. This prevents the backwards
offset from being applied at service start.

[kzak@redhat.com: - fix comment, add commit message]

Fixes: https://github.com/util-linux/util-linux/issues/4018
Signed-off-by: Karel Zak <kzak@redhat.com>
7 weeks agoblkzone: make N/A string translatable
Karel Zak [Mon, 16 Feb 2026 12:30:55 +0000 (13:30 +0100)] 
blkzone: make N/A string translatable

The "N/A" string for write pointer should be marked for translation
to support localization, following the pattern used elsewhere in
util-linux (e.g., blockdev.c).

Signed-off-by: Karel Zak <kzak@redhat.com>
7 weeks agoMerge branch 'wilfred/blkzone-report-wptr' of https://github.com/twilfredo/util-linux
Karel Zak [Mon, 16 Feb 2026 12:25:20 +0000 (13:25 +0100)] 
Merge branch 'wilfred/blkzone-report-wptr' of https://github.com/twilfredo/util-linux

* 'wilfred/blkzone-report-wptr' of https://github.com/twilfredo/util-linux:
  blkzone: don't show wptr when zones are full

7 weeks agoMerge branch 'patch-26' of https://github.com/mariobl/util-linux
Karel Zak [Mon, 16 Feb 2026 12:19:01 +0000 (13:19 +0100)] 
Merge branch 'patch-26' of https://github.com/mariobl/util-linux

* 'patch-26' of https://github.com/mariobl/util-linux:
  Fix various typos and markup in man pages
  Fix typo in flock.1.adoc

7 weeks agotests: add tests for column --table-header-as-columns
Karel Zak [Mon, 16 Feb 2026 10:22:12 +0000 (11:22 +0100)] 
tests: add tests for column --table-header-as-columns

Add test coverage for the --table-header-as-columns (-K) option
added in PR #4003.

Tests cover:
- Basic tab-separated input with header line
- CSV input with comma separator
- JSON output with header-derived column names
- Empty column names in header

Addresses: https://github.com/util-linux/util-linux/pull/4003
Signed-off-by: Karel Zak <kzak@redhat.com>
7 weeks agoMerge branch 'feat/3971' of https://github.com/echoechoin/util-linux
Karel Zak [Mon, 16 Feb 2026 10:11:59 +0000 (11:11 +0100)] 
Merge branch 'feat/3971' of https://github.com/echoechoin/util-linux

* 'feat/3971' of https://github.com/echoechoin/util-linux:
  column: add bash-completion for table-header-as-columns
  column: add option '--table-header-as-columns' for using first line as table columns names.

7 weeks agolib/pager: Rename caught_signal to pager_caught_signal
Karel Zak [Mon, 16 Feb 2026 09:45:27 +0000 (10:45 +0100)] 
lib/pager: Rename caught_signal to pager_caught_signal

The variable name caught_signal is too generic. Rename it to
pager_caught_signal to follow the existing naming convention in the
file where pager-related static variables use the pager_ prefix
(pager_process, pager_argv, etc.).

Signed-off-by: Karel Zak <kzak@redhat.com>
7 weeks agoMerge branch 'pager_fd' of https://github.com/stoeckmann/util-linux
Karel Zak [Mon, 16 Feb 2026 09:44:03 +0000 (10:44 +0100)] 
Merge branch 'pager_fd' of https://github.com/stoeckmann/util-linux

* 'pager_fd' of https://github.com/stoeckmann/util-linux:
  lib/pager: Use original stderr in pager_close
  lib/pager: Use pager_open/close for pager_redirect
  lib/pager: Clear potential stdout/stderr errors
  lib/pager: Flush outputs in pager_close
  lib/pager: Improve signal handling in pager_close

7 weeks agoMerge branch 'pager_leak' of https://github.com/stoeckmann/util-linux
Karel Zak [Mon, 16 Feb 2026 09:31:34 +0000 (10:31 +0100)] 
Merge branch 'pager_leak' of https://github.com/stoeckmann/util-linux

* 'pager_leak' of https://github.com/stoeckmann/util-linux:
  lib/pager: Release resources on pager_open error

7 weeks agodmesg: update prepare_buffer() comment
Karel Zak [Mon, 16 Feb 2026 09:18:56 +0000 (10:18 +0100)] 
dmesg: update prepare_buffer() comment

The function was renamed from process_buffer() to prepare_buffer()
and no longer handles printing. Update the comment to reflect that
it only reads and prepares the message buffer.

Signed-off-by: Karel Zak <kzak@redhat.com>
7 weeks agoMerge branch 'dmesg_io_split' of https://github.com/stoeckmann/util-linux
Karel Zak [Mon, 16 Feb 2026 09:16:51 +0000 (10:16 +0100)] 
Merge branch 'dmesg_io_split' of https://github.com/stoeckmann/util-linux

7 weeks agodmesg: improve buffer size error message
Karel Zak [Mon, 16 Feb 2026 09:04:43 +0000 (10:04 +0100)] 
dmesg: improve buffer size error message

Improve the error message when buffer size is too large to include
the maximum allowed size. This helps users understand what the actual
limit is rather than just reporting an invalid value.

Before: invalid buffer size argument: '...'
After: buffer size ... is too large (maximum is ...)

Signed-off-by: Karel Zak <kzak@redhat.com>
7 weeks agoMerge branch 'dmesg32' of https://github.com/stoeckmann/util-linux
Karel Zak [Mon, 16 Feb 2026 09:00:01 +0000 (10:00 +0100)] 
Merge branch 'dmesg32' of https://github.com/stoeckmann/util-linux

* 'dmesg32' of https://github.com/stoeckmann/util-linux:
  dmesg: Fix short memory allocation with 32 bit

7 weeks agoMerge branch 'lsfd--SIOCGSKNS-based-SOCK_NETNS' of https://github.com/masatake/util...
Karel Zak [Mon, 16 Feb 2026 08:58:17 +0000 (09:58 +0100)] 
Merge branch 'lsfd--SIOCGSKNS-based-SOCK_NETNS' of https://github.com/masatake/util-linux

* 'lsfd--SIOCGSKNS-based-SOCK_NETNS' of https://github.com/masatake/util-linux:
  lsfd: fill SOCK.NETNS even when sock_diag netlink can't report sockets
  tests: (test_mkfds:netns) conditionally report EPERM when ioctl(SIOCGSKNS) fails
  tests: (test_mkfd::tcp-bare) new factory creating an unbound/unconnected TCP socket
  lsfd: add inspect_target_fd method to file_class
  lsfd: (refactor) make call_with_foreign_fd reusable
  lsfd: make pidfd for the target process available while collecting fds
  lsfd: (comment) update the description of sock_xinfo::netns_inode
  lsfd: (cosmetic) delete an empty line

8 weeks agoupdated test case
Arvin Schnell [Fri, 13 Feb 2026 11:06:02 +0000 (12:06 +0100)] 
updated test case

8 weeks agoinclude device in json output and use json array when needed
Arvin Schnell [Fri, 13 Feb 2026 10:43:16 +0000 (11:43 +0100)] 
include device in json output and use json array when needed

8 weeks agoblkzone: don't show wptr when zones are full
Wilfred Mallawa [Thu, 12 Feb 2026 03:02:03 +0000 (13:02 +1000)] 
blkzone: don't show wptr when zones are full

blkzone report displays the write pointer when zones are full, however, the
writepointer value is not accurate for full zones as all zone LBAs have been
written. Instead, fix this so that we show "N/A" for the writepointer field
if the zone condition is full.

While we are at it, extend this behavior for convetional zones instead
of displaying 0 for the writepointer.

Signed-off-by: Wilfred Mallawa <wilfred.mallawa@wdc.com>
8 weeks agoFix various typos and markup in man pages
Mario Blättermann [Tue, 10 Feb 2026 13:38:36 +0000 (14:38 +0100)] 
Fix various typos and markup in man pages

8 weeks agoFix typo in flock.1.adoc
Mario Blättermann [Tue, 10 Feb 2026 11:56:32 +0000 (12:56 +0100)] 
Fix typo in flock.1.adoc

2 months agocolumn: add bash-completion for table-header-as-columns
WanBingjiang [Fri, 30 Jan 2026 12:36:57 +0000 (20:36 +0800)] 
column: add bash-completion for table-header-as-columns

2 months agocolumn: add option '--table-header-as-columns' for using first line as table columns...
WanBingjiang [Fri, 30 Jan 2026 09:28:13 +0000 (17:28 +0800)] 
column: add option '--table-header-as-columns' for using first line as table columns names.

2 months agostyle: convert tabs to spaces in meson.build
zhanghongyuan [Wed, 4 Feb 2026 13:42:57 +0000 (21:42 +0800)] 
style: convert tabs to spaces in meson.build

2 months agolib/pager: Use original stderr in pager_close
Tobias Stoeckmann [Wed, 4 Feb 2026 19:46:57 +0000 (20:46 +0100)] 
lib/pager: Use original stderr in pager_close

Having restored stdout/stderr before calling wait_for_pager allows
potential error messages to be printed on terminal instead of being lost
due to an already closed pipe stderr.

Although dup2 closes the target descriptor, make sure that the pipe
is closed even if dup2 fails.

With everything in place, call exit after restoring the original signal
handlers. This way, signals received between wait_for_pager and signal
restoration are processed as well. A race condition exists if multiple
signals are received, which would allow original handlers to be
processed before exit is called, yet the overhead of properly blocking
signals and unblocking them is most likely not worth the effort.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agolib/pager: Use pager_open/close for pager_redirect
Tobias Stoeckmann [Wed, 4 Feb 2026 20:45:48 +0000 (21:45 +0100)] 
lib/pager: Use pager_open/close for pager_redirect

Restore original stdout/stderr for pager_redirect as well to support
atexit handlers of parent which might use these descriptors.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agolib/pager: Release resources on pager_open error
Tobias Stoeckmann [Wed, 4 Feb 2026 20:31:01 +0000 (21:31 +0100)] 
lib/pager: Release resources on pager_open error

If __setup_pager is unable to spawn a new process, close the duplicated
file descriptors on error path. Also, for the sake of completeness,
clear all other fields in pager_process as well.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agolib/pager: Clear potential stdout/stderr errors
Tobias Stoeckmann [Wed, 4 Feb 2026 19:42:59 +0000 (20:42 +0100)] 
lib/pager: Clear potential stdout/stderr errors

Clear stdout/stderr errors which might have occurred in communication
with pager. Since output is flushed and file descriptors replaced, the
information is meaningless.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agolib/pager: Flush outputs in pager_close
Tobias Stoeckmann [Wed, 4 Feb 2026 19:36:48 +0000 (20:36 +0100)] 
lib/pager: Flush outputs in pager_close

Flush all outputs before waiting for child. This allows even outputs
which do not end in a newline to be shown by pager.

More importantly, it avoids output to be printed into original file
descriptors which were meant for pager.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agolib/pager: Improve signal handling in pager_close
Tobias Stoeckmann [Wed, 4 Feb 2026 19:30:18 +0000 (20:30 +0100)] 
lib/pager: Improve signal handling in pager_close

During pager_close execution, incoming signals can have different
effects:

For one, waitpid might be called multiple times. In this case,
stdout/stderr are closed two times, leading to failing system calls.

Also, the original stdout/stderr can be closed by the signal handler
when waitpid succeeded already and dup2 calls were performed. The signal
handler erroneously tries to signal EOF to the child this way.

To fix these issues, only set a flag and perform wait_for_pager exactly
once. If one of these signals is received during the operation, call
_exit to imitate the signal handling behavior as good as possible.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agodmesg: Fix short memory allocation with 32 bit
Tobias Stoeckmann [Wed, 4 Feb 2026 17:01:30 +0000 (18:01 +0100)] 
dmesg: Fix short memory allocation with 32 bit

The buffer size can be specified as 32 bit unsigned int with command
line argument. In read_syslog_buffer, the allocation is increased by 8
bytes. This means that an unsigned integer overflow could occur, leading
to less amount of memory allocated than expected.

Please note that this does not lead to a security issue, just an incomplete
message.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agodmesg: Add release_buffer function
Tobias Stoeckmann [Wed, 4 Feb 2026 18:15:21 +0000 (19:15 +0100)] 
dmesg: Add release_buffer function

The buffer handling is properly split into three functions now:

- prepare_buffer
- print_buffer
- release_buffer

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agodmesg: Split preparing and printing of buffer
Tobias Stoeckmann [Wed, 4 Feb 2026 18:01:13 +0000 (19:01 +0100)] 
dmesg: Split preparing and printing of buffer

Have a strict separation between preparing the buffer and printing
content of buffer. This will help in further changes to more efficiently
prepare output, i.e. pager setup.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agoMerge branch 'pager_exit' of https://github.com/stoeckmann/util-linux
Karel Zak [Wed, 4 Feb 2026 09:50:18 +0000 (10:50 +0100)] 
Merge branch 'pager_exit' of https://github.com/stoeckmann/util-linux

* 'pager_exit' of https://github.com/stoeckmann/util-linux:
  lib/pager: Call _exit in signal handler, not raise

2 months agoMerge branch 'pager_path' of https://github.com/stoeckmann/util-linux
Karel Zak [Wed, 4 Feb 2026 09:49:59 +0000 (10:49 +0100)] 
Merge branch 'pager_path' of https://github.com/stoeckmann/util-linux

* 'pager_path' of https://github.com/stoeckmann/util-linux:
  lib/pager: Do not resolve directories with PATH

2 months agoMerge branch 'pager_sigchld' of https://github.com/stoeckmann/util-linux
Karel Zak [Wed, 4 Feb 2026 09:49:11 +0000 (10:49 +0100)] 
Merge branch 'pager_sigchld' of https://github.com/stoeckmann/util-linux

* 'pager_sigchld' of https://github.com/stoeckmann/util-linux:
  lib/pager: Set SIGCHLD to default handling

2 months agoMerge branch 'dmesg_oob' of https://github.com/stoeckmann/util-linux
Karel Zak [Wed, 4 Feb 2026 09:48:48 +0000 (10:48 +0100)] 
Merge branch 'dmesg_oob' of https://github.com/stoeckmann/util-linux

* 'dmesg_oob' of https://github.com/stoeckmann/util-linux:
  dmesg: Check if file is too large
  dmesg: Only check for newline if input exists
  dmesg: Check input length before calling strtol

2 months agoMerge branch 'zfs-unaligned-sparc' of https://github.com/ixhamza/util-linux
Karel Zak [Wed, 4 Feb 2026 09:42:38 +0000 (10:42 +0100)] 
Merge branch 'zfs-unaligned-sparc' of https://github.com/ixhamza/util-linux

* 'zfs-unaligned-sparc' of https://github.com/ixhamza/util-linux:
  libblkid: zfs: fix unaligned memory access on SPARC

2 months agoMerge branch 'check_test_coverage' of https://github.com/cgoesche/util-linux-fork
Karel Zak [Wed, 4 Feb 2026 08:53:51 +0000 (09:53 +0100)] 
Merge branch 'check_test_coverage' of https://github.com/cgoesche/util-linux-fork

* 'check_test_coverage' of https://github.com/cgoesche/util-linux-fork:
  tests: search for all executable scripts in test subdirs
  build-sys: add a target for tools/testcoverage.sh
  tools: (get-options.sh) refine regex for unsupported programs to avoid false positives
  tools: expand relative paths provided by $top_srcdir for robustness
  tools: helper script to generate a test coverage report
  tools: (get-options.sh) ensure functionality for out-of-tree builds

2 months agolsfd: fill SOCK.NETNS even when sock_diag netlink can't report sockets
Masatake YAMATO [Sat, 29 Nov 2025 22:28:33 +0000 (07:28 +0900)] 
lsfd: fill SOCK.NETNS even when sock_diag netlink can't report sockets

lsfd could not fill SOCK.NETNS when socket netns information was not
available via sock_diag netlink. Although TCP sockets support sock_diag,
unbound/unconnected TCP sockets are not reported there, so SOCK.NETNS
remained empty for them.

lsfd already obtained socket netns information via ioctl(SIOCGSKNS) in
load_fdsk_xinfo(), called from collect_file_symlink(). That information
was only used to enumerate network namespaces on the target system and
was not associated with socket objects. Use it to fill SOCK.NETNS.

Move the netns lookup to sock_class->inspect_target_fd. The new helper
get_netns_from_socket() retrieves the netns inode via ioctl(SIOCGSKNS),
and sock_inspect_target_fd() stores it in sock->netns_inode. Then
sock_fill_column() uses sock->netns_inode for SOCK.NETNS when present.

* lsfd-cmd/sock.h (struct sock::netns_inode): new member
* lsfd-cmd/lsfd.c (collect_file_symlink): stop calling load_fdsk_xinfo()
* lsfd-cmd/sock-xinfo.c (load_fdsk_xinfo_cb): remove
* lsfd-cmd/sock.c: add get_netns_from_socket(), sock_inspect_target_fd()
and wire inspect_target_fd in sock_class; use netns_inode in
sock_fill_column() for SOCK.NETNS
* tests/ts/lsfd/mkfds-tcp-bare: add test case

Signed-off-by: Masatake YAMATO <yamato@redhat.com>
2 months agoMerge branch 'master' of https://github.com/echoechoin/util-linux
Karel Zak [Wed, 4 Feb 2026 08:38:59 +0000 (09:38 +0100)] 
Merge branch 'master' of https://github.com/echoechoin/util-linux

* 'master' of https://github.com/echoechoin/util-linux:
  hexdump: add fetch_more_extents to retrieve all file extents
  hexdump: add FIEMAP-based sparse file optimization

2 months agotests: (test_mkfds:netns) conditionally report EPERM when ioctl(SIOCGSKNS) fails
Masatake YAMATO [Tue, 3 Feb 2026 21:45:43 +0000 (06:45 +0900)] 
tests: (test_mkfds:netns) conditionally report EPERM when ioctl(SIOCGSKNS) fails

Signed-off-by: Masatake YAMATO <yamato@redhat.com>
2 months agotests: (test_mkfd::tcp-bare) new factory creating an unbound/unconnected TCP socket
Masatake YAMATO [Sun, 1 Feb 2026 18:00:07 +0000 (03:00 +0900)] 
tests: (test_mkfd::tcp-bare) new factory creating an unbound/unconnected TCP socket

Signed-off-by: Masatake YAMATO <yamato@redhat.com>
2 months agolsfd: add inspect_target_fd method to file_class
Masatake YAMATO [Mon, 1 Dec 2025 21:19:27 +0000 (06:19 +0900)] 
lsfd: add inspect_target_fd method to file_class

lsfd has mainly used the following information sources:
* stat(2) of readlink(/proc/$pid/fd/$fd),
* values in /proc/$pid/fdinfo/$fd, and
* netlink diag.

The new method adds a new information source, file descriptors
imported from the target process. lsfd uses pidfd_getfd(2) to import
the specified fd from the target process.

In the inspect_target_fd method, the imported file descriptor can be
used freely. For example, you can call ioctl(2) on it to obtain extra
information.

Signed-off-by: Masatake YAMATO <yamato@redhat.com>
2 months agotests: search for all executable scripts in test subdirs
Christian Goeschel Ndjomouo [Thu, 29 Jan 2026 06:47:22 +0000 (01:47 -0500)] 
tests: search for all executable scripts in test subdirs

Instead of looking for scripts that contain ts_init()
look for all executable scripts as some of them contain
helper functions with commands and long options.

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agobuild-sys: add a target for tools/testcoverage.sh
Christian Goeschel Ndjomouo [Thu, 22 Jan 2026 00:13:48 +0000 (19:13 -0500)] 
build-sys: add a target for tools/testcoverage.sh

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agotools: (get-options.sh) refine regex for unsupported programs to avoid false positives
Christian Goeschel Ndjomouo [Sun, 18 Jan 2026 20:15:38 +0000 (15:15 -0500)] 
tools: (get-options.sh) refine regex for unsupported programs to avoid false positives

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agotools: expand relative paths provided by $top_srcdir for robustness
Christian Goeschel Ndjomouo [Thu, 29 Jan 2026 02:42:43 +0000 (21:42 -0500)] 
tools: expand relative paths provided by $top_srcdir for robustness

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agotools: helper script to generate a test coverage report
Christian Goeschel Ndjomouo [Sun, 18 Jan 2026 17:27:23 +0000 (12:27 -0500)] 
tools: helper script to generate a test coverage report

This script uses a heuristic approach to determine an approx.
test coverage of all util-linux tools. It does this by simply
looking at all the test scripts for a given tool and compares
the long options seen in them with all available ones for the
concerned tool. It also reports if a tool is either missing a
test subdirectory in tests/ts or doesn't have any test script
at all.

This script is not necessarily intended to be ran for build
tests but rather for code quality checks and to help util-linux
developers to get a better overview of their testing infrastructure
and plan accordingly for improvements.

It will potentially also help in keeping the tools stable and
detect regressions more efficiently.

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agohexdump: add fetch_more_extents to retrieve all file extents
WanBingjiang [Tue, 3 Feb 2026 01:49:47 +0000 (09:49 +0800)] 
hexdump: add fetch_more_extents to retrieve all file extents

Add fetch_more_extents() so FIEMAP can fetch extents in batches beyond
the initial fixed batch, instead of being limited to FIEMAP_EXTENTS_BATCH
extents only.

2 months agolib/pager: Call _exit in signal handler, not raise
Tobias Stoeckmann [Mon, 2 Feb 2026 20:21:07 +0000 (21:21 +0100)] 
lib/pager: Call _exit in signal handler, not raise

The signals are registered without SA_RESETHAND, which means that the
same signal handler is called over and over again.

This just works because eventually, the waitpid call will fail, leading
to a suppressed error message (because stderr is already closed) and
then an _exit(EXIT_FAILURE) call.

Just call _exit(EXIT_FAILURE) directly to avoid unneeded and failing
system calls.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agolib/pager: Do not resolve directories with PATH
Tobias Stoeckmann [Mon, 2 Feb 2026 19:23:45 +0000 (20:23 +0100)] 
lib/pager: Do not resolve directories with PATH

If PAGER contains any slash in program part, avoid resolving it with
PATH environment variable. Even if it is found there (in a
subdirectory), sh -c won't execute it.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agolib/pager: Set SIGCHLD to default handling
Tobias Stoeckmann [Mon, 2 Feb 2026 19:07:35 +0000 (20:07 +0100)] 
lib/pager: Set SIGCHLD to default handling

If SIGCHLD is ignored, then waitpid might return an error if child
process is already terminated, since zombie process generation would be
blocked.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agodmesg: Check if file is too large
Tobias Stoeckmann [Mon, 2 Feb 2026 18:47:01 +0000 (19:47 +0100)] 
dmesg: Check if file is too large

32 bit systems might encounter a file which is larger than 2 GB. The
current code would silently truncate the input.

Exit with a proper error message instead.

Add the equal check to silence compiler warnings on 64 bit systems.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agodmesg: Only check for newline if input exists
Tobias Stoeckmann [Mon, 2 Feb 2026 18:28:32 +0000 (19:28 +0100)] 
dmesg: Only check for newline if input exists

If a memory mapped file does not end with a newline, do not check for
its existence. Accessing *end would lead to an out of boundary read.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agodmesg: Check input length before calling strtol
Tobias Stoeckmann [Mon, 2 Feb 2026 18:25:56 +0000 (19:25 +0100)] 
dmesg: Check input length before calling strtol

The dmesg input can be a memory mapped file, yet strtol is used to
parse numbers (facility, level, and syslog timestamp).

Make sure that a terminating character exists to stop strtol before
reaching end.

While at it, actually check if terminating character is the one we
were looking for.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agolsfd: (refactor) make call_with_foreign_fd reusable
Masatake YAMATO [Sat, 29 Nov 2025 19:53:24 +0000 (04:53 +0900)] 
lsfd: (refactor) make call_with_foreign_fd reusable

Signed-off-by: Masatake YAMATO <yamato@redhat.com>
2 months agolsfd: make pidfd for the target process available while collecting fds
Masatake YAMATO [Sun, 1 Feb 2026 16:28:17 +0000 (01:28 +0900)] 
lsfd: make pidfd for the target process available while collecting fds

This is a preparation change for adding inspect_target_fd method to
file_class.

Signed-off-by: Masatake YAMATO <yamato@redhat.com>
2 months agolsfd: (comment) update the description of sock_xinfo::netns_inode
Masatake YAMATO [Mon, 2 Feb 2026 17:13:47 +0000 (02:13 +0900)] 
lsfd: (comment) update the description of sock_xinfo::netns_inode

Signed-off-by: Masatake YAMATO <yamato@redhat.com>
2 months agolibblkid: zfs: fix unaligned memory access on SPARC
Ameer Hamza [Mon, 2 Feb 2026 16:16:50 +0000 (21:16 +0500)] 
libblkid: zfs: fix unaligned memory access on SPARC

SPARC requires aligned memory access for uint32_t values. The ZFS code
was directly dereferencing uint32_t pointers that could be unaligned due
to XDR encoding, causing SIGBUS crashes. Introduce copy_be32_to_cpu()
helper using memcpy to safely read from potentially unaligned memory.

Addresses: https://github.com/util-linux/util-linux/issues/4010

Signed-off-by: Ameer Hamza <ahamza@ixsystems.com>
2 months agolsfd: (cosmetic) delete an empty line
Masatake YAMATO [Sun, 25 Jan 2026 23:00:27 +0000 (08:00 +0900)] 
lsfd: (cosmetic) delete an empty line

Signed-off-by: Masatake YAMATO <yamato@redhat.com>
2 months agotools: (get-options.sh) ensure functionality for out-of-tree builds
Christian Goeschel Ndjomouo [Thu, 29 Jan 2026 02:19:33 +0000 (21:19 -0500)] 
tools: (get-options.sh) ensure functionality for out-of-tree builds

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agoMerge PR #3953: waitpid pidfd inode format support
Karel Zak [Mon, 2 Feb 2026 12:54:05 +0000 (13:54 +0100)] 
Merge PR #3953: waitpid pidfd inode format support

Resolved conflicts due to test directory reorganization.
The waitpid test files were already moved to tests/expected/waitpid/
in a previous commit.

Signed-off-by: Karel Zak <kzak@redhat.com>
2 months agoMerge branch 'PR/chfn-version-help' of https://github.com/karelzak/util-linux-work
Karel Zak [Mon, 2 Feb 2026 12:48:41 +0000 (13:48 +0100)] 
Merge branch 'PR/chfn-version-help' of https://github.com/karelzak/util-linux-work

* 'PR/chfn-version-help' of https://github.com/karelzak/util-linux-work:
  chfn: allow --help and --version without login.defs restrictions

2 months agoMerge branch 'tests_convert_to_long_opts' of https://github.com/cgoesche/util-linux...
Karel Zak [Mon, 2 Feb 2026 12:46:44 +0000 (13:46 +0100)] 
Merge branch 'tests_convert_to_long_opts' of https://github.com/cgoesche/util-linux-fork

* 'tests_convert_to_long_opts' of https://github.com/cgoesche/util-linux-fork: (26 commits)
  tests: (waitpid) use long options to improve test coverage report
  tests: use long options globally in test scripts
  tests: (setarch) use long options to improve test coverage report
  tests: (script) use long options to improve test coverage report
  tests: (rev) use long options to improve test coverage report
  tests: (rename) use long options to improve test coverage report
  tests: (mount) use long options to improve test coverage report
  tests: (more) use long options to improve test coverage report
  tests: (lsns) use long options to improve test coverage report
  tests: (lsmem) use long options to improve test coverage report
  tests: (lscpu) use long options to improve test coverage report
  tests: (lsclocks) use long options to improve test coverage report
  tests: (losetup) use long options to improve test coverage report
  tests: (logger) use long options to improve test coverage report
  tests: (ipcs) use long options to improve test coverage report
  tests: (ionice) use long options to improve test coverage report
  tests: (hexdump) use long options to improve test coverage report
  tests: (getopt) use long options to improve test coverage report
  tests: (findmnt) use long options to improve test coverage report
  tests: (fdisk) use long options to improve test coverage report
  ...

2 months agoMerge branch 'issue/3980/hexdump' of https://github.com/echoechoin/util-linux
Karel Zak [Mon, 2 Feb 2026 12:38:18 +0000 (13:38 +0100)] 
Merge branch 'issue/3980/hexdump' of https://github.com/echoechoin/util-linux

* 'issue/3980/hexdump' of https://github.com/echoechoin/util-linux:
  hexdump: fixes Heap-buffer-overflow in rewrite_rules

2 months agoMerge branch 'lib_strutils_incomplete_null_term_check' of https://github.com/cgoesche...
Karel Zak [Mon, 2 Feb 2026 12:33:51 +0000 (13:33 +0100)] 
Merge branch 'lib_strutils_incomplete_null_term_check' of https://github.com/cgoesche/util-linux-fork

* 'lib_strutils_incomplete_null_term_check' of https://github.com/cgoesche/util-linux-fork:
  lib: (strutils.c) fix unchecked lookahead in ul_parse_size()

2 months agoMerge branch 'lsfd--ASSOC-pidfs' of https://github.com/masatake/util-linux
Karel Zak [Mon, 2 Feb 2026 12:28:12 +0000 (13:28 +0100)] 
Merge branch 'lsfd--ASSOC-pidfs' of https://github.com/masatake/util-linux

* 'lsfd--ASSOC-pidfs' of https://github.com/masatake/util-linux:
  lsfd: add new association "pidfs"

2 months agoMerge branch 'mount_manpage_grammar_mistake' of https://github.com/cgoesche/util...
Karel Zak [Mon, 2 Feb 2026 12:22:25 +0000 (13:22 +0100)] 
Merge branch 'mount_manpage_grammar_mistake' of https://github.com/cgoesche/util-linux-fork

* 'mount_manpage_grammar_mistake' of https://github.com/cgoesche/util-linux-fork:
  mount: (manpage) fix minor grammar mistakes

2 months agoMerge branch 'nsenter_manpage_improve' of https://github.com/cgoesche/util-linux...
Karel Zak [Mon, 2 Feb 2026 12:21:46 +0000 (13:21 +0100)] 
Merge branch 'nsenter_manpage_improve' of https://github.com/cgoesche/util-linux-fork

* 'nsenter_manpage_improve' of https://github.com/cgoesche/util-linux-fork:
  nsenter: (manpage) fix minor grammar mistake

2 months agoMerge branch 'column_man_page' of https://github.com/echoechoin/util-linux
Karel Zak [Mon, 2 Feb 2026 12:20:52 +0000 (13:20 +0100)] 
Merge branch 'column_man_page' of https://github.com/echoechoin/util-linux

* 'column_man_page' of https://github.com/echoechoin/util-linux:
  column doc: add missing attrubutes
  column doc: fix incorrect attribute: hidden

2 months agoMerge branch 'getino_man_page_improvements' of https://github.com/cgoesche/util-linux...
Karel Zak [Mon, 2 Feb 2026 12:18:33 +0000 (13:18 +0100)] 
Merge branch 'getino_man_page_improvements' of https://github.com/cgoesche/util-linux-fork

* 'getino_man_page_improvements' of https://github.com/cgoesche/util-linux-fork:
  getino: (manpage) improve grammar and wording

2 months agoMerge branch 'more_column_tests' of https://github.com/cgoesche/util-linux-fork
Karel Zak [Mon, 2 Feb 2026 12:11:11 +0000 (13:11 +0100)] 
Merge branch 'more_column_tests' of https://github.com/cgoesche/util-linux-fork

* 'more_column_tests' of https://github.com/cgoesche/util-linux-fork:
  tests: (column) add more tests

2 months agohexdump: fixes Heap-buffer-overflow in rewrite_rules
WanBingjiang [Mon, 2 Feb 2026 06:55:11 +0000 (14:55 +0800)] 
hexdump: fixes Heap-buffer-overflow in rewrite_rules

2 months agolib: (strutils.c) fix unchecked lookahead in ul_parse_size()
Christian Goeschel Ndjomouo [Mon, 2 Feb 2026 00:15:41 +0000 (19:15 -0500)] 
lib: (strutils.c) fix unchecked lookahead in ul_parse_size()

If the numeric value provided to ul_parse_size() via @str
is a decimal with fractions only containing zeros, the logic
fails to identify the end of the string and goes to the label
'check_suffix' and will do an unchecked lookahead (*p + 1)
that will result in an out-of-bounds read.

This is because the logic only checks for null-termination
when a fraction has been parsed, i.e. a fraction not only
containing zeros.

To fix the issue, we implicitly check for null-termination
when we have finished parsing the fraction.

Reported-by: Yashashree Gund <yash_gund@live.com>
Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agotests: (waitpid) add tests for the pidfd inode format support
Christian Goeschel Ndjomouo [Tue, 27 Jan 2026 00:33:00 +0000 (19:33 -0500)] 
tests: (waitpid) add tests for the pidfd inode format support

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agotests: (waitpid) move waitpid tests to a dedicated subdir
Christian Goeschel Ndjomouo [Tue, 27 Jan 2026 00:28:41 +0000 (19:28 -0500)] 
tests: (waitpid) move waitpid tests to a dedicated subdir

Moving tests for waitpid(1) in tests/ts/misc to its own
subdirectory, namely tests/ts/waitpid, makes it possible
to add more extensive tests without cluttering tests/ts/misc
and makes the directory structure more coherent.

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agowaitpid: (manpage) document the support for the "PID:inode" addressing format
Christian Goeschel Ndjomouo [Wed, 14 Jan 2026 01:37:26 +0000 (20:37 -0500)] 
waitpid: (manpage) document the support for the "PID:inode" addressing format

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agowaitpid: close fd after removal from epoll interest list
Christian Goeschel Ndjomouo [Mon, 12 Jan 2026 18:53:36 +0000 (13:53 -0500)] 
waitpid: close fd after removal from epoll interest list

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agowaitpid: support 'PID:inode' process addressing format
Christian Goeschel Ndjomouo [Wed, 14 Jan 2026 00:42:09 +0000 (19:42 -0500)] 
waitpid: support 'PID:inode' process addressing format

Adding support for the 'PID:inode' format to address a
process ensures that waitpid(1) safely polls the status
of the expected process in a race-free manner. Worthy of
note is that with the addition of the getino(1) command
the aforementioned task becomes trivially simple.

Example:
        waitpid $(getino -p 123456)

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agowaitpid: refactor to improve maintainability
Christian Goeschel Ndjomouo [Wed, 14 Jan 2026 00:02:47 +0000 (19:02 -0500)] 
waitpid: refactor to improve maintainability

This refactor introduces 'struct waitpid_control' which is
used to control the program state, e.g. option flags, to
create context for internal routines that can adapt their
execution flow accordingly. It has as goal to make the code
easier to understand and reduces the scope of variables.

It also adds 'struct process_info' which stores information
on a process, specified by the PID passed on the command line,
such as the PID, process file descriptor and pidfd inode number.

An array of process_info is used to store information on all
specified PIDs on the command line and is used to create the
event poll list that is integral to the waitpid(1) logic.

This refactor lays the ground work to introduce support for
the 'PID:inode' process addressing format.

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agolib: (pidfd-utils) provide a more liberal variant of ul_get_valid_pidfd_or_err()
Christian Goeschel Ndjomouo [Sat, 10 Jan 2026 01:53:00 +0000 (20:53 -0500)] 
lib: (pidfd-utils) provide a more liberal variant of ul_get_valid_pidfd_or_err()

The new function ul_get_valid_pidfd() behaves less opinionated
in an error case and instead of terminating the calling process
it returns an error.

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agolsfd: add new association "pidfs"
Masatake YAMATO [Fri, 30 Jan 2026 20:27:02 +0000 (05:27 +0900)] 
lsfd: add new association "pidfs"

This new association is inspired by the getino command.

Output example:

  $ ./lsfd --pid=1 -Q '(ASSOC == "pidfs")'
  COMMAND PID USER ASSOC  XMODE  TYPE       SOURCE MNTID INODE NAME
  systemd   1 root pidfs ------ pidfd anon_inodefs     5     2 pid=1 comm=systemd nspid=1

Signed-off-by: Masatake YAMATO <yamato@redhat.com>
2 months agonsenter: (manpage) fix minor grammar mistake
Christian Goeschel Ndjomouo [Fri, 30 Jan 2026 18:28:02 +0000 (13:28 -0500)] 
nsenter: (manpage) fix minor grammar mistake

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agomount: (manpage) fix minor grammar mistakes
Christian Goeschel Ndjomouo [Fri, 30 Jan 2026 18:34:17 +0000 (13:34 -0500)] 
mount: (manpage) fix minor grammar mistakes

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agocolumn doc: add missing attrubutes
WanBingjiang [Fri, 30 Jan 2026 13:32:06 +0000 (21:32 +0800)] 
column doc: add missing attrubutes

2 months agocolumn doc: fix incorrect attribute: hidden
WanBingjiang [Fri, 30 Jan 2026 13:22:28 +0000 (21:22 +0800)] 
column doc: fix incorrect attribute: hidden

2 months agohexdump: add FIEMAP-based sparse file optimization
WanBingjiang [Fri, 30 Jan 2026 05:48:24 +0000 (13:48 +0800)] 
hexdump: add FIEMAP-based sparse file optimization

Use Linux FIEMAP ioctl to detect sparse file holes and skip reading
them. This significantly improves performance when dumping large
sparse files by avoiding unnecessary disk I/O for hole regions.

Key changes:
- Add fiemap, in_sparse_hole, and region_end fields to struct hexdump
- Use check_hole() with cached region boundaries to minimize syscalls
- Only skip holes when vflag==DUP to preserve correct "*" output
- Distinguish real sparse holes from duplicate data in regular files

2 months agogetino: (manpage) improve grammar and wording
Christian Goeschel Ndjomouo [Fri, 30 Jan 2026 02:45:10 +0000 (21:45 -0500)] 
getino: (manpage) improve grammar and wording

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>