Jenkinsfile 7.89 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
19
20
21
    def cmake_build = { bconf ->
        def compiler = bconf.get("compiler", "/opt/rocm/llvm/bin/clang++")
        def flags = bconf.get("flags", "")
        def gpu_debug = bconf.get("gpu_debug", "0")
Paul's avatar
Paul committed
22
        def cmd = """
Paul's avatar
Paul committed
23
            ulimit -c unlimited
Paul's avatar
Paul committed
24
25
            echo "leak:dnnl::impl::malloc" > suppressions.txt
            export LSAN_OPTIONS="suppressions=\$(pwd)/suppressions.txt"
Paul Fultz II's avatar
Paul Fultz II committed
26
27
28
29
            export MIGRAPHX_GPU_DEBUG=${gpu_debug}
            export CXX=${compiler}
            export CXXFLAGS='-Werror'
            env
Paul's avatar
Paul committed
30
31
32
            rm -rf build
            mkdir build
            cd build
33
            cmake -DCMAKE_C_COMPILER_LAUNCHER=ccache -DCMAKE_CXX_COMPILER_LAUNCHER=ccache -DBUILD_DEV=On -DCMAKE_EXECUTE_PROCESS_COMMAND_ECHO=STDOUT ${flags} ..
34
35
36
37
38
39
            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
40
            md5sum ./*.deb
Paul's avatar
Paul committed
41
42
43
        """
        echo cmd
        sh cmd
Umang Yadav's avatar
Umang Yadav committed
44
45
46
        // 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
47
        }
Paul's avatar
Paul committed
48
49
    }
    node(name) {
50
        withEnv(['HSA_ENABLE_SDMA=0']) {
Paul's avatar
Paul committed
51
52
53
            stage("checkout ${variant}") {
                checkout scm
            }
Paul's avatar
Paul committed
54
            gitStatusWrapper(credentialsId: "${env.status_wrapper_creds}", gitHubContext: "Jenkins - ${variant}", account: 'ROCmSoftwarePlatform', repo: 'AMDMIGraphX') {
Paul's avatar
Paul committed
55
56
57
58
59
60
                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
61

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

85
def rocmnodename(name) {
Paul's avatar
Paul committed
86
87
88
89
90
91
    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";
92
93
    } else if(name == "navi21") {
        node_name = "${rocmtest_name} && navi21";
94
    } else if(name == "mi100+") {
95
        node_name = "${rocmtest_name} && (gfx908 || gfx90a) && !vm";
96
    } else if(name == "cdna") {
97
        node_name = "${rocmtest_name} && (gfx908 || gfx90a || vega20) && !vm";
98
    } else if(name == "navi32") {
99
        node_name = "${rocmtest_name} && gfx1101 && !vm";
Paul's avatar
Paul committed
100
    } else if(name == "nogpu") {
101
        node_name = "${rocmtest_name} && nogpu";
Paul's avatar
Paul committed
102
    }
103
    return node_name
Paul's avatar
Paul committed
104
105
}

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

112
rocmtest clang_debug: rocmnode('mi100+') { cmake_build ->
113
    stage('hipRTC Debug') {
114
115
116
117
118
119
120
        // 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
121
    }
122
}, clang_release: rocmnode('mi100+') { cmake_build ->
123
    stage('Hip Clang Release') {
Chris Austen's avatar
Chris Austen committed
124
125
        def gpu_targets = getgputargets()
        cmake_build(flags: "-DCMAKE_BUILD_TYPE=release -DGPU_TARGETS='${gpu_targets}'")
Paul Fultz II's avatar
Paul Fultz II committed
126
        stash includes: 'build/*.deb', name: 'migraphx-package'
Paul's avatar
Paul committed
127
    }
128
129
130
131
// }, 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")
//     }
132
}, all_targets_debug : rocmnode('mi100+') { cmake_build ->
133
    stage('All targets Release') {
Chris Austen's avatar
Chris Austen committed
134
135
        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}'")
136
    }
137
}, mlir_debug: rocmnode('mi100+') { cmake_build ->
138
    stage('MLIR Debug') {
139
        withEnv(['MIGRAPHX_ENABLE_EXTRA_MLIR=1']) {
140
            def sanitizers = "undefined"
141
142
143
            // 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
144
145
            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}'")
146
        }
147
    }
148
149
}, ck_hiprtc: rocmnode('mi100+') { cmake_build ->
    stage('CK hipRTC') {
150
        withEnv(['MIGRAPHX_ENABLE_CK=1', 'MIGRAPHX_TUNE_CK=1', 'MIGRAPHX_DISABLE_MLIR=1']) {
Chris Austen's avatar
Chris Austen committed
151
152
            def gpu_targets = getgputargets()
            cmake_build(flags: "-DCMAKE_BUILD_TYPE=release -DMIGRAPHX_USE_HIPRTC=On -DGPU_TARGETS='${gpu_targets}'")
153
154
        }
    }
Paul's avatar
Paul committed
155
156
157
}, clang_asan: rocmnode('nogpu') { cmake_build ->
    stage('Clang ASAN') {
        def sanitizers = "undefined,address"
Paul's avatar
Paul committed
158
        def debug_flags = "-g -O2 -fno-omit-frame-pointer -fsanitize=${sanitizers} -fno-sanitize-recover=${sanitizers}"
Chris Austen's avatar
Chris Austen committed
159
160
        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
161
    }
Ted Themistokleous's avatar
Ted Themistokleous committed
162
}, clang_release_navi: rocmnode('navi32') { cmake_build ->
Ted Themistokleous's avatar
Ted Themistokleous committed
163
164
165
166
167
168
    stage('HIP Clang Release Navi32') {
        cmake_build(flags: "-DCMAKE_BUILD_TYPE=release")
    }
}


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
        '''
    }
}