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中看到的一样,并且原始码流亮度存储的内存也有变化,说明数据已经进来了,可能还是哪个寄存器没设置上。此外,查了很多资料,有说是同步方式,或者掩码的问题,但都不是很确定。
以上就是小弟这边的情况,跪谢大牛帮助,谢谢啦~
论坛的各位大大好!最近在调试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个
时间排序
认可量排序
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片![alt](url)
相关问答
-
2018-12-27 14:55:07
-
2019-09-02 12:03:04
-
2017-11-30 18:19:47
-
2016-03-17 19:06:13
-
2015-11-07 10:33:53
-
2019-05-19 13:16:05
-
2018-12-26 14:49:53
-
2014-10-29 20:21:17
-
2019-04-17 10:26:01
-
2021-07-15 10:05:45
-
2014-10-29 20:18:08
-
2019-12-05 14:43:14
-
2017-08-28 08:57:40
-
2020-04-30 17:48:30
-
2017-05-20 18:15:51
-
2018-08-29 15:53:15
-
2017-10-09 10:51:14
-
2019-08-12 14:49:38
-
2016-03-25 02:26:19
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
50帮忙解决个交叉编译的问题
-
20帮忙交叉编译个源码
-
5Hi3516CV610 如何使用SD卡升级固件
-
5cat /dev/logmpp 报错 <3>[ vi] [func]:vi_send_frame_node [line]:99 [info]:vi pic queue is full!
-
50如何获取vpss chn的图像修改后发送至vo
-
5FPGA通过Bt1120传YUV422数据过来,vi接收不到数据——3516dv500
-
50SS928 运行PQtools 拼接 推到设备里有一半画面会异常
-
53536AV100的sample_vdec输出到CVBS显示
-
10海思板子mpp怎么在vi阶段改变视频数据尺寸
-
10HI3559AV100 多摄像头同步模式
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认