1 Introduction to RAM Random-access memory, or RAM, provides large quantities of temporary storage in a computer system. Remember the basic capabilities.

Slides:



Advertisements
Similar presentations
MEMORY popo.
Advertisements

Chapter 5 Internal Memory
Combinational Circuits
M. Mateen Yaqoob The University of Lahore Spring 2014.
Flip-Flops Last time, we saw how latches can be used as memory in a circuit. Latches introduce new problems: We need to know when to enable a latch. We.
The 8085 Microprocessor Architecture
1 Microprocessor History. 2 The date is the year that the processor was first introduced. Many processors are re- introduced at higher clock speeds for.
Random access memory Sequential circuits all depend upon the presence of memory. A flip-flop can store one bit of information. A register can store a single.
What is memory? Memory is used to store information within a computer, either programs or data. Programs and data cannot be used directly from a disk or.
Henry Hexmoor1 Chapter 7 Henry Hexmoor Registers and RTL.
Chapter 9 Memory Basics Henry Hexmoor1. 2 Memory Definitions  Memory ─ A collection of storage cells together with the necessary circuits to transfer.
1 The Basic Memory Element - The Flip-Flop Up until know we have looked upon memory elements as black boxes. The basic memory element is called the flip-flop.
Memory and Programmable Logic
1 Lecture 16B Memories. 2 Memories in General Computers have mostly RAM ROM (or equivalent) needed to boot ROM is in same class as Programmable Logic.
Overview Memory definitions Random Access Memory (RAM)
PLA, Cache memory Prof. Sin-Min Lee Department of Computer Science.
Dynamic memory in a nutshell
Registers  Flip-flops are available in a variety of configurations. A simple one with two independent D flip-flops with clear and preset signals is illustrated.
Lecture 4: Computer Memory
1Registers and Counters Acknowledgement: Most of the following slides are adapted from Prof. Kale's slides at UIUC, USA.
1 EE365 Read-only memories Static read/write memories Dynamic read/write memories.
CS 151 Digital Systems Design Lecture 31 Read Only Memory (ROM)
CS1104-8Memory1 CS1104: Computer Organisation Lecture 8: Memory
Counters and Registers
MEMORY.
Memory. Random Access Memory Defined What is memory? operating system and other system software that control the usage of the computer equipment application.
EKT 221 Digital Electronics II
Khaled A. Al-Utaibi Memory Devices Khaled A. Al-Utaibi
CS1Q Computer Systems Lecture 8
EKT 221 : Digital 2 Memory Basics
Logic and Computer Design Dr. Sanjay P. Ahuja, Ph.D. FIS Distinguished Professor of CIS ( ) School of Computing, UNF.
1 CSCI 2510 Computer Organization Memory System I Organization.
Memory and Programmable Logic Memory device: Device to which binary information is transferred for storage, and from which information is available for.
IKI c-Decoders, Selectors, etc. Bobby Nazief Semester-I The materials on these slides are adopted from: CS231’s Lecture Notes at UIUC,
Lecture 30 Read Only Memory (ROM)
Memory and Storage Dr. Rebhi S. Baraka
Computer Architecture CST 250 MEMORY ARCHITECTURE Prepared by:Omar Hirzallah.
CPEN Digital System Design
Khaled A. Al-Utaibi  Memory Interface and the 3 Buses  Interfacing the 8088 Processor  Interfacing the 8086 Processor  Interfacing.
SEQUENTIAL CIRCUITS Component Design and Use. Register with Parallel Load  Register: Group of Flip-Flops  Ex: D Flip-Flops  Holds a Word of Data 
+ CS 325: CS Hardware and Software Organization and Architecture Memory Organization.
PHY 201 (Blum)1 Microcode Source: Digital Computer Electronics (Malvino and Brown)
CS231 Boolean Algebra1 Summary so far So far: – A bunch of Boolean algebra trickery for simplifying expressions and circuits – The algebra guarantees us.
ECEN 248: INTRODUCTION TO DIGITAL SYSTEMS DESIGN Dr. Shi Dept. of Electrical and Computer Engineering.
Computer operation is of how the different parts of a computer system work together to perform a task.
Random Access Memory (RAM).  A memory unit stores binary information in groups of bits called words.  The data consists of n lines (for n-bit words).
COMP541 Memories II: DRAMs
1 KU College of Engineering Elec 204: Digital Systems Design Lecture 22 Memory Definitions Memory ─ A collection of storage cells together with the necessary.
Introduction to Computing Systems and Programming Digital Logic Structures.
07/11/2005 Register File Design and Memory Design Presentation E CSE : Introduction to Computer Architecture Slides by Gojko Babić.
© 2009 Pearson Education, Upper Saddle River, NJ All Rights ReservedFloyd, Digital Fundamentals, 10 th ed Digital Logic Design Dr. Oliver Faust.
REGISTER TRANSFER LANGUAGE (RTL) INTRODUCTION TO REGISTER Registers1.
CS 1410 Intro to Computer Tecnology Computer Hardware1.
D IGITAL ELECTRONICS Prepared By - Patel Aniket ( )
Computer Architecture Chapter (5): Internal Memory
Introduction to RAM Random-access memory, or RAM, provides large quantities of temporary storage in a computer system. Remember the basic capabilities.
REGISTER TRANSFER LANGUAGE (RTL)
MEMORY.
Random access memory Sequential circuits all depend upon the presence of memory. A flip-flop can store one bit of information. A register can store a single.
Random access memory Sequential circuits all depend upon the presence of memory. A flip-flop can store one bit of information. A register can store a single.
Memory chips Memory chips have two main properties that determine their application, storage capacity (size) and access time(speed). A memory chip contains.
An Introduction to Microprocessor Architecture using intel 8085 as a classic processor
Other memories Last time we showed how to build arbitrarily-large static memories from single-bit RAM cells. Today we’ll look at some other kinds of memories.
Other memories Last time we showed how to build arbitrarily-large static memories from single-bit RAM cells. Today we’ll look at some other kinds of memories.
Datapaths For the rest of the semester, we’ll focus on computer architecture: how to assemble the combinational and sequential components we’ve studied.
Recall: ROM example Here are three functions, V2V1V0, implemented with an 8 x 3 ROM. Blue crosses (X) indicate connections between decoder outputs and.
Recall: ROM example Here are three functions, V2V1V0, implemented with an 8 x 3 ROM. Blue crosses (X) indicate connections between decoder outputs and.
Random access memory Sequential circuits all depend upon the presence of memory. A flip-flop can store one bit of information. A register can store a single.
ECE 352 Digital System Fundamentals
Presentation transcript:

1 Introduction to RAM Random-access memory, or RAM, provides large quantities of temporary storage in a computer system. Remember the basic capabilities of a memory: – It should be able to store a value. – You should be able to read the value that was saved. – You should be able to change the stored value. A RAM is similar, except that it can store many values. – An address will specify which memory value we’re interested in. – Each value can be a multiple-bit word (e.g., 32 bits). We’ll refine the memory properties as follows: A RAM should be able to: - Store many words, one per address - Read the word that was saved at a particular address - Change the word that’s saved at a particular address

2 Picture of memory You can think of computer memory as being one big array of data. – The address serves as an array index. – Each address refers to one word of data. You can read or modify the data at any given memory address, just like you can read or modify the contents of an array at any given index.

3 Block diagram of RAM This block diagram introduces the main interface to RAM. – A Chip Select, CS, enables or disables the RAM. – ADRS specifies the address or location to read from or write to. – WR selects between reading from or writing to the memory.  To read from memory, WR should be set to 0. OUT will be the n-bit value stored at ADRS.  To write to memory, we set WR = 1. DATA is the n-bit value to save in memory. This interface makes it easy to combine RAMs together, as we’ll see. 2 k x n memory ADRSOUT DATA CS WR k n n

4 Memory sizes We refer to this as a 2 k x n memory. – There are k address lines, which can specify one of 2 k addresses. – Each address contains an n-bit word. For example a 2 24 x 16 RAM contains 2 24 = 16M words, each 16 bits long. – The RAM would need 24 address lines. – The total storage capacity is 2 24 x 16 = 2 28 bits. 2 k x n memory ADRSOUT DATA CS WR k n n

5 Size matters! Memory sizes are usually specified in numbers of bytes (8 bits). The bit memory on the previous page translates into: 2 28 bits / 8 bits per byte = 2 25 bytes With the abbreviations below, this is equivalent to 32 megabytes.

6 Typical memory sizes Some typical memory capacities: – PCs usually come with MB RAM. Many operating systems implement virtual memory, which makes the memory seem larger than it really is. – Most systems allow up to 32-bit addresses. This works out to 2 32, or about four billion, different possible addresses. – With a data size of one byte, the result is apparently a 4GB memory! – The operating system uses hard disk space as a substitute for “real” memory.

7 Reading RAM To read from this RAM, the controlling circuit must: – Enable the chip by ensuring CS = 1. – Select the read operation, by setting WR = 0. – Send the desired address to the ADRS input. – The contents of that address appear on OUT after a little while. Notice that the DATA input is unused for read operations. 2 k x n memory ADRSOUT DATA CS WR k n n

8 Writing RAM To write to this RAM, you need to: – Enable the chip by setting CS = 1. – Select the write operation, by setting WR = 1. – Send the desired address to the ADRS input. – Send the word to store to the DATA input. The output OUT is not needed for memory write operations. 2 k x n memory ADRSOUT DATA CS WR k n n

9 My first RAM We can use these cells to make a 4 x 1 RAM. Since there are four words, ADRS is two bits. Each word is only one bit, so DATA and OUT are one bit each. Word selection is done with a decoder attached to the CS inputs of the RAM cells. Only one cell can be read or written at a time. Notice that the outputs are connected together with a single line!

10 Those funny triangles The triangle represents a three-state buffer. Unlike regular logic gates, the output can be one of three different possibilities, as shown in the table. “Disconnected” means no output appears at all, in which case it’s safe to connect OUT to another output signal. The disconnected value is also sometimes called high impedance or Hi-Z.

11 Connecting three-state buffers together You can connect several three-state buffer outputs together if you can guarantee that only one of them is enabled at any time. The easiest way to do this is to use a decoder ! If the decoder is disabled, then all the three-state buffers will appear to be disconnected, and OUT will also appear disconnected. If the decoder is enabled, then exactly one of its outputs will be true, so only one of the tri-state buffers will be connected and produce an output. The net result is we can save some wire and gate costs. We also get a little more flexibility in putting circuits together.

12 Bigger and better Here is the 4 x 1 RAM once again. How can we make a “wider” memory with more bits per word, like maybe a 4 x 4 RAM? Duplicate the stuff in the blue box!

13 A 4 x 4 RAM DATA and OUT are now each four bits long, so you can read and write four-bit words.

14 Bigger RAMs from smaller RAMs We can use small RAMs as building blocks for making larger memories, by following the same principles as in the previous examples. Example suppose we have some 64K x 8 RAMs to start with: – 64K = 2 6 x 2 10 = 2 16  there are 16 address lines. – There are 8 data lines

Making a larger memory Example Design a 256K x 8 memory, given that you have 64K x 8 chips Solution For 256K words, we need 18 address lines. – The two most significant address lines go to the decoder, which selects one of the four 64K x 8 RAM chips. – The other 16 address lines are shared by the 64K x 8 chips. The 64K x 8 chips also share WR and DATA inputs. This assumes the 64K x 8 chips have three-state outputs.

16 Analyzing the 256K x 8 RAM There are 256K words of memory, spread out among the four smaller 64K x 8 RAM chips. When the two most significant bits of the address are 00, the bottom RAM chip is selected. It holds data for the first 64K addresses. The next chip up is enabled when the address starts with 01. It holds data for the second 64K addresses. The third chip up holds data for the next 64K addresses. The final chip contains the data of the final 64K addresses

17 Address ranges (0x3ffff) to (0x30000) (0x2ffff) to (0x20000) (0x1ffff) to (0x10000) (0x0ffff) to (0x00000)

18 Making a wider memory You can also combine smaller chips to make wider memories, with the same number of addresses but more bits per word. Example Design a 64K x 16 RAM, using two 64K x 8 chips. – The left chip contains the most significant 8 bits of the data. – The right chip contains the lower 8 bits of the data

19 Dynamic memory Dynamic memory is built with capacitors. – A stored charge on the capacitor represents a logical 1. – No charge represents a logic 0. However, capacitors lose their charge after a few milliseconds. The memory requires constant refreshing to recharge the capacitors. (That’s what’s “dynamic” about it.) Dynamic RAMs tend to be physically smaller than static RAMs. – A single bit of data can be stored with just one capacitor and one transistor, while static RAM cells typically require 4-6 transistors. – This means dynamic RAM is cheaper and denser—more bits can be stored in the same physical area.

20 Synchronous DRAM Memory chips are organized into “modules” that are connected to the CPU via a 64-bit (8-byte) bus. Speeds are rated in megahertz: PC66, PC100 and PC133 memory run at 66MHz, 100MHz and 133MHz respectively. Memory bandwidth = # of transfers/sec X size of each transfer – PC100 can transfer up to 800MB/sec  (100MHz x 8 bytes/cycle). Example Given an SDRAM with bus speed of 100MHz and bus width of 8-bytes, then Find the memory bandwidth? Memory bandwidth = 100MHz x 8 bytes/cycle = 800MB/sec

21 Double Data Rate RAM Similar to regular SDRAM, except data can be transferred on both the positive and negative clock edges. For MHz buses, the effective memory speeds appear to be MHz. DDR-RAM has lower power consumption, using 2.5V instead of 3.3V like SDRAM. This makes it good for notebooks and other mobile devices.

22 Example Given a DDR-RAM with bus speed of 100MHz and bus width of 8-bytes. Find the : A) Effective memory speed? Since data can be transferred on positive and negative edge then Effective memory speed = 2 X 100MHz B) Maximum transfer rate? = 200MHz X 8 bytes/cycle = 1600 MB/s

23 RDRAM Another new type of memory called RDRAM is used in the Playstation 2 as well as some Pentium 4 computers. The data bus is only 16 bits wide. But the memory runs at 400MHz, and data can be transferred on both the positive and negative clock edges. – That works out to a maximum transfer rate of 1.6GB per second. – You can also implement two “channels” of memory, resulting in up to 3.2GB/s of bandwidth. (from amazon.com)

24 Dynamic vs. static memory Dynamic RAM is used for a computer’s main memory, since it’s cheap and you can pack a lot of storage into a small space. Disadvantage of dynamic RAM is its speed. – Transfer rates are 800MHz at best, which can be much slower than the processor itself. – You also have to consider latency, or the time it takes data to travel from RAM to the processor. Real systems augment dynamic memory with small fast sections of static memory called caches.

25 Read-only memory A ROM, is a special kind of memory whose contents cannot be easily modified. – The WR and DATA inputs that we saw in RAMs are not needed. – Data is stored onto a ROM chip using special hardware tools. ROMs are useful for holding data that never changes. – Arithmetic circuits might use tables to speed up computations of logarithms or divisions. – Many computers use a ROM to store important programs that should not be modified, such as the system BIOS. – Game machines, cell phones, vending machines and other electronic devices may also contain non-modifiable programs. 2 k x n ROM ADRSOUT CS kn

26 Memories and functions ROMs are actually combinational devices, not sequential ones! – You can’t store arbitrary data into a ROM, so the same address will always contain the same data. A ROM table is basically just a truth table. – The table shows what data is stored at each ROM address. – You can generate that data combinationally, using the address as the input.

27 Decoders We can already convert truth tables to circuits easily, with decoders. For example, you can think of this old circuit as a memory that “stores” the sum and carry outputs from the truth table on the right.

28 ROM setup ROMs are based on this decoder implementation of functions. – A blank ROM just provides a decoder and several OR gates. – The connections between the decoder and the OR gates are “programmable,” so different functions can be implemented. To program a ROM, you just make the desired connections between the decoder outputs and the OR gate inputs.

29 ROM example Here are three functions, V 2 V 1 V 0, implemented with an 8 x 3 ROM. Blue crosses (X) indicate connections between decoder outputs and OR gates. Otherwise there is no connection. V 2 =  m(1,2,3,4)V 1 =  m(2,6,7)V 0 =  m(4,6,7) A2A1A0A2A1A0

30 V2V1V0V2V1V0 A2A1A0A2A1A0 The same example again Here is an alternative presentation of the same 8 x 3 ROM, using “abbreviated” OR gates to make the diagram neater. V 2 =  m(1,2,3,4) V 1 =  m(2,6,7) V 0 =  m(4,6,7)

31 Why is this a “memory”? This combinational circuit can be considered a read-only memory. – It stores eight words of data, each consisting of three bits. – The decoder inputs form an address, which refers to one of the eight available words. – So every input combination corresponds to an address, which is “read” to produce a 3-bit data output. V2V1V0V2V1V0 A2A1A0A2A1A0

32 Programmable logic arrays A ROM is potentially inefficient because it uses a decoder, which generates all possible minterms. No circuit minimization is done. Using a ROM to implement an n-input function requires – An n-to-2 n decoder, with n inverters and 2 n n-input AND gates. – An OR gate with up to 2 n inputs. – The number of gates roughly doubles for each additional ROM input. A programmable logic array, makes the decoder part of the ROM “programmable” too. Instead of generating all minterms, you can choose which products (not necessarily minterms) to generate.

33 A blank 3 x 4 x 3 PLA This is a 3 x 4 x 3 PLA (3 inputs, up to 4 product terms, and 3 outputs), ready to be programmed. The left part of the diagram replaces the decoder used in a ROM. Connections can be made in the “AND array” to produce four arbitrary products, instead of 8 minterms as with a ROM. Those products can then be summed together in the “OR array.” Inputs Outputs AND array OR array

34 Regular K-map minimization The normal K-map approach is to minimize the number of product terms for each individual function. For our three functions, this would result in a total of six different product terms. V2V1V0V2V1V0 V 2 =  m(1,2,3,4) V 1 =  m(2,6,7) V 0 =  m(4,6,7)

35 PLA minimization For a PLA, we should minimize the number of product terms for all functions together. We could express V 2, V 1 and V 0 with just four total products: V 2 = xy’z’ + x’z + x’yz’V 1 = x’yz’ + xyV 0 = xy’z’ + xy V 2 =  m(1,2,3,4) V 1 =  m(2,6,7) V 0 =  m(4,6,7)

36 PLA example So we can implement these three functions using a 3 x 4 x 3 PLA: V2V1V0V2V1V0 xy’z’ xy x’z x’yz’ V 2 =  m(1,2,3,4)= xy’z’ + x’z + x’yz’ V 1 =  m(2,6,7)= x’yz’ + xy V 0 =  m(4,6,7)= xy’z’ + xy A2A1A0A2A1A0