在linux下编译.pc文件(即应用了oracle的嵌入式数据库开发语言)过程有两步:
首先经过proc预处理把.pc文件编译成.c文件:
proc test.pc
这期间如果报错那么就是一些库文件和头文件没有包含进去。proc 常用参数选项说明:
(1)code:指出预编译处理所生成的c函数的格式当code= ANSI_C时,生成符合ANSI_C标准的函数原型参数:
extern sqlca(log*,void *);
当code=KR_C时生成如下格式的函数原型参数:
extern sqlca(/*_log*,void *_*/);
语法:code=ANSI_C|KR_C缺省值为KR_C。注:能在命令行里或程序上输入。
(2)DBMS:指定所用oracle数据库管理系统的版本。
语法:DBMS=NATIVE|v6|v7
缺省值:NATIVE。注:只能在命令行上输入。
(3)ERRORS:
指出编译程序时产生的错误信息是否发送到终端和清单文件。
语法:ERRORS=YES|NO,为YES时发送到终端和清单文件,为NO 时只发送到清单文件。
默认:YES。
注:能在程序和命令行上输入。
(4)INCLUDE:指定EXEC SQL INCLUDE 文件的目录路径,只适用于使用目录的操作系统。
语法:INCLUDE =PATH
(5)MODE:指定程序遵循的标准
语法:
MODE=ORACLE|ISO|ANSI.....还有其他标准。
(6)ONAME:指定输出文件:
语法:
ONAME=PATH+FILENAME
(7)LINES:指出预编译处理程序是否对输出文件加#line命令。
(8)INAME:指定输 入文件:
语法:
ONAME=PATH+FILENAME
预编译完后会产生相应的.c文件,接下来对.c文件进行编译:
这里使用gcc编译。
gcc编译的选项参数说明:
-c
只激活预处理,编译,和汇编,也就是他只把程序做成obj文件
例子用法:
gcc -c hello.c
他将生成.o的obj文件
-S
只激活预处理和编译,就是指把文件编译成为汇编代码。
例子用法
gcc -S hello.c
他将生成.s的汇编代码,你可以用文本编辑器察看
-E
只激活预处理,这个不生成文件,你需要把它重定向到一个输出文件里
面.
例子用法:
gcc -E hello.c > pianoapan.txt
gcc -E hello.c | more
慢慢看吧,一个hello word 也要与处理成800行的代码
-o
制定目标名称,缺省的时候,gcc 编译出来的文件是a.out,很难听,如果
你和我有同感,改掉它,哈哈
例子用法
gcc -o hello.exe hello.c (哦,windows用习惯了)
gcc -o hello.asm -S hello.c
-ansi
关闭gnu c中与ansi c不兼容的特性,激活ansi c的专有特性(包括禁止一
些asm inline typeof关键字,以及UNIX,vax等预处理宏,
-wall
显示警告信息
-fno-asm
此选项实现ansi选项的功能的一部分,它禁止将asm,inline和typeof用作
关键字。
-fno-strict-prototype
只对g++起作用,使用这个选项,g++将对不带参数的函数,都认为是没有显式
的对参数的个数和类型说明,而不是没有参数.
而gcc无论是否使用这个参数,都将对没有带参数的函数,认为城没有显式说
明的类型
-fthis-is-varialble
就是向传统c++看齐,可以使用this当一般变量使用.
-fcond-mismatch
允许条件表达式的第二和第三参数类型不匹配,表达式的值将为void类型
-funsigned-char
-fno-signed-char
-fsigned-char
-fno-unsigned-char
这四个参数是对char类型进行设置,决定将char类型设置成unsigned char(前
两个参数)或者 signed char(后两个参数)
-include file
包含某个代码,简单来说,就是便以某个文件,需要另一个文件的时候,就可以
用它设定,功能就相当于在代码中使用#include
例子用法:
gcc hello.c -include /root/pianopan.h
-imacros file
将file文件的宏,扩展到gcc/g++的输入文件,宏定义本身并不出现在输入文件
中
-Dmacro
相当于C语言中的#define macro
-Dmacro=defn
相当于C语言中的#define macro=defn
-Umacro
相当于C语言中的#undef macro
-undef
取消对任何非标准宏的定义
-Idir
在你是用#include"file"的时候,gcc/g++会先在当前目录查找你所制定的头
文件,如果没有找到,他回到缺省的头文件目录找,如果使用-I制定了目录,他
回先在你所制定的目录查找,然后再按常规的顺序去找.
对于#include,gcc/g++会到-I制定的目录查找,查找不到,然后将到系
统的缺省的头文件目录查找
-I-
就是取消前一个参数的功能,所以一般在-Idir之后使用
-idirafter dir
在-I的目录里面查找失败,讲到这个目录里面查找.
-iprefix prefix
-iwithprefix dir
一般一起使用,当-I的目录查找失败,会到prefix+dir下查找
-nostdinc
使编译器不再系统缺省的头文件目录里面找头文件,一般和-I联合使用,明确
限定头文件的位置
-nostdin C++
规定不在g++指定的标准路经中搜索,但仍在其他路径中搜索,.此选项在创建
libg++库使用
-C
在预处理的时候,不删除注释信息,一般和-E使用,有时候分析程序,用这个很
方便的
-M
生成文件关联的信息。包含目标文件所依赖的所有源代码
你可以用gcc -M hello.c来测试一下,很简单。
-MM
和上面的那个一样,但是它将忽略由#include造成的依赖关系。
-MD
和-M相同,但是输出将导入到.d的文件里面
-MMD
和-MM相同,但是输出将导入到.d的文件里面
-Wa,option
此选项传递option给汇编程序;如果option中间有逗号,就将option分成多个选
项,然后传递给会汇编程序
-Wl.option
此选项传递option给连接程序;如果option中间有逗号,就将option分成多个选
项,然后传递给会连接程序.
-llibrary
制定编译的时候使用的库
例子用法
gcc -lcurses hello.c
使用ncurses库编译程序
-Ldir
制定编译的时候,搜索库的路径。比如你自己的库,可以用它制定目录,不然
编译器将只在标准库的目录找。这个dir就是目录的名称。
-O0
-O1
-O2
-O3
编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最
高
-g
只是编译器,在编译的时候,产生条是信息。
-gstabs
此选项以stabs格式声称调试信息,但是不包括gdb调试信息.
-gstabs+
此选项以stabs格式声称调试信息,并且包含仅供gdb使用的额外调试信息.
-ggdb
此选项将尽可能的生成gdb的可以使用的调试信息.
这期间报错,是一些必要库文件和头文件没有链接上,只要把所需的东西链接上就OK了,下面一个MAKEIFLE文件显示整个编译过程:
#---------------------------------------------
# rules of making *.pc, DON'T change anytime !
.c.o:
$(CC) $*.c;
echo " $(CC) $*.c\n";
.pc.o:
$(PROC) iname=$*.pc
$(CC) $*.c
@rm $*.c
@rm *.lis
@echo " "
.SUFFIXES: .pc .c .o
#---------------------------------------------
OS=Linux
MACRO=TUXEDO
MACRO1=FUN
#PROCFLAGS = unsafe_null= yes dynamic=ansi mode=oracle dbms=v8 parse=full
PROCFLAGS = mode=oracle dbms=v8 unsafe_null=yes dynamic=ansi PARSE=none code=ansi_c lines=yes
CC = gcc $(INCL) -D$(OS) -D$(MACRO) -c *.c
PROC = proc $(INCL_PC) $(PROCFLAGS)
INCL = -I$(ORACLE_HOME)/precomp/public -I$(ORACLE_HOME)/rdbms/public
INCL_PC = include=$(ORACLE_HOME)/precomp/public \
include=$(ORACLE_HOME)/rdbms/public \
include=$(HOME)/incl
BIN = myprog
$(BIN):$(OBJS)
$(PROC) *.pc
$(CC) -o $(BIN)
@rm tp??????
@rm *.c
@rm *.lis
@echo " "
@echo " ==================MAKE [$(BIN)] SUCCESS!!=============="
附:查看GCC文档说明的好方法:
记得以前总有些朋友问怎么把manpage输出到一个文本文件
我现在找到了,可以这样做
man gcc | col -b > gcc.mantxt
希望能对部分朋友有些帮助
☆─────────────────────────────────────☆
stoneboy (Denise|石头哥) 于 (Fri Jul 28 09:02:42 2006) 提到:
呵呵, 用这个也不错
man -t gcc | ps2pdf - > gcc.pdf
【 在 fxl (小楼一夜听春雨) 的大作中提到: 】
: 记得以前总有些朋友问怎么把manpage输出到一个文本文件
: 我现在找到了,可以这样做
: man gcc | col -b > gcc.mantxt
分享到:
相关推荐
3. 编译过程中,系统会生成`.config`文件,记录用户在`menuconfig`中所做的选择。 通过以上步骤,我们可以定制一个符合特定需求的Linux内核。这个过程对于系统性能优化、添加特定硬件支持或修复内核问题至关重要。...
在给定的文件“linux-2.6.15.tar.gz”中,我们讨论的是Linux内核的一个特定版本——2.6.15。这个版本发布于2005年,是Linux发展史上的一个重要里程碑,带来了许多性能提升和功能增强。 首先,让我们了解一下`.tar....
交叉编译工具是必不可少的,因为它可以使开发者在PC机上编译出可以在MIPs架构的平台上运行的Linux系统和应用程序。交叉编译工具可以使开发者充分利用PC机的运算能力和丰富的工具,从而提高开发效率。 制作交叉编译...
在Linux环境下,通常使用x86架构的PC来编译ARM或其他架构的嵌入式设备上的程序。 二、交叉编译工具链 2. 工具链组成:交叉编译工具链包括了预处理器(cpp)、编译器(gcc)、链接器(ld)以及各种库文件,这些组件...
在Linux环境下,为PC机和ARM开发板编译并使用QT下的MySQL驱动涉及到多个步骤,主要是针对不同平台的编译配置。以下将详细介绍这些过程。 首先,对于PC机上特定版本的QT-x86下的MySQL驱动编译: 1. 安装MySQL驱动...
总结来说,这个资源是针对Linux开发环境的ARM交叉编译工具链,通过提供的setup.sh脚本,用户可以方便地在i686 PC上安装和配置好整个工具链,从而为ARM设备开发和编译软件。对于嵌入式系统开发者,尤其是那些需要在非...
"linux-2.6.34.15.tar.gz" 是一个包含Linux内核源代码的压缩文件,适用于学习和研究Linux内核的设计与实现。这个版本的内核在2010年发布,属于Linux 2.6系列,是Linux发展历史上的一个重要里程碑。 源码压缩文件的...
当我们在Linux上进行静态编译时,会使用到`pthread.libc.a`这样的静态库。静态库是一种将所有依赖的代码都包含在目标文件或可执行文件中的库,这意味着在运行程序时不需要额外的库文件。这种编译方式的好处是可移植...
wayland是Linux下的一套新的显示服务器协议,文档中提到了wayland相关组件的编译安装步骤。 8. 移动库文件 有时候需要将系统库文件移动到合适的位置,例如`mv /usr/lib/aarch64-linux-gnu/libwayland-*/opt/...
本文档详细介绍了如何在虚拟机Ubuntu 18.04下安装PowerPC系列的编译工具链,以及怎样进行编译uboot。下面是相关的知识点: 1. MPC8640D uboot 交叉编译环境搭建:本文档适用于 powerpc 系列 u-boot 代码编译,包括 ...
交叉编译允许我们在x86架构的PC上使用Linux系统和强大的编译工具,来构建能够在MIPS平台运行的Linux内核和应用程序。 **1. 交叉编译概念** 交叉编译是在一种架构(宿主机)上编译出可在另一种架构(目标机)上运行...
Linux内核编译是一个将源代码编译成可执行文件的过程,在这个过程中,开发者可以根据需要选择不同的配置选项来定制内核,以满足特定系统的要求。Linux 2.6.19.x内核作为一个较早期的稳定版本,其编译配置选项非常...
设备树源代码通常存储在`arch/powerpc/boot/dts`目录下,以`.dts`文件形式存在。例如,`mpc8313erdb.dts`文件描述了特定平台的硬件信息。 6. 设备树的编译与转换 `.dts`文件是文本格式,而引导时需要的是二进制的`....
【PowerPC平台Linux设备移植】涉及的是在Linux操作系统下,针对PowerPC处理器的嵌入式系统设备驱动的移植和配置过程。Linux因其开放源码、适应性强和高度可裁剪的特性,在嵌入式领域得到广泛应用。PowerPC处理器在...
在`linux-3.4`这个压缩包中,你可能会发现以下几类重要文件和目录: 1. **arch**:这是存放各种架构相关代码的目录,如x86、ARM、PowerPC等。每个架构都有自己的中断处理程序、处理器特定的系统调用实现和其他低级...
- **步骤6**:`make zImage`编译内核,生成zImage文件,存放在`/2410RP_linux/kernel/arch/arm/boot`目录下。 - **步骤7**:`make modules`编译模块驱动程序,包含在menuconfig中标记为的项。 5. **make ...
"arm-none-linux-gnueabi-i686-pc-linux-gnu.tar.bz2" 文件很可能就是这样的一个预配置好的交叉编译工具链,其中 "i686-pc-linux-gnu" 指的是宿主机平台(这里是 x86_64 PC,虽然 i686 表示的是 32 位,但这里可能也...
这个压缩包包含了预编译的二进制文件,可以直接在 CentOS 8 或类似系统中使用,无需编译源码。`tar.gz` 文件是一种常见的归档格式,可以通过 `tar` 命令解压。 描述中的 "centeos8测试可用, cp ./rg /usr/sbin/" ...
其中,交叉编译工具链是开发嵌入式Linux系统的核心工具,它允许开发者在PC上为嵌入式设备编译和构建代码。常用交叉编译工具包括arm-linux-gcc、mips-linux-gcc等。 三、Linux内核编译及配置 Linux内核是嵌入式Linux...
在压缩包子文件的文件名称列表中,我们只看到一个条目:"arm-2013.11-33-arm-none-linux-gnueabi-i686-pc-linux-gnu.tar.bz2",这与标题完全吻合,确认了压缩包中包含的就是这个交叉编译工具链的文件。 使用这样的...