C程序编译与CUDA编译
2017-10-16 15:40
218 查看
1,C编译流程
预处理(Preprocessing)
展开宏,添加引用的文件,去除不影响程序执行的语句
gcc
-E hello.c
-o hello.i
编译(Compilation)
将预处理后的文件转化为汇编代码(包括优化)
gcc -S
hello.i -o
hello.s
汇编(Assembly)
将汇编代码转化为机器码
gcc
-c hello.c
-o hello.o
链接(Linking)
调用链接器ld链接运行程序需要一些目标文件
gcc
-o hello
hello.c -L./addlib
-ladd
2,编译选项
-shared :指定生成动态链接库。
-static :指定生成静态链接库。
-fPIC :表示编译为位置独立的代码,用于编译共享库。目标文件需要创建成位置无关码,念上就是在可执行程序装载它们的时候,它们可以放在可执行程序的内存里的任何地方。
-L. :表示要连接的库所在的目录。
-l:指定链接时需要的动态库。编译器查找动态连接库时有隐含的命名规则,即在给出的名字前面加上lib,后面加上.a/.so来确定库的名称。
-Wall :生成所有警告信息。
-ggdb :此选项将尽可能的生成gdb的可以使用的调试信息。
-g :编译器在编译的时候产生调试信息。
-c :只激活预处理、编译和汇编,也就是把程序做成目标文件(.o文件)。
-Wl,options :把参数(options)传递给链接器ld。如果options中间有逗号,就将options分成多个选项,然后传递给链接程序。
3,CUDA编译流程
nvcc编译器会将cudaApp.cu的内容分为主机端和设备端进行不同的处理:
设备端:通过nvcc对设备端代码进行编译产生kernel.ptx文件(微码文件),在通过ptxas将微码编译为kernel.cubin文件
主机端:将调用设备端的代码转化为c代码,加上kernel.cubin文件一起由主机端的编译器进行编译。
预处理(Preprocessing)
展开宏,添加引用的文件,去除不影响程序执行的语句
gcc
-E hello.c
-o hello.i
编译(Compilation)
将预处理后的文件转化为汇编代码(包括优化)
gcc -S
hello.i -o
hello.s
汇编(Assembly)
将汇编代码转化为机器码
gcc
-c hello.c
-o hello.o
链接(Linking)
调用链接器ld链接运行程序需要一些目标文件
gcc
-o hello
hello.c -L./addlib
-ladd
2,编译选项
-shared :指定生成动态链接库。
-static :指定生成静态链接库。
-fPIC :表示编译为位置独立的代码,用于编译共享库。目标文件需要创建成位置无关码,念上就是在可执行程序装载它们的时候,它们可以放在可执行程序的内存里的任何地方。
-L. :表示要连接的库所在的目录。
-l:指定链接时需要的动态库。编译器查找动态连接库时有隐含的命名规则,即在给出的名字前面加上lib,后面加上.a/.so来确定库的名称。
-Wall :生成所有警告信息。
-ggdb :此选项将尽可能的生成gdb的可以使用的调试信息。
-g :编译器在编译的时候产生调试信息。
-c :只激活预处理、编译和汇编,也就是把程序做成目标文件(.o文件)。
-Wl,options :把参数(options)传递给链接器ld。如果options中间有逗号,就将options分成多个选项,然后传递给链接程序。
3,CUDA编译流程
nvcc编译器会将cudaApp.cu的内容分为主机端和设备端进行不同的处理:
设备端:通过nvcc对设备端代码进行编译产生kernel.ptx文件(微码文件),在通过ptxas将微码编译为kernel.cubin文件
主机端:将调用设备端的代码转化为c代码,加上kernel.cubin文件一起由主机端的编译器进行编译。
相关文章推荐
- cuda程序的编译运行
- Makefile(1)编写简单的makefile批量编译CUDA程序
- 如何在多个CUDA版本之间自由切换、编译程序
- 在编译CUDA程序时出现 fatal error C1083: 无法打开包括文件:“cutil.h”: No such file or directory 的问题
- Mac中用clang++和nvcc编译cuda程序的一个例子
- 基于 cuda aware 的多节点 多显卡程序编译
- CUDA的MFC程序框架中编译出现nafxcw.lib与LIBCMT.lib链接重定义的解决
- MPI+CUDA混合程序的编译命令
- CUDA程序编译过程中产生警告的解决方法
- 在MAC OS X 10.9下编译CUDA 5.5例子程序出错解决方案
- NVCC 分歩 编译 CUDA 程序
- NSight Eclipse Edition 下创建CUDA程序并执行远程编译及调试
- cuda8.0使用nvcc编译程序出现warning:The 'compute_20', 'sm_20', and 'sm_21' architectures are deprecated的解决办法
- 编译和调试CUDA程序
- visual studio 2013 编译第一个cuda 6.5程序
- 用Cmake 编译cuda程序
- cuda程序编译出错: skipping incompatible /usr/lib/gcc/x86_64-redhat-linux/4.8.5
- cuda程序的编译运行
- Ubuntu平台下,apktool反编译android程序
- 减小vc编译程序的体积