SixWeining added a comment. Sorry for the late reply.
Should we choose not to implement the `-mfpu=` option which is not mandatory? ================ Comment at: clang/lib/Driver/ToolChains/Arch/LoongArch.cpp:31 + options::OPT_msingle_float, + options::OPT_msoft_float)) { + if (A->getOption().matches(options::OPT_mdouble_float)) ---------------- MaskRay wrote: > This is strange. Other architectures using -msoft-float makes it orthogonal > to -mdouble-float... > > Instead of having -mdouble-float/-msingle-float, can you just use > -mfloat-abi=? Sorry for the late reply. Similar to @xry111's explanation below, `-m{double,single,soft}-float` are different from `-mfpu={64,32,0,none}`. `-m{double,single,soft}-float` affect both codegen-ed instructions and the ABI while `-mfpu={64,32,0,none}` only affect the codegen-ed instructions. That is to say: * `-mdouble-float` implies `-mfpu=64` and `-mabi={lp64d,ilp32d}`; * `-msingle-float` implies `-mfpu=32` and `-mabi={lp64f,ilp32f}`; * `-msoft-float` implies `-mfpu={0,none}` and `-mabi={lp64s,ilp32s}`. The `-mfpu={64,32,0,none}` clang option is like the `--mattr=+{d,f}` llc option. And the `-mabi=` clang option is like the `--target-abi=` llc option. But I have to admit this introduce some complexity to clang implementation because we have to take care of the order these options appear on the command line. The doc says: > As a general rule, the effect of all LoongArch-specific compiler options that > are given for one compiler invocation should be as if they are processed in > the order they appear on the command line. The only exception to this rule is > -m*-float: their configuration of floating-point instruction set and calling > convention will not be changed by subsequent options other than -m*-float. ================ Comment at: clang/lib/Driver/ToolChains/Arch/LoongArch.cpp:44 + // Select abi based on -mfpu=xx. + if (const Arg *A = Args.getLastArg(options::OPT_mfpu_EQ)) { ---------------- xry111 wrote: > MaskRay wrote: > > It's better to stick with just one canonical spelling. Is there time to > > remove support for one set of options? When `-mfpu=64 -msoft-float` is > > specified, is a -Wunused-command-line-argument warning expected? > According to the doc, the semantics of -mfpu=64 and -mdouble-float are not > exactly same. `-mfpu=64 -mabi=lp64s` will allow the compiler to generate > 64-bit floating-point instructions but keep LP64S calling convention. > `-mdouble-float -mabi=lp64s` will be same as `-mdouble-float -mabi=lp64d` > (with a warning emitted, maybe). The doc says that the implementation of `-mfpu` is not mandatory. So maybe we can choose not to implement it? But I'm not sure whether it has been used by any programs. > -mdouble-float -mabi=lp64s will be same as -mdouble-float -mabi=lp64d (with a > warning emitted, maybe). Yes, I think so. GCC indeed emits a warning. We also should emit one. ================ Comment at: clang/test/Driver/loongarch-march-error.c:1 +// RUN: not %clang --target=loongarch64 -march=loongarch -fsyntax-only %s 2>&1 \ +// RUN: | FileCheck --check-prefix=LOONGARCH %s ---------------- MaskRay wrote: > The more common style is to place `|` in the end. The idea is that even > without `\`, after typing the first line in a shell, it will wait for the > second line. OK. But seems both styles are used in the code base. -;) ================ Comment at: clang/test/Driver/loongarch-march.c:12 +// CC1-LOONGARCH64: "-target-feature" "+64bit" +// CC1-LOONGARCH64-SAME: {{^}} "-target-feature" "+f" +// CC1-LOONGARCH64-SAME: {{^}} "-target-feature" "+d" ---------------- MaskRay wrote: > Check target-feature options on one line OK. ================ Comment at: llvm/lib/Support/LoongArchTargetParser.cpp:46 + if ((A.Features & F.Kind) == F.Kind && F.Kind != FK_INVALID) { + Features.push_back(F.Name); + } ---------------- MaskRay wrote: > delete braces OK. Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D136146/new/ https://reviews.llvm.org/D136146 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits