Welcome to EDAboard.com

Welcome to our site! EDAboard.com is an international Electronics Discussion Forum focused on EDA software, circuits, schematics, books, theory, papers, asic, pld, 8051, DSP, Network, RF, Analog Design, PCB, Service Manuals... and a whole lot more! To participate you need to register. Registration is free. Click here to register now.

Help me write a code for CoreGen memory module

Status
Not open for further replies.

suddy72

Member level 2
Joined
Jun 28, 2007
Messages
50
Helped
0
Reputation
0
Reaction score
0
Trophy points
1,286
Activity points
1,694
Hi guys,

I thought i had cracked the core gen memory module but its not doing what i expected.

When you create the module, you have your data_in line , clk , address , write enable and data_out signals.

Do you have to have a command like address <= address + 1 to get to the next memory address or will it do it aumomatically after every rising clock edge?

I have written code so that writes data_in to every addresss in the module then when it gets to end it jumps to the second address down and leaves the first one alone. Then when we = '0' is should show the contents in memory 1 , but it doesnt , it seems like its writing to that location , even though i have not told it to.

any help or code would be great.

cheers people.
 

rberek

Full Member level 6
Joined
May 23, 2007
Messages
339
Helped
98
Reputation
202
Reaction score
83
Trophy points
1,308
Location
Canada
Activity points
4,042
Re: CoreGen Memory

You have to update the address yourself. It does not do it for you.

Why does it seem like its writing to that location?
 

suddy72

Member level 2
Joined
Jun 28, 2007
Messages
50
Helped
0
Reputation
0
Reaction score
0
Trophy points
1,286
Activity points
1,694
Re: CoreGen Memory

Thanks for reply.

See when the address gets to the end of the memory , ie say 1111 does it automatically go back to 0000 or does it just stop ?
 

rberek

Full Member level 6
Joined
May 23, 2007
Messages
339
Helped
98
Reputation
202
Reaction score
83
Trophy points
1,308
Location
Canada
Activity points
4,042
Re: CoreGen Memory

The address doesn't automatically do anything. You are responsible for providing the address. It will write to the address you provide, and assume nothing else about the address.
 

suddy72

Member level 2
Joined
Jun 28, 2007
Messages
50
Helped
0
Reputation
0
Reaction score
0
Trophy points
1,286
Activity points
1,694
Re: CoreGen Memory

So does that mean when the address is at "1111" which is the last address in my memory array, if the command is address ,= address + 1; will it just stay where it is or what will it do ?
 

rberek

Full Member level 6
Joined
May 23, 2007
Messages
339
Helped
98
Reputation
202
Reaction score
83
Trophy points
1,308
Location
Canada
Activity points
4,042
Re: CoreGen Memory

My assumption:

The value address that you are generating is a register that provides the input to the memory's address port. The register will take on whatever value you give it. If the address register is 4 bits, and it is at 1111 ,when you increment it by one, it will go to 0000. If it is five bits, its value will go to 10000. In your RTL, you have connected that register to the address port to provide the address input. If your memory address port is 4 bits wide, the memory's address value will change to 0000. If it is five bits wide, your memory's address value will change to 10000.
 

echo47

Advanced Member level 5
Joined
Apr 7, 2002
Messages
3,942
Helped
637
Reputation
1,272
Reaction score
88
Trophy points
1,328
Location
USA
Activity points
33,183
CoreGen Memory

If you can show us your code (preferably a short complete module), maybe someone here can help you debug it.

If your are using Xiling XST, remember that you could create the RAM by using an HDL register array instead of instantiating a coregen RAM. You may find it easier to use and debug. For more info, see your XST User Guide chapter "HDL Coding Techniques" section "RAMs and ROMs".
 

Status
Not open for further replies.

Part and Inventory Search

Welcome to EDABoard.com

Sponsor

Top