[+grembo@ for iocage]

On 3/15/25 06:26, Alexander Leidinger wrote:
Am 2025-02-26 16:20, schrieb Alexander Leidinger:
Hi,

the working system is from 2025-01-25-141603, the non working system is from 2025-02-21-115311.

I'm not sure what the issue is exactly. I have traced down the change of behavior to
---snip---
if not LIBC.setfstab(fstab_file_path.encode()):
---snip---

In the working case LIBC.setfstab returns true (so with the not it doesn't take this branch), and in the non-working case it returns false (so with the not it takes this branch).

Is someone aware of a change in this area? Searching for it (https:// cgit.freebsd.org/src/log/?qt=grep&q=setfstab) only brings the initial commit.

Interestingly my own commit triggers this issue.

I bisected and commit 1c2ae9233b0ed4f6b92c59c0e4026f6ddc073e4a is causing this. This is the first ref which triggers the issue that iocage can not mount filesystems anymore. And the failing call in iocage seems to be the python LIBC.setfstab() call. And this only triggers, when the basesystem is compiled with the stack clash protection. I do not see any obvious issue in our setfstab code. Anyone with an idea?

setfstab() implementation seems more or less fine, but it's hard to tell what's going on with iocage there. setfstab(3) doesn't actually have a return value in any version of FreeBSD, so I guess it's picking up some sort of garbage as the return value.

Looking at the context, you can only tell if the open failed with the subsequent getfsent()/setfsent(); that branch should probably just be removed entirely, and the initial getfsent() might be worth error-checking for potential error or premature EOF.

Thanks,

Kyle Evans

Reply via email to