From 014e0ae7136ccd47412916acdbcbfaa2ceeac603 Mon Sep 17 00:00:00 2001 From: Bill Hoffa Date: Wed, 21 Feb 2018 08:22:06 -0600 Subject: Add Kernel Debug Trace for Out of Memory condition - Display size of page requested if requested memory doesn't become available Change-Id: I5b101ce6650cdc155be276c5d00f95bc35a0ff90 Reviewed-on: http://ralgit01.raleigh.ibm.com/gerrit1/54491 Tested-by: Jenkins Server Tested-by: Jenkins OP Build CI Tested-by: Jenkins OP HW Tested-by: FSP CI Jenkins Reviewed-by: Prachi Gupta Reviewed-by: Christian R. Geddes Reviewed-by: Daniel M. Crowell --- src/kernel/pagemgr.C | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/kernel/pagemgr.C b/src/kernel/pagemgr.C index bdc8244f2..978c6b9d2 100644 --- a/src/kernel/pagemgr.C +++ b/src/kernel/pagemgr.C @@ -5,7 +5,7 @@ /* */ /* OpenPOWER HostBoot Project */ /* */ -/* Contributors Listed Below - COPYRIGHT 2010,2017 */ +/* Contributors Listed Below - COPYRIGHT 2010,2018 */ /* [+] International Business Machines Corp. */ /* */ /* */ @@ -155,6 +155,7 @@ void* PageManager::allocatePage(size_t n, bool userspace) // In non-kernel mode, make a system-call to allocate in kernel-mode. if (!KernelMisc::in_kernel_mode()) { + size_t attempts = 0; while (NULL == page) { page = _syscall1(Systemcalls::MM_ALLOC_PAGES, @@ -164,6 +165,12 @@ void* PageManager::allocatePage(size_t n, bool userspace) // will eventually free up (ex. VMM flushes). if (NULL == page) { + attempts++; + if( attempts == 10000 ) //arbitrarily huge number + { + printk("Cannot allocate %ld pages\n", n); + MAGIC_INSTRUCTION(MAGIC_BREAK_ON_ERROR); + } task_yield(); } } -- cgit v1.2.3