由指针而引发的bug, 非常难发现

今天下午在那儿调一个程序,看了半天都没有看出问题所在,最后查出来问题就是出在指针上面,特此记下,以备以后查看。

if (pd_addr & PTE_P)
{
    return (pte_t *)(KADDR(PTE_ADDR(pd_addr)) + PTX(la));
}

最主要的问题就上面这条语句上。改为以下形式后工作正常了。

if (pd_addr & PTE_P)
{
    return (pte_t *)KADDR(PTE_ADDR(pd_addr)) + PTX(la);
}

pte_t定义为 unsigned int, 而KADDR返回的一个void *的指针。如果先加上括号,也就是上面出错的情况,对指针的偏移量是PTX(la), 而如果改为正确的情况,也就是去掉括号后的情况,偏移量变为PTX(la) * sizeof(pte_t *)。

你可能感兴趣的:(由指针而引发的bug, 非常难发现)