CUDA Hook 项目教程
2024-09-25 18:59:50作者:俞予舒Fleming
1. 项目介绍
CUDA Hook 是一个开源项目,旨在通过自动化代码生成工具来钩取与 CUDA 相关的动态库。该项目基于 CUDA 原生头文件,自动生成钩取 CUDA API 的代码,具有极高的实用性和可扩展性。目前,该项目已经完成了对 CUDA 驱动、NVML、CUDA 运行时、cuDNN、cuBLAS、cuBLASLt、cuFFT、NVTX、NVRTC、cuRAND、cuSPARSE、cuSOLVER、NVJPEG 和 NVBLAS 等动态库的钩取,并且可以轻松扩展到其他 CUDA 动态库的钩取。
2. 项目快速启动
2.1 环境准备
- 操作系统: Linux
- CMake 版本: >= 3.12
- GCC 版本: >= 4.8
- CUDA 版本: 11.4 (最佳)
- CUDA 驱动版本: 470.129.06 (最佳)
- cuDNN 版本: 7.6.5 (最佳)
2.2 克隆项目
git clone https://github.com/Bruce-Lee-LY/cuda_hook.git
cd cuda_hook
2.3 构建项目
根据不同的 GPU 型号,选择相应的构建命令:
GTX 1080 Ti
./build.sh -a 61 -t Release -s ON -b OFF
./build.sh -a 61 -t Debug -s OFF -b ON
Tesla V100
./build.sh -a 70 -t Release -s ON -b OFF
./build.sh -a 70 -t Debug -s OFF -b ON
RTX 2080 Ti
./build.sh -a 75 -t Release -s ON -b OFF
./build.sh -a 75 -t Debug -s OFF -b ON
NVIDIA A100
./build.sh -a 80 -t Release -s ON -b OFF
./build.sh -a 80 -t Debug -s OFF -b ON
RTX 3080 Ti / RTX 3090 / RTX A6000
./build.sh -a 86 -t Release -s ON -b OFF
./build.sh -a 86 -t Debug -s OFF -b ON
2.4 运行示例
./run_sample.sh
3. 应用案例和最佳实践
3.1 应用案例
CUDA Hook 可以用于以下场景:
- 性能分析: 通过钩取 CUDA API,可以实时监控和分析 CUDA 程序的性能瓶颈。
- 调试: 在 CUDA 程序中插入自定义逻辑,帮助调试和定位问题。
- 动态库替换: 通过钩取 CUDA 动态库,可以实现动态库的替换和扩展。
3.2 最佳实践
- 自动化代码生成: 使用
tools/code_generate
目录下的工具,自动生成钩取 CUDA API 的代码。 - 扩展支持: 根据项目需求,扩展对其他 CUDA 动态库的钩取支持。
4. 典型生态项目
- NVIDIA CUDA Toolkit: 提供 CUDA 编程的核心库和工具。
- cuDNN: 深度学习库,提供高性能的神经网络操作。
- cuBLAS: 线性代数库,提供高性能的矩阵和向量操作。
- cuFFT: 快速傅里叶变换库,提供高性能的 FFT 操作。
- NVTX: NVIDIA Tools Extension,用于性能分析和调试。
通过 CUDA Hook,可以更好地集成和扩展这些生态项目,提升 CUDA 程序的开发和调试效率。
热门项目推荐
相关项目推荐
鸿蒙开发工具大赶集
本仓将收集和展示鸿蒙开发工具,欢迎大家踊跃投稿。通过pr附上您的工具介绍和使用指南,并加上工具对应的链接,通过的工具将会成功上架到我们社区。012hertz
Go 微服务 HTTP 框架,具有高易用性、高性能、高扩展性等特点。Go01每日精选项目
🔥🔥 每日精选已经升级为:【行业动态】,快去首页看看吧,后续都在【首页 - 行业动态】内更新,多条更新哦~🔥🔥 每日推荐行业内最新、增长最快的项目,快速了解行业最新热门项目动态~~029kitex
Go 微服务 RPC 框架,具有高性能、强可扩展的特点。Go00Cangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。Cangjie057毕方Talon工具
本工具是一个端到端的工具,用于项目的生成IR并自动进行缺陷检测。Python040PDFMathTranslate
PDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服务,提供 CLI/GUI/DockerPython06mybatis-plus
mybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com 低代码组件库 http://aizuda.comJava03国产编程语言蓝皮书
《国产编程语言蓝皮书》-编委会工作区018- DDeepSeek-R1探索新一代推理模型,DeepSeek-R1系列以大规模强化学习为基础,实现自主推理,表现卓越,推理行为强大且独特。开源共享,助力研究社区深入探索LLM推理能力,推动行业发展。【此简介由AI生成】Python00
热门内容推荐
最新内容推荐
项目优选
收起

Python - 100天从新手到大师
Python
611
115

本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
286
79

✍ WeChat Markdown Editor | 一款高度简洁的微信 Markdown 编辑器:支持 Markdown 语法、色盘取色、多图上传、一键下载文档、自定义 CSS 样式、一键重置等特性
Vue
112
25

旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
60
48

🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
45
29

🦄🦄🦄AI赋能股票分析:自选股行情获取,成本盈亏展示,涨跌报警推送,市场整体/个股情绪分析,K线技术指标分析等。数据全部保留在本地。支持DeepSeek,OpenAI, Ollama,LMStudio,AnythingLLM,硅基流动,火山方舟,阿里云百炼等平台或模型。
Go
1
0

本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
205
57

前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。
官网地址:https://matechat.gitcode.com
383
36

🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
182
44

这是一个人工生命试验项目,最终目标是创建“有自我意识表现”的模拟生命体。
Java
8
0