0x7F9DC00 means 127 MiBs and few KiBs, but I have 128 MiBs...Octacone wrote:TheLittleWho wrote: Then you must be doing something wrong. I managed to count 127 MB (0x7F9DC00 bytes) of free RAM from the image you provided.
GRUB Returning Less Memory
-
- Member
- Posts: 51
- Joined: Sun Mar 01, 2015 7:58 am
Re: GRUB Returning Less Memory
Re: GRUB Returning Less Memory
TheLittleWho wrote:0x7F9DC00 means 127 MiBs and few KiBs, but I have 128 MiBs...Octacone wrote:TheLittleWho wrote: Then you must be doing something wrong. I managed to count 127 MB (0x7F9DC00 bytes) of free RAM from the image you provided.
Read that again, slowly. I also mentioned something about ACPI reclaimable space. That should give you those extra few kilobytes, but first make sure to reclaim that space and use the data from it accordingly.Octacone wrote:Basically what I've done is summed up all the lengths (note they are 64 bit wide) that are marked as free. Only count those free ones or else you'll register more RAM than physically available.
Also when printing out those values, printing them in bytes is the most accurate way, everything else is kind of not precise (4 GB instead of 4.2). See the decimal point? Floating point printing is handy for that type of stuff.
OS: Basic OS
About: 32 Bit Monolithic Kernel Written in C++ and Assembly, Custom FAT 32 Bootloader
About: 32 Bit Monolithic Kernel Written in C++ and Assembly, Custom FAT 32 Bootloader
Re: GRUB Returning Less Memory
In general there's two different numbers, the amount of RAM installed and the amount available for your OS. If you want to know how much RAM is installed then you might want to take a look at SMBios. If you want to know the address and availability of memory then you use the memory map provided to you.TheLittleWho wrote:0x7F9DC00 means 127 MiBs and few KiBs, but I have 128 MiBs...Octacone wrote:TheLittleWho wrote: Then you must be doing something wrong. I managed to count 127 MB (0x7F9DC00 bytes) of free RAM from the image you provided.
For instance if you have an integrated GPU then it might take a piece of the RAM and that piece won't be available for your OS as such. The firmware (BIOS/UEFI) might/will also take some memory for itself, some of the ACPI memory is reclaimable after you're done with it, some might not be. So simply put, the memory you should ever use for allocation is the memory in the mmap. The SMBios stuff for installed memory is likely more useful for "accounting" purposes, for instance large organizations like to be able to automatically detect what hardware they have.
Re: GRUB Returning Less Memory
Well, I wouldn't say you missed the last line, instead I'd drop the use of uint32_t in the math (though not necessarily in code). You need the 16 mega _bits_, and since each byte is 8 bits that means 16/8 = 2 MiB. By using uint32_t you end up with a number that is 1/4 of what it should be, then you multiply it with 4 to get the correct result, just redundant to essentially divide and multiply by the same number in a sense..Octacone wrote: 64 GB = 64 * 1024 MB = 64 * 1024 * 1024 KB = 64 * 1024 * 1024 * 1024 Bytes = 68719476736 Bytes conatined in 64 GB of RAM.
We don't want to store 68719476736 different addresses, we want to store blocks of memory (4 KB chunks).
4 KB = 4096 Bytes --> 68719476736 / 4096 = 16777216 Bytes/Addresses to store.
Now since we are using a bitmap there are 32 bits inside a single uint32_t, so we need to divide 16777216 by 32 = 524288 addresses to store in total.
524288 addresses = 524288 different variables = each one of them being 4 bytes so 524288 * 4 = 2097152 bytes in total to store them = exactly 2 MB.
Wow! I was missing the last line... Good catch.
But anyway, as said, my main point was that for a full 64-bit PAS you'd waste a lot of memory, unless you record the base address, so you don't need a full bitmap for the entire 64-bit PAS, given that no hardware even supports the full 64-bit PAS, AFAIK.
-
- Member
- Posts: 51
- Joined: Sun Mar 01, 2015 7:58 am
Re: GRUB Returning Less Memory
Thank you! I will read about SMBios, but that structure is on bios legacy and uefi or?
Re: GRUB Returning Less Memory
http://wiki.osdev.org/System_Management_BIOSTheLittleWho wrote:Thank you! I will read about SMBios, but that structure is on bios legacy and uefi or?
I haven't actually used SMBIOS myself (except on Linux/BSD type systems, but that's not my code), but I think it should be available on UEFI as well.