首页
登录 | 注册

在QQ2440开发板上移植KVM并测试成功

项目最终需要实现目标:
在嵌入式开发板QQ2440(处理器S3C2440)上用java实现串口全双工通信
存在技术疑问见帖子:
http://linux.chinaunix.net/bbs/viewthread.php?tid=1043545

本文主要记录在嵌入式开发板QQ2440上实现KVM移植的过程

开发环境developing workstation:
        1、 X86 PC机
      2、linux操作系统  版本fedora8
      3、交叉编译器  arm-linux-gcc版本2.95.3

目标平台target device:
   1、友善之臂FriendlyArm QQ2440V3 开发板
   2、操作系统为自己移植的linux2.6.20.3版本,根文件系统为自己制作的
     yaffs可读写文件系统

参考资料:
       
1、移植KVM到arm-linux
http://jayya.com/2006/01/16/109
2、
http://blog.csdn.net/huangqiqun/archive/2007/01/20/1488854.aspx
3、
http://blog.csdn.net/hotdust/archive/2007/09/11/1781223.aspx
4、解
压j2me_cldc-1_1-fcs-src-winunix.zip包在目录
j2me_cldc-1_1-fcs-src-winunix/doc/porting下的KVM_porting.pdf
此KVM移植手册很有用,
建议仔细看!
5、安装j2sdk-1_4_2_18-linux-i586.bin后生成文件j2sdk1.4.2_18下的README

所需源代码:
    1、j2sdk-1_4_2_18-linux-i586.bin,不推荐使用jdk1.5及以上版本,不       能编译通过
    2、j2me_cldc-1_1-fcs-src-winunix.zip包,此zip包包含KVM的源代码
            
      
第一步:安装j2sdk-1_4_2_18-linux-i586.bin,并设置此jdk的环境变量
        直接运行此bin文件边可以顺利安装,主要问题在于jdk环境变量的设置。
        打开根目录下的.bash_profile文件(隐藏文件,安ctrl+h显示),添加如        下代码:
JAVA_HOME=/home/j2sdk-1_4_2_18/j2sdk1.4.2_18
PATH=$JAVA_HOME/bin:$PATH
CLASSPATH=$JAVA_HOME/lib:/root/JAVA
export JAVA_HOME PATH CLASSPATH
根据你自己的实际解压位置作适当的修改,我的解压位置为/home/j2sdk-1_4_2_18/文件夹下 其中PATH是指指令的搜索路径,比如说用javac去编译一个.java文件,直接在命令行中用javac就可以,而不要代绝对路径了。 CALSSPATH中的 $JAVA_HOME/lib 为你的java代码运行的类 路径,/root/JAVA 为编译你的java代码生成的class所放置的路径。
第二步:修改代码
第一处:修改j2me_cldc/kvm/VmUnix/build/目录下的makefile文件
进入j2me_cldc/kvm/VmUnix/build/,vi Makefile,主要修改将原来使用的x86的编译器GCC改为我们的arm-linux-gcc,这样才能得到我们的所需,我主要是修改下面的句子:       ifeq ($(GCC), true) CC
=arm-linux-gcc
另外在文件的开始指定export
PLATFORM=linux
第二处:修改j2me_cldc/kvm/VmUnix/src/runtime_md.c文件
把这个文件中void InitializeFloatingPoint()函数中的两句注释掉,如:
#if defined(LINUX) && PROCESSOR_ARCHITECTURE_X86
/* Set the precision FPU to double precision */
// fpu_control_t cw = (_FPU_DEFAULT & ~_FPU_EXTENDED) | _FPU_DOUBLE;
// _FPU_SETCW(cw);
#endif
这样,编译的时候才不会出现错误,但也不支持浮点数了。
第三步:编译生成KVM
修改完成之后记得要保存,然后进入j2me_cldc-1_1-fcs-src-winunix/kvm/VmUnix/build目录,make,这样就会顺序完在此目录下生成KVM可执行bin文件
第四步:编译生成preverify        直接进入tools/preverfiyer/build/linux下,make,这里没有必要对这个makefile进行修
改。可以看到此时在目录下生成了preverfiyer可执行文件。第五步:测试,验证KVM移植成功            1、编写Hello World代码,保存成FirstSample.java
public class FirstSample
{
    public static void main(String[] args)
    {
    System.out.println("We will not use 'Hello World'");
    }
}
      
         2、编译:javac    FirstSample.java
             如果你之前安装jdk的时候环境变量没有设置好这步会出错,记得修改的.bash_profile要重新启动计算机才生效。
      
         3、预校验preverify:
         将生成的preverify可执行文件放到你文件系统的/bin目录下面去,然后
         preverify -classpath kvm/classes -d . mydir preverify有         几个参数:
         -classpath 同上 -d 输出验证后的class文件,默认的是当前目录下的          output文件夹下。这里最容易出错了,我在此处就折腾了老半天。这样生          成的.class文件放到板子上去运行会出现如下提示:
ALERT:java/lang/NoClassDefFoundError
         解决办法:
        
preverify的时候,在classpath中不仅要指定自己的类,而且还要指定需         要用来做验证
处理的CLDC的类(在cldc中是在tools\jcc下的那两个          zip 包)将它解压出来,然后在classpath中指定它的路径就可以了比          如:将其解压成d:\classes那么preverify应该写成(比如要验证的          class为test.class)
         preverify -classpath d:\classes;. test
        (注d:\classes;. 这里是分号和点,分号是表示路径的分隔,点是表示          test在当前目录下)
         要相应改动 preverify -classpath d:\classes;. test此句。
我的过程如以下截图所示:

        4、在板子上校验
          将kvm和经过preverify处理之后生成的FirstSample.class文件放          置到开发板中,运行,执行如下指令:
           #kvm   FirstSample  
                 注:不要画蛇添足加.class后缀写成
           #kvm   FirstSample.class
                正确输出说明KVM移植成功!
附KVM源码包:  

       
        文件:j2me_cldc-1_1-fcs-src-winunix.zip
        大小:4714KB
        下载:
下载
       

相关文章

  • Android系统源码都有虚拟机GPS HAL层文件gps_qemu.c,移植GPS HAL层修改该文件就可以了.下面将从上到下说明主要修改的地方.修改LOG TAG#define  LOG_TAG  "gps_qemu" ...
  • 自荐.net快速开发平台,新时代的选择
    力软信息 快速开发平台,不敢保证别人家的平台怎么样,但是对我们力软快速开发平台还是有信心的. 1.力软敏捷开发框架介绍 力软敏捷开发框架(learun framework)是力软快速开发平台推出的国内领先企业基础二次开发框架.Learun框 ...
  • 【Java Web开发】数据库及SQL/MySQL基础
    详细课程链接:[Java Web开发]数据库及SQL/MySQL基础 -- 阿里云大学 MySQL概述 什么是数据库 ? 答:数据的仓库,如:在ATM的示例中我们创建了一个 db 目录,称其为数据库 什么是 MySQL.Oracle.SQL ...
  • Hadoop是一个用Java编写的Apache开源框架,允许使用简单的编程模型跨计算机集群分布式处理大型数据集.Hadoop框架工作的应用程序在跨计算机集群提供分布式存储和计算的环境中工作.Hadoop旨在从单个服务器扩展到数千个机器,每个 ...
  • 简介 Hive为我们提供了众多的内置函数,但是在实际的运用过程中仍然不能满足我们所有的需求.hive是用java开发的,本身提供了使用java去开发UDF的方式.而这里我们采用python的方式去实现UDF函数. DEMO实现 我们这里用p ...
  •     如何在 KVM 虚拟机上运行 KVM 暨 如何让虚拟机支持虚拟化     测试普华IAAS时,没有真实机器当计算节点,所以想到拿虚拟机当计算节点.首先一点,计算节点必须支持虚拟化,知道vmware可以将CPU硬件虚拟化"传 ...

2020 unjeep.com webmaster#unjeep.com
12 q. 0.012 s.
苏ICP备12049786号-20