[all-commits] [llvm/llvm-project] e99630: [Attributor] AAValueConstantRange: Value range ana...

Hideto Ueno via All-commits all-commits at lists.llvm.org
Tue Dec 31 22:38:50 PST 2019


  Branch: refs/heads/master
  Home:   https://github.com/llvm/llvm-project
  Commit: e9963034314edf49a12ea5e29f694d8f9f52734a
      https://github.com/llvm/llvm-project/commit/e9963034314edf49a12ea5e29f694d8f9f52734a
  Author: Hideto Ueno <uenoku.tokotoko at gmail.com>
  Date:   2020-01-01 (Wed, 01 Jan 2020)

  Changed paths:
    M llvm/include/llvm/Transforms/IPO/Attributor.h
    M llvm/lib/Transforms/IPO/Attributor.cpp
    M llvm/test/Transforms/Attributor/IPConstantProp/return-constant.ll
    M llvm/test/Transforms/Attributor/IPConstantProp/solve-after-each-resolving-undefs-for-function.ll
    M llvm/test/Transforms/Attributor/dereferenceable-1.ll
    A llvm/test/Transforms/Attributor/lvi-after-jumpthreading.ll
    A llvm/test/Transforms/Attributor/lvi-for-ashr.ll
    A llvm/test/Transforms/Attributor/range.ll
    M llvm/test/Transforms/Attributor/value-simplify.ll

  Log Message:
  -----------
  [Attributor] AAValueConstantRange: Value range analysis using constant range

This patch introduces `AAValueConstantRange`, which answers a possible range for integer value in a specific program point.
One of the motivations is propagating existing `range` metadata. (I think we need to change the situation that `range` metadata cannot be put to Argument).

The state is a tuple of `ConstantRange` and it is initialized to (known, assumed) = ([-∞, +∞], empty).

Currently, AAValueConstantRange is created when AAValueSimplify cannot
simplify the value.

Supported
 - BinaryOperator(add, sub, ...)
 - CmpInst(icmp eq, ...)
 - !range metadata

`AAValueConstantRange` is not intended to extend to polyhedral range value analysis.

Reviewed By: jdoerfert

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




More information about the All-commits mailing list