git: 54b26298c822 - main - sysutils/e2fsprogs: port rework

Matthias Andree mandree at FreeBSD.org
Fri Aug 6 21:26:17 UTC 2021


Am 06.08.21 um 22:58 schrieb Baptiste Daroussin:
> 
> 4 août 2021 23:23:27 Matthias Andree <mandree at FreeBSD.org>:
> 
>> The branch main has been updated by mandree:
>>
>> URL: https://cgit.FreeBSD.org/ports/commit/?id=54b26298c82275501e6dcc6c733d21c0a6bf0d9f
>>
>> commit 54b26298c82275501e6dcc6c733d21c0a6bf0d9f
>> Author:     Matthias Andree <mandree at FreeBSD.org>
>> AuthorDate: 2021-08-04 20:09:19 +0000
>> Commit:     Matthias Andree <mandree at FreeBSD.org>
>> CommitDate: 2021-08-04 21:23:08 +0000
>>
>>     sysutils/e2fsprogs: port rework
>>    
>>     1 - sysutils/e2fsprogs: fix checksum mismatches
>>    
>>         e2fsprogs has replaced symlinks by hardlinks in its post-install if
>>         /sbin and ${PREFIX}/sbin were on the same file system, and unless
>>         script processing was defeated on install or upgrade.
>>    
>>         Leave symlinks in place to avoid checksum mismatches.
>>    
>>     PR:             252184 [1]
> 
> We already discuss this, the problem here is what this package is doing, installing in base is a violation of the ports tree rules in 99% of the case if not 100%. The purpose of this installation of hardlinksto only support a case which is known not to be functionnal: using e2fs family as a root filesystem for freebsd is a bad reason to do it. Either install everything in base or in localbase but do not do both.
> 
> Running pkg check -r is even worse.
> 1/ i am not sure it works are both pkg install and pkg check will attempt to get an exclusive lock o' the db
> 2/ by design is defeats the principle why we are having checksums on pkg

Baptiste,

you need to read and understand the whole of the two commits before you
comment.

* pkg seems to lack, or I am unaware, of a way to modify the install
before recording files and checksums.

* The current commit to e2fsprogs forgoes the need to do just that, the
price we pay is "absolute symlinks" from $PREFIX/sbin to /sbin.  I've
removed the replace-by-hardlinks stuff from pkg-install.

* installing into /sbin and $PREFIX/... at the same time is something
that the port has been doing for ages, but feel free to send me a patch
for review that splits it into one e2fsprogs port that installs only
into / [/sbin] and RUN_DEPENDS on a separate e2fsprogs-bin port, or we
can revisit this once we have subpackages and pkg grows a
hardlink-or-copy or a hardlink-or-symlink feature that does not cause
apparent checksum mismatches in the database.

* as long as the kernel supports ext2fs we need to be able to fsck so we
don't create circular dependencies that wedge the boot process.

* e2fsck and fsck_ext2fs are linked semi-statically, in order to only
require /lib but not $PREFIX/lib, for use from /sbin.

* pkg check -r is not applied in the current state, and the port
installs symlinks from $PREFIX/sbin to /sbin.

* the current flavours address the installation matters, there is a
flavor that leaves the root fs alone.

And for the pkg matter:

* you can't run pkg check from within a post-install shell script.
Haven't tried Lua. For shell scripts, I explored stuffing a script into
at(1) which worked with an up-to-5 minute delay to recalculate
checksums, daemon(8) would probably have been another option I did not try.

Finally, function overrules beauty.  I will not pollute outside hier(7)
just because someone wants either-or beyond the bare necessities to fsck
from /etc/fstab on boot.

Regards,
Matthias


More information about the dev-commits-ports-all mailing list