7.2. How to keep HLS intermediate files generated by Mercurium?¶
Mercurium generates an intermediate C++ HLS source file for each FPGA task defined in the source code.
Those files are used by AIT to generate the FPGA bitstream, and removed after the invocation.
To keep the Mercurium intermediate files, there is the -k
option.
It will keep the C/C++ intermediate files for the native compiler and the C++ HLS files for AIT.
Usage example:
fpgacc --ompss --bitstream-generation -k src/dotproduct.c -o dotproduct \
--Wf,--board=zedboard
Note
HLS source files are not generated if --bitstream-generation
option is not used in Mercurium call
Edit the HLS intermediate files and call AIT
It is not recommended, but under some circumstances one would need to edit the HLS intermediate files before the AIT call. The following steps shows how to do so.
We call Mercurium with the desired options and two extra flags: -
-k
which keeps the intermediate files generated by the compiler. ---verbose
which enables the verbose mode of the compiler. This is needed to gather the AIT command call that Mercurium executes.We could add an unsupported argument in the AIT flags to make it abort, as we do not want the bitstream before the modifications. For example, we could add the
--abort
flag to--Wf
option of Mercurium. Example of Mercurium call and generated output:[user@machine] $ fpgacc --ompss -k --verbose --bitstream-generation --Wf,-b=zcu102,--hwruntime=som,--abort foo.c -o foo Loading compiler phases for profile 'fpgacc' Compiler phases for profile 'fpgacc' loaded in 0.02 seconds Compiling file 'foo.c' gcc -E -D_OPENMP=200805 -D_OMPSS=1 -I/home/user/opt/ompss/git/nanox/include/nanox -include nanos.h -include nanos_omp.h -include nanos-fpga.h -std=gnu99 -D_MCC -D_MERCURIUM -o /tmp/fpgacc_zHMisA foo.c File 'foo.c' preprocessed in 0.01 seconds Parsing file 'foo.c' ('/tmp/fpgacc_zHMisA') File 'foo.c' ('/tmp/fpgacc_zHMisA') parsed in 0.02 seconds Nanos++ prerun Early compiler phases pipeline executed in 0.00 seconds File 'foo.c' ('/tmp/fpgacc_zHMisA') semantically analyzed in 0.01 seconds Checking parse tree consistency Parse tree consistency verified in 0.00 seconds Freeing parse tree Parse tree freed in 0.00 seconds Checking integrity of nodecl tree Nodecl integrity verified in 0.00 seconds foo.c:1:13: info: unless 'no_copy_deps' is specified, the default in OmpSs is now 'copy_deps' foo.c:1:13: info: this diagnostic is only shown for the first task found foo.c:2:13: info: adding task function 'foo' for device 'fpga' Nanos++ phase foo.c:10:3: info: call to task function 'foo' foo.c:2:13: info: task function declared here FPGA bitstream generation phase analysis - ON Compiler phases pipeline executed in 0.01 seconds Prettyprinted into file 'fpgacc_foo.c' in 0.00 seconds Performing native compilation of 'fpgacc_foo.c' into 'foo.o' gcc -std=gnu99 -c -o foo.o fpgacc_foo.c File 'foo.c' ('fpgacc_foo.c') natively compiled in 0.02 seconds objdump -w -h foo.o 1> /tmp/fpgacc_d9sKiY gcc -o foo -std=gnu99 foo.o -Xlinker --enable-new-dtags -L/home/user/opt/ompss/git/nanox/lib/performance -Xlinker -rpath -Xlinker /home/user/opt/ompss/git/nanox/lib/performance -Xlinker --no-as-needed -lnanox-ompss -lnanox-c -lnanox -lpthread -lrt -lnanox-fpga-api Link performed in 0.04 seconds ait -b=zcu102 --hwruntime=som --abort --wrapper_version=7 -n=foo usage: ait -b BOARD -n NAME ait error: unrecognized arguments: --abort. Try 'ait -h' for more information. Link fpga failed Removing temporary filename '/tmp/fpgacc_d9sKiY' Removing temporary filename 'foo.o' Removing temporary filename '/tmp/fpgacc_zHMisA'
Now the intermediate files are available and we could edit them as desired. In the example,
7288177970:1:foo_hls_automatic_mcxx.cpp
is available:[user@machine] $ ls -l total 44 -rw-r--r-- 1 user user 3735 Jun 5 10:27 7288177970:1:foo_hls_automatic_mcxx.cpp -rwxr-xr-x 1 user user 17568 Jun 5 10:27 foo -rw-r--r-- 1 user user 235 Jun 4 15:17 foo.c -rw-r--r-- 1 user user 13460 Jun 5 10:27 fpgacc_foo.c
After modifying the HLS intermediate files, the AIT call that Mercurium usually performs has to be executed. In the verbose output of the first step, there is one line with the invoked call. This call has to be repeated, removing the extra options added to make AIT abort (if any). In the example, the
--abort
option has to be removed and the AIT command to invoke will be:[user@machine] $ ait -b=zcu102 --hwruntime=som --wrapper_version=7 -n=foo Using xilinx backend Checking vendor support for selected board ...