Fix characters from DEFENV literals for conda (#4035) (#4044)

The baked in DEFENV paths might end up with extra NULL characters
at the end if the binaries are installed by something that patches them
for relocatable installs (e.g. conda).  Avoid this issue by immediately
passing them through std::string::c_str() method to stop at the first NULL
This commit is contained in:
Tim Snyder 2023-03-18 10:25:27 -05:00 committed by GitHub
parent ba9e141fae
commit 053f760e2a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -656,8 +656,11 @@ string V3Options::getenvPERL() { //
string V3Options::getenvSYSTEMC() { string V3Options::getenvSYSTEMC() {
string var = V3Os::getenvStr("SYSTEMC", ""); string var = V3Os::getenvStr("SYSTEMC", "");
if (var == "" && string(DEFENV_SYSTEMC) != "") { // Treat compiled-in DEFENV string literals as C-strings to enable
var = DEFENV_SYSTEMC; // binary patching for relocatable installs (e.g. conda)
string defenv = string{DEFENV_SYSTEMC}.c_str();
if (var == "" && defenv != "") {
var = defenv;
V3Os::setenvStr("SYSTEMC", var, "Hardcoded at build time"); V3Os::setenvStr("SYSTEMC", var, "Hardcoded at build time");
} }
return var; return var;
@ -665,8 +668,11 @@ string V3Options::getenvSYSTEMC() {
string V3Options::getenvSYSTEMC_ARCH() { string V3Options::getenvSYSTEMC_ARCH() {
string var = V3Os::getenvStr("SYSTEMC_ARCH", ""); string var = V3Os::getenvStr("SYSTEMC_ARCH", "");
if (var == "" && string(DEFENV_SYSTEMC_ARCH) != "") { // Treat compiled-in DEFENV string literals as C-strings to enable
var = DEFENV_SYSTEMC_ARCH; // binary patching for relocatable installs (e.g. conda)
string defenv = string{DEFENV_SYSTEMC_ARCH}.c_str();
if (var == "" && defenv != "") {
var = defenv;
V3Os::setenvStr("SYSTEMC_ARCH", var, "Hardcoded at build time"); V3Os::setenvStr("SYSTEMC_ARCH", var, "Hardcoded at build time");
} }
if (var == "") { if (var == "") {
@ -697,8 +703,11 @@ string V3Options::getenvSYSTEMC_ARCH() {
string V3Options::getenvSYSTEMC_INCLUDE() { string V3Options::getenvSYSTEMC_INCLUDE() {
string var = V3Os::getenvStr("SYSTEMC_INCLUDE", ""); string var = V3Os::getenvStr("SYSTEMC_INCLUDE", "");
if (var == "" && string(DEFENV_SYSTEMC_INCLUDE) != "") { // Treat compiled-in DEFENV string literals as C-strings to enable
var = DEFENV_SYSTEMC_INCLUDE; // binary patching for relocatable installs (e.g. conda)
string defenv = string{DEFENV_SYSTEMC_INCLUDE}.c_str();
if (var == "" && defenv != "") {
var = defenv;
V3Os::setenvStr("SYSTEMC_INCLUDE", var, "Hardcoded at build time"); V3Os::setenvStr("SYSTEMC_INCLUDE", var, "Hardcoded at build time");
} }
if (var == "") { if (var == "") {
@ -710,8 +719,11 @@ string V3Options::getenvSYSTEMC_INCLUDE() {
string V3Options::getenvSYSTEMC_LIBDIR() { string V3Options::getenvSYSTEMC_LIBDIR() {
string var = V3Os::getenvStr("SYSTEMC_LIBDIR", ""); string var = V3Os::getenvStr("SYSTEMC_LIBDIR", "");
if (var == "" && string(DEFENV_SYSTEMC_LIBDIR) != "") { // Treat compiled-in DEFENV string literals as C-strings to enable
var = DEFENV_SYSTEMC_LIBDIR; // binary patching for relocatable installs (e.g. conda)
string defenv = string{DEFENV_SYSTEMC_LIBDIR}.c_str();
if (var == "" && defenv != "") {
var = defenv;
V3Os::setenvStr("SYSTEMC_LIBDIR", var, "Hardcoded at build time"); V3Os::setenvStr("SYSTEMC_LIBDIR", var, "Hardcoded at build time");
} }
if (var == "") { if (var == "") {
@ -724,8 +736,11 @@ string V3Options::getenvSYSTEMC_LIBDIR() {
string V3Options::getenvVERILATOR_ROOT() { string V3Options::getenvVERILATOR_ROOT() {
string var = V3Os::getenvStr("VERILATOR_ROOT", ""); string var = V3Os::getenvStr("VERILATOR_ROOT", "");
if (var == "" && string(DEFENV_VERILATOR_ROOT) != "") { // Treat compiled-in DEFENV string literals as C-strings to enable
var = DEFENV_VERILATOR_ROOT; // binary patching for relocatable installs (e.g. conda)
string defenv = string{DEFENV_VERILATOR_ROOT}.c_str();
if (var == "" && defenv != "") {
var = defenv;
V3Os::setenvStr("VERILATOR_ROOT", var, "Hardcoded at build time"); V3Os::setenvStr("VERILATOR_ROOT", var, "Hardcoded at build time");
} }
if (var == "") v3fatal("$VERILATOR_ROOT needs to be in environment\n"); if (var == "") v3fatal("$VERILATOR_ROOT needs to be in environment\n");