Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Is it possible to perform some computations within the RAM?

Theoretically, is there any way to perform any computations within the RAM, using memory related instructions such as move, clflush or whatever, such as an xor between two adjacent rows for example?

With my limited knowledge about RAM and assembly, I can't think of any such possibilities.

like image 260
agemO Avatar asked Oct 22 '25 11:10

agemO


1 Answers

No, any computation is done in the CPU (or GPU, or other system devices that can load/store to RAM). Even the Turing-complete mov stuff that @PaulR linked in a comment is just using the CPU's address-generation hardware with data in registers to do calculations.

The memory still just sees 64B burst-loads and 64B burst-stores when the CPU has cache misses.

See also What Every Programmer Should Know About Memory for some background on how the DDR protocol works (send address, then transfer a burst of data to/from the RAM)


Related: is num++ atomic in C, or with x86 inc [mem]?

lock inc [mem] is actually implemented inside the CPU with a load/modify/store that the CPU makes look atomic to all possible other observers in the system (e.g. other CPU cores, and PCIe devices). But not including stuff like hooking up a logic analyzer to the memory bus, which doesn't respect the cache-coherency protocol that a CPU core uses to hold exclusive rights to a cache line while it's doing the atomic read-modify-write.

Some people thought that the add is done "inside" the memory chips, but they are mistaken. There is no adder, or even boolean AND/OR/XOR hardware in a DRAM chip (or in the interface chips that connect it to a DDR4 bus); all it can do is load or store from a given address. Any chip that can do more than that is not just DRAM.

Well obviously there's logic in the memory interface chips, but it isn't hooked up to operate on the data.

If it did have that, it would be a type of Computational RAM. (Thanks linking that in comments, BTW. Interesting computer-architecture idea. AFAIK, no mainstream CPU or GPUs use C-RAM, though.)

You can't even ask DDR4 DRAM to zero a page for you. The CPU has to do that through the memory controllers.

like image 95
Peter Cordes Avatar answered Oct 24 '25 13:10

Peter Cordes



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!