Forum Discussion

Altera_Forum's avatar
Altera_Forum
Icon for Honored Contributor rankHonored Contributor
10 years ago

Using IOWR IOED on Cyclone 5 SoC with HPS

Hi,

I have the standard ALTERA timer_core element in (Cyclone 5 SoC with HPS) FPGA. I try to access its registers using:

# define IOWR(offset, x, data) (*((volatile UINT32*)(offset)) = data) // WR access

# define IORD(offset, x) (*(volatile UINT32*)(offset)) // RD access

However, I get exception.

Using the same macros for HPS peripherals is fine, no problem...

I wonder, what's wrong? What should I use instead?

Thanks!

Ran

1 Reply

  • Altera_Forum's avatar
    Altera_Forum
    Icon for Honored Contributor rankHonored Contributor

    You need to add the base address of the peripheral. The reason this works for HPS is that the base offset is fixed and defined starting at 0 rather than the beginning of the device's register space.

    All of the standard Altera cores will have code generated for them in the BSP. You should use that rather than writing it yourself.