Hi all, I'm currenlty gettting into embedded system architecture and would like to know where can I find any kind of tutorial/articles/lecture notes regarding the "art" of selecting the memory for my design I.E. what kind of memory to use SDRAM , SRAM ,FLASH ,EEPROM and where to use it. another thing I'm looking for is stuff on the subject of memory mapping I.E. how to arrange the different memories , peripherals etc. I hope you guys will be able to help me with those. Thanks in advance , Mordehay.
Memory selection for an embedded system
Started by ●February 10, 2006
Reply by ●February 10, 20062006-02-10
me_2003@walla.co.il wrote:> Hi all, > I'm currenlty gettting into embedded system architecture and would like > to know where can I find any kind of tutorial/articles/lecture notes > regarding the "art" of selecting the memory for my design I.E. what > kind of memory to use SDRAM , SRAM ,FLASH ,EEPROM and where to use it. > another thing I'm looking for is stuff on the subject of memory mapping > I.E. how to arrange the different memories , peripherals etc. > I hope you guys will be able to help me with those. > Thanks in advance , Mordehay.I'm not sure if there are any articles, for the simple reason one size never fits all in the embedded space (if anywhere at all). Just what memories you need depends on the system, the processor you use, the code / data requirements etc. There are many systems with no external memory (where external means a separate chip from the processor) and there are some with huge amounts of all the types you list. To determine the type and amount you need, you first need a requirement and know what processor you are going to use. The processor decision is usually driven in part by the memory requirement, too. I usually decide what the processor is going to be (based on all the requirements - performance, integrated options, memory overall requirements), but the processor decision is not simply driven by the performance requirement. It's various built-in interfaces (if they exist) are a large part of the decision. Different processors support differing types of memory directly, which impacts the decision, and differing system requirements will vary what is necessary. So there is no silver bullet for this, nor can it be reduced to an equation - that's why we have designers :) I have personally designed systems from controller only (no external memory) to boards with a SoC [multiple cores], 3 independent DDR memory systems, large amounts of flash (some for FPGA loading, some for boot), lots of serial eeprom and even some SRAM on board (on a single board) and most things in between. So - set a requirement for what your board must do, and go from there. Cheers PeteS
Reply by ●February 11, 20062006-02-11
The types of memories that you mentioned, SDRAM, SRAM, FLASH, and EEPROM, all have certain features that make them an advantage or dis-advantage in certain situations. For example, SDRAM will be fast and high density per dollar, but it requires a refresh circuit which isn't necessarilly feasible on an embedded application. Therefore, SRAM is often times use instead as it doesn't require this, but it is a bit slower (70ns is typical I think) and slightly more expensive. The last time I looked, a 256K x 16 SRAM chip on digikey was about $4 for one device, which for most embedded systems, unless you call pentium computers running windows an embedded system, which I don't, is a lot of memory. Flash, on the other hand is non volatile, fairly high density and is reprogrammable, often times used as ROM while EEPROM is also nonvolatile, but fairly low density and speed. The choice of which type of memory you select depends on the goal of the application and a typical system will likely have multiple form of memory in it.
Reply by ●February 14, 20062006-02-14
Noway2 wrote:> The types of memories that you mentioned, SDRAM, SRAM, FLASH, and > EEPROM, all have certain features that make them an advantage or > dis-advantage in certain situations. For example, SDRAM will be fast > and high density per dollar, but it requires a refresh circuit which > isn't necessarilly feasible on an embedded application. Therefore, > SRAM is often times use instead as it doesn't require this, but it is a > bit slower (70ns is typical I think) and slightly more expensive. The > last time I looked, a 256K x 16 SRAM chip on digikey was about $4 for > one device, which for most embedded systems, unless you call pentium > computers running windows an embedded system, which I don't, is a lot > of memory. Flash, on the other hand is non volatile, fairly high > density and is reprogrammable, often times used as ROM while EEPROM is > also nonvolatile, but fairly low density and speed. > > The choice of which type of memory you select depends on the goal of > the application and a typical system will likely have multiple form of > memory in it.
Reply by ●February 14, 20062006-02-14
The SDRAM size selection is not only depends on the Processor interface but it has certain other factors also. Processor interface is responsible for how much maximum size a processor can support SDRAM The other factors are like a) Code execution from SDRAM ( u have code on Hard disc or on NAND flash on ur system, u have to copy the code to SDRAM for execution) b) Runtime allocation of memory ( Task stack, heap) c) Stack Size d) SDARM used for back up ( say during format). I am also really interested to know any standard free tool is available on WEB for initial estimate of SDRAM size
Reply by ●February 14, 20062006-02-14
surojit wrote:> The SDRAM size selection is not only depends on the Processor interface > but it has certain other factors also. Processor interface is > responsible for how much maximum size a processor can support SDRAM > The other factors are like a) Code execution from SDRAM ( u have code > on Hard disc or on NAND flash on ur system, u have to copy the code to > SDRAM for execution) b) Runtime allocation of memory ( Task stack, > heap) c) Stack Size d) SDARM used for back up ( say during format). > > I am also really interested to know any standard free tool is available > on WEB for initial estimate of SDRAM size^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ This must be a joke. You will need to know what cpu your using, what application you trying to do. And you want it FREE !!! This is a joke. Look at the stars, its as good as you'll get. donald
Reply by ●February 14, 20062006-02-14
Donald wrote:> surojit wrote: > > > The SDRAM size selection is not only depends on the Processor interface > > but it has certain other factors also. Processor interface is > > responsible for how much maximum size a processor can support SDRAM > > The other factors are like a) Code execution from SDRAM ( u have code > > on Hard disc or on NAND flash on ur system, u have to copy the code to > > SDRAM for execution) b) Runtime allocation of memory ( Task stack, > > heap) c) Stack Size d) SDARM used for back up ( say during format). > > > > I am also really interested to know any standard free tool is available > > on WEB for initial estimate of SDRAM size > ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ > > This must be a joke. > > You will need to know what cpu your using, what application you trying > to do. > > And you want it FREE !!! > > This is a joke. > > Look at the stars, its as good as you'll get. > > donaldSnort It's not free - usually a *minimum* of a decade of experience and caffeine tolerance levels at 'astronomical' are required. Hair loss not guaranteed but likely. :) Cheers PeteS