kernel: use C++11 fold hack to prevent recursion
[yosys.git] / kernel / rtlil.h
1 /* -*- c++ -*-
2 * yosys -- Yosys Open SYnthesis Suite
3 *
4 * Copyright (C) 2012 Clifford Wolf <clifford@clifford.at>
5 *
6 * Permission to use, copy, modify, and/or distribute this software for any
7 * purpose with or without fee is hereby granted, provided that the above
8 * copyright notice and this permission notice appear in all copies.
9 *
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17 *
18 */
19
20 #include "kernel/yosys.h"
21
22 #ifndef RTLIL_H
23 #define RTLIL_H
24
25 YOSYS_NAMESPACE_BEGIN
26
27 namespace RTLIL
28 {
29 enum State : unsigned char {
30 S0 = 0,
31 S1 = 1,
32 Sx = 2, // undefined value or conflict
33 Sz = 3, // high-impedance / not-connected
34 Sa = 4, // don't care (used only in cases)
35 Sm = 5 // marker (used internally by some passes)
36 };
37
38 enum SyncType : unsigned char {
39 ST0 = 0, // level sensitive: 0
40 ST1 = 1, // level sensitive: 1
41 STp = 2, // edge sensitive: posedge
42 STn = 3, // edge sensitive: negedge
43 STe = 4, // edge sensitive: both edges
44 STa = 5, // always active
45 STg = 6, // global clock
46 STi = 7 // init
47 };
48
49 enum ConstFlags : unsigned char {
50 CONST_FLAG_NONE = 0,
51 CONST_FLAG_STRING = 1,
52 CONST_FLAG_SIGNED = 2, // only used for parameters
53 CONST_FLAG_REAL = 4 // only used for parameters
54 };
55
56 struct Const;
57 struct AttrObject;
58 struct Selection;
59 struct Monitor;
60 struct Design;
61 struct Module;
62 struct Wire;
63 struct Memory;
64 struct Cell;
65 struct SigChunk;
66 struct SigBit;
67 struct SigSpecIterator;
68 struct SigSpecConstIterator;
69 struct SigSpec;
70 struct CaseRule;
71 struct SwitchRule;
72 struct SyncRule;
73 struct Process;
74
75 typedef std::pair<SigSpec, SigSpec> SigSig;
76
77 struct IdString
78 {
79 #undef YOSYS_XTRACE_GET_PUT
80 #undef YOSYS_SORT_ID_FREE_LIST
81 #undef YOSYS_USE_STICKY_IDS
82 #undef YOSYS_NO_IDS_REFCNT
83
84 // the global id string cache
85
86 static struct destruct_guard_t {
87 bool ok; // POD, will be initialized to zero
88 destruct_guard_t() { ok = true; }
89 ~destruct_guard_t() { ok = false; }
90 } destruct_guard;
91
92 static std::vector<char*> global_id_storage_;
93 static dict<char*, int, hash_cstr_ops> global_id_index_;
94 #ifndef YOSYS_NO_IDS_REFCNT
95 static std::vector<int> global_refcount_storage_;
96 static std::vector<int> global_free_idx_list_;
97 #endif
98
99 #ifdef YOSYS_USE_STICKY_IDS
100 static int last_created_idx_ptr_;
101 static int last_created_idx_[8];
102 #endif
103
104 static inline void xtrace_db_dump()
105 {
106 #ifdef YOSYS_XTRACE_GET_PUT
107 for (int idx = 0; idx < GetSize(global_id_storage_); idx++)
108 {
109 if (global_id_storage_.at(idx) == nullptr)
110 log("#X# DB-DUMP index %d: FREE\n", idx);
111 else
112 log("#X# DB-DUMP index %d: '%s' (ref %d)\n", idx, global_id_storage_.at(idx), global_refcount_storage_.at(idx));
113 }
114 #endif
115 }
116
117 static inline void checkpoint()
118 {
119 #ifdef YOSYS_USE_STICKY_IDS
120 last_created_idx_ptr_ = 0;
121 for (int i = 0; i < 8; i++) {
122 if (last_created_idx_[i])
123 put_reference(last_created_idx_[i]);
124 last_created_idx_[i] = 0;
125 }
126 #endif
127 #ifdef YOSYS_SORT_ID_FREE_LIST
128 std::sort(global_free_idx_list_.begin(), global_free_idx_list_.end(), std::greater<int>());
129 #endif
130 }
131
132 static inline int get_reference(int idx)
133 {
134 if (idx) {
135 #ifndef YOSYS_NO_IDS_REFCNT
136 global_refcount_storage_[idx]++;
137 #endif
138 #ifdef YOSYS_XTRACE_GET_PUT
139 if (yosys_xtrace)
140 log("#X# GET-BY-INDEX '%s' (index %d, refcount %d)\n", global_id_storage_.at(idx), idx, global_refcount_storage_.at(idx));
141 #endif
142 }
143 return idx;
144 }
145
146 static int get_reference(const char *p)
147 {
148 log_assert(destruct_guard.ok);
149
150 if (!p[0])
151 return 0;
152
153 log_assert(p[0] == '$' || p[0] == '\\');
154 log_assert(p[1] != 0);
155
156 auto it = global_id_index_.find((char*)p);
157 if (it != global_id_index_.end()) {
158 #ifndef YOSYS_NO_IDS_REFCNT
159 global_refcount_storage_.at(it->second)++;
160 #endif
161 #ifdef YOSYS_XTRACE_GET_PUT
162 if (yosys_xtrace)
163 log("#X# GET-BY-NAME '%s' (index %d, refcount %d)\n", global_id_storage_.at(it->second), it->second, global_refcount_storage_.at(it->second));
164 #endif
165 return it->second;
166 }
167
168 #ifndef YOSYS_NO_IDS_REFCNT
169 if (global_free_idx_list_.empty()) {
170 if (global_id_storage_.empty()) {
171 global_refcount_storage_.push_back(0);
172 global_id_storage_.push_back((char*)"");
173 global_id_index_[global_id_storage_.back()] = 0;
174 }
175 log_assert(global_id_storage_.size() < 0x40000000);
176 global_free_idx_list_.push_back(global_id_storage_.size());
177 global_id_storage_.push_back(nullptr);
178 global_refcount_storage_.push_back(0);
179 }
180
181 int idx = global_free_idx_list_.back();
182 global_free_idx_list_.pop_back();
183 global_id_storage_.at(idx) = strdup(p);
184 global_id_index_[global_id_storage_.at(idx)] = idx;
185 global_refcount_storage_.at(idx)++;
186 #else
187 if (global_id_storage_.empty()) {
188 global_id_storage_.push_back((char*)"");
189 global_id_index_[global_id_storage_.back()] = 0;
190 }
191 int idx = global_id_storage_.size();
192 global_id_storage_.push_back(strdup(p));
193 global_id_index_[global_id_storage_.back()] = idx;
194 #endif
195
196 if (yosys_xtrace) {
197 log("#X# New IdString '%s' with index %d.\n", p, idx);
198 log_backtrace("-X- ", yosys_xtrace-1);
199 }
200
201 #ifdef YOSYS_XTRACE_GET_PUT
202 if (yosys_xtrace)
203 log("#X# GET-BY-NAME '%s' (index %d, refcount %d)\n", global_id_storage_.at(idx), idx, global_refcount_storage_.at(idx));
204 #endif
205
206 #ifdef YOSYS_USE_STICKY_IDS
207 // Avoid Create->Delete->Create pattern
208 if (last_created_idx_[last_created_idx_ptr_])
209 put_reference(last_created_idx_[last_created_idx_ptr_]);
210 last_created_idx_[last_created_idx_ptr_] = idx;
211 get_reference(last_created_idx_[last_created_idx_ptr_]);
212 last_created_idx_ptr_ = (last_created_idx_ptr_ + 1) & 7;
213 #endif
214
215 return idx;
216 }
217
218 #ifndef YOSYS_NO_IDS_REFCNT
219 static inline void put_reference(int idx)
220 {
221 // put_reference() may be called from destructors after the destructor of
222 // global_refcount_storage_ has been run. in this case we simply do nothing.
223 if (!destruct_guard.ok || !idx)
224 return;
225
226 #ifdef YOSYS_XTRACE_GET_PUT
227 if (yosys_xtrace) {
228 log("#X# PUT '%s' (index %d, refcount %d)\n", global_id_storage_.at(idx), idx, global_refcount_storage_.at(idx));
229 }
230 #endif
231
232 int &refcount = global_refcount_storage_[idx];
233
234 if (--refcount > 0)
235 return;
236
237 log_assert(refcount == 0);
238 free_reference(idx);
239 }
240 static inline void free_reference(int idx)
241 {
242 if (yosys_xtrace) {
243 log("#X# Removed IdString '%s' with index %d.\n", global_id_storage_.at(idx), idx);
244 log_backtrace("-X- ", yosys_xtrace-1);
245 }
246
247 global_id_index_.erase(global_id_storage_.at(idx));
248 free(global_id_storage_.at(idx));
249 global_id_storage_.at(idx) = nullptr;
250 global_free_idx_list_.push_back(idx);
251 }
252 #else
253 static inline void put_reference(int) { }
254 #endif
255
256 // the actual IdString object is just is a single int
257
258 int index_;
259
260 inline IdString() : index_(0) { }
261 inline IdString(const char *str) : index_(get_reference(str)) { }
262 inline IdString(const IdString &str) : index_(get_reference(str.index_)) { }
263 inline IdString(IdString &&str) : index_(str.index_) { str.index_ = 0; }
264 inline IdString(const std::string &str) : index_(get_reference(str.c_str())) { }
265 inline ~IdString() { put_reference(index_); }
266
267 inline void operator=(const IdString &rhs) {
268 put_reference(index_);
269 index_ = get_reference(rhs.index_);
270 }
271
272 inline void operator=(const char *rhs) {
273 IdString id(rhs);
274 *this = id;
275 }
276
277 inline void operator=(const std::string &rhs) {
278 IdString id(rhs);
279 *this = id;
280 }
281
282 inline const char *c_str() const {
283 return global_id_storage_.at(index_);
284 }
285
286 inline std::string str() const {
287 return std::string(global_id_storage_.at(index_));
288 }
289
290 inline bool operator<(const IdString &rhs) const {
291 return index_ < rhs.index_;
292 }
293
294 inline bool operator==(const IdString &rhs) const { return index_ == rhs.index_; }
295 inline bool operator!=(const IdString &rhs) const { return index_ != rhs.index_; }
296
297 // The methods below are just convenience functions for better compatibility with std::string.
298
299 bool operator==(const std::string &rhs) const { return str() == rhs; }
300 bool operator!=(const std::string &rhs) const { return str() != rhs; }
301
302 bool operator==(const char *rhs) const { return strcmp(c_str(), rhs) == 0; }
303 bool operator!=(const char *rhs) const { return strcmp(c_str(), rhs) != 0; }
304
305 char operator[](size_t i) const {
306 const char *p = c_str();
307 for (; i != 0; i--, p++)
308 log_assert(*p != 0);
309 return *p;
310 }
311
312 std::string substr(size_t pos = 0, size_t len = std::string::npos) const {
313 if (len == std::string::npos || len >= strlen(c_str() + pos))
314 return std::string(c_str() + pos);
315 else
316 return std::string(c_str() + pos, len);
317 }
318
319 int compare(size_t pos, size_t len, const char* s) const {
320 return strncmp(c_str()+pos, s, len);
321 }
322
323 bool begins_with(const char* prefix) const {
324 size_t len = strlen(prefix);
325 if (size() < len) return false;
326 return compare(0, len, prefix) == 0;
327 }
328
329 bool ends_with(const char* suffix) const {
330 size_t len = strlen(suffix);
331 if (size() < len) return false;
332 return compare(size()-len, len, suffix) == 0;
333 }
334
335 size_t size() const {
336 return strlen(c_str());
337 }
338
339 bool empty() const {
340 return c_str()[0] == 0;
341 }
342
343 void clear() {
344 *this = IdString();
345 }
346
347 unsigned int hash() const {
348 return index_;
349 }
350
351 // The following is a helper key_compare class. Instead of for example std::set<Cell*>
352 // use std::set<Cell*, IdString::compare_ptr_by_name<Cell>> if the order of cells in the
353 // set has an influence on the algorithm.
354
355 template<typename T> struct compare_ptr_by_name {
356 bool operator()(const T *a, const T *b) const {
357 return (a == nullptr || b == nullptr) ? (a < b) : (a->name < b->name);
358 }
359 };
360
361 // often one needs to check if a given IdString is part of a list (for example a list
362 // of cell types). the following functions helps with that.
363
364 template<typename... Args>
365 bool in(Args... args) const {
366 //return in(first) || in(rest...);
367
368 // Credit: https://articles.emptycrate.com/2016/05/14/folds_in_cpp11_ish.html
369 bool result = false;
370 (void) std::initializer_list<int>{ (result = result || in(args), 0)... };
371 return result;
372 }
373
374 bool in(IdString rhs) const { return *this == rhs; }
375 bool in(const char *rhs) const { return *this == rhs; }
376 bool in(const std::string &rhs) const { return *this == rhs; }
377 bool in(const pool<IdString> &rhs) const { return rhs.count(*this) != 0; }
378 };
379
380 namespace ID {
381 #define X(_id) extern IdString _id;
382 #include "constids.inc"
383 #undef X
384 };
385
386 extern dict<std::string, std::string> constpad;
387
388 static inline std::string escape_id(const std::string &str) {
389 if (str.size() > 0 && str[0] != '\\' && str[0] != '$')
390 return "\\" + str;
391 return str;
392 }
393
394 static inline std::string unescape_id(const std::string &str) {
395 if (str.size() < 2)
396 return str;
397 if (str[0] != '\\')
398 return str;
399 if (str[1] == '$' || str[1] == '\\')
400 return str;
401 if (str[1] >= '0' && str[1] <= '9')
402 return str;
403 return str.substr(1);
404 }
405
406 static inline std::string unescape_id(RTLIL::IdString str) {
407 return unescape_id(str.str());
408 }
409
410 static inline const char *id2cstr(RTLIL::IdString str) {
411 return log_id(str);
412 }
413
414 template <typename T> struct sort_by_name_id {
415 bool operator()(T *a, T *b) const {
416 return a->name < b->name;
417 }
418 };
419
420 template <typename T> struct sort_by_name_str {
421 bool operator()(T *a, T *b) const {
422 return strcmp(a->name.c_str(), b->name.c_str()) < 0;
423 }
424 };
425
426 struct sort_by_id_str {
427 bool operator()(RTLIL::IdString a, RTLIL::IdString b) const {
428 return strcmp(a.c_str(), b.c_str()) < 0;
429 }
430 };
431
432 // see calc.cc for the implementation of this functions
433 RTLIL::Const const_not (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
434 RTLIL::Const const_and (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
435 RTLIL::Const const_or (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
436 RTLIL::Const const_xor (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
437 RTLIL::Const const_xnor (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
438
439 RTLIL::Const const_reduce_and (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
440 RTLIL::Const const_reduce_or (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
441 RTLIL::Const const_reduce_xor (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
442 RTLIL::Const const_reduce_xnor (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
443 RTLIL::Const const_reduce_bool (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
444
445 RTLIL::Const const_logic_not (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
446 RTLIL::Const const_logic_and (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
447 RTLIL::Const const_logic_or (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
448
449 RTLIL::Const const_shl (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
450 RTLIL::Const const_shr (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
451 RTLIL::Const const_sshl (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
452 RTLIL::Const const_sshr (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
453 RTLIL::Const const_shift (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
454 RTLIL::Const const_shiftx (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
455
456 RTLIL::Const const_lt (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
457 RTLIL::Const const_le (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
458 RTLIL::Const const_eq (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
459 RTLIL::Const const_ne (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
460 RTLIL::Const const_eqx (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
461 RTLIL::Const const_nex (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
462 RTLIL::Const const_ge (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
463 RTLIL::Const const_gt (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
464
465 RTLIL::Const const_add (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
466 RTLIL::Const const_sub (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
467 RTLIL::Const const_mul (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
468 RTLIL::Const const_div (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
469 RTLIL::Const const_mod (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
470 RTLIL::Const const_pow (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
471
472 RTLIL::Const const_pos (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
473 RTLIL::Const const_neg (const RTLIL::Const &arg1, const RTLIL::Const &arg2, bool signed1, bool signed2, int result_len);
474
475
476 // This iterator-range-pair is used for Design::modules(), Module::wires() and Module::cells().
477 // It maintains a reference counter that is used to make sure that the container is not modified while being iterated over.
478
479 template<typename T>
480 struct ObjIterator {
481 using iterator_category = std::forward_iterator_tag;
482 using value_type = T;
483 using difference_type = ptrdiff_t;
484 using pointer = T*;
485 using reference = T&;
486 typename dict<RTLIL::IdString, T>::iterator it;
487 dict<RTLIL::IdString, T> *list_p;
488 int *refcount_p;
489
490 ObjIterator() : list_p(nullptr), refcount_p(nullptr) {
491 }
492
493 ObjIterator(decltype(list_p) list_p, int *refcount_p) : list_p(list_p), refcount_p(refcount_p) {
494 if (list_p->empty()) {
495 this->list_p = nullptr;
496 this->refcount_p = nullptr;
497 } else {
498 it = list_p->begin();
499 (*refcount_p)++;
500 }
501 }
502
503 ObjIterator(const RTLIL::ObjIterator<T> &other) {
504 it = other.it;
505 list_p = other.list_p;
506 refcount_p = other.refcount_p;
507 if (refcount_p)
508 (*refcount_p)++;
509 }
510
511 ObjIterator &operator=(const RTLIL::ObjIterator<T> &other) {
512 if (refcount_p)
513 (*refcount_p)--;
514 it = other.it;
515 list_p = other.list_p;
516 refcount_p = other.refcount_p;
517 if (refcount_p)
518 (*refcount_p)++;
519 return *this;
520 }
521
522 ~ObjIterator() {
523 if (refcount_p)
524 (*refcount_p)--;
525 }
526
527 inline T operator*() const {
528 log_assert(list_p != nullptr);
529 return it->second;
530 }
531
532 inline bool operator!=(const RTLIL::ObjIterator<T> &other) const {
533 if (list_p == nullptr || other.list_p == nullptr)
534 return list_p != other.list_p;
535 return it != other.it;
536 }
537
538
539 inline bool operator==(const RTLIL::ObjIterator<T> &other) const {
540 return !(*this != other);
541 }
542
543 inline ObjIterator<T>& operator++() {
544 log_assert(list_p != nullptr);
545 if (++it == list_p->end()) {
546 (*refcount_p)--;
547 list_p = nullptr;
548 refcount_p = nullptr;
549 }
550 return *this;
551 }
552
553 inline const ObjIterator<T> operator++(int) {
554 ObjIterator<T> result(*this);
555 ++(*this);
556 return result;
557 }
558 };
559
560 template<typename T>
561 struct ObjRange
562 {
563 dict<RTLIL::IdString, T> *list_p;
564 int *refcount_p;
565
566 ObjRange(decltype(list_p) list_p, int *refcount_p) : list_p(list_p), refcount_p(refcount_p) { }
567 RTLIL::ObjIterator<T> begin() { return RTLIL::ObjIterator<T>(list_p, refcount_p); }
568 RTLIL::ObjIterator<T> end() { return RTLIL::ObjIterator<T>(); }
569
570 size_t size() const {
571 return list_p->size();
572 }
573
574 operator pool<T>() const {
575 pool<T> result;
576 for (auto &it : *list_p)
577 result.insert(it.second);
578 return result;
579 }
580
581 operator std::vector<T>() const {
582 std::vector<T> result;
583 result.reserve(list_p->size());
584 for (auto &it : *list_p)
585 result.push_back(it.second);
586 return result;
587 }
588
589 pool<T> to_pool() const { return *this; }
590 std::vector<T> to_vector() const { return *this; }
591 };
592 };
593
594 struct RTLIL::Const
595 {
596 int flags;
597 std::vector<RTLIL::State> bits;
598
599 Const();
600 Const(std::string str);
601 Const(int val, int width = 32);
602 Const(RTLIL::State bit, int width = 1);
603 Const(const std::vector<RTLIL::State> &bits) : bits(bits) { flags = CONST_FLAG_NONE; }
604 Const(const std::vector<bool> &bits);
605 Const(const RTLIL::Const &c);
606 RTLIL::Const &operator =(const RTLIL::Const &other) = default;
607
608 bool operator <(const RTLIL::Const &other) const;
609 bool operator ==(const RTLIL::Const &other) const;
610 bool operator !=(const RTLIL::Const &other) const;
611
612 bool as_bool() const;
613 int as_int(bool is_signed = false) const;
614 std::string as_string() const;
615 static Const from_string(const std::string &str);
616
617 std::string decode_string() const;
618
619 inline int size() const { return bits.size(); }
620 inline bool empty() const { return bits.empty(); }
621 inline RTLIL::State &operator[](int index) { return bits.at(index); }
622 inline const RTLIL::State &operator[](int index) const { return bits.at(index); }
623 inline decltype(bits)::iterator begin() { return bits.begin(); }
624 inline decltype(bits)::iterator end() { return bits.end(); }
625
626 bool is_fully_zero() const;
627 bool is_fully_ones() const;
628 bool is_fully_def() const;
629 bool is_fully_undef() const;
630
631 inline RTLIL::Const extract(int offset, int len = 1, RTLIL::State padding = RTLIL::State::S0) const {
632 RTLIL::Const ret;
633 ret.bits.reserve(len);
634 for (int i = offset; i < offset + len; i++)
635 ret.bits.push_back(i < GetSize(bits) ? bits[i] : padding);
636 return ret;
637 }
638
639 void extu(int width) {
640 bits.resize(width, RTLIL::State::S0);
641 }
642
643 void exts(int width) {
644 bits.resize(width, bits.empty() ? RTLIL::State::Sx : bits.back());
645 }
646
647 inline unsigned int hash() const {
648 unsigned int h = mkhash_init;
649 for (auto b : bits)
650 mkhash(h, b);
651 return h;
652 }
653 };
654
655 struct RTLIL::AttrObject
656 {
657 dict<RTLIL::IdString, RTLIL::Const> attributes;
658
659 void set_bool_attribute(RTLIL::IdString id, bool value=true);
660 bool get_bool_attribute(RTLIL::IdString id) const;
661
662 bool get_blackbox_attribute(bool ignore_wb=false) const {
663 return get_bool_attribute(ID::blackbox) || (!ignore_wb && get_bool_attribute(ID::whitebox));
664 }
665
666 void set_strpool_attribute(RTLIL::IdString id, const pool<string> &data);
667 void add_strpool_attribute(RTLIL::IdString id, const pool<string> &data);
668 pool<string> get_strpool_attribute(RTLIL::IdString id) const;
669
670 void set_src_attribute(const std::string &src);
671 std::string get_src_attribute() const;
672 };
673
674 struct RTLIL::SigChunk
675 {
676 RTLIL::Wire *wire;
677 std::vector<RTLIL::State> data; // only used if wire == NULL, LSB at index 0
678 int width, offset;
679
680 SigChunk();
681 SigChunk(const RTLIL::Const &value);
682 SigChunk(RTLIL::Wire *wire);
683 SigChunk(RTLIL::Wire *wire, int offset, int width = 1);
684 SigChunk(const std::string &str);
685 SigChunk(int val, int width = 32);
686 SigChunk(RTLIL::State bit, int width = 1);
687 SigChunk(const RTLIL::SigBit &bit);
688 SigChunk(const RTLIL::SigChunk &sigchunk);
689 RTLIL::SigChunk &operator =(const RTLIL::SigChunk &other) = default;
690
691 RTLIL::SigChunk extract(int offset, int length) const;
692 inline int size() const { return width; }
693
694 bool operator <(const RTLIL::SigChunk &other) const;
695 bool operator ==(const RTLIL::SigChunk &other) const;
696 bool operator !=(const RTLIL::SigChunk &other) const;
697 };
698
699 struct RTLIL::SigBit
700 {
701 RTLIL::Wire *wire;
702 union {
703 RTLIL::State data; // used if wire == NULL
704 int offset; // used if wire != NULL
705 };
706
707 SigBit();
708 SigBit(RTLIL::State bit);
709 SigBit(bool bit);
710 SigBit(RTLIL::Wire *wire);
711 SigBit(RTLIL::Wire *wire, int offset);
712 SigBit(const RTLIL::SigChunk &chunk);
713 SigBit(const RTLIL::SigChunk &chunk, int index);
714 SigBit(const RTLIL::SigSpec &sig);
715 SigBit(const RTLIL::SigBit &sigbit);
716 RTLIL::SigBit &operator =(const RTLIL::SigBit &other) = default;
717
718 bool operator <(const RTLIL::SigBit &other) const;
719 bool operator ==(const RTLIL::SigBit &other) const;
720 bool operator !=(const RTLIL::SigBit &other) const;
721 unsigned int hash() const;
722 };
723
724 struct RTLIL::SigSpecIterator : public std::iterator<std::input_iterator_tag, RTLIL::SigSpec>
725 {
726 RTLIL::SigSpec *sig_p;
727 int index;
728
729 inline RTLIL::SigBit &operator*() const;
730 inline bool operator!=(const RTLIL::SigSpecIterator &other) const { return index != other.index; }
731 inline bool operator==(const RTLIL::SigSpecIterator &other) const { return index == other.index; }
732 inline void operator++() { index++; }
733 };
734
735 struct RTLIL::SigSpecConstIterator : public std::iterator<std::input_iterator_tag, RTLIL::SigSpec>
736 {
737 const RTLIL::SigSpec *sig_p;
738 int index;
739
740 inline const RTLIL::SigBit &operator*() const;
741 inline bool operator!=(const RTLIL::SigSpecConstIterator &other) const { return index != other.index; }
742 inline bool operator==(const RTLIL::SigSpecIterator &other) const { return index == other.index; }
743 inline void operator++() { index++; }
744 };
745
746 struct RTLIL::SigSpec
747 {
748 private:
749 int width_;
750 unsigned long hash_;
751 std::vector<RTLIL::SigChunk> chunks_; // LSB at index 0
752 std::vector<RTLIL::SigBit> bits_; // LSB at index 0
753
754 void pack() const;
755 void unpack() const;
756 void updhash() const;
757
758 inline bool packed() const {
759 return bits_.empty();
760 }
761
762 inline void inline_unpack() const {
763 if (!chunks_.empty())
764 unpack();
765 }
766
767 // Only used by Module::remove(const pool<Wire*> &wires)
768 // but cannot be more specific as it isn't yet declared
769 friend struct RTLIL::Module;
770
771 public:
772 SigSpec();
773 SigSpec(const RTLIL::SigSpec &other);
774 SigSpec(std::initializer_list<RTLIL::SigSpec> parts);
775 RTLIL::SigSpec &operator=(const RTLIL::SigSpec &other);
776
777 SigSpec(const RTLIL::Const &value);
778 SigSpec(const RTLIL::SigChunk &chunk);
779 SigSpec(RTLIL::Wire *wire);
780 SigSpec(RTLIL::Wire *wire, int offset, int width = 1);
781 SigSpec(const std::string &str);
782 SigSpec(int val, int width = 32);
783 SigSpec(RTLIL::State bit, int width = 1);
784 SigSpec(const RTLIL::SigBit &bit, int width = 1);
785 SigSpec(const std::vector<RTLIL::SigChunk> &chunks);
786 SigSpec(const std::vector<RTLIL::SigBit> &bits);
787 SigSpec(const pool<RTLIL::SigBit> &bits);
788 SigSpec(const std::set<RTLIL::SigBit> &bits);
789 SigSpec(bool bit);
790
791 SigSpec(RTLIL::SigSpec &&other) {
792 width_ = other.width_;
793 hash_ = other.hash_;
794 chunks_ = std::move(other.chunks_);
795 bits_ = std::move(other.bits_);
796 }
797
798 const RTLIL::SigSpec &operator=(RTLIL::SigSpec &&other) {
799 width_ = other.width_;
800 hash_ = other.hash_;
801 chunks_ = std::move(other.chunks_);
802 bits_ = std::move(other.bits_);
803 return *this;
804 }
805
806 size_t get_hash() const {
807 if (!hash_) hash();
808 return hash_;
809 }
810
811 inline const std::vector<RTLIL::SigChunk> &chunks() const { pack(); return chunks_; }
812 inline const std::vector<RTLIL::SigBit> &bits() const { inline_unpack(); return bits_; }
813
814 inline int size() const { return width_; }
815 inline bool empty() const { return width_ == 0; }
816
817 inline RTLIL::SigBit &operator[](int index) { inline_unpack(); return bits_.at(index); }
818 inline const RTLIL::SigBit &operator[](int index) const { inline_unpack(); return bits_.at(index); }
819
820 inline RTLIL::SigSpecIterator begin() { RTLIL::SigSpecIterator it; it.sig_p = this; it.index = 0; return it; }
821 inline RTLIL::SigSpecIterator end() { RTLIL::SigSpecIterator it; it.sig_p = this; it.index = width_; return it; }
822
823 inline RTLIL::SigSpecConstIterator begin() const { RTLIL::SigSpecConstIterator it; it.sig_p = this; it.index = 0; return it; }
824 inline RTLIL::SigSpecConstIterator end() const { RTLIL::SigSpecConstIterator it; it.sig_p = this; it.index = width_; return it; }
825
826 void sort();
827 void sort_and_unify();
828
829 void replace(const RTLIL::SigSpec &pattern, const RTLIL::SigSpec &with);
830 void replace(const RTLIL::SigSpec &pattern, const RTLIL::SigSpec &with, RTLIL::SigSpec *other) const;
831
832 void replace(const dict<RTLIL::SigBit, RTLIL::SigBit> &rules);
833 void replace(const dict<RTLIL::SigBit, RTLIL::SigBit> &rules, RTLIL::SigSpec *other) const;
834
835 void replace(const std::map<RTLIL::SigBit, RTLIL::SigBit> &rules);
836 void replace(const std::map<RTLIL::SigBit, RTLIL::SigBit> &rules, RTLIL::SigSpec *other) const;
837
838 void replace(int offset, const RTLIL::SigSpec &with);
839
840 void remove(const RTLIL::SigSpec &pattern);
841 void remove(const RTLIL::SigSpec &pattern, RTLIL::SigSpec *other) const;
842 void remove2(const RTLIL::SigSpec &pattern, RTLIL::SigSpec *other);
843
844 void remove(const pool<RTLIL::SigBit> &pattern);
845 void remove(const pool<RTLIL::SigBit> &pattern, RTLIL::SigSpec *other) const;
846 void remove2(const pool<RTLIL::SigBit> &pattern, RTLIL::SigSpec *other);
847 void remove2(const std::set<RTLIL::SigBit> &pattern, RTLIL::SigSpec *other);
848
849 void remove(int offset, int length = 1);
850 void remove_const();
851
852 RTLIL::SigSpec extract(const RTLIL::SigSpec &pattern, const RTLIL::SigSpec *other = NULL) const;
853 RTLIL::SigSpec extract(const pool<RTLIL::SigBit> &pattern, const RTLIL::SigSpec *other = NULL) const;
854 RTLIL::SigSpec extract(int offset, int length = 1) const;
855 RTLIL::SigSpec extract_end(int offset) const { return extract(offset, width_ - offset); }
856
857 void append(const RTLIL::SigSpec &signal);
858 inline void append(Wire *wire) { append(RTLIL::SigSpec(wire)); }
859 inline void append(const RTLIL::SigChunk &chunk) { append(RTLIL::SigSpec(chunk)); }
860 inline void append(const RTLIL::Const &const_) { append(RTLIL::SigSpec(const_)); }
861
862 void append(const RTLIL::SigBit &bit);
863 inline void append(RTLIL::State state) { append(RTLIL::SigBit(state)); }
864 inline void append(bool bool_) { append(RTLIL::SigBit(bool_)); }
865
866 void extend_u0(int width, bool is_signed = false);
867
868 RTLIL::SigSpec repeat(int num) const;
869
870 void reverse() { inline_unpack(); std::reverse(bits_.begin(), bits_.end()); }
871
872 bool operator <(const RTLIL::SigSpec &other) const;
873 bool operator ==(const RTLIL::SigSpec &other) const;
874 inline bool operator !=(const RTLIL::SigSpec &other) const { return !(*this == other); }
875
876 bool is_wire() const;
877 bool is_chunk() const;
878 inline bool is_bit() const { return width_ == 1; }
879
880 bool is_fully_const() const;
881 bool is_fully_zero() const;
882 bool is_fully_ones() const;
883 bool is_fully_def() const;
884 bool is_fully_undef() const;
885 bool has_const() const;
886 bool has_marked_bits() const;
887
888 bool as_bool() const;
889 int as_int(bool is_signed = false) const;
890 std::string as_string() const;
891 RTLIL::Const as_const() const;
892 RTLIL::Wire *as_wire() const;
893 RTLIL::SigChunk as_chunk() const;
894 RTLIL::SigBit as_bit() const;
895
896 bool match(const char* pattern) const;
897
898 std::set<RTLIL::SigBit> to_sigbit_set() const;
899 pool<RTLIL::SigBit> to_sigbit_pool() const;
900 std::vector<RTLIL::SigBit> to_sigbit_vector() const;
901 std::map<RTLIL::SigBit, RTLIL::SigBit> to_sigbit_map(const RTLIL::SigSpec &other) const;
902 dict<RTLIL::SigBit, RTLIL::SigBit> to_sigbit_dict(const RTLIL::SigSpec &other) const;
903
904 static bool parse(RTLIL::SigSpec &sig, RTLIL::Module *module, std::string str);
905 static bool parse_sel(RTLIL::SigSpec &sig, RTLIL::Design *design, RTLIL::Module *module, std::string str);
906 static bool parse_rhs(const RTLIL::SigSpec &lhs, RTLIL::SigSpec &sig, RTLIL::Module *module, std::string str);
907
908 operator std::vector<RTLIL::SigChunk>() const { return chunks(); }
909 operator std::vector<RTLIL::SigBit>() const { return bits(); }
910 const RTLIL::SigBit &at(int offset, const RTLIL::SigBit &defval) { return offset < width_ ? (*this)[offset] : defval; }
911
912 unsigned int hash() const { if (!hash_) updhash(); return hash_; };
913
914 #ifndef NDEBUG
915 void check() const;
916 #else
917 void check() const { }
918 #endif
919 };
920
921 struct RTLIL::Selection
922 {
923 bool full_selection;
924 pool<RTLIL::IdString> selected_modules;
925 dict<RTLIL::IdString, pool<RTLIL::IdString>> selected_members;
926
927 Selection(bool full = true) : full_selection(full) { }
928
929 bool selected_module(RTLIL::IdString mod_name) const;
930 bool selected_whole_module(RTLIL::IdString mod_name) const;
931 bool selected_member(RTLIL::IdString mod_name, RTLIL::IdString memb_name) const;
932 void optimize(RTLIL::Design *design);
933
934 template<typename T1> void select(T1 *module) {
935 if (!full_selection && selected_modules.count(module->name) == 0) {
936 selected_modules.insert(module->name);
937 selected_members.erase(module->name);
938 }
939 }
940
941 template<typename T1, typename T2> void select(T1 *module, T2 *member) {
942 if (!full_selection && selected_modules.count(module->name) == 0)
943 selected_members[module->name].insert(member->name);
944 }
945
946 bool empty() const {
947 return !full_selection && selected_modules.empty() && selected_members.empty();
948 }
949 };
950
951 struct RTLIL::Monitor
952 {
953 unsigned int hashidx_;
954 unsigned int hash() const { return hashidx_; }
955
956 Monitor() {
957 static unsigned int hashidx_count = 123456789;
958 hashidx_count = mkhash_xorshift(hashidx_count);
959 hashidx_ = hashidx_count;
960 }
961
962 virtual ~Monitor() { }
963 virtual void notify_module_add(RTLIL::Module*) { }
964 virtual void notify_module_del(RTLIL::Module*) { }
965 virtual void notify_connect(RTLIL::Cell*, const RTLIL::IdString&, const RTLIL::SigSpec&, const RTLIL::SigSpec&) { }
966 virtual void notify_connect(RTLIL::Module*, const RTLIL::SigSig&) { }
967 virtual void notify_connect(RTLIL::Module*, const std::vector<RTLIL::SigSig>&) { }
968 virtual void notify_blackout(RTLIL::Module*) { }
969 };
970
971 // Forward declaration; defined in preproc.h.
972 struct define_map_t;
973
974 struct RTLIL::Design
975 {
976 unsigned int hashidx_;
977 unsigned int hash() const { return hashidx_; }
978
979 pool<RTLIL::Monitor*> monitors;
980 dict<std::string, std::string> scratchpad;
981
982 int refcount_modules_;
983 dict<RTLIL::IdString, RTLIL::Module*> modules_;
984 std::vector<AST::AstNode*> verilog_packages, verilog_globals;
985 std::unique_ptr<define_map_t> verilog_defines;
986
987 std::vector<RTLIL::Selection> selection_stack;
988 dict<RTLIL::IdString, RTLIL::Selection> selection_vars;
989 std::string selected_active_module;
990
991 Design();
992 ~Design();
993
994 RTLIL::ObjRange<RTLIL::Module*> modules();
995 RTLIL::Module *module(RTLIL::IdString name);
996 RTLIL::Module *top_module();
997
998 bool has(RTLIL::IdString id) const {
999 return modules_.count(id) != 0;
1000 }
1001
1002 void add(RTLIL::Module *module);
1003 RTLIL::Module *addModule(RTLIL::IdString name);
1004 void remove(RTLIL::Module *module);
1005 void rename(RTLIL::Module *module, RTLIL::IdString new_name);
1006
1007 void scratchpad_unset(const std::string &varname);
1008
1009 void scratchpad_set_int(const std::string &varname, int value);
1010 void scratchpad_set_bool(const std::string &varname, bool value);
1011 void scratchpad_set_string(const std::string &varname, std::string value);
1012
1013 int scratchpad_get_int(const std::string &varname, int default_value = 0) const;
1014 bool scratchpad_get_bool(const std::string &varname, bool default_value = false) const;
1015 std::string scratchpad_get_string(const std::string &varname, const std::string &default_value = std::string()) const;
1016
1017 void sort();
1018 void check();
1019 void optimize();
1020
1021 bool selected_module(RTLIL::IdString mod_name) const;
1022 bool selected_whole_module(RTLIL::IdString mod_name) const;
1023 bool selected_member(RTLIL::IdString mod_name, RTLIL::IdString memb_name) const;
1024
1025 bool selected_module(RTLIL::Module *mod) const;
1026 bool selected_whole_module(RTLIL::Module *mod) const;
1027
1028 RTLIL::Selection &selection() {
1029 return selection_stack.back();
1030 }
1031
1032 const RTLIL::Selection &selection() const {
1033 return selection_stack.back();
1034 }
1035
1036 bool full_selection() const {
1037 return selection_stack.back().full_selection;
1038 }
1039
1040 template<typename T1> bool selected(T1 *module) const {
1041 return selected_module(module->name);
1042 }
1043
1044 template<typename T1, typename T2> bool selected(T1 *module, T2 *member) const {
1045 return selected_member(module->name, member->name);
1046 }
1047
1048 template<typename T1, typename T2> void select(T1 *module, T2 *member) {
1049 if (selection_stack.size() > 0) {
1050 RTLIL::Selection &sel = selection_stack.back();
1051 sel.select(module, member);
1052 }
1053 }
1054
1055
1056 std::vector<RTLIL::Module*> selected_modules() const;
1057 std::vector<RTLIL::Module*> selected_whole_modules() const;
1058 std::vector<RTLIL::Module*> selected_whole_modules_warn() const;
1059 #ifdef WITH_PYTHON
1060 static std::map<unsigned int, RTLIL::Design*> *get_all_designs(void);
1061 #endif
1062 };
1063
1064 struct RTLIL::Module : public RTLIL::AttrObject
1065 {
1066 unsigned int hashidx_;
1067 unsigned int hash() const { return hashidx_; }
1068
1069 protected:
1070 void add(RTLIL::Wire *wire);
1071 void add(RTLIL::Cell *cell);
1072
1073 public:
1074 RTLIL::Design *design;
1075 pool<RTLIL::Monitor*> monitors;
1076
1077 int refcount_wires_;
1078 int refcount_cells_;
1079
1080 dict<RTLIL::IdString, RTLIL::Wire*> wires_;
1081 dict<RTLIL::IdString, RTLIL::Cell*> cells_;
1082 std::vector<RTLIL::SigSig> connections_;
1083
1084 RTLIL::IdString name;
1085 pool<RTLIL::IdString> avail_parameters;
1086 dict<RTLIL::IdString, RTLIL::Memory*> memories;
1087 dict<RTLIL::IdString, RTLIL::Process*> processes;
1088
1089 Module();
1090 virtual ~Module();
1091 virtual RTLIL::IdString derive(RTLIL::Design *design, const dict<RTLIL::IdString, RTLIL::Const> &parameters, bool mayfail = false);
1092 virtual RTLIL::IdString derive(RTLIL::Design *design, const dict<RTLIL::IdString, RTLIL::Const> &parameters, const dict<RTLIL::IdString, RTLIL::Module*> &interfaces, const dict<RTLIL::IdString, RTLIL::IdString> &modports, bool mayfail = false);
1093 virtual size_t count_id(RTLIL::IdString id);
1094 virtual void reprocess_module(RTLIL::Design *design, const dict<RTLIL::IdString, RTLIL::Module *> &local_interfaces);
1095
1096 virtual void sort();
1097 virtual void check();
1098 virtual void optimize();
1099 virtual void makeblackbox();
1100
1101 void connect(const RTLIL::SigSig &conn);
1102 void connect(const RTLIL::SigSpec &lhs, const RTLIL::SigSpec &rhs);
1103 void new_connections(const std::vector<RTLIL::SigSig> &new_conn);
1104 const std::vector<RTLIL::SigSig> &connections() const;
1105
1106 std::vector<RTLIL::IdString> ports;
1107 void fixup_ports();
1108
1109 template<typename T> void rewrite_sigspecs(T &functor);
1110 template<typename T> void rewrite_sigspecs2(T &functor);
1111 void cloneInto(RTLIL::Module *new_mod) const;
1112 virtual RTLIL::Module *clone() const;
1113
1114 bool has_memories() const;
1115 bool has_processes() const;
1116
1117 bool has_memories_warn() const;
1118 bool has_processes_warn() const;
1119
1120 std::vector<RTLIL::Wire*> selected_wires() const;
1121 std::vector<RTLIL::Cell*> selected_cells() const;
1122
1123 template<typename T> bool selected(T *member) const {
1124 return design->selected_member(name, member->name);
1125 }
1126
1127 RTLIL::Wire* wire(RTLIL::IdString id) { return wires_.count(id) ? wires_.at(id) : nullptr; }
1128 RTLIL::Cell* cell(RTLIL::IdString id) { return cells_.count(id) ? cells_.at(id) : nullptr; }
1129
1130 RTLIL::ObjRange<RTLIL::Wire*> wires() { return RTLIL::ObjRange<RTLIL::Wire*>(&wires_, &refcount_wires_); }
1131 RTLIL::ObjRange<RTLIL::Cell*> cells() { return RTLIL::ObjRange<RTLIL::Cell*>(&cells_, &refcount_cells_); }
1132
1133 // Removing wires is expensive. If you have to remove wires, remove them all at once.
1134 void remove(const pool<RTLIL::Wire*> &wires);
1135 void remove(RTLIL::Cell *cell);
1136
1137 void rename(RTLIL::Wire *wire, RTLIL::IdString new_name);
1138 void rename(RTLIL::Cell *cell, RTLIL::IdString new_name);
1139 void rename(RTLIL::IdString old_name, RTLIL::IdString new_name);
1140
1141 void swap_names(RTLIL::Wire *w1, RTLIL::Wire *w2);
1142 void swap_names(RTLIL::Cell *c1, RTLIL::Cell *c2);
1143
1144 RTLIL::IdString uniquify(RTLIL::IdString name);
1145 RTLIL::IdString uniquify(RTLIL::IdString name, int &index);
1146
1147 RTLIL::Wire *addWire(RTLIL::IdString name, int width = 1);
1148 RTLIL::Wire *addWire(RTLIL::IdString name, const RTLIL::Wire *other);
1149
1150 RTLIL::Cell *addCell(RTLIL::IdString name, RTLIL::IdString type);
1151 RTLIL::Cell *addCell(RTLIL::IdString name, const RTLIL::Cell *other);
1152
1153 // The add* methods create a cell and return the created cell. All signals must exist in advance.
1154
1155 RTLIL::Cell* addNot (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1156 RTLIL::Cell* addPos (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1157 RTLIL::Cell* addNeg (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1158
1159 RTLIL::Cell* addAnd (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1160 RTLIL::Cell* addOr (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1161 RTLIL::Cell* addXor (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1162 RTLIL::Cell* addXnor (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1163
1164 RTLIL::Cell* addReduceAnd (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1165 RTLIL::Cell* addReduceOr (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1166 RTLIL::Cell* addReduceXor (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1167 RTLIL::Cell* addReduceXnor (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1168 RTLIL::Cell* addReduceBool (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1169
1170 RTLIL::Cell* addShl (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1171 RTLIL::Cell* addShr (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1172 RTLIL::Cell* addSshl (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1173 RTLIL::Cell* addSshr (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1174 RTLIL::Cell* addShift (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1175 RTLIL::Cell* addShiftx (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1176
1177 RTLIL::Cell* addLt (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1178 RTLIL::Cell* addLe (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1179 RTLIL::Cell* addEq (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1180 RTLIL::Cell* addNe (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1181 RTLIL::Cell* addEqx (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1182 RTLIL::Cell* addNex (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1183 RTLIL::Cell* addGe (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1184 RTLIL::Cell* addGt (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1185
1186 RTLIL::Cell* addAdd (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1187 RTLIL::Cell* addSub (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1188 RTLIL::Cell* addMul (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1189 RTLIL::Cell* addDiv (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1190 RTLIL::Cell* addMod (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1191 RTLIL::Cell* addPow (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool a_signed = false, bool b_signed = false, const std::string &src = "");
1192
1193 RTLIL::Cell* addLogicNot (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1194 RTLIL::Cell* addLogicAnd (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1195 RTLIL::Cell* addLogicOr (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, bool is_signed = false, const std::string &src = "");
1196
1197 RTLIL::Cell* addMux (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_s, const RTLIL::SigSpec &sig_y, const std::string &src = "");
1198 RTLIL::Cell* addPmux (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_s, const RTLIL::SigSpec &sig_y, const std::string &src = "");
1199
1200 RTLIL::Cell* addSlice (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_y, RTLIL::Const offset, const std::string &src = "");
1201 RTLIL::Cell* addConcat (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, const std::string &src = "");
1202 RTLIL::Cell* addLut (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_y, RTLIL::Const lut, const std::string &src = "");
1203 RTLIL::Cell* addTribuf (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_y, const std::string &src = "");
1204 RTLIL::Cell* addAssert (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_en, const std::string &src = "");
1205 RTLIL::Cell* addAssume (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_en, const std::string &src = "");
1206 RTLIL::Cell* addLive (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_en, const std::string &src = "");
1207 RTLIL::Cell* addFair (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_en, const std::string &src = "");
1208 RTLIL::Cell* addCover (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_en, const std::string &src = "");
1209 RTLIL::Cell* addEquiv (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_y, const std::string &src = "");
1210
1211 RTLIL::Cell* addSr (RTLIL::IdString name, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr, const RTLIL::SigSpec &sig_q, bool set_polarity = true, bool clr_polarity = true, const std::string &src = "");
1212 RTLIL::Cell* addFf (RTLIL::IdString name, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, const std::string &src = "");
1213 RTLIL::Cell* addDff (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity = true, const std::string &src = "");
1214 RTLIL::Cell* addDffe (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity = true, bool en_polarity = true, const std::string &src = "");
1215 RTLIL::Cell* addDffsr (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr,
1216 RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity = true, bool set_polarity = true, bool clr_polarity = true, const std::string &src = "");
1217 RTLIL::Cell* addAdff (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_arst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q,
1218 RTLIL::Const arst_value, bool clk_polarity = true, bool arst_polarity = true, const std::string &src = "");
1219 RTLIL::Cell* addDlatch (RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, bool en_polarity = true, const std::string &src = "");
1220 RTLIL::Cell* addDlatchsr (RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr,
1221 RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool en_polarity = true, bool set_polarity = true, bool clr_polarity = true, const std::string &src = "");
1222
1223 RTLIL::Cell* addBufGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_y, const std::string &src = "");
1224 RTLIL::Cell* addNotGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_y, const std::string &src = "");
1225 RTLIL::Cell* addAndGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_y, const std::string &src = "");
1226 RTLIL::Cell* addNandGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_y, const std::string &src = "");
1227 RTLIL::Cell* addOrGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_y, const std::string &src = "");
1228 RTLIL::Cell* addNorGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_y, const std::string &src = "");
1229 RTLIL::Cell* addXorGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_y, const std::string &src = "");
1230 RTLIL::Cell* addXnorGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_y, const std::string &src = "");
1231 RTLIL::Cell* addAndnotGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_y, const std::string &src = "");
1232 RTLIL::Cell* addOrnotGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_y, const std::string &src = "");
1233 RTLIL::Cell* addMuxGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_s, const RTLIL::SigBit &sig_y, const std::string &src = "");
1234 RTLIL::Cell* addNmuxGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_s, const RTLIL::SigBit &sig_y, const std::string &src = "");
1235 RTLIL::Cell* addAoi3Gate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_c, const RTLIL::SigBit &sig_y, const std::string &src = "");
1236 RTLIL::Cell* addOai3Gate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_c, const RTLIL::SigBit &sig_y, const std::string &src = "");
1237 RTLIL::Cell* addAoi4Gate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_c, const RTLIL::SigBit &sig_d, const RTLIL::SigBit &sig_y, const std::string &src = "");
1238 RTLIL::Cell* addOai4Gate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_c, const RTLIL::SigBit &sig_d, const RTLIL::SigBit &sig_y, const std::string &src = "");
1239
1240 RTLIL::Cell* addFfGate (RTLIL::IdString name, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, const std::string &src = "");
1241 RTLIL::Cell* addDffGate (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity = true, const std::string &src = "");
1242 RTLIL::Cell* addDffeGate (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity = true, bool en_polarity = true, const std::string &src = "");
1243 RTLIL::Cell* addDffsrGate (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr,
1244 RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool clk_polarity = true, bool set_polarity = true, bool clr_polarity = true, const std::string &src = "");
1245 RTLIL::Cell* addAdffGate (RTLIL::IdString name, const RTLIL::SigSpec &sig_clk, const RTLIL::SigSpec &sig_arst, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q,
1246 bool arst_value = false, bool clk_polarity = true, bool arst_polarity = true, const std::string &src = "");
1247 RTLIL::Cell* addDlatchGate (RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_d, const RTLIL::SigSpec &sig_q, bool en_polarity = true, const std::string &src = "");
1248 RTLIL::Cell* addDlatchsrGate (RTLIL::IdString name, const RTLIL::SigSpec &sig_en, const RTLIL::SigSpec &sig_set, const RTLIL::SigSpec &sig_clr,
1249 RTLIL::SigSpec sig_d, const RTLIL::SigSpec &sig_q, bool en_polarity = true, bool set_polarity = true, bool clr_polarity = true, const std::string &src = "");
1250
1251 // The methods without the add* prefix create a cell and an output signal. They return the newly created output signal.
1252
1253 RTLIL::SigSpec Not (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, bool is_signed = false, const std::string &src = "");
1254 RTLIL::SigSpec Pos (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, bool is_signed = false, const std::string &src = "");
1255 RTLIL::SigSpec Bu0 (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, bool is_signed = false, const std::string &src = "");
1256 RTLIL::SigSpec Neg (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, bool is_signed = false, const std::string &src = "");
1257
1258 RTLIL::SigSpec And (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1259 RTLIL::SigSpec Or (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1260 RTLIL::SigSpec Xor (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1261 RTLIL::SigSpec Xnor (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1262
1263 RTLIL::SigSpec ReduceAnd (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, bool is_signed = false, const std::string &src = "");
1264 RTLIL::SigSpec ReduceOr (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, bool is_signed = false, const std::string &src = "");
1265 RTLIL::SigSpec ReduceXor (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, bool is_signed = false, const std::string &src = "");
1266 RTLIL::SigSpec ReduceXnor (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, bool is_signed = false, const std::string &src = "");
1267 RTLIL::SigSpec ReduceBool (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, bool is_signed = false, const std::string &src = "");
1268
1269 RTLIL::SigSpec Shl (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1270 RTLIL::SigSpec Shr (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1271 RTLIL::SigSpec Sshl (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1272 RTLIL::SigSpec Sshr (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1273 RTLIL::SigSpec Shift (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1274 RTLIL::SigSpec Shiftx (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1275
1276 RTLIL::SigSpec Lt (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1277 RTLIL::SigSpec Le (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1278 RTLIL::SigSpec Eq (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1279 RTLIL::SigSpec Ne (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1280 RTLIL::SigSpec Eqx (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1281 RTLIL::SigSpec Nex (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1282 RTLIL::SigSpec Ge (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1283 RTLIL::SigSpec Gt (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1284
1285 RTLIL::SigSpec Add (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1286 RTLIL::SigSpec Sub (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1287 RTLIL::SigSpec Mul (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1288 RTLIL::SigSpec Div (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1289 RTLIL::SigSpec Mod (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1290 RTLIL::SigSpec Pow (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool a_signed = false, bool b_signed = false, const std::string &src = "");
1291
1292 RTLIL::SigSpec LogicNot (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, bool is_signed = false, const std::string &src = "");
1293 RTLIL::SigSpec LogicAnd (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1294 RTLIL::SigSpec LogicOr (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, bool is_signed = false, const std::string &src = "");
1295
1296 RTLIL::SigSpec Mux (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_s, const std::string &src = "");
1297 RTLIL::SigSpec Pmux (RTLIL::IdString name, const RTLIL::SigSpec &sig_a, const RTLIL::SigSpec &sig_b, const RTLIL::SigSpec &sig_s, const std::string &src = "");
1298
1299 RTLIL::SigBit BufGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const std::string &src = "");
1300 RTLIL::SigBit NotGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const std::string &src = "");
1301 RTLIL::SigBit AndGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const std::string &src = "");
1302 RTLIL::SigBit NandGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const std::string &src = "");
1303 RTLIL::SigBit OrGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const std::string &src = "");
1304 RTLIL::SigBit NorGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const std::string &src = "");
1305 RTLIL::SigBit XorGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const std::string &src = "");
1306 RTLIL::SigBit XnorGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const std::string &src = "");
1307 RTLIL::SigBit AndnotGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const std::string &src = "");
1308 RTLIL::SigBit OrnotGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const std::string &src = "");
1309 RTLIL::SigBit MuxGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_s, const std::string &src = "");
1310 RTLIL::SigBit NmuxGate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_s, const std::string &src = "");
1311 RTLIL::SigBit Aoi3Gate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_c, const std::string &src = "");
1312 RTLIL::SigBit Oai3Gate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_c, const std::string &src = "");
1313 RTLIL::SigBit Aoi4Gate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_c, const RTLIL::SigBit &sig_d, const std::string &src = "");
1314 RTLIL::SigBit Oai4Gate (RTLIL::IdString name, const RTLIL::SigBit &sig_a, const RTLIL::SigBit &sig_b, const RTLIL::SigBit &sig_c, const RTLIL::SigBit &sig_d, const std::string &src = "");
1315
1316 RTLIL::SigSpec Anyconst (RTLIL::IdString name, int width = 1, const std::string &src = "");
1317 RTLIL::SigSpec Anyseq (RTLIL::IdString name, int width = 1, const std::string &src = "");
1318 RTLIL::SigSpec Allconst (RTLIL::IdString name, int width = 1, const std::string &src = "");
1319 RTLIL::SigSpec Allseq (RTLIL::IdString name, int width = 1, const std::string &src = "");
1320 RTLIL::SigSpec Initstate (RTLIL::IdString name, const std::string &src = "");
1321
1322 #ifdef WITH_PYTHON
1323 static std::map<unsigned int, RTLIL::Module*> *get_all_modules(void);
1324 #endif
1325 };
1326
1327 struct RTLIL::Wire : public RTLIL::AttrObject
1328 {
1329 unsigned int hashidx_;
1330 unsigned int hash() const { return hashidx_; }
1331
1332 protected:
1333 // use module->addWire() and module->remove() to create or destroy wires
1334 friend struct RTLIL::Module;
1335 Wire();
1336 ~Wire();
1337
1338 public:
1339 // do not simply copy wires
1340 Wire(RTLIL::Wire &other) = delete;
1341 void operator=(RTLIL::Wire &other) = delete;
1342
1343 RTLIL::Module *module;
1344 RTLIL::IdString name;
1345 int width, start_offset, port_id;
1346 bool port_input, port_output, upto;
1347
1348 #ifdef WITH_PYTHON
1349 static std::map<unsigned int, RTLIL::Wire*> *get_all_wires(void);
1350 #endif
1351 };
1352
1353 struct RTLIL::Memory : public RTLIL::AttrObject
1354 {
1355 unsigned int hashidx_;
1356 unsigned int hash() const { return hashidx_; }
1357
1358 Memory();
1359
1360 RTLIL::IdString name;
1361 int width, start_offset, size;
1362 #ifdef WITH_PYTHON
1363 ~Memory();
1364 static std::map<unsigned int, RTLIL::Memory*> *get_all_memorys(void);
1365 #endif
1366 };
1367
1368 struct RTLIL::Cell : public RTLIL::AttrObject
1369 {
1370 unsigned int hashidx_;
1371 unsigned int hash() const { return hashidx_; }
1372
1373 protected:
1374 // use module->addCell() and module->remove() to create or destroy cells
1375 friend struct RTLIL::Module;
1376 Cell();
1377 ~Cell();
1378
1379 public:
1380 // do not simply copy cells
1381 Cell(RTLIL::Cell &other) = delete;
1382 void operator=(RTLIL::Cell &other) = delete;
1383
1384 RTLIL::Module *module;
1385 RTLIL::IdString name;
1386 RTLIL::IdString type;
1387 dict<RTLIL::IdString, RTLIL::SigSpec> connections_;
1388 dict<RTLIL::IdString, RTLIL::Const> parameters;
1389
1390 // access cell ports
1391 bool hasPort(RTLIL::IdString portname) const;
1392 void unsetPort(RTLIL::IdString portname);
1393 void setPort(RTLIL::IdString portname, RTLIL::SigSpec signal);
1394 const RTLIL::SigSpec &getPort(RTLIL::IdString portname) const;
1395 const dict<RTLIL::IdString, RTLIL::SigSpec> &connections() const;
1396
1397 // information about cell ports
1398 bool known() const;
1399 bool input(RTLIL::IdString portname) const;
1400 bool output(RTLIL::IdString portname) const;
1401
1402 // access cell parameters
1403 bool hasParam(RTLIL::IdString paramname) const;
1404 void unsetParam(RTLIL::IdString paramname);
1405 void setParam(RTLIL::IdString paramname, RTLIL::Const value);
1406 const RTLIL::Const &getParam(RTLIL::IdString paramname) const;
1407
1408 void sort();
1409 void check();
1410 void fixup_parameters(bool set_a_signed = false, bool set_b_signed = false);
1411
1412 bool has_keep_attr() const {
1413 return get_bool_attribute(ID::keep) || (module && module->design && module->design->module(type) &&
1414 module->design->module(type)->get_bool_attribute(ID::keep));
1415 }
1416
1417 template<typename T> void rewrite_sigspecs(T &functor);
1418 template<typename T> void rewrite_sigspecs2(T &functor);
1419
1420 #ifdef WITH_PYTHON
1421 static std::map<unsigned int, RTLIL::Cell*> *get_all_cells(void);
1422 #endif
1423 };
1424
1425 struct RTLIL::CaseRule : public RTLIL::AttrObject
1426 {
1427 std::vector<RTLIL::SigSpec> compare;
1428 std::vector<RTLIL::SigSig> actions;
1429 std::vector<RTLIL::SwitchRule*> switches;
1430
1431 ~CaseRule();
1432 void optimize();
1433
1434 bool empty() const;
1435
1436 template<typename T> void rewrite_sigspecs(T &functor);
1437 template<typename T> void rewrite_sigspecs2(T &functor);
1438 RTLIL::CaseRule *clone() const;
1439 };
1440
1441 struct RTLIL::SwitchRule : public RTLIL::AttrObject
1442 {
1443 RTLIL::SigSpec signal;
1444 std::vector<RTLIL::CaseRule*> cases;
1445
1446 ~SwitchRule();
1447
1448 bool empty() const;
1449
1450 template<typename T> void rewrite_sigspecs(T &functor);
1451 template<typename T> void rewrite_sigspecs2(T &functor);
1452 RTLIL::SwitchRule *clone() const;
1453 };
1454
1455 struct RTLIL::SyncRule
1456 {
1457 RTLIL::SyncType type;
1458 RTLIL::SigSpec signal;
1459 std::vector<RTLIL::SigSig> actions;
1460
1461 template<typename T> void rewrite_sigspecs(T &functor);
1462 template<typename T> void rewrite_sigspecs2(T &functor);
1463 RTLIL::SyncRule *clone() const;
1464 };
1465
1466 struct RTLIL::Process : public RTLIL::AttrObject
1467 {
1468 RTLIL::IdString name;
1469 RTLIL::CaseRule root_case;
1470 std::vector<RTLIL::SyncRule*> syncs;
1471
1472 ~Process();
1473
1474 template<typename T> void rewrite_sigspecs(T &functor);
1475 template<typename T> void rewrite_sigspecs2(T &functor);
1476 RTLIL::Process *clone() const;
1477 };
1478
1479
1480 inline RTLIL::SigBit::SigBit() : wire(NULL), data(RTLIL::State::S0) { }
1481 inline RTLIL::SigBit::SigBit(RTLIL::State bit) : wire(NULL), data(bit) { }
1482 inline RTLIL::SigBit::SigBit(bool bit) : wire(NULL), data(bit ? State::S1 : State::S0) { }
1483 inline RTLIL::SigBit::SigBit(RTLIL::Wire *wire) : wire(wire), offset(0) { log_assert(wire && wire->width == 1); }
1484 inline RTLIL::SigBit::SigBit(RTLIL::Wire *wire, int offset) : wire(wire), offset(offset) { log_assert(wire != nullptr); }
1485 inline RTLIL::SigBit::SigBit(const RTLIL::SigChunk &chunk) : wire(chunk.wire) { log_assert(chunk.width == 1); if (wire) offset = chunk.offset; else data = chunk.data[0]; }
1486 inline RTLIL::SigBit::SigBit(const RTLIL::SigChunk &chunk, int index) : wire(chunk.wire) { if (wire) offset = chunk.offset + index; else data = chunk.data[index]; }
1487 inline RTLIL::SigBit::SigBit(const RTLIL::SigBit &sigbit) : wire(sigbit.wire), data(sigbit.data){ if (wire) offset = sigbit.offset; }
1488
1489 inline bool RTLIL::SigBit::operator<(const RTLIL::SigBit &other) const {
1490 if (wire == other.wire)
1491 return wire ? (offset < other.offset) : (data < other.data);
1492 if (wire != nullptr && other.wire != nullptr)
1493 return wire->name < other.wire->name;
1494 return (wire != nullptr) < (other.wire != nullptr);
1495 }
1496
1497 inline bool RTLIL::SigBit::operator==(const RTLIL::SigBit &other) const {
1498 return (wire == other.wire) && (wire ? (offset == other.offset) : (data == other.data));
1499 }
1500
1501 inline bool RTLIL::SigBit::operator!=(const RTLIL::SigBit &other) const {
1502 return (wire != other.wire) || (wire ? (offset != other.offset) : (data != other.data));
1503 }
1504
1505 inline unsigned int RTLIL::SigBit::hash() const {
1506 if (wire)
1507 return mkhash_add(wire->name.hash(), offset);
1508 return data;
1509 }
1510
1511 inline RTLIL::SigBit &RTLIL::SigSpecIterator::operator*() const {
1512 return (*sig_p)[index];
1513 }
1514
1515 inline const RTLIL::SigBit &RTLIL::SigSpecConstIterator::operator*() const {
1516 return (*sig_p)[index];
1517 }
1518
1519 inline RTLIL::SigBit::SigBit(const RTLIL::SigSpec &sig) {
1520 log_assert(sig.size() == 1 && sig.chunks().size() == 1);
1521 *this = SigBit(sig.chunks().front());
1522 }
1523
1524 template<typename T>
1525 void RTLIL::Module::rewrite_sigspecs(T &functor)
1526 {
1527 for (auto &it : cells_)
1528 it.second->rewrite_sigspecs(functor);
1529 for (auto &it : processes)
1530 it.second->rewrite_sigspecs(functor);
1531 for (auto &it : connections_) {
1532 functor(it.first);
1533 functor(it.second);
1534 }
1535 }
1536
1537 template<typename T>
1538 void RTLIL::Module::rewrite_sigspecs2(T &functor)
1539 {
1540 for (auto &it : cells_)
1541 it.second->rewrite_sigspecs2(functor);
1542 for (auto &it : processes)
1543 it.second->rewrite_sigspecs2(functor);
1544 for (auto &it : connections_) {
1545 functor(it.first, it.second);
1546 }
1547 }
1548
1549 template<typename T>
1550 void RTLIL::Cell::rewrite_sigspecs(T &functor) {
1551 for (auto &it : connections_)
1552 functor(it.second);
1553 }
1554
1555 template<typename T>
1556 void RTLIL::Cell::rewrite_sigspecs2(T &functor) {
1557 for (auto &it : connections_)
1558 functor(it.second);
1559 }
1560
1561 template<typename T>
1562 void RTLIL::CaseRule::rewrite_sigspecs(T &functor) {
1563 for (auto &it : compare)
1564 functor(it);
1565 for (auto &it : actions) {
1566 functor(it.first);
1567 functor(it.second);
1568 }
1569 for (auto it : switches)
1570 it->rewrite_sigspecs(functor);
1571 }
1572
1573 template<typename T>
1574 void RTLIL::CaseRule::rewrite_sigspecs2(T &functor) {
1575 for (auto &it : compare)
1576 functor(it);
1577 for (auto &it : actions) {
1578 functor(it.first, it.second);
1579 }
1580 for (auto it : switches)
1581 it->rewrite_sigspecs2(functor);
1582 }
1583
1584 template<typename T>
1585 void RTLIL::SwitchRule::rewrite_sigspecs(T &functor)
1586 {
1587 functor(signal);
1588 for (auto it : cases)
1589 it->rewrite_sigspecs(functor);
1590 }
1591
1592 template<typename T>
1593 void RTLIL::SwitchRule::rewrite_sigspecs2(T &functor)
1594 {
1595 functor(signal);
1596 for (auto it : cases)
1597 it->rewrite_sigspecs2(functor);
1598 }
1599
1600 template<typename T>
1601 void RTLIL::SyncRule::rewrite_sigspecs(T &functor)
1602 {
1603 functor(signal);
1604 for (auto &it : actions) {
1605 functor(it.first);
1606 functor(it.second);
1607 }
1608 }
1609
1610 template<typename T>
1611 void RTLIL::SyncRule::rewrite_sigspecs2(T &functor)
1612 {
1613 functor(signal);
1614 for (auto &it : actions) {
1615 functor(it.first, it.second);
1616 }
1617 }
1618
1619 template<typename T>
1620 void RTLIL::Process::rewrite_sigspecs(T &functor)
1621 {
1622 root_case.rewrite_sigspecs(functor);
1623 for (auto it : syncs)
1624 it->rewrite_sigspecs(functor);
1625 }
1626
1627 template<typename T>
1628 void RTLIL::Process::rewrite_sigspecs2(T &functor)
1629 {
1630 root_case.rewrite_sigspecs2(functor);
1631 for (auto it : syncs)
1632 it->rewrite_sigspecs2(functor);
1633 }
1634
1635 YOSYS_NAMESPACE_END
1636
1637 #endif