-
Notifications
You must be signed in to change notification settings - Fork 14
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
Hammerblade #101
Comments
It should definitely fit on vu47p. Perhaps the manycore config is set too large. Do you have a utilization report you can post? |
Following is the report: ERROR: [DRC UTLZ-1] Resource utilization: LUT as Logic over-utilized in Top Level Design (This design requires more LUT as Logic cells than are available in the target device. This design requires 71984 of such cell types but only 70560 compatible sites are available in the target device. Please analyze your synthesis results and constraints to ensure the design is mapped to Xilinx primitives as expected. If so, please consider targeting a larger device. Please set tcl parameter "drc.disableLUTOverUtilError" to 1 to change this error to warning.) |
Can you post the actual reports and not just the error? Would need to see the hierarchical breakdown to see where LUTs are going |
Copyright 1986-2022 Xilinx, Inc. All Rights Reserved.| Tool Version : Vivado v.2022.1 (lin64) Build 3526262 Mon Apr 18 15:47:01 MDT 2022
|
Above report is from ultra96v2. There is no vps_zynq_bd.vu47p.tcl in https://github.com/black-parrot-hdk/zynq-parrot/tree/master/cosim/tcl/bd |
Yes, so it should fit on vu47p. There is no vps configuration file as the vu47p is not a zynq part (no PS) For the vu47p, we use a uart bridge to emulate the PS. You can see the connection here: https://github.com/black-parrot-hdk/zynq-parrot/blob/master/cosim/xdc/board.vu47p.xdc and the cosimulation here: https://github.com/black-parrot-hdk/zynq-parrot/blob/master/cosim/include/bridge/bsg_zynq_pl.h but we haven’t open-sourced a hardware configuration as it’s a fairly custom solution. For the ultra96v2 that report is indicating it is very close to fitting. Reducing sizes of the structures in the BlackParrot cores may get you there. Take a look at the TinyParrot configuration in the aviary and experiment with reducing branch predictors and caches |
I am wondering, is there any possibility to port the hardware to Alveo U250 data center card (https://www.amd.com/en/products/accelerators/alveo/u250/a-u250-a64g-pq-g.html), if I can what are the changes to be done? By the way, bsg_manycore accelerator is 32 bit, can one change to 64 bit? If possible, what are the changes to be done? |
These are both very substantial projects. The U250 has a pynq port, so beginning there and working through the cosim examples is the way to start. Once cosim is working, hardware examples should port in a straightforward manner There was a student who ported the manycore toolchain to 64b: The hardware would require more changes, but primarily in parameterization. The actual RV64I ISA difference is minimal, especially if only F support is needed Both projects would require a highly motivated student for likely two+ quarters. Feel free to reach out to discuss funding for these efforts |
Thanks let me see. I was running vcs simulation from /home/ynq-parrot/cosim/hammerblade-example/vcs, I am getting following errors: "/home/zynq-parrot/cosim/v/bsg_zynq_pl_shell.sv", 405: bsg_nonsynth_zynq_testbench.dut.top_fpga_inst.zps.pl_to_ps[0].unnamed$$_0: started at 0ps failed at 0ps bsg_tag_master transitioning to error state; be sure to run gate-level netlist to avoid sim/synth mismatch (bsg_nonsynth_zynq_testbench.dut.top_fpga_inst.master) |
Please help, I am getting these errors in VCS: BSG ERROR (bsg_nonsynth_zynq_testbench.axil4.wready_gpio): final block executed before fini() was called |
Can you please point file and line number where I can experiment with aviary by reducing branch predictors and caches? |
I have curious question, why you did not use MicroBlaze soft core the project? |
Microblaze RISCV was released in 2024, BlackParrot has been around since 2018 when this project was started Microblaze cannot be taped out, only used in Xilinx FPGAs per license. This project is an ASIC prototype platform. There are currently one academic and two commercial tapeouts of BlackParrot+Manycore HammerBlades that I am aware of, and all were done with 0 licensing cost for this IP |
My question was, instead of using Zynq processor as PS, you could have used MicroBlaze as PS? I think MicroBlaze is compatible with most boards. |
I am curious about above question, can you please clarify? Many Thanks |
Keeping in mind our goal to SSH into the PS and compile the co-emulation code on it, there are two primary reasons that we chose to use the hard core:
By using Z2 boards in the way that we do, students can simply buy a board or ssh into a cluster and be ready to go immediately. That said, Alveo is a non-Zynq that has Pynq compatibility. However, I believe the “host code” is running all on the x86 and not a microblaze. I haven’t looked too closely into it though |
Thanks for the clarification. Yes you are right, in Alveo you can run host code on the x86 but PCIe driver is giving errors. Therefore, we are planning to use MicroBlaze soft IP core as PS. |
Yeah, PCIE is a nightmare to debug which is why we try to do as much as possible over Ethernet. Well, if you get a working PetaLinux build for microblaze+SSH, please open-source and send a PR. I'd certainly be interested in seeing if the infrastructure can support non-pynq boards |
Sure. I will let you know if we get it working on MicroBlaze... |
I am trying to implement hammerblade example in pynqz2,ultra96v2, and vu47p but it is running out of resources. This issue has been raised in #76 but even for ultra96v2 it is running out of resources. Please let me know which board to use. Thanks.
The text was updated successfully, but these errors were encountered: