Install public executables into bindir instead of pkgdatadir (#5140) (#5544)

Instead of installing redirect scripts in to bindir, and real
executables in to pkgdatadir/bin, we now put the real executables into
bindir, and add redirect scripts into pkgdatadir/bin. (That is, we
redirect in the opposite direction as before).

This enables the same relocatable and testable installations as before
without putting architecture specific binaries into pkgdatadir, so
hopefully we now conform to the Linux Filesystem Hierarchy Standard.

This requires a small fixup in the installed `verilator` script to
hardcode the relative path between bindir and pkgdatadir.

Fixes #5140
This commit is contained in:
Geza Lore 2024-10-18 10:06:28 +01:00 committed by GitHub
parent ece0613e09
commit 55661e7f71
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 23 additions and 18 deletions

View File

@ -266,11 +266,15 @@ mkbindirs:
installbin: | mkbindirs installbin: | mkbindirs
cd $(srcdir)/bin; \ cd $(srcdir)/bin; \
for p in $(VL_INST_PUBLIC_SCRIPT_FILES) ; do \ for p in $(VL_INST_PUBLIC_SCRIPT_FILES) ; do \
$(INSTALL_PROGRAM) $$p $(DESTDIR)$(pkgdatadir)/bin/$$p; \ $(INSTALL_PROGRAM) $$p $(DESTDIR)$(bindir)/$$p; \
done done
perl -p -i -e 'use File::Spec;' \
-e' $$path = File::Spec->abs2rel("$(realpath $(DESTDIR)$(pkgdatadir))", "$(realpath $(DESTDIR)$(bindir))");' \
-e 's/my \$$verilator_pkgdatadir_relpath = .*/my \$$verilator_pkgdatadir_relpath = "$$path";/g' \
-- "$(DESTDIR)/$(bindir)/verilator"
cd bin; \ cd bin; \
for p in $(VL_INST_PUBLIC_BIN_FILES) ; do \ for p in $(VL_INST_PUBLIC_BIN_FILES) ; do \
$(INSTALL_PROGRAM) $$p $(DESTDIR)$(pkgdatadir)/bin/$$p; \ $(INSTALL_PROGRAM) $$p $(DESTDIR)$(bindir)/$$p; \
done done
cd $(srcdir)/bin; \ cd $(srcdir)/bin; \
for p in $(VL_INST_PRIVATE_SCRIPT_FILES) ; do \ for p in $(VL_INST_PRIVATE_SCRIPT_FILES) ; do \
@ -280,11 +284,11 @@ installbin: | mkbindirs
installredirect: installbin | mkbindirs installredirect: installbin | mkbindirs
cp ${srcdir}/bin/redirect ${srcdir}/bin/redirect.tmp cp ${srcdir}/bin/redirect ${srcdir}/bin/redirect.tmp
perl -p -i -e 'use File::Spec;' \ perl -p -i -e 'use File::Spec;' \
-e' $$path = File::Spec->abs2rel("$(realpath $(DESTDIR)$(pkgdatadir)/bin)", "$(realpath $(DESTDIR)$(bindir))");' \ -e' $$path = File::Spec->abs2rel("$(realpath $(DESTDIR)$(bindir))", "$(realpath $(DESTDIR)$(pkgdatadir)/bin)");' \
-e 's/RELPATH.*/"$$path";/g' -- "${srcdir}/bin/redirect.tmp" -e 's/RELPATH.*/"$$path";/g' -- "${srcdir}/bin/redirect.tmp"
cd $(srcdir)/bin; \ cd $(srcdir)/bin; \
for p in $(VL_INST_PUBLIC_SCRIPT_FILES) $(VL_INST_PUBLIC_BIN_FILES) ; do \ for p in $(VL_INST_PUBLIC_SCRIPT_FILES) $(VL_INST_PUBLIC_BIN_FILES) ; do \
$(INSTALL_PROGRAM) redirect.tmp $(DESTDIR)$(bindir)/$$p; \ $(INSTALL_PROGRAM) redirect.tmp $(DESTDIR)$(pkgdatadir)/bin/$$p; \
done done
rm ${srcdir}/bin/redirect.tmp rm ${srcdir}/bin/redirect.tmp

View File

@ -69,7 +69,9 @@ if (! GetOptions(
pod2usage(-exitstatus => 2, -verbose => 0); pod2usage(-exitstatus => 2, -verbose => 0);
} }
my $verilator_root = realpath("$RealBin/.."); # WARNING: $verilator_pkgdatadir_relpath is substituted during Verilator 'make install'
my $verilator_pkgdatadir_relpath = "..";
my $verilator_root = realpath("$RealBin/$verilator_pkgdatadir_relpath");
if (defined $ENV{VERILATOR_ROOT}) { if (defined $ENV{VERILATOR_ROOT}) {
if ((!-d $ENV{VERILATOR_ROOT}) || $verilator_root ne realpath($ENV{VERILATOR_ROOT})) { if ((!-d $ENV{VERILATOR_ROOT}) || $verilator_root ne realpath($ENV{VERILATOR_ROOT})) {
warn "%Error: verilator: VERILATOR_ROOT is set to inconsistent path. Suggest leaving it unset.\n"; warn "%Error: verilator: VERILATOR_ROOT is set to inconsistent path. Suggest leaving it unset.\n";

View File

@ -31,7 +31,10 @@ def test():
print("== stage 0") print("== stage 0")
run("/bin/rm -rf " + blddir) run("/bin/rm -rf " + blddir)
run("/bin/mkdir -p " + blddir) run("/bin/mkdir -p " + blddir)
run("cd " + blddir + " && " + srcdir + "/configure --prefix " + prefix) # Matches Ubuntu's e.g. /usr/share/pkgconfig/verilator.pc
run("cd " + blddir + " && " + srcdir + "/configure --prefix " + prefix +
" --exec-prefix " + prefix + " --datarootdir " + prefix + "/share" + " --includedir " +
prefix + "/share/verilator/include")
run("cd " + blddir + " && make -j " + str(calc_jobs())) run("cd " + blddir + " && make -j " + str(calc_jobs()))
# Install it under the prefix # Install it under the prefix

View File

@ -14,26 +14,22 @@ test.scenarios('dist')
# See also t_flag_version.py # See also t_flag_version.py
def check(interpreter, prog): def check(prog):
logfile = test.obj_dir + "/t_help__" + os.path.basename(prog) + ".log" logfile = test.obj_dir + "/t_help__" + os.path.basename(prog) + ".log"
test.run(fails=False, test.run(fails=False, cmd=[prog, "--help"], logfile=logfile, tee=False, verilator_run=True)
cmd=[interpreter, prog, "--help"],
logfile=logfile,
tee=False,
verilator_run=True)
test.file_grep(logfile, r'(DISTRIBUTION|usage:)') test.file_grep(logfile, r'(DISTRIBUTION|usage:)')
check("perl", os.environ["VERILATOR_ROOT"] + "/bin/verilator") check(os.environ["VERILATOR_ROOT"] + "/bin/verilator")
check("perl", os.environ["VERILATOR_ROOT"] + "/bin/verilator_coverage") check(os.environ["VERILATOR_ROOT"] + "/bin/verilator_coverage")
check("python3", os.environ["VERILATOR_ROOT"] + "/bin/verilator_ccache_report") check(os.environ["VERILATOR_ROOT"] + "/bin/verilator_ccache_report")
check("python3", os.environ["VERILATOR_ROOT"] + "/bin/verilator_gantt") check(os.environ["VERILATOR_ROOT"] + "/bin/verilator_gantt")
check("python3", os.environ["VERILATOR_ROOT"] + "/bin/verilator_profcfunc") check(os.environ["VERILATOR_ROOT"] + "/bin/verilator_profcfunc")
if os.path.exists(os.environ["VERILATOR_ROOT"] + "/bin/verilator_difftree"): if os.path.exists(os.environ["VERILATOR_ROOT"] + "/bin/verilator_difftree"):
check("python3", os.environ["VERILATOR_ROOT"] + "/bin/verilator_difftree") check(os.environ["VERILATOR_ROOT"] + "/bin/verilator_difftree")
test.passes() test.passes()