[all-commits] [llvm/llvm-project] 3f4ba9: [BPF] disable ReduceLoadWidth during SelectionDag ...

yonghong-song via All-commits all-commits at lists.llvm.org
Mon Feb 10 04:47:38 PST 2020


  Branch: refs/heads/release/10.x
  Home:   https://github.com/llvm/llvm-project
  Commit: 3f4ba96a59a9329ce819f735550882519a4f6cb5
      https://github.com/llvm/llvm-project/commit/3f4ba96a59a9329ce819f735550882519a4f6cb5
  Author: Yonghong Song <yhs at fb.com>
  Date:   2020-02-10 (Mon, 10 Feb 2020)

  Changed paths:
    M llvm/lib/Target/BPF/BPFISelLowering.h
    A llvm/test/CodeGen/BPF/CORE/no-narrow-load.ll

  Log Message:
  -----------
  [BPF] disable ReduceLoadWidth during SelectionDag phase

The compiler may transform the following code
  ctx = ctx + reloc_offset
  ... (*(u32 *)ctx) & 0x8000 ...
to
  ctx = ctx + reloc_offset
  ... (*(u8 *)(ctx + 1)) & 0x80 ...
where reloc_offset will be replaced with a constant during
AsmPrinter phase.

The above transformed code will be rejected the kernel verifier
as it does not allow
  *(type *)((ctx + non_zero_offset1) + non_zero_offset2)
style access pattern.

It is hard at SelectionDag phase to identify whether a load
is related to context or not. Sometime, interprocedure analysis
may be needed. So let us simply prevent such optimization
from happening.

Differential Revision: https://reviews.llvm.org/D73997

(cherry picked from commit d96c1bbaa03574daf759e5e9a6c75047c5e3af64)




More information about the All-commits mailing list