DiggerLin marked 3 inline comments as done.
DiggerLin added inline comments.


================
Comment at: llvm/test/tools/llvm-ranlib/aix-X-option.test:17-18
+## Test the OBJECT_MODE environment variable when adding symbol table.
+# RUN: unset OBJECT_MODE
+# RUN: llvm-ranlib t_X32.a
+# RUN: llvm-nm --print-armap t_X32.a 2>&1 | FileCheck --check-prefixes=GLOB32 
--implicit-check-not="in t64" %s
----------------
jhenderson wrote:
> DiggerLin wrote:
> > jhenderson wrote:
> > > Assuming the unsetting is intended to be just for the llvm-ranlib line, I 
> > > believe the preferred approach is `env -u OBJECT_MODE llvm-ranlib ...`. 
> > > That way, you don't impact the behaviour in subsequent lines.
> > the command `env` of AIX OS do not support -u.  and there is no mapping  
> > option of `env -u`
> > 
> > https://www.ibm.com/docs/en/aix/7.2?topic=e-env-command
> I'm 90% certain that `env` here is the built-in lit `env`, not a system `env` 
> executable. `env -u` seems to be only rarely used in the test suite, but see 
> llvm/utils/lit/tests/Inputs/shtest-env/env-u.txt for an example. I assume you 
> can run this test locally?
it run fail in AIX OS locally.


================
Comment at: llvm/tools/llvm-ar/llvm-ar.cpp:1463
 
+  if (object::Archive::getDefaultKindForHost() == object::Archive::K_AIXBIG) {
+    // If not specify -X option, get BitMode from enviorment variable
----------------
jhenderson wrote:
> DiggerLin wrote:
> > jhenderson wrote:
> > > DiggerLin wrote:
> > > > jhenderson wrote:
> > > > > Is there a particular reason that this is after the command-line 
> > > > > option parsing for llvm-ranlib, but before it in llvm-ar? If this 
> > > > > were before the option parsing, you wouldn't need the `HasAixXOption` 
> > > > > variable.
> > > > in AIX OS  `ranlib` has behavior as
> > > > 
> > > > 
> > > > ```
> > > > -bash-5.0$ env OBJECT_MODE=31 ranlib tmpk.a
> > > > 0654-603 The OBJECT_MODE environment variable has an invalid setting.
> > > >         OBJECT_MODE must be 32, 64, or 32_64.
> > > > -bash-5.0$ env OBJECT_MODE=31 ranlib -X32  tmpk.a
> > > > -bash-5.0$
> > > > ```  
> > > > 
> > > > Given invalid env OBJECT_MODE , if there is no -X option in the ranlib 
> > > > command, it will output as 
> > > > 
> > > > ```
> > > > 0654-603 The OBJECT_MODE environment variable has an invalid setting.
> > > >         OBJECT_MODE must be 32, 64, or 32_64.
> > > > ```
> > > > 
> > > > Given invalid env OBJECT_MODE , and there is -X option in the ranlib 
> > > > command,  it do not care about the invalid env OBJECT_MODE,  So I has 
> > > > to parse the -X option before the getBitMode(getenv("OBJECT_MODE"))
> > > > 
> > > So with AIX ar, does an invalid OBJECT_MODE environment variable get 
> > > reported if the -X option is specified?
> > > 
> > > In my opinion, I think it is very unlikely there will be any real users 
> > > out there with an invalid OBJECT_MODE environment variable, because other 
> > > tools will reject it, even if ranlib doesn't. Even if there are, they 
> > > should be able to easily fix their variable, if they start getting an 
> > > error message after switching to llvm-ranlib. I'm therefore thinking that 
> > > there isn't a need to mirror this logic in llvm-ranlib, if it would make 
> > > the code simpler (which it would).
> > > So with AIX ar, does an invalid OBJECT_MODE environment variable get 
> > > reported if the -X option is specified?
> > 
> > it do no report invalid OBJECT_MODE environment if the -X option is 
> > specified.
> > 
> > 
> > ```
> > bash-5.0$ export OBJECT_MODE=31
> > bash-5.0$ ar  q tmpp.acheck.o
> > ar: 0707-133 The OBJECT_MODE environment variable has an invalid setting.
> >         OBJECT_MODE must be 32, 64, 32_64, d64, or any.
> > bash-5.0$ ar -X32 q tmpp.acheck.o
> > bash-5.0$
> > ```
> > 
> > 
> > 
> > > In my opinion, I think it is very unlikely there will be any real users 
> > > out there with an invalid OBJECT_MODE environment variable, because other 
> > > tools will reject it, even if ranlib doesn't. Even if there are, they 
> > > should be able to easily fix their variable, if they start getting an 
> > > error message after switching to llvm-ranlib. I'm therefore thinking that 
> > > there isn't a need to mirror this logic in llvm-ranlib, if it would make 
> > > the code simpler (which it would).
> > 
> > since -X option will overwrite the env variable OBJECT_MODE, 
> > in the source code , we should check the -X option of the command line 
> > first, if there is no  -X option ,  we will check the env variable 
> > OBJECT_MODE. the logic of code is correct in the patch.  we should not 
> > always  getenv("OBJECT_MODE")  before checking the -X option.
> > 
> > since -X option will overwrite the env variable OBJECT_MODE, in the source 
> > code , we should check the -X option of the command line first, if there is 
> > no -X option , we will check the env variable OBJECT_MODE. the logic of 
> > code is correct in the patch. we should not always getenv("OBJECT_MODE") 
> > before checking the -X option.
> 
> I don't agree. It is normal to validate all of a a user's input options 
> (including environment variables that are a proxy for command-line options) 
> even if they don't end up getting used. Consider a similar, admittedly 
> somewhat arbitrary case. If you had one command called e.g. `--doTheThing` 
> whose sole purpose was to ensure that some `if` block was run, and then 
> another option `--doTheThingThisWay={methodA|methodB}` which controlled what 
> happens within that `if` block, it would be perfectly normal and acceptable 
> to check the value passed to `--doTheThingThisWay` even without 
> `--doTheThing` being specified. The code would typically look like this 
> pseudo code:
> ```
> Config processCommandLine(Args args) {
>   Config cfg;
>   if ("doTheThing" in args) {
>     cfg.doTheThing = true;
>   }
>   if ("doTheThingThisWay" in args) {
>     switch(args["doTheThingThisWay"].value) {
>        case "methodA":
>         cfg.doTheThingThisWay = DoTheThingThisWayKind::MethodA;
>         break;
>        case "methodB":
>         cfg.doTheThingThisWay = DoTheThingThisWayKind::MethodB;
>         break;
>       default:
>         reportError("invalid --doTheThingThisWay value");
>     }
>   }
> }
> ```
> The OBJECT_MODE environment variable is a proxy for the -X option. Therefore, 
> it should be parsed and checked in the same manner as the -X option even if 
> it isn't used. This brings consistency between the two tools, which is good. 
> Incosistency is bad: it increases code complexity and potentially can confuse 
> users. What is the benefit to making the two tools inconsistent?
> The OBJECT_MODE environment variable is a proxy for the -X option. Therefore, 
> it should be parsed and checked in the same manner as the -X option even if 
> it isn't used. This brings consistency between the two tools, which is good. 
> Incosistency is bad: it increases code complexity and potentially can confuse 
> users. What is the benefit to making the two tools inconsistent?

as I mention before , I will create  patches to let the llvm-ar and llvm-nm to 
work same as logic  llvm-ranlib for the env variable "OBJECT_MODE" 


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D142660

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to