void R_PORT_Create(void)
{
P7 = _01_Pn0_OUTPUT_1 | _00_Pn2_OUTPUT_0 | _00_Pn7_OUTPUT_0;
PM7 = _00_PMn0_MODE_OUTPUT | _02_PMn1_MODE_INPUT | _ 00_PMn2_MODE_OUTPUT | _08_PMn3_MODE_INPUT | _10_PMn4_NOT_USE |
_20_PMn5_NOT_USE | _40_PMn6_NOT_USE | _00_PMn7_MODE_OUTPUT;
}
这是个标准定义。
调用的话。
P7&=_00_Pn7_OUTPUT_0;//=0
P7|=_80_Pn7_OUTPUT_1;//=1
而输入输出转换标准定法是这样的:
void PORT_ChangeP00Input(BOOL enablepu)
{
if (enablepu)
{
PU0 |= _01_PUn0_PULLUP_ON;
}
else
{
PU0 &= (UCHAR)~_01_PUn0_PULLUP_ON;
}
PM0 |= _01_PMn0_MODE_INPUT;
}
这么定义我感觉读起来有点累。
用宏定义又太麻烦?
大家现在是怎么定义的啊。
用宏定义成C51的那种方式
P77=0; /// P7 &= _00_Pn7_OUTPUT_0;//=0
P77=1;
大家是这样定义的不??是不?????
关于IO的输入输出选换也可以定义成宏方式不?
这样为什么不对?如下
#define SDA=0 P7&=_00_Pn7_OUTPUT_0
SDA=0;
我要赚赏金打赏帖 |
|
|---|---|
| 【S32DS】S32K3 RTD7.0.1 HSE 组件配置报错问题解决被打赏¥27元 | |
| 【S32K3XX】MCME 启动 CORE1被打赏¥23元 | |
| AG32VH407下温度大气压传感器及其检测被打赏¥20元 | |
| AG32VH407下光照强度传感器BH1750及其检测被打赏¥22元 | |
| AT32VH407下使用温湿度传感器DHT22进行检测被打赏¥20元 | |
| DIY一个婴儿澡盆温度计被打赏¥34元 | |
| 【FreeRtos】FreeRtos+MPU region 配置规则被打赏¥23元 | |
| 【分享开发笔记,赚取电动螺丝刀】三分钟快速上手驱动墨水屏(ArduinoIDE)被打赏¥28元 | |
| 【S32K3XX】LIN 通讯模块使用被打赏¥31元 | |
| 【FreeRtos】FreeRtos + MPU模块的配置使用被打赏¥32元 | |
我要赚赏金
