compat-wireless: add -t argument for time statistics
[~emulex/for-vlad/old/compat.git] / bin / ckmake
1 #!/bin/bash
2 #
3 # Copyright (C) 2012, Luis R. Rodriguez <mcgrof@frijolero.org>
4 # Copyright (C) 2012, Hauke Mehrtens <hauke@hauke-m.de>
5 #
6 # This program is free software; you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License version 2 as
8 # published by the Free Software Foundation.
9 #
10 # You can use this to compile a module accross all installed kernels
11 # found. This relies on distribution specific kernels, but can handle
12 # your own custom list of target kernels. Log is setnt to LOG variable.
13
14 # Pretty colors
15 GREEN="\033[01;32m"
16 YELLOW="\033[01;33m"
17 NORMAL="\033[00m"
18 BLUE="\033[34m"
19 RED="\033[31m"
20 PURPLE="\033[35m"
21 CYAN="\033[36m"
22 UNDERLINE="\033[02m"
23
24 #export KCFLAGS="-Wno-unused-but-set-variable"
25 KERNEL_DIR="/lib/modules"
26 KLIBS=""
27 LOG="ckmake.log"
28 TIME="0"
29
30 LSB_RED_ID=$(/usr/bin/lsb_release -i -s)
31 case $LSB_RED_ID in
32 "Ubuntu")
33         for i in $(find /lib/modules/ -type d -name \*generic\* | sort -n -r | grep -v -E '\-[[:alnum:]]{1,2}\-'); do
34                 KLIBS="$KLIBS $i"
35         done
36         ;;
37 *)
38         echo -e "Unsupported distribution"
39         exit
40         ;;
41 esac
42
43 function tee_color_split()
44 {
45         while read; do
46                 echo -e $REPLY | ./scripts/skip-colors >> $LOG
47                 echo -e $REPLY
48         done
49 }
50
51 function log_try_kernel()
52 {
53         echo -en "Trying kernel ${BLUE}"
54         printf "%40s\t" "${1}"
55         echo -en "${NORMAL}"
56 }
57
58 function usage()
59 {
60         echo -e "Usage: $0 [-t]"
61         echo -e "-t   will run: 'time ckmake; time ckmake' account for"
62         echo -e "     benchmark how long it takes to compile without ccache"
63         echo -e "     and a run after cache kicks in"
64 }
65
66 if [[ $# -gt 1 ]]; then
67         usage
68         exit 1
69 fi
70
71 if [[ $# -eq 1 ]]; then
72         if [[ $1 != "-t" ]]; then
73                 usage
74                 exit 1
75         fi
76         TIME="1"
77 fi
78
79 function run_ckmake()
80 {
81         for i in $KLIBS; do
82                 KERNEL=$(basename $i)
83                 DIR=${i}/build/
84                 echo -e "--------------------------------------------" >> $LOG
85
86                 if [[ ! -d $DIR ]]; then
87                         continue
88                 fi
89
90                 # We cannot use tee_color_split() as bash read only spits
91                 # out output when a newline comes in. We can modif IFS but
92                 # I am still not sure how to do this properly.
93                 log_try_kernel $KERNEL | ./scripts/skip-colors >> $LOG
94                 log_try_kernel $KERNEL
95
96                 ionice -c 3 nice -n 20 make -s KLIB=$DIR KLIB_BUILD=$DIR -j6 -Wunused-but-set-variable &>> $LOG
97                 if [[ $? -eq 0 ]]; then
98                         echo -e "${GREEN}[OK]${NORMAL}" | tee_color_split
99                 else
100                         echo -e "${RED}[FAILED]${NORMAL}" | tee_color_split
101                 fi
102
103                 nice make clean KLIB=$DIR KLIB_BUILD=$DIR 2>&1 >> $LOG
104         done
105 }
106
107 nice make clean 2>&1 > $LOG
108
109 if [[ $TIME != "1" ]]; then
110         run_ckmake
111         exit 0
112 fi
113
114 time $0
115 time $0 | egrep "real|user|sys"