在Fedora 12下编译和调试RT-Thread

在Fedora 12下编译和调试RT-Thraed

1.安装编译工具

yum install scons
yum install python

安装工具arm-2010q1-202-arm-none-linux-gnueabi.bin,我是安装在/home/lixianjing/CodeSourcery目录下的,后面会引用这个路径。 2.下载RT-Thread

[lixianjing@vm os]$ wget http://rt-thread.googlecode.com/files/rt-thread-0.4.0%20beta1.zip
[lixianjing@vm os]$ unzip rt-thread-0.4.0/ beta1.zip
[lixianjing@vm os]$ cd rt-thread-0.4.0/ beta1/bsp/mini2440/

3.修改rtconfig.h

//#define RT_USING_NEWLIB
//#define RT_USING_PTHREADS

使用NEWLIB和PTHREADS,在我这里有些问题,编译时会说头文件有冲突。加上-nostdinc选项之后又说有些头文件找不到了。估计newlib还不太成熟,所以我暂时没有用NEWLIB。 4.修改rtconfig.py

    #EXEC_PATH  = 'E:/Program Files/CodeSourcery/Sourcery G++ Lite/bin'
    EXEC_PATH = '/home/lixianjing/CodeSourcery/Sourcery_G++_Lite/bin'

    #PREFIX = 'arm-none-eabi-'
    PREFIX = 'arm-none-linux-gnueabi-'

    LFLAGS += ' -nostdlib'
    CFLAGS += ' -nostdinc -nostdlib'

如果不加nostd,就会出现头文件冲突的情况,通常编译内核都是要加这个选项的,但是不清楚为什么在Windows下没有问题。 5.修改SConstruct

# build program
env.Program(TARGET, objs, LIBS=['libgcc.a'], LIBPATH='/home/lixianjing/CodeSourcery/Sourcery_G++_Lite/lib/gcc/arm-none-linux-gnueabi/4.4.1/armv4t/')

因为arm没有除法指令,所以除法是用函数实现的,这些函数在libgcc.a里。因为前面加了nostdlib选项,所以这里要链接一下libgcc.a。 6.加上一个raise函数 raise.c:

void raise(void)
{
    return;
}

这个函数可能是libgcc.a里某处引了它,应该相当于abort之类的功能吧,这里实现一个空函数即可。 7.修改SConscript

src_bsp = ['application.c', 'startup.c', 'board.c', 'raise.c']

这里只是把raise.c加入编译。 8.编译RT-Thread

[lixianjing@vm mini2440]$ scons

如果出现下列信息,那就是编译成功了:

arm-none-linux-gnueabi-objcopy -O binary rtthread-mini2440.axf rtthread.bin
arm-none-linux-gnueabi-size rtthread-mini2440.axf
  text       data        bss        dec        hex    filename
363064       1516      14740     379320      5c9b8    rtthread-mini2440.axf
scons: done building targets.

注意:以上工作都是在bsp/mini2440/目录下完成的。 9.编译qemu 直接用yum安装qemu是不行的,因为里面没有mini2440的配置,要下载qemu for mini2440的源代码才行:

[lixianjing@vm os]$ git clone git://repo.or.cz/qemu/mini2440.git
[lixianjing@vm os]$ cd mini2440

10.修改hw/mini2440.c

static void mini2440_reset(void *opaque)
{
    struct mini2440_board_s *s = (struct mini2440_board_s *) opaque;
    uint32_t image_size;

    if (s->kernel) {
       image_size = load_image(s->kernel, qemu_get_ram_ptr(0));
       if (image_size > 0) {
           if (image_size & (512 -1))  
               image_size = (image_size + 512) & ~(512-1);            s->cpu->env->regs[15] = S3C_RAM_BASE ;
           mini2440_printf("loaded kernel %s at %p/n", s->kernel, s->cpu->env->regs[15]);
       }

       return;
    }
...
}

开始我直接编译了qemu,运行时总出现无效地址问题。后来发现是qemu是按u-boot加载的RT-Thread,RT-Thread加载的地址与u-boot是不同的,所以根本没有执行到RT-Thread的代码。 11.编译qemu

[lixianjing@vm mini2440]$ ./configure --target-list=arm-softmmu --disable-linux-user;make
[lixianjing@vm mini2440]$ su
[root@vm mini2440]# make install

12.调试运行RT-Thread 开两个终端,都进入bsp/mini2440目录。 终端1:

[lixianjing@vm mini2440]$ qemu-system-arm -S -s -M mini2440 -kernel rtthread.bin -serial stdio
S3C: CLK=240 HCLK=240 PCLK=240 UCLK=57
QEMU: ee24c08_init
DM9000: INIT QEMU MAC : 52:54:00:12:34:56
QEMU mini2440_reset: loaded kernel rtthread.bin at 0x30000000

加 -S -s 选项表示qemu等待调试器连接。 终端2:

[lixianjing@vm mini2440]$ arm-none-linux-gnueabi-gdb rtthread-mini2440.axf
(gdb) target remote :1234
Remote debugging using :1234
_start () at /home/lixianjing/lab/os/rt-thread-0.4.0 beta1/libcpu/arm/s3c24x0/start_gcc.S:91
91        b        reset
(gdb) b rt_init_thread_entry
Breakpoint 1 at 0x30000350: file application.c, line 64.
(gdb) c
Continuing.

Breakpoint 1, rt_init_thread_entry (parameter=0x0) at application.c:64
64            dfs_init();
(gdb)

1234是qemu等待调试器的缺省端口号。 然后就可以用gdb研究RT-Thread了。 这里说明一下,我的工作目录是/home/lixianjing/lab/os,针对mini2440定制的qemu在mini2440下,rt-thread源代码在rt-thread-0.4.0 beta1下。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
"多谢关注realboard,请访问慧至科技官方网站www.hugacy.com" 感谢大家关注realboard,再三感谢,尤其是众多发email过来询问的网友。 鉴于有网友怀疑realboad速度比qemu慢,事实胜于雄辩,提供测试方法如下: 测试方法: 分别运行两个batch程序,用秒表或PC时钟计时(大概1分钟左右结束) 计时方法: 程序启动开始计时; 出现UI画面结束计时. 测试代码(rt-thread 0.4.0 relese): 如果对测试代码有疑问,请联系rt-thread咨询 bsp/mini2440/sdcard.c rt_uint8_t sd_init(void) { //-- SD controller & card initialize int i; sd_delay(1000000); //此处增加一行对ARM仿真性能进行压力测试 /* Important notice for MMC test condition */ /* Cmd & Data lines must be enabled by pull up resister */ SDIPRE = PCLK/(INICLK)-1; SDICON = (0<<4) | 1; // Type A, clk enable SDIFSTA = SDIFSTA | (1<<16); SDIBSIZE = 0x200; /* 512byte per one block */ SDIDTIMER=0x7fffff; /* timeout count */ /* Wait 74SDCLK for MMC card */ for(i=0; i<0x1000; i++); sd_cmd0(); 参考配置: Pentium(R) Dual-Core CPU E5400 @ 2.70GHz 2.69GHz, 3.46GB of RAM 参考结果: qemu为47秒, realboard为28秒 realboard之所有没有达到23秒以内,是因为Timer处理和外设IO还有专门优化。 早期曾经对realboard核心指令集模拟器做过多媒体解码测试,综合性能是qemu的2倍。 详情请参考我的CSDN blog realboard -- 继续挑战ARM高性能软件仿真极限 <** 任何个人或团体学习者,教育培训机构,自由项目开发组织,在非商业赢利前提下,均可以无偿体验和使用realboard,商业使用请联系作者获得授权, email : lxzhg@hotmail.com **> 测试包中所含其它资源为自由软件开发组织所有,请参考各自许可协议。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值