qn1521739087

qn1521739087

0个粉丝

1

问答

0

专栏

0

资料

qn1521739087  发布于  2018-03-31 02:20:38
采纳率 0%
1个问答
5418

求救:ADV7611+Hi3531进行显示屏录制,但中断丢失

 
本帖最后由 qn1521739087 于 2018-3-31 02:52 编辑

论坛的各位大大好!最近在调试Hi3531过程中遇到了问题,卡了很久,在这里求助一下下,先行谢过了,谢谢~

1. 硬件情况:需录屏的电脑的视频信号(sRGB,720p@60Hz/30Hz)通过DVI接入ADV7611,经ADV7611转化为YCbCr格式,再通过BT1120传入Hi3531。

2. 线路连接:ADV7611的16根数据管脚(P0-P15管脚)和1路时钟管脚,分别接Hi3531输入设备Dev0的16个数据管脚,以及时钟线,此时7611的模式选择寄存器OP_FORMAT_SEL,地址0x03[7:0],设置为0x80,即16-Bit SDR ITU-R BT.656 4:2:2 Mode 0,OP_CH_SEL(地址 0x04[7:5])设置为011 (default),即P[23:16] V/R, P[15:8] Y/G, P[7:0] U/CrCb/B,这与管脚连线是对应的,即8-15对应亮度分量Y,0-7对应色彩分量C。依据的官方文档:


3. 程序运行:对ADV7611其他寄存器配置都是官方例程中的, edid的配置是直接借用了另外一个显示器的edid信息;运行SDK中的例子sample_venc,选择4*hd模式, 一直打印获取视频流失败,如下图。


4. 现象分析:
(1)查看proc调试日志如下图,掩码是跟官方中文档一致的,中断也一直有,就是全都丢失了,可见是中断处理失败,无法正常采集码流数据;




(2)示波器检测ADV7611与Hi3531的时钟连线和数据连线,时钟连线在屏幕扫描30Hz时是74.25MHz,60Hz时是148.5MHz,数据线比较杂乱,处于一直变化中;

(3)下图是把日志设置为7时,/dev/log的输出,看不太懂;


(4)使用hdmd.l查询“原始码流亮度存储基地址寄存器  CH_YBASE_ADDR”,地址0x2059042011,值经常在变化,通过himd.l打印该值的内存块,也是在变化的,需录屏的电脑的DVI线与调试底板断开后,这两项数据都不再变化;

(5)通道状态寄存器CH_STATUS 0x2059043C,值是0x08080000,表示原始码流忙、小码流忙;

(6)使用工具vi_dump 0也无法保存输入信号。

5. 个人猜想:中断有,且与/proc/interrupts中看到的一样,并且原始码流亮度存储的内存也有变化,说明数据已经进来了,可能还是哪个寄存器没设置上。此外,查了很多资料,有说是同步方式,或者掩码的问题,但都不是很确定。

以上就是小弟这边的情况,跪谢大牛帮助,谢谢啦~
我来回答
回答14个
时间排序
认可量排序

goodman

4个粉丝

30

问答

18

专栏

17

资料

goodman 2018-03-31 09:27:07
认可0
本帖最后由 goodman 于 2018-3-31 09:28 编辑

你试试把VB放多看看,另外看看logmpp看看里面有没有什么错误信息

hero

0个粉丝

1

问答

0

专栏

0

资料

hero 2018-03-31 10:07:32
认可0
有可能是VB问题:)

qn1521739087

0个粉丝

1

问答

0

专栏

0

资料

qn1521739087 2018-04-01 00:26:47
认可0
[quote][url=forum.php?mod=redirect&goto=findpost&pid=86060&ptid=39241]goodman 发表于 2018-3-31 09:27[/url]
你试试把VB放多看看,另外看看logmpp看看里面有没有什么错误信息[/quote]

谢谢回复,您说的VB是指的公共缓冲池分配的大小吗:lol

qn1521739087

0个粉丝

1

问答

0

专栏

0

资料

qn1521739087 2018-04-01 00:28:04
认可0
[quote][url=forum.php?mod=redirect&goto=findpost&pid=86064&ptid=39241]hero 发表于 2018-3-31 10:07[/url]
有可能是VB问题[/quote]

谢谢回复~您之前遇到过类似的问题吗,那可能是我VB分配的不够用吗?

qn1521739087

0个粉丝

1

问答

0

专栏

0

资料

qn1521739087 2018-04-02 12:42:01
认可0
[quote][url=forum.php?mod=redirect&goto=findpost&pid=86060&ptid=39241]goodman 发表于 2018-3-31 09:27[/url]
你试试把VB放多看看,另外看看logmpp看看里面有没有什么错误信息[/quote]

我把公共缓存池中缓存块数目设成64个,再次运行样例程序,还是报错,下图是log日志,看不出什么错误啊;调试日志/proc/umap/vb /proc/umap/sys也附在后面了。


qn1521739087

0个粉丝

1

问答

0

专栏

0

资料

qn1521739087 2018-04-02 12:44:09
认可0
:Q顶一下,大牛们帮分析一下吧,谢谢啊!

zhuangweiye

8个粉丝

0

问答

0

专栏

0

资料

zhuangweiye 2018-04-02 17:13:34
认可0
[quote][url=forum.php?mod=redirect&goto=findpost&pid=86102&ptid=39241]qn1521739087 发表于 2018-4-2 12:44[/url]
顶一下,大牛们帮分析一下吧,谢谢啊![/quote]

从 /proc/umap/vi来看

1. VBfail 为零, 因此当前不用考虑VB不够的问题

2. ccErrN == IntCnt == LostInt 说明中断都是异常的,都被丢掉了
   一般来说这种情况可以先检查Vi的mask配置,线序是否反接,管脚复用是否正确,A/D输出时序是否和VI配置匹配

qn1521739087

0个粉丝

1

问答

0

专栏

0

资料

qn1521739087 2018-04-02 22:20:06
认可0
[quote][url=forum.php?mod=redirect&goto=findpost&pid=86111&ptid=39241]zhuangweiye 发表于 2018-4-2 17:13[/url]
从 /proc/umap/vi来看

1. VBfail 为零, 因此当前不用考虑VB不够的问题
[/quote]

多谢庄老师回复!今天又调试了一天,感觉很可能是7611输出时序与Hi3531的vi配置不一致所致:7611这边设置的是BT656,VI设置的是BT1120,而程序运行时是以16个数据管脚进行Y/C分量传输的。
针对这个问题,又阅读了一下手册,发现一个“接口时序寄存器 1”,如下图,尝试过设置该寄存器,但是写的新值不生效。

zhuangweiye

8个粉丝

0

问答

0

专栏

0

资料

zhuangweiye 2018-04-03 11:03:30
认可0
[quote][url=forum.php?mod=redirect&goto=findpost&pid=86120&ptid=39241]qn1521739087 发表于 2018-4-2 22:20[/url]
多谢庄老师回复!今天又调试了一天,感觉很可能是7611输出时序与Hi3531的vi配置不一致所致:7611这边设置 ...[/quote]


一般来说不会直接去设置这些寄存器,如果有需要,修改mask比较好(比如接线不是默认方式)

7611的16-Bit SDR ITU-R BT.656 4:2:2 Mode 0 实际上就是bt1120,p15-p8是Y p7-p0是CbCr

qn1521739087

0个粉丝

1

问答

0

专栏

0

资料

qn1521739087 2018-04-03 14:02:31
认可0
[quote][url=forum.php?mod=redirect&goto=findpost&pid=86125&ptid=39241]zhuangweiye 发表于 2018-4-3 11:03[/url]
一般来说不会直接去设置这些寄存器,如果有需要,修改mask比较好(比如接线不是默认方式)

7611的16 ...[/quote]

庄老师,谢谢回复。板子的接线方式为: 8-15是Y分量,接VIU0_DATA8~VIU0_DATA15,0-7是C分量,接VIU0_DATA0~VIU0_DATA7。感觉接线方式好像没啥问题。另外,再向您确认一下adv7611的16 bit BT656 4:2:2就是BT1120时序吗?7611手册上没有找到。😂现在没啥思路了,黔驴技穷啊。

qn1521739087

0个粉丝

1

问答

0

专栏

0

资料

qn1521739087 2018-04-09 00:55:59
认可0
:lol 现在能看到画面了,原来是7611的avcode控制寄存器需要设置使能。目前遇到的问题是画面一直有水平的干扰线,查看vi日志有一半中断丢失,IntRate=30,跟视频输入源1080@30Hz是一致的,视频采集频率FrmRate=15,并且ccErrN也一直增加,现在不确定哪里有问题,大牛们有遇到过来类似问题吗?先行谢过了,谢谢!
录屏现象、vi日志如下图所示:



zhuangweiye

8个粉丝

0

问答

0

专栏

0

资料

zhuangweiye 2018-04-09 09:08:28
认可0
本帖最后由 zhuangweiye 于 2018-4-9 09:10 编辑

[quote][url=forum.php?mod=redirect&goto=findpost&pid=86213&ptid=39241]qn1521739087 发表于 2018-4-9 00:55[/url]
现在能看到画面了,原来是7611的avcode控制寄存器需要设置使能。目前遇到的问题是画面一直有水平的干 ...[/quote]


Field 是 intl, 表示是隔行

不是逐行(VI_SCAN_PROGRESSIVE)吗?

qn1521739087

0个粉丝

1

问答

0

专栏

0

资料

qn1521739087 2018-04-09 11:31:50
认可0
本帖最后由 qn1521739087 于 2018-4-9 11:33 编辑

[quote][url=forum.php?mod=redirect&goto=findpost&pid=86216&ptid=39241]zhuangweiye 发表于 2018-4-9 09:08[/url]
Field 是 intl, 表示是隔行

不是逐行(VI_SCAN_PROGRESSIVE)吗?[/quote]

庄老师好:handshake~
只有在录制的屏幕设置为1080@30hz输出,VI_DEV_ATTR中的输入模式设置为隔行,这样才能采集到上面帖子那样的图形,若把VI_DEV_ATTR的输入模式设置为逐行,不管30Hz还是60Hz帧率都采集不到数据,且ccERRN=LosInt。(测试过程中,VI_DEV_ATTR的接口模式始终是VI_MODE_BT1120_STANDARD)

qn1521739087

0个粉丝

1

问答

0

专栏

0

资料

qn1521739087 2018-04-09 22:49:15
认可0
:lol有哪位大牛见过类似问题吗
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币

Markdown 语法

  • 加粗**内容**
  • 斜体*内容*
  • 删除线~~内容~~
  • 引用> 引用内容
  • 代码`代码`
  • 代码块```编程语言↵代码```
  • 链接[链接标题](url)
  • 无序列表- 内容
  • 有序列表1. 内容
  • 缩进内容
  • 图片![alt](url)
+ 添加网盘链接/附件

Markdown 语法

  • 加粗**内容**
  • 斜体*内容*
  • 删除线~~内容~~
  • 引用> 引用内容
  • 代码`代码`
  • 代码块```编程语言↵代码```
  • 链接[链接标题](url)
  • 无序列表- 内容
  • 有序列表1. 内容
  • 缩进内容
  • 图片![alt](url)
举报反馈

举报类型

  • 内容涉黄/赌/毒
  • 内容侵权/抄袭
  • 政治相关
  • 涉嫌广告
  • 侮辱谩骂
  • 其他

详细说明

易百纳技术社区