#define RALINK_PRGIO_ADDR RALINK_PIO_BASE // Programmable I/O
#define RALINK_SYSCTL_ADDR RALINK_SYSCTL_BASE
#define GPIO_MODE (RALINK_SYSCTL_ADDR + 0x60)
#define RALINK_REG_PIO2100INT (RALINK_PRGIO_ADDR + 0x00) //设置中断
#define RALINK_REG_PIO2100EDGE (RALINK_PRGIO_ADDR + 0x04) //触发方式
#define RALINK_REG_PIO2100RENA (RALINK_PRGIO_ADDR + 0x08) //上升沿触发
#define RALINK_REG_PIO2100FENA (RALINK_PRGIO_ADDR + 0x0C) //下降沿触发
#define RALINK_REG_PIO2100DATA (RALINK_PRGIO_ADDR + 0x20) //IO口数据位
#define RALINK_REG_PIO2100DIR (RALINK_PRGIO_ADDR + 0x24) //IO方向
#define RALINK_REG_PIO2100PIO (RALINK_PRGIO_ADDR + 0x28) //反转对应的IO时,对应的位也要置1
#define RALINK_REG_PIO2100SET (RALINK_PRGIO_ADDR + 0x2C)
#define RALINK_REG_PIO2100RESET (RALINK_PRGIO_ADDR + 0x30)
#define RALINK_REG_PIO2100TOGGLE (RALINK_PRGIO_ADDR + 0x34)
#define WORK_LED (1<<9)
static void init_gpio()
{
int gpiomode = le32_to_cpu(*(volatile u32 *)(GPIO_MODE));
gpiomode |= GPIOMODE_JTAG|(7<<2);
*(volatile u32 *)(GPIO_MODE) = cpu_to_le32(gpiomode);
*(volatile u32 *)(RALINK_REG_PIO2100DIR) |= cpu_to_le32(WORK_LED) ; //set pin outpuT
*(volatile u32 *)(RALINK_REG_PIO2100PIO) |= cpu_to_le32(WORK_LED) ;
tem = *(volatile u32 *)(RALINK_REG_PIO2100SET);
tem |= cpu_to_le32(WORK_LED) ;
*(volatile u32 *)(RALINK_REG_PIO2100SET) =tem;
*(volatile u32 *)(RALINK_REG_PIO2100TOGGLE)|=cpu_to_le32(WORK_LED);
*(volatile u32 *)(RALINK_REG_PIO2100DATA)|=cpu_to_le32(WORK_LED);
*(volatile u32 *)(RALINK_REG_PIO2100DIR) = 0;
int gpiodata = *(volatile u32 *)RALINK_REG_PIO2100DATA;
printk("gpiodata === %x\n",gpiodata);
}
参照datasheet配置gpio,想把第9位拉高,可不管怎么配置,都改变不了第9位gpio的状态。
通过读RALINK_REG_PIO2100DATA,第9位已经置1,但是去量引脚还是低电平(硬件是绝对没问题的),求解?????????????