2009年2月20日星期五

EP93xx GPIO interface

名词

AMBA是EP93xx采用的内部总线结构,他包含一个高速总线(AHB)和一个低速总线(APB)。

AHB (Advanced High-Performance Bus),包含一个高速内部总线时钟,用来同步协处理 器、MMU、cache、DMA控制器和其他内存模块。

APB (Advanced Peripheral Bus),此总线就来连接一些低速并行设备,比如UART和GPIO。 AHB 和 APB 使用 AMBA 架构中的 AHB/APB 总线连接,

GPIO (General Purpose I/O),GPIO在EP93xx中是APB的一个子模块,他提供简单的LED控制, 可实现非常基础的调试功能(相当于printk?)。

GPIO

GPIO 包含两种类型和8个接口。

  • 标准GPIO (port C, D, E, G, H)。每个端口包含两组寄存器
    1. data reg x1
    2. data direction reg x1
  • 增强型的GPIO(EGPIO, port A, B, F),包含三种寄存器
    1. data reg x1
    2. data direction reg x1
    3. intr reg and status regs x?

标准GPIO的每个端口都包含一个8位数据寄存器(data regs)和另外的8位数据方向寄存器 (datadirection regs)。而EGPIO还会多包含一组8位中断控制寄存器。

ABF端口还包括了七个多余的寄存器。

  1. GPIO Interrupt Enable registers (GPIOAIntEn, GPIOBIntEn, GPIOFIntEn)
  2. GPIO Interrupt Type 1 registers (GPIOAIntType1, GPIOBIntType1, GPIOFIntType1)
  3. GPIO Interrupt Type 2 registers (GPIOAIntType2, GPIOBIntType2, GPIOFIntType2)
  4. GPIO End-Of-Interrupt registers (GPIOAEOI, GPIOBEOI, GPIOFEOI)
  5. GPIO Debounce registers (GPIOADB, GPIOBDB, GPIOFDB)
  6. Interrupt Status registers (IntStsA, IntStsB, IntStsF)
  7. Raw Interrupt Status registers (RawIntStsA, RawIntStsB, RawIntStsF)

GPIO 初始化

系统复位的时候,GPIO 会执行初始化。

  • 所有端口的 data reg 和 data direction reg 都将清零,设置为 input 方式
  • Port E[1:0] 用来表示 RDLED 和 GRLED,他们将会被置高,也就是 0x11
  • Port G[3:2] 用来表示 SLA[1:0] 输出,他们被置低。
  • Port G[1:0] 用来表示 EEDAT 和 EECLK,设置为 input 方式
  • 所有的中断控制寄存器和祛抖动寄存器都被清零

GPIO端口和针脚映射

EP93xx的阵脚情况不一样,后继版本的板子总是多了点,下面只是列出EP9301/EP9302的针 脚映射:

主板针脚名称 位于GPIO模块上的端口
EGPIO[7:0] Port A
EGPIO[15:8] Port B
GRLED1 Port E0
RDLED2 Port E1
EECLK3 Port G0
EEDAT4 Port G1

GPIO 寄存器映射

鉴于GPIO寄存器很多,我也就不列出来了。

只是说几个要点。

  1. PADR ― PHDR,数据寄存器
    • 读取这些寄存器将会返回GPIO模块输入端口的值(由PXDDR控制),默认情况是缺省端 口映射下的端口状态信息。
  2. PEDR,他的bit[1:0]提供了LED 驱动方法,默认是0x11
  3. RAWSTATUSx,共三个寄存器。显示了无关针脚的读取状态

寄存器索引

引用

  1. EP9302 User's Guide

2009年2月17日星期二

新章: 试用LXDE Desktop Environment

闲聊

好了,很长时间没写字,我都不知道如何动笔了。

其实不是不想写,也非过年过皮实了,而是这些天都在忙活。从过年来,天天加班到九点, 回到家里还要折腾自己的小窝,面对邪恶的加菲,我在家里几乎无所事事。但是我也没闲着, 天天折腾到两三点,至于我干什么?我在折腾这两年累计的东西呢。

就说今天干了什么吧。

新手接触 LXDE

我今天测试了一下新的桌面环境LXDE,这是来自彼岸的台湾同胞洪任谕开发的(他同时也是 PC Man文件管理器的作者)。LXDE是非常小巧的羽量级桌面环境,他的桌面组建加载的很少, 这样本身的代码量就比较小(加起来总共只有9M左右),这样运行起来就很快很快。

LXDE采用了openbox作为窗口管理器,这个东西也是非常的迅速。使用的文件浏览器是看家 的 pcmanfm,一些官方维护的组件如下:

  • PCManFM,文件管理器,类似于Nautilus
  • LXLauncher,一个快速启动面板
  • LXPanel,简洁的桌面面板,类似于 gnome-panel
  • LXSession,会话管理器
  • LXAppearance,主题管理器
  • LXSessionEdit,进化的任务管理器
  • Leafpad,默认的记事本
  • Xarchiver,内嵌的归档管理器
  • GPicView
  • LXTerminal
  • LXTask
  • LXNM
  • Openbox
  • LXRandr,屏幕管理器,可以管理多个屏幕的分辨率,刷新频率等等,大赞!
  • LXShortCut,用来快捷方式
  • LXMusic
  • LXDE Common
  • GtkNetCat

希望

目前的LXDE还是太少,跟树大根深的GNOME自然无法比,但是LXDE有着很多的先天优势。对 于我来说,LXDE还需要改进的是:一个快捷键管理工具,虽然你可以手动编辑 ~/.config/openbox/lxde-rc.xml;一个很好的桌面字体渲染引擎;采用更多的轻量级应用 软件,比如Office,画图等等;增强PCMan文件管理器功能,当然这要建立在不牺牲速度和 性能的基础之上,毕竟这是LXDE的设计哲学。

安装 LXDE 请看:

追踪 LXDE 社区线索:

截图