-
Notifications
You must be signed in to change notification settings - Fork 0
/
configure.py
204 lines (174 loc) · 6.97 KB
/
configure.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
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
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
"""Basic configurations for building torchair"""
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
import os
import re
import subprocess
import sys
import warnings
_COMPAT_TORCH_VERSION = "2.1"
_PYTHON_BIN_PATH_ENV = "TARGET_PYTHON_PATH"
_ASCEND_SDK_ENV = "ASCEND_SDK_PATH"
_NO_ASCEND_SDK = "NO_ASCEND_SDK"
class PathManager:
MAX_PATH_LENGTH = 4096
MAX_FILE_NAME_LENGTH = 255
DATA_FILE_AUTHORITY = 0o640
DATA_DIR_AUTHORITY = 0o750
@classmethod
def check_path_owner_consistent(cls, path: str):
if not os.path.exists(path):
msg = f"The path does not exist: {path}"
raise RuntimeError(msg)
if os.stat(path).st_uid != os.getuid():
warnings.warn(f"Warning: The {path} owner does not match the current user.")
@classmethod
def check_directory_path_writeable(cls, path):
cls.check_path_owner_consistent(path)
if os.path.islink(path):
msg = f"Invalid path is a soft chain: {path}"
raise RuntimeError(msg)
if not os.access(path, os.W_OK):
msg = f"The path permission check failed: {path}"
raise RuntimeError(msg)
@classmethod
def create_file_safety(cls, path: str):
msg = f"Failed to create file: {path}"
if os.path.islink(path):
raise RuntimeError(msg)
if os.path.exists(path):
return
try:
os.close(os.open(path, os.O_WRONLY | os.O_CREAT, cls.DATA_FILE_AUTHORITY))
except Exception as err:
raise RuntimeError(msg) from err
def run_command(cmd):
"""Execute command"""
output = subprocess.check_output(cmd)
return output.decode('UTF-8').strip()
def get_input(question):
"""Get response from user keyboard input"""
try:
try:
answer = raw_input(question)
except NameError:
answer = input(question)
except EOFError:
answer = ''
return answer
def real_config_path(file):
"""Get complete file path"""
return os.path.join("tools", file)
def get_torch_version_num(version):
nums = re.findall(r'\d+', version)
if len(nums) < 3:
print("Parse torch version failure, version:%s" % version)
return ''
return "{}{:0>2d}{:0>2d}".format(nums[0], int(nums[1]), int(nums[2]))
def setup_python(env_path):
"""Get python install path."""
default_python_bin_path = sys.executable
ask_python_bin_path = ('Please specify the location of python with valid '
'torch 2.x site-packages installed. [Default '
'is %s]\n(You can make this quiet by set env '
'[TARGET_PYTHON_PATH]): ') % default_python_bin_path
custom_python_bin_path = env_path
while True:
if not custom_python_bin_path:
python_bin_path = get_input(ask_python_bin_path)
else:
python_bin_path = custom_python_bin_path
custom_python_bin_path = None
if not python_bin_path:
python_bin_path = default_python_bin_path
# Check if the path is valid
if os.path.isfile(python_bin_path) and os.access(python_bin_path, os.X_OK):
pass
elif not os.path.exists(python_bin_path):
print('Invalid python path: %s cannot be found.' % python_bin_path)
continue
else:
print('%s is not executable. Is it the python binary?' %
python_bin_path)
continue
try:
compile_args = run_command([
python_bin_path, '-c',
'''
import os
import distutils.sysconfig
import torch
print('|'.join([
torch.__version__,
os.path.dirname(torch.__file__),
f"-D_GLIBCXX_USE_CXX11_ABI={'1' if torch.compiled_with_cxx11_abi() else '0'}",
distutils.sysconfig.get_python_inc()
]))
'''
]).split("|")
except subprocess.CalledProcessError:
print('Invalid python path: %s torch not installed.' %
python_bin_path)
continue
if not compile_args[0] >= _COMPAT_TORCH_VERSION:
print('Invalid python path: %s expect torch version >= %s'
' got %s.' % (python_bin_path, _COMPAT_TORCH_VERSION,
compile_args[0]))
continue
for path in ['PYTHON_BIN_PATH', 'TORCH_INSTALLED_PATH', 'COMPILE_FLAGS']:
real_path = os.path.abspath(real_config_path(path))
PathManager.create_file_safety(real_path)
PathManager.check_directory_path_writeable(real_path)
# Write tools/python_bin_path.sh
with open(real_config_path('PYTHON_BIN_PATH'), 'w') as f:
f.write(python_bin_path)
with open(real_config_path('TORCH_INSTALLED_PATH'), 'w') as f:
f.write(compile_args[1])
with open(real_config_path('COMPILE_FLAGS'), 'w') as f:
for flag in compile_args[2:-1]:
f.write("".join([flag, '\n']))
f.write("".join(["-I", compile_args[-1], '\n']))
torch_version = get_torch_version_num(compile_args[0])
if len(torch_version) > 0:
with open(real_config_path('TORCH_VERSION'), 'w') as f:
f.write(torch_version)
break
def setup_ascend_sdk(env_path):
"""Get ascend install path."""
ask_ascend_path = f'Specify the location of ascend sdk for debug on localhost or leave empty.' + \
f'\n(You can make this quiet by set env [{_ASCEND_SDK_ENV}]): '
custom_ascend_path = env_path
while True:
if not custom_ascend_path:
ascend_path = get_input(ask_ascend_path)
else:
ascend_path = custom_ascend_path
custom_ascend_path = None
if not ascend_path:
print(f"No ascend sdk path specified")
return
# Check if the path is valid
if os.path.isdir(ascend_path) and os.access(ascend_path, os.X_OK):
break
if not os.path.exists(ascend_path):
print('Invalid ascend path: %s cannot be found.' % ascend_path)
for path in ['ASCEND_SDK_PATH', 'env.sh']:
real_path = os.path.abspath(real_config_path(path))
PathManager.create_file_safety(real_path)
PathManager.check_directory_path_writeable(real_path)
with open(real_config_path('ASCEND_SDK_PATH'), 'w') as f:
f.write(ascend_path)
with open(real_config_path('env.sh'), 'w') as f:
stub_libs = os.path.dirname(os.path.abspath(__file__)) + "/build/stubs"
sdk_libs = f"{ascend_path}/lib:{ascend_path}/lib64"
f.write(f"#!/bin/sh\n")
f.write(f'export LD_LIBRARY_PATH={stub_libs}:{sdk_libs}')
def main():
"""Entry point for configuration"""
env_snapshot = dict(os.environ)
setup_python(env_snapshot.get(_PYTHON_BIN_PATH_ENV))
if not env_snapshot.get(_NO_ASCEND_SDK) in ["1", "true", "True"]:
setup_ascend_sdk(env_snapshot.get(_ASCEND_SDK_ENV))
if __name__ == '__main__':
main()