成功从linux2.6.17.4移植到linux2.6.38.8版本[一]

来源:互联网 发布:centos安装网络配置 编辑:程序博客网 时间:2024/06/14 02:13

***************************************************************************************************************************
作者:EasyWave                                                                                 时间:2012.02.14

类别:linux驱动开发                                                                           声明:转载,请保留链接

***************************************************************************************************************************

只要移植linux2.6.38.8成功之后,再移植到linux3.0会容易得多,因为linux3.0以上跟linux2.6.38和linux2.6.39差别不大,不过不同的地方是linux3.0之后的lookup_machine_type函数有变化,好像是放到C代码里面去了,还没有来得及仔细阅读代码呢, 在移植到linux2.6.38.8版本前,还是先来介绍下,linux2.6.38.8版本的新特征:

    * 合并自动进程分组。
    * 改善 VFS虚拟文件系统可扩展性, 提升文件夹缓存扩展性。
    * BTRFS 文件系统增加 LZO 压缩,支持创建只读快照。
    * 透明化内存 Huge Pages 使用过程,实现按需自动调用。
    * 多 CPU 条件下对网络传出数据实现自动负载均衡。
    * B.A.T.M.A.N. (Better Approach To Mobile Adhoc Networking) Mesh 协议:去中心化分布式无线 Adhoc 模式 ,特别适用于自然灾害等紧急情况下的网络接入共享。
    * AMD Fusion 系列 APU 内置 GPU 的开源驱动

一:machine_desc结构体 
跟以前的版本变化不大,不过细节上还是有些变化,首先是machine_desc结构体跟以前少了phys_io和io_pg_offst,在arch\arm\inclue\mach\arch.h见下说明:
struct machine_desc { unsigned int  nr;  /* architecture number */ const char  *name;  /* architecture name */ unsigned long  boot_params; /* tagged list  */ unsigned int  nr_irqs; /* number of IRQs */ unsigned int  video_start; /* start of video RAM */ unsigned int  video_end; /* end of video RAM */ unsigned int  reserve_lp0 :1; /* never has lp0 */ unsigned int  reserve_lp1 :1; /* never has lp1 */ unsigned int  reserve_lp2 :1; /* never has lp2 */ unsigned int  soft_reboot :1; /* soft reboot  */ void   (*fixup)(struct machine_desc *,      struct tag *, char **,      struct meminfo *); void   (*reserve)(void);/* reserve mem blocks */ void   (*map_io)(void);/* IO mapping function */ void   (*init_early)(void); void   (*init_irq)(void); struct sys_timer *timer;  /* system tick timer */ void   (*init_machine)(void);#ifdef CONFIG_MULTI_IRQ_HANDLER void   (*handle_irq)(struct pt_regs *);#endif};/* * Current machine - only accessible during boot. */extern struct machine_desc *machine_desc;/* * Set of macros to define architecture features.  This is built into * a table by the linker. */#define MACHINE_START(_type,_name)   \static const struct machine_desc __mach_desc_##_type \ __used       \ __attribute__((__section__(".arch.info.init"))) = { \ .nr  = MACH_TYPE_##_type,  \ .name  = _name,#define MACHINE_END    \};

这样的话,MACHINE_START宏定义与MACHINE_END宏定义的位置,需要改变下:

MACHINE_START(W90P950EVB, "W90P950EVB")
.boot_params =  0x100,
.map_io  = nuc950evb_map_io,
.init_irq = nuc900_init_irq,
.init_machine = nuc950evb_init,
.timer  = &nuc900_timer,
MACHINE_END
将phys_io和io_pg_offst拿掉,但请注意,boot_params 参数不可更改,因为这个是和内核的起始地址有关的,如果此地址有变化则Makefile.boot文件也需要更改。

二:lookup_machine_type子程序

这个也是需要修改的一个地方,如果你是采用UBOOT的话,这个也是需要匹配的,至于UBOOT怎么跟linux内核如何匹配,可以到网络上搜索。当然也可以修改lookup_machine_type函数,见下:

__lookup_machine_type:
#ifdef CONFIG_ARCH_S3C2410      //此处需要和内核的mach-types文件中的一致
       mov      r1, #0x708
       add      r1, r1, #0x42
       add      r1, r1, #0x04
#endif
 adr r3, __lookup_machine_type_data
 ldmia r3, {r4, r5, r6}
 sub r3, r3, r4   @ get offset between virt&phys
 add r5, r5, r3   @ convert virt addresses to
 add r6, r6, r3   @ physical address space
1: ldr r3, [r5, #MACHINFO_TYPE] @ get machine type
 teq r3, r1    @ matches loader number?
 beq 2f    @ found
 add r5, r5, #SIZEOF_MACHINE_DESC @ next machine_desc
 cmp r5, r6
 blo 1b
 mov r5, #0    @ unknown machine
2: mov pc, lr
ENDPROC(__lookup_machine_type)

MACHINFO_TYPE是在arch\arm\kernel\asm-offsets.c定义,如下所示:

  DEFINE(SIZEOF_MACHINE_DESC, sizeof(struct machine_desc));
  DEFINE(MACHINFO_TYPE,  offsetof(struct machine_desc, nr));
  DEFINE(MACHINFO_NAME,  offsetof(struct machine_desc, name));

 

   未完待续..........

原创粉丝点击