6469
- 收藏
- 点赞
- 分享
- 举报
海思软件配置的LVDS同步码和直接查看寄存器中的同步码不一样
FPGA通过LVDS接口发送数据过来,海思侧需要设置同步码,按照手册设置同步码,如下:
[code]combo_dev_attr_t LVDS_4lane_CHN0_12BIT_NOWDR_ATTR =
{
.devno = 0,
.input_mode = INPUT_MODE_LVDS,
.data_rate = MIPI_DATA_RATE_X2, // 1 pixel per clock/2 pixel per clock
.img_rect = {0, 0, 608, 600},
{
.lvds_attr =
{
.input_data_type = DATA_TYPE_RAW_8BIT,
.wdr_mode = HI_WDR_MODE_NONE,
.sync_mode = LVDS_SYNC_MODE_SOF,
.vsync_attr = {LVDS_VSYNC_NORMAL, 0, 0},
.fid_attr = {LVDS_FID_NONE, HI_TRUE},
.data_endian = LVDS_ENDIAN_LITTLE,
.sync_code_endian = LVDS_ENDIAN_LITTLE,
.lane_id = {0, 1, 2, 3, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1},
.sync_code =
{
/* each vc has 4 params, sync_code:
sync_mode is SYNC_MODE_SOF: SOF, EOF, SOL, EOL
sync_mode is SYNC_MODE_SAV: invalid sav, invalid eav, valid sav, valid eav */
{
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D}
},
{
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D}
},
{
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D}
},
{
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D}
}
}
}
}
};[/code]
在海思的文档《Hi3559A╱C V100 ultra-HD Mobile Camera SoC 用户指南》查看MIPI Rx的寄存器中有下面的描述
我用himd.l 工具去查看相应地址的时候打印信息如下:
查看 LVDS 同步码寄存器设置:
~ # himd.l 0x11A40030 1
*** Board tools : ver0.0.1_20121120 ***
[debug]: {source/utils/cmdshell.c:168}cmdstr:himd.l
====dump memory 0x11A40030====
0000: 00ab00ab 000ab0ab 00ab00ab 00ab00ab
[END]
发现Lane 0、1、2、3的同步码都有错误,我试着改变软件层次的配置,例如改为:
[code] .sync_code =
{
/* each vc has 4 params, sync_code:
sync_mode is SYNC_MODE_SOF: SOF, EOF, SOL, EOL
sync_mode is SYNC_MODE_SAV: invalid sav, invalid eav, valid sav, valid eav */
{
{0x02, 0x03, 0x00, 0x01}, //PHY0_lane0
{0x22, 0x23, 0x20, 0x21},
{0x12, 0x13, 0x10, 0x11},
{0x32, 0x33, 0x30, 0x31}
},
{
{0x02, 0x03, 0x00, 0x01}, //PHY0_lane1
{0x22, 0x23, 0x20, 0x21},
{0x12, 0x13, 0x10, 0x11},
{0x32, 0x33, 0x30, 0x31}
},
{
{0x02, 0x03, 0x00, 0x01}, //PHY0_lane2
{0x22, 0x23, 0x20, 0x21},
{0x12, 0x13, 0x10, 0x11},
{0x32, 0x33, 0x30, 0x31}
},
{
{0x02, 0x03, 0x00, 0x01}, //PHY0_lane3
{0x22, 0x23, 0x20, 0x21},
{0x12, 0x13, 0x10, 0x11},
{0x32, 0x33, 0x30, 0x31}
}
}[/code]
然后查看lane0、1、2、3的寄存器内容如下:
~ # himd.l 0x11A40030 1
*** Board tools : ver0.0.1_20121120 ***
[debug]: {source/utils/cmdshell.c:168}cmdstr:himd.l
====dump memory 0x11A40030====
0000: 00020002 00020002 00020002 00020002
[END]
发现软件配置的同步码并没有设置到对应的寄存器中,似乎只将对应的第一个字节设置进去,不是很清楚为什么会这样?有人遇到过类似的问题吗》请教一下,十分感谢!
[code]combo_dev_attr_t LVDS_4lane_CHN0_12BIT_NOWDR_ATTR =
{
.devno = 0,
.input_mode = INPUT_MODE_LVDS,
.data_rate = MIPI_DATA_RATE_X2, // 1 pixel per clock/2 pixel per clock
.img_rect = {0, 0, 608, 600},
{
.lvds_attr =
{
.input_data_type = DATA_TYPE_RAW_8BIT,
.wdr_mode = HI_WDR_MODE_NONE,
.sync_mode = LVDS_SYNC_MODE_SOF,
.vsync_attr = {LVDS_VSYNC_NORMAL, 0, 0},
.fid_attr = {LVDS_FID_NONE, HI_TRUE},
.data_endian = LVDS_ENDIAN_LITTLE,
.sync_code_endian = LVDS_ENDIAN_LITTLE,
.lane_id = {0, 1, 2, 3, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1},
.sync_code =
{
/* each vc has 4 params, sync_code:
sync_mode is SYNC_MODE_SOF: SOF, EOF, SOL, EOL
sync_mode is SYNC_MODE_SAV: invalid sav, invalid eav, valid sav, valid eav */
{
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D}
},
{
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D}
},
{
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D}
},
{
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D},
{0xAB, 0xB6, 0x80, 0x9D}
}
}
}
}
};[/code]
在海思的文档《Hi3559A╱C V100 ultra-HD Mobile Camera SoC 用户指南》查看MIPI Rx的寄存器中有下面的描述
我用himd.l 工具去查看相应地址的时候打印信息如下:
查看 LVDS 同步码寄存器设置:
~ # himd.l 0x11A40030 1
*** Board tools : ver0.0.1_20121120 ***
[debug]: {source/utils/cmdshell.c:168}cmdstr:himd.l
====dump memory 0x11A40030====
0000: 00ab00ab 000ab0ab 00ab00ab 00ab00ab
[END]
发现Lane 0、1、2、3的同步码都有错误,我试着改变软件层次的配置,例如改为:
[code] .sync_code =
{
/* each vc has 4 params, sync_code:
sync_mode is SYNC_MODE_SOF: SOF, EOF, SOL, EOL
sync_mode is SYNC_MODE_SAV: invalid sav, invalid eav, valid sav, valid eav */
{
{0x02, 0x03, 0x00, 0x01}, //PHY0_lane0
{0x22, 0x23, 0x20, 0x21},
{0x12, 0x13, 0x10, 0x11},
{0x32, 0x33, 0x30, 0x31}
},
{
{0x02, 0x03, 0x00, 0x01}, //PHY0_lane1
{0x22, 0x23, 0x20, 0x21},
{0x12, 0x13, 0x10, 0x11},
{0x32, 0x33, 0x30, 0x31}
},
{
{0x02, 0x03, 0x00, 0x01}, //PHY0_lane2
{0x22, 0x23, 0x20, 0x21},
{0x12, 0x13, 0x10, 0x11},
{0x32, 0x33, 0x30, 0x31}
},
{
{0x02, 0x03, 0x00, 0x01}, //PHY0_lane3
{0x22, 0x23, 0x20, 0x21},
{0x12, 0x13, 0x10, 0x11},
{0x32, 0x33, 0x30, 0x31}
}
}[/code]
然后查看lane0、1、2、3的寄存器内容如下:
~ # himd.l 0x11A40030 1
*** Board tools : ver0.0.1_20121120 ***
[debug]: {source/utils/cmdshell.c:168}cmdstr:himd.l
====dump memory 0x11A40030====
0000: 00020002 00020002 00020002 00020002
[END]
发现软件配置的同步码并没有设置到对应的寄存器中,似乎只将对应的第一个字节设置进去,不是很清楚为什么会这样?有人遇到过类似的问题吗》请教一下,十分感谢!
我来回答
回答3个
时间排序
认可量排序
认可0
认可0
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片![alt](url)
相关问答
-
2017-01-11 11:34:37
-
2023-12-18 08:52:13
-
2020-02-29 18:15:07
-
2014-09-12 17:54:51
-
2024-09-04 11:03:46
-
2018-12-30 11:36:18
-
2019-12-17 17:08:27
-
2019-03-01 16:41:54
-
2019-03-14 16:47:57
-
2016-03-09 16:21:52
-
142013-12-10 23:10:39
-
2021-04-16 17:41:17
-
2018-11-07 14:03:03
-
2019-12-20 10:56:40
-
2014-11-11 11:51:26
-
2018-09-25 10:54:35
-
2018-11-14 09:05:27
-
2016-06-13 13:31:50
-
2019-03-14 15:18:29
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
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 多摄像头同步模式
-
9海思ss928单路摄像头vio中加入opencv处理并显示
-
10EB-RV1126-BC-191板子运行自己编码的程序
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认