zoukankan      html  css  js  c++  java
  • uncompressing linux .................................................后没反应解决办法

    编译kernel是的no machine record defined 错误,网上有一些解法,其实都是错误的,以讹传讹。不打算自己写,找到一篇还算靠谱的,转摘一下。

    其根本原因是没有在 __proc_info_end  与 __proc_info_begin 之间找到有效的machine ID。

    http://hi.baidu.com/rwen2012/item/9f5191c64036d87ecfd4f849

    在新的kernel 2.6.29 上编译不能通过,终端提示: 

    arm-none-linux-gnueabi-ld: no machine record defined 

    解决方法 
    放狗搜后,按照如下方法可以解决。将arch/arm/kernel/vmlinux.lds的最后两行(如下),给注释起来,但都没说是为了什么 

    ASSERT((__proc_info_end - __proc_info_begin), "missing CPU support") 
    ASSERT((__arch_info_end - __arch_info_begin), "no machine record defined") 


    自己到arch/arm/kernel/vmlinux.lds里看的时候,才发现那两行的上头写着 

    /* These must never be empty 
    If you have to comment these two assert statements out, your binutils is too old (for other reasons as well) */ 
    ASSERT((__proc_info_end - __proc_info_begin), "missing CPU support") 
    ASSERT((__arch_info_end - __arch_info_begin), "no machine record defined") 


    我想可能不是我交叉编译器太旧的缘故,而是太新了! 
    我用的是:Sourcery G++ Lite 2009q1-126 for ARM GNU/Linux 
    而官方是:Sourcery G++ Lite 2008q1-126 for ARM GNU/Linux 

    机器ID错误: 
    现在注释后可以正常编译内核了!替换新的内核文件,在boot后提示: 
    uncompressing linux ................................................. 
    然后再没有动静了,我想可能解压后给kernel传递参数时出现问题了吧。但是是什么参数可能出的问题就不晓得啦。 

    在这里困住了好久!因为这句话啥都没提示!好歹有句话啊。。。。。。。。 

    经过多方搜索,发现了一个调试技巧,嘿嘿嘿,一般人我不告诉他!那就是下面解决方法中提到的设置Kernel debugging,设置后,再重启启动内核就会出现详细的问题说明。 



    因为内核启动时首先进入SVC模式,关闭中断,并machine ID,如果uboot传输过来的 machine ID跟编译的内核machine ID不一致,那就就咯屁了。具体表现为:啥反应都没有! 

    解决方法: 
    1)。执行make xconfig 

    在配置中进入Kernel hacking,打开Kernel debugging和Kernel low-level debugging functions. 

    选中这两项的目的是打印出调试信息,重新make uImage 

    Starting kernel ... 

    Uncompressing Linux........................................................................................... done, booting the kernel. 

    Error: unrecognized/unsupported machine ID (r1 = 0x000007d1). 

    Available machine support: 

    ID (hex) NAME 

    罓?0009 

    Please check your kernel config and/or bootloader. 


    终于看到阻在这里的原因啦,是机器ID错误,别人的机器ID错误至少有个NAME值啊,我的咋为空呢? 

    2) 是不是没有注册机器ID?猜测。这一步保证系统支持的ID里面含有devkit8000! 

    make xconfig 发现system type菜单下面没有devkit的选项,肯定是哪里的配置文件还没有添加,经过分析,找到了/kernel/arch/arm/mach-omap2/Kconfig文件,在末尾配置添加了devkit8000支持。 

    config MACH_OMAP3_BEAGLE 

    bool "OMAP3 BEAGLE board" 

    depends on ARCH_OMAP3 && ARCH_OMAP34XX 

    config MACH_OMAP3_DEVKIT8000 

    bool "OMAP3 DEVKIT8000 board" 

    depends on ARCH_OMAP3 && ARCH_OMAP34XX 


    然后make xconfig 发现system type菜单,选择devkit选项,选devkit8000,保存。 

    3)上一步仅仅能保证可以支持,要想能正确支持,还要修改下面的文件。 

    1. 我们进到arch/arm/mach-omap2/board_devkit8000.c,在最后一段有这句 

    MACHINE_START(OMAP3_DEVKIT8000 , ”OMAP3 beggle board”) 


    这里OMAP3_DEVKIT8000就是machine ID的代号~ 呢具体值是多少呢?~ 

    2. 在文件arch/arm/tools/mach-types中最后一行添加,设置我们的machine ID是2001。 

    omap3_devkit8000 ARCH_OMAP3_DEVKIT8000 OMAP3_DEVKIT8000 2001 


    通过修改Kconfig和mach-types两个文件,我们可以使系统正确的识别我们的machine ID,并且从上面我们也可以看到r1= 0x000007d1,0x7d1就是2001。与我们所设置的machine ID是相一致的。

  • 相关阅读:
    关于BehaviorEditorPart 不显示的问题(出自msdn)
    webpart msdn 的位置
    Visual Studio 2008 具有一些新的报表功能和改进之处
    .NET Framework 类库
    Reporting Service 安装 及相关问题如:授予的权限不足解决办法
    单服务器部署&&双服务器部署
    Windows Server 2003安装完毕后汉字都为乱码“方框”,配置域控制器
    Dreamweaver MX显示汉字为乱码的解决方法
    名称以无效字符开头。处理资源 'http://localhost/发布了的/Default.aspx' 时出错。第 1 行,位置: 2
    【随感】my feeling about Long Ying
  • 原文地址:https://www.cnblogs.com/lys0827/p/5880476.html
Copyright © 2011-2022 走看看