第一节:XS128 如何处理像素中断信号 PCLK
我们已经知道,对于 OV7620 来说,行信号 HREF 与场信号 VSYN 的时间比较长,XS12 的单片机足以捕捉到;但是 OV7620 的像素同步信号 PCLK 只有 73ns,而 XS12 单片机的稳定总线时钟只有 25M,很难捕捉到 PCLK 这个像素同步信号;即使单片机主频倍频到 60M 以上能够捕捉到 73ns 的信号,而这其间还有采集这一步,很难做到既采集也判断是否有像素同步。
在以上方案不通的情况下,我们进行了一下论证。然而,我们是否真正的必须捕捉 PCLK 的信号,读回来的信号才是正确的呢?显然是否定的,对于 XS12 单片机,即使不用 PCLK 读回来图像也是正确的。为什么呢?原因是 S12 单片机的读取速度是有限的,曾经做过实验,在 24M 主频下,即使当行信号 HERF 到来的时候,单片机什么也不做,就去读取图像,程序用纯汇编写,而且不用循环判断语句,牺牲空间换取时间来采集,即使是这样,读到有效点数一行也只在 450 多左右,而 OV7620 的每行像素输出是 640 点,这说明单机的读取速度比 CMOS 的图像输出慢,但是已经可以读取到整行图像数据的大部分数据了。
那么,如果我们一行要读取 120 点,我们如何来确保隔像素采集平分 640 个点呢?方法很简单,就是延时,采集一点,延时一会,再采集,平均分为 120 点,如何去控制延时就得进行实验了,最好借助于示波器。有人会问,采集的这 120 点之中,难道就没有无效点吗,难道不会采集到 PCLK 的消隐区吗?不排除这种可能性,但是就算是无效,它能差很多吗?打个比方,采集到的这个点的前一个像素值为 70,后一个像素值为 78,那么即使采集此点的时候 PCLK 不是高电平,采集到的值也是在 70-78 之间;或许大家还有疑问,在黑线的边沿处,如果发生这种情况如何呢?请大家记住,即使在黑线的边沿,COMS 的图像输出也不会少于 5 点,所以这个问题,也不用考虑了。
对于 PCLK 的具体用处,在用 K60 或 K10 采集的时候,就会显现出它的作用,在《新手入门摄像头系列》的后续篇章中,会介绍到。
另外,对于 S12 单片机,如果真的想捕捉到 TCLK 信号,也是可以的,必需地 PCLK 作一定的处理。通过写 SCCB 对 PCLK 分频,将 PCLK 降为微秒级就可以,基于 SCCB 的分频,DEMOK 也做了实验,后续会在论坛逐一发布。
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
全部0条评论
快来发表一下你的评论吧 !