历史上的今天
今天是:2025年07月22日(星期二)
2020年07月22日 | ARM Linux中一些重要的宏及地址定义
2020-07-22 来源:elecfans
1)TEXT_OFFSET 内核在RAM中的起始位置相对于RAM起始地址偏移。值为0x00008000
。/arch/arm/Makefile
111 textofs-y := 0x00008000
112 textofs-$(CONFIG_ARCH_CLPS711X) := 0x00028000
113 # We don‘t want the htc bootloader to corrupt kernel during resume
114 textofs-$(CONFIG_PM_H1940) := 0x00108000
115 # SA1111 DMA bug: we don’t want the kernel to live in precious DMA-able memory
116 ifeq ($(CONFIG_ARCH_SA1100),y)
117 textofs-$(CONFIG_SA1111) := 0x00208000
118 endif
212 # The byte offset of the kernel image in RAM from the start of RAM.
213 TEXT_OFFSET := $(textofs-y)
2)PAGE_OFFSE 内核镜像起始虚拟地址。值为0xC0000000
arch/arm/Kconfig
1165 config PAGE_OFFSET ----这个就是CONFIG_PAGE_OFFSET宏,默认值为0xC0000000
1166 hex
1167 default 0x40000000 if VMSPLIT_1G
1168 default 0x80000000 if VMSPLIT_2G
1169 default 0xC0000000
。/arch/arm/include/asm/memory.h
34 #define PAGE_OFFSET UL(CONFIG_PAGE_OFFSET)
3)PHYS_OFFSET RAM启始物理地址,对应于DDR的物理地址。需要在mach-xxxx/include/mach/memory.h文件中定义这个宏。
对于2410来说值为0x30000000,RAM接在片选6上
arch/arm/mach-s3c2410/include/mach/memory.h
#define PHYS_OFFSET UL(0x30000000)
4)KERNEL_RAM_VADDR 内核在RAM中的虚拟地址。值为0xC0008000
5)KERNEL_RAM_PADDR 内核在RAM中的物理地址。值为0x30008000
arch/arm/kernel/head.S
29 #define KERNEL_RAM_VADDR (PAGE_OFFSET + TEXT_OFFSET)
30 #define KERNEL_RAM_PADDR (PHYS_OFFSET + TEXT_OFFSET)
6)swapper_pg_dir 初始页表虚拟地址,值为0xC0004000,
一般分配KERNEL_RAM_VADDR地址下16K作为页表,因此,我们必须确保正确设置KERNEL_RAM_VADDR。
arch/arm/kernel/head.S
44 .globl swapper_pg_dir
45 .equ swapper_pg_dir, KERNEL_RAM_VADDR - 0x4000
7)VMALLOC_START 0xc4800000
8)VMALLOC_END 0xe0000000
9)MODULES_VADDR 0xbf000000
10)MODULES_END 0xc0000000
arch/arm/include/asm/memory.h
47 #ifndef CONFIG_THUMB2_KERNEL
48 #define MODULES_VADDR (PAGE_OFFSET - 16*1024*1024)
49 #else
50 /* smaller range for Thumb-2 symbols relocation (2^24)*/
51 #define MODULES_VADDR (PAGE_OFFSET - 8*1024*1024)
52 #endif
53
54 #if TASK_SIZE 》 MODULES_VADDR
55 #error Top of user space clashes with start of module space
56 #endif
57
58 /*
59 * The highmem pkmap virtual space shares the end of the module area.
60 */
61 #ifdef CONFIG_HIGHMEM
62 #define MODULES_END (PAGE_OFFSET - PMD_SIZE)
63 #else
64 #define MODULES_END (PAGE_OFFSET)
65 #endif
11)PKMAP_BASE
arch/arm/include/asm/highmem.h:
6:#define PKMAP_BASE (PAGE_OFFSET - PMD_SIZE)
12)TASK_SIZE
。/arch/arm/include/asm/memory.h
34 #define PAGE_OFFSET UL(CONFIG_PAGE_OFFSET)
35 #define TASK_SIZE (UL(CONFIG_PAGE_OFFSET) - UL(0x01000000))
36 #define TASK_UNMAPPED_BASE (UL(CONFIG_PAGE_OFFSET) / 3)
13)一些不同地址之间转换的宏
。/arch/arm/include/asm/memory.h
135 /*
136 * Physical vs virtual RAM address space conversion. These are
137 * private definitions which should NOT be used outside memory.h
138 * files. Use virt_to_phys/phys_to_virt/__pa/__va instead.
139 */
140 #ifndef __virt_to_phys
141 #define __virt_to_phys(x) ((x) - PAGE_OFFSET + PHYS_OFFSET)//物理地址和虚拟地址
142 #define __phys_to_virt(x) ((x) - PHYS_OFFSET + PAGE_OFFSET)//之间转换的宏
143 #endif
144
145 /*
146 * Convert a physical address to a Page Frame Number and back
147 */
148 #define __phys_to_pfn(paddr) ((paddr) 》》 PAGE_SHIFT) //物理地址和页帧号之间
149 #define __pfn_to_phys(pfn) ((pfn) 《《 PAGE_SHIFT) //转换的宏
150
151 /*
152 * Convert a page to/from a physical address
153 */
154 #define page_to_phys(page) (__pfn_to_phys(page_to_pfn(page)))//页地址和物理地址
155 #define phys_to_page(phys) (pfn_to_page(__phys_to_pfn(phys)))//之间的转换宏依赖于内存模型。
201 /*
202 * Drivers should NOT use these either.
203 */
204 #define __pa(x) __virt_to_phys((unsigned long)(x))
205 #define __va(x) ((void *)__phys_to_virt((unsigned long)(x)))
206 #define pfn_to_kaddr(pfn) __va((pfn) 《《 PAGE_SHIFT)
207
208 /*
209 * Virtual 《-》 DMA view memory address translations
210 * Again, these are *only* valid on the kernel direct mapped RAM
211 * memory. Use of these is *deprecated* (and that doesn‘t mean
212 * use the __ prefixed forms instead.) See dma-mapping.h.
213 */
214 #ifndef __virt_to_bus
215 #define __virt_to_bus __virt_to_phys
216 #define __bus_to_virt __phys_to_virt
217 #define __pfn_to_bus(x) __pfn_to_phys(x)
218 #define __bus_to_pfn(x) __phys_to_pfn(x)
219 #endif
史海拾趣
|
想请教一下我用74hc4051 两个输出引脚短路的话芯片会不会烧坏啊 我是测试线路故障中用的 如果线路连接短路了 我中间用这个开关芯片测试,芯片会不会烧坏啊 谢谢了… 查看全部问答> |
|
目前在北京学习嵌入式linux, 主要学习C语言、UNIX环境高级编程、ARM、设备驱动开发, 八月份就要面临结业找工作了。 因为我是从长春辞职出来培训的,女友在长春做医药代表也做的很好,我的很多朋友也都在长春,所以想回长春找工作, 但是 ...… 查看全部问答> |
|
HDC hDC = GetDC(hWnd); BitBlt(g_hBufDC,0,0,ScreenW,ScreenH,g_hMapDC,0,0,SRCCOPY); BitBlt(hDC,0,0,ScreenW,ScreenH,g_hBufDC,0,0,SRCCOPY); 只显示 ...… 查看全部问答> |
|
如: BOOL func() { if(~~) { return fALSE; //flag 1 } if(##) {~~~; ~~~; ~~~; & ...… 查看全部问答> |
|
浅谈PLC学习的5个阶段 一.逻辑阶段所谓的逻辑阶段就是可以实现继电系统中的一般逻辑性设计,既然是继电系统所以电力拖动知识就是该阶段的基础。我个人总结学习继电系统的根在于一个字“抢”,继电系统之所以能实现逻辑控制就在这个字上。继电系统 ...… 查看全部问答> |
|
我用STM32读外部RTC(8025),IIC通讯,主机发0x64后,然后开始读,通过示波器我发的数据是对的,0x64+读标志位=发的应该是0x65,但没有收到应答位,速度100K,第一次执行I2C_Send7bitAddress,发的是0x65,是8位,没有收到应答位,再单步执 ...… 查看全部问答> |
|
LM3S811的AD采样,为什么始终不执行ADCProcessorTrigger(ADC_BASE,0);函数? 程序编译不报错,但是执行到了ADCProcessorTrigger(ADC_BASE,0);,就没反应了,中断函数也没执行,后面的都不执行?为什么啊?… 查看全部问答> |
|
谁有过430G2553的ilb。isis能用的或者protel 我想仿真一下,但是没有给G2553的lib,我现实中有没有一些器件,搞得我现在还是小白白。求大哥大姐,帮忙一下。给我个lib或者怎么才能仿真,我是小白,希望能详细讲解一下,实在是没有空,就给我说个方向。… 查看全部问答> |




