3346|5

99

帖子

0

TA的资源

一粒金砂(中级)

楼主
 

GPIO寄存器问题 [复制链接]

#define GPIO_BASE                0x40028000        /* GPIO registers base*/
GPIO寄存器定义
typedef struct
{
        volatile UNS_32 pio_inp_state;   /* Input pin state register */
        volatile UNS_32 pio_outp_set;    /* Output pin set register */
        volatile UNS_32 pio_outp_clr;    /* Output pin clear register */
        volatile UNS_32 pio_outp_state;  /* Output pin state register */
        volatile UNS_32 pio_dir_set;     /* GPIO direction set register */
        volatile UNS_32 pio_dir_clr;     /* GPIO direction clear register */
        volatile UNS_32 pio_dir_state;   /* GPIO direction state register */
        volatile UNS_32 pio_sdinp_state; /* SDRAM-Input pin state register*/
        volatile UNS_32 pio_sdoutp_set;  /* SDRAM-Output pin set register */
        volatile UNS_32 pio_sdoutp_clr;  /* SDRAM-Output pin clear register*/
        volatile UNS_32 pio_mux_set;     /* PIO mux control set register*/
        volatile UNS_32 pio_mux_clr;     /* PIO mux control clear register*/
        volatile UNS_32 pio_mux_state;   /* PIO mux state register */
        volatile UNS_32 reserved1 [3];
        volatile UNS_32 p0_pin_read;    /* P0 GPIOs pin read register */
        volatile UNS_32 p0_outp_set;    /* P0 GPIOs output set register */
        volatile UNS_32 p0_outp_clr;    /* P0 GPIOs output clear register */
        volatile UNS_32 p0_outp_state;  /* P0 GPIOs output state register */
        volatile UNS_32 p0_dir_set;     /* P0 GPIOs direction set reg */
        volatile UNS_32 p0_dir_clr;     /* P0 GPIOs direction clear reg */
        volatile UNS_32 p0_dir_state;   /* P0 GPIOs direction state reg */
。。。。。。。。。。。。。。。。

} GPIO_REGS_T;
#define GPIO  ((GPIO_REGS_T *)(GPIO_BASE))
****************************************************************************************
但手册里实际的寄存器
Port 3
0x4002 8000 P3_INP_STATE
0x4002 8004 P3_OUTP_SET
0x4002 8008 P3_OUTP_CLR
0x4002 800C P3_OUTP_STATE
Port 2
0x4002 801C P2_INP_STATE
0x4002 8020 P2_OUTP_SET
0x4002 8024 P2_OUTP_CLR
0x4002 8010 P2_DIR_SET
0x4002 8014 P2_DIR_CLR
0x4002 8018 P2_DIR_STATE
Port 0
0x4002 8040 P0_INP_STATE
0x4002 8044 P0_OUTP_SET
0x4002 8048 P0_OUTP_CLR
0x4002 804C P0_OUTP_STATE
0x4002 8050 P0_DIR_SET
0x4002 8054 P0_DIR_CLR
0x4002 8058 P0_DIR_STATE
Port 1
0x4002 8060 P1_INP_STATE
0x4002 8064 P1_OUTP_SET
0x4002 8068 P1_OUTP_CLR
0x4002 806C P1_OUTP_STATE
0x4002 8070 P1_DIR_SET
0x4002 8074 P1_DIR_CLR
0x4002 8078 P1_DIR_STATE
。。。。。。。。。
对比发现寄存器排列顺序不一致啊,那他们怎么能相互对应起来呢

最新回复

哈哈,这个东西估计不是2440的,X86的吧  详情 回复 发表于 2008-10-22 16:19
点赞 关注

回复
举报

81

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
你在结构中可以定义一些reserved的无用变量啊,反正能对齐就可以了
 
 

回复

66

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
是对应的,只是他名字不一样而已。。。
 
 
 

回复

82

帖子

0

TA的资源

一粒金砂(初级)

4
 
引用 2 楼 andylao62 的回复:
是对应的,只是他名字不一样而已。。。


唉,这个问题我回答过,不过现在我也找不到在哪里了,挺长的,现在没有空回答。---我觉得楼主你要看看C语言,结构体那部分以及ARM的数据手册,地址等,我只能这么建议了
楼主你在搜索栏里面搜索“IO”估计还可以找到。唉。建议eeworld把一些初学者必备的问题分到一个标签下,让他们自己去看,免得重复发这些问题。浪费资源。
 
 
 

回复

75

帖子

0

TA的资源

一粒金砂(初级)

5
 
我明白那个结构体的,只是它命名的方式不一样,弄得我看了好半天的
 
 
 

回复

92

帖子

0

TA的资源

一粒金砂(初级)

6
 
引用 4 楼 andylao62 的回复:
我明白那个结构体的,只是它命名的方式不一样,弄得我看了好半天的


哈哈,这个东西估计不是2440的,X86的吧
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表