diff options
| author | Mel Gorman <mel@csn.ul.ie> | 2009-06-16 18:33:04 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-06-16 22:47:44 -0400 |
| commit | 608e8e66a154cbc3d591a59dcebfd9cbc9e3431a (patch) | |
| tree | 460c5ff888d0305d875049fbb6117c34d1c5df7a /scripts | |
| parent | 168f5ac668f63dfb64439766e3ef9e866b83719d (diff) | |
mm: add a gfp-translate script to help understand page allocation failure reports
The page allocation failure messages include a line that looks like
page allocation failure. order:1, mode:0x4020
The mode is easy to translate but irritating for the lazy and a bit error
prone. This patch adds a very simple helper script gfp-translate for the
mode: portion of the page allocation failure messages. An example usage
looks like
mel@machina:~/linux-2.6 $ scripts/gfp-translate 0x4020
Source: /home/mel/linux-2.6
Parsing: 0x4020
#define __GFP_HIGH (0x20) /* Should access emergency pools? */
#define __GFP_COMP (0x4000) /* Add compound page metadata */
The script is not a work of art but it has come in handy for me a few
times so I thought I would share.
[akpm@linux-foundation.org: clarify an error message]
Signed-off-by: Mel Gorman <mel@csn.ul.ie>
Acked-by: Rik van Riel <riel@redhat.com>
Acked-by: Pekka Enberg <penberg@cs.helsinki.fi>
Cc: Christoph Hellwig <hch@infradead.org>
Cc: Minchan Kim <minchan.kim@gmail.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'scripts')
| -rw-r--r-- | scripts/gfp-translate | 81 |
1 files changed, 81 insertions, 0 deletions
diff --git a/scripts/gfp-translate b/scripts/gfp-translate new file mode 100644 index 000000000000..073cb6d152a0 --- /dev/null +++ b/scripts/gfp-translate | |||
| @@ -0,0 +1,81 @@ | |||
| 1 | #!/bin/bash | ||
| 2 | # Translate the bits making up a GFP mask | ||
| 3 | # (c) 2009, Mel Gorman <mel@csn.ul.ie> | ||
| 4 | # Licensed under the terms of the GNU GPL License version 2 | ||
| 5 | SOURCE= | ||
| 6 | GFPMASK=none | ||
| 7 | |||
| 8 | # Helper function to report failures and exit | ||
| 9 | die() { | ||
| 10 | echo ERROR: $@ | ||
| 11 | if [ "$TMPFILE" != "" ]; then | ||
| 12 | rm -f $TMPFILE | ||
| 13 | fi | ||
| 14 | exit -1 | ||
| 15 | } | ||
| 16 | |||
| 17 | usage() { | ||
| 18 | echo "usage: gfp-translate [-h] [ --source DIRECTORY ] gfpmask" | ||
| 19 | exit 0 | ||
| 20 | } | ||
| 21 | |||
| 22 | # Parse command-line arguements | ||
| 23 | while [ $# -gt 0 ]; do | ||
| 24 | case $1 in | ||
| 25 | --source) | ||
| 26 | SOURCE=$2 | ||
| 27 | shift 2 | ||
| 28 | ;; | ||
| 29 | -h) | ||
| 30 | usage | ||
| 31 | ;; | ||
| 32 | --help) | ||
| 33 | usage | ||
| 34 | ;; | ||
| 35 | *) | ||
| 36 | GFPMASK=$1 | ||
| 37 | shift | ||
| 38 | ;; | ||
| 39 | esac | ||
| 40 | done | ||
| 41 | |||
| 42 | # Guess the kernel source directory if it's not set. Preference is in order of | ||
| 43 | # o current directory | ||
| 44 | # o /usr/src/linux | ||
| 45 | if [ "$SOURCE" = "" ]; then | ||
| 46 | if [ -r "/usr/src/linux/Makefile" ]; then | ||
| 47 | SOURCE=/usr/src/linux | ||
| 48 | fi | ||
| 49 | if [ -r "`pwd`/Makefile" ]; then | ||
| 50 | SOURCE=`pwd` | ||
| 51 | fi | ||
| 52 | fi | ||
| 53 | |||
| 54 | # Confirm that a source directory exists | ||
| 55 | if [ ! -r "$SOURCE/Makefile" ]; then | ||
| 56 | die "Could not locate kernel source directory or it is invalid" | ||
| 57 | fi | ||
| 58 | |||
| 59 | # Confirm that a GFP mask has been specified | ||
| 60 | if [ "$GFPMASK" = "none" ]; then | ||
| 61 | usage | ||
| 62 | fi | ||
| 63 | |||
| 64 | # Extract GFP flags from the kernel source | ||
| 65 | TMPFILE=`mktemp -t gfptranslate-XXXXXX` || exit 1 | ||
| 66 | grep "^#define __GFP" $SOURCE/include/linux/gfp.h | sed -e 's/(__force gfp_t)//' | sed -e 's/u)/)/' | grep -v GFP_BITS | sed -e 's/)\//) \//' > $TMPFILE | ||
| 67 | |||
| 68 | # Parse the flags | ||
| 69 | IFS=" | ||
| 70 | " | ||
| 71 | echo Source: $SOURCE | ||
| 72 | echo Parsing: $GFPMASK | ||
| 73 | for LINE in `cat $TMPFILE`; do | ||
| 74 | MASK=`echo $LINE | awk '{print $3}'` | ||
| 75 | if [ $(($GFPMASK&$MASK)) -ne 0 ]; then | ||
| 76 | echo $LINE | ||
| 77 | fi | ||
| 78 | done | ||
| 79 | |||
| 80 | rm -f $TMPFILE | ||
| 81 | exit 0 | ||
