Linux内核定义的常量

转载 2007年10月07日 05:28:00

定义了你的机器上的地址转换__virt_to_phys()。这个宏用于把虚拟地址转换为一个物理地址。通常情况下:

             phys = virt - PAGE_OFFSET + PHYS_OFFSET

2 解压缩符号

l         ZTEXTADDR

解压缩器的地址地址。由于当你调用解压缩器代码时,通常关闭MMU,因此这里并不讨论虚拟地址和物理地址的问题。通常你在这个地址处调用内核,开始引导内核。它不需要在RAM中,只需要位于FLASH或其他只读或读/写的可寻址的存储设备中。

l         ZBSSADDR

解压缩器的初始化为0的工作区的起始地址。必须位于RAM中,解压缩器会替你把它初始化为0,此外,需要关闭MMU

l         ZRELADDR

解压缩内核将被写入的地址和最终的执行地址。必须满足:

__virt_to_phys(TEXTADDR) == ZRELADDR

内核的开始部分被编码为与位置无关的代码。

l         INITRD_PHYS

放置初始RAM盘的物理地址。仅当你使用bootpImage时相关(这是一种非常老的param_struct结构)

l         INITRD_VIRT

初始RAM盘的虚拟地址。必须满足:

__virt_to_phys(INITRD_VIRT) == INITRD_PHYS

l         PARAMS_PHYS

param_struct 结构体或tag lis的物理地址,用于给定内核执行环境下的不同参数。

3 内核符号

l         PHYS_OFFSET

RAM第一个BANK的物理地址地址。

l         PAGE_OFFSET

RAM第一个BANK的虚拟地址地址。在内核引导阶段,虚拟地址PAGE_OFFSE将被映射为物理地址PHYS_OFFSET,它应该与TASK_SIZE具有相同的值。

l         TASK_SIZE

一个用户进程的最大值,单位为byte。用户空间的堆栈从这个地址处向下增长。

任何一个低于TASK_SIZE的虚拟地址对用户进程来说都是不可见的,因此,内核通过进程偏移对每个进行进行动态的管理。我把这叫做用户段。任何高于TASK_SIZE的对所有进程都是相同的,称之为内核段。(换句话说,你不能把IO映射放在低于TASK_SIZEPAGE_OFFSET的位置处。)

l         TEXTADDR

内核的虚拟起始地址,通常为PAGE_OFFSET + 0x8000。内核映射必须在此结束。

l         DATAADDR

内核数据段的虚拟地址,不能在使用解压缩器的情况下定义。

l         VMALLOC_START

l         VMALLOC_END

用于限制vmalloc( )区域的虚拟地址。此地址必须位于内核段。 通常,vmalloc( )区域在最后的虚拟RAM地址以上开始VMALLOC_OFFSET字节。

l         VMALLOC_OFFSET

Offset normally incorporated into VMALLOC_START to provide a hole between virtual RAM and the vmalloc area. We do this to allow out of bounds memory accesses (eg, something writing off the end of the mapped memory map) to be caught. Normally set to 8MB.

4 构架相关的宏

l         BOOT_MEM(pram,pio,vio)

pram——指定了RAM起始的物理地址,必须始终存在,并应等于PHYS_OFFSET

pio——是供arch/arm/kernel/debug-armv.S中的调试宏使用的,包含IO8 MB区域的物理地址。

vio——是8MB调试区域的虚拟地址。

这个调试区域将被位于代码中(通过MAPIO函数)的随后的构架相关代码再次进行初始化。

l         BOOT_PARAMS

参见 PARAMS_PHYS.

l         FIXUP(func)

机器相关的修正,在存储子系统被初始化前运行。

l         MAPIO(func)

机器相关的函数,用于IO区域的映射(包括上面的调试区)。

l         INITIRQ(func)

用于初始化中断的机器相关的函数

 
 

相关文章推荐

linux内核源码中常见宏定义

1. gcc的__attribute__编绎属性 要了解Linux Kernel代码的分段信息,需要了解一下gcc的__attribute__的编绎属性,__attribute__主要用于改变所声明...

从一个简单的宏定义看linux内核的严谨,窥C语言的强大(ZZ

include/linux/kernel.h ------------------------------------------------------ /*  * min()/max() m...

Linux内核源码中使用宏定义的若干技巧

在C中,宏定义的概念虽然简单,但是真要用好却并不那么容易,下面从Linux源码中抽取一些宏定义的使用方法,希望能从中得到点启发: 1. 类型检查 比如module_init的宏定义: ...

盘点Linux内核源码中使用宏定义的若干技巧(1)

盘点Linux内核源码中使用宏定义的若干技巧(1) (2012-03-20 21:30) 标签:  Linux内核源码  宏定义  宏的使用技巧  分类: Linux系统内核 ...

Linux内核导出符号宏定义EXPORT_SYMBOL的源码分析

源代码: ……. #ifndef MODULE_SYMBOL_PREFIX #define MODULE_SYMBOL_PREFIX "" #endif ……. struct kernel_symb...

linux内核中3个定义错误号的头文件

查看错误号(errno,一个整数值)是调试程序的一个重要方法。当linux内核中的函数发生异常时,一般会将errno的负值返回,通过查看该值就可找到出错的原因。 1-34号在include/...

【转】 从一个简单的宏定义看linux内核的严谨,窥C语言的强大(ZZ)

include/linux/kernel.h ------------------------------------------------------ /*  * min()/max() m...

Linux内核源码--min,swap宏定义

Linux3.5的部分宏定义在Linux-3.5/include/linux/kernel.h的头文件中有定义 一: 最大值和最小值相关的宏 [cpp] view ...

【C语言】Linux内核源码--min,swap宏定义

Linux3.5的部分宏定义在linux-3.5/include/linux/kernel.h的头文件中有定义 /* * min()/max()/clamp() macros that also d...

linux内核宏定义

linux内核宏定义1. gcc的__attribute__编绎属性要了解Linux Kernel代码的分段信息,需要了解一下gcc的__attribute__的编绎属性,__attribute__主...
  • lqx4_3
  • lqx4_3
  • 2011-04-21 15:06
  • 1182
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)