diff options
author | myrtle <gatecat@ds0.me> | 2023-02-18 16:37:53 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-02-18 16:37:53 +0100 |
commit | d20a5e9001f46262bf0cef220f1a6943946e421d (patch) | |
tree | 6ec76a7b9146145cd9117d7b6a4e244487d77d79 | |
parent | 5991092f5179b9bccdb7fa8d46a0bc0245b0996f (diff) | |
parent | dd2dce84c4e3d895671a559a7ccb8b96e01587e8 (diff) | |
download | icestorm-master.tar.gz icestorm-master.tar.bz2 icestorm-master.zip |
icebram: fix WebAssembly compatibility
-rw-r--r-- | icebram/icebram.cc | 28 |
1 files changed, 15 insertions, 13 deletions
diff --git a/icebram/icebram.cc b/icebram/icebram.cc index 86ca11e..edebb9f 100644 --- a/icebram/icebram.cc +++ b/icebram/icebram.cc @@ -19,9 +19,9 @@ #include <stdio.h> #include <stdint.h> #include <stdlib.h> +#include <limits.h> #include <unistd.h> #include <sys/time.h> -#include <bits/stdc++.h> #include <cstring> #include <fstream> @@ -67,7 +67,7 @@ private: size_t m_word_size; std::vector<bool> parse_digits(std::vector<int> &digits) const; - void parse_line(std::string &line); + bool parse_line(std::string &line); public: HexFile(const char *filename, bool pad_words); virtual ~HexFile() { }; @@ -87,17 +87,15 @@ HexFile::HexFile(const char *filename, bool pad_words=false) if (!stream.is_open()) { fprintf(stderr, "Failed to open file %s\n", filename); - throw std::runtime_error("Unable to open input file"); + exit(1); } // Parse file std::string line; for (int i=1; std::getline(stream, line); i++) - try { - this->parse_line(line); - } catch (std::exception &e) { + if (!this->parse_line(line)) { fprintf(stderr, "Can't parse line %d of %s: %s\n", i, filename, line.c_str()); - throw std::runtime_error("Invalid input file"); + exit(1); } // Check word size @@ -107,7 +105,7 @@ HexFile::HexFile(const char *filename, bool pad_words=false) { if ((w.size() != this->m_word_size) && !pad_words) { fprintf(stderr, "Inconsistent word sizes in %s\n", filename); - throw std::runtime_error("Invalid input file"); + exit(1); } if (w.size() > this->m_word_size) this->m_word_size = w.size(); @@ -129,7 +127,7 @@ HexFile::parse_digits(std::vector<int> &digits) const return line_data; } -void +bool HexFile::parse_line(std::string &line) { std::vector<int> digits; @@ -152,12 +150,14 @@ HexFile::parse_line(std::string &line) digits.clear(); } } else { - throw std::runtime_error("Invalid char"); + return false; } } if (digits.size()) this->m_data.push_back(this->parse_digits(digits)); + + return true; } void @@ -197,7 +197,7 @@ HexFile::generate_pattern(HexFile &to) const if (pattern_from.size() == 256) { if (pattern.count(pattern_from)) { fprintf(stderr, "Conflicting from pattern for bit slice from_hexfile[%d:%d][%d]!\n", j, j-255, i); - throw std::runtime_error("Non-unique source pattern"); + exit(1); } pattern[pattern_from] = std::make_pair(pattern_to, 0); pattern_from.clear(), pattern_to.clear(); @@ -283,8 +283,10 @@ EBRData::load_data() digit = 10 + c - 'a'; else if ('A' <= c && c <= 'F') digit = 10 + c - 'A'; - else - throw std::runtime_error("Invalid char"); + else { + fprintf(stderr, "Invalid char in BRAM data\n"); + exit(1); + } idx -= 4; |