build.sh 16.0 KB
Newer Older
Y
Yan Chunwei 已提交
1
#!/bin/bash
2
set -ex
Y
Yan Chunwei 已提交
3

4
TESTS_FILE="./lite_tests.txt"
Y
Yan Chunwei 已提交
5
LIBS_FILE="./lite_libs.txt"
Y
Yan Chunwei 已提交
6 7

readonly common_flags="-DWITH_LITE=ON -DLITE_WITH_LIGHT_WEIGHT_FRAMEWORK=OFF -DWITH_PYTHON=OFF -DWITH_TESTING=ON -DLITE_WITH_ARM=OFF"
8

C
Chunwei 已提交
9 10
NUM_CORES_FOR_COMPILE=8

11 12
# for code gen, a source file is generated after a test, but is dependended by some targets in cmake.
# here we fake an empty file to make cmake works.
13
function prepare_workspace {
14
    # in build directory
15 16 17 18 19 20 21 22 23
    # 1. Prepare gen_code file
    GEN_CODE_PATH_PREFIX=paddle/fluid/lite/gen_code
    mkdir -p ./${GEN_CODE_PATH_PREFIX}
    touch ./${GEN_CODE_PATH_PREFIX}/__generated_code__.cc

    # 2.Prepare debug tool
    DEBUG_TOOL_PATH_PREFIX=paddle/fluid/lite/tools/debug
    mkdir -p ./${DEBUG_TOOL_PATH_PREFIX}
    cp ../${DEBUG_TOOL_PATH_PREFIX}/analysis_tool.py ./${DEBUG_TOOL_PATH_PREFIX}/
24
}
S
up  
superjomn 已提交
25 26 27 28 29

function check_need_ci {
    git log -1 --oneline | grep "test=develop" || exit -1
}

Y
Yan Chunwei 已提交
30
function cmake_x86 {
31
    prepare_workspace
32
    cmake ..  -DWITH_GPU=OFF -DWITH_MKLDNN=OFF -DLITE_WITH_X86=ON ${common_flags}
Y
Yan Chunwei 已提交
33 34
}

Z
Zhen Wang 已提交
35
function cmake_opencl {
Z
ZhenWang 已提交
36 37
    # $1: ARM_TARGET_OS in "android" , "armlinux"
    # $2: ARM_TARGET_ARCH_ABI in "arm64-v8a", "armeabi-v7a" ,"armeabi-v7a-hf"
Z
Zhen Wang 已提交
38 39 40 41 42 43 44 45 46 47 48
    cmake .. \
        -DLITE_WITH_OPENCL=ON \
        -DWITH_GPU=OFF \
        -DWITH_MKL=OFF \
        -DWITH_LITE=ON \
        -DLITE_WITH_CUDA=OFF \
        -DLITE_WITH_X86=OFF \
        -DLITE_WITH_ARM=ON \
        -DLITE_WITH_LIGHT_WEIGHT_FRAMEWORK=ON \
        -DWITH_TESTING=ON \
        -DARM_TARGET_OS=$1 -DARM_TARGET_ARCH_ABI=$2
Z
Zhen Wang 已提交
49 50 51
}


C
Chunwei 已提交
52
# This method is only called in CI.
Y
Yan Chunwei 已提交
53
function cmake_x86_for_CI {
54
    prepare_workspace # fake an empty __generated_code__.cc to pass cmake.
Y
Yan Chunwei 已提交
55
    cmake ..  -DWITH_GPU=OFF -DWITH_MKLDNN=OFF -DLITE_WITH_X86=ON ${common_flags} -DLITE_WITH_PROFILE=ON
C
Chunwei 已提交
56 57 58 59 60 61 62

    # Compile and execute the gen_code related test, so it will generate some code, and make the compilation reasonable.
    make test_gen_code_lite -j$NUM_CORES_FOR_COMPILE
    make test_cxx_api_lite -j$NUM_CORES_FOR_COMPILE
    ctest -R test_cxx_api_lite
    ctest -R test_gen_code_lite
    make test_generated_code -j$NUM_CORES_FOR_COMPILE
Y
Yan Chunwei 已提交
63 64
}

Y
Yan Chunwei 已提交
65
function cmake_gpu {
66
    prepare_workspace
Y
Yan Chunwei 已提交
67 68 69
    cmake .. " -DWITH_GPU=ON {common_flags} -DLITE_WITH_GPU=ON"
}

S
up  
superjomn 已提交
70 71
function check_style {
    export PATH=/usr/bin:$PATH
S
update  
superjomn 已提交
72
    #pre-commit install
S
up  
superjomn 已提交
73 74 75 76 77 78 79 80
    clang-format --version

    if ! pre-commit run -a ; then
        git diff
        exit 1
    fi
}

T
tensor-tang 已提交
81
function build_single {
82
    #make $1 -j$(expr $(nproc) - 2)
C
Chunwei 已提交
83
    make $1 -j$NUM_CORES_FOR_COMPILE
T
tensor-tang 已提交
84 85
}

Y
Yan Chunwei 已提交
86
function build {
87
    make lite_compile_deps -j$NUM_CORES_FOR_COMPILE
C
Chunwei 已提交
88 89 90

    # test publish inference lib
    make publish_inference_lite
Y
Yan Chunwei 已提交
91
}
Y
Yan Chunwei 已提交
92 93 94 95 96

# It will eagerly test all lite related unittests.
function test_lite {
    local file=$1
    echo "file: ${file}"
Y
Yan Chunwei 已提交
97

Y
Yan Chunwei 已提交
98 99 100 101 102
    for _test in $(cat $file); do
        ctest -R $_test -V
    done
}

103 104 105 106 107
# Build the code and run lite server tests. This is executed in the CI system.
function build_test_server {
    mkdir -p ./build
    cd ./build
    export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:/paddle/build/third_party/install/mklml/lib"
Y
Yan Chunwei 已提交
108
    cmake_x86_for_CI
C
Chunwei 已提交
109
    build
C
Chunwei 已提交
110

111 112 113
    test_lite $TESTS_FILE
}

T
tensor-tang 已提交
114 115
# test_arm_android <some_test_name> <adb_port_number>
function test_arm_android {
C
Chunwei 已提交
116 117
    local test_name=$1
    local port=$2
T
tensor-tang 已提交
118 119 120 121 122 123 124 125 126 127 128
    if [[ "${test_name}x" == "x" ]]; then
        echo "test_name can not be empty"
        exit 1
    fi
    if [[ "${port}x" == "x" ]]; then
        echo "Port can not be empty"
        exit 1
    fi

    echo "test name: ${test_name}"
    adb_work_dir="/data/local/tmp"
S
sangoly 已提交
129

C
Chunwei 已提交
130
    skip_list=("test_model_parser_lite" "test_mobilenetv1_lite" "test_mobilenetv2_lite" "test_resnet50_lite" "test_inceptionv4_lite" "test_light_api_lite" "test_apis_lite" "test_paddle_api_lite")
S
sangoly 已提交
131 132 133 134
    for skip_name in ${skip_list[@]} ; do
        [[ $skip_name =~ (^|[[:space:]])$test_name($|[[:space:]]) ]] && echo "skip $test_name" && return
    done

C
Chunwei 已提交
135 136
    local testpath=$(find ./paddle/fluid -name ${test_name})

C
Chunwei 已提交
137 138 139 140 141 142 143 144 145 146
    adb -s emulator-${port} push ${testpath} ${adb_work_dir}
    adb -s emulator-${port} shell "${adb_work_dir}/${test_name}"
}

# test the inference high level api
function test_arm_api {
    local port=$1
    local test_name="test_paddle_api_lite"

    make $test_name -j$NUM_CORES_FOR_COMPILE
C
Chunwei 已提交
147

C
Chunwei 已提交
148 149 150 151 152 153
    local model_path=$(find . -name "lite_naive_model")
    local remote_model=${adb_work_dir}/paddle_api
    local testpath=$(find ./paddle/fluid -name ${test_name})

    arm_push_necessary_file $port $model_path $remote_model
    adb -s emulator-${port} shell mkdir -p $remote_model
T
tensor-tang 已提交
154 155
    adb -s emulator-${port} push ${testpath} ${adb_work_dir}
    adb -s emulator-${port} shell chmod +x "${adb_work_dir}/${test_name}"
C
Chunwei 已提交
156
    adb -s emulator-${port} shell "${adb_work_dir}/${test_name} --model_dir $remote_model"
T
tensor-tang 已提交
157 158
}

S
sangoly 已提交
159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183
function test_arm_model {
    local test_name=$1
    local port=$2
    local model_dir=$3

    if [[ "${test_name}x" == "x" ]]; then
        echo "test_name can not be empty"
        exit 1
    fi
    if [[ "${port}x" == "x" ]]; then
        echo "Port can not be empty"
        exit 1
    fi
    if [[ "${model_dir}x" == "x" ]]; then
        echo "Model dir can not be empty"
        exit 1
    fi

    echo "test name: ${test_name}"
    adb_work_dir="/data/local/tmp"

    testpath=$(find ./paddle/fluid -name ${test_name})
    adb -s emulator-${port} push ${model_dir} ${adb_work_dir}
    adb -s emulator-${port} push ${testpath} ${adb_work_dir}
    adb -s emulator-${port} shell chmod +x "${adb_work_dir}/${test_name}"
C
Chunwei 已提交
184
    local adb_model_path="${adb_work_dir}/`basename ${model_dir}`"
185
    adb -s emulator-${port} shell "${adb_work_dir}/${test_name} --model_dir=$adb_model_path"
T
tensor-tang 已提交
186

S
sangoly 已提交
187 188
}

T
tensor-tang 已提交
189
function cmake_arm {
190
    prepare_workspace
T
tensor-tang 已提交
191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213
    # $1: ARM_TARGET_OS in "android" , "armlinux"
    # $2: ARM_TARGET_ARCH_ABI in "armv8", "armv7" ,"armv7hf"
    # $3: ARM_TARGET_LANG in "gcc" "clang"
    cmake .. \
        -DWITH_GPU=OFF \
        -DWITH_MKL=OFF \
        -DWITH_LITE=ON \
        -DLITE_WITH_CUDA=OFF \
        -DLITE_WITH_X86=OFF \
        -DLITE_WITH_ARM=ON \
        -DLITE_WITH_LIGHT_WEIGHT_FRAMEWORK=ON \
        -DWITH_TESTING=ON \
        -DARM_TARGET_OS=$1 -DARM_TARGET_ARCH_ABI=$2 -DARM_TARGET_LANG=$3
}

# $1: ARM_TARGET_OS in "android" , "armlinux"
# $2: ARM_TARGET_ARCH_ABI in "armv8", "armv7" ,"armv7hf"
# $3: ARM_TARGET_LANG in "gcc" "clang"
function build_arm {
    os=$1
    abi=$2
    lang=$3

C
Chunwei 已提交
214
    cur_dir=$(pwd)
T
tensor-tang 已提交
215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241
    if [[ ${os} == "armlinux" ]]; then
        # TODO(hongming): enable compile armv7 and armv7hf on armlinux, and clang compile
        if [[ ${lang} == "clang" ]]; then
            echo "clang is not enabled on armlinux yet"
            return 0
        fi
        if [[ ${abi} == "armv7hf" ]]; then
            echo "armv7hf is not supported on armlinux yet"
            return 0
        fi
        if [[ ${abi} == "armv7" ]]; then
            echo "armv7 is not supported on armlinux yet"
            return 0
        fi
    fi

    if [[ ${os} == "android" && ${abi} == "armv7hf" ]]; then
        echo "android do not need armv7hf"
        return 0
    fi

    build_dir=$cur_dir/build.lite.${os}.${abi}.${lang}
    mkdir -p $build_dir
    cd $build_dir

    cmake_arm ${os} ${abi} ${lang}
    build $TESTS_FILE
C
Chunwei 已提交
242 243 244

    # test publish inference lib
    make publish_inference_lite
T
tensor-tang 已提交
245 246 247 248 249 250 251 252 253 254 255 256
}

# $1: ARM_TARGET_OS in "android" , "armlinux"
# $2: ARM_TARGET_ARCH_ABI in "armv8", "armv7" ,"armv7hf"
# $3: ARM_TARGET_LANG in "gcc" "clang"
# $4: android test port
# Note: test must be in build dir
function test_arm {
    os=$1
    abi=$2
    lang=$3
    port=$4
C
Chunwei 已提交
257

T
tensor-tang 已提交
258 259 260 261 262 263 264 265 266 267
    if [[ ${os} == "armlinux" ]]; then
        # TODO(hongming): enable test armlinux on armv8, armv7 and armv7hf
        echo "Skip test arm linux yet. armlinux must in another docker"
        return 0
    fi

    if [[ ${os} == "android" && ${abi} == "armv7hf" ]]; then
        echo "android do not need armv7hf"
        return 0
    fi
C
Chunwei 已提交
268

T
tensor-tang 已提交
269 270 271
    echo "test file: ${TESTS_FILE}"
    for _test in $(cat $TESTS_FILE); do
        test_arm_android $_test $port
T
tensor-tang 已提交
272
    done
C
Chunwei 已提交
273 274 275

    # test finally
    test_arm_api $port
T
tensor-tang 已提交
276
}
T
tensor-tang 已提交
277

C
Chunwei 已提交
278 279 280
function prepare_emulator {
    local port_armv8=$1
    local port_armv7=$2
T
tensor-tang 已提交
281 282 283 284 285

    adb kill-server
    adb devices | grep emulator | cut -f1 | while read line; do adb -s $line emu kill; done
    # start android armv8 and armv7 emulators first
    echo n | avdmanager create avd -f -n paddle-armv8 -k "system-images;android-24;google_apis;arm64-v8a"
S
superjomn 已提交
286
    echo -ne '\n' | ${ANDROID_HOME}/emulator/emulator -avd paddle-armv8 -noaudio -no-window -gpu off -port ${port_armv8} &
T
tensor-tang 已提交
287 288
    sleep 1m
    echo n | avdmanager create avd -f -n paddle-armv7 -k "system-images;android-24;google_apis;armeabi-v7a"
S
superjomn 已提交
289
    echo -ne '\n' | ${ANDROID_HOME}/emulator/emulator -avd paddle-armv7 -noaudio -no-window -gpu off -port ${port_armv7} &
T
tensor-tang 已提交
290
    sleep 1m
C
Chunwei 已提交
291 292
}

C
Chunwei 已提交
293 294 295 296 297 298 299 300
function arm_push_necessary_file {
    local port=$1
    local testpath=$2
    local adb_work_dir=$3

    adb -s emulator-${port} push ${testpath} ${adb_work_dir}
}

C
Chunwei 已提交
301 302 303 304 305 306 307 308 309 310

# We split the arm unittest into several sub-tasks to parallel and reduce the overall CI timetime.
# sub-task1
function build_test_arm_subtask_android {
    ########################################################################
    # job 1-4 must be in one runner
    port_armv8=5554
    port_armv7=5556

    prepare_emulator $port_armv8 $port_armv7
T
tensor-tang 已提交
311

T
tensor-tang 已提交
312 313 314 315 316 317
    # job 1
    build_arm "android" "armv8" "gcc"
    test_arm "android" "armv8" "gcc" ${port_armv8}
    cd -

    # job 2
C
Chunwei 已提交
318 319 320
    #build_arm "android" "armv8" "clang"
    #test_arm "android" "armv8" "clang" ${port_armv8}
    #cd -
T
tensor-tang 已提交
321

T
tensor-tang 已提交
322 323 324 325 326 327
    # job 3
    build_arm "android" "armv7" "gcc"
    test_arm "android" "armv7" "gcc" ${port_armv7}
    cd -

    # job 4
C
Chunwei 已提交
328 329 330
    #build_arm "android" "armv7" "clang"
    #test_arm "android" "armv7" "clang" ${port_armv7}
    #cd -
T
tensor-tang 已提交
331

T
tensor-tang 已提交
332 333
    adb devices | grep emulator | cut -f1 | while read line; do adb -s $line emu kill; done
    echo "Done"
C
Chunwei 已提交
334 335 336 337
}

# sub-task2
function build_test_arm_subtask_armlinux {
T
tensor-tang 已提交
338
    ########################################################################
C
Chunwei 已提交
339 340 341 342 343
    # job 1-4 must be in one runner
    port_armv8=5554
    port_armv7=5556

    prepare_emulator $port_armv8 $port_armv7
T
tensor-tang 已提交
344

C
Chunwei 已提交
345 346
    cur=$PWD

T
tensor-tang 已提交
347
    # job 5
C
Chunwei 已提交
348 349 350
    build_arm "armlinux" "armv8" "gcc" $port_armv8
    test_arm "armlinux" "armv8" "gcc" $port_armv8
    cd $cur
T
tensor-tang 已提交
351 352

    # job 6
C
Chunwei 已提交
353 354 355
    build_arm "armlinux" "armv7" "gcc" $port_armv8
    test_arm "armlinux" "armv7" "gcc" $port_armv8
    cd $cur
T
tensor-tang 已提交
356 357

    # job 7
C
Chunwei 已提交
358 359 360
    build_arm "armlinux" "armv7hf" "gcc" $port_armv8
    test_arm "armlinux" "armv7hf" "gcc" $port_armv8
    cd $cur
T
tensor-tang 已提交
361

C
Chunwei 已提交
362 363 364 365
    adb devices | grep emulator | cut -f1 | while read line; do adb -s $line emu kill; done
    echo "Done"
}

366 367
# sub-task-model
function build_test_arm_subtask_model {
C
Chunwei 已提交
368 369 370 371 372 373 374
    local port_armv8=5554
    local port_armv7=5556
    # We just test following single one environment to limit the CI time.
    local os=android
    local abi=armv8
    local lang=gcc

375 376 377
    local test_name=$1
    local model_name=$2

C
Chunwei 已提交
378 379 380 381 382
    cur_dir=$(pwd)
    build_dir=$cur_dir/build.lite.${os}.${abi}.${lang}
    mkdir -p $build_dir
    cd $build_dir
    cmake_arm $os $abi $lang
383
    make $test_name -j$NUM_CORES_FOR_COMPILE
C
Chunwei 已提交
384 385 386 387

    prepare_emulator $port_armv8 $port_armv7

    # just test the model on armv8
388
    test_arm_model $test_name $port_armv8 "./third_party/install/$model_name"
C
Chunwei 已提交
389 390

    adb devices | grep emulator | cut -f1 | while read line; do adb -s $line emu kill; done
T
tensor-tang 已提交
391
    echo "Done"
T
tensor-tang 已提交
392 393
}

S
update  
superjomn 已提交
394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409

# this test load a model, optimize it and check the prediction result of both cxx and light APIS.
function test_arm_predict_apis {
    local port=$1
    local workspace=$2
    local naive_model_path=$3
    local api_test_path=$(find . -name "test_apis_lite")
    # the model is pushed to ./lite_naive_model
    adb -s emulator-${port} push ${naive_model_path} ${workspace}
    adb -s emulator-${port} push $api_test_path ${workspace}

    # test cxx_api first to store the optimized model.
    adb -s emulator-${port} shell ./test_apis_lite --model_dir ./lite_naive_model --optimized_model ./lite_naive_model_opt
}


C
Chunwei 已提交
410 411 412 413 414 415 416 417 418 419 420 421
# Build the code and run lite arm tests. This is executed in the CI system.
function build_test_arm {
    ########################################################################
    # job 1-4 must be in one runner
    port_armv8=5554
    port_armv7=5556

    build_test_arm_subtask_android
    build_test_arm_subtask_armlinux
}


Y
Yan Chunwei 已提交
422 423 424 425 426 427 428
############################# MAIN #################################
function print_usage {
    echo -e "\nUSAGE:"
    echo
    echo "----------------------------------------"
    echo -e "cmake_x86: run cmake with X86 mode"
    echo -e "cmake_cuda: run cmake with CUDA mode"
T
tensor-tang 已提交
429
    echo -e "--arm_os=<os> --arm_abi=<abi> cmake_arm: run cmake with ARM mode"
Y
Yan Chunwei 已提交
430 431
    echo
    echo -e "build: compile the tests"
T
tensor-tang 已提交
432
    echo -e "--test_name=<test_name> build_single: compile single test"
Y
Yan Chunwei 已提交
433 434
    echo
    echo -e "test_server: run server tests"
T
tensor-tang 已提交
435
    echo -e "--test_name=<test_name> --adb_port_number=<adb_port_number> test_arm_android: run arm test"
Y
Yan Chunwei 已提交
436 437 438 439 440 441 442 443 444 445 446 447
    echo "----------------------------------------"
    echo
}

function main {
    # Parse command line.
    for i in "$@"; do
        case $i in
            --tests=*)
                TESTS_FILE="${i#*=}"
                shift
                ;;
T
tensor-tang 已提交
448 449 450 451 452 453 454 455 456 457 458 459
            --test_name=*)
                TEST_NAME="${i#*=}"
                shift
                ;;
            --arm_os=*)
                ARM_OS="${i#*=}"
                shift
                ;;
            --arm_abi=*)
                ARM_ABI="${i#*=}"
                shift
                ;;
T
tensor-tang 已提交
460 461 462 463
            --arm_lang=*)
                ARM_LANG="${i#*=}"
                shift
                ;;
T
tensor-tang 已提交
464 465 466 467
            --arm_port=*)
                ARM_PORT="${i#*=}"
                shift
                ;;
Y
Yan Chunwei 已提交
468 469 470 471 472
            build)
                build $TESTS_FILE
                build $LIBS_FILE
                shift
                ;;
T
tensor-tang 已提交
473 474 475 476
            build_single)
                build_single $TEST_NAME
                shift
                ;;
Y
Yan Chunwei 已提交
477 478 479 480
            cmake_x86)
                cmake_x86
                shift
                ;;
Z
Zhen Wang 已提交
481
            cmake_opencl)
Z
ZhenWang 已提交
482
                cmake_opencl $ARM_OS $ARM_ABI
Z
Zhen Wang 已提交
483 484
                shift
                ;;
Y
Yan Chunwei 已提交
485 486 487 488 489
            cmake_cuda)
                cmake_cuda
                shift
                ;;
            cmake_arm)
T
tensor-tang 已提交
490 491 492 493 494
                cmake_arm $ARM_OS $ARM_ABI $ARM_LANG
                shift
                ;;
            build_arm)
                build_arm $ARM_OS $ARM_ABI $ARM_LANG
Y
Yan Chunwei 已提交
495 496 497 498 499 500
                shift
                ;;
            test_server)
                test_lite $TESTS_FILE
                shift
                ;;
T
tensor-tang 已提交
501 502 503 504
            test_arm)
                build_arm $ARM_OS $ARM_ABI $ARM_LANG $ARM_PORT
                shift
                ;;
T
tensor-tang 已提交
505 506
            test_arm_android)
                test_arm_android $TEST_NAME $ARM_PORT
Y
Yan Chunwei 已提交
507 508
                shift
                ;;
509 510 511 512
            build_test_server)
                build_test_server
                shift
                ;;
T
tensor-tang 已提交
513 514 515 516
            build_test_arm)
                build_test_arm
                shift
                ;;
C
Chunwei 已提交
517 518 519 520 521 522 523 524
            build_test_arm_subtask_android)
                build_test_arm_subtask_android
                shift
                ;;
            build_test_arm_subtask_armlinux)
                build_test_arm_subtask_armlinux
                shift
                ;;
525 526 527 528 529
            build_test_arm_model_mobilenetv1)
                build_test_arm_subtask_model test_mobilenetv1_lite mobilenet_v1
                shift
                ;;
            build_test_arm_model_mobilenetv2)
S
sangoly 已提交
530
                build_test_arm_subtask_model test_mobilenetv2_lite mobilenet_v2_relu
531 532 533 534 535 536 537
                shift
                ;;
            build_test_arm_model_resnet50)
                build_test_arm_subtask_model test_resnet50_lite resnet50
                shift
                ;;
            build_test_arm_model_inceptionv4)
S
sangoly 已提交
538
                build_test_arm_subtask_model test_inceptionv4_lite inception_v4_simple
C
Chunwei 已提交
539 540
                shift
                ;;
S
up  
superjomn 已提交
541 542 543 544
            check_style)
                check_style
                shift
                ;;
S
up  
superjomn 已提交
545 546 547 548
            check_need_ci)
                check_need_ci
                shift
                ;;
Y
Yan Chunwei 已提交
549 550 551 552 553 554 555 556 557 558
            *)
                # unknown option
                print_usage
                exit 1
                ;;
        esac
    done
}

main $@