2010年12月10日星期五

I2C transfer highlight

Every byte put on the SDA line must be 8-bits long. The number of bytes that can be transmitted per transfer is unrestricted. Each byte has to be followed by an acknowledge bit
传输多少字节的数据,I2C没有限制,但是每8位传输需要一个确认位回复。

2010年11月11日星期四

display driver must take care of Blanking interval to avoid tearing screen

这里有和timing相关的3个参数
1.

Front Porch
2. Pulse Width
3. Back Porch
VGA每绘制一整屏幕的pixel时,都会有Vsync信号的de-active的时间是pulse width,从宏观讲,前一屏幕的绘制完毕到后一屏幕的绘制开始,一定是会有个时间间隔的,它就是blanking interval。
如图所示blanking interval=front porch + pulsewidth + back porch,具体这些参数是什么依赖于LCD panel datasheet。Front porch和back porch是不容忽视的两个"大"参数。我拿我手头上的LCD panel datasheet举例,front porch,pulse width,back porch的比例是4:1:1,这也是我为什么说是"大"参数的原因。以常用的51us的Hsync周期,blanking interval就是51us x ( 4 + 1 + 1) = 306us 。相对于当代的处理器,这是一个非常长的时间。60Hz一个屏幕的刷新率,每一屏幕绘制花费16ms,其中306us是间歇。
在blanking interval期间,LCD controller相当于是休息的。我们就应该在这个间隙时间更新framebuffer,就可以避免裂屏的现象。

님是敬语sir的意思

2010年10月25日星期一

最大的PC瓶颈

当前所有的台式机或者笔记本的配置都已经相当快了,除了一个家伙。即使你花了大量的钞票配了4核,8核的处理器,超牛的显卡,你会发现系统的整体性能还是达不到想象中的样子。这就是"木桶效应",每片木头都要长短一样,否则花出去的钱都会严重打折。这片最短的木头就是硬盘。目前硬盘多采用SATA接口
SATA 1.0 1.5Gbit/s
SATA 2.0 3Gbit/s
SATA 3.0 6Gbit/s
而且最流行的就是SATA2.0,该接口的理论传输速度是3Gbit/s,也就是380MByte/s,这个速度是个什么概念,USB 2.0 high speed是480Mbit/s,即60MByte/s,也就是说SATA2.0的速度是USB 2.0的4倍,总的来说还是比较快的。可是你买个USB的移动硬盘用用,会发现它的速度和内装的硬盘也差不了多少。
哎!对了!我前面说的是接口速度,就是说硬盘的最快可以达到的传输速度。实际的硬盘的速度你如果测试一下会让你大跌眼镜。根据主流的硬盘的测试结构,台式机机械硬盘的读速度为110MByte/s,笔记本机械硬盘的读速度为60Mbyte/s,他们都远低于SATA可以提供的传输速度。这就是瓶颈,真正的瓶颈。
因此我想说,当你想配置一台PC时,不妨多花些钱在高速度的硬盘配置上,比花在CPU上有效果的多。这话在当前是有效的,可是若干年后就不一定了。
这个PC最大的瓶颈,其实已经被一些厂商意识到,只是他们不强调。目前解决硬盘的瓶颈问题有两种方法,一种是使用RAID的条带,一种是新流行的SSD,当然还有更高性能的SSD+RAID。苹果已经在他部分高性能产品中使用SSD硬盘,而intel直接在他的P55 platform controller hub中集成了RAID控制器。SSD没话说必然是未来的趋势,它的优点太多了,可是目前价格不菲,而且软件的技术上也还不成熟。至少我认为机械硬盘+RAID是当下性价比最高的解决办法。
P55和H55主板的差价在100元左右,他们的主要差别也就是有无RAID控制器,和你单独买个RAID PCI卡差不多。这样硬盘你就"掰成两半"来买,比如你想买240G硬盘那就买两个120G组成RAID0是个不错的选择。

2010年10月22日星期五

UBI到nand驱动判断坏块的call path

MTD如何判断NAND flash坏块

nand_block_bad()在nand_base.c中定义,它是NAND MTD的通用函数,用于坏块的判断。市面上现有的NAND flash都是在page的spare area开始部分标记是否是坏块。
Spare area在MTD中就对应的是OOB,所以猜测一下,nand_block_bad()会读取OOB,然后对标记进行检测。

代码一看果然如此。
先通过cmdfunc来个NAND_CMD_READOOB,再来个read_byte把标记读出来,判断是不是0xFF就知道是不是坏块儿了。

struct nand_chip结构体的函数指针表中的block_bad默认就是指向这个函数。

UBI内核模块需要参数

加载UBI kernel module需要参数来制定底层要使用哪个mtd设备,参数如mtd=/dev/mtd0

MTD夹心UBI

"This is a small driver which implements fake MTD devices on top of UBI volumes. This sounds strange, but it is in fact quite useful to make MTD-oriented software (including all the legacy software) work on top of UBI."

作者留下了关于gluebi.c的设计目的,可以看出UBI的下层是MTD,结果上层还是MTD。这种肉夹馍的结构,只是上层的MTD是一个虚拟层,用于兼容以前的驱动

2010年10月21日星期四

Linux MTD nand read page抽象方法

Nand_read_page_hwecc()是抽象了硬件以后的接口,也是NAND flash一个最为基本平常的操作page read。和我见过的所有的其他的平台完全不一样,Linux MTD将硬件的NAND controller抽象成了,hwctl() 紧接着read_buf()这样的操作序列。可以看出hwctl负责下命令,包括read ,program ,erase等等。

2010年10月20日星期三

phone modem RT OS can disable time slice to improve performance

ThreadX具有时间片功能,但是这样的实时操作系统往往用在一下小型的系统上,比如phone modem里。在这样的应用中,由于内部的中断非常频繁,所以往往会disable time slice,来减小上下文切换开销,而达到高效的效果。

2010年9月17日星期五

flight term

distance measuring equipment (DME)
VHF omnidirectional range (VOR)
non-directional beacons (NDBs)

2010年8月12日星期四

DMA flow controller can solve unknown packet length problem

The peripheral that controls the length of the packet is known as the flow controller. The
flow controller is usually the DMAC, where the packet length is programmed by
software before the DMA channel is enabled. If the packet length is unknown when the
DMA channel is enabled, you can use either the source or destination peripherals as the
flow controller.

2010年8月4日星期三

git no branch


兄弟,那个git no branch ,网上查到了
终于救回来了,
有个命令git help里看不到的 叫reflog
Git reflog 可以看到no branch 上 提交的tag list
然后找到 最后一个tag , git checkout xxxx 就可以了

2010年5月31日星期一

UART RX的一个细节

当UART内部支持FIFO,那么一般情况,RX interrupt的触发条件就是RX FIFO接收到的数据,超过了level trigger。但是如果只有这一种触发条件是不够的,因为如果对方发送了很少的数据,比如一个字节,但是没有超过level trigger,那么逻辑上讲就不会触发RX interrupt,也就是上层软件意识不到有数据来临,但事实是对方已经发了东西,所以是就一个条件触发RX interrupt不够的。
基于以上的原因,在UART的hardware设计时,往往会加入一些条件:如果RX FIFO中不是空,但是在很短的时间内,还没有超过level trigger,此时就认为是一种timeout,同时也会触发RX interrupt,这样就解决了上面逻辑上和事实上不符合的问题

2010年5月21日星期五

cygwin in Win7 Command Prompt

The message I get when trying to run gcc in Win7 cmd.exe is: "Access is denied."
This is a known limitation of the symbolic links in Cygwin 1.7. The solution is to invoke the command('gcc-3.exe' or 'gcc-4.exe')  directly

2010年3月29日星期一

Linux中断和异常的处理交错的核心原则

在Linux中,中断和异常的处理是可以交错执行的。中断可以打断其他中断的处理,同时也可以打断异常的处理。

2010年3月25日星期四

Android目录结构

到目前为止,Android的代码结构是我5年以来见到的最漂亮的。专门有个build的目录,是它的build system。其他的目录主要依靠Android.mk来控制,这个文件的语法简单,结构清晰。根目录下的Makefile激发整个build system的编译过程。

而且代码直接包括tool chain,几乎无须另外安装什么东西(关于这点也许是优点,也许是缺点)。

2010年3月24日星期三

Linux tool chain

CodeSourcery is the best choice of Linux tool chain. When you consider which tool chain you will use to compiler Linux kernel, as well as Linux applications, do not hesitate, CodeSourcery product is your first choice. And the source code of their tool chain you can obtain freely.

2010年3月18日星期四

荣幸

如果现在还能看到这篇文章的,那么要不是翻墙出境,要不就是搜索引擎的cache。我感到非常荣幸!很久没来这里,这里是我最喜欢的博客服务,可是被国人给封闭了。现在天天都可以到这里来了,因为到了一家新公司。
以后希望能每天到这里写点东西。