Nios® V/II Embedded Design Suite (EDS)
Support for Embedded Development Tools, Processors (SoCs and Nios® V/II processor), Embedded Development Suites (EDSs), Boot and Configuration, Operating Systems, C and C++

Custom FIFO read in Nios IDE

Altera_Forum
Honored Contributor II
1,143 Views

I created a custom fifo in sopc builder and i am trying to read data from fifo. However, i got no idea about how to manipulate it .Is it right if i make a pointer which points at the base address of the fifo ? 

 

As i am a starter in FPGA & NIOS,or maybe my question is so simple, i would be so appreciate if some give some advice when i meet this kind of problem... 

Thanks.
0 Kudos
5 Replies
Altera_Forum
Honored Contributor II
399 Views

Is there anyone who can give some advice? I would be so appreciate..

0 Kudos
Altera_Forum
Honored Contributor II
399 Views

You have basically the choice between the IORD/WR macros to directly access hardware, or use pointers to the base address. 

If possible it's better to use pointers, as this method is probably more futureproof than the macros, especially if you plan to move to a MMU system one day. There is just one thing to be careful about when using pointers to access hardware: you must avoid using the CPU's data cache. For that the best way is to use the alt_remap_uncached() function (see page 14-47 of this document (http://www.altera.com/literature/hb/nios2/n2sw_nii52010.pdf)) to convert your base address to an uncached pointer.
0 Kudos
Altera_Forum
Honored Contributor II
399 Views

 

--- Quote Start ---  

You have basically the choice between the IORD/WR macros to directly access hardware, or use pointers to the base address. 

If possible it's better to use pointers, as this method is probably more futureproof than the macros, especially if you plan to move to a MMU system one day. There is just one thing to be careful about when using pointers to access hardware: you must avoid using the CPU's data cache. For that the best way is to use the alt_remap_uncached() function (see page 14-47 of this document (http://www.altera.com/literature/hb/nios2/n2sw_nii52010.pdf)) to convert your base address to an uncached pointer. 

--- Quote End ---  

 

 

So..if my custom fifo-ip's address is 0x04000400 to 0x04000401(the span is 2) and the CUSTOM_FIFO_IP_BASE points at 0x04000400, may i program like the following ? 

 

for(counter = 0 ;counter < 255 ;counter++) { write_buffer = *(alt_16 *) (CUSTOM_FIFO_IP_BASE) ; }  

 

Write_buffer stores the data to be sent.
0 Kudos
Altera_Forum
Honored Contributor II
399 Views

If you have a data cache then this won't work. On the first loop iteration the CPU will read from your FIFO, but for the next iterations it will just read the value again from the cache instead of accessing your FIFO. Something like this would be better (not tested)#include <sys/alt_cache.h> alt_16 *my_fifo = alt_remap_uncached((void*)CUSTOM_FIFO_IP_BASE,sizeof(alt_16)); for(counter = 0 ;counter < 255 ;counter++) { write_buffer = *my_fifo ; }

0 Kudos
Altera_Forum
Honored Contributor II
399 Views

A slightly separate issue. 

Give your fifo a 32bit interface. Since the fifo itself is 16bits wide set the high bits to zero on reads. 

As defined you'll find that the actual span is 4 bytes and you'll see two read cycles for every access (the second one will have a different address). Since the nios cpu always asserts all 4 byte enables for reads, both reads will have both byte enables asserted. 

If you do a 16bit write, one of the writes has no asserted byte enables. 

I'm not sure the order of the accesses is defined either.
0 Kudos
Reply