sh_cl_ddr_is_ready not being asserted

0

I have a new design, only using DDR C in the SH, not the other 3 (I've instanced sh_ddr with them disabled). My design works OK in simulation but when I actually make it and load it into an FPGA instance sh_cl_ddr_is_ready never gets asserted. I can talk to my design over PCIS so it's awake and doing stuff, just not initialising the DDR.

As I understand it I don't need to do anything on the C side, it should all just come up, I'm calling fpga_mgmt_init()/fpga_pci_attach()/fpga_pci_get_address() and doing 64-bit reads/writes directly (as mentioned above that bit works OK)

So is there something I'm doing wrong? some pin in the interface that needs to be initialised that I've missed?

Taniwha
preguntada hace 4 años268 visualizaciones
7 Respuestas
0

Hi,

Can you please try to force load the fpga image (AGFI) using the, -F option for the fpga-load-local-image command.
-F, --force-shell-reload
Reload the FPGA shell on AFI load, even if the next AFI
doesn't require it.

fpga-load-local-image -S <slot_num> -I <image_agfi_id> -F

This should reset the FPGA shell logic, before loading the custom logic (CL).

respondido hace 4 años
0

Thanks for the response, I tried this without any change, still no assertion of sh_cl_ddr_is_ready I'm afraid.

One question, do I need to hook up the stats interface on the sh_ddr() if I'm only using the C DDR instance?

Taniwha
respondido hace 4 años
0

Hello,

We have couple of follow up questions:

  1. How do you probe "sh_cl_ddr_is_ready" in your CL? Do you connect it to some register or an ILA?

  2. The stats interface must be tied off, if you are not using the DDR Controllers (DDR-A, DDR-B, DDR-D) in the CL.
    https://github.com/aws/aws-fpga/blob/master/hdk/common/shell_v04261818/design/interfaces/cl_ports.vh#L194
    Alternatively, you may include the following file in top level CL which will automatically tie-off unused DDR interfaces:
    https://github.com/aws/aws-fpga/blob/master/hdk/common/shell_v04261818/design/interfaces/unused_ddr_a_b_d_template.inc

  3. With sh_cl_ddr_is_ready = 0, the data transfer to/from DDR-C has no issues and works just fine. Can you confirm if my understanding is correct here?

  4. Do you see same issues if you try on another instance?

Thanks!
Chakra

Edited by: awschakra on Sep 23, 2020 9:23 AM

AWS
respondido hace 4 años
0
  1. I'm using an ILA, it also samples a bunch of other things in CL, mostly resets, they seem sane (I include sh_cl_ddr_is_ready in the reset logic to the underlying logic, so nothing else comes out of reset)
  2. mostly I had it tied off, I'd had started with the code from ./common/shell_v04261818/new_cl_template/design/cl_template.sv that's used when you run the new design script - in it the nets tie_zero_stat_addr and tie_zero_stat_data are left floating, I just forced them to 0s but that had no effect on what's happening here (note there's other stuff wrong in this file that I've had to fix too - for example the sh_ddr's clock is left floating)
Taniwha
respondido hace 4 años
0
  1. I think it fails to work when sh_cl_ddr_is_ready is 0 (the simulation model stalls until it goes to 0) I'll rebuild and make sure what happens in the FPGA

  2. seems to fail in every instance (I'm running in Sydney is that helps)

Taniwha
respondido hace 4 años
0

Hi,

Unfortunately we are unable to reproduce this issue on our end. I modified CL_HELLO_WORLD example to probe "sh_cl_ddr_is_ready" signal using an ILA, and see that sh_cl_ddr_is_ready=1.
https://github.com/aws/aws-fpga/blob/master/hdk/cl/examples/cl_hello_world/design/cl_hello_world.sv

Attached is the ILA snapshot from my run on an F1 instance.

Could you try using our example design to ensure its working for you?

Thanks!
Chakra

AWS
respondido hace 4 años
0

Thanks for your help - I've solved this - essentially the problem was that I was setting both the pcie vendor and device ids to 0 - the fpga instance would let me load it (with a warning) and would run with some functionality, but some parts (like the dram) didn't get correctly initialised.

I made this (noob) mistake because, as mentioned above, I started with the script that copies from the file ./common/shell_v04261818/new_cl_template/design/cl_template.sv - which contains the lines:

//-------------------------------------------
// Tie-Off Global Signals
//-------------------------------------------
assign cl_sh_id0[31:0] = 32'h0000_0000;
assign cl_sh_id1[31:0] = 32'h0000_0000;

Chakra - might I suggest the following changes for these files for your next software release, to save someone else dealing with this:

  1. include a valid version of the cl_id_defines.vh file in with cl_template.sv
  2. include cl_id_defines.vh in cl_template.sv and change: assign cl_sh_id0\[31:0] = CL_SH_ID0;
    assign cl_sh_id1[31:0] = `CL_SH_ID1;
  3. hook up the clocks to sh_ddr() to something so they're not left hangin
  4. connect tie_zero_stat_addr and tie_zero_stat_data to something

again thanks for your help - Paul

Taniwha
respondido hace 4 años

No has iniciado sesión. Iniciar sesión para publicar una respuesta.

Una buena respuesta responde claramente a la pregunta, proporciona comentarios constructivos y fomenta el crecimiento profesional en la persona que hace la pregunta.

Pautas para responder preguntas