- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 5.7k
          base: add Sys.detectwsl()
          #57069
        
          New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
  
    base: add Sys.detectwsl()
  
  #57069
              
            Conversation
Co-Authored-By: Max Horn <[email protected]>
| Seems all Linux platforms failed. Maybe I need to use  Line 619 in 316f0fe 
 | 
        
          
                base/sysinfo.jl
              
                Outdated
          
        
      |  | ||
| for f in (:isunix, :islinux, :isbsd, :isapple, :iswindows, :isfreebsd, :isopenbsd, :isnetbsd, :isdragonfly, :isjsvm) | ||
| """ | ||
| Sys.detectwsl([os]) | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Perhaps Sys.iswsl() for consistency with the other platform detection functions?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is actually on purpose, as detectwsl detects at runtime, so names of the form is_platform are not used.
See discuss in #36354
| There is already a WSL detection in base at Line 658 in 316f0fe 
 | 
| As a data point, Ubuntu's Snap daemon looks for  Some references: | 
Co-authored-by: Alex Arslan <[email protected]>
| I read through the links that @ararslan posted, and to me the  The superuser post also mentions on the other hand that the method implemented here in this PR might give a false positive maybe even on Azure, where MS might be running a custom kernel, and so greping for just "Microsoft" might get fooled. I also think that if Ubuntu uses a given approach for snap, then it is probably a good idea to just follow that. Ubuntu and MS have worked really closely together on this whole WSL stuff, so just following their lead strikes me as a good idea. | 
| I should note that my claim about Snap comes from the linked answer on SuperUser, which is from 2022; it's possible that Ubuntu has changed the implementation since then. | 
| 
 They added testing for the existence of “/run/WSL/” as a fallback. // We detect WSL via the existence of /proc/sys/fs/binfmt_misc/WSLInterop
// Under some undocumented circumstances this file may be missing. We have /run/WSL as a backup.
//
// We detect WSL1 via the root filesystem type:
// - wslfs or lxfs mean WSL1
// - Anything else means WSL2
// After knowing we're in WSL, if any error occurs we assume WSL2 as it is the more flexible version
func getWSLVersion() int {
	if !fileExists("/proc/sys/fs/binfmt_misc/WSLInterop") && !fileExists("/run/WSL") {
		return 0
	}
	fstype, err := filesystemRootType()
	if err != nil {
		// TODO log error here once logger can be imported without circular imports
		return 2
	}
	if fstype == "wslfs" || fstype == "lxfs" {
		return 1
	}
	return 2
}Some test under Ubuntu and alpine: Ubuntu 22.04.5 LTS (default/Offical) ~$ lsb_release
No LSB modules are available.
~$ lsb_release -a
No LSB modules are available.
Distributor ID: Ubuntu
Description:    Ubuntu 22.04.5 LTS
Release:        22.04
Codename:       jammy
~$ uname -a
Linux A309-Y9000P 5.15.137.3-microsoft-standard-WSL2+ #4 SMP Wed Jan 10 11:18:39 CST 2024 x86_64 x86_64 x86_64 GNU/Linux
~$ cat /proc/sys/fs/binfmt_misc/WSLInterop
enabled
interpreter /init
flags: PF
offset 0
magic 4d5a
~$ ls /run/WSL/
1_interop  2_interop  3217_interop  518_interop
~$ cat /proc/sys/kernel/osrelease
5.15.137.3-microsoft-standard-WSL2+
~$alpine-release-3.17.0 (win store): ~$ cat /etc/alpine-release
3.17.0
~$ cat /proc/sys/fs/binfmt_misc/WSLInterop
enabled
interpreter /init
flags: PF
offset 0
magic 4d5a
~$ ls /run/WSL/
14_interop  1_interop
~$ cat /proc/sys/kernel/osrelease
5.15.137.3-microsoft-standard-WSL2+
~$ | 
Close #36425, fix #36354
How to detect WSL?
There are a number of ways that can be used to detect WSL environments,
but each can have false positives.
We finally chose to use the same method as Snapd to detect WSL.
Because Windows installs Ubuntu LTS as WSL by default.
So we assume that Snapd's detection method will work for most users.
Known limitations
this is a runtime test, and thus cannot meaningfully be used in
@static ifconstructs.Linux users can create their own
/proc/sys/fs/binfmt_misc/WSLInteropfile/run/WSL/folderto pretend to be a WSL environment.
figure out which one is more robust