From: Mariusz Kozlowski <m.kozlowski@xxxxxxxxxx> Date: Wed, 26 Mar 2008 13:02:45 +0100 > cat /proc/<pid>/pagemap > > and > > cat /proc/<pid>/task/<pid>/pagemap > > eats up to 100% of CPU while looping forever somewhere. On the other > hand on my old x86 the same commands take well below 1s so I > guess that is the expected behaviour. The patch below will speed this up for 32-bit processes but for 64-bit ones it's still going to take a long time. Cat'ing this file writes a 64-bit value for every possible page in the task's address space, which for 64-bit is an enormous number of entries. This is not how this file is supposed to be used. Programs are supposed to inspect /proc/${PID}/maps, and use those ranges to lseek() around the pagemap file and fish out the values they need. This expensive operation is quite harmless, the process can still be killed, it is not unstoppable. commit c101b088ba0ed16d7109b2f3c2d16798d162a535 Author: David S. Miller <davem@xxxxxxxxxxxxx> Date: Wed Mar 26 17:32:33 2008 -0700 [SPARC64]: Define TASK_SIZE_OF() This make "cat /proc/${PID}/pagemap" more efficient for 32-bit tasks. Based upon a report by Mariusz Kozlowski. Signed-off-by: David S. Miller <davem@xxxxxxxxxxxxx> diff --git a/include/asm-sparc64/processor.h b/include/asm-sparc64/processor.h index 8da484c..885b6a1 100644 --- a/include/asm-sparc64/processor.h +++ b/include/asm-sparc64/processor.h @@ -37,6 +37,9 @@ #endif #define TASK_SIZE ((unsigned long)-VPTE_SIZE) +#define TASK_SIZE_OF(tsk) \ + (test_tsk_thread_flag(tsk,TIF_32BIT) ? \ + (1UL << 32UL) : TASK_SIZE) #ifdef __KERNEL__ #define STACK_TOP32 ((1UL << 32UL) - PAGE_SIZE) -- To unsubscribe from this list: send the line "unsubscribe sparclinux" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html