Environment: MacBook Air M4 (Tahoe 26.3), Docker version 29.2.1, build a5c7197
Symptom: Attempting to run msfconsole -q produces the following output:
/usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/path_scanner.rb:91:in `scan_dir': Too many levels of symbolic links - opendir @ /usr/lib/llvm-18/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/Debug+Asserts/build/include/llvm-c (Errno::ELOOP)
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/path_scanner.rb:91:in `native_call'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/path.rb:76:in `entries'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/cache.rb:170:in `block (2 levels) in unshift_paths_locked'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/cache.rb:163:in `reverse_each'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/cache.rb:163:in `block in unshift_paths_locked'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/store.rb:53:in `block in transaction'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/store.rb:52:in `synchronize'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/store.rb:52:in `transaction'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/cache.rb:162:in `unshift_paths_locked'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/cache.rb:113:in `block in unshift_paths'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/cache.rb:113:in `synchronize'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/cache.rb:113:in `unshift_paths'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/change_observer.rb:22:in `unshift'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/railties-7.2.3/lib/rails/application.rb:405:in `add_lib_to_load_path!'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/railties-7.2.3/lib/rails/application.rb:75:in `inherited'
from /usr/share/metasploit-framework/config/application.rb:38:in `<module:Framework>'
from /usr/share/metasploit-framework/config/application.rb:37:in `<module:Metasploit>'
from /usr/share/metasploit-framework/config/application.rb:36:in `<top (required)>'
from /usr/lib/ruby/3.3.0/bundled_gems.rb:69:in `require'
from /usr/lib/ruby/3.3.0/bundled_gems.rb:69:in `block (2 levels) in replace_require'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:33:in `require'
from /usr/share/metasploit-framework/config/environment.rb:2:in `<top (required)>'
from /usr/lib/ruby/3.3.0/bundled_gems.rb:69:in `require'
from /usr/lib/ruby/3.3.0/bundled_gems.rb:69:in `block (2 levels) in replace_require'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:33:in `require'
from /usr/share/metasploit-framework/lib/msfenv.rb:28:in `<top (required)>'
from /usr/lib/ruby/3.3.0/bundled_gems.rb:69:in `require'
from /usr/lib/ruby/3.3.0/bundled_gems.rb:69:in `block (2 levels) in replace_require'
from /usr/share/metasploit-framework/vendor/bundle/ruby/3.3.0/gems/bootsnap-1.22.0/lib/bootsnap/load_path_cache/core_ext/kernel_require.rb:33:in `require'
from /usr/bin/msfconsole:21:in `<main>'
Workaround: Purge the LLVM build directory rm -rf /usr/lib/llvm-18/build then open msfconsole
Environment: MacBook Air M4 (Tahoe 26.3), Docker version 29.2.1, build a5c7197
Symptom: Attempting to run
msfconsole -qproduces the following output:Workaround: Purge the LLVM build directory
rm -rf /usr/lib/llvm-18/buildthen openmsfconsole