uclinux-2008r1(bf561)内核的icache支持(2):icplb_table的生成
来源:互联网 发布:西安大数据公司 编辑:程序博客网 时间:2024/05/21 08:41
icplb_table的生成是由generate_cpl_tables实现的。以下代码删除了与icplb初始化化无关的部分:
void __init generate_cpl_tables(void)
{
u16 i, j, process;
u32 a_start, a_end, as, ae, as_1m;
struct cplb_tab *t_i = NULL;
struct s_cplb cplb;
cplb.init_i.size = MAX_CPLBS;
cplb.init_i.pos = 0;
cplb.init_i.tab = icplb_table;
for (i = ZERO_P; i < ARRAY_SIZE(cplb_data); ++i) {
if (!cplb_data[i].valid)
continue;
as = cplb_data[i].start % SIZE_4M;
ae = cplb_data[i].end % SIZE_4M;
if (as)
a_start = cplb_data[i].start + (SIZE_4M - (as));
else
a_start = cplb_data[i].start;
a_end = cplb_data[i].end - ae;
for (j = INITIAL_T; j <= SWITCH_T; j++) {
switch (j) {
case INITIAL_T:
if (cplb_data[i].attr & INITIAL_T) {
t_i = &cplb.init_i;
t_d = &cplb.init_d;
process = 1;
} else
process = 0;
break;
default:
process = 0;
break;
}
if (!process)
continue;
if (cplb_data[i].attr & I_CPLB)
__fill_code_cplbtab(t_i, i, a_start, a_end);
}
}
/* close tables */
close_cplbtab(&cplb.init_i);
cplb.init_i.tab[cplb.init_i.pos] = -1;
}
在这里cplb_data是在文件头中定义的一个10个元素的数组,它详细说明了每块内存的属性,如大小,类型等等。
当程序运行到__fill_code_cplbtab时,以下几块将被填入ICPLB的数组中:
{
.start = L1_CODE_START,
.end = L1_CODE_START + L1_CODE_LENGTH,
.psize = SIZE_4M,
.attr = INITIAL_T | SWITCH_T | I_CPLB,
.i_conf = L1_IMEMORY,
.d_conf = 0,
.valid = 1,
.name = "L1 I-Memory",
},
{
.start = 0,
.end = 0, /* dynamic */
.psize = 0,
.attr = INITIAL_T | SWITCH_T | I_CPLB | D_CPLB,
.i_conf = SDRAM_IGENERIC,
.d_conf = SDRAM_DGENERIC,
.valid = 1,
.name = "Kernel Memory",
},
其中,Kernel Memory这个块的.end已经设置为SDRAM的结束位置。
- uclinux-2008r1(bf561)内核的icache支持(2):icplb_table的生成
- uclinux-2008r1(bf561)内核的icache支持(3):__fill_code_cplbtab
- uclinux-2008r1(bf561)内核的icache支持(1):寄存器配置初始化
- uclinux-2008r1(bf561)内核的icache支持(4):换页问题
- uclinux-2008r1-rc8(bf561)内核的console(1):数据结构
- 重读uclinux-2008r1-rc8(bf561)内核的中断处理(2):中断配置
- uclinux-2008r1-rc8(bf561)内核的console(2):驱动初始化
- uclinux-2008r1-rc8(bf561)的中断处理(2):evt_nmi
- uclinux-2008r1(bf561)内核中的EXPORT_SYMBOL
- uclinux-2008r1(bf561)内核中的per_cpu
- 再读uclinux-2008r1-rc8(bf561)内核的中断处理(1):数据结构
- 重读uclinux-2008r1-rc8(bf561)内核的中断处理(3):中断处理流程
- 重读uclinux-2008r1-rc8(bf561)内核的中断处理(4):特定处理函数
- uclinux-2008r1-rc8(bf561)内核的console(3):通过console输出信息
- uclinux-2008r1(bf561)内核中与存储管理相关的几个全局变量
- uclinux-2008r1(bf561)内核中内存管理相关的几个结构体
- uclinux-2008R1-RC8(bf561)到VDSP5的移植(59): Milestone:内核成功启动
- uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(75):Milestone:内核成功启动
- linux下手动安装postgresql
- uclinux-2008r1(bf561)内核的icache支持(1):寄存器配置初始化
- oracle 函数说明
- 几个细节提高你的网上商店可信度
- ExecuteNonQuery方法教训
- uclinux-2008r1(bf561)内核的icache支持(2):icplb_table的生成
- Linux下的经典文件共享设置(NFS篇)
- table
- 自然力前,人类如此渺小
- 编写windows服务遇到的问题
- WebPart的数据库连接问题
- 将属性的XML解析成对象数组列表
- Learning python 系列1
- jar | war | ear |