Just switched 4GBs to 16GBs of RAM. However, when I look at how much memory I have, it says 15.3. I'm just wondering why did my memory drop down when I just installed 16 GBs of RAM.
Best Answer
Short Answer
It's probably just the kernel using memory. Instead of reporting kernel memory usage, Ubuntu instead subtracts form the total available. This is simply to let you know that the kernel memory cannot be freed in most cases. That memory is being used for things that are absolutely necessary, and so it will never be available.
Diagnostic Commands
I don't expect you to run all of these, but I've included them here for reference and completeness. Most relevant are commands 3 and 4. Also please note that all sizes are going to be in base 2 (e.g. GiB) and not in base 10 (e.g. GB) despite what the unit abbreviations might be.
You can check how big your RAM sticks are claiming to be with:
sudo dmidecode | grep Size | grep MB
You can check how much RAM is available for general use with (look for Mem and total):
free -h
You can estimate how much memory the kernel is using with:
cat /proc/meminfo | grep Slab
You can check for "stolen" graphics card memory with:
dmesg | grep stolen
You can look for specific hardware reserved memory by looking through:
dmesg | grep e820
You can test to make certain all of your memory works by running memtest
Explanation
The most likely explanation is simply that the extra space is being used by either your graphics card or the kernel itself. If you're not familiar, the kernel is the lowest-level part of the operating system, and any memory that it's using will not be available to you and so is not reported as free. The memory might be used for any number of reasons, such as the virtual memory tables, memory-mapped I/O, kernel processes, certain caches, shared graphics memory, etc.
Example: Looking at My Laptop
It is very likely that adding the output of command 3 to your 15.3GiB will result in almost exactly 16GiB. This was the case in my system:
Installed RAM: 6GiB
Reported in System Settings > Details: 5.6GiB
Output of cat /proc/meminfo | grep Slab: 316652 kB
Converted to GiB: 316652/2^20 = 0.3GiB
Output of dmesg | grep stolen: 32768K
Converted to GiB: 32768/2^20 = 0.03GiB
Adding them together: 5.6 + 0.3 + 0.03 = 5.93GiB
Since the Slab memory is not comprehensive, we can assume that the kernel is using the remaining 0.07GiB in places we can't see, and so this is a very satisfying result.
On a 32-bit operating system, there's a maximum of 4GB of RAM which can be used. The exception is a PAE kernel, which is basically a 32-bit kernel which supports more RAM.
I suggest you just install a 64-bit operating system, as this generally gives better performance. The other solution would be to install the PAE kernel, which can be done from the software centre.
You should install Preload which will preload the software you use the most in your RAM (it'll learn which software to preload on its own). That's very easy to setup:
sudo apt-get install preload
You probably don't need to touch it, but if you want you can edit the options in /etc/preload.conf
Best Answer
Short Answer
It's probably just the kernel using memory. Instead of reporting kernel memory usage, Ubuntu instead subtracts form the total available. This is simply to let you know that the kernel memory cannot be freed in most cases. That memory is being used for things that are absolutely necessary, and so it will never be available.
Diagnostic Commands
I don't expect you to run all of these, but I've included them here for reference and completeness. Most relevant are commands 3 and 4. Also please note that all sizes are going to be in base 2 (e.g.
GiB
) and not in base 10 (e.g.GB
) despite what the unit abbreviations might be.You can check how big your RAM sticks are claiming to be with:
You can check how much RAM is available for general use with (look for
Mem
andtotal
):You can estimate how much memory the kernel is using with:
You can check for "stolen" graphics card memory with:
You can look for specific hardware reserved memory by looking through:
You can test to make certain all of your memory works by running memtest
Explanation
The most likely explanation is simply that the extra space is being used by either your graphics card or the kernel itself. If you're not familiar, the kernel is the lowest-level part of the operating system, and any memory that it's using will not be available to you and so is not reported as free. The memory might be used for any number of reasons, such as the virtual memory tables, memory-mapped I/O, kernel processes, certain caches, shared graphics memory, etc.
Example: Looking at My Laptop
It is very likely that adding the output of command 3 to your
15.3GiB
will result in almost exactly16GiB
. This was the case in my system:6GiB
5.6GiB
cat /proc/meminfo | grep Slab
:316652 kB
GiB
:316652/2^20 = 0.3GiB
dmesg | grep stolen
:32768K
GiB
:32768/2^20 = 0.03GiB
5.6 + 0.3 + 0.03 = 5.93GiB
Since the
Slab
memory is not comprehensive, we can assume that the kernel is using the remaining0.07GiB
in places we can't see, and so this is a very satisfying result.See Also