1 Star 0 Fork 76

hlzhangaj/third_party_mindspore_7

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
build_helper.py 6.39 KB
一键复制 编辑 原始数据 按行查看 历史
hlzhangaj 提交于 2024-09-13 08:03 . test
#!/usr/bin/env python3
# encoding: utf-8
# Copyright 2024 Huawei Technologies Co., Ltd
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ============================================================================
import os
import shutil
import zipfile
import argparse
import hashlib
import subprocess
def extract_source(in_zip_path, out_src_path):
"depress source code form release package"
print('Extracting zipped release package...')
f = zipfile.ZipFile(in_zip_path, "r")
f.extractall(path=out_src_path)
old_src_dir = out_src_path + "/mindspore-v2.1.0/"
new_src_dir = out_src_path + "/source/"
os.rename(old_src_dir, new_src_dir)
print("Done extraction.")
def do_patch(patch_dir, target_dir):
patches = [
'0001-build-gn-c-api-for-OHOS.patch',
'0002-train-and-build.patch',
'0003-add-js-api.patch',
'0004-cross-compile-ndkso-fp16-nnrt-train_capi.patch',
'0005-micro-for-ohos.patch',
'0006-remove-lite-expression-fix-double-loadso.patch',
'0007-deobfuscator.patch',
'0008-upgrade-flatbuffers-fix_crash.patch',
'0009-npu-zero-copy.patch',
'0010-micro-dynamic-shape-support-discrete-value.patch',
'0011-fix-npu-infer-memory-leak-delete-liteGraph.patch',
'0012-add-mindir-ops.patch',
'0013-hiappevent.patch',
'0014-DynamicQuant-strategy-optimization.patch',
'0015-bugfix-for-cpu-kernel.patch',
'0016-bugfix-for-argminmax-swish-int8-and-vad-asan.patch',
'0017-bugfix-for-onnx-parser.patch',
'0018-nnrt-litegraph-dequant.patch',
'0019-adaper-NNCore-Api.patch',
'0020-fix-ocr-gcn-model-crash.patch',
'0021-add-mindir-ops.patch',
'0022-adapter-HiAI-Foundation-NPU.patch',
'0023-support-x86-emulator-build.patch',
'0024-fix-gcn-model-squeeze-transpose-infershape-not-do.patch',
'0025-support-kirin-npu-dynamic-dims.patch',
'0026-fix-depthwise-conv-kernel.patch',
'0027-reduce-memory-when-npu-compilation-with-cache.patch',
'0028-fix-onnx-parser-and-cpu-kernel.patch',
'0029-remove-recursive-lock.patch',
'0030-generate-flatbuffer-notice.patch',
'0031-fix-matmul-assemble-can-not-protect-stack-in-mutil-thread.patch',
'0032-fix-for-concat-bool-type.patch',
'0033-fix-nullptr-etal.patch',
'0034-fix-semicolon-and-nullptr-etal.patch',
'0035-fix-ArgMaxFusion_get_max_parameter_uninitialized.patch',
'0036-fix-split-non-uniform-split.patch',
'0037-fix-for-fuzz-problem.patch',
'0038-refactor-nnrt-allocator-to-singleton.patch',
'0039-add-compile-option-SP-extensions-white-list.patch',
'0040-fix-context-double-free.patch',
'0041-fix-MutableData-memory-leak.patch',
'0042-scatterND-indices-illegal.patch',
]
cwd = os.getcwd()
os.chdir(target_dir)
print('Change dir to', os.getcwd())
subprocess.run(['git', 'init', '.'])
subprocess.run(['git', 'add', '.'])
subprocess.run(['git', 'commit', '-m', '"init"'])
for patch in patches:
print('Applying ', patch, '...')
ret = subprocess.run(['git', 'apply', '{0}/{1}'.format(patch_dir, patch)])
if ret.returncode != 0:
raise Exception("Apply patch {0} failed, ret: {1}".format(patch, ret))
subprocess.run(['git', 'add', '.'])
subprocess.run(['git', 'commit', '-m', "auto-apply {0}".format(patch)])
print('Done')
os.chdir(cwd)
def create_status_file(out_src_path):
with open("{0}/.status".format(out_src_path), 'w+') as f:
f.write('ok')
def compute_md5(file):
m = hashlib.md5()
with open(file, 'rb') as f:
m.update(f.read())
return m.hexdigest()
def save_md5s(folder_path, out_path):
files_list = []
for file_name in os.listdir(folder_path):
if (file_name.endswith(".patch")):
files_list.append(file_name)
os.makedirs(out_path, exist_ok=True)
for pf in files_list:
md5_path = os.path.join(out_path, pf.replace(".patch", ".md5"))
with open(md5_path, 'w') as f:
f.write(compute_md5(os.path.join(folder_path, pf)))
def md5_changed(patch_path, md5_path):
if not os.path.exists(md5_path):
return True
patch_list = []
md5_list = []
for file_name in os.listdir(patch_path):
if (file_name.endswith(".patch")):
patch_list.append(file_name)
for file_name in os.listdir(md5_path):
if (file_name.endswith(".md5")):
md5_list.append(file_name)
if (len(patch_list) != len(md5_list)):
return True
for md5_file in md5_list:
if not os.path.exists(os.path.join(patch_path, md5_file.replace(".md5", ".patch"))):
return True
with open(os.path.join(md5_path, md5_file), 'r') as f:
origin_v = f.read().strip()
if (origin_v != compute_md5(os.path.join(patch_path, md5_file.replace(".md5", ".patch")))):
return True
return False
def source_has_changed(out_src_path, patch_path, md5_path):
if not os.path.exists(os.path.join(out_src_path, ".status")):
print(".status not exist.")
return True
return md5_changed(patch_path, md5_path)
def main_work():
parser = argparse.ArgumentParser(description="mindspore build helper")
parser.add_argument('--in_zip_path')
parser.add_argument('--out_src_path')
parser.add_argument('--patch_dir')
args = vars(parser.parse_args())
in_zip_path = os.path.realpath(args['in_zip_path'])
out_src_path = args['out_src_path']
patch_dir = os.path.realpath(args['patch_dir'])
if os.path.exists(out_src_path):
shutil.rmtree(out_src_path)
os.makedirs(out_src_path, exist_ok=True)
out_src_path = os.path.realpath(out_src_path)
extract_source(in_zip_path, out_src_path)
do_patch(patch_dir, out_src_path + '/source/')
create_status_file(out_src_path)
if __name__ == "__main__":
main_work()
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/hlzhangaj/third_party_mindspore_7.git
[email protected]:hlzhangaj/third_party_mindspore_7.git
hlzhangaj
third_party_mindspore_7
third_party_mindspore_7
master

搜索帮助