build.sh 15.5 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 137 138 139 140 141
    local testpath=$(find ./paddle/fluid -name ${test_name})

    # if [[ "$test_name" == "test_light_api" ]]; then
    #     local model_path=$(find . -name "lite_naive_model")
    #     arm_push_necessary_file $port $model_path $adb_work_dir
    # fi

T
tensor-tang 已提交
142 143 144 145 146
    adb -s emulator-${port} push ${testpath} ${adb_work_dir}
    adb -s emulator-${port} shell chmod +x "${adb_work_dir}/${test_name}"
    adb -s emulator-${port} shell "./${adb_work_dir}/${test_name}"
}

S
sangoly 已提交
147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171
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 已提交
172
    local adb_model_path="${adb_work_dir}/`basename ${model_dir}`"
173
    adb -s emulator-${port} shell "${adb_work_dir}/${test_name} --model_dir=$adb_model_path"
T
tensor-tang 已提交
174

S
sangoly 已提交
175 176
}

T
tensor-tang 已提交
177
function cmake_arm {
178
    prepare_workspace
T
tensor-tang 已提交
179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201
    # $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 已提交
202
    cur_dir=$(pwd)
T
tensor-tang 已提交
203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229
    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 已提交
230 231 232

    # test publish inference lib
    make publish_inference_lite
T
tensor-tang 已提交
233 234 235 236 237 238 239 240 241 242 243 244
}

# $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 已提交
245

T
tensor-tang 已提交
246 247 248 249 250 251 252 253 254 255
    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
256
   
T
tensor-tang 已提交
257 258 259
    echo "test file: ${TESTS_FILE}"
    for _test in $(cat $TESTS_FILE); do
        test_arm_android $_test $port
T
tensor-tang 已提交
260
    done
T
tensor-tang 已提交
261
}
T
tensor-tang 已提交
262

C
Chunwei 已提交
263 264 265
function prepare_emulator {
    local port_armv8=$1
    local port_armv7=$2
T
tensor-tang 已提交
266 267 268 269 270

    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 已提交
271
    echo -ne '\n' | ${ANDROID_HOME}/emulator/emulator -avd paddle-armv8 -noaudio -no-window -gpu off -port ${port_armv8} &
T
tensor-tang 已提交
272 273
    sleep 1m
    echo n | avdmanager create avd -f -n paddle-armv7 -k "system-images;android-24;google_apis;armeabi-v7a"
S
superjomn 已提交
274
    echo -ne '\n' | ${ANDROID_HOME}/emulator/emulator -avd paddle-armv7 -noaudio -no-window -gpu off -port ${port_armv7} &
T
tensor-tang 已提交
275
    sleep 1m
C
Chunwei 已提交
276 277
}

C
Chunwei 已提交
278 279 280 281 282 283 284 285
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 已提交
286 287 288 289 290 291 292 293 294 295

# 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 已提交
296

T
tensor-tang 已提交
297 298 299 300 301 302
    # job 1
    build_arm "android" "armv8" "gcc"
    test_arm "android" "armv8" "gcc" ${port_armv8}
    cd -

    # job 2
C
Chunwei 已提交
303 304 305
    #build_arm "android" "armv8" "clang"
    #test_arm "android" "armv8" "clang" ${port_armv8}
    #cd -
T
tensor-tang 已提交
306

T
tensor-tang 已提交
307 308 309 310 311 312
    # job 3
    build_arm "android" "armv7" "gcc"
    test_arm "android" "armv7" "gcc" ${port_armv7}
    cd -

    # job 4
C
Chunwei 已提交
313 314 315
    #build_arm "android" "armv7" "clang"
    #test_arm "android" "armv7" "clang" ${port_armv7}
    #cd -
T
tensor-tang 已提交
316

T
tensor-tang 已提交
317 318
    adb devices | grep emulator | cut -f1 | while read line; do adb -s $line emu kill; done
    echo "Done"
C
Chunwei 已提交
319 320 321 322
}

# sub-task2
function build_test_arm_subtask_armlinux {
T
tensor-tang 已提交
323
    ########################################################################
C
Chunwei 已提交
324 325 326 327 328
    # job 1-4 must be in one runner
    port_armv8=5554
    port_armv7=5556

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

C
Chunwei 已提交
330 331
    cur=$PWD

T
tensor-tang 已提交
332
    # job 5
C
Chunwei 已提交
333 334 335
    build_arm "armlinux" "armv8" "gcc" $port_armv8
    test_arm "armlinux" "armv8" "gcc" $port_armv8
    cd $cur
T
tensor-tang 已提交
336 337

    # job 6
C
Chunwei 已提交
338 339 340
    build_arm "armlinux" "armv7" "gcc" $port_armv8
    test_arm "armlinux" "armv7" "gcc" $port_armv8
    cd $cur
T
tensor-tang 已提交
341 342

    # job 7
C
Chunwei 已提交
343 344 345
    build_arm "armlinux" "armv7hf" "gcc" $port_armv8
    test_arm "armlinux" "armv7hf" "gcc" $port_armv8
    cd $cur
T
tensor-tang 已提交
346

C
Chunwei 已提交
347 348 349 350
    adb devices | grep emulator | cut -f1 | while read line; do adb -s $line emu kill; done
    echo "Done"
}

351 352
# sub-task-model
function build_test_arm_subtask_model {
C
Chunwei 已提交
353 354 355 356 357 358 359
    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

360 361 362
    local test_name=$1
    local model_name=$2

C
Chunwei 已提交
363 364 365 366 367
    cur_dir=$(pwd)
    build_dir=$cur_dir/build.lite.${os}.${abi}.${lang}
    mkdir -p $build_dir
    cd $build_dir
    cmake_arm $os $abi $lang
368
    make $test_name -j$NUM_CORES_FOR_COMPILE
C
Chunwei 已提交
369 370 371 372

    prepare_emulator $port_armv8 $port_armv7

    # just test the model on armv8
373
    test_arm_model $test_name $port_armv8 "./third_party/install/$model_name"
C
Chunwei 已提交
374 375

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

S
update  
superjomn 已提交
379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394

# 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 已提交
395 396 397 398 399 400 401 402 403 404 405 406
# 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 已提交
407 408 409 410 411 412 413
############################# 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 已提交
414
    echo -e "--arm_os=<os> --arm_abi=<abi> cmake_arm: run cmake with ARM mode"
Y
Yan Chunwei 已提交
415 416
    echo
    echo -e "build: compile the tests"
T
tensor-tang 已提交
417
    echo -e "--test_name=<test_name> build_single: compile single test"
Y
Yan Chunwei 已提交
418 419
    echo
    echo -e "test_server: run server tests"
T
tensor-tang 已提交
420
    echo -e "--test_name=<test_name> --adb_port_number=<adb_port_number> test_arm_android: run arm test"
Y
Yan Chunwei 已提交
421 422 423 424 425 426 427 428 429 430 431 432
    echo "----------------------------------------"
    echo
}

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

main $@