linuxOS_D21X/doc/topics/sdk/dvp/dvp_data_struct.html
2025-01-23 16:35:08 +08:00

295 lines
34 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml" xml:lang="zh-cn" lang="zh-cn" data-whc_version="27.0">
<head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/><meta name="viewport" content="width=device-width, initial-scale=1.0"/><meta http-equiv="X-UA-Compatible" content="IE=edge"/><meta name="description" content="DVP 自定义的数据结构都在 aic_dvp.h 中。 struct aic_dvp定义了 DVP 控制器的设备管理信息: struct aic_dvp { /* Device resources */ struct device *dev; void __iomem *regs; struct clk *clk; struct reset_control *rst; u32 clk_rate; ..."/><meta name="DC.rights.owner" content="(C) 版权 2025"/><meta name="copyright" content="(C) 版权 2025"/><meta name="generator" content="DITA-OT"/><meta name="DC.type" content="concept"/><meta name="DC.relation" content="../../../topics/sdk/dvp/dvp_design.html"/><meta name="DC.relation" content="../../../topics/sdk/dvp/dvp_key_procedure.html"/><meta name="DC.relation" content="../../../topics/sdk/dvp/dvp_interface.html"/><meta name="DC.contributor" content="yan.wang"/><meta name="DC.contributor" content="yan.wang"/><meta name="DC.date.modified" content="2024-01-15"/><meta name="DC.format" content="HTML5"/><meta name="DC.identifier" content="dvp_data_structure"/><meta name="DC.language" content="zh-CN"/><title>数据结构设计</title><!-- Generated with build number 2024112209. --><meta name="wh-path2root" content="../../../"/><meta name="wh-toc-id" content="dvp_data_structure-d4445e5302"/><meta name="wh-source-relpath" content="topics/sdk/dvp/dvp_data_struct.dita"/><meta name="wh-out-relpath" content="topics/sdk/dvp/dvp_data_struct.html"/>
<link rel="stylesheet" type="text/css" href="../../../webhelp/app/commons.css?buildId=2024112209"/>
<link rel="stylesheet" type="text/css" href="../../../webhelp/app/topic.css?buildId=2024112209"/>
<script src="../../../webhelp/app/options/properties.js?buildId=20250123154945"></script>
<script src="../../../webhelp/app/localization/strings.js?buildId=2024112209"></script>
<script src="../../../webhelp/app/search/index/keywords.js?buildId=20250123154945"></script>
<script defer="defer" src="../../../webhelp/app/commons.js?buildId=2024112209"></script>
<script defer="defer" src="../../../webhelp/app/topic.js?buildId=2024112209"></script>
<link rel="stylesheet" type="text/css" href="../../../webhelp/template/aic-styles-web.css?buildId=2024112209"/><link rel="stylesheet" type="text/css" href="../../../webhelp/template/notes.css?buildId=2024112209"/><link rel="stylesheet" type="text/css" href="../../../webhelp/template/aic-common.css?buildId=2024112209"/><link rel="stylesheet" type="text/css" href="../../../webhelp/template/aic-images.css?buildId=2024112209"/><link rel="stylesheet" type="text/css" href="../../../webhelp/template/footnote.css?buildId=2024112209"/><link rel="stylesheet" type="text/css" href="../../../webhelp/template/aic-web-watermark.css?buildId=2024112209"/><link rel="stylesheet" type="text/css" href="../../../webhelp/template/topic-body-list.css?buildId=2024112209"/></head>
<body id="dvp_data_structure" class="wh_topic_page frmBody">
<a href="#wh_topic_body" class="sr-only sr-only-focusable">
跳转到主要内容
</a>
<header class="navbar navbar-default wh_header">
<div class="container-fluid">
<div class="wh_header_flex_container navbar-nav navbar-expand-md navbar-dark">
<div class="wh_logo_and_publication_title_container">
<div class="wh_logo_and_publication_title">
<a href="http://www.artinchip.com" class=" wh_logo d-none d-sm-block "><img src="../../../company-logo-white.png" alt=" Linux SDK 使用指南 SDK 指南文件 "/></a>
<div class=" wh_publication_title "><a href="../../../index.html"><span class="booktitle"> <span class="ph mainbooktitle">Linux SDK 使用指南</span> <span class="ph booktitlealt">SDK 指南文件</span> </span></a></div>
</div>
</div>
<div class="wh_top_menu_and_indexterms_link collapse navbar-collapse" id="wh_top_menu_and_indexterms_link">
</div>
</div>
</div>
</header>
<div class=" wh_search_input navbar-form wh_topic_page_search search " role="form">
<form id="searchForm" method="get" role="search" action="../../../search.html"><div><input type="search" placeholder="搜索 " class="wh_search_textfield" id="textToSearch" name="searchQuery" aria-label="搜索查询" required="required"/><button type="submit" class="wh_search_button" aria-label="搜索"><span class="search_input_text">搜索</span></button></div></form>
</div>
<div class="container-fluid" id="wh_topic_container">
<div class="row">
<nav class="wh_tools d-print-none navbar-expand-md" aria-label="Tools">
<div data-tooltip-position="bottom" class=" wh_breadcrumb "><ol class="d-print-none"><li><span class="home"><a href="../../../index.html"><span>主页</span></a></span></li><li><div class="topicref" data-id="id"><div class="title"><a href="../../../topics/sdk/chapter-advanced-app.html">高级应用</a><div class="wh-tooltip"><p class="shortdesc">系统、存储、多媒体、接口、安全等模块的详细配置和设计说明。</p></div></div></div></li><li><div class="topicref" data-id="concept_mcc_32s_nbc"><div class="title"><a href="../../../topics/chapter-title/chapter-multi-media-sdk.html">多媒体</a><div class="wh-tooltip"><p class="shortdesc">GE、VE、Display、DVP、MPP、MPP 播放器等多媒体模块的介绍和使用说明。</p></div></div></div></li><li><div class="topicref" data-id="concept_h4d_fwt_tzb"><div class="title"><a href="../../../topics/sdk/dvp/dvp_user_guide.html">DVP 使用指南</a></div></div></li><li><div class="topicref" data-id="dvp_design_intro"><div class="title"><a href="../../../topics/sdk/dvp/dvp_design.html">设计说明</a></div></div></li><li class="active"><div class="topicref" data-id="dvp_data_structure"><div class="title"><a href="../../../topics/sdk/dvp/dvp_data_struct.html">数据结构设计</a></div></div></li></ol></div>
<div class="wh_right_tools">
<button class="wh_hide_highlight" aria-label="切换搜索突出显示" title="切换搜索突出显示"></button>
<button class="webhelp_expand_collapse_sections" data-next-state="collapsed" aria-label="折叠截面" title="折叠截面"></button>
<div class=" wh_navigation_links "><span id="topic_navigation_links" class="navheader">
<span class="navprev"><a class="- topic/link link" href="../../../topics/sdk/dvp/dvp_key_procedure.html" title="关键流程设计" aria-label="上一主题: 关键流程设计" rel="prev"></a></span>
<span class="navnext"><a class="- topic/link link" href="../../../topics/sdk/dvp/dvp_interface.html" title="接口设计" aria-label="下一主题: 接口设计" rel="next"></a></span> </span></div>
<div class=" wh_print_link print d-none d-md-inline-block "><button onClick="window.print()" title="打印此页" aria-label="打印此页"></button></div>
<button type="button" id="wh_toc_button" class="custom-toggler navbar-toggler collapsed wh_toggle_button navbar-light" aria-expanded="false" aria-label="Toggle publishing table of content" aria-controls="wh_publication_toc">
<span class="navbar-toggler-icon"></span>
</button>
</div>
</nav>
</div>
<div class="wh_content_area">
<div class="row">
<nav id="wh_publication_toc" class="col-lg-3 col-md-3 col-sm-12 d-md-block d-none d-print-none" aria-label="Table of Contents Container">
<div id="wh_publication_toc_content">
<div class=" wh_publication_toc " data-tooltip-position="right"><span class="expand-button-action-labels"><span id="button-expand-action" role="button" aria-label="Expand"></span><span id="button-collapse-action" role="button" aria-label="Collapse"></span><span id="button-pending-action" role="button" aria-label="Pending"></span></span><ul role="tree" aria-label="Table of Contents"><li role="treeitem"><div data-tocid="revinfo_linux-d4445e1079" class="topicref" data-id="revinfo_linux" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/revinfo/revinfo_linux.html" id="revinfo_linux-d4445e1079-link">修订记录</a></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="id-d4445e1096" class="topicref" data-id="id" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action id-d4445e1096-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/env/sdk-compile.html" id="id-d4445e1096-link">SDK 编译</a><div class="wh-tooltip"><p class="shortdesc">介绍不同编译环境下 SDK 的详细编译流程。</p></div></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="tocId-d4445e1240" class="topicref" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action tocId-d4445e1240-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/advanced/lb_usage_commands.html" id="tocId-d4445e1240-link">使用指南</a></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="concept_rcx_czh_pzb-d4445e1360" class="topicref" data-id="concept_rcx_czh_pzb" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action concept_rcx_czh_pzb-d4445e1360-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/chapter-app.html" id="concept_rcx_czh_pzb-d4445e1360-link">应用场景</a><div class="wh-tooltip"><p class="shortdesc">描述了 SDK 在不同应用场景中的配置和使用包括系统更新、OTA、安全方案等。</p></div></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="id-d4445e1678" class="topicref" data-id="id" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action id-d4445e1678-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/peripheral/peripheral-intro.html" id="id-d4445e1678-link">外设移植</a><div class="wh-tooltip"><p class="shortdesc"><span class="ph">触摸屏、显示器、WIFI 模块、按键</span>等外设的介绍和使用说明。</p></div></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="id-d4445e1964" class="topicref" data-id="id" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action id-d4445e1964-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/bringup/chapter-bringup.html" id="id-d4445e1964-link">BringUp</a><div class="wh-tooltip"><p class="shortdesc">在硬件上电后快速初始化系统,为操作系统的启动准备好必要的硬件环境。</p></div></div></div></li><li role="treeitem" aria-expanded="true"><div data-tocid="id-d4445e2153" class="topicref" data-id="id" data-state="expanded"><span role="button" tabindex="0" aria-labelledby="button-collapse-action id-d4445e2153-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/chapter-advanced-app.html" id="id-d4445e2153-link">高级应用</a><div class="wh-tooltip"><p class="shortdesc">系统、存储、多媒体、接口、安全等模块的详细配置和设计说明。</p></div></div></div><ul role="group" class="navbar-nav nav-list"><li role="treeitem" aria-expanded="false"><div data-tocid="uBoot-d4445e2170" class="topicref" data-id="uBoot" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action uBoot-d4445e2170-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/boot/uboot-module.html" id="uBoot-d4445e2170-link">U-Boot</a><div class="wh-tooltip"><p class="shortdesc">启动支持的基本功能以及运行时的基本硬件环境。</p></div></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="concept_mtx_tk3_pzb-d4445e3028" class="topicref" data-id="concept_mtx_tk3_pzb" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action concept_mtx_tk3_pzb-d4445e3028-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/linux/chapter_linux.html" id="concept_mtx_tk3_pzb-d4445e3028-link">Linux</a></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="chapter-system-d4445e3198" class="topicref" data-id="chapter-system" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action chapter-system-d4445e3198-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/chapter-title/chapter-system.html" id="chapter-system-d4445e3198-link">系统</a><div class="wh-tooltip"><p class="shortdesc"></p></div></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="chapter-memory-d4445e4054" class="topicref" data-id="chapter-memory" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action chapter-memory-d4445e4054-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/chapter-title/chapter-memory-sdk.html" id="chapter-memory-d4445e4054-link">存储</a><div class="wh-tooltip"><p class="shortdesc">SDMC、SPI NAND、SPI NOR 等存储模块的介绍和使用说明。</p></div></div></div></li><li role="treeitem" aria-expanded="true"><div data-tocid="concept_mcc_32s_nbc-d4445e4438" class="topicref" data-id="concept_mcc_32s_nbc" data-state="expanded"><span role="button" tabindex="0" aria-labelledby="button-collapse-action concept_mcc_32s_nbc-d4445e4438-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/chapter-title/chapter-multi-media-sdk.html" id="concept_mcc_32s_nbc-d4445e4438-link">多媒体</a><div class="wh-tooltip"><p class="shortdesc">GE、VE、Display、DVP、MPP、MPP 播放器等多媒体模块的介绍和使用说明。</p></div></div></div><ul role="group" class="navbar-nav nav-list"><li role="treeitem" aria-expanded="false"><div data-tocid="ge-d4445e4455" class="topicref" data-id="ge" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action ge-d4445e4455-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/ge/ge_user_guide.html" id="ge-d4445e4455-link">GE 使用指南</a></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="ve-d4445e4637" class="topicref" data-id="ve" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action ve-d4445e4637-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/ve/ve-user-guide.html" id="ve-d4445e4637-link">VE 使用指南</a></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="id-d4445e4777" class="topicref" data-id="id" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action id-d4445e4777-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/display/display_user_guide.html" id="id-d4445e4777-link">Display 使用指南</a></div></div></li><li role="treeitem" aria-expanded="true"><div data-tocid="concept_h4d_fwt_tzb-d4445e5218" class="topicref" data-id="concept_h4d_fwt_tzb" data-state="expanded"><span role="button" tabindex="0" aria-labelledby="button-collapse-action concept_h4d_fwt_tzb-d4445e5218-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/dvp/dvp_user_guide.html" id="concept_h4d_fwt_tzb-d4445e5218-link">DVP 使用指南</a></div></div><ul role="group" class="navbar-nav nav-list"><li role="treeitem"><div data-tocid="dvp_configuration-d4445e5232" class="topicref" data-id="dvp_configuration" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/dvp/dvp_config.html" id="dvp_configuration-d4445e5232-link">DVP 配置</a></div></div></li><li role="treeitem"><div data-tocid="dvp_debug_guide-d4445e5246" class="topicref" data-id="dvp_debug_guide" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/dvp/dvp_debug.html" id="dvp_debug_guide-d4445e5246-link">调试指南</a></div></div></li><li role="treeitem"><div data-tocid="dvp_test_guide-d4445e5260" class="topicref" data-id="dvp_test_guide" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/dvp/dvp_test.html" id="dvp_test_guide-d4445e5260-link">测试指南</a></div></div></li><li role="treeitem" aria-expanded="true"><div data-tocid="dvp_design_intro-d4445e5274" class="topicref" data-id="dvp_design_intro" data-state="expanded"><span role="button" tabindex="0" aria-labelledby="button-collapse-action dvp_design_intro-d4445e5274-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/dvp/dvp_design.html" id="dvp_design_intro-d4445e5274-link">设计说明</a></div></div><ul role="group" class="navbar-nav nav-list"><li role="treeitem"><div data-tocid="dvp_key_procedures-d4445e5288" class="topicref" data-id="dvp_key_procedures" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/dvp/dvp_key_procedure.html" id="dvp_key_procedures-d4445e5288-link">关键流程设计</a></div></div></li><li role="treeitem" class="active"><div data-tocid="dvp_data_structure-d4445e5302" class="topicref" data-id="dvp_data_structure" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/dvp/dvp_data_struct.html" id="dvp_data_structure-d4445e5302-link">数据结构设计</a></div></div></li><li role="treeitem"><div data-tocid="dvp_interface_design-d4445e5316" class="topicref" data-id="dvp_interface_design" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/dvp/dvp_interface.html" id="dvp_interface_design-d4445e5316-link">接口设计</a></div></div></li><li role="treeitem"><div data-tocid="dvp-demo-d4445e5330" class="topicref" data-id="dvp-demo" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/dvp/dvp_demo.html" id="dvp-demo-d4445e5330-link">APP Demo</a></div></div></li></ul></li><li role="treeitem"><div data-tocid="dvp_common_issues-d4445e5344" class="topicref" data-id="dvp_common_issues" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/dvp/dvp_faq.html" id="dvp_common_issues-d4445e5344-link">常见问题</a></div></div></li></ul></li><li role="treeitem" aria-expanded="false"><div data-tocid="mpp-d4445e5358" class="topicref" data-id="mpp" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action mpp-d4445e5358-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/mpp/mpp_user_guide.html" id="mpp-d4445e5358-link">MPP 使用指南</a></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="mpp_0-d4445e5498" class="topicref" data-id="mpp_0" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action mpp_0-d4445e5498-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/mpp/mpp_player_user_guide.html" id="mpp_0-d4445e5498-link">MPP 播放器使用指南</a></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="gstreamer-d4445e5582" class="topicref" data-id="gstreamer" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action gstreamer-d4445e5582-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/gstreamer/gstreamer-user-guide.html" id="gstreamer-d4445e5582-link">Gstreamer 使用指南</a></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="i2s-d4445e5680" class="topicref" data-id="i2s" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action i2s-d4445e5680-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/i2s/i2s_user_guide.html" id="i2s-d4445e5680-link">I2S 使用指南</a></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="audio_codec_user_guide-d4445e5806" class="topicref" data-id="audio_codec_user_guide" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action audio_codec_user_guide-d4445e5806-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/audio_codec/audio-codec-user-guide.html" id="audio_codec_user_guide-d4445e5806-link">Audio Codec 使用指南</a></div></div></li></ul></li><li role="treeitem" aria-expanded="false"><div data-tocid="concept_nww_hzh_pzb-d4445e5947" class="topicref" data-id="concept_nww_hzh_pzb" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action concept_nww_hzh_pzb-d4445e5947-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/chapter-title/chapter-interface-sdk.html" id="concept_nww_hzh_pzb-d4445e5947-link">接口</a><div class="wh-tooltip"><p class="shortdesc">CAN、CIR、GPAI、GPIO、I2C、PSADC、PWM 等接口模块的介绍和使用说明。</p></div></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="chapter-safety-d4445e7944" class="topicref" data-id="chapter-safety" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action chapter-safety-d4445e7944-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/chapter-title/chapter-safety-sdk.html" id="chapter-safety-d4445e7944-link">安全</a><div class="wh-tooltip"><p class="shortdesc">SPI ENC、CE、eFuse 等安全模块的介绍和使用说明。</p></div></div></div></li></ul></li></ul></div>
</div>
</nav>
<div class="col-lg-9 col-md-9 col-sm-12" id="wh_topic_body">
<button id="wh_close_publication_toc_button" class="close-toc-button d-none" aria-label="Toggle publishing table of content" aria-controls="wh_publication_toc" aria-expanded="true">
<span class="close-toc-icon-container">
<span class="close-toc-icon"></span>
</span>
</button>
<div class=" wh_topic_content body "><main role="main"><article class="- topic/topic concept/concept topic concept" role="article" aria-labelledby="ariaid-title1">
<span class="edit-link" style="font-size:12px; opacity:0.6; text-align:right; vertical-align:middle"><a target="_blank" title="Edit this document" href="http://172.16.35.88/tasks/jdssno1uvvbf2mltu9kb9v3if05d5gopuakboe8hlud18rma/edit/F:/aicdita/aicdita-cn/topics/sdk/dvp/dvp_data_struct.dita">Edit online</a></span><h1 class="- topic/title title topictitle1" id="ariaid-title1">数据结构设计</h1>
<div class="date inPage">15 Jan 2024</div><div style="color: gray;">
Read time: 3 minute(s)
</div>
<div class="- topic/body concept/conbody body conbody">
<div class="- topic/p p" data-ofbid="d85168e33__20250123155206">DVP 自定义的数据结构都在 <span class="+ topic/ph sw-d/filepath ph filepath">aic_dvp.h</span> 中。<ul class="- topic/ul ul" id="dvp_data_structure__ul_wjp_2dh_d1c" data-ofbid="dvp_data_structure__ul_wjp_2dh_d1c">
<li class="- topic/li li" data-ofbid="d85168e40__20250123155206">struct aic_dvp定义了 DVP
控制器的设备管理信息:<pre class="+ topic/pre pr-d/codeblock pre codeblock language-c" id="dvp_data_structure__codeblock_pgx_fdh_d1c" data-ofbid="dvp_data_structure__codeblock_pgx_fdh_d1c"><code><strong class="hl-keyword">struct</strong> aic_dvp {
<em class="hl-comment">/* Device resources */</em>
<strong class="hl-keyword">struct</strong> device *dev;
<strong class="hl-keyword">void</strong> __iomem *regs;
<strong class="hl-keyword">struct</strong> clk *clk;
<strong class="hl-keyword">struct</strong> reset_control *rst;
u32 clk_rate;
<strong class="hl-keyword">int</strong> irq;
<strong class="hl-keyword">int</strong> ch;
<strong class="hl-keyword">struct</strong> vb2_v4l2_buffer *vbuf[DVP_MAX_BUF];
<strong class="hl-keyword">struct</strong> aic_dvp_config cfg; <em class="hl-comment">/* The configuration of DVP HW */</em>
<strong class="hl-keyword">struct</strong> v4l2_fwnode_bus_parallel bus; <em class="hl-comment">/* The format of input data */</em>
<strong class="hl-keyword">struct</strong> v4l2_pix_format_mplane fmt; <em class="hl-comment">/* The format of output data */</em>
<em class="hl-comment">/* Main Device */</em>
<strong class="hl-keyword">struct</strong> v4l2_device v4l2;
<strong class="hl-keyword">struct</strong> media_device mdev;
<strong class="hl-keyword">struct</strong> video_device vdev;
<strong class="hl-keyword">struct</strong> media_pad vdev_pad;
<em class="hl-comment">/* Local subdev */</em>
<strong class="hl-keyword">struct</strong> v4l2_subdev subdev;
<strong class="hl-keyword">struct</strong> media_pad subdev_pads[DVP_SUBDEV_PAD_NUM];
<strong class="hl-keyword">struct</strong> v4l2_mbus_framefmt subdev_fmt;
<em class="hl-comment">/* V4L2 Async variables */</em>
<strong class="hl-keyword">struct</strong> v4l2_async_subdev asd;
<strong class="hl-keyword">struct</strong> v4l2_async_notifier notifier;
<strong class="hl-keyword">struct</strong> v4l2_subdev *src_subdev;
<strong class="hl-keyword">int</strong> src_pad;
<em class="hl-comment">/* V4L2 variables */</em>
<strong class="hl-keyword">struct</strong> mutex lock;
<em class="hl-comment">/* Videobuf2 */</em>
<strong class="hl-keyword">struct</strong> vb2_queue queue;
<strong class="hl-keyword">struct</strong> list_head buf_list;
spinlock_t qlock;
<strong class="hl-keyword">unsigned</strong> <strong class="hl-keyword">int</strong> sequence;
};</code></pre></li>
<li class="- topic/li li" data-ofbid="d85168e45__20250123155206">struct aic_dvp_config定义了 V4L2 媒体数据的配置信息:<pre class="+ topic/pre pr-d/codeblock pre codeblock language-c" id="dvp_data_structure__codeblock_n1b_gdh_d1c" data-ofbid="dvp_data_structure__codeblock_n1b_gdh_d1c"><code><span class="hl-tag-doctype-comment">/**
* Save the configuration information for DVP controller.</span><span class="- topic/ph ph">
* @code: media bus format code (MEDIA_BUS_FMT_*, in media-bus-format.h)
* @field: used interlacing type (<strong class="hl-keyword">enum</strong> v4l2_field)
* @width: frame width
* @height: frame height
*/</span>
<strong class="hl-keyword">struct</strong> aic_dvp_config {
<em class="hl-comment">/* Input format */</em>
<strong class="hl-keyword">enum</strong> dvp_input input;
<strong class="hl-keyword">enum</strong> dvp_input_yuv_seq input_seq;
<strong class="hl-keyword">enum</strong> v4l2_field field;
<em class="hl-comment">/* Output format */</em>
<strong class="hl-keyword">enum</strong> dvp_output output;
u32 width;
u32 height;
u32 stride[DVP_MAX_PLANE];
u32 sizeimage[DVP_MAX_PLANE];
};</code></pre></li>
<li class="- topic/li li" data-ofbid="d85168e53__20250123155206">aic_dvp_buf<div class="- topic/p p" data-ofbid="d85168e55__20250123155206">定义了 DVP 驱动的 Buf
管理信息:<pre class="+ topic/pre pr-d/codeblock pre codeblock language-c" id="dvp_data_structure__codeblock_ymc_gdh_d1c" data-ofbid="dvp_data_structure__codeblock_ymc_gdh_d1c"><code><strong class="hl-keyword">struct</strong> aic_dvp_buf {
<strong class="hl-keyword">struct</strong> vb2_v4l2_buffer vb;
<strong class="hl-keyword">struct</strong> list_head list;
dma_addr_t paddr[DVP_MAX_PLANE];
bool dvp_using;
};</code></pre></div></li>
</ul></div>
<section class="- topic/section section" id="dvp_data_structure__section_ytx_qzm_4dc" data-ofbid="dvp_data_structure__section_ytx_qzm_4dc"><h2 class="- topic/title title sectiontitle"> 输入输出的数据格式</h2>
<ul class="- topic/ul ul" id="dvp_data_structure__ul_upd_5xm_4dc" data-ofbid="dvp_data_structure__ul_upd_5xm_4dc">
<li class="- topic/li li" data-ofbid="d85168e68__20250123155206">
<div class="- topic/div div section" id="dvp_data_structure__enum-dvp-input">
<strong class="+ topic/ph hi-d/b ph b">enum dvp_input</strong>
<div class="- topic/p p" data-ofbid="d85168e75__20250123155206">定义了 DVP
输入数据的格式:<pre class="+ topic/pre pr-d/codeblock pre codeblock language-c" id="dvp_data_structure__codeblock_jf1_mkt_2dc" data-ofbid="dvp_data_structure__codeblock_jf1_mkt_2dc"><code><strong class="hl-keyword">enum</strong> dvp_input {
DVP_IN_RAW = <span class="hl-number">0</span>,
DVP_IN_YUV422 = <span class="hl-number">1</span>,
DVP_IN_BT656 = <span class="hl-number">2</span>,
};</code></pre></div></div>
</li>
<li class="- topic/li li" data-ofbid="d85168e81__20250123155206">
<div class="- topic/div div section" id="dvp_data_structure__enum-dvp-input-yuv-seq">
<strong class="+ topic/ph hi-d/b ph b">enum dvp_input_yuv_seq</strong>
<div class="- topic/p p" data-ofbid="d85168e88__20250123155206">定义了 DVP 输入数据的 YUV
格式:<pre class="+ topic/pre pr-d/codeblock pre codeblock language-c" id="dvp_data_structure__codeblock_bkq_mkt_2dc" data-ofbid="dvp_data_structure__codeblock_bkq_mkt_2dc"><code><strong class="hl-keyword">enum</strong> dvp_input_yuv_seq {
DVP_YUV_DATA_SEQ_YUYV = <span class="hl-number">0</span>,
DVP_YUV_DATA_SEQ_YVYU = <span class="hl-number">1</span>,
DVP_YUV_DATA_SEQ_UYVY = <span class="hl-number">2</span>,
DVP_YUV_DATA_SEQ_VYUY = <span class="hl-number">3</span>,
};</code></pre></div></div>
</li>
<li class="- topic/li li" data-ofbid="d85168e94__20250123155206">
<div class="- topic/div div section" id="dvp_data_structure__enum-dvp-output">
<strong class="+ topic/ph hi-d/b ph b">enum dvp_output</strong>
<div class="- topic/p p" data-ofbid="d85168e101__20250123155206">定义了 DVP
输出数据的格式:<pre class="+ topic/pre pr-d/codeblock pre codeblock language-c" id="dvp_data_structure__codeblock_l3v_mkt_2dc" data-ofbid="dvp_data_structure__codeblock_l3v_mkt_2dc"><code><strong class="hl-keyword">enum</strong> dvp_output {
DVP_OUT_RAW_PASSTHROUGH = <span class="hl-number">0</span>,
DVP_OUT_YUV422_COMBINED_NV16 = <span class="hl-number">1</span>,
DVP_OUT_YUV420_COMBINED_NV12 = <span class="hl-number">2</span>,
};</code></pre></div></div>
</li>
</ul>
</section>
</div>
</article></main></div>
</div>
</div>
</div>
</div>
<footer class="navbar navbar-default wh_footer">
<div class=" footer-container mx-auto ">
<title>footer def</title>
<style><!--
.p1 {
font-family: FangZhengShuSong, Times, serif;
}
.p2 {
font-family: Arial, Helvetica, sans-serif;
}
.p3 {
font-family: "Lucida Console", "Courier New", monospace;
}
--></style>
<div class="webhelp.fragment.footer">
<p class="p1">Copyright © 2019-2024 广东匠芯创科技有限公司. All rights reserved.</p>
</div><div>
<div class="generation_time">
Update Time: 2025-01-23
</div>
</div>
</div>
</footer>
<button id="go2top" class="d-print-none" title="返回顶部">
<span class="oxy-icon oxy-icon-up"></span>
</button>
<div id="modal_img_large" class="modal">
<span class="close oxy-icon oxy-icon-remove"></span>
<div id="modal_img_container"></div>
<div id="caption"></div>
</div>
<script src="${pd}/publishing/publishing-styles-AIC-template/js/custom.js" defer="defer"></script>
</body>
</html>