//-------------------------------------------------------------------------------------------------
// 作者:wogoyixikexie@gliet
//论坛账号:gooogleman (经常在CSDN出没)
// 版权:桂林电子科技大学一系科协wogoyixikexie@gliet
// 平台:wince5.0 2440 5.0 BSP
// 发布日期:2009年9月29日16:18:35
// 最后修改:
// 注意事项:未经作者同意,不得在转载的时候擅自修改、删除文章的任何部分
//-------------------------------------------------------------------------------------------------
在eboot下我写了如下代码: volatile S3C2440A_IOPORT_REG *s2440IOP ; s2440IOP = (S3C2440A_IOPORT_REG *)OALPAtoVA(S3C2440A_BASE_REG_PA_IOPORT, FALSE);
s2440IOP->GPFDAT &=0xFB; mdelay(1);//如果我去掉这个延时,会导致s2440IOP->GPFDAT &=0xFB无效,加上延时才有效,也就是bit[2]不会等于零 s2440IOP->GPFDAT &=0xFE;
mdelay(1);//如果我去掉这个延时,会导致s2440IOP->GPFDAT &=0xFB无效,加上延时才有效 ——这个问题我觉得很奇怪,对于地址,是uncache地址了,怎么2440速度这么慢呢!我觉得很不解,加个延时,啥都好了,不会2440会这么奇怪吧。
还有,如果这样写 s2440IOP->GPFDAT=(s2440IOP->GPFDAT&0xFB)&0xFE;又完全正确,真是神了。
还有 // Set GPF0 as output pin s2440IOP->GPFCON &=~(1 < <1); s2440IOP->GPFCON |=(1 < <0);
这样一个与与一个或搭配又完全正确,
请问各位大侠,我是否犯了严重基础错误,我检查了一个下午,也找不出原因。
请指点,多谢。
===============================================================
s2440IOP->GPFDAT &=0xFB; mdelay(1);//如果我去掉这个延时,会导致s2440IOP->GPFDAT &=0xFB无效,加上延时才有效,也就是bit[2]不会等于零 s2440IOP->GPFDAT &=0xFE;
把上面的改成
s2440IOP->GPFDAT &=~(1 < <2); mdelay(1);//如果我去掉这个延时,会导致s2440IOP->GPFDAT &=~(1 < <2); 无效,加上延时才有效,也就是bit[2]不会等于零 s2440IOP->GPFDAT &=~(1 < <0);
如果我去掉这个延时会一样导致s2440IOP->GPFDAT &=~(1 < <2); 无效
========================================================
这个郁闷的问题郁闷了我好几天啊,后来有人提示是否是负载电容太大,我如梦初醒, 刚开始我还以为是MMU问题,结果关闭和打开一样的效果,嘿嘿。 是这样的,我的是买的开发板,我直接用接按钮的GPIO引出,没有想到这个按钮两端接了电容。 现在我的问题所有都解决了。 LCD也点亮了。嘿嘿。搞定NEC LCD,恭喜。
厚着脸皮写这个,希望同志们不要像我这么郁闷,一个GPIO搞了五天,天天测量,天天郁闷, 连开发板生意都没有心情做了。 嘿嘿,公司的事情解决,那么就开始6410学习了。 |