嵌入式爱好者

查看: 163440|回复: 194

[技术分享] 开帖详述linux-2.6.33内核的移植

    [复制链接]

29

主题

9048

帖子

5593

积分

扫一扫,手机访问本帖
发表于 2010-2-4 17:59:29 | 显示全部楼层 |阅读模式
宿主机:ubuntu9.10
目标机:s3c2440
交叉编译器:arm-linux-gcc-3.4.1
交叉编译器路径:/usr/local/arm/3.4.1
要移植的内核版本:linux-2.6.33
文件系统类型: yaffs2 (目前使用光盘中linux-2.6.28.7的文件系统)

欢迎大家一起讨论,请各位指正。另外请回帖的各位老师、同学、工程师写清楚移植过程。如果只是通篇的问题,很难判断哪里有问题。
-------------------------------华丽的分割线--------------------------------
其实这个移植好的内核可以用arm-linux-gcc-4.3.2来编译,编译好以后仍可使用2.6.28.7的文件系统来启动。更换编译器方法见修改Makefile。
不过要在配置内核的时候添加一个选项,如下:
  1. Kernel Features  --->  
  2.     [*] Use the ARM EABI to compile the kernel
  3.    [*]   Allow old ABI binaries to run with this kernel (EXPERIMENTAL)
复制代码
------------------------------华丽的分割线too------------------------------
下载解压内核
        首先,从官网上下载linux-2.6.33的内核。
        ftp://ftp.kernel.org/pub/linux/kernel/v2.6/可以找到。
        新建目录mkdir /file/fl。将内核源码包拷贝到/file/fl的目录下。
        解压源码包
  1. tar zxvf linux-2.6.33.tar.gz
复制代码
回复

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-2-4 18:05:55 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-7-15 16:23 编辑

在这声明一下,为了让我发的移植方面的楼连起来,删除了中间几位朋友的回复,在这里我表示歉意。
谢谢你们的回复和问题,你们是我继续前进的动力。



移植yaffs2驱动
下载最新的驱动http://www.aleph1.co.uk/cgi-bin/ ... fs2.tar.gz?view=tar
解压在/file/fl下
  1. tar zxvf yaffs2.tar.gz
复制代码
进入yaffs2,
  1. cd yaffs2
复制代码
给内核打补丁
  1. ./patch-ker.sh  c  /file/fl/linux-2.6.33
复制代码
成功后打印信息
  1. Updating /file/fl/linux-2.6.33/fs/Kconfig
  2. Updating /file/fl/linux-2.6.33/fs/Makefile
复制代码
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-2-4 19:23:20 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-3-16 08:09 编辑

修改机器码
飞凌开发板的bootloader默认的机器码是193,所以我们在使用smdk2440机器的时候,需要修改机器码。修改arch/arm/tools/mach-types。将
  1. s3c2410      ARCH_S3C2410    S3C2410    193
复制代码
删掉。然后将
  1. s3c2440      ARCH_S3C2440    S3C2440    362
复制代码
修改为
  1. s3c2440      ARCH_S3C2440    S3C2440    193
复制代码
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-2-5 08:53:56 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-3-16 08:08 编辑

指定目标板machine、编译器和编译器路径
修改linux-2.6.33/Makefile,将
  1. ARCH                ?= $(SUBARCH)
  2. CROSS_COMPILE        ?=  
复制代码
修改成
  1. #ARCH                ?= $(SUBARCH)
  2. #CROSS_COMPILE        ?=
  3. ARCH                ?= arm
  4. CROSS_COMPILE        ?= /usr/local/arm/3.4.1/bin/arm-linux-  
复制代码
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-2-5 09:25:13 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-3-16 08:08 编辑

增加devfs文件管理器的支持
我们所用的文件系统使用的是devfs文件管理器。修改fs/Kconfig,
找到
  1. menu "Pseudo filesystems"
复制代码
添加如下语句:
  1. config DEVFS_FS
  2.          bool "/dev file system support (OBSOLETE)"
  3.          default y   
  4. config DEVFS_MOUNT
  5. bool "Automatically mount at boot"
  6. default y
  7. depends on DEVFS_FS
复制代码
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-2-5 09:28:32 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-3-16 08:09 编辑

修改晶振频率( 可解决打印信息乱码问题 )
文件:arch/arm/mach-s3c2440/mach-smdk2440.c
  1. /*s3c24xx_init_clocks(16934400);*/  s3c24xx_init_clocks(12000000);  
复制代码
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-2-5 09:31:29 | 显示全部楼层
修改MTD分区
文件: arch/arm/plat-s3c24xx/common-smdk.c
需要和bootloader中的分区信息相同(128M),否则,启动时出错。
  1. static struct mtd_partition smdk_default_nand_part[] = {

  2.         [0] = {
  3.                 .name        = "Boot",
  4.                 .size        = 0x00100000,
  5.                 .offset = 0
  6.         },
  7.         [1] = {
  8.                 .name        = "MyApp",
  9.                 .size        = 0x003c0000,
  10.                 .offset = 0x00140000,
  11.         },
  12.         [2] = {
  13.                 .name        = "Kernel",
  14.                 .size        = 0x00300000,
  15.                 .offset = 0x00500000,
  16.         },
  17.         [3] = {
  18.                 .name        = "fs_yaffs",
  19.                 .size        = 0x03c00000,         //30M
  20.                 .offset = 0x00800000,
  21.         },       
  22.         [4] = {
  23.                 .name        = "WINCE",
  24.                 .size        = 0x03c00000,
  25.                 .offset = 0x04400000,
  26.         }
  27. };
复制代码
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-2-5 09:33:09 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-3-16 08:09 编辑

关闭ECC校验
文件:drivers/mtd/nand/s3c2410.c
函数:s3c2410_nand_init_chip
  1. /*chip->ecc.mode = NAND_ECC_SOFT; */  chip->ecc.mode = NAND_ECC_NONE;
复制代码
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-2-5 09:42:53 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-6-13 08:43 编辑

修改nandflash驱动,支持K9F1G08的nandflash
修改drivers/mtd/nand下面的nand_bbt.c文件:
  1. static struct nand_bbt_descr largepage_memorybased = {
  2.         .options = 0,
  3.         .offs = 0,
  4.         .len = 1,           // 原数值为2,支持2K每页的flash修改为1。K9F1G08,K9F2G08是2k每页的flash
  5.         .pattern = scan_ff_pattern
  6. };
  7. static struct nand_bbt_descr largepage_flashbased = {
  8.         .options = NAND_BBT_SCAN2NDPAGE,
  9.         .offs = 0,
  10.         .len = 1,           //原数值为2,支持2K每页的flash修改为1。K9F1G08,K9F2G08是2k每页的flash
  11.         .pattern = scan_ff_pattern
  12. };
复制代码
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-2-5 10:45:20 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-6-13 08:47 编辑

下面,开始配置内核。
进入linux-2.6.33目录,把s3c2410的默认配置写入config文件。
  1. make s3c2410_defconfig
复制代码
配置文件系统选项
配置yaffs2文件系统
修改配置如下:
  1. File systems  --->
  2.     [*] Miscellaneous filesystems  --->
  3.         <*>   YAFFS2 file system support
  4.             -*-     512 byte / page devices
  5.             -*-     2048 byte (or larger) / page devices
  6.                 [*]       Autoselect yaffs2 format
  7.                 [*]     Cache short names in RAM
复制代码
配置cpu相关选项
修改配置如下:
  1. System Type  --->
  2.     S3C2440 Machines  --->
  3.         [*] SMDK2440
  4.         [*] SMDK2440 with S3C2440 CPU module
复制代码
去掉S3C2400 Machines、S3C2410 Machines、S3C2412 Machines、S3C2442 Machines的所有选项,否则会报错。如果现在编译内核,下载到开发板中,内核就可以正常启动了。呵呵,有了雏形,咱们继续移植设备驱动。
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-3-13 16:11:44 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-4-15 10:22 编辑

移植USB host驱动
在这个版本的linux内核,已经对USB驱动进行来很好的支持,仅仅需要修改配置。
  1. Device Drivers  --->
  2.     [*] USB support  --->
  3.         {*}   Support for Host-side USB
  4.         [*]     USB device filesystem (DEPRECATED)
  5.         [*]     USB device class-devices (DEPRECATED)
  6.         <*>     OHCI HCD support
  7.         <*>   USB Mass Storage support

  8.     [*] HID Devices  --->
  9.         {*}   Generic HID support
  10.         [*]     /dev/hidraw raw HID device support

  11.     SCSI device support  --->
  12.         <*> SCSI device support
  13.         [*] legacy /proc/scsi/ support
  14.         <*> SCSI disk support
  15.         <*> SCSI tape support
复制代码
目前2.6.28.7版本的根文件系统的设备管理器是静态生成节点的,所以需要添加节点。
开发板启动以后,在/dev目录下输入一下命令:
mknod sda1 b 8 1
这个命令中的sda1是设备节点名
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-3-13 16:25:01 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-3-13 16:27 编辑

移植RTC驱动
在这个版本的linux内核,已经对RTC驱动进行来很好的支持,不需要修改配置。相应配置如下
  1. Device Drivers  --->
  2.     <*> Real Time Clock  --->
  3.         [*]   Set system time from RTC on startup and resume
  4.         (rtc0)  RTC used to set the system time
  5.         [ ]   RTC debug support
  6.               *** RTC interfaces ***
  7.         [*]   /sys/class/rtc/rtcN (sysfs)
  8.         [*]   /proc/driver/rtc (procfs for rtc0)
  9.         [*]   /dev/rtcN (character devices)
  10.         <*>   Samsung S3C series SoC RTC
复制代码
然后添加对设备的支持
打开
  1. arch/arm/mach-s3c2440/mach-smdk2440.c
复制代码
添加设备,代码如下:
  1. static struct platform_device *smdk2440_devices[] __initdata = {
  2.         &s3c_device_usb,
  3.         &s3c_device_lcd,
  4.         &s3c_device_wdt,
  5.         &s3c_device_i2c0,
  6.         &s3c_device_iis,
  7.         &s3c_device_rtc,
  8. };
复制代码
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-3-15 11:32:28 | 显示全部楼层
移植UDA1341驱动
在平台上添加和配置UDA1341:
修改
  1. arch/arm/mach-s3c2440/mach-smdk2440.c
复制代码
在开始添加头文件
  1. #include <sound/s3c24xx_uda134x.h>
  2. #include <mach/gpio-fns.h>
复制代码
添加设备配置
  1. static struct s3c24xx_uda134x_platform_data s3c24xx_uda134x_data = {
  2.         .l3_clk = S3C2410_GPB(4),
  3.         .l3_data = S3C2410_GPB(3),
  4.         .l3_mode = S3C2410_GPB(2),
  5.         .model = UDA134X_UDA1341,
  6. };

  7. static struct platform_device s3c24xx_uda134x = {
  8.         .name = "s3c24xx_uda134x",
  9.         .dev = {
  10.                 .platform_data    = &s3c24xx_uda134x_data,
  11.         }
  12. };
复制代码
把设备添加到平台当中
  1. static struct platform_device *smdk2440_devices[] __initdata = {
  2.         &s3c_device_usb,
  3.         &s3c_device_lcd,
  4.         &s3c_device_wdt,
  5.         &s3c_device_i2c0,
  6.         &s3c_device_iis,
  7.         &s3c_device_rtc,
  8.         &s3c24xx_uda134x,
  9. };
复制代码
配置如下
  1. Device Drivers  --->
  2.     <*> Sound card support  --->
  3.         <*>   Advanced Linux Sound Architecture  --->
  4.             <*>   OSS Mixer API
  5.             <*>   OSS PCM (digital audio) API
  6.                 [*]     OSS PCM (digital audio) API - Include plugin system
  7.                 [*]   Support old ALSA API
  8.                 [*]   Verbose procfs contents
  9.                 [*]   Verbose printk
  10.                 [*]   Generic sound devices  --->
  11.                 <*>   ALSA for SoC audio support  --->
  12.                     <*>   SoC Audio for the Samsung S3C24XX chips
  13.                     <*>   SoC I2S Audio support UDA134X wired to a S3C24XX
复制代码
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-3-15 15:32:43 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-7-20 14:54 编辑

移植DM9000驱动
1.修改 drivers/net/dm9000.c 文件:
   头文件增加:
  1. #include <mach/regs-gpio.h>
  2. #include <mach/irqs.h>
  3. #include <mach/hardware.h>
复制代码
在dm9000_probe 函数开始增加:
  1. unsigned char ne_def_eth_mac_addr[]={0x00,0x12,0x34,0x56,0x80,0x49};
  2.     static void *bwscon;
  3.     static void *gpfcon;
  4.     static void *extint0;
  5.     static void *intmsk;
  6.     #define BWSCON           (0x48000000)
  7.     #define GPFCON           (0x56000050)
  8.     #define EXTINT0           (0x56000088)
  9.     #define INTMSK           (0x4A000008)
  10.        
  11.         bwscon=ioremap_nocache(BWSCON,0x0000004);
  12.         gpfcon=ioremap_nocache(GPFCON,0x0000004);
  13.         extint0=ioremap_nocache(EXTINT0,0x0000004);
  14.         intmsk=ioremap_nocache(INTMSK,0x0000004);
  15.                       
  16.         writel(readl(bwscon)|0xc0000,bwscon);
  17.         writel( (readl(gpfcon) & ~(0x3 << 14)) | (0x2 << 14), gpfcon);
  18.         writel( readl(gpfcon) | (0x1 << 7), gpfcon); // Disable pull-up
  19.         writel( (readl(extint0) & ~(0xf << 28)) | (0x4 << 28), extint0); //rising edge
  20.         writel( (readl(intmsk))  & ~0x80, intmsk);   
复制代码
在这个函数的最后需要修改:
  1. if (!is_valid_ether_addr(ndev->dev_addr)) {
  2.                 /* try reading from mac */
  3.                
  4.                 mac_src = "chip";
  5.                 for (i = 0; i < 6; i++)
  6.                         //ndev->dev_addr[i] = ior(db, i+DM9000_PAR);
  7.                         ndev->dev_addr[i] = ne_def_eth_mac_addr[i];
  8.         }
复制代码
2. 修改arch/arm/mach-s3c2440/mach-smdk2440.c,添加设备
  1. static struct platform_device *smdk2440_devices[] __initdata = {
  2.         &s3c_device_usb,
  3.         &s3c_device_lcd,
  4.         &s3c_device_wdt,
  5.         &s3c_device_i2c0,
  6.         &s3c_device_iis,
  7.         &s3c_device_rtc,
  8.         &s3c24xx_uda134x,
  9.         &s3c_device_dm9000,
  10. };
复制代码
3. 修改 arch/arm/plat-s3c24xx/devs.c
添加头文件
  1. #include <linux/dm9000.h>
复制代码
  1. static struct resource s3c_dm9000_resource[] = {
  2.         [0] = {
  3.         .start = S3C24XX_PA_DM9000,
  4.         .end   = S3C24XX_PA_DM9000+ 0x3,
  5.         .flags = IORESOURCE_MEM
  6.         },
  7.         [1]={
  8.         .start = S3C24XX_PA_DM9000 + 0x4, //CMD pin is A2
  9.         .end = S3C24XX_PA_DM9000 + 0x4 + 0x7c,
  10.         .flags = IORESOURCE_MEM
  11.         },
  12.         [2] = {
  13.         .start = IRQ_EINT7,
  14.         .end   = IRQ_EINT7,
  15.         .flags = IORESOURCE_IRQ
  16.         },
  17.         };

  18.         static struct dm9000_plat_data s3c_device_dm9000_platdata = {
  19.         .flags= DM9000_PLATF_16BITONLY,
  20.         };

  21.         struct platform_device s3c_device_dm9000 = {
  22.         .name= "dm9000",
  23.         .id= 0,
  24.         .num_resources= ARRAY_SIZE(s3c_dm9000_resource),
  25.         .resource= s3c_dm9000_resource,
  26.           .dev= {
  27.         .platform_data = &s3c_device_dm9000_platdata,
  28.           }
  29. };
  30. EXPORT_SYMBOL(s3c_device_dm9000);
复制代码
4. 修改 arch/arm/plat-s3c/include/plat/devs.h   45行附近,添加
  1. extern struct platform_device s3c_device_dm9000;
复制代码
5.修改arch/arm/mach-s3c2410/include/mach/map.h 文件
  1. /* DM9000 */
  2. #define   S3C24XX_PA_DM9000 0x20000300
  3. #define   S3C24XX_VA_DM9000 0xE0000000
复制代码
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-3-16 11:26:08 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-6-9 15:32 编辑

启动画面显示小企鹅的方法
http://bbs.witech.com.cn/thread-473-1-1.html
附送修改小企鹅图片的方法,我用的是卡卡西的320*240的图片。
http://bbs.witech.com.cn/viewthr ... &extra=#pid7956
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-3-17 08:30:01 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-6-9 08:48 编辑

3.5寸LCD显示的移植
更改arch/arm/mach-s3c2440/mach-smdk2440.c
  1. /* LCD driver info */

  2. static struct s3c2410fb_display smdk2440_lcd_cfg __initdata = {

  3.         .lcdcon5        = S3C2410_LCDCON5_FRM565 |
  4.                           S3C2410_LCDCON5_INVVLINE |
  5.                           S3C2410_LCDCON5_INVVFRAME |
  6.                           S3C2410_LCDCON5_PWREN |
  7.                           S3C2410_LCDCON5_HWSWP,

  8.         .type                = S3C2410_LCDCON1_TFT,

  9.         .width                = 240,
  10.         .height                = 320,

  11.         .pixclock        = 166667, /* HCLK 60 MHz, divisor 10 */
  12.         .xres                = 240,
  13.         .yres                = 320,
  14.         .bpp                = 16,
  15.         .left_margin        = 20,
  16.         .right_margin        = 8,
  17.         .hsync_len        = 4,
  18.         .upper_margin        = 8,
  19.         .lower_margin        = 7,
  20.         .vsync_len        = 4,
  21. };

  22. static struct s3c2410fb_mach_info smdk2440_fb_info __initdata = {
  23.         .displays        = &smdk2440_lcd_cfg,
  24.         .num_displays        = 1,
  25.         .default_display = 0,

  26. #if 0
  27.         /* currently setup by downloader */
  28.         .gpccon                = 0xaa940659,
  29.         .gpccon_mask        = 0xffffffff,
  30.         .gpcup                = 0x0000ffff,
  31.         .gpcup_mask        = 0xffffffff,
  32.         .gpdcon                = 0xaa84aaa0,
  33.         .gpdcon_mask        = 0xffffffff,
  34.         .gpdup                = 0x0000faff,
  35.         .gpdup_mask        = 0xffffffff,
  36. #endif

  37.         .lpcsel                = ((0xCE6) & ~7) | 1<<4,
  38. };
复制代码
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-3-17 08:30:17 | 显示全部楼层
占楼 触摸屏驱动移植
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-3-17 08:30:33 | 显示全部楼层
本帖最后由 飞凌-fatfish 于 2010-6-9 08:39 编辑

占楼 mp3播放器移植
移植madplay
http://bbs.witech.com.cn/thread-1185-1-1.html
上面这个帖子可以适用于2.6.12和2.6.33,当然区别也是有的,主要是编译器不一样了。
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-3-17 08:30:48 | 显示全部楼层
占楼 vsftp移植
回复 支持 反对

使用道具 举报

29

主题

9048

帖子

5593

积分

 楼主| 发表于 2010-3-18 16:06:33 | 显示全部楼层
哎呀  你们码砖太快了,我的占上几楼。
占楼  移植SD卡驱动
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋| 飞凌嵌入式 ( 冀ICP备12004394号-1 )

GMT+8, 2024-12-26 12:42

Powered by Discuz! X3.4

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表