On 09/26/2013 05:10 AM, Andrew Morton wrote: > On Thu, 26 Sep 2013 04:56:32 +0530 "Srivatsa S. Bhat" <srivatsa.bhat@xxxxxxxxxxxxxxxxxx> wrote: > >> Experimental Results: >> ==================== >> >> Test setup: >> ---------- >> >> x86 Sandybridge dual-socket quad core HT-enabled machine, with 128GB RAM. >> Memory Region size = 512MB. > > Yes, but how much power was saved ;) > I don't have those numbers yet, but I'll be able to get them going forward. Let me explain the challenge I am facing. A prototype powerpc platform that I work with has the capability to transition memory banks to content-preserving low-power states at a per-socket granularity. What that means is that we can get memory power savings *without* needing to go to full-system-idle, unlike Intel platforms such as Sandybridge. So, since we can exploit per-socket memory power-savings irrespective of whether the system is fully idle or not, using this patchset to shape the memory references appropriately is definitely going to be beneficial on that platform. But the challenge is that I don't have all the pieces in place for demarcating the actual boundaries of the power-manageable memory chunks of that platform and exposing it to the Linux kernel. As a result, I was not able to test and report the overall power-savings from this patchset. But I'll soon start working on getting the required pieces ready to expose the memory boundary info of the platform via device-tree and then using that to construct the Linux MM's view of memory regions (instead of hard-coding them as I did in this patchset). With that done, I should be able to test and report the overall power-savings numbers on this prototype powerpc platform. Until then, in this and previous versions of the patchset, I had used an Intel Sandybridge system just to evaluate the effectiveness of this patchset by looking at the statistics (such as /proc/zoneinfo, /proc/pagetypeinfo etc)., and of course this patchset has the code to export per-memory-region info in procfs to enable such analyses. Apart from this, I was able to evaluate the performance overhead of this patchset similarly, without actually needing to run on a system with true (hardware) memory region boundaries. Of course, this was a first-level algorithmic/functional testing and evaluation, and I was able to demonstrate a huge benefit over mainline in terms of consolidation of allocations. Going forward, I'll work on getting this running on a setup that can give me the overall power-savings numbers as well. BTW, it would be really great if somebody who has access to custom BIOSes (which export memory region/ACPI MPST info) on x86 platforms could try out this patchset and let me know how well this patchset performs on x86 in terms of memory power savings. I don't have a custom x86 BIOS to get that info, so I don't think I'll be able to try that out myself :-( > Also, the changelogs don't appear to discuss one obvious downside: the > latency incurred in bringing a bank out of one of the low-power states > and back into full operation. Please do discuss and quantify that to > the best of your knowledge. > > As Andi mentioned, the wakeup latency is not expected to be noticeable. And these power-savings logic is turned on in the hardware by default. So its not as if this patchset is going to _introduce_ that latency. This patchset only tries to make the Linux MM _cooperate_ with the (already existing) hardware power-savings logic and thereby get much better memory power-savings benefits out of it. Regards, Srivatsa S. Bhat -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>