samitolvanen added a comment.

> Needs some thoughts to merge the above paragraphs with the existing one

Great points. I updated the commit message and tried to capture most of these, 
PTAL.



================
Comment at: llvm/lib/Target/RISCV/RISCVAsmPrinter.cpp:332
+      continue;
+    while (!isRegAvailable(NextReg))
+      ++NextReg;
----------------
MaskRay wrote:
> As a minor optimization to skip one redundant `isRegAvailable` call: `while 
> (!isRegAvailable(++NextReg));`
`Reg` != `NextReg` here, and using `while (!isRegAvailable(++NextReg))` would 
always skip the first alternative register by first incrementing `NextReg` 
before calling `isRegsAvailable`. What am I missing?


================
Comment at: llvm/lib/Target/RISCV/RISCVAsmPrinter.cpp:368
+  // Load the expected type hash.
+  const int64_t Type = MI.getOperand(1).getImm();
+  const int64_t Hi20 = ((Type + 0x800) >> 12) & 0xFFFFF;
----------------
MaskRay wrote:
> `int64_t` is the return type of `getImm`, not the original `KCFI_CHECK` 
> operand type. Casting this to a `uint32_t` is perhaps clearer.
I don't think casting this to `uint32_t` make sense since we'd have to cast it 
back to a larger type immediately below (to prevent `+ 0x800` from 
overflowing). I changed the comment to indicate this is a 32-bit value though.


================
Comment at: llvm/lib/Target/RISCV/RISCVAsmPrinter.cpp:375
+        MCInstBuilder(RISCV::LUI).addReg(ScratchRegs[1]).addImm(Hi20));
+  if (Lo12 || Hi20 == 0)
+    EmitToStreamer(*OutStreamer,
----------------
MaskRay wrote:
> Is `Hi20 == 0` tested?
Good catch, added a test.


================
Comment at: llvm/lib/Target/RISCV/RISCVISelLowering.cpp:14427
   SDValue Callee = CLI.Callee;
+  bool IsCFICall = CLI.CB && CLI.CB->isIndirectCall() && CLI.CFIType;
   bool &IsTailCall = CLI.IsTailCall;
----------------
MaskRay wrote:
> If `CLI.CFIType != 0`, is `CLI.CB->isIndirectCall()` possible? If not, add an 
> assert?
> This is  an opportunity to save a redundant check.
Sure. `CFIType` should be set only for indirect calls when we reach this point.


================
Comment at: llvm/test/CodeGen/RISCV/kcfi-patchable-function-prefix.ll:4
+
+; NOC:            .p2align 2
+; C:              .p2align 1
----------------
MaskRay wrote:
> f1/f2/f3/f4 have the same shape. Without increasing the number of functions, 
> we can make some disturbance (e.g. add one extra indirect call, use inline 
> asm to clobber some registers) to check various cases without using .mir 
> tests. `.mir` tests are fine, but the signal-to-noise ratio is not great and 
> readers can be lost in the paramemters...
There are four functions because we're testing type hash locations in relation 
to patchable-function-prefix nops in four different cases, in addition to the 
code generated for KCFI checks. I'm not sure there's a way to do this with 
fewer functions.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D148385

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

Reply via email to