aboutsummaryrefslogtreecommitdiffstats
path: root/frontends/blif
diff options
context:
space:
mode:
authorClifford Wolf <clifford@clifford.at>2015-05-17 15:10:37 +0200
committerClifford Wolf <clifford@clifford.at>2015-05-17 15:10:37 +0200
commite5116eeb77c5b7d77f726da4d512f14b7f31eada (patch)
tree7898dced7846eedcd7c5c88d922490a1830b79f0 /frontends/blif
parent7dad017c9ce7b00a1aa3cc0b323297d8fe2cccf5 (diff)
downloadyosys-e5116eeb77c5b7d77f726da4d512f14b7f31eada.tar.gz
yosys-e5116eeb77c5b7d77f726da4d512f14b7f31eada.tar.bz2
yosys-e5116eeb77c5b7d77f726da4d512f14b7f31eada.zip
Generalized blifparse API
Diffstat (limited to 'frontends/blif')
-rw-r--r--frontends/blif/blifparse.cc40
-rw-r--r--frontends/blif/blifparse.h2
2 files changed, 25 insertions, 17 deletions
diff --git a/frontends/blif/blifparse.cc b/frontends/blif/blifparse.cc
index a69cfde19..fb71cee16 100644
--- a/frontends/blif/blifparse.cc
+++ b/frontends/blif/blifparse.cc
@@ -21,7 +21,7 @@
YOSYS_NAMESPACE_BEGIN
-static bool read_next_line(char *&buffer, size_t &buffer_size, int &line_count, FILE *f)
+static bool read_next_line(char *&buffer, size_t &buffer_size, int &line_count, std::istream &f)
{
int buffer_len = 0;
buffer[0] = 0;
@@ -42,32 +42,31 @@ static bool read_next_line(char *&buffer, size_t &buffer_size, int &line_count,
if (buffer_len > 0 && buffer[buffer_len-1] == '\\')
buffer[--buffer_len] = 0;
line_count++;
- if (fgets(buffer+buffer_len, buffer_size-buffer_len, f) == NULL)
+ if (!f.getline(buffer+buffer_len, buffer_size-buffer_len))
return false;
} else
return true;
}
}
-RTLIL::Design *abc_parse_blif(FILE *f, std::string dff_name)
+void parse_blif(RTLIL::Design *design, std::istream &f, std::string dff_name)
{
- RTLIL::Design *design = new RTLIL::Design;
- RTLIL::Module *module = new RTLIL::Module;
-
+ RTLIL::Module *module = nullptr;
RTLIL::Const *lutptr = NULL;
RTLIL::State lut_default_state = RTLIL::State::Sx;
- module->name = "\\netlist";
- design->add(module);
-
size_t buffer_size = 4096;
char *buffer = (char*)malloc(buffer_size);
int line_count = 0;
while (1)
{
- if (!read_next_line(buffer, buffer_size, line_count, f))
- goto error;
+ if (!read_next_line(buffer, buffer_size, line_count, f)) {
+ if (module != nullptr)
+ goto error;
+ free(buffer);
+ return;
+ }
continue_without_read:
if (buffer[0] == '#')
@@ -85,13 +84,24 @@ RTLIL::Design *abc_parse_blif(FILE *f, std::string dff_name)
char *cmd = strtok(buffer, " \t\r\n");
- if (!strcmp(cmd, ".model"))
+ if (!strcmp(cmd, ".model")) {
+ if (module != nullptr)
+ goto error;
+ module = new RTLIL::Module;
+ module->name = RTLIL::escape_id(strtok(NULL, " \t\r\n"));
+ if (design->module(module->name))
+ log_error("Duplicate definition of module %s in line %d!\n", log_id(module->name), line_count);
+ design->add(module);
continue;
+ }
+
+ if (module == nullptr)
+ goto error;
if (!strcmp(cmd, ".end")) {
module->fixup_ports();
- free(buffer);
- return design;
+ module = nullptr;
+ continue;
}
if (!strcmp(cmd, ".inputs") || !strcmp(cmd, ".outputs")) {
@@ -256,8 +266,6 @@ RTLIL::Design *abc_parse_blif(FILE *f, std::string dff_name)
error:
log_error("Syntax error in line %d!\n", line_count);
- // delete design;
- // return NULL;
}
YOSYS_NAMESPACE_END
diff --git a/frontends/blif/blifparse.h b/frontends/blif/blifparse.h
index 31f5b2e5c..1da36e00a 100644
--- a/frontends/blif/blifparse.h
+++ b/frontends/blif/blifparse.h
@@ -24,7 +24,7 @@
YOSYS_NAMESPACE_BEGIN
-extern RTLIL::Design *abc_parse_blif(FILE *f, std::string dff_name);
+extern void parse_blif(RTLIL::Design *design, std::istream &f, std::string dff_name);
YOSYS_NAMESPACE_END