PXA3xx_MFP_CFG(desc, pin, af, drv, rdh, lpm, edge)宏定义中rdh参数是用来设置进入或退出low power时GPIO的电平由什么决定,为0时进入low power时由lpm决定,离开时恢复原值,为1时GPIO的值由ASCR[RDH]决定,一般该参数设置为0;lpm参数的作用是当系统由工作模式进入省电模式后,该GPIO的状态,是输出0或1,还是输入pull high或pull low。
Pull hight或者pull low只有在input pin时才有效。下/上拉电阻的主要目的就是防止Pin悬空,悬空的Pin可以看作一个天线,它容易受外界干扰,造成Pin值的不确实性。下/上拉电阻能够给Input Pin一个默认的输入值,下拉电阻接地,默认输入低电平,上拉电阻接电源,默认输入高电平。当真正有外接输入时,它们自动无效,同时避免短路,起到限流作用。
#define MFP_LPM_DRIVE_LOW
#define MFP_LPM_DRIVE_HIGH
#define MFP_LPM_PULL_HIGH
#define MFP_LPM_PULL_LOW
#define MFP_LPM_FLOAT
#define MFP_LPM_PULL_NEITHER
下面举两个例子来说明:
CHG_CHGING是input pin,所以lpm参数应设置为MFP_LPM_PULL_HIGH;
由于SYS_EN是output pin,所以lpm参数应根据datasheet说明来设置为MFP_LPM_DRIVE_LOW或MFP_LPM_DRIVE_HIGH或MFP_LPM_PULL_NEITHER;
若SYS_EN是input pin,则lpm参数应设置为MFP_LPM_PULL_LOW。
详情可参考
PXA3xx_DM_Vol_I.pdf中的4.10;
以及http://blog.youkuaiyun.com/absurd/archive/2007/07/09/1683936.aspx
1.纠正一个错误,关于上次说的在sleep的时候的上拉下拉电阻,其实pullup_en,pulldown_en参数是启用cpu内部的该GPIO口上的上拉或下拉电阻,所以如果外部电路中已经有上拉或下拉电阻了,我们就没必要再启用cpu内部的上拉或下拉电阻了。
2.在suspend的时候用pxa3xx_gpio_set_direction函数来更改pin的方向看起来是不行的,
因为MFPR寄存器中有一个单独的位sleep_oe_n,专门用来设置在S2状态下pin的方向,所以要更改S2状态下pin的方向,必须设置这个bit,
这个是在GPIO初始化的时候用PXA3xx_MFP_CFG宏来设置。
具体请参考PXA3xx_DM_Vol_I.pdf中的4.10。