From 3a5dccb159834968567a2e45e561dc1aeaa8f8a8 Mon Sep 17 00:00:00 2001 From: Xu Zhao Date: Fri, 20 Dec 2024 16:09:57 -0800 Subject: [PATCH] Add library path to the subprocess executable Summary: fbcode will add customized library path to the system executable and we need to handle that in our runner too. Reviewed By: adamomainz Differential Revision: D67545174 fbshipit-source-id: dc2adf735b0b6c28e01d092afc17d624211bd762 --- tritonbench/components/workers/subprocess_worker.py | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/tritonbench/components/workers/subprocess_worker.py b/tritonbench/components/workers/subprocess_worker.py index 5420201d..4b4f31e0 100644 --- a/tritonbench/components/workers/subprocess_worker.py +++ b/tritonbench/components/workers/subprocess_worker.py @@ -124,6 +124,17 @@ def __init__( worker_env["PYTHONPATH"] = f'{worker_env["PYTHONPATH"]}:{parent_sys_path}' else: worker_env["PYTHONPATH"] = parent_sys_path + # setup additional library path for fbcode + if "#platform-runtime" in sys.executable: + old_library_path = os.environ.get("LD_LIBRARY_PATH", "") + lib_dir = os.path.join( + os.path.dirname(os.path.dirname(sys.executable)), "lib" + ) + if os.path.exists(lib_dir): + worker_env["LD_LIBRARY_PATH"] = ( + f"{lib_dir}:{old_library_path}" if old_library_path else lib_dir + ) + self._proc = subprocess.Popen( args=self.args, stdin=subprocess.PIPE,