fix ci cost time bug

This commit is contained in:
liangzelang 2022-05-31 16:02:19 +08:00
parent 5f2388d6d1
commit f350e1dd9f
2 changed files with 71 additions and 2 deletions

View File

@ -22,7 +22,6 @@ from datetime import datetime
from tbe.common.rl_bank.bank_manager import set_current_op_name from tbe.common.rl_bank.bank_manager import set_current_op_name
from tbe.common.repository_manager.interface import cann_kb_finalize, cann_kb_init from tbe.common.repository_manager.interface import cann_kb_finalize, cann_kb_init
from tbe.common.rl_bank.bank_cfg import LocalLock
from te.platform.cce_conf import te_set_version from te.platform.cce_conf import te_set_version
from te.platform.cce_policy import set_L1_info from te.platform.cce_policy import set_L1_info
from te_fusion.compile_task_manager import dispatch_prebuild_task, dispatch_single_op_compile_task, import_py_module, \ from te_fusion.compile_task_manager import dispatch_prebuild_task, dispatch_single_op_compile_task, import_py_module, \
@ -35,7 +34,7 @@ from te_fusion.parallel_compilation import init_multi_process_env, start_ga_mult
get_finished_compilation_task get_finished_compilation_task
from .tbe_helper import get_soc_info, assemble_op_args, get_compute_op_list, get_options_info, get_fuzz_build_info, \ from .tbe_helper import get_soc_info, assemble_op_args, get_compute_op_list, get_options_info, get_fuzz_build_info, \
adjust_custom_op_info, pack_op_args, get_module_name, get_real_op_debug_level adjust_custom_op_info, pack_op_args, get_module_name, get_real_op_debug_level, LocalLock
from .tbe_job import TbeJob, JobStatus from .tbe_job import TbeJob, JobStatus
PLATFORM_FLAG = ["Ascend310", "Ascend910", "Hi3796CV300ES", "Ascend710", "Ascend610", "Hi3796CV300CS", "SD3403"] PLATFORM_FLAG = ["Ascend310", "Ascend910", "Hi3796CV300ES", "Ascend710", "Ascend610", "Hi3796CV300CS", "SD3403"]

View File

@ -14,11 +14,81 @@
# ============================================================================ # ============================================================================
"""tbe helper to parse json content""" """tbe helper to parse json content"""
import os import os
import stat
import fcntl
from enum import Enum from enum import Enum
from .tbe_job import JobType from .tbe_job import JobType
def create_dir(dir_path):
"""
create dir
:param dir_path:
:return: T/F
"""
dir_path = os.path.realpath(dir_path)
is_exists = os.path.exists(dir_path)
if not is_exists:
try:
os.makedirs(dir_path, 0o750, exist_ok=True)
except (OSError, TypeError) as excep:
raise excep
finally:
pass
return True
def write_to_file(file_path, content=""):
"""
write to file
:param file_path:
:param content:
:return: T/F
"""
dir_name = os.path.dirname(file_path)
ret = create_dir(dir_name)
if not ret:
return False
with os.fdopen(os.open(file_path, os.O_WRONLY | os.O_CREAT, \
stat.S_IWUSR | stat.S_IRUSR | stat.S_IRGRP), 'w') as file_handler:
file_handler.write(content)
return True
class LocalLock:
"""
LocalLock
"""
def __init__(self, lock_file):
if not os.path.exists(lock_file):
write_to_file(lock_file)
self.lock_fd = os.open(lock_file, os.O_WRONLY | os.O_CREAT, stat.S_IWUSR | stat.S_IRUSR | stat.S_IRGRP)
def __del__(self):
try:
os.close(self.lock_fd)
except OSError:
pass
finally:
pass
def lock(self):
"""
lock
"""
fcntl.flock(self.lock_fd, fcntl.LOCK_EX)
def unlock(self):
"""
unlock
"""
fcntl.flock(self.lock_fd, fcntl.LOCK_UN)
os.close(self.lock_fd)
class BuildType(Enum): class BuildType(Enum):
""" Build Type """ """ Build Type """
INITIALLY = "initially_build" INITIALLY = "initially_build"