[PATCH] D86170: PrintStackTrace: don't symbolize if LLVM_DISABLE_SYMBOLIZATION is set

Fangrui Song via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Mon Aug 24 17:00:23 PDT 2020


MaskRay added inline comments.


================
Comment at: llvm/test/tools/not/disable-symbolization.test:1
+# RUN: not --crash env > %t || true
+# RUN: FileCheck %s < %t
----------------
zequanwu wrote:
> aganea wrote:
> > zequanwu wrote:
> > > MaskRay wrote:
> > > > aganea wrote:
> > > > > zequanwu wrote:
> > > > > > aganea wrote:
> > > > > > > dblaikie wrote:
> > > > > > > > MaskRay wrote:
> > > > > > > > > aganea wrote:
> > > > > > > > > > This test also fails on Windows - I think lit doesn't like `env` alone.
> > > > > > > > > > 
> > > > > > > > > > ```
> > > > > > > > > > ******************** TEST 'LLVM :: tools/not/disable-symbolization.test' FAILED ********************
> > > > > > > > > > Script:
> > > > > > > > > > --
> > > > > > > > > > : 'RUN: at line 1';   not --crash env > D:\llvm-project\buildninjaRel\test\tools\not\Output\disable-symbolization.test.tmp || true
> > > > > > > > > > : 'RUN: at line 2';   d:\llvm-project\buildninjarel\bin\filecheck.exe D:\llvm-project\llvm\test\tools\not\disable-symbolization.test < D:\llvm-project\buildninjaRel\test\tools\not\Output\disable-symbolization.test.tmp
> > > > > > > > > > --
> > > > > > > > > > Exit Code: 127
> > > > > > > > > > 
> > > > > > > > > > Command Output (stdout):
> > > > > > > > > > --
> > > > > > > > > > $ ":" "RUN: at line 1"
> > > > > > > > > > $ "not" "--crash" "env"
> > > > > > > > > > # command stderr:
> > > > > > > > > > Error: 'env' requires a subcommand
> > > > > > > > > > error: command failed with exit status: 127
> > > > > > > > > > 
> > > > > > > > > > --
> > > > > > > > > > ```
> > > > > > > > > > 
> > > > > > > > > > `printenv` instead?
> > > > > > > > > Thanks! `printenv` is not specified by POSIX, so I did not use it. But I just checked: `printenv` appeared in 3.0BSD & Solaris has it as well, so the portability is good.
> > > > > > > > Any ideas if this'll work on Windows?
> > > > > > > @dblaikie It does work, since a Unix-like shell is required anyway to run the lit tests on Windows, either MinGW, CygWin or GnuWin32 on the top of the regular cmd shell.
> > > > > > Hi, this test failed on Windows
> > > > > > ```
> > > > > > ******************** TEST 'LLVM :: tools/not/disable-symbolization.test' FAILED ********************
> > > > > >  Script:
> > > > > >  --
> > > > > >  : 'RUN: at line 1';   not --crash printenv > C:\b\s\w\ir\cache\builder\src\third_party\llvm-bootstrap\test\tools\not\Output\disable-symbolization.test.tmp || true
> > > > > >  : 'RUN: at line 2';   c:\b\s\w\ir\cache\builder\src\third_party\llvm-bootstrap\bin\filecheck.exe C:\b\s\w\ir\cache\builder\src\third_party\llvm\llvm\test\tools\not\disable-symbolization.test < C:\b\s\w\ir\cache\builder\src\third_party\llvm-bootstrap\test\tools\not\Output\disable-symbolization.test.tmp
> > > > > >  --
> > > > > >  Exit Code: 2
> > > > > >  
> > > > > >  Command Output (stdout):
> > > > > >  --
> > > > > >  $ ":" "RUN: at line 1"
> > > > > >  $ "not" "--crash" "printenv"
> > > > > >  # command stderr:
> > > > > >  error: unable to find `printenv' in PATH: no such file or directory
> > > > > > ```
> > > > > @zequanwu Are you running from a cmd shell or a Unix-like shell? Do you have GnuWin32 installed and in PATH?
> > > > > 
> > > > > This is what I see from cmd.exe:
> > > > > ```
> > > > > D:\llvm-project>which printenv
> > > > > C:\Users\aganea\Downloads\GetGnuWin32\gnuwin32\bin\printenv.EXE
> > > > > ```
> > > > > From a MinGW shell:
> > > > > ```
> > > > > $ which printenv
> > > > > /usr/bin/printenv
> > > > > ```
> > > > @aganea If printenv is not always available, I'd like to use
> > > > 
> > > > `UNSUPPORTED: system-windows` 
> > > > 
> > > > and switch back to `env` (POSIX).
> > > It's a building bot and running from cmd.exe
> > > ```
> > > cmd.exe /C "cd /D C:\b\s\w\ir\cache\builder\src\third_party\llvm-bootstrap && C:\b\s\w\ir\cipd_bin_packages\cpython3\bin\python3.exe C:/b/s/w/ir/cache/builder/src/third_party/llvm-bootstrap/./bin/llvm-lit.py -sv --param USE_Z3_SOLVER=0 C:/b/s/w/ir/cache/builder/src/third_party/llvm-bootstrap/projects/compiler-rt/test/profile/Profile-x86_64 C:/b/s/w/ir/cache/builder/src/third_party/llvm-bootstrap/tools/clang/test C:/b/s/w/ir/cache/builder/src/third_party/llvm-bootstrap/tools/lld/test C:/b/s/w/ir/cache/builder/src/third_party/llvm-bootstrap/utils/lit C:/b/s/w/ir/cache/builder/src/third_party/llvm-bootstrap/test"
> > >  ninja: build stopped: subcommand failed.
> > > ```
> > @MaskRay Ok, but I'd like to understand what is going on. [[ https://llvm.org/docs/GettingStartedVS.html#software | This page ]] mandates having GnuWin32 in PATH, and GnuWin32 hasn't been updated since 2010, so `printenv` should be there,
> > @zequanwu Is it a public bot? Would you have a link to the logs?
> Yes. https://logs.chromium.org/logs/chromium/buildbucket/cr-buildbucket.appspot.com/8871047405536941408/+/steps/package_clang/0/stdout?format=raw
Sent D86496

I'd want to use 'env' instead of 'printenv' as well, since the former is specified by POSIX.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D86170/new/

https://reviews.llvm.org/D86170



More information about the llvm-commits mailing list