Jenkinsfile 8.05 KB
Newer Older
Chris Austen's avatar
Chris Austen committed
1
def getgputargets() {
2
    targets="gfx906;gfx908;gfx90a;gfx1030;gfx1100;gfx1101;gfx1102"
Chris Austen's avatar
Chris Austen committed
3
4
    return targets
}
Paul's avatar
Paul committed
5

6
7
8
9
10
11
12
13
// def rocmtestnode(variant, name, body, args, pre) {
def rocmtestnode(Map conf) {
    def variant = conf.get("variant")
    def name = conf.get("node")
    def body = conf.get("body")
    def docker_args = conf.get("docker_args", "")
    def docker_build_args = conf.get("docker_build_args", "")
    def pre = conf.get("pre", {})
Paul Fultz II's avatar
Paul Fultz II committed
14
    def ccache = "/var/jenkins/.cache/ccache"
Paul's avatar
Paul committed
15
    def image = 'migraphxlib'
Paul Fultz II's avatar
Paul Fultz II committed
16
17
    env.CCACHE_COMPRESSLEVEL = 7
    env.CCACHE_DIR = ccache
Paul Fultz II's avatar
Paul Fultz II committed
18
    def cmake_build = { bconf ->
Artur Wojcik's avatar
Jenkins  
Artur Wojcik committed
19
20
        def cxx_compiler = bconf.get("cxx_compiler", "/opt/rocm/llvm/bin/clang++")
        def cc_compiler = bconf.get("cc_compiler", "/opt/rocm/llvm/bin/clang")
Paul Fultz II's avatar
Paul Fultz II committed
21
22
        def flags = bconf.get("flags", "")
        def gpu_debug = bconf.get("gpu_debug", "0")
Paul's avatar
Paul committed
23
        def cmd = """
Paul's avatar
Paul committed
24
            ulimit -c unlimited
Paul's avatar
Paul committed
25
            echo "leak:dnnl::impl::malloc" > suppressions.txt
26
27
            echo "leak:libtbb.so" >> suppressions.txt
            cat suppressions.txt
Paul's avatar
Paul committed
28
            export LSAN_OPTIONS="suppressions=\$(pwd)/suppressions.txt"
Paul Fultz II's avatar
Paul Fultz II committed
29
            export MIGRAPHX_GPU_DEBUG=${gpu_debug}
Artur Wojcik's avatar
Jenkins  
Artur Wojcik committed
30
31
            export CXX=${cxx_compiler}
            export CC=${cc_compiler}
Paul Fultz II's avatar
Paul Fultz II committed
32
33
            export CXXFLAGS='-Werror'
            env
Paul's avatar
Paul committed
34
35
36
            rm -rf build
            mkdir build
            cd build
37
            cmake -DCMAKE_C_COMPILER_LAUNCHER=ccache -DCMAKE_CXX_COMPILER_LAUNCHER=ccache -DBUILD_DEV=On -DCMAKE_EXECUTE_PROCESS_COMMAND_ECHO=STDOUT -DMIGRAPHX_DISABLE_VIRTUAL_ENV=ON ${flags} ..
38
39
40
41
42
43
            git diff
            git diff-index --quiet HEAD || (echo "Git repo is not clean after running cmake." && exit 1)
            make -j\$(nproc) generate VERBOSE=1
            git diff
            git diff-index --quiet HEAD || (echo "Generated files are different. Please run make generate and commit the changes." && exit 1)
            make -j\$(nproc) all doc package check VERBOSE=1
Chris Austen's avatar
Chris Austen committed
44
            md5sum ./*.deb
Paul's avatar
Paul committed
45
46
47
        """
        echo cmd
        sh cmd
Umang Yadav's avatar
Umang Yadav committed
48
49
50
        // Only archive from master or develop
        if (env.BRANCH_NAME == "develop" || env.BRANCH_NAME == "master") {
            archiveArtifacts artifacts: "build/*.deb", allowEmptyArchive: true, fingerprint: true
Paul's avatar
Paul committed
51
        }
Paul's avatar
Paul committed
52
53
    }
    node(name) {
54
        withEnv(['HSA_ENABLE_SDMA=0']) {
Paul's avatar
Paul committed
55
56
57
            stage("checkout ${variant}") {
                checkout scm
            }
Paul's avatar
Paul committed
58
            gitStatusWrapper(credentialsId: "${env.status_wrapper_creds}", gitHubContext: "Jenkins - ${variant}", account: 'ROCmSoftwarePlatform', repo: 'AMDMIGraphX') {
Paul's avatar
Paul committed
59
60
61
62
63
64
                pre()
                stage("image ${variant}") {
                    try {
                        docker.build("${image}", "${docker_build_args} .")
                    } catch(Exception ex) {
                        docker.build("${image}", "${docker_build_args} --no-cache .")
Paul's avatar
Paul committed
65

Paul's avatar
Paul committed
66
                    }
Paul's avatar
Paul committed
67
                }
Paul Fultz II's avatar
Paul Fultz II committed
68
                withDockerContainer(image: image, args: "--device=/dev/kfd --device=/dev/dri --group-add video --cap-add SYS_PTRACE -v=/var/jenkins/:/var/jenkins ${docker_args}") {
69
                    timeout(time: 2, unit: 'HOURS') {
Paul's avatar
Paul committed
70
71
                        body(cmake_build)
                    }
Paul's avatar
Paul committed
72
                }
Paul's avatar
Paul committed
73
74
75
76
77
78
            }
        }
    }
}
def rocmtest(m) {
    def builders = [:]
Paul Fultz II's avatar
Paul Fultz II committed
79
    m.each { e ->
Paul's avatar
Paul committed
80
81
82
83
84
85
86
87
88
        def label = e.key;
        def action = e.value;
        builders[label] = {
            action(label)
        }
    }
    parallel builders
}

89
def rocmnodename(name) {
Paul's avatar
Paul committed
90
91
92
93
94
95
    def rocmtest_name = "(rocmtest || migraphx)"
    def node_name = "${rocmtest_name}"
    if(name == "fiji") {
        node_name = "${rocmtest_name} && fiji";
    } else if(name == "vega") {
        node_name = "${rocmtest_name} && vega";
96
97
    } else if(name == "navi21") {
        node_name = "${rocmtest_name} && navi21";
98
    } else if(name == "mi100+") {
99
        node_name = "${rocmtest_name} && (gfx908 || gfx90a) && !vm";
100
    } else if(name == "cdna") {
101
        node_name = "${rocmtest_name} && (gfx908 || gfx90a || vega20) && !vm";
Paul's avatar
Paul committed
102
    } else if(name == "nogpu") {
103
        node_name = "${rocmtest_name} && nogpu";
Paul's avatar
Paul committed
104
    }
105
    return node_name
Paul's avatar
Paul committed
106
107
}

Paul Fultz II's avatar
Paul Fultz II committed
108
def rocmnode(name, body) {
109
110
111
    return { label ->
        rocmtestnode(variant: label, node: rocmnodename(name), body: body)
    }
Paul Fultz II's avatar
Paul Fultz II committed
112
113
}

114
rocmtest clang_debug: rocmnode('mi100+') { cmake_build ->
115
    stage('hipRTC Debug') {
116
117
118
119
120
121
122
        // Disable MLIR since it doesnt work with all ub sanitizers
        withEnv(['MIGRAPHX_DISABLE_MLIR=1']) {
            def sanitizers = "undefined"
            def debug_flags = "-g -O2 -fsanitize=${sanitizers} -fno-sanitize-recover=${sanitizers}"
            def gpu_targets = getgputargets()
            cmake_build(flags: "-DCMAKE_BUILD_TYPE=debug -DMIGRAPHX_ENABLE_PYTHON=Off -DCMAKE_CXX_FLAGS_DEBUG='${debug_flags}' -DCMAKE_C_FLAGS_DEBUG='${debug_flags}' -DMIGRAPHX_USE_HIPRTC=On -DGPU_TARGETS='${gpu_targets}'", gpu_debug: true)
        }
Paul Fultz II's avatar
Paul Fultz II committed
123
    }
124
}, clang_release: rocmnode('mi100+') { cmake_build ->
125
    stage('Hip Clang Release') {
Chris Austen's avatar
Chris Austen committed
126
127
        def gpu_targets = getgputargets()
        cmake_build(flags: "-DCMAKE_BUILD_TYPE=release -DGPU_TARGETS='${gpu_targets}'")
Paul Fultz II's avatar
Paul Fultz II committed
128
        stash includes: 'build/*.deb', name: 'migraphx-package'
Paul's avatar
Paul committed
129
    }
130
131
132
133
// }, hidden_symbols: rocmnode('cdna') { cmake_build ->
//     stage('Hidden symbols') {
//         cmake_build(flags: "-DMIGRAPHX_ENABLE_PYTHON=Off -DMIGRAPHX_ENABLE_GPU=On -DMIGRAPHX_ENABLE_CPU=On -DCMAKE_CXX_VISIBILITY_PRESET=hidden -DCMAKE_C_VISIBILITY_PRESET=hidden")
//     }
134
}, all_targets_debug : rocmnode('mi100+') { cmake_build ->
135
    stage('All targets Release') {
Chris Austen's avatar
Chris Austen committed
136
137
        def gpu_targets = getgputargets()
        cmake_build(flags: "-DCMAKE_BUILD_TYPE=release -DMIGRAPHX_ENABLE_GPU=On -DMIGRAPHX_ENABLE_CPU=On -DMIGRAPHX_ENABLE_FPGA=On -DGPU_TARGETS='${gpu_targets}'")
138
    }
139
}, mlir_debug: rocmnode('mi100+') { cmake_build ->
140
    stage('MLIR Debug') {
141
        withEnv(['MIGRAPHX_ENABLE_EXTRA_MLIR=1']) {
142
            def sanitizers = "undefined"
143
144
145
            // Note: the -fno-sanitize= is copied from upstream LLVM_UBSAN_FLAGS.
            def debug_flags_cxx = "-g -O2 -fsanitize=${sanitizers} -fno-sanitize=vptr,function -fno-sanitize-recover=${sanitizers}"
            def debug_flags = "-g -O2 -fsanitize=${sanitizers} -fno-sanitize=vptr -fno-sanitize-recover=${sanitizers}"
Chris Austen's avatar
Chris Austen committed
146
147
            def gpu_targets = getgputargets()
            cmake_build(flags: "-DCMAKE_BUILD_TYPE=debug -DMIGRAPHX_ENABLE_PYTHON=Off -DMIGRAPHX_ENABLE_MLIR=On -DCMAKE_CXX_FLAGS_DEBUG='${debug_flags_cxx}' -DCMAKE_C_FLAGS_DEBUG='${debug_flags}' -DGPU_TARGETS='${gpu_targets}'")
148
        }
149
    }
150
151
}, ck_hiprtc: rocmnode('mi100+') { cmake_build ->
    stage('CK hipRTC') {
152
        withEnv(['MIGRAPHX_ENABLE_CK=1', 'MIGRAPHX_TUNE_CK=1', 'MIGRAPHX_DISABLE_MLIR=1']) {
Chris Austen's avatar
Chris Austen committed
153
154
            def gpu_targets = getgputargets()
            cmake_build(flags: "-DCMAKE_BUILD_TYPE=release -DMIGRAPHX_USE_HIPRTC=On -DGPU_TARGETS='${gpu_targets}'")
155
156
        }
    }
Paul's avatar
Paul committed
157
158
159
}, clang_asan: rocmnode('nogpu') { cmake_build ->
    stage('Clang ASAN') {
        def sanitizers = "undefined,address"
Paul's avatar
Paul committed
160
        def debug_flags = "-g -O2 -fno-omit-frame-pointer -fsanitize=${sanitizers} -fno-sanitize-recover=${sanitizers}"
Chris Austen's avatar
Chris Austen committed
161
162
        def gpu_targets = getgputargets()
        cmake_build(flags: "-DCMAKE_BUILD_TYPE=debug -DMIGRAPHX_ENABLE_PYTHON=Off -DMIGRAPHX_ENABLE_GPU=Off -DMIGRAPHX_ENABLE_CPU=On -DCMAKE_CXX_FLAGS_DEBUG='${debug_flags}' -DCMAKE_C_FLAGS_DEBUG='${debug_flags}' -DGPU_TARGETS='${gpu_targets}'")
Paul's avatar
Paul committed
163
    }
164
165
}//, clang_release_navi: rocmnode('navi21') { cmake_build ->
//    stage('HIP Clang Release Navi') {
Paul Fultz II's avatar
Paul Fultz II committed
166
//        cmake_build(flags: "-DCMAKE_BUILD_TYPE=release")
167
168
//    }
//}
Paul Fultz II's avatar
Paul Fultz II committed
169

170
171
172
173
def onnxnode(name, body) {
    return { label ->
        rocmtestnode(variant: label, node: rocmnodename(name), docker_args: '-u root', body: body, pre: {
            sh 'rm -rf ./build/*.deb'
174
            unstash 'migraphx-package'
175
176
177
178
        })
    }
}

179
rocmtest onnx: onnxnode('mi100+') { cmake_build ->
Paul Fultz II's avatar
Paul Fultz II committed
180
181
    stage("Onnx runtime") {
        sh '''
182
            apt install half
Chris Austen's avatar
Chris Austen committed
183
184
            #ls -lR
            md5sum ./build/*.deb
185
            dpkg -i ./build/*.deb
186
            env
Paul Fultz II's avatar
Paul Fultz II committed
187
188
189
190
            cd /onnxruntime && ./build_and_test_onnxrt.sh
        '''
    }
}