打印

相应的管脚寄存器数据不改变一直是0xBAD0BAD0

[复制链接]
1299|35
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
wyjie|  楼主 | 2018-11-2 20:18 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

#include "inc/hw_ints.h"
#include "inc/hw_memmap.h"
#include "inc/hw_types.h"
#include "driverlib/gpio.h"
#include "driverlib/sysctl.h"
#define PINS GPIO_PIN_6
void delay(int d)
{
        for(;d;--d);
}
void SysCtlClockSet(unsigned long ulConfig)
{}

void   SysCtlPeripheralEnable (unsigned long ulPeripheral)
{}

void GPIODirModeSet(unsigned long ulPort,unsigned char ucPins,unsigned long ulPinIO)
{}

void GPIOPinWrite(unsigned long ulPort, unsigned char ucPins, unsigned char ucVal)
{}

int main(void)
{
        unsigned int i;

          SysCtlClockSet(SYSCTL_SYSDIV_1|SYSCTL_USE_OSC|SYSCTL_OSC_MAIN|SYSCTL_XTAL_6MHZ);//直接使用外部晶振
          SysCtlPeripheralEnable(SYSCTL_PERIPH_GPIOB);//使能GPIO的PB模块
          GPIODirModeSet(GPIO_PORTB_BASE,PINS,GPIO_DIR_MODE_OUT);//设置PB6输出
          for(i=0;i<10;i++)
          {
                  GPIOPinWrite(GPIO_PORTB_BASE,PINS,~PINS);//置PB6低电平
                  delay(20000);
                  GPIOPinWrite(GPIO_PORTB_BASE,PINS,PINS);//置PB6高电平
                  delay(20000);
          }
          SysCtlClockSet(SYSCTL_SYSDIV_1|SYSCTL_USE_PLL|SYSCTL_OSC_MAIN|SYSCTL_XTAL_6MHZ);//使用PLL
          for(i=0;i<10;i++)
          {GPIOPinWrite(GPIO_PORTB_BASE,PINS,~PINS);
          delay(20000);
          GPIOPinWrite(GPIO_PORTB_BASE,PINS,PINS);
          delay(20000);
          }

          return 0;

}
用的CCSV5 单步执行能执行,但是发现相应的管脚寄存器数据不改变一直是0xBAD0BAD0

相关帖子

沙发
jiajs| | 2018-11-2 20:21 | 只看该作者
请问楼上这个是为什么吗?我不是很懂啊

使用特权

评论回复
板凳
wyjie|  楼主 | 2018-11-2 20:26 | 只看该作者

而且没有使能的GPIO A C D模块能看到数据~按理说我没有使能的模块 应该显示 cant read   求指导
向0x20000000写入数据时  数据能正确写入

使用特权

评论回复
地板
zhanghqi| | 2018-11-2 20:30 | 只看该作者

楼主能截个图传上来看看嘛?
0xBAD0BAD0是哪个管脚寄存器的数值?

使用特权

评论回复
5
zhenykun| | 2018-11-2 20:33 | 只看该作者
用GPIOPinWrite(GPIO_PORTB_BASE, GPIO_PIN_6, 1)和GPIOPinWrite(GPIO_PORTB_BASE, GPIO_PIN_6, 0)这两句试试

使用特权

评论回复
6
jlyuan| | 2018-11-2 20:37 | 只看该作者
是不是没使能APB或者AHB的原因?

使用特权

评论回复
7
wyjie|  楼主 | 2018-11-2 20:40 | 只看该作者
我只是使能了GPIOB模块  然后设置为输出  就置高置低  其他的不是大懂呢

使用特权

评论回复
8
wyjie|  楼主 | 2018-11-2 20:43 | 只看该作者
我看一般的例程 都没有提到使能AHB  APB  我觉得应该使能GPIO  然后设置为输出好像就可以了

使用特权

评论回复
9
dengdc| | 2018-11-2 20:46 | 只看该作者
你单步调试的时候,点那个刷新试试了吗?有时寄存器串口会更新不及时

使用特权

评论回复
10
wyjie|  楼主 | 2018-11-6 16:45 | 只看该作者
点了  我也不知道这是什么情况用HWREG(0x200000000)能写入数据  但是向HWREG(0x400000000)不能写入  因为后者是向GPIO写入 而我没有使能所以写入不成功,我使能之后依然不能写入

使用特权

评论回复
11
wyjie|  楼主 | 2018-11-6 16:48 | 只看该作者

我用HWREG(0x400FE000)=0x2//使能GPIOB模块

确实能正确执行,是不是说明我调用的头文件中没有包含GPIOPinWrite函数 ?

使用特权

评论回复
12
heweibig| | 2018-11-6 16:51 | 只看该作者

改进一下

使用特权

评论回复
13
wyjie|  楼主 | 2018-11-6 16:54 | 只看该作者
使能函数  配置输入输出函数单步执行都不改变, 我也包含了该包含的  头文件了?不清楚为什么还是出现这个问题?

使用特权

评论回复
14
jiahy| | 2018-11-6 16:57 | 只看该作者
一般GPIO相关的API都在src/gpio.c中

使用特权

评论回复
15
wuhany| | 2018-11-6 17:00 | 只看该作者
0xBAD0BAD0是哪个管脚寄存器的数值

使用特权

评论回复
16
wyjie|  楼主 | 2018-11-6 17:03 | 只看该作者
嗯,我再好好缕一缕吧,有了好消息及时通知大家,结贴喽

使用特权

评论回复
17
wwppd| | 2018-11-7 13:26 | 只看该作者
实际电平状态不一致?

使用特权

评论回复
18
jkl21| | 2018-11-7 13:26 | 只看该作者
怎么看到个寄存器和引脚输出啊?

使用特权

评论回复
19
maqianqu| | 2018-11-7 13:27 | 只看该作者
一般用到哪个管脚操作的就是那个管脚

使用特权

评论回复
20
dspmana| | 2018-11-7 13:27 | 只看该作者
配置正确了吗

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

927

主题

12706

帖子

5

粉丝