]> git.ipfire.org Git - thirdparty/util-linux.git/log
thirdparty/util-linux.git
2 months agoMerge branch 'manpages-fix' of https://github.com/mariobl/util-linux
Karel Zak [Mon, 23 Feb 2026 10:03:13 +0000 (11:03 +0100)] 
Merge branch 'manpages-fix' of https://github.com/mariobl/util-linux

* 'manpages-fix' of https://github.com/mariobl/util-linux:
  Fix formatting in getino.1.adoc

2 months agologin: improve comments for signal handling in fork_session()
Karel Zak [Mon, 23 Feb 2026 10:00:20 +0000 (11:00 +0100)] 
login: improve comments for signal handling in fork_session()

Add more detailed comments explaining the signal blocking and
sigsuspend() pattern introduced by the previous commit. The key
insight is that sigsuspend() is the actual wait point where
SIGTERM/SIGHUP are forwarded to the child, while waitpid() with
WNOHANG only performs non-blocking checks for terminated children.

Signed-off-by: Karel Zak <kzak@redhat.com>
2 months agojsonwrt: simplify ul_jsonwrt_empty() and add comments for COMPACT format
WanBingjiang [Mon, 23 Feb 2026 08:32:48 +0000 (16:32 +0800)] 
jsonwrt: simplify ul_jsonwrt_empty() and add comments for COMPACT format

Consolidate duplicated LINE/COMPACT branches in ul_jsonwrt_empty()
into a single else-branch, since they produce identical output.

Add comments explaining the indent depth checks in ul_jsonwrt_open()
and ul_jsonwrt_close() for COMPACT format.

2 months agocolumn: using switch-case replaces if-else
WanBingjiang [Thu, 5 Feb 2026 10:02:47 +0000 (18:02 +0800)] 
column: using switch-case replaces if-else

2 months agocolumn: add JSON compact format output subtest.
WanBingjiang [Thu, 5 Feb 2026 09:30:12 +0000 (17:30 +0800)] 
column: add JSON compact format output subtest.

2 months agocolumn: add JSON LINES format output subtest.
WanBingjiang [Thu, 5 Feb 2026 09:13:44 +0000 (17:13 +0800)] 
column: add JSON LINES format output subtest.

2 months agocolumn: introduce LIBSMARTCOLS_JSON environment argument
WanBingjiang [Thu, 5 Feb 2026 09:11:06 +0000 (17:11 +0800)] 
column: introduce LIBSMARTCOLS_JSON environment argument

2 months agojsonwrt: support Compact JSON format output
WanBingjiang [Thu, 5 Feb 2026 08:53:29 +0000 (16:53 +0800)] 
jsonwrt: support Compact JSON format output

2 months agolibsmartcols: support JSON Lines format output
WanBingjiang [Thu, 5 Feb 2026 09:02:39 +0000 (17:02 +0800)] 
libsmartcols: support JSON Lines format output

2 months agochoom: (testcoverage) add long options tests
Christian Goeschel Ndjomouo [Sun, 22 Feb 2026 03:04:38 +0000 (22:04 -0500)] 
choom: (testcoverage) add long options tests

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agoblkid: (testcoverage) add more long option tests
Christian Goeschel Ndjomouo [Sun, 22 Feb 2026 02:09:27 +0000 (21:09 -0500)] 
blkid: (testcoverage) add more long option tests

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agoblkdiscard: (tests) add more long option tests
Christian Goeschel Ndjomouo [Sat, 21 Feb 2026 01:34:50 +0000 (20:34 -0500)] 
blkdiscard: (tests) add more long option tests

Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agoFix formatting in getino.1.adoc
Mario Blättermann [Fri, 20 Feb 2026 12:47:36 +0000 (13:47 +0100)] 
Fix formatting in getino.1.adoc

2 months agolsmem: fix missing zone info when memory blocks start at an index other than 0
Christian Goeschel Ndjomouo [Fri, 20 Feb 2026 00:02:09 +0000 (19:02 -0500)] 
lsmem: fix missing zone info when memory blocks start at an index other than 0

On systems that have an uncommon physical memory layout, e.g. where hotpluggable
memory blocks start at an offset greater than 0, we failed to set the 'have_zones'
control flag, which caused an omission of the ZONES information of the listed
individual memory block or a block range. This is because we explicitly tested for
/sys/devices/system/memory/memory0/valid_zones, however it is better to simply
look for any memory<n> directory entry and validate the existence of the valid_zones
attribute.

Closes: #4055
Signed-off-by: Christian Goeschel Ndjomouo <cgoesc2@wgu.edu>
2 months agologin: Fix signal race in child handling
Tobias Stoeckmann [Thu, 19 Feb 2026 19:58:10 +0000 (20:58 +0100)] 
login: Fix signal race in child handling

Two cases exist in which login might send signals to a process which is
actually not a child process:

- If SIGCHLD is set to SIG_IGN by login's parent process (unlikely),
  then no zombie process exists. The kernel could already reuse the PID
  for another process just before login's signal_handler function sends
  a signal to its stored child PID -- which was already reused
- If wait succeeds, the PID can be reused by the kernel for another
  process. The registered signal_handlers could still use the stored
  child PID to send signals -- but erroneously to a wrong process

Fix these cases by blocking and unblocking SIGCHLD and signal_handler
triggering signals around the wait call. Set child_pid to 0 after wait
succeeded and before signal_handler signals are unblocked again.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agolib/pager: Gracefully handle SIGPIPE errors
Tobias Stoeckmann [Thu, 19 Feb 2026 17:16:32 +0000 (18:16 +0100)] 
lib/pager: Gracefully handle SIGPIPE errors

A user might prematurely close the pager before the parent wrote its
full output into the pipe. This triggers SIGPIPE, which would eventually
lead to an error return value.

The programs dmesg and fdisk can keep running just fine in these cases.
In fact, dmesg's source code was already prepared for EPIPE error return
values.

If the pager returns with a success return value, ignore SIGPIPE. If
there was an error within the pager, stop the parent as well.

With this, dmesg does not return an error anymore if the ring buffer was
not fully sent to the pager before it was closed.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agodmesg: Gracefully handle EPIPE errors
Tobias Stoeckmann [Thu, 19 Feb 2026 17:14:23 +0000 (18:14 +0100)] 
dmesg: Gracefully handle EPIPE errors

Just calling exit with a success return value in case of an EPIPE error
in safe_fwrite is not precise enough. If dmesg was called with "-c",
i.e. to print and then clear the ring buffer, a successful return value
should mean that the ring buffer is cleared as well.

Instead, continue operation on EPIPE error but stop any further regular
output.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agodmesg: Register pager_close as exit handler
Tobias Stoeckmann [Thu, 19 Feb 2026 17:13:25 +0000 (18:13 +0100)] 
dmesg: Register pager_close as exit handler

Make sure that pager is properly closed even in case of err/errx calls
while pager is running.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agoMerge branch 'pg_warn' of https://github.com/stoeckmann/util-linux
Karel Zak [Thu, 19 Feb 2026 12:18:26 +0000 (13:18 +0100)] 
Merge branch 'pg_warn' of https://github.com/stoeckmann/util-linux

* 'pg_warn' of https://github.com/stoeckmann/util-linux:
  pg: Fix compiler warning

2 months agoMerge branch 'PR/setpriv-apparmor-exec' of https://github.com/karelzak/util-linux...
Karel Zak [Thu, 19 Feb 2026 11:59:45 +0000 (12:59 +0100)] 
Merge branch 'PR/setpriv-apparmor-exec' of https://github.com/karelzak/util-linux-work

* 'PR/setpriv-apparmor-exec' of https://github.com/karelzak/util-linux-work:
  setpriv: use AppArmor LSM-specific proc interface

2 months agoMerge branch 'PR/agetty-netlink-cloexec' of https://github.com/karelzak/util-linux...
Karel Zak [Thu, 19 Feb 2026 11:59:26 +0000 (12:59 +0100)] 
Merge branch 'PR/agetty-netlink-cloexec' of https://github.com/karelzak/util-linux-work

* 'PR/agetty-netlink-cloexec' of https://github.com/karelzak/util-linux-work:
  lib/netlink: set SOCK_CLOEXEC on netlink socket

2 months agoMerge branch 'PR/blkid-btrfs-zone-cleanup' of https://github.com/karelzak/util-linux...
Karel Zak [Thu, 19 Feb 2026 11:59:02 +0000 (12:59 +0100)] 
Merge branch 'PR/blkid-btrfs-zone-cleanup' of https://github.com/karelzak/util-linux-work

* 'PR/blkid-btrfs-zone-cleanup' of https://github.com/karelzak/util-linux-work:
  libblkid: (btrfs) use BTRFS_NR_SB_LOG_ZONES and rep->zones

2 months agologin: use original FQDN for PAM_RHOST
Karel Zak [Thu, 19 Feb 2026 11:20:28 +0000 (12:20 +0100)] 
login: use original FQDN for PAM_RHOST

When login -h <remotehost> is invoked, init_remote_info() strips the
local domain suffix from the hostname (FQDN to short name) before
storing it in cxt->hostname. This truncated value is then used for
PAM_RHOST, which can bypass pam_access host deny rules that match on
the FQDN.

Preserve the original -h hostname in a new cmd_hostname field and use
it for PAM_RHOST, while keeping the truncated hostname for utmp/wtmp
and logging unchanged.

Note, the real-world impact is low -- login -h is only used by legacy
telnet/rlogin daemons, and exploitation requires FQDN-specific
pam_access rules on a system still using these obsolete services.

Reported-by: Asim Viladi Oglu Manizada <manizada@pm.me>
Signed-off-by: Karel Zak <kzak@redhat.com>
2 months agolib/fileeq: Prevent OOB with short read files
Tobias Stoeckmann [Wed, 18 Feb 2026 17:04:54 +0000 (18:04 +0100)] 
lib/fileeq: Prevent OOB with short read files

Using the Linux Crypto API stores hash sums of read chunks in memory. It
trusts that get_digest is called as often as "read blocks" exist in file.

It becomes an issue with files which have less content than st_size
suggests, e.g. files in sysfs. Eventually, the iterator n will be
eq->blocksmax, because the EOF is never noticed. Writing this next hash
sum into memory would lead to an out of boundary write.

Verify that n is less than eq->blocksmax. If this is not true anymore,
treat it as an error so files are considered to be not equal. This is
much safer than erroneously treating them as equal.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agolib/fileeq: Extend debug message
Tobias Stoeckmann [Wed, 18 Feb 2026 20:10:21 +0000 (21:10 +0100)] 
lib/fileeq: Extend debug message

Log how many bytes were actually read, not just how many were requested.
This difference occurs for files smaller than 32 bytes.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agolib/fileeq: Fix formatters
Tobias Stoeckmann [Wed, 18 Feb 2026 20:10:06 +0000 (21:10 +0100)] 
lib/fileeq: Fix formatters

Use formatters for given data types.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agolib/fileeq: Fix typos
Tobias Stoeckmann [Wed, 18 Feb 2026 17:15:02 +0000 (18:15 +0100)] 
lib/fileeq: Fix typos

Fix grammar and typos in comments. No functional change.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agopg: Fix compiler warning
Tobias Stoeckmann [Wed, 18 Feb 2026 17:26:52 +0000 (18:26 +0100)] 
pg: Fix compiler warning

Seen compiler warning with GCC 15.2.1 and glibc 2.43:
```
text-utils/pg.c: In function ‘prompt’:
text-utils/pg.c:621:24: warning: assignment discards ‘const’ qualifier from pointer target type [-Wdiscarded-qualifiers]
  621 |                 if ((p = strstr(pstring, "%d")) == NULL) {
      |                        ^
```

This happens if strstr is actually a preprocessor definition with a
__glibc_const_generic. For this, __GLIBC_USE (ISOC23) must be true.

Setting the pointer to const does not hurt and clarifies that the
content is not modfied.

Signed-off-by: Tobias Stoeckmann <tobias@stoeckmann.org>
2 months agoMerge branch 'PR/pidfd-utils-have-defines' of https://github.com/karelzak/util-linux...
Karel Zak [Wed, 18 Feb 2026 11:36:16 +0000 (12:36 +0100)] 
Merge branch 'PR/pidfd-utils-have-defines' of https://github.com/karelzak/util-linux-work

* 'PR/pidfd-utils-have-defines' of https://github.com/karelzak/util-linux-work:
  pidfd-utils: move USE_PIDFD_INO_SUPPORT after syscall fallbacks
  pidfd-utils: define HAVE_PIDFD_* when syscall fallbacks are used

2 months agonsenter: use USE_NAMESPACE_ID_SUPPORT macro for nsid feature
Karel Zak [Wed, 18 Feb 2026 09:59:30 +0000 (10:59 +0100)] 
nsenter: use USE_NAMESPACE_ID_SUPPORT macro for nsid feature

Replace direct HAVE_STRUCT_NSFS_FILE_HANDLE ifdefs with a
feature-specific USE_NAMESPACE_ID_SUPPORT macro that also
requires HAVE_PIDFD_OPEN, since the namespace ID support
depends on pidfd_open().

Addresses: https://github.com/util-linux/util-linux/pull/4044
Signed-off-by: Karel Zak <kzak@redhat.com>
2 months agonsenter: fix minor issues with namespace ID support
Karel Zak [Wed, 18 Feb 2026 09:47:19 +0000 (10:47 +0100)] 
nsenter: fix minor issues with namespace ID support

- fix pidfd_self FD leak when ioctl(PIDFD_GET_MNT_NAMESPACE) fails
- fix "namesapces" typo in man page
- document "./" disambiguation for files starting with ":"
- use standard C initializer = { 0 } instead of = {}

Addresses: https://github.com/util-linux/util-linux/pull/4044
Signed-off-by: Karel Zak <kzak@redhat.com>
2 months agopidfd-utils: move USE_PIDFD_INO_SUPPORT after syscall fallbacks
Karel Zak [Wed, 18 Feb 2026 09:34:46 +0000 (10:34 +0100)] 
pidfd-utils: move USE_PIDFD_INO_SUPPORT after syscall fallbacks

Signed-off-by: Karel Zak <kzak@redhat.com>
2 months agopidfd-utils: define HAVE_PIDFD_* when syscall fallbacks are used
Karel Zak [Wed, 18 Feb 2026 09:30:25 +0000 (10:30 +0100)] 
pidfd-utils: define HAVE_PIDFD_* when syscall fallbacks are used

Follow the pattern already used in fileutils.h for close_range() and
statx().

Signed-off-by: Karel Zak <kzak@redhat.com>
2 months 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>
2 months 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>
2 months agosetpriv: use AppArmor LSM-specific proc interface
Karel Zak [Tue, 17 Feb 2026 11:33:58 +0000 (12:33 +0100)] 
setpriv: use AppArmor LSM-specific proc interface

Remove the check for /sys/kernel/security/apparmor (securityfs) before
writing to the proc attr interface. The securityfs check fails in
environments where AppArmor is enabled but securityfs is not mounted
(e.g., containers, WSL2, embedded systems).

Use the LSM-specific /proc/self/attr/apparmor/exec interface introduced
in Linux 5.8 (kernel commit 6413f852ce08) which is not affected by LSM
load ordering issues. Fall back to the legacy /proc/self/attr/exec for
older kernels.

Fixes: https://github.com/util-linux/util-linux/issues/4033
Signed-off-by: Karel Zak <kzak@redhat.com>
2 months agolib/netlink: set SOCK_CLOEXEC on netlink socket
Karel Zak [Tue, 17 Feb 2026 10:35:17 +0000 (11:35 +0100)] 
lib/netlink: set SOCK_CLOEXEC on netlink socket

Set SOCK_CLOEXEC when creating the NETLINK_ROUTE socket in
ul_nl_open() to prevent the file descriptor from leaking to
child processes across execv().

In agetty, the netlink socket used to monitor IP address changes
for \4/\6 issue escapes was inherited by the login program, causing
SELinux AVC denials (local_login_t denied read/write on getty_t's
netlink_route_socket).

Fixes: https://github.com/util-linux/util-linux/issues/4032
Signed-off-by: Karel Zak <kzak@redhat.com>
2 months agolibblkid: (btrfs) use BTRFS_NR_SB_LOG_ZONES and rep->zones
Karel Zak [Tue, 17 Feb 2026 10:20:38 +0000 (11:20 +0100)] 
libblkid: (btrfs) use BTRFS_NR_SB_LOG_ZONES and rep->zones

Use the BTRFS_NR_SB_LOG_ZONES constant instead of a hardcoded 2 when
calling blkdev_get_zonereport() to be consistent with the rest of the
function that already uses this constant.

Replace the pointer arithmetic (struct blk_zone *)(rep + 1) with the
more readable rep->zones flexible array member access.

Addresses: https://github.com/util-linux/util-linux/pull/3995
Signed-off-by: Karel Zak <kzak@redhat.com>
2 months 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

2 months 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>
2 months 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

2 months 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

2 months 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>
2 months 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>
2 months 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>
2 months agoavoid repetitive code
Arvin Schnell [Mon, 16 Feb 2026 15:34:04 +0000 (16:34 +0100)] 
avoid repetitive code

2 months 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

2 months 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>
2 months 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

2 months 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>
2 months 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>
2 months 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

2 months 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

2 months 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>
2 months 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.

2 months 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>
2 months 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

2 months 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

2 months 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>
2 months 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

2 months 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>
2 months 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

2 months 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

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

2 months 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

2 months 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>
2 months 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

2 months 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>