Versioned Staged Flow-Sensitive Pointer Analysis

2024-09-07 01:28

本文主要是介绍Versioned Staged Flow-Sensitive Pointer Analysis,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

VSFS

  • 1.Introduction
  • 2.Approach
    • 2.1.相关概念
    • 2.2.VSFS
  • 3.Evaluation
  • 参考文献

1.Introduction

上一篇blog我介绍了目前flow-sensitive pointer analysis常用的SFS算法。相比IFDS-based方法,SFS显著通过稀疏分析提升了效率,但是其内部依旧有许多冗余计算,留下了很大优化空间。

以下图为例,其内容展示的是基于Andersen计算的SVFG,当前Andersen分析的结果中 pts(p) = {o}, pts(q) = {a}, pts(r) = {b}。其中图中5个代码块分别对应2个 store 指令 l1: *p = ql2: *p = r 以及3个 load 指令 l3: x = *_l4: y = *_l5: z = *_。其中 l3, l4, l5 加载的指针都可能指向 o。图中存在value-flow edge包括: l 1 → o l 3 l_1 \stackrel{o}{\rightarrow} l_3 l1ol3 l 1 → o l 4 l_1 \stackrel{o}{\rightarrow} l_4 l1ol4 l 1 → o l 5 l_1 \stackrel{o}{\rightarrow} l_5 l1ol5 l 2 → o l 4 l_2 \stackrel{o}{\rightarrow} l_4 l2ol4 l 2 → o l 5 l_2 \stackrel{o}{\rightarrow} l_5 l2ol5 l 1 → o l 2 l_1 \stackrel{o}{\rightarrow} l_2 l1ol2

请添加图片描述

根据SFS算法,每个 store 指令需要IN和OUT集合保存incoming和outgoing pointer information,将address-taken variable映射为指向的address-taken variable集合。而 load 指令则需要一个IN集合。下图左上部分为SFS分析上图SVFG时涉及到的point-to map, p t l 1 ∣ ( o ) pt_{l_1|}(o) ptl1(o) 表示address-taken variable o o o l 1 l_1 l1 出口处的point-to map, p t ∣ l 2 ( o ) pt_{|l_2}(o) ptl2(o) o o o l 2 l_2 l2 入口处的point-to map。这里 l 1 l_1 l1 的出口处可直达 l 2 l_2 l2 出口处,不管怎么迭代多少轮, p t l 1 ∣ ( o ) pt_{l_1|}(o) ptl1(o) p t ∣ l 2 ( o ) pt_{|l_2}(o) ptl2(o) 的值恒等,因此可以合并到一起,不用多个map保存,其它的point-to map同理类似。

作者因此提出Versioned Staged Flow-Sensitive Pointer Analysis (VSFS),首先通过pre-analysis分析object的version,随后压缩point-to map数量,经过压缩后可将6个point-to map压缩到3个。

请添加图片描述
压缩后的point-to map会被赋予version id,可用来获取对应的point-to map,这里version k 1 k_1 k1 对应 l 1 l_1 l1 出口处和 l 2 l_2 l2, l 3 l_3 l3 入口处 o o o 的version。 k 1 ⋄ k 2 k_1 \diamond k_2 k1k2 表示合并 k 1 k_1 k1 k 2 k_2 k2 version的结果。

2.Approach

2.1.相关概念

定义:

  • C l ( o ) C_l(o) Cl(o),表示address-taken variable o o o 在指令 l l l 的入口处consume的version,返回的是version,也就是入口处version。

  • Y l ( o ) Y_l(o) Yl(o),表示address-taken variable o o o 在指令 l l l 的出口出yield的version,返回version。

一切point-to set都需要通过version访问,因此VSFS的分析过程满足下面关系:

  • C l ( o ) = C l ′ ( o ) ⇒ p t ∣ l ( o ) = p t ∣ l ′ ( o ) C_l(o) = C_{l^{'}}(o) \Rightarrow pt_{|l}(o) = pt_{|l^{'}}(o) Cl(o)=Cl(o)ptl(o)=ptl(o)

  • C l ( o ) = Y l ′ ( o ) ⇒ p t ∣ l ( o ) = p t l ′ ∣ ( o ) C_l(o) = Y_{l^{'}}(o) \Rightarrow pt_{|l}(o) = pt_{l^{'}|}(o) Cl(o)=Yl(o)ptl(o)=ptl(o)

  • Y l ( o ) = Y l ′ ( o ) ⇒ p t l ∣ ( o ) = p t l ′ ∣ ( o ) Y_l(o) = Y_{l^{'}}(o) \Rightarrow pt_{l|}(o) = pt_{l^{'}|}(o) Yl(o)=Yl(o)ptl(o)=ptl(o)

前面的示例中, Y l 1 ( o ) = C l 2 ( o ) = C l 3 ( o ) = k 1 Y_{l_1}(o) = C_{l_2}(o) = C_{l_3}(o) = k_1 Yl1(o)=Cl2(o)=Cl3(o)=k1,而 C l 4 ( o ) = C l 5 ( o ) = k 1 ⋄ k 2 C_{l_4}(o) = C_{l_5}(o) = k_1 \diamond k_2 Cl4(o)=Cl5(o)=k1k2,表示接受了来自version k 1 k_1 k1 k 2 k_2 k2 的信息。

version之间的运算满足下面定律

请添加图片描述

作者这里用unsigned interger来表示version。在LLVM IR中只有 store Φ \Phi Φ 指令可能生成新的version(store 是因为flow-sensitive分析之前无法确定该指令是否会修改对应address-taken variable的指向,因此保守认为会产生新的version, Φ \Phi Φ 指令则是进行合并操作产生新version。)

version分析可分为prelabel和meld 2个阶段,prelabel类似初始化,meld类似传播分析,prelabel之前每个指令(store, load 对应的version id都会被设置为 ε \varepsilon ε),prelabel对应的规则如下图所示:

  • n v ( o ) nv(o) nv(o) 表示给 Y l ( o ) Y_l(o) Yl(o) 分配新的version

  • p t a ( p ) pt^a(p) pta(p) 则是AUX(Andersen)分析的 p p p 的point-to map

  • δ ( l ) \delta(l) δ(l) 表示指令 l l l 要么是间接调用指令,或者是可能被间接调用的函数的入口指令,这里用到的是AUX分析出的间接调用结果(paper中给出的形式化描述有点晦涩难懂,看SVF代码分析的)。

请添加图片描述
Meld阶段对应的传播规则如下:

  • [ I N T E R N A L ] V [INTERNAL]^V [INTERNAL]V 对应的是非 store 指令内部的传播规则,即该指令IN和OUT处version一致。

  • [ E X T E R N A L ] V [EXTERNAL]^V [EXTERNAL]V 对应的是value-flow edge两端的指令之间的传播规则

请添加图片描述

2.2.VSFS

完整的传播规则如下图所示,红框中标出的为VSFS相比SFS改进的部分,传播过程的多了查询version的步骤。

请添加图片描述下面这张图是SFS中 store 指令的传播规则,其中的框则为VSFS规则中对应修改的部分:

请添加图片描述

3.Evaluation

作者用了15个open-source project,用clang-10与wllvm在 o3 level下将project编译为LLVM IR。

请添加图片描述
与SFS的性能对比如下图所示,论时间开销平均分析速度相比SFS快了5.31倍,最高加速达到26.22,论内存开销平均节省了2.11倍,最高节省了5.46倍。

请添加图片描述

参考文献

Barbar M, Sui Y, Chen S. Object versioning for flow-sensitive pointer analysis[C]//2021 IEEE/ACM International Symposium on Code Generation and Optimization (CGO). IEEE, 2021: 222-235.

这篇关于Versioned Staged Flow-Sensitive Pointer Analysis的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1143667

相关文章

GNSS CTS GNSS Start and Location Flow of Android15

目录 1. 本文概述2.CTS 测试3.Gnss Flow3.1 Gnss Start Flow3.2 Gnss Location Output Flow 1. 本文概述 本来是为了做Android 14 Gnss CTS 的相关环境的搭建和测试,然后在测试中遇到了一些问题,去寻找CTS源码(/cts/tests/tests/location/src/android/locat

Understanding the GitHub Flow

这里看下Github的入门介绍    --链接 GitHub Flow is a lightweight, branch-based workflow that supports teams and projects where deployments are made regularly. This guide explains how and why GitHub Flow works

pointer-events: auto; 是一个 CSS 属性,

pointer-events: auto; 是一个 CSS 属性,用于控制一个元素是否可以成为鼠标事件(如点击、悬停、拖动等)的目标。以下是对 pointer-events 属性及其值的详细解释: pointer-events 属性 定义: pointer-events 属性控制如何处理鼠标事件。它可以用于控制元素是否响应鼠标事件以及如何处理事件。 pointer-events: auto;

Salt Function Flow:深度解析复杂网关编排的优势与实践

系列文章索引: Salt Function Flow 系列文章 在业务流程编排中,处理条件逻辑、并行任务、以及复杂的流程分支是常见的挑战。对于需要高度灵活性和扩展性的项目,Salt Function Flow 提供了强大的网关编排能力,使开发者能够轻松定义和管理复杂的业务流程。本文将深入探讨Salt Function Flow中的复杂网关编排功能,展示其如何通过排他网关、并行执行等功能应对复杂的

Salt Function Flow 系列文章

Salt Function Flow 是一款Java开发、轻量级、内存级的业务流程编排框架,旨在帮助开发者通过函数式编程的方式定义和管理复杂的业务流程。它以高效、灵活的流程处理为核心,适用于多种业务场景,从简单任务自动化到复杂业务逻辑处理。 系列文章: Salt Function Flow:深度研发经验的沉淀,打造轻量级高效流程编排框架 Salt Function Flow:深度解析复杂网关编排

OpenCV_连通区域分析(Connected Component Analysis-Labeling)

申明:本文非笔者原创,原文转载自:http://blog.csdn.net/icvpr/article/details/10259577 OpenCV_连通区域分析(Connected Component Analysis/Labeling) 【摘要】 本文主要介绍在CVPR和图像处理领域中较为常用的一种图像区域(Blob)提取的方法——连通性分析法(连通区域标

Kotlin 流 Flow

挂起函数可以异步地返回一个值,而对于返回多个值,可以使用流,使用 emit(x) 发射多个值, collect { } 来收集值。 默认 流是冷的,只有 收集(collect) 时才会执行。 1. 流的创建 flow {} 生成流,emit(x) 来发射值;xxx.asFlow() 集合转成Flow;flowOf(1, 2, 3) 生成固定值的流。 1.1 flow {} flow {}

CSS-标准文档流(Normal Flow)

目录 1 定义2 脱离文档流3 相对定位文章参考 1 定义 文档流中:内联元素默认从左到右流,遇到阻碍或者宽度不够自动换行,继续按照从左到右的方式布局。块级元素单独占据一行,并按照从上到下的方式布局。 2 脱离文档流 文档一旦脱离文档流,则元素不再按照文档流的排列方式进行排列,如块级元素脱离文档流后,该块级元素不再接着上个元素从上到下排列,而是成为第一个元素,从顶部开始排列

Salt Function Flow:深度研发经验的沉淀,打造轻量级高效流程编排框架

在开发者的世界里,业务流程编排是一个既复杂又关键的环节。如何高效地管理和编排这些流程,直接影响着系统的性能和可维护性。本次介绍一款基于大量研发实践经验而打造的流程编排框架——Salt Function Flow。它不仅轻量、强大,更是将多年实践中的最佳经验沉淀于其中,为开发者提供了一套经过验证的可靠解决方案。 为什么选择Salt Function Flow? 深厚的研发积淀 Salt Fun

MATH36022 Numerical Analysis 2 Approximation of Functions – Week 3 Exercises

Show that the Chebyshev polynomials are orthogonal on ( − 1 , 1 ) (−1, 1) (−1,1) with respect to the weight function ( 1 − x 2 ) − 1 / 2 (1 − x^2)^{−1/2} (1−x2)−1/2. Ans: T n ( x ) = cos ⁡ ( n arcc