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

AI 时代:祛魅、适应与重新定义杂

指令替换项目需求将加法指令替换为减法项目目录如下/MyProject├── CMakeLists.txt # CMake 配置文件├── build/ #构建目录│ └── test.c #测试编译代码└── mypass2.cpp # pass 项目代码一测试代码示例test.c// test.c#includeint 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和%1Value *lhs Inst.getOperand(0); // 左操作数Value *rhs Inst.getOperand(1); // 右操作数//这里是构建新的指令sub//其中参数是//1左操作数//2操作数//3返回的变量名相当于%add add nsw i32 %0, %1中的%addValue *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::PassPluginLibraryInfollvmGetPassPluginInfo() {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 标准为 C17。(这里如果不用17编译会报错)set(CMAKE_CXX_STANDARD 17)#强制要求必须支持 C17如果编译器不支持则失败。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_TYPERelWithDebInfo不选会报错由于我之前编译的是带符号的relase版本cmake -G Ninja -DCMAKE_BUILD_TYPERelWithDebInfo ..#编译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#使用passopt -load-pass-pluginmypass2.dll -passesmypass2 test.ll -S -o test_opt.ll#编译使用pass后的execlang test_opt.ll -o test_opt.exe#编译使用pass前的execlang test.ll -o test.exe输出结果运行test.exe不使用pass输出结果如下Result: 30运行test_opt.exe使用pass后输出结果如下Result: -10咽安橙潘

相关文章:

AI 时代:祛魅、适应与重新定义杂

指令替换 项目需求:将加法指令替换为减法 项目目录如下 /MyProject ├── CMakeLists.txt # CMake 配置文件 ├── build/ #构建目录 │ └── test.c #测试编译代码 └── mypass2.cpp # pass 项目代码 一,测试代码示例 test.c // test.c #includ…...

.NET源码生成器基于partial范式开发和nuget打包臼

1 安装与初始化 # 全局安装 OpenSpec npm install -g fission-ai/openspeclatest # 在项目目录下初始化 cd /path/to/your-project openspec init 初始化时,OpenSpec 会提示你选择使用的 AI 工具(Claude Code、Cursor、Trae、Qoder 等)。 3 O…...

三分钟掌握Real-ESRGAN-ncnn-vulkan:让模糊图片瞬间高清的专业工具

三分钟掌握Real-ESRGAN-ncnn-vulkan:让模糊图片瞬间高清的专业工具 【免费下载链接】Real-ESRGAN-ncnn-vulkan NCNN implementation of Real-ESRGAN. Real-ESRGAN aims at developing Practical Algorithms for General Image Restoration. 项目地址: https://git…...

Cursor AI编程实战:用SSH远程开发+图片问答功能快速调试OpenWRT项目

Cursor AI编程实战:SSH远程开发与图片问答在OpenWRT项目中的高效应用 当你在凌晨三点调试OpenWRT路由器时,突然遇到一个诡异的网络丢包问题,传统方式可能需要反复修改配置、重启设备、查看日志——这个过程往往令人崩溃。但现在,A…...

别再只用默认画法了!用MediaPipe玩转自定义姿态估计可视化(Python实战)

突破MediaPipe可视化限制:打造个性化姿态估计渲染引擎 你是否厌倦了MediaPipe默认的蓝色骨架和固定连接方式?当我们需要在演示文稿、艺术项目或专业分析中使用姿态估计可视化时,标准输出往往显得单调乏味。实际上,MediaPipe提供的…...

想知道如何清理Ubuntu系统,以释放磁盘空间

磁盘占用到了75%,是时候做个大扫除了。别担心,这个占用率虽然不算紧急,但已经是很好的清理时机了。 我为你整理了一份从最安全快速到更彻底的清理步骤指南,你可以按顺序一步步操作,效果会很明显。 💡 清理第…...

2026年怎么部署OpenClaw?2分钟云端保姆级搭建及百炼Coding Plan指南

2026年怎么部署OpenClaw?2分钟云端保姆级搭建及百炼Coding Plan指南。本文面向零基础用户,完整说明在轻量服务器与本地Windows11、macOS、Linux系统中部署OpenClaw(Clawdbot)的流程,包含环境配置、服务启动、Skills集成…...

免费NTFS读写终极指南:三分钟让Mac完美支持Windows硬盘

免费NTFS读写终极指南:三分钟让Mac完美支持Windows硬盘 【免费下载链接】Free-NTFS-for-Mac Nigate: An open-source NTFS utility for Mac. It supports all Mac models (Intel and Apple Silicon), providing full read-write access, mounting, and management f…...

Hotkey Detective:5步解决Windows热键冲突的终极指南

Hotkey Detective:5步解决Windows热键冲突的终极指南 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 你是否曾经…...

Qt网格布局实战:从入门到精通

1. Qt网格布局基础入门 第一次接触Qt网格布局时,我完全被它的灵活性震惊了。想象一下Excel表格,每个单元格可以自由合并拆分,这就是QGridLayout给我的直观感受。作为Qt中最强大的布局管理器之一,它能够将界面元素精准地放置在网格…...

从汽车诊断到机器人:手把手教你用Wireshark抓包分析SocketCAN数据

从汽车诊断到机器人:用Wireshark解密SocketCAN的高级逆向工程 当面对CAN总线上汹涌而来的十六进制数据流时,大多数工程师的第一反应是打开candump工具。但很快,屏幕上滚动如瀑布般的原始帧会让任何人感到窒息——就像试图用吸管喝干消防水龙带…...

从Matterport3D看室内三维重建:它如何帮我们训练更好的表面法线估计模型?

Matterport3D数据集如何革新表面法线估计模型的训练范式 当你在昏暗的灯光下试图分辨墙面的细微纹理时,人类视觉系统会不自觉地通过光影变化来推断表面朝向——这种对法线方向的感知能力,正是计算机视觉中表面法线估计任务试图复制的核心功能。而在算法训…...

OpenArk:当Windows系统变得神秘莫测时,你的终极诊断工具箱

OpenArk:当Windows系统变得神秘莫测时,你的终极诊断工具箱 【免费下载链接】OpenArk The Next Generation of Anti-Rookit(ARK) tool for Windows. 项目地址: https://gitcode.com/GitHub_Trending/op/OpenArk 你是否曾经遇到过这样的困扰&#x…...

Onekey Steam Depot清单下载器:三步快速获取游戏清单的完整指南

Onekey Steam Depot清单下载器:三步快速获取游戏清单的完整指南 【免费下载链接】Onekey Onekey Steam Depot Manifest Downloader 项目地址: https://gitcode.com/gh_mirrors/one/Onekey 还在为Steam游戏清单的复杂获取流程而烦恼吗?Onekey Stea…...

Phi-3-mini-4k-instruct-gguf企业落地:ERP系统嵌入式智能搜索与字段解释生成

Phi-3-mini-4k-instruct-gguf企业落地:ERP系统嵌入式智能搜索与字段解释生成 1. 企业ERP系统的智能化挑战 现代企业ERP系统往往包含数千个数据字段和复杂业务流程,员工在使用过程中面临两大核心痛点: 字段理解困难:系统中有大量…...

零基础小白也能用!GLM-OCR专业文档识别保姆级入门教程

零基础小白也能用!GLM-OCR专业文档识别保姆级入门教程 你是不是也遇到过这样的烦恼?手头有一堆纸质文件、扫描件或者截图,想把里面的文字、表格、公式提取出来,却只能一个字一个字地敲键盘?或者用那些免费的OCR工具&a…...

SDMatte与Python爬虫结合实战:自动化素材采集与背景抠图

SDMatte与Python爬虫结合实战:自动化素材采集与背景抠图 1. 场景痛点与解决方案 电商运营和内容创作者每天都要处理大量图片素材——商品主图需要统一白底、社交媒体配图要去除杂乱背景、广告海报要精准抠图。传统工作流程存在三大痛点: 素材获取效率…...

Wan2.2-I2V-A14B提示词库建设:构建可复用的高质量视频生成模板

Wan2.2-I2V-A14B提示词库建设:构建可复用的高质量视频生成模板 1. 为什么需要系统化的提示词库 视频生成领域有个常见现象:同样的模型,不同人使用效果天差地别。关键差异往往就在于提示词的质量。我们团队在使用Wan2.2-I2V-A14B模型时发现&…...

终极游戏模组管理指南:如何用Nexus Mods App告别模组冲突烦恼

终极游戏模组管理指南:如何用Nexus Mods App告别模组冲突烦恼 【免费下载链接】NexusMods.App Home of the development of the Nexus Mods App 项目地址: https://gitcode.com/gh_mirrors/ne/NexusMods.App 你是否曾在《赛博朋克2077》中因为模组冲突而反复…...

c# 文件编译的过程

两次编译的过程:整个流程的核心思路是:.NET 用两次编译把"写代码"和"跑代码"这两件事解耦开来。第一次编译:源码 → IL(开发时完成)你写的 C# 代码(.cs 文件)通过 csc.exe …...

进阶与总结:成为核心贡献者的路径、开源伦理与专栏知识体系复盘

进阶与总结:成为核心贡献者的路径、开源伦理与专栏知识体系复盘 从一次深夜提交被拒说起 上周三凌晨两点,我给一个嵌入式RTOS项目提交了优化中断延迟的补丁。邮件列表三小时后回复:“代码逻辑没问题,但破坏了ARM Cortex-M3的上下文对齐约定,请重新阅读porting guide第4.…...

3分钟解锁纯净音乐:免费实现Spotify广告拦截的完整指南

3分钟解锁纯净音乐:免费实现Spotify广告拦截的完整指南 【免费下载链接】BlockTheSpot Video, audio & banner adblock/skip for Spotify 项目地址: https://gitcode.com/gh_mirrors/bl/BlockTheSpot 你是否厌倦了在享受音乐时被突如其来的广告打断&…...

提交艺术:编写规范的Commit Message与创建高质量的Pull Request

提交艺术:编写规范的Commit Message与创建高质量的Pull Request 从一次痛苦的代码回溯说起 上周排查一个线上闪退问题,git log 拉出来一看,满屏的“fix bug”“update”“优化代码”这类提交信息。为了定位引入问题的变更,我们不得不逐个点开提交看diff,花了近两个小时才…...

协作与迭代:当Code Review意见砸过来,CI流水线又红了

协作与迭代:当Code Review意见砸过来,CI流水线又红了 上周三深夜,我在仓库里提交了一段SPI驱动优化代码。自觉逻辑清晰,性能提升明显,满心等着合入。第二天一早,企业微信弹出三条Code Review通知,紧接着CI流水线标红——一个隐蔽的时序bug在QEMU仿真里被逮了出来。这场…...

OpenWrt上Asterisk依赖包全解析:解决SIP通话无声问题的完整配置清单

OpenWrt上Asterisk依赖包全解析:解决SIP通话无声问题的完整配置清单 在家庭或小型办公室环境中搭建内网VOIP系统时,OpenWrt与Asterisk的组合堪称黄金搭档。但许多开发者在编译安装过程中常被依赖包缺失和SIP通话无声问题困扰。本文将深入剖析这些技术难题…...

LoFTR:当Transformer遇见无检测器特征匹配——从全局感受野到像素级对齐的革新之路

1. LoFTR算法为何掀起特征匹配革命? 第一次接触LoFTR是在处理一组室内装修效果图匹配时,当时用传统方法在纯色墙面区域死活得不到理想结果。直到尝试了这个基于Transformer的方案,才明白无检测器设计为何被称为特征匹配领域的"范式转移&…...

CODESYS定时器进阶:从标准功能到高效自定义应用

1. IEC标准定时器深度解析 在工业自动化领域,定时器就像是我们日常生活中的闹钟,只不过它控制的不是起床时间,而是各种设备的启停顺序。CODESYS作为主流的PLC编程环境,提供了三种符合IEC61131-3标准的定时器功能块,它们…...

Delphi XE跨平台开发实战:Linux服务端应用构建指南

1. 为什么选择Delphi XE开发Linux服务端应用 作为一个在Windows平台深耕多年的Delphi开发者,当我第一次听说Delphi XE支持Linux开发时,内心是充满怀疑的。毕竟Linux开发环境向来以命令行和开源工具链著称,而Delphi给我的印象一直是可视化开发…...

2026届毕业生推荐的五大AI写作网站实际效果

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 使AIGC(人工智能生成内容)检测率得以降低的关键核心之所在&#xff0…...

SDMatte效果对比:与传统方法及在线工具的精度与速度测评

SDMatte效果对比:与传统方法及在线工具的精度与速度测评 1. 开篇:抠图技术的革新时刻 抠图技术正经历一场革命性变革。传统方法要么耗时费力,要么效果欠佳,而新兴的AI解决方案正在改写游戏规则。SDMatte作为开源模型代表&#x…...