summaryrefslogtreecommitdiff
path: root/kernel
diff options
context:
space:
mode:
Diffstat (limited to 'kernel')
-rw-r--r--kernel/log.cc7
-rw-r--r--kernel/rtlil.h4
2 files changed, 9 insertions, 2 deletions
diff --git a/kernel/log.cc b/kernel/log.cc
index f67d64c2..9cabc6a8 100644
--- a/kernel/log.cc
+++ b/kernel/log.cc
@@ -41,6 +41,7 @@ int log_verbose_level;
std::vector<int> header_count;
std::list<std::string> string_buf;
+int string_buf_size = 0;
static struct timeval initial_tv = { 0, 0 };
static bool next_print_log = false;
@@ -166,6 +167,7 @@ void log_pop()
{
header_count.pop_back();
string_buf.clear();
+ string_buf_size = 0;
log_flush();
}
@@ -174,6 +176,7 @@ void log_reset_stack()
while (header_count.size() > 1)
header_count.pop_back();
string_buf.clear();
+ string_buf_size = 0;
log_flush();
}
@@ -197,6 +200,10 @@ const char *log_signal(const RTLIL::SigSpec &sig, bool autoint)
fputc(0, f);
fclose(f);
+ if (string_buf_size < 100)
+ string_buf_size++;
+ else
+ string_buf.pop_front();
string_buf.push_back(ptr);
free(ptr);
diff --git a/kernel/rtlil.h b/kernel/rtlil.h
index 9430da31..7b989385 100644
--- a/kernel/rtlil.h
+++ b/kernel/rtlil.h
@@ -74,7 +74,7 @@ namespace RTLIL
struct IdString
{
- // the global string cache
+ // the global id string cache
struct char_ptr_cmp {
bool operator()(const char *a, const char *b) {
@@ -134,7 +134,7 @@ namespace RTLIL
global_free_idx_list_.push_back(idx);
}
- // The actual IdString objects just is a single int
+ // the actual IdString object is just is a single int
int index_;