View source for Toolchain/zh cn
From Openmoko
You do not have permission to edit this page, for the following reasons:
You can view and copy the source of this page:
Template used on this page:
Return to Toolchain/zh cn.
You do not have permission to edit this page, for the following reasons:
You can view and copy the source of this page:
Template used on this page:
Return to Toolchain/zh cn.
Languages: |
English • العربية • Български • Česky • Dansk • Deutsch • Esperanto • Eesti • Español • فارسی • Suomi • Français • עברית • Magyar • Italiano • 한국어 • Nederlands • Norsk (bokmål) • Polski • Português • Română • Русский • Svenska • Slovenčina • Українська • 中文(中国大陆) • 中文(台灣) • Euskara • Català |
工具链是一组用来编译代码的工具集。OpenMoko有两类不同用途的工具链:
针对这个用途,你应该可以使用针对Openmoko项目所预先建立好的toolchain。在这里你可以找到如何使用toolchain的方法,带领你进入编译项目的一连串程序,并且让程序能顺利的在你的手持式装置上执行。你应该听过 OpenEmbedded,身为一个程序开发人员,你应该’’’不要’’’使用OpenEmbedded。
针对系统整合及客制化套件,在ootstrapping/build process时,你应该使用OpenEmbedded来建立cross compiler。系统整合及套件客制化整合等问题,超过本文章所要讨论的问题,因此在此不加以讨论。
熟悉Linux 及其基本的指令工具是最基本的,你必须有x86兼容,至少1G的磁盘空间。你也必须要有使用本机编译器来编译原始码的相关操作经验。在此,提醒您,本篇文章是假设你有存取/home及/usr/local/ 目录的权限 (有需要时,需成为root)。如果你没有上述的权限,请与你的管理人员连络。
你至少应该能使用安装程序的权限,允许你使用autotools编译软件包。(the triade of ./configure, make, make install).
需要安装的软件—有需要请加入以下 的套件:
sudo apt-get install gcc g++ autoconf automake binutils libtool libglib2.0-dev ccache libxrender-dev intltool
toolchain 可以自 [downloads.openmoko.org]下载:
mkdir ~/sources cd ~/sources
wget http://downloads.openmoko.org/toolchains/openmoko-x86_64-arm-linux-gnueabi-toolchain.tar.bz2 or wget http://downloads.openmoko.org/toolchains/openmoko-i686-arm-linux-gnueabi-toolchain.tar.bz2
接着,你想要将它解压缩到档案系统时,toolchain 它必须安装到/usr/local/openmoko/.
现在,你有以下的选项:
cd / tar -xjvf ~/sources/openmoko-XYZ-arm-linux-gnueabi-toolchain.tar.bz2
bunzip2 openmoko-x86_64-arm-linux-gnueabi-toolchain.tar.bz2 gzip openmoko-x86_64-arm-linux-gnueabi-toolchain.tar fakeroot alien -d openmoko-x86_64-arm-linux-gnueabi-toolchain.tar.gz
bitbake meta-toolchain-openmoko
最后,每次你想要使用这个工具时,必须改变环境变量,这样才会找到要用的工具。Toolchain提供了script进行这项工作,因此你必须做的事只是取得它。
请注意,如果你并没有使用"sh" 或"bash" shell (用"echo $SHELL" 查看) ,那你必须先从"sh" 或"bash"开始。
. /usr/local/openmoko/arm/setup-env
在选定的目标目录地址中 (在本范例中为~/):
cp -r /usr/local/openmoko/source/openmoko-sample2 ~/
. /usr/local/openmoko/arm/setup-env
om-conf openmoko-sample2
cd openmoko-sample2 make
如果你希望在主机上安装这个项目,你可以利用下面的操作,将它安装到一个现有的设定中:
om-conf --prefix=/usr/local/openmoko openmoko-sample2 cd openmoko-sample2 make install
为了要使用Openmoko-sample2 档案来制作你自己的项目,某些变更是必须的: * 复制下载的范例应用程序: cp -r /usr/local/openmoko/source/openmoko-sample2 ~/
mv openmoko-sample2 your-project-name cd your-project-name cd src rm *.c
cp your-sources . cd ..
PKG_NAME="your-project-name"
AC_INIT(your-project-main, 0.0.1, http://www.openmoko.org/) AC_CONFIG_SRCDIR(src/main.c)
cd data mv openmoko-sample.png your-project-name.png mv openmoko-sample.desktop your-project-name.desktop
dist_desktop_DATA = your-project-name.desktop dist_appicon_DATA = your-project-name.png
dist_desktop_DATA = smart-search.desktop dist_appicon_DATA = smart-search.png
Name=your-project-name Encoding=UTF-8 Version=0.0.1 Type=Application Exec=your-project-name
Icon=your-project-name
cd .. cd src
bin_PROGRAMS = your-project-name your_project_name_SOURCES = \ main.c your_project_name_LDADD = @DEPENDENCIES_LIBS@
我们已经加入了一个script在你的应用程序外制作了ipkg 。请注意这并不是要在Neo上测试你的应用程序 ( 若你要测试应用程序,你只要使用SCP产出的二进制代码及数据),它对于想你将你的软件发布给其它人而言,相当方便。
om-make-ipkg openmoko-sample2
现在你已经取得了openmoko-sample2_0.1_armv4t.ipk ,你可以将它`scp' 到你的Neo,并且安装它。
scp openmoko-sample2_0.1_armv4t.ipk root@192.168.0.202: ssh root@192.168.0.202 ipkg install openmoko-sample2_0.1_armv4t.ipk
请注意当你重新发布产生的ipkg ,请注意它只是一个有更多信息的ipk骨架,若你无法取得链接库的独立性。查看下面的内容来暸解如何修复这个问题。 你也可以在控制档中提出这个版本的编号,描述及作者/连络方式。
om-make-ipkg myapp myapp_control
myapp_control的范本:
Package: $appname Version: 0.1 Description: package built by openmoko toolchain Section: openmoko/applications Priority: optional Maintainer: $USER Architecture: armv4t Homepage: http://www.openmoko.org/ Depends: Source: ${SRC}
使用外部的 toolchain是一个为Neo建立程序的好方法。如果你熟悉这个产品的话,你也会想要参考:
加入必要的链接库到src/Makefile.am 的 _LDADD 字段,如:
openmoko_sample2_LDADD = @DEPENDENCIES_LIBS@ -lmokogsmd2
之后,请确定再次执行 om-conf
不久之后,你会想要编译一个无法透过预先编译toolchain来完成依存性的程序,’如一些obscure libraries。
在这样的案例当中,请放心的将其它的libraries 放到下一次释出的Openmoko toolchain。以下是你如何扩充 toolchain安装。也就是说,我们想要加入一个名为liburiparse的链接库:
cd ~/source wget http://downloads.sourceforge.net/uriparser/uriparser-0.6.0.tar.bz2 ./configure --host=arm-angstrom-linux-gnueabi --prefix=/usr/local/openmoko/arm make make install
当你撰写了一支很好的应用式,而你想要与其它人分享,最佳的方式是
您也可以参考 客制化你的Openmoko套件.