linux上交叉编译的方法

 

说明:本文档主要讲述将开源的软件移植到嵌入式平台上的方法。

linux上的开源软件如(fastdb,sqlite)等都是可以移植到嵌入式开发板上的。下面以fastdb为例进行介绍。

1.       搭建交叉编译平台

我们在linux环境下进行交叉编译,任何一个linux操作系统的发行版本都可以。笔者用的操作系统是fedora 8。

(1)    首先创建路径:mkdir /usr/local/arm

(2)    将中嵌公司提供的工具软件arm-2007q3.tar.bz2 拷贝到我们创建的目录中,并解压:

cp arm-2007q3.tar.bz2 /usr/local/arm/

cd /usr/local/arm

tar jxvf arm-2007q3.tar.bz2

(3)    修改环境变量PATH。通过修改文件/etc/profile,修改环境变量。

gedit /etc/profile

在该文件的末尾添加如下两行:

PATH=$PATH:/usr/local/arm/arm-2007q3/bin

export PATH

保存文件。

注销用户并重新登录后,新设置的环境变量方生效。

2.       进行交叉编译

下面我们进行fastdb的交叉编译。

(1)    将fastdb的源代码拷贝至/home路径下(该路径可以任意),并解压,然后进入解压后的路径。

cd /home

cp fastdb-9.4.tar.gz /home

tar zxvf fastdb-9.4.tar.gz

cd fastdb

(2)    交叉编译

./configure --host=arm-none-linux-gnueabi

make

该过程一般耗时较久(10分钟左右)。

3.       拷贝编译生成文件到嵌入式开发板

交叉编译后生成的可执行文件和动态库一般位于文件目录的src路径下。

对于fastdb来讲,生成的可执行文件位于/home/fastdb/src,该目录下可执行文件有四个:subsql, forcerecovery, cleanupsem, cgistub。将其拷贝至开发板的/usr/local/bin/路径下

(拷贝的方法可以通过我们集成开发环境中的telnet进行,也可以通过ftp进行拷贝,通过ftp拷贝的方法在本文后面进行介绍)。

fastdb生成的动态库文件位于/home/fastdb/src/.libs下。将文件libfastdb.so.2.0.0 拷贝至开发板的/usr/local/lib/路径下,并更名为libfastdb.so。

为了测试生成的文件是否可以执行,可以在开发板的系统中输入subsql指令,若出现类似如下提示,则证明移植成功。

[root@wusq .libs]# subsql

SubSQL interactive utility for FastDB v. 3.67

Type 'help' for more information

>> 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
概述FastDB是一个高效率的内存数据库系统,具有实时性能和方便的C++接口。 FastDB并不支持客户端/服务器结构,所有使用FastDB数据库的应用程序都必须运行在同一台主机上。FastDB为具有主导读取访问模式的应用程序作了优化。通过消除数据传输的开销和使用高性能的锁工具实现了查询执行的高速度。数据库文件和使用该数据库的每一个应用程序占用的虚拟内存空间相映射。所以查询在应用程序的任务中执行,不需要进行任务切换和数据传输。在FastDB中,通过原子指令来实现对数据库并发访问的同步,对查询处理几乎不增加任何开销。FastDB假设整个数据库都在当前内存中,并且在这个假设的基础上优化查询算法和结构。另外,数据库缓存管理几乎不会给FastDB增加任何开销,同时FastDB也不需要在数据库文件和缓冲池中进行数据传送。这就是为什么FastDB比将所有数据放在缓冲池中的传统数据库明显速度快的原因。   FastDB支持事务、在线备份和系统崩溃之后的自动恢复。事务提交协议基于一个影子根页算法,对数据库执行原子更新操作。恢复操作执行起来非常快,给关键应用程序提供了高效率。另外,它还取消了事务日志,提高了系统的整体性能,并且能够更加有效地使用系统资源。   FastDB是面向应用程序的数据库,使用应用程序的类信息来构建数据库的表。FastDB支持自动系统赋值,只允许你在一个地方——你的应用程序的类中,改变它们的值。FastDB为从数据库中提取数据提供了一个灵活而方便的接口。使用类似于SQL的语言来书写查询语句。这些非原子字段、嵌套数组、用户自定义类型和方法、直接指向对象内部的指针等后关系性能,简化了数据库应用程序的设计,并且使得它们更加高效。   虽然FastDB的优化是基于整个数据库都存放在机器的物理内存的这个假设上的,我们依然可以将FastDB使用在那些大小超过系统物理内存的数据库上。最后,标准操作系统的交换机制将会起作用。但是所有的FastDB的算法和结构的优化都是基于数据存放在内存中这个假设上的,所以数据交换的效率不会很高。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值