Fix some MSVC warnings

This commit is contained in:
Wilson Snyder 2024-01-28 14:47:14 -05:00
parent a84be1844f
commit ce174743bb
6 changed files with 14 additions and 20 deletions

View File

@ -19,14 +19,14 @@ int main(int argc, char** argv) {
// e.g. examples/c_tracing. // e.g. examples/c_tracing.
// Construct a VerilatedContext to hold simulation time, etc. // Construct a VerilatedContext to hold simulation time, etc.
VerilatedContext* contextp = new VerilatedContext; VerilatedContext* const contextp = new VerilatedContext;
// Pass arguments so Verilated code can see them, e.g. $value$plusargs // Pass arguments so Verilated code can see them, e.g. $value$plusargs
// This needs to be called before you create any model // This needs to be called before you create any model
contextp->commandArgs(argc, argv); contextp->commandArgs(argc, argv);
// Construct the Verilated model, from Vtop.h generated from Verilating "top.v" // Construct the Verilated model, from Vtop.h generated from Verilating "top.v"
Vtop* top = new Vtop{contextp}; Vtop* const top = new Vtop{contextp};
// Simulate until $finish // Simulate until $finish
while (!contextp->gotFinish()) { while (!contextp->gotFinish()) {

View File

@ -25,7 +25,7 @@ int sc_main(int argc, char* argv[]) {
// e.g. examples/c_tracing. // e.g. examples/c_tracing.
// Construct the Verilated model, from Vtop.h generated from Verilating "top.v" // Construct the Verilated model, from Vtop.h generated from Verilating "top.v"
Vtop* top = new Vtop{"top"}; Vtop* const top = new Vtop{"top"};
// Pass arguments so Verilated code can see them, e.g. $value$plusargs // Pass arguments so Verilated code can see them, e.g. $value$plusargs
// This needs to be called before you create any model // This needs to be called before you create any model

View File

@ -20,13 +20,13 @@ int main(int argc, char** argv) {
if (false && argc && argv) {} if (false && argc && argv) {}
// Construct context to hold simulation time, etc // Construct context to hold simulation time, etc
VerilatedContext* contextp = new VerilatedContext; const std::unique_ptr<VerilatedContext> contextp{new VerilatedContext};
contextp->debug(0); contextp->debug(0);
contextp->randReset(2); contextp->randReset(2);
contextp->commandArgs(argc, argv); contextp->commandArgs(argc, argv);
// Construct the Verilated model, including the secret module // Construct the Verilated model, including the secret module
Vtop* top = new Vtop{contextp}; const std::unique_ptr<Vtop> top{new Vtop{contextp.get(), "TOP"}};
#if VM_TRACE #if VM_TRACE
// When tracing, the contents of the secret module will not be seen // When tracing, the contents of the secret module will not be seen
@ -65,12 +65,6 @@ int main(int argc, char** argv) {
} }
#endif #endif
// Destroy model
delete top;
top = nullptr;
delete contextp;
contextp = nullptr;
// Return good completion status // Return good completion status
// Don't use exit() or destructor won't get called // Don't use exit() or destructor won't get called
return 0; return 0;

View File

@ -791,7 +791,7 @@ std::string _vl_vsformat_time(char* tmp, T ld, int timeunit, bool left, size_t w
} }
} }
const int needmore = width - digits; const int needmore = static_cast<int>(width) - digits;
std::string padding; std::string padding;
if (needmore > 0) padding.append(needmore, ' '); // Pad with spaces if (needmore > 0) padding.append(needmore, ' '); // Pad with spaces
return left ? (tmp + padding) : (padding + tmp); return left ? (tmp + padding) : (padding + tmp);
@ -947,9 +947,9 @@ void _vl_vsformat(std::string& output, const std::string& format, va_list ap) VL
} else { } else {
append = VL_DECIMAL_NW(lbits, lwp); append = VL_DECIMAL_NW(lbits, lwp);
} }
digits = append.length(); digits = static_cast<int>(append.length());
} }
const int needmore = width - digits; const int needmore = static_cast<int>(width) - digits;
if (needmore > 0) { if (needmore > 0) {
std::string padding; std::string padding;
if (left) { if (left) {
@ -976,9 +976,9 @@ void _vl_vsformat(std::string& output, const std::string& format, va_list ap) VL
append = t_tmp; append = t_tmp;
} else { } else {
append = VL_DECIMAL_NW(lbits, lwp); append = VL_DECIMAL_NW(lbits, lwp);
digits = append.length(); digits = static_cast<int>(append.length());
} }
const int needmore = width - digits; const int needmore = static_cast<int>(width) - digits;
if (needmore > 0) { if (needmore > 0) {
std::string padding; std::string padding;
if (left) { if (left) {
@ -1044,7 +1044,7 @@ void _vl_vsformat(std::string& output, const std::string& format, va_list ap) VL
} }
} // switch } // switch
const int needmore = width - digits; const int needmore = static_cast<int>(width) - digits;
if (needmore > 0) { if (needmore > 0) {
std::string padding; std::string padding;
if (left) { if (left) {

View File

@ -294,7 +294,7 @@ public: // But only for verilated*.cpp
std::fill(m_fdps.begin() + start, m_fdps.end(), static_cast<FILE*>(nullptr)); std::fill(m_fdps.begin() + start, m_fdps.end(), static_cast<FILE*>(nullptr));
m_fdFree.resize(excess); m_fdFree.resize(excess);
for (std::size_t i = 0, id = start; i < m_fdFree.size(); ++i, ++id) { for (std::size_t i = 0, id = start; i < m_fdFree.size(); ++i, ++id) {
m_fdFree[i] = id; m_fdFree[i] = static_cast<IData>(id);
} }
} }
const IData idx = m_fdFree.back(); const IData idx = m_fdFree.back();

View File

@ -214,10 +214,10 @@ public:
~VlThreadPool() override; ~VlThreadPool() override;
// METHODS // METHODS
int numThreads() const { return m_workers.size(); } int numThreads() const { return static_cast<int>(m_workers.size()); }
VlWorkerThread* workerp(int index) { VlWorkerThread* workerp(int index) {
assert(index >= 0); assert(index >= 0);
assert(static_cast<size_t>(index) < m_workers.size()); assert(index < static_cast<int>(m_workers.size()));
return m_workers[index]; return m_workers[index];
} }