66

I have two sticks of RAM in my computer that I would like to sell or donate. From what I understand some RAM is volatile, losing all its contents when power is gone for a few minutes, and some is non-volatile, retaining that information after power is lost. I would like to know which kind of RAM I have and whether it is safe to give it to someone else.

I am not very tech savvy, all I know about the sticks is that the manufacturer is Kingston, and when I open Task Manager it says that it is "DDR3" and the form factor is "DIMM".

schroeder
  • 125,553
  • 55
  • 289
  • 326
  • 23
    All non-volatile RAM that you'll ever encounter is more commonly known as "flash". – chrylis -cautiouslyoptimistic- Feb 05 '21 at 05:16
  • 36
    I can't improve the answers below, but just an anecdote that's relevant. Years ago I used to work at a shop that bought computers, fixed them up, and resold them. We quite often bought used computers from the NSA. They nearly always came with the RAM still installed, but never once a hard drive. I figure that if they were at all concerned about data in the RAM, then we'd have never seen a single stick. – BrianFreud Feb 05 '21 at 14:39
  • I've got dozens of old hard drives on a shelf. Customer hands me old machine. I remove hard drive and put it on the shelf. I put the machine (including RAM) out on the curb. It magically disappears *before* trash day. – manassehkatz-Moving 2 Codidact Feb 05 '21 at 15:41
  • 2
    @BrianFreud From the NSA, you say? Did fixing them up include removing the flash chip holding the BIOS and installing one programmed with the M/B manufacturer's firmware? ;) – Andrew Morton Feb 06 '21 at 17:30
  • 1
    @chrylis-cautiouslyoptimistic- don't be so sure about that "ever". Currently yes, but it's very plausible that in a decade or two other technologies will mature and find their way into mainstream consumer PCs. (Like Optane DC PM (Persistent Memory) currently is used in servers, with [3D XPoint](https://en.wikipedia.org/wiki/3D_XPoint) phase-change memory, not flash, as the underlying technology.) Or good old battery-backed DRAM like in some RAID controllers. Anyway, if it ends up hooked up via the memory bus like Optane to take advantage of the latency and B/W, it can be called NV RAM. – Peter Cordes Feb 07 '21 at 00:09
  • 1
    @Andrew Morton To my memory, they were stock BIOS chips. We had a big pile of 286s collecting dust, and turned over a decent number of Pentiums, P2s, and P3s from them. The only really odd bit with them was the missing hard drive; instead they had a 5.25" adaptor bay with a slot to allow a 3.5" drive to be used as a removeable drive. (And of course, they had the adaptors, but not the drives). – BrianFreud Feb 07 '21 at 04:13
  • @BrianFreud - The hard drives would have been destroyed by a mechanical shredder. – Stephen C Feb 07 '21 at 08:22
  • 1
    Mh, the purchaser would have like 60 milliseconds to power the stick after you unplugged it (assuming a "hot" unplug). – Yves Daoust Feb 17 '21 at 09:28
  • Your edit cut out quite a lot of context. If nothing else, the RAM specifics in the last paragraph are important. Why do you want to remove so much? – schroeder Apr 15 '21 at 11:59

3 Answers3

159

Yes, they're safe. Consumer memory DIMMs use volatile SDRAM memory. Volatile means that it does not hold its state after you turn it off.

SDRAM memory chips are constructed from an array of memory cells, with one cell per bit of data stored. Modern memory ICs have billions of cells each. Each memory cell is constructed from a transistor and a capacitor. A transistor is like an electronic switch, and a capacitor is like a tiny battery. The value stored in the cell is a single bit - a value of 0 or 1, represented by a low or high voltage.

Here's a circuit diagram of a simple memory cell:

Memory cell circuit

You can simulate this circuit in your browser here, and I'll talk you through how it works. You can control the simulation with the "Run/STOP" and "Reset" buttons on the top right. If the run/stop button is red, you've stopped the simulation. If it's grey, it's running.

I've labelled the transistor and the capacitor, so you can see where they are. The parts marked 10k, 100k, and 1M are resistors - don't worry about those for now.

At the top left of the circuit we've got our input data. This is a switch that selects either 5V or 0V (ground), to represent a value of 1 or 0. We use this switch to select which value we want to write into the cell. On the right, we've got our output data. This will show as 1 or 0 when we read from the cell.

Underneath that, we have a write/read switch. This selects which operation we want to perform. When switched to the left it writes a value to the cell, using whichever value was set by the input data switch. When switched to the right it reads a value from the cell and displays it on the output data.

The enable switch allows us to decide whether or not we want to talk to this specific cell at any point in time. When there are many of these cells all connected to the same input and output signals, this allows us to select just one cell to be read from or written to.

There's another switch marked "leakage". I'll get to that later - leave that switch open for now.

First, let's write a 1 to the cell. Set the input data switch to 1 and the write/read switch to write. Then close the enable switch. You'll see the bottom of the circuit light up green, and little yellow dots will move for a moment to indicate that a current is flowing as the capacitor charges up.

Writing a 1 to the cell

The top part of the capacitor goes green, indicating that the capacitor is now charged up and the cell's value is set to 1.

Next, flip the write/read switch to the right, in order to read from the cell. The output data now shows 1.

Reading the cell

Repeat this again, but for an input value of 0.

Also have a play with the enable switch - you'll see that when it is open, the output data will always be 0 regardless of what you do with the input value and the write/read switch. Additionally, whatever value is stored in the capacitor stays there until you turn the enable switch back on.

What we've looked at so far is an ideal memory cell. It can store a 0 or 1 almost perpetually. However, in reality there is always some leakage in the capacitor that causes it to slowly lose its charge. You can simulate this with the leakage switch I included in the circuit.

Close the leakage switch, then set the input data to 1, the write/read switch to write, and close the enable switch. This will cause a 1 to be written to the cell. Now change the write/read switch to read, and look at the output data. It will show 1, just as before. Now wait a few seconds. The output data will flip back to 0.

Leakage in the cell

If you watch the path through the leakage switch and the 10k resistor, you'll see the current dots flowing slowly along as the capacitor charge leaks out. Eventually, the capacitor voltage drops below the threshold voltage, causing it to be read as a 0 instead of a 1.

Try this a few times to get a feel for what's happening. Once you're happy with that, it's time for another experiment.

With the leakage switch closed, repeat the write process again and store a 1 in the cell. This time, instead of immediately performing a read operation, open the enable switch beforehand. Wait a few seconds, then close the enable switch. Here's the full steps in case it's not clear:

  1. Close the leakage switch.
  2. Set the input data to 1.
  3. Set the write/read switch to write.
  4. Close the enable switch. Observe the capacitor charging up.
  5. Open the enable switch.
  6. Set the write/read switch to read.
  7. Wait 5 seconds.
  8. Close the enable switch.

Notice that the output data is zero! What happened is that the charge in the capacitor leaked away while you were waiting, causing it to drop from 1 to 0.

This happens in real DRAM chips, too. The controller on the memory chip has to constantly refresh the data in the cells by reading them and writing their values back, to keep up with leakage. When you turn off your computer the data in the DRAM memory chips quickly degrades and leaks back to all zeroes. This process normally takes only a few seconds.

(interesting little aside here: the time it takes to set up the switches and get the data in and out of a specific cell is what defines the latency of memory, often listed as four numbers or just something like "CL16" - the memory timings wiki has some further info on this)

The leakage process can be artificially slowed down by cooling the chips down to very low temperatures, in what's known as a cold boot attack. This causes the cells to retain their values for much longer. It only works if you freeze the RAM right at the same time as powering the system off - if you wait even a few seconds before freezing it all the data will have begun to degrade. As such it's not a problem for you.


There are some additional interesting things that can be talked about here, such as SPD flash, NVDIMM, and Intel Optane, but I'm due to play a D&D game in ten minutes so I don't have time to expand this answer right now. I'll come back later and edit them in. Don't worry, though - they don't affect the safety of your sale!


Ok, zombie beholder's dead. Let's talk non-volatile RAM.

There's a special type of memory technology called NVDIMM. An NVDIMM is like a regular DDR SDRAM module, except it has a battery backup on it and a non-volatile flash memory chip. This allows the system to be powered off without losing memory state. The battery backup on the DIMM allows it to continue to refresh the memory cells. It then copies the contents of the memory cells into the non-volatile flash chip. It can then safely power off, because the contents of memory are saved and the volatile memory chips do not need to be refreshed. The operating system has to be built with support for this feature. This is a specialist memory technology usually reserved for server applications where you need to be able to recover the contents of memory during a power outage, or bring the system up to the same state quickly after maintenance (e.g. replacing a PSU or UPS).

Another type of non-volatile DIMM is Intel Optane. This is actually not RAM at all - it's better to think of it like a very low latency NVMe SSD that just happens to plug into a DIMM slot.

Finally, let's talk about SPD flash. When you plug a DIMM into your system, your motherboard needs to be able to identify it and learn about its specs and features - its name, size, type, speed, latencies, voltage requirements, inbuilt overclocking profiles, and all sorts of other details. This information is provided by a standard interface called Serial Presence Detect (SPD). In practice, the information is stored in a table (the exact format and contents of which is defined by JEDEC) in a small non-volatile flash EEPROM chip on the DIMM, which the motherboard can talk to via SMBus. The operating system can also talk to this chip to find out information about the memory - you can view it with a tool like CPU-Z.

Normally this SPD data is written to the EEPROM at the factory and never changed. However, it is entirely possible to write to the flash chip from the operating system. Some chips do technically have the ability to lock the first half of the data (usually the first 256 bytes) but often this is not done, and the second half of the data is always writable. The size of the SPD table for DDR4 is 383 bytes. However, nobody makes 383 byte EEPROM chips - that'd be weird. Instead, you'll usually find that the chip is 512 bytes in size. This means that there are 129 bytes left in the EEPROM that aren't used for anything. If you wanted to, you could store 129 bytes of non-volatile data in every stick of RAM in your computer, by writing to the SPD flash. I wouldn't recommend trying this yourself, since there's every chance you could brick your RAM if you do it wrong, but I did this as an on-stage demo at a security conference a while back.

The SPD interface isn't usually exposed to anything but the kernel, but there are many signed Windows drivers out there that either provide write access to SPD by design, as well as drivers that provide write access to SPD by accident, which you can abuse to write a small amount of data to the SPD flash chips.

There is, therefore, a scenario in which an attacker could use one of these drivers to write to the SPD flash. This data would remain on the DIMMs even after the system rebooted, or even if you re-installed your OS. The data doesn't do anything by itself - you need malicious code to already be running on the system to actually read and write it - but it is a nice little hidden storage location for a few bytes of data. There's almost no reason to abuse this storage location in practice - it's complicated, error-prone, requires admin and a loaded driver, for almost no benefit in return - but it is a fun little trick to store non-volatile data on regular volatile memory DIMMs!

One scenario where this is actually really important is bare-metal cloud hosting environments. In these environments, customers rent physical systems that they have complete administrative access to, rather than virtualised instances. Providers of these services need to ensure that there is no data remanence between one customer and the next. The SPD writing trick is one way for an attacker to achieve data remanence. There are plenty of other EEPROMs on the motherboard, hard disks, network card, RAID card, etc. that can also potentially be written to by an attacker with that kind of access. Bare-metal cloud providers have to implement special checks to ensure that these non-volatile flash memory devices were not modified. It's quite a challenge and hardware attestation is far from a solved problem. Again, this doesn't affect your consumer memory DIMMs, but it's a situation where a device that you expect to be volatile or stateless may actually have some non-volatile state.

Polynomial
  • 133,763
  • 43
  • 302
  • 380
  • 52
    While this response is great and very detailed, I feel like we might have overwhelmed the OP. – jeanluc Feb 05 '21 at 01:03
  • 72
    Most of the point of stackexchange is for people who wander in much later, so hopefully someone finds this detailed explanation useful! I know if I were the op I'd probably have stopped reading after the first bit if I didn't want an electronics lesson. Well explained and thorough! – Justin W Feb 05 '21 at 01:16
  • Interesting points about the non-volatile items that can fit into a "DRAM slot". I'm not sure if this qualifies as a separate question, but could one individual swap out one for the other in a second individual's PC and the second not notice based on the PC's operation? Should that be asked separately? – uhoh Feb 05 '21 at 05:56
  • 4
    @uhoh In theory one can plug a battery backup (or just parasitic power) RAM stick into a PC without noticeable performance degradation (it might even be the same stick), but if an attacker has such access they usually have a far more practical attack vector – Martheen Feb 05 '21 at 08:39
  • [Wikipedia seems to disagree](https://en.wikipedia.org/wiki/NVDIMM) on your definition of NVDIMM. Pedantically, any memory that plugs into DIMM and is non-volatile is an NVDIMM and in fact I first came into contact with the term when reading about Optane DC. – jaskij Feb 05 '21 at 14:23
  • Well I came here for exactly this, when people really dig deep is when it gets interesting. – Anunay Feb 07 '21 at 00:00
  • great answer ! I guess the 10 uF capacity value is for illustration/simulation purposes only (typical capacitances seem to be of the order of tens to hundreds of femto Farad). If each bit on a 16 GByte DRAM bar had 10 uF, we could store 0.324 kWh of energy on such a bar at 1.35 Volts. Or equivalently build a 75 kWh (electric car like capacity) storage from 231 DIMMs. – Andre Holzner Feb 07 '21 at 08:45
  • 1
    @AndreHolzner Yes, very much for simulation only. – Polynomial Feb 07 '21 at 16:13
70

Yes, they’re safe to sell. No consumer PCs use non-volatile RAM for their main memory.

Polynomial
  • 133,763
  • 43
  • 302
  • 380
Mike Scott
  • 10,134
  • 1
  • 28
  • 35
  • Advocatus diaboli: using an ssd (nvme) for swapping, makes it effectively non-volatile main memory. :-) – peterh Feb 04 '21 at 12:21
  • 3
    @peterh-ReinstateMonica Would this be a DDR3 SSD DIMM that you’re talking about? – Mike Scott Feb 04 '21 at 12:57
  • 1
    No, it would be a flash, in arbitrary format, but reachable over a standard ssd/nvme interface. Anyways, direct access to stale swap space is a possible security attack point. – peterh Feb 04 '21 at 13:06
  • 41
    They are safe to sell, unless someone convinces you to freeze the RAM with liquid nitrogen while still in your powered on computer, and then sell them while still chilled. – multithr3at3d Feb 04 '21 at 15:37
  • 8
    @peterh-ReinstateMonica Yes, but we’re talking about DDR3 DIMMs here. – Mike Scott Feb 04 '21 at 17:47
  • So a commercial non-volatile RAM exists? – MCCCS Feb 04 '21 at 19:58
  • @MikeScott You mean volatile, not non-volatile. EDIT: No, I should learn to read sentence structures properly! (sorry - reverted my edit to your answer) – Polynomial Feb 04 '21 at 22:16
  • @MCCCS Yes. I'm editing info into my answer now. – Polynomial Feb 04 '21 at 22:17
  • 4
    @peterh-ReinstateMonica Magnetic core memory isn't quite extinct yet. The two Voyager spacecraft used it and are still functional. Core was/is certainly non-volatile. – alephzero Feb 04 '21 at 23:34
  • 27
    if you're paranoid running memtest-86 for a few rounds will blast any remnants of personal data, and has the side effect of confriming that they are still in perfect working order. – Jasen Feb 05 '21 at 05:01
  • 2
    @MCCCS flash is a kind of non-volatile RAM. And if you have more money then [XPoint](https://en.wikipedia.org/wiki/3D_XPoint) A.K.A Optane memory is a thing that you can plug into no normal RAM slots – phuclv Feb 05 '21 at 11:20
  • 1
    Where can I get some of that DDR3 magnetic core memory? ;-) – Toby Speight Feb 05 '21 at 13:33
  • 1
    @TobySpeight actually... would spintronics count as "magnetic core"? I'm sure it would. The nice thing about spin is that the magnetic dipole moment can't decay because it has nowhere to decay to. It can still change direction, but stopping it from having a reason to is a Problem That Will Be Solved Soon. And When We Do Solve It, we can use it to store quantum information ~~indefinitely~~.... or at least for long enough to run the algorithm and not get more noise than useful data. – John Dvorak Feb 06 '21 at 10:28
6

Yes, they're safe to sell, but as you describe yourself as "not very tech-savvy" I would add that you also need to be mindful of the fact that it's not just the security of your data that you should be concerned about.

RAM is also very sensitive to damage/destruction due to electrostatic damage... that's a little zap of static electricity from something such as your fingers to one of the pins of the chip, being very low current but thousands of volts is enough to burn out the microscopic components or circuitry etched into the silicon inside it.

This may not cause immediate obvious failure, but it's often enough to degrade the performance or cause it to die over time.

To protect against this, and lessen the possibility of the person who buys it off you coming back to you with it and complaining that you sold them some useless pieces of e-Waste, you should read about (or watch e.g. YouTube videos about) anti-static precautions for electronics and follow those.

If it's very dry or cold, static is more of a danger. If you wear woollen or synthetic clothes or are walking on carpet or a plastic floor covering it's worse. You should "earth" your body by touching the frame of the PC before and whist putting anything near, let alone touching the DIMMs.

Bear in mind that the voltage levels that build up on your body can easily jump a couple of inches when they're high enough. The idea is to create a circuit between yourself and the frame of the PC, so you and whatever comes near the chips are at the same voltage as it. You can get anti-static wrist-bands which are usually an elastic strap with a metal skin-contactor and a wire going to a clip which you clip onto the PC frame.

Once you've removed them you should put them straight into an anti-static bag (not a normal plastic bag, which can have static itself) if you don't have an anti-static bag, wrapping them in aluminium foil is a reasonable substitute - it needs to be something that conducts electricity.

When it comes to static: Conductors good, insulators bad.

I hope this helps!

JohnGH
  • 161
  • 1