当前位置: 首页 > news >正文

AI开发-python-langchain框架(--AI 直接生成并执行 Python 代码 )圃

指令替换

项目需求:将加法指令替换为减法

项目目录如下

/MyProject

├── CMakeLists.txt # CMake 配置文件

├── build/ #构建目录

│ └── test.c #测试编译代码

└── mypass2.cpp # pass 项目代码

一,测试代码示例

test.c

// test.c

#include

int my_add(int a, int b) {

return a + b;

}

int main() {

int x = 10;

int y = 20;

printf("Result: %d\n", my_add(x, y));

return 0;

}

二,编写Pass

其他的固定的模板之前文章注释有,这里我只注释当前项目重要的部分

代码流程: 遍历指令并匹配ADD指令->替换为sub指令

#include "llvm/IR/PassManager.h"

#include "llvm/Passes/PassBuilder.h"

#include "llvm/Passes/PassPlugin.h"

#include "llvm/Support/raw_ostream.h"

#include "llvm/IR/Function.h"

#include "llvm/IR/BasicBlock.h"

#include "llvm/IR/Instruction.h"

#include "llvm/IR/Instructions.h"

#include "llvm/IR/IRBuilder.h" // <--- 【新增】必须包含这个头文件!

using namespace llvm;

namespace {

struct mypass3 : public PassInfoMixin {

PreservedAnalyses run(Function &F, FunctionAnalysisManager &) {

errs() << "Analyzing Function: " << F.getName() << "\n";

bool changed = false;

//这里的2个循环获取的是遍历函数的指令(函数->代码块->指令)

for (BasicBlock &BB : F) {

for (Instruction &Inst : BB) {

]//判断当前的指令是ADD指令(加法)

if (Inst.getOpcode() == Instruction::Add) {

errs() << "Found ADD, changing to SUB...\n" << Inst << "\n";

//创建IR构建器

//在修改IR时需要用到构建器

IRBuilder<> builder(&Inst);

//这里时获取ADD的操作数:

//%add = add nsw i32 %0, %1中的%0和%1

Value *lhs = Inst.getOperand(0); // 左操作数

Value *rhs = Inst.getOperand(1); // 右操作数

//这里是构建新的指令:sub

//其中参数是:

//1:左操作数

//2:操作数

//3:返回的变量名,相当于:%add = add nsw i32 %0, %1中的%add

Value *newSub = builder.CreateSub(lhs, rhs, "new_sub");

//替换指令

Inst.replaceAllUsesWith(newSub);

errs() << "Replaced with SUB: \n" << *lhs << "\n" << *rhs << "\n" << *newSub << "\n";

changed = true;

}

}

}

if (changed) {

return PreservedAnalyses::none();

}

return PreservedAnalyses::all();

}

};

}

extern "C" LLVM_ATTRIBUTE_WEAK ::llvm::PassPluginLibraryInfo

llvmGetPassPluginInfo() {

return {

LLVM_PLUGIN_API_VERSION,

"mypass3",

"v0.1",

[](PassBuilder &PB) {

PB.registerPipelineParsingCallback(

[](StringRef Name, FunctionPassManager &FPM,

ArrayRef) {

if (Name == "mypass3") {

FPM.addPass(mypass3());

return true;

}

return false;

});

}};

}

三,Pass的构建

下面引用的是之前文章的内容

构建LLVM Pass需要写CMakeLists.txt构建声明

1. 配置CMake配置文件

CMakeLists.txt

下面的cmake配置可以直接拿去用,我已经标注好需要修改的位置

#cmake 版本,可通过 cmake --version 判断

cmake_minimum_required(VERSION 4.1.1) #---->修改 cmake版本号

#项目名字

project(mypass2) #---->修改 项目名称

#导入项目的 LLVM cmake 配置文件路径(如果根据我之前文章安装这里就相同)

set(LLVM_DIR "D:/LLVM/llvm-project/build/lib/cmake/llvm")#---->修改 llvm cmake配置路径

#寻找 LLVM 的包文件

#REQUIRED 找不到 LLVM 则停止构建

#强制使用 LLVM 安装时生成的配置文件进行定位

find_package(LLVM REQUIRED CONFIG)

#将 LLVM 的 CMake 模块路径添加到当前 CMake 搜索路径中,以便后续使用 include(AddLLVM)。

list(APPEND CMAKE_MODULE_PATH "${LLVM_CMAKE_DIR}")

#引入 LLVM 提供的专用 CMake 宏

include(AddLLVM)

#将 LLVM 的头文件目录(如 llvm/IR/Function.h)加入编译器的搜索路径

include_directories(${LLVM_INCLUDE_DIRS})

#导入 LLVM 编译时使用的宏定义

add_definitions(${LLVM_DEFINITIONS})

#设置 C++ 标准为 C++17。(这里如果不用17编译会报错)

set(CMAKE_CXX_STANDARD 17)

#强制要求必须支持 C++17,如果编译器不支持则失败。

set(CMAKE_CXX_STANDARD_REQUIRED ON)

#创建一个模块化的库(.dll)

add_library(mypass2 MODULE mypass2.cpp) #---->修改 项目名称,文件名

#windows不用会报错:导出符号

#LLVM Pass 需要暴露一些特定的入口点(如 getAnalysisUsage)给 opt 工具调用。

set_target_properties(mypass2 PROPERTIES WINDOWS_EXPORT_ALL_SYMBOLS ON) #---->修改 项目名称

# 指定该 Pass 需要链接的 LLVM 核心组件。

# LLVMCore: 提供 IR、Function、Module 等核心类。

# LLVMSupport: 提供各种辅助工具类(如 errs() 输出)。

target_link_libraries(mypass2 LLVMCore LLVMSupport) #---->修改 项目名称,文件名

# 为该目标设置特定的编译器选项。

# /utf-8: 告诉 MSVC 编译器使用 UTF-8 编码处理源代码,防止中文注释引起的乱码或编译错误。

target_compile_options(mypass2 PRIVATE /utf-8)#---->修改 项目名称,文件名

2.编译并构建Pass

打开visual studio的工作台,我这里是x64 Native Tools Command Prompt for VS 2022`

进到build目录

#构建项目

#其中-DCMAKE_BUILD_TYPE=RelWithDebInfo不选会报错,由于我之前编译的是带符号的relase版本

cmake -G "Ninja" -DCMAKE_BUILD_TYPE=RelWithDebInfo ..

#编译

ninja

最后出现下面提示,即为编译成功

[2/2] Linking CXX shared module mypass2.dll

四,使用当前的pass

进到build目录

#把.c文件编译为.ll

#-O1 使用O1优化(这里我尝试-O0不优化,会导致我的pass无法应用)

#-Xclang -disable-llvm-passes 不使用默认的pass优化

clang -S -emit-llvm -O1 -Xclang -disable-llvm-passes test.c -S -o test.ll

#使用pass

opt -load-pass-plugin=mypass2.dll -passes=mypass2 test.ll -S -o test_opt.ll

#编译使用pass后的exe

clang test_opt.ll -o test_opt.exe

#编译使用pass前的exe

clang test.ll -o test.exe

输出结果

运行test.exe:不使用pass,输出结果如下:

Result: 30

运行test_opt.exe:使用pass后,输出结果如下:

Result: -10祷艺率塘

http://www.jsqmd.com/news/632415/

相关文章:

  • 深蓝词库转换:跨平台输入法词库迁移实战指南
  • AI时代新型的项目管理应该是什么样的?驼
  • Phi-4-mini推理模型实战:用它来辅导孩子数学作业,效果惊艳!
  • 2026年评价高的污水泵/五二五污水泵/立式液下污水泵直销厂家推荐 - 品牌宣传支持者
  • 基于Retinaface+CurricularFace的实时视频人脸分析系统开发
  • GTE-Pro在政务知识库落地案例:本地化部署+意图识别双合规实践
  • C# 面试高频题:装箱和拆箱是如何影响性能的?菇
  • 为什么你的vLLM吞吐量比竞品低37%?,深度拆解基准测试套件中被忽略的3层时序对齐机制(含CUDA Graph级采样代码)
  • Windows福音:Qwen-Image-2512-ComfyUI中文图像生成,5步快速体验
  • 一次由拨码开关引发的香橙派AIPro“假死”排查记
  • 2026年评价高的电动三轮车锂电池/三轮车锂电池厂家推荐 - 行业平台推荐
  • 电子信息保研面试真题库:钢琴爱好竟成加分项?附5类必问专业课速记清单
  • GLM-OCR Python API调用详解:5行代码集成OCR能力到业务系统
  • BL0910直流计量模式怎么玩?从模式寄存器配置到锂电池充放电监控实战
  • 2026年评价高的广东中央空调设备回收/冲床设备回收/广东五金设备回收/设备回收品牌厂家推荐 - 行业平台推荐
  • 手把手教你用Docker部署Crawl4AI服务,打造一个随时可用的AI爬虫API
  • 程序员副业指南:高收入技术变现全攻略
  • 2026年Q2杭州写字楼租赁标杆名录:杭州办公楼出租、杭州商务楼租赁、杭州写字楼招租、杭州写字楼租赁选择指南 - 优质品牌商家
  • Kubernetes Pod 网络延迟分析
  • AI 时代,计算机专业学生该怎么学?柯
  • 从信号到系统:深入解析以太网PHY的硬件实现与接口协议
  • 【限时技术白皮书】全球首批通过MLPerf Inference v4.0弹性测试的6套扩缩容配置模板(含Qwen3-72B/Gemma3-27B实测参数)
  • 2026年4月无人机机库企业如何选,无人机自动巡检/室外无人机自动巡检/无人机机库,无人机机库生产厂家有哪些 - 品牌推荐师
  • 2026年质量好的卫生间防水修缮/外墙防水修缮/自建房防水修缮/江西外墙防水修缮推荐公司 - 品牌宣传支持者
  • Pixel Fashion Atelier惊艳案例:天空蓝×活力橙UI下生成的30套高纯度像素皮装
  • OpenClaw 太难装了?试试 LangTARS:一行命令部署 + WebUI 管理面板,还能接入 Dify/Coze/nn??剖
  • AudioSeal多场景落地:教育(AI讲题)、医疗(问诊合成)、法律(笔录生成)全覆盖
  • Langchain Agent实战避坑:用通义千问调用高德API,我踩过的异步和工具定义那些坑
  • AI Coding越来越强,我们还有必要学Processing吗? · 创意编程家
  • 2026成都借款纠纷技术分享:成都强奸猥亵律师事务所、成都律师事务所、成都房产纠纷律师事务所quot;、成都抚养权分割律师事务所选择指南 - 优质品牌商家