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

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

               

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

1.安装编译工具

yum install sconsyum 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 programenv.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.binarm-none-linux-gnueabi-size rtthread-mini2440.axf  text       data        bss        dec        hex    filename363064       1516      14740     379320      5c9b8    rtthread-mini2440.axfscons: 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 stdioS3C: CLK=240 HCLK=240 PCLK=240 UCLK=57QEMU: ee24c08_initDM9000: INIT QEMU MAC : 52:54:00:12:34:56QEMU 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 :1234Remote debugging using :1234_start () at /home/lixianjing/lab/os/rt-thread-0.4.0 beta1/libcpu/arm/s3c24x0/start_gcc.S:9191        b        reset(gdb) b rt_init_thread_entryBreakpoint 1 at 0x30000350: file application.c, line 64.(gdb) cContinuing.Breakpoint 1, rt_init_thread_entry (parameter=0x0) at application.c:6464            dfs_init();(gdb)

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

           

给我老师的人工智能教程打call!http://blog.csdn.net/jiangjunshow

这里写图片描述

猜你喜欢

转载自blog.csdn.net/jggyff/article/details/84195664