现在的位置: 首页 > 综合 > 正文

linux kernel for mips memory lost when pfn!=0

2017年12月22日 ⁄ 综合 ⁄ 共 1298字 ⁄ 字号 评论关闭

 这个标题很难理解,需要解释一下,一般mips cpu DRAM的起始地址都是0x80000000, 所以在linux kernel中定义PAGE_OFFSET = 0x80000000,  物理地址从0开始,也就是这里的pfn=0 的意思。 但是也有少数的mips cpu DRAM的起始地址不是从0x80000000开始的,比如从0x88000000开始。这种情况下,一般linux kernel也可以正常工作,但是会有一个很大的memory lost的现象,我这里要说的就是如何解决这个问题。
    在linux 2.6.x kernel很容易解决,因为已经考虑这种状况了。在include/asm-mips/page.h中,

#ifndef PHYS_OFFSET
#define PHYS_OFFSET 0UL
#endif

这个PHYS_OFFSET就是为了解决这种问题专门设置的, 比如0x88000000这中情况下,就可以设  PHYS_OFFSET=0x08000000,  同时也要调整一下另外几个定义:

#define CAC_BASE 0x80000000
#define IO_BASE 0xa0000000
#define UNCAC_BASE 0xa0000000

/*
 * This handles the memory map.
 * We handle pages at KSEG0 for kernels with 32 bit address space.
 */

#define PAGE_OFFSET 0x80000000UL

相应变成:

#define CAC_BASE 0x88000000
#define IO_BASE 0xa8000000
#define UNCAC_BASE 0xa8000000

/*
 * This handles the memory map.
 * We handle pages at KSEG0 for kernels with 32 bit address space.
 */

#define PAGE_OFFSET 0x88000000UL

    linux kernel 2.4.x中,因为没有PHYS_OFFSET 的处理,我的做法是,从2.6.x移植相应的代码过来,也不是很复杂,只要修改这样几个文件就可以了:
.
|-- arch
|   `-- mips
|       |-- kernel
|       |   `-- setup.c                       ##bootmem_init()
|       `-- mm
|           `-- init.c                        ##paging_init(), mem_init()
|-- include
|   `-- asm-mips
|       |-- io.h
|       |-- page.h
|       `-- pgtable-32.h
`-- mm
    `-- page_alloc.c              ## free_area_init_core() ,  free_area_init()

    其实arm cpu也有一样的问题,但是,即使是2.4.x kenrel已经有对PHYS_OFFSET的处理了

抱歉!评论已关闭.