网站公告列表

  没有公告

加入收藏
设为首页
联系本站
您现在的位置: AnalogCN安诺电子 >> 文章 >> 技术交流 >> 文章正文
  uclinux-2008r1(bf561)内核的icache支持(2):icplb_table的生成           ★★★ 【字体:
uclinux-2008r1(bf561)内核的icache支持(2):icplb_table的生成
作者:快乐虾    文章来源:http://blog.csdn.net/lights_joy    点击数:    更新时间:2008-5-19    
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的结束位置。
文章录入:admin    责任编辑:admin 
  • 上一篇文章:

  • 下一篇文章:
  • 发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    最新热点 最新推荐 相关文章
    前置放大器在移动医疗服务系
    便携式多通道大容量生理信号
    防腐监测仪的设计与应用
    基于AD1674的酶标仪的设计
    基于C/S模式的JRTPLIB库的测
    ffmpeg与jrtplib相结合应用
    blackfin模拟摄像头驱动中的
    可编程逻辑在数字信号处理系
    发现VDSP4.5一个BUG:单步调
    VDSP5.0双核工程下sml3中的变
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    版权所有:AnalogCN安诺电子 湘ICP备06016315号