这个标题很难理解,需要解释一下,一般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的处理了。
阅读(1793) | 评论(0) | 转发(0) |