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

***************************************************************************************************************************
作者: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));

 

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值