Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

bump fork for version 0.46 #25

Merged
merged 249 commits into from
Oct 9, 2024
Merged
Changes from 1 commit
Commits
Show all changes
249 commits
Select commit Hold shift + click to select a range
3f71bc4
check: Rephrase comment
povik Jul 18, 2024
e70b125
check: Adjust prints
povik Jul 18, 2024
0cefe8a
check: Skip detailed edge modeling if costly
povik Jul 18, 2024
0922142
Add generic topological sort and SCC detection
jix Apr 15, 2024
c73c8a3
kernel/log: Add log_str helper for custom log_* functions/overloads
jix Apr 15, 2024
f24e253
kernel/rtlil: Add `SigBit operator[](int offset)` to `SigChunk`
jix Apr 15, 2024
5657297
drivertools: Utility code for indexing and traversing signal drivers
jix Apr 15, 2024
68c3a47
WIP temporary drivertools example
jix Apr 15, 2024
f29422f
topo_scc: Add sources_first option
jix Apr 11, 2024
d4e3daa
ComputeGraph datatype for the upcoming functional backend
jix Apr 11, 2024
d90268f
fixup! drivertools: Utility code for indexing and traversing signal d…
jix Apr 17, 2024
dd5ec84
fix bugs in drivertools
aiju May 1, 2024
63dea89
add initial version of functional C++ backend
aiju May 1, 2024
7611dda
add initial version of functional smtlib backend
aiju May 23, 2024
720429b
Add test_cell tests for C++ functional backend
RCoeurjoly Jun 12, 2024
76371d1
Change assert to log_assert
RCoeurjoly Jun 12, 2024
7b29d17
add support for memories to c++ and smtlib functional backends
aiju Jun 12, 2024
3552a8a
sim.h cannot use log_assert because does not include yosys headers
RCoeurjoly Jun 12, 2024
dbf2bc3
need unsigned comparison when checking shift widths for overflow in f…
aiju Jun 12, 2024
248d5f7
add support for std::variant to hashlib
aiju Jun 20, 2024
6f9e212
add new generic compute graph and rewrite c++ functional backend to u…
aiju Jun 20, 2024
4e370f4
Initial functional SMT backend using functional IR
RCoeurjoly Jun 21, 2024
54225b5
Add test for SMT backend. Tests if SMT is valid and compares simulati…
RCoeurjoly Jun 21, 2024
c6e1126
Remove unused includes
RCoeurjoly Jun 23, 2024
547c546
Ignore smt2 files, generated by the execution of the tests
RCoeurjoly Jun 24, 2024
71aaa1c
Consolidate tests scripts into one
RCoeurjoly Jun 24, 2024
b98210d
Valid SMT is emitted, improved test script
RCoeurjoly Jun 26, 2024
94ddbc9
Fix reduce_or
RCoeurjoly Jun 26, 2024
4109fce
clang-format smtlib.cc
RCoeurjoly Jun 26, 2024
39bf4f0
Create VCD file from SMT file
RCoeurjoly Jun 26, 2024
eb2bb8c
tidy up generic functional backend, add generic scope class, tidy up …
aiju Jun 27, 2024
21bb1cf
rewrite functional c++ simulation library
aiju Jun 27, 2024
e235fc7
Create std::mt19937 only once
RCoeurjoly Jun 27, 2024
ee6bd59
Removed unnecesary nested_lets variable, use writer.print instead
RCoeurjoly Jun 27, 2024
32cdf25
Use FunctionalTools::Scope instead of replaceCharacters
RCoeurjoly Jun 27, 2024
9700df5
add generic writer class with formatting function to FunctionalTools
aiju Jul 4, 2024
cb5f083
´SMT success only if simulation is equivalent
RCoeurjoly Jul 3, 2024
73ed514
Check that there are not other solutions other than the first given
RCoeurjoly Jul 4, 2024
762f8dd
Add readme explaining how to create test files
RCoeurjoly Jul 4, 2024
50f487e
Added $ff test
RCoeurjoly Jul 4, 2024
1b2986f
add support for $mul, $div, $divfloor, $mod, $modfloor, $pow in funct…
aiju Jul 4, 2024
57af68a
include algorithm, needed for std::reverse
RCoeurjoly Jul 4, 2024
e296b88
Add Makefile helpers for coverage
mmicko Jul 5, 2024
f0f436c
Fix parenthesis for arithmetic_shift_right
RCoeurjoly Jul 5, 2024
5780357
Emit valid SMT for stateful designs, fix some cells
RCoeurjoly Jul 7, 2024
fad76ce
Fix memory leak
RCoeurjoly Jul 7, 2024
7cff8fa
Fix corner case of pos cell with input and output being same width
RCoeurjoly Jul 7, 2024
566e57d
Support $lut cells. Both C++ and SMT tests pass
RCoeurjoly Jul 7, 2024
80582ed
Check the existance of a different set of outputs. No need for (push …
RCoeurjoly Jul 8, 2024
9f660b1
rewrite smtlib pass to use SExpr class
aiju Jul 10, 2024
c659ef2
change smtlib backend to use list() function instead of SExpr{} const…
aiju Jul 10, 2024
00a6575
factor out SExpr/SExprWriter classes out of smtlib backend, and also …
aiju Jul 11, 2024
6e7ae88
fix bugs in smtlib backend
aiju Jul 12, 2024
9ad859f
add bwmux, bweqx, bmux, demux cells
aiju Jul 12, 2024
674e6d2
rewrite functional backend test code in python
aiju Jul 12, 2024
6922633
fix a few bugs in the functional backend and refactor the testing
aiju Jul 16, 2024
55c2c17
document functionalir.h and change visitors to derive from AbstractVi…
aiju Jul 17, 2024
7f8f21b
remove widths parameters from FunctionalIR factory methods and from f…
aiju Jul 17, 2024
c0c90c2
functional backend: require shift width == clog2(operand width)
aiju Jul 17, 2024
13bacc5
eliminate pmux in functional backend
aiju Jul 17, 2024
3cd5f4e
add support for RTLIL cells with multiple outputs to the functional b…
aiju Jul 17, 2024
4722f13
functional backend: reduce $lcu to $alu
aiju Jul 18, 2024
145af6f
fix memory handling in functional backend, add more error messages an…
aiju Jul 18, 2024
6d329e1
functional backend: error out if multiply driven or undriven signals …
aiju Jul 18, 2024
12a31a4
add MemContents class to mem.h
aiju Jul 24, 2024
bdb59ff
add -fst-noinit flag to sim for not initializing the state from the f…
aiju Jul 24, 2024
99effb6
add support for initializing registers and memories to the functional…
aiju Jul 24, 2024
95d28c2
functional backend: make Memory in the C++ simulation library read-on…
aiju Jul 24, 2024
7ac0e92
functional backend: rename get_input and get_current_state to input a…
aiju Jul 25, 2024
8c0f625
functional backend: topological sort starts with the output and next …
aiju Jul 25, 2024
850b3a6
convert class FunctionalIR to a namespace Functional, rename function…
aiju Jul 25, 2024
fbee310
add optional header and hashlib implementation for optional
aiju Jul 25, 2024
8f77494
silence some warnings
aiju Jul 25, 2024
79a1b69
silence some more warnings, undo mistaken addition
aiju Jul 25, 2024
50047d2
functional backend: add different types of input/output/state variables
aiju Aug 6, 2024
831da51
add picorv test to functional backend
aiju Aug 8, 2024
f456761
add sandia copyright notice to the functional backend
aiju Aug 13, 2024
9b5e81b
drivertools: fix C++20 "incomplete type" error by moving constructors…
aiju Aug 22, 2024
761eff5
functional backend: missing includes for stl containers
aiju Aug 22, 2024
459e6b9
add functional ir documentation
aiju Aug 27, 2024
b428bf4
functional backends: identifiers in c++/smtlib may not start with digits
aiju Aug 27, 2024
27efed2
functional backend: more documentation
aiju Aug 28, 2024
4eeb8d3
functional backend: rename "type" to either "kind" or "sort" to make …
aiju Aug 28, 2024
2b8db94
functional backend: add test to verify test_generic
aiju Aug 29, 2024
9c1bcb3
write_xaiger: Get by without endianness helpers
povik Sep 3, 2024
8b29629
smtr: Fork smtlib for rosette
KrystalDelusion Aug 22, 2024
7fe9157
smtr: Add rkt to functional tests
KrystalDelusion Aug 22, 2024
07b6908
smtr: Use rosette/safe
KrystalDelusion Aug 29, 2024
5a29b3e
smtr: More sanitization
KrystalDelusion Aug 29, 2024
a2abbcb
smtr: Use scope.unique_name
KrystalDelusion Sep 3, 2024
d6c5e13
smtr: Structs have local scope
KrystalDelusion Sep 3, 2024
75ed6d3
fix rst formatting in functional_ir.rst
aiju Sep 3, 2024
7de8be1
functional_ir.rst: fix typo, document SExprWriter::flush
aiju Sep 3, 2024
0ce7631
internal_stats: init, report current memory consumption on linux and mac
widlarizer Sep 3, 2024
68fbca8
Merge pull request #4554 from YosysHQ/emil/devstat
povik Sep 3, 2024
d567164
Bump version
github-actions[bot] Sep 4, 2024
5a476a8
functional tests: run from make tests but not smtlib/rkt tests
aiju Sep 4, 2024
21494d1
Makefile: Update coverage_functional
KrystalDelusion Sep 4, 2024
17ee367
Docs: Use Read the Docs SPHINXOPTS
KrystalDelusion Sep 5, 2024
bd6f7bb
ff: improve comments
widlarizer Sep 5, 2024
14b9155
internal_stats: fix doc build by adding a help string
widlarizer Sep 5, 2024
73a2d35
Merge pull request #4581 from YosysHQ/emil/ff-clk-comment
povik Sep 5, 2024
7e65b83
Merge pull request #4576 from povik/xaiger-drop-bswap
povik Sep 5, 2024
3b8f3c2
Merge pull request #4582 from YosysHQ/emil/internal_stats-help-string
povik Sep 5, 2024
e8951ab
Bump version
github-actions[bot] Sep 6, 2024
fc10a6e
Run functional tests on private runner only
mmicko Sep 6, 2024
0ad2431
Merge pull request #4585 from YosysHQ/functional_tests
mmicko Sep 6, 2024
b20df72
Merge pull request #4536 from YosysHQ/functional
mmicko Sep 6, 2024
dcf9f58
Bump version
github-actions[bot] Sep 7, 2024
c1205eb
Initialize area stats in stat pass
hnpl Sep 8, 2024
982fade
Merge pull request #4587 from hnpl/main
povik Sep 9, 2024
e64fcee
clockgate: prototype clock gating
widlarizer Sep 9, 2024
dc039d8
clockgate: test fine-grained cells
widlarizer Sep 9, 2024
7e47329
clockgate: bail on constant signals
widlarizer Sep 9, 2024
6937241
Bump version
github-actions[bot] Sep 10, 2024
bdc43c6
Add left and right bound properties to wire. Add test. Fix printing
RCoeurjoly Aug 21, 2024
ab35dff
Gowin. Add the EMCU primitive.
yrabbit Sep 11, 2024
8b46434
clockgate: no initvals
widlarizer Sep 11, 2024
1372c47
internal_stats: astnode (sizeof)
widlarizer Sep 11, 2024
3457270
Merge pull request #4595 from YosysHQ/emil/internal_stats-astnode
povik Sep 11, 2024
1e999a3
clockgate: EN can be a bit on a multi-bit wire
widlarizer Sep 11, 2024
38f9e6c
-y flag for libyosys Python scripts
donn Aug 27, 2024
738b5ee
Add dirname of script file to sys.path
donn Sep 10, 2024
8dac271
Typos
donn Sep 11, 2024
229d1ea
Bump version
github-actions[bot] Sep 12, 2024
c8b42b7
Merge pull request #4538 from RCoeurjoly/verific_bounds
nakengelhardt Sep 12, 2024
a8a92d3
clockgate: help string
widlarizer Sep 16, 2024
be7c93e
clockgate: 1-bit const 0
widlarizer Sep 16, 2024
f193bcf
clockgate: help string
widlarizer Sep 16, 2024
52382c6
Merge pull request #4583 from YosysHQ/emil/clock_gate
widlarizer Sep 16, 2024
f8ad371
Merge pull request #4594 from yrabbit/cpu-wip
widlarizer Sep 16, 2024
c884624
Bump version
github-actions[bot] Sep 17, 2024
d0b5dfa
Add bufnorm pass
clairexen Sep 27, 2023
32808a0
Improvements and fixes to "bufnorm" cmd
clairexen Sep 27, 2023
f4b7ea5
Improvements in "bufnorm" pass
clairexen Sep 28, 2023
4d469f4
Add coarse-grain $buf buffer cell type
clairexen Sep 29, 2023
d027ead
Improvements in "bufnorm" pass
clairexen Sep 29, 2023
8bb70ba
Improvements in "bufnorm" pass
clairexen Sep 29, 2023
8011938
Add RTLIL "buffered-normalized mode" and improve "bufnorm" pass
clairexen Sep 29, 2023
865df26
Adjust buf-normalized mode
povik May 21, 2024
38de018
Mark `bufnorm` experimental
povik Sep 11, 2024
e13ace6
dump: Update help after option removal
povik Sep 16, 2024
eeffca9
simlib: Add `$buf` disclaimer
povik Sep 17, 2024
a553b7c
Merge pull request #3967 from YosysHQ/claire/bufnorm
povik Sep 17, 2024
4cfdb7a
Adjust operation naming in aigmap test
povik Sep 10, 2024
fb26945
Start an 'aiger2' backend
povik Sep 10, 2024
fa39227
aiger2: Support `$pos`
povik Sep 11, 2024
5671c10
aiger2: Add strashing option
povik Sep 11, 2024
de8a2fb
aiger2: Fix duplicate symbols on multibit ports
povik Sep 11, 2024
e59387e
aiger2: Add `aigsize` as a second user of index
povik Sep 11, 2024
d7128cb
aiger2: Use shorthands
povik Sep 11, 2024
8e29675
aiger2: Support `$bwmux`, comparison operators
povik Sep 11, 2024
e4b24e8
aiger2: Fix literal typing
povik Sep 11, 2024
dbc937b
aiger2: Describe supported cells in help
povik Sep 11, 2024
9db1ca8
aiger2: Drop `empty_lit()` as a function
povik Sep 11, 2024
4d581a9
Bump version
github-actions[bot] Sep 18, 2024
4976abb
read_liberty: Optionally import unit delay arcs
povik Sep 18, 2024
31476e8
tests: Avoid temporary script file
povik Sep 18, 2024
d5756eb
tests: Add trivial liberty -unit_delay test
povik Sep 18, 2024
6c1fa45
aiger2: Ingest `$pmux`
povik Sep 16, 2024
1cfb902
aiger2: Use `REDUCE` for reduction ops
povik Sep 16, 2024
6cecf19
aiger2: Ingest `$bmux`
povik Sep 16, 2024
1ab7f29
Start read_xaiger2 -sc_mapping
povik Sep 18, 2024
72d6506
aiger2: Ignore benign cells
povik Sep 18, 2024
2a3e907
aiger2: Adjust typing
povik Sep 18, 2024
ea76568
aiger2: Adjust hierarchy/port handling
povik Sep 18, 2024
5f8d7ff
Start new write_xaiger2 backend for export w/ boxes
povik Sep 18, 2024
3a1b003
celltypes: Fix `$buf` eval
povik Sep 18, 2024
f168b2f
read_xaiger2: Update box handling
povik Sep 18, 2024
9018d06
quicklogic: Avoid carry chains in division mapping
povik Sep 19, 2024
8e1e2b9
Merge pull request #4495 from povik/check-avert-costly-detail
nakengelhardt Sep 23, 2024
b788de9
smtbmc: escape path identifiers
georgerennie Sep 24, 2024
3e3515e
log: Never silence `log_cmd_error`
povik Sep 24, 2024
ce7db66
Added cast to type support (#4284)
rherveille Sep 29, 2024
59404f8
Bump version
github-actions[bot] Sep 30, 2024
5fca9b8
Add Get vcd2fst step to test-yosys job
RCoeurjoly Sep 30, 2024
35c8ad6
cli/python: error-checking, python interpreter bugfix
donn Sep 30, 2024
500db6a
Merge pull request #4621 from RCoeurjoly/roland/get_vcd2fst
mmicko Sep 30, 2024
1bf908d
Bump version
github-actions[bot] Oct 1, 2024
997cb30
cxxrtl: test stream operator
widlarizer Oct 1, 2024
13ecbd5
quicklogic: test that dividing by a constant does not infer carry chains
Ravenslofty Oct 3, 2024
5841b44
docs: Simplify images generation to allow parallel build
tarikgraba Oct 6, 2024
d8038c1
Add -j flag to make docs CI
KrystalDelusion Oct 6, 2024
571d181
Fix top-level make docs prerequisites
KrystalDelusion Oct 6, 2024
3534e6b
Merge pull request #4632 from tarikgraba/main
KrystalDelusion Oct 6, 2024
6155c59
Bump version
github-actions[bot] Oct 7, 2024
2e1181a
ci: Run make docs on PRs
KrystalDelusion Oct 7, 2024
468a019
docs: Makefile tidying
KrystalDelusion Oct 7, 2024
0b1b94d
Docs: Clean example outputs
KrystalDelusion Oct 7, 2024
13d7b5f
Docs: Ignore example outputs
KrystalDelusion Oct 7, 2024
1f517d6
Merge pull request #4553 from donn/python_scriptfile
widlarizer Oct 7, 2024
3e6e8c8
Bump abc submodule
widlarizer Oct 7, 2024
edf29e7
Docs: Add functional_ir to index
KrystalDelusion Oct 7, 2024
33930e4
ci: Test build docs
KrystalDelusion Oct 7, 2024
f72d021
Update test-build.yml
KrystalDelusion Oct 7, 2024
d4e009f
aiger2: Add TODO
povik Oct 2, 2024
e58a9b6
abc9: Understand ASIC options similar to `abc`
povik Apr 9, 2024
2b1b565
Adjust `read_xaiger2` prints
povik Oct 4, 2024
8d12492
read_xaiger2: Fix detecting the end of extensions
povik Oct 4, 2024
f7c7371
aiger2: Fix relative ordering of PI/POs and box I/Os
povik Oct 5, 2024
4c0a8a1
aiger2: Add analysis step to order boxes
povik Oct 5, 2024
b8f3893
aiger2: Convert x-states to zeroes
povik Oct 5, 2024
e0a86d5
abc_new: Start new command for aiger2-based round trip
povik Oct 5, 2024
81688e3
aigsize: Remove
povik Oct 5, 2024
ac79a05
aiger2: Adjust help
povik Oct 5, 2024
3b6dcc7
abc9_exe: Remove `-genlib` option
povik Oct 5, 2024
2e587c8
abc9_exe: Document SC mapping options
povik Oct 5, 2024
ebe51e2
aiger2: Fix warnings
povik Oct 5, 2024
373e7a1
aiger2: Fix print
povik Oct 5, 2024
47fd2b9
aiger2: Update help
povik Oct 5, 2024
d0a11e2
aiger2: Add test of writing a flattened view
povik Oct 7, 2024
72f0fea
aiger2: Try to fix VS build
povik Oct 7, 2024
f44a418
read_xaiger2: Add casts to silence warnings
povik Oct 7, 2024
7989d53
read_xaiger2: Add help
povik Oct 7, 2024
b01b176
Add test of error not getting silenced
povik Oct 7, 2024
ca5c2fd
quicklogic: Relax the LUT number test
povik Oct 7, 2024
407343a
Pyosys Wheels
donn Aug 12, 2024
ab4ea84
wheels: more compatibility
donn Sep 28, 2024
ab84c10
Add test, shell for windows
donn Sep 28, 2024
67f17a1
wheels: symlink python3-config
donn Sep 29, 2024
08c23b7
wheels: skip musllinux for now
donn Sep 29, 2024
0bb1f89
wheels: convert versions to match pypa spec, add uploading
donn Oct 4, 2024
43128f6
wheels: move from postreleases to minor versions, remove authors
donn Oct 7, 2024
6c1450f
Merge pull request #4607 from povik/ql-nodiv
povik Oct 7, 2024
74e92d1
Merge pull request #4593 from povik/aiger2
povik Oct 7, 2024
0aab8b4
Merge pull request #4605 from povik/liberty-unit-delay
povik Oct 7, 2024
0556cb5
Merge pull request #4628 from povik/bump-abc
povik Oct 7, 2024
e46cc57
Merge pull request #4613 from povik/err-never-silence
povik Oct 7, 2024
a76bcdc
bufnorm: avoid remove warning. NFC
widlarizer Oct 7, 2024
9479d3b
Merge pull request #4637 from YosysHQ/emil/bufnorm-warning
povik Oct 7, 2024
d7cf023
wheels: properly migrate to artifact@v4
donn Oct 7, 2024
b3b88e5
Merge pull request #4609 from georgerennie/george/smtbmc_paths
jix Oct 7, 2024
b151036
ci: Switch test build docs to our runner
KrystalDelusion Oct 7, 2024
c160442
ci: Call make html directly
KrystalDelusion Oct 7, 2024
1e3973c
Explictly #include <variant> for std::variant usage.
mikesinouye Oct 7, 2024
408597b
Bump version
github-actions[bot] Oct 8, 2024
f079772
Add TODO for missing help messages
mmicko Oct 8, 2024
0be3b7d
Merge pull request #4635 from YosysHQ/krys/pr_docs_ci
KrystalDelusion Oct 8, 2024
535b330
Merge pull request #4534 from donn/test_wheels
mmicko Oct 8, 2024
380a425
Merge pull request #4639 from mikesinouye/hashlib
povik Oct 8, 2024
b4fd8e7
Bump version
github-actions[bot] Oct 9, 2024
e97731b
Release version 0.46
mmicko Oct 9, 2024
8893dad
Next dev cycle
mmicko Oct 9, 2024
c93c7f8
CI: lld is now separate brew package
mmicko Oct 9, 2024
a5968e4
Merge pull request #4642 from YosysHQ/fix_ci
mmicko Oct 9, 2024
a6ccf22
force brew formula update
mmicko Oct 9, 2024
eefd111
Merge pull request #4647 from YosysHQ/fix_macos_ci
mmicko Oct 9, 2024
038e262
Merge pull request #4624 from YosysHQ/emil/cxxrtl-smoke-test
widlarizer Oct 9, 2024
a761999
cxxrtl: fix formatting of UNICHAR
rroohhh Oct 9, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
write_xaiger: Get by without endianness helpers
povik committed Sep 3, 2024
commit 9c1bcb38d97eca203e44872109a9d1e92c363c4f
60 changes: 11 additions & 49 deletions backends/aiger/xaiger.cc
Original file line number Diff line number Diff line change
@@ -18,32 +18,6 @@
*
*/

// https://stackoverflow.com/a/46137633
#ifdef _MSC_VER
#include <stdlib.h>
#define bswap32 _byteswap_ulong
#elif defined(__APPLE__)
#include <libkern/OSByteOrder.h>
#define bswap32 OSSwapInt32
#elif defined(__GNUC__)
#define bswap32 __builtin_bswap32
#else
#include <cstdint>
inline static uint32_t bswap32(uint32_t x)
{
// https://stackoverflow.com/a/27796212
register uint32_t value = number_to_be_reversed;
uint8_t lolo = (value >> 0) & 0xFF;
uint8_t lohi = (value >> 8) & 0xFF;
uint8_t hilo = (value >> 16) & 0xFF;
uint8_t hihi = (value >> 24) & 0xFF;
return (hihi << 24)
| (hilo << 16)
| (lohi << 8)
| (lolo << 0);
}
#endif

#include "kernel/yosys.h"
#include "kernel/sigtools.h"
#include "kernel/utils.h"
@@ -52,16 +26,6 @@ inline static uint32_t bswap32(uint32_t x)
USING_YOSYS_NAMESPACE
PRIVATE_NAMESPACE_BEGIN

inline int32_t to_big_endian(int32_t i32) {
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
return bswap32(i32);
#elif __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__
return i32;
#else
#error "Unknown endianness"
#endif
}

void aiger_encode(std::ostream &f, int x)
{
log_assert(x >= 0);
@@ -537,9 +501,12 @@ struct XAigerWriter

f << "c";

auto write_buffer = [](std::stringstream &buffer, int i32) {
int32_t i32_be = to_big_endian(i32);
buffer.write(reinterpret_cast<const char*>(&i32_be), sizeof(i32_be));
auto write_buffer = [](std::ostream &buffer, unsigned int u32) {
typedef unsigned char uchar;
unsigned char u32_be[4] = {
(uchar) (u32 >> 24), (uchar) (u32 >> 16), (uchar) (u32 >> 8), (uchar) u32
};
buffer.write((char *) u32_be, sizeof(u32_be));
};
std::stringstream h_buffer;
auto write_h_buffer = std::bind(write_buffer, std::ref(h_buffer), std::placeholders::_1);
@@ -640,14 +607,12 @@ struct XAigerWriter

f << "r";
std::string buffer_str = r_buffer.str();
int32_t buffer_size_be = to_big_endian(buffer_str.size());
f.write(reinterpret_cast<const char*>(&buffer_size_be), sizeof(buffer_size_be));
write_buffer(f, buffer_str.size());
f.write(buffer_str.data(), buffer_str.size());

f << "s";
buffer_str = s_buffer.str();
buffer_size_be = to_big_endian(buffer_str.size());
f.write(reinterpret_cast<const char*>(&buffer_size_be), sizeof(buffer_size_be));
write_buffer(f, buffer_str.size());
f.write(buffer_str.data(), buffer_str.size());

RTLIL::Design *holes_design;
@@ -664,22 +629,19 @@ struct XAigerWriter

f << "a";
std::string buffer_str = a_buffer.str();
int32_t buffer_size_be = to_big_endian(buffer_str.size());
f.write(reinterpret_cast<const char*>(&buffer_size_be), sizeof(buffer_size_be));
write_buffer(f, buffer_str.size());
f.write(buffer_str.data(), buffer_str.size());
}
}

f << "h";
std::string buffer_str = h_buffer.str();
int32_t buffer_size_be = to_big_endian(buffer_str.size());
f.write(reinterpret_cast<const char*>(&buffer_size_be), sizeof(buffer_size_be));
write_buffer(f, buffer_str.size());
f.write(buffer_str.data(), buffer_str.size());

f << "i";
buffer_str = i_buffer.str();
buffer_size_be = to_big_endian(buffer_str.size());
f.write(reinterpret_cast<const char*>(&buffer_size_be), sizeof(buffer_size_be));
write_buffer(f, buffer_str.size());
f.write(buffer_str.data(), buffer_str.size());
//f << "o";
//buffer_str = o_buffer.str();