Search code examples
cpu-architectureram

What is the typical DRAM row buffer size? How to find it?


How can I find DRAM row buffer size programmatically or by using already existing tools in say a *nix system ?


Solution

  • As an example, with a Kingston DDR4, I executed the following commands (you might need to install some packages) :

      sudo modprobe eeprom
      decode-dimms
    

    These commands, among many information, give me the characteristics of my DDR stick:

    ---=== Memory Characteristics ===---
    Maximum module speed                             2132 MHz (PC4-17000)
    Size                                             16384 MB
    Banks x Rows x Columns x Bits                    16 x 16 x 10 x 64
    SDRAM Device Width                               8 bits
    Ranks                                            2
    Rank Mix                                         Symmetrical
    AA-RCD-RP-RAS (cycles)                           14-14-14-35
    Supported CAS Latencies                          16T, 15T, 14T, 13T, 12T, 11T, 9T
    

    Rows and columns are actually number of address bits (you can check the decode-dimms source at https://fossies.org/linux/i2c-tools/eeprom/decode-dimms, and understand what the code is doing when you look at the DDR4 SPD information: https://en.wikipedia.org/wiki/Serial_presence_detect#DDR4_SDRAM)

    Thus, if we have 10 column bits, we have 1024 columns (2^10), where each column is composed of the module width (64 as per the data above, represented as "bits"). Since we can also see that the SDRAM device width is 8x, we can deduce that the DIMM locksteps 8 SDRAM chips (those black boxes you see in your DRAM stick) to get that total width of 64 bits.

    The row buffer size in my DDR4 is, therefore, 64 bits * 1024 columns = 65536 bits wide (8192 Bytes). Row buffer sizes in DDR3 and DDR4 are mostly this length, but new architectures such as HMC and HBM have different sizes.

    So, in one short commandline, to return in bits (just divide by 8 to get bytes): decode-dimms | grep "Columns x Bits" | awk -F 'x' '{print (2^$(NF-1))*$NF}

    PS: mind you, this handles a single DIMM. if you have multiple DIMMS decode-dimms might return information for multiple modules.