From bc504f4f4d5c86458c7d23800967c0872604c678 Mon Sep 17 00:00:00 2001 From: David Anderson Date: Wed, 25 Dec 2024 02:01:13 -0800 Subject: [PATCH 1/3] Client: add some error reporting to WSL detection --- client/hostinfo_wsl.cpp | 6 +++++- lib/win_util.cpp | 32 +++++++++++++++++++++++++------- lib/win_util.h | 2 +- 3 files changed, 31 insertions(+), 9 deletions(-) diff --git a/client/hostinfo_wsl.cpp b/client/hostinfo_wsl.cpp index cb852c4ab7..f07dd76c8d 100644 --- a/client/hostinfo_wsl.cpp +++ b/client/hostinfo_wsl.cpp @@ -48,6 +48,7 @@ int get_all_distros(WSL_DISTROS& distros) { lxss_path.c_str(), 0, KEY_QUERY_VALUE | KEY_ENUMERATE_SUB_KEYS, &hKey ); if (lRet != ERROR_SUCCESS) { + msg_printf(0, MSG_INFO, "WSL: registry open failed"); return -1; } @@ -59,6 +60,7 @@ int get_all_distros(WSL_DISTROS& distros) { (LPBYTE)default_wsl_guid, &default_wsl_guid_len ); if ((lRet != ERROR_SUCCESS) || (default_wsl_guid_len > buf_len)) { + msg_printf(0, MSG_INFO, "WSL: registry query failed"); return -1; } @@ -179,10 +181,12 @@ int get_wsl_information(WSL_DISTROS &distros) { WSL_DISTROS all_distros; int retval = get_all_distros(all_distros); if (retval) return retval; + string err_msg; WSL_CMD rs; - if (rs.setup()) { + if (rs.setup(err_msg)) { + msg_printf(0, MSG_INFO, "WSL setup error: %s", err_msg.c_str()); return -1; } diff --git a/lib/win_util.cpp b/lib/win_util.cpp index 65e2ccda45..57ec394bcb 100644 --- a/lib/win_util.cpp +++ b/lib/win_util.cpp @@ -199,7 +199,7 @@ typedef HRESULT(WINAPI *PWslLaunch)( static PWslLaunch pWslLaunch = NULL; static HINSTANCE wsl_lib = NULL; -int WSL_CMD::setup() { +int WSL_CMD::setup(string &err_msg) { in_read = NULL; in_write = NULL; out_read = NULL; @@ -207,9 +207,15 @@ int WSL_CMD::setup() { if (!pWslLaunch) { wsl_lib = LoadLibraryA("wslapi.dll"); - if (!wsl_lib) return -1; + if (!wsl_lib) { + err_msg = "Can't load wslapi.dll"); + return -1; + } pWslLaunch = (PWslLaunch)GetProcAddress(wsl_lib, "WslLaunch"); - if (!pWslLaunch) return -1; + if (!pWslLaunch) { + err_msg = "WslLaunch not in wslapi.dll"); + return -1; + } } SECURITY_ATTRIBUTES sa; @@ -217,10 +223,22 @@ int WSL_CMD::setup() { sa.bInheritHandle = TRUE; sa.lpSecurityDescriptor = NULL; - if (!CreatePipe(&out_read, &out_write, &sa, 0)) return -1; - if (!SetHandleInformation(out_read, HANDLE_FLAG_INHERIT, 0)) return -1; - if (!CreatePipe(&in_read, &in_write, &sa, 0)) return -1; - if (!SetHandleInformation(in_write, HANDLE_FLAG_INHERIT, 0)) return -1; + if (!CreatePipe(&out_read, &out_write, &sa, 0)) { + err_msg = "Can't create out pipe"); + return -1; + } + if (!SetHandleInformation(out_read, HANDLE_FLAG_INHERIT, 0)) { + err_msg = "Can't inherit out pipe"); + return -1; + } + if (!CreatePipe(&in_read, &in_write, &sa, 0)) { + err_msg = "Can't create in pipe"); + return -1; + } + if (!SetHandleInformation(in_write, HANDLE_FLAG_INHERIT, 0)) { + err_msg = "Can't inherit in pipe"); + return -1; + } return 0; } diff --git a/lib/win_util.h b/lib/win_util.h index 0dba261b10..9cffddb62c 100644 --- a/lib/win_util.h +++ b/lib/win_util.h @@ -53,7 +53,7 @@ struct WSL_CMD { // Use WslLaunch() to run a shell in the WSL container // The shell will run as the default user // - int setup(); + int setup(std::string&); // Use wsl.exe to run a shell as root in the WSL container // From c0c68b28b163a3f848830f4ec9f181f4d8742ea8 Mon Sep 17 00:00:00 2001 From: davidpanderson Date: Wed, 25 Dec 2024 02:12:48 -0800 Subject: [PATCH 2/3] build fixes --- lib/util.cpp | 3 ++- lib/win_util.cpp | 12 ++++++------ 2 files changed, 8 insertions(+), 7 deletions(-) diff --git a/lib/util.cpp b/lib/util.cpp index 55312ff694..55413de728 100644 --- a/lib/util.cpp +++ b/lib/util.cpp @@ -704,9 +704,10 @@ string parse_ldd_libc(const char* input) { #ifdef _WIN32 int DOCKER_CONN::init(DOCKER_TYPE docker_type, string distro_name, bool _verbose) { + string err_msg; cli_prog = docker_cli_prog(docker_type); if (docker_type == DOCKER) { - int retval = ctl_wc.setup(); + int retval = ctl_wc.setup(err_msg); if (retval) return retval; retval = ctl_wc.run_program_in_wsl(distro_name, "", true); if (retval) return retval; diff --git a/lib/win_util.cpp b/lib/win_util.cpp index 57ec394bcb..64592fb68b 100644 --- a/lib/win_util.cpp +++ b/lib/win_util.cpp @@ -208,12 +208,12 @@ int WSL_CMD::setup(string &err_msg) { if (!pWslLaunch) { wsl_lib = LoadLibraryA("wslapi.dll"); if (!wsl_lib) { - err_msg = "Can't load wslapi.dll"); + err_msg = "Can't load wslapi.dll"; return -1; } pWslLaunch = (PWslLaunch)GetProcAddress(wsl_lib, "WslLaunch"); if (!pWslLaunch) { - err_msg = "WslLaunch not in wslapi.dll"); + err_msg = "WslLaunch not in wslapi.dll"; return -1; } } @@ -224,19 +224,19 @@ int WSL_CMD::setup(string &err_msg) { sa.lpSecurityDescriptor = NULL; if (!CreatePipe(&out_read, &out_write, &sa, 0)) { - err_msg = "Can't create out pipe"); + err_msg = "Can't create out pipe"; return -1; } if (!SetHandleInformation(out_read, HANDLE_FLAG_INHERIT, 0)) { - err_msg = "Can't inherit out pipe"); + err_msg = "Can't inherit out pipe"; return -1; } if (!CreatePipe(&in_read, &in_write, &sa, 0)) { - err_msg = "Can't create in pipe"); + err_msg = "Can't create in pipe"; return -1; } if (!SetHandleInformation(in_write, HANDLE_FLAG_INHERIT, 0)) { - err_msg = "Can't inherit in pipe"); + err_msg = "Can't inherit in pipe"; return -1; } return 0; From 104e3be35353f3f6ecc9da440df50537422b45e6 Mon Sep 17 00:00:00 2001 From: davidpanderson Date: Wed, 25 Dec 2024 14:01:33 -0800 Subject: [PATCH 3/3] build fix --- samples/wsl_wrapper/wsl_wrapper.cpp | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/samples/wsl_wrapper/wsl_wrapper.cpp b/samples/wsl_wrapper/wsl_wrapper.cpp index b2103b7eb0..0f4b9d1fc7 100644 --- a/samples/wsl_wrapper/wsl_wrapper.cpp +++ b/samples/wsl_wrapper/wsl_wrapper.cpp @@ -97,9 +97,10 @@ int error(const char* where, int retval) { // int launch(const char* distro, const char* cmd) { char launch_cmd[256]; + string err_msg; sprintf(launch_cmd, "echo $$; %s; touch boinc_job_done\n", cmd); - int retval = app_wc.setup(); - if (retval) return error("app setup", retval); + int retval = app_wc.setup(err_msg); + if (retval) return error(err_msg.c_str(), retval); retval = app_wc.run_program_in_wsl(distro, launch_cmd, true); if (retval) return error("app run_program_in_wsl", retval); @@ -117,8 +118,8 @@ int launch(const char* distro, const char* cmd) { // set up control channel // - retval = ctl_wc.setup(); - if (retval) return error("ctl setup", retval); + retval = ctl_wc.setup(err_msg); + if (retval) return error(err_msg.c_str(), retval); retval = ctl_wc.run_program_in_wsl(distro, "", true); // empty string means run shell if (retval) return error("ctl run_program_in_wsl", retval);