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

300 lines
38 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="非命令队列模式,即 normal 模式。 GE normal 模式的控制流程如下所示: 当用户态通过 open 函数打开 /dev/ge 设备节点,会调用到驱动中的 open。 当用户通过 close 关闭驱动时,会调用到驱动中的 release。 在 open 中主要是实现了模块 clock 的打开操作, 在 release 中实现了模块 clock 的关闭操作。 当用户态有多个用户打开 GE ..."/><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/ge/ge_design.html"/><meta name="DC.relation" content="../../../topics/sdk/ge/ge_design.html"/><meta name="DC.relation" content="../../../topics/sdk/ge/ge_cmdq_mode.html"/><meta name="DC.contributor" content="yan.wang"/><meta name="DC.creator" content="yan.wang"/><meta name="DC.date.modified" content="2024-01-15"/><meta name="DC.format" content="HTML5"/><meta name="DC.identifier" content="ge_normal_mode"/><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="ge_normal_mode-d4445e4525"/><meta name="wh-source-relpath" content="topics/sdk/ge/ge_normal_mode.dita"/><meta name="wh-out-relpath" content="topics/sdk/ge/ge_normal_mode.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="ge_normal_mode" 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="ge"><div class="title"><a href="../../../topics/sdk/ge/ge_user_guide.html">GE 使用指南</a></div></div></li><li><div class="topicref" data-id="ge_design_intro"><div class="title"><a href="../../../topics/sdk/ge/ge_design.html">设计说明</a></div></div></li><li class="active"><div class="topicref" data-id="ge_normal_mode"><div class="title"><a href="../../../topics/sdk/ge/ge_normal_mode.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/ge/ge_design.html" title="设计说明" aria-label="上一主题: 设计说明" rel="prev"></a></span>
<span class="navnext"><a class="- topic/link link" href="../../../topics/sdk/ge/ge_cmdq_mode.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="true"><div data-tocid="ge-d4445e4455" class="topicref" data-id="ge" data-state="expanded"><span role="button" tabindex="0" aria-labelledby="button-collapse-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><ul role="group" class="navbar-nav nav-list"><li role="treeitem"><div data-tocid="ge_configuration-d4445e4469" class="topicref" data-id="ge_configuration" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/ge/ge_config.html" id="ge_configuration-d4445e4469-link">GE 配置</a></div></div></li><li role="treeitem"><div data-tocid="ge_debug_guide-d4445e4483" class="topicref" data-id="ge_debug_guide" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/ge/ge_debug.html" id="ge_debug_guide-d4445e4483-link">调试指南</a></div></div></li><li role="treeitem"><div data-tocid="ge_test_guide-d4445e4497" class="topicref" data-id="ge_test_guide" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/ge/ge_test.html" id="ge_test_guide-d4445e4497-link">测试指南</a></div></div></li><li role="treeitem" aria-expanded="true"><div data-tocid="ge_design_intro-d4445e4511" class="topicref" data-id="ge_design_intro" data-state="expanded"><span role="button" tabindex="0" aria-labelledby="button-collapse-action ge_design_intro-d4445e4511-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/ge/ge_design.html" id="ge_design_intro-d4445e4511-link">设计说明</a></div></div><ul role="group" class="navbar-nav nav-list"><li role="treeitem" class="active"><div data-tocid="ge_normal_mode-d4445e4525" class="topicref" data-id="ge_normal_mode" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/ge/ge_normal_mode.html" id="ge_normal_mode-d4445e4525-link">非命令队列模式</a></div></div></li><li role="treeitem"><div data-tocid="ge_command_queue_mode-d4445e4539" class="topicref" data-id="ge_command_queue_mode" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/ge/ge_cmdq_mode.html" id="ge_command_queue_mode-d4445e4539-link">命令队列模式</a></div></div></li><li role="treeitem"><div data-tocid="ge-compare-mode-d4445e4553" class="topicref" data-id="ge-compare-mode" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/ge/ge_compare_mode.html" id="ge-compare-mode-d4445e4553-link">非命令队列和命令队列对比</a></div></div></li><li role="treeitem"><div data-tocid="ge_data_structure-d4445e4567" class="topicref" data-id="ge_data_structure" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/ge/ge_data_structure.html" id="ge_data_structure-d4445e4567-link">数据结构设计</a></div></div></li><li role="treeitem"><div data-tocid="ge_interface_design-d4445e4581" class="topicref" data-id="ge_interface_design" data-state="leaf"><span role="button" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/ge/ge_interface.html" id="ge_interface_design-d4445e4581-link">接口设计</a></div></div></li><li role="treeitem" aria-expanded="false"><div data-tocid="ge_mpp_api-d4445e4595" class="topicref" data-id="ge_mpp_api" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-action ge_mpp_api-d4445e4595-link" class="wh-expand-btn"></span><div class="title"><a href="../../../topics/sdk/ge/ge_mpp_api.html" id="ge_mpp_api-d4445e4595-link">MPP 对 GE 接口的封装</a></div></div></li></ul></li></ul></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="false"><div data-tocid="concept_h4d_fwt_tzb-d4445e5218" class="topicref" data-id="concept_h4d_fwt_tzb" data-state="not-ready"><span role="button" tabindex="0" aria-labelledby="button-expand-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></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-7 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>
<button id="wh_close_topic_toc_button" class="close-toc-button d-none" aria-label="Toggle topic table of content" aria-controls="wh_topic_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/ge/ge_normal_mode.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: 2 minute(s)
</div>
<div class="- topic/body concept/conbody body conbody">
<p class="- topic/p p" data-ofbid="d189248e33__20250123155220">非命令队列模式,即 normal 模式。</p>
<div class="- topic/p p" data-ofbid="d189248e36__20250123155220">GE normal 模式的控制流程如下所示:<ul class="- topic/ul ul" id="ge_normal_mode__ul_stj_lx4_bcc" data-ofbid="ge_normal_mode__ul_stj_lx4_bcc">
<li class="- topic/li li" data-ofbid="d189248e40__20250123155220">当用户态通过 open 函数打开 /dev/ge 设备节点,会调用到驱动中的 open。</li>
<li class="- topic/li li" data-ofbid="d189248e43__20250123155220">当用户通过 close 关闭驱动时,会调用到驱动中的 release。</li>
<li class="- topic/li li" data-ofbid="d189248e46__20250123155220">在 open 中主要是实现了模块 clock 的打开操作, 在 release 中实现了模块 clock 的关闭操作。</li>
<li class="- topic/li li" data-ofbid="d189248e49__20250123155220">当用户态有多个用户打开 GE 驱动时,对驱动打开次数进行引用计数。</li>
<li class="- topic/li li" data-ofbid="d189248e52__20250123155220">至少有一个用户打开 GE 驱动时打开 GE 的 clock。</li>
<li class="- topic/li li" data-ofbid="d189248e56__20250123155220">当所有的用户都关闭 GE 驱动时关闭 GE 的 clock。 </li>
</ul></div>
<div class="- topic/p p" data-ofbid="d189248e60__20250123155220">
<figure class="- topic/fig fig fignone" id="ge_normal_mode__fig_uvv_gbb_d1c" data-ofbid="ge_normal_mode__fig_uvv_gbb_d1c">
<br/><div class="imagecenter"><img class="- topic/image image imagecenter" id="ge_normal_mode__image_bvc_hbb_d1c" src="../../../images/ge/ge_sw_normal.png" alt="ge_sw_normal"/></div><br/>
<figcaption data-caption-side="bottom" class="- topic/title title figcapcenter"><span class="figtitleprefix fig--title-label"><span class="fig--title-label-number"> 1</span><span class="fig--title-label-punctuation">. </span></span><span class="fig--title">非命令队列模式架构</span></figcaption></figure>
</div>
<div class="- topic/p p" data-ofbid="d189248e75__20250123155220">在 Normal 模式下,用户态可用 <span class="+ topic/keyword pr-d/apiname keyword apiname">ioctl</span> 控制 GE包括以下几种操作<ul class="- topic/ul ul" id="ge_normal_mode__ul_d2l_jbb_d1c" data-ofbid="ge_normal_mode__ul_d2l_jbb_d1c">
<li class="- topic/li li" data-ofbid="d189248e82__20250123155220">
<p class="- topic/p p" data-ofbid="d189248e84__20250123155220"><span class="+ topic/keyword pr-d/apiname keyword apiname">IOC_GE_VERSION</span></p>
</li>
<li class="- topic/li li" data-ofbid="d189248e89__20250123155220">
<p class="- topic/p p" data-ofbid="d189248e91__20250123155220"><span class="+ topic/keyword pr-d/apiname keyword apiname">IOC_GE_MODE</span></p>
</li>
<li class="- topic/li li" data-ofbid="d189248e96__20250123155220">
<p class="- topic/p p" data-ofbid="d189248e98__20250123155220"><span class="+ topic/keyword pr-d/apiname keyword apiname">IOC_GE_FILLRECT</span></p>
</li>
<li class="- topic/li li" data-ofbid="d189248e103__20250123155220">
<p class="- topic/p p" data-ofbid="d189248e105__20250123155220"><span class="+ topic/keyword pr-d/apiname keyword apiname">IOC_GE_BITBLT</span></p>
</li>
<li class="- topic/li li" data-ofbid="d189248e110__20250123155220">
<p class="- topic/p p" data-ofbid="d189248e112__20250123155220"><span class="+ topic/keyword pr-d/apiname keyword apiname">IOC_GE_ROTATE</span></p>
</li>
</ul></div>
<p class="- topic/p p" data-ofbid="d189248e118__20250123155220">在 normal 模式下,对
<span class="+ topic/keyword pr-d/apiname keyword apiname">IOC_GE_FILLRECT</span><span class="+ topic/keyword pr-d/apiname keyword apiname">IOC_GE_BITBLT</span><span class="+ topic/keyword pr-d/apiname keyword apiname">IOC_GE_ROTATE</span>
接口的调用是同步的,即硬件执行任务完成后接口调用才会返回。 </p>
<section class="- topic/section section" id="ge_normal_mode__section_bq5_vpr_ndc" data-ofbid="ge_normal_mode__section_bq5_vpr_ndc"><h2 class="- topic/title title sectiontitle">GE 控制函数</h2>
<div class="- topic/p p" data-ofbid="d189248e136__20250123155220">
<ul class="- topic/ul ul" id="ge_normal_mode__ul_uz4_nqr_ndc" data-ofbid="ge_normal_mode__ul_uz4_nqr_ndc">
<li class="- topic/li li" data-ofbid="d189248e140__20250123155220">
<div class="- topic/p p" data-ofbid="d189248e142__20250123155220"><strong class="+ topic/ph hi-d/b ph b">函数 <span class="+ topic/keyword pr-d/apiname keyword apiname">ge_open</span></strong>:打开
GE<pre class="+ topic/pre pr-d/codeblock pre codeblock language-c" id="ge_normal_mode__codeblock_vvs_4qr_ndc" data-ofbid="ge_normal_mode__codeblock_vvs_4qr_ndc"><code><strong class="hl-keyword">static</strong> <strong class="hl-keyword">int</strong> ge_open(<strong class="hl-keyword">struct</strong> inode *inode, <strong class="hl-keyword">struct</strong> file *file)
{
mutex_lock(&amp;g_data-&gt;lock);
<strong class="hl-keyword">if</strong> (g_data-&gt;refs == <span class="hl-number">0</span>) {
ge_clk_enable(g_data);
}
g_data-&gt;refs++;
mutex_unlock(&amp;g_data-&gt;lock);
<strong class="hl-keyword">return</strong> nonseekable_open(inode, file);
}
</code></pre></div>
</li>
<li class="- topic/li li" data-ofbid="d189248e152__20250123155220">
<div class="- topic/p p" data-ofbid="d189248e154__20250123155220"><strong class="+ topic/ph hi-d/b ph b">函数 <span class="+ topic/keyword pr-d/apiname keyword apiname">ge_release</span></strong>:关闭
GE<pre class="+ topic/pre pr-d/codeblock pre codeblock language-c" id="ge_normal_mode__codeblock_ny3_3bb_d1c" data-ofbid="ge_normal_mode__codeblock_ny3_3bb_d1c"><code><strong class="hl-keyword">static</strong> <strong class="hl-keyword">int</strong> ge_release(<strong class="hl-keyword">struct</strong> inode *inode, <strong class="hl-keyword">struct</strong> file *file)
{
mutex_lock(&amp;g_data-&gt;lock);
<strong class="hl-keyword">if</strong> (g_data-&gt;refs == <span class="hl-number">1</span>) {
ge_clk_disable(g_data);
}
g_data-&gt;refs--;
mutex_unlock(&amp;g_data-&gt;lock);
<strong class="hl-keyword">return</strong> <span class="hl-number">0</span>;
}</code></pre></div>
</li>
</ul>
</div>
</section>
<section class="- topic/section section" id="ge_normal_mode__section_z4j_qbb_d1c" data-ofbid="ge_normal_mode__section_z4j_qbb_d1c"><h2 class="- topic/title title sectiontitle">关键流程设计</h2>
<p class="- topic/p p" data-ofbid="d189248e174__20250123155220">在 GE normal 模式下GE 驱动各种功能通过 <span class="+ topic/keyword pr-d/apiname keyword apiname">ioctrl</span> 调用实现。</p>
<div class="- topic/p p" data-ofbid="d189248e180__20250123155220">每一次 <span class="+ topic/keyword pr-d/apiname keyword apiname">ioctrl</span> 的调用,都包括以下步骤:<ol class="- topic/ol ol" id="ge_normal_mode__ol_nnr_smz_2dc" data-ofbid="ge_normal_mode__ol_nnr_smz_2dc">
<li class="- topic/li li" data-ofbid="d189248e187__20250123155220">GE 参数配置。</li>
<li class="- topic/li li" data-ofbid="d189248e190__20250123155220">GE 模块中断开启。</li>
<li class="- topic/li li" data-ofbid="d189248e193__20250123155220">GE 硬件启动。</li>
<li class="- topic/li li" data-ofbid="d189248e196__20250123155220">GE 等待中断,当前线程进入等待状态,直到收到中断通知。</li>
<li class="- topic/li li" data-ofbid="d189248e199__20250123155220">硬件完成任务后,关闭中断。</li>
</ol>
</div>
<p class="- topic/p p" data-ofbid="d189248e204__20250123155220"><span class="+ topic/keyword pr-d/apiname keyword apiname">ioctrl</span> 通过 mutex 保护, 确保多线程环境下的安全性。在 normal 模式下,支持多用户同时打开驱动设备节点,并调用
<span class="+ topic/keyword pr-d/apiname keyword apiname">ioctrl</span></p>
<figure class="- topic/fig fig fignone" id="ge_normal_mode__fig_elx_qbb_d1c" data-ofbid="ge_normal_mode__fig_elx_qbb_d1c">
<br/><div class="imagecenter"><img class="- topic/image image imagecenter" id="ge_normal_mode__image_apj_qbb_d1c" src="../../../images/ge/ge_sw_normal_interrupt.png" alt="normal_interrupt"/></div><br/>
<figcaption data-caption-side="bottom" class="- topic/title title figcapcenter"><span class="figtitleprefix fig--title-label"><span class="fig--title-label-number"> 2</span><span class="fig--title-label-punctuation">. </span></span><span class="fig--title">Normal 模式中断流程</span></figcaption></figure>
<div class="- topic/p p" data-ofbid="d189248e225__20250123155220">等待中断流程:<ul class="- topic/ul ul" id="ge_normal_mode__ul_v1k_hpm_f1c" data-ofbid="ge_normal_mode__ul_v1k_hpm_f1c">
<li class="- topic/li li" data-ofbid="d189248e229__20250123155220">
<p class="- topic/p p" data-ofbid="d189248e231__20250123155220">在执行 <span class="+ topic/keyword pr-d/apiname keyword apiname">probe</span>
时初始化等待队列:<span class="+ topic/keyword pr-d/apiname keyword apiname">init_waitqueue_head(&amp;data-&gt;wait)</span></p>
</li>
<li class="- topic/li li" data-ofbid="d189248e241__20250123155220">
<p class="- topic/p p" data-ofbid="d189248e243__20250123155220"><span class="+ topic/keyword pr-d/apiname keyword apiname">ioctl</span> 中调用如下函数,使当前进程在等待队列中睡眠:</p>
<p class="- topic/p p" data-ofbid="d189248e249__20250123155220"><span class="+ topic/keyword pr-d/apiname keyword apiname">wait_event_timeout(data-&gt;wait, data-&gt;status,
msecs_to_jiffies(GE_TIMEOUT_MS))</span></p>
</li>
<li class="- topic/li li" data-ofbid="d189248e255__20250123155220">
<p class="- topic/p p" data-ofbid="d189248e257__20250123155220">在中断服务程序中调用 <span class="+ topic/keyword pr-d/apiname keyword apiname">wake_up(&amp;data-&gt;wait)</span>,唤醒等待队列中的睡眠进程。</p>
</li>
</ul></div>
</section>
</div>
</article></main></div>
</div>
<nav role="navigation" id="wh_topic_toc" aria-label="On this page" class="col-lg-2 d-none d-lg-block navbar d-print-none">
<div id="wh_topic_toc_content">
<div class=" wh_topic_toc "><div class="wh_topic_label">在本页上</div><ul><li class="section-item"><div class="section-title"><a href="#ge_normal_mode__section_bq5_vpr_ndc" data-tocid="ge_normal_mode__section_bq5_vpr_ndc">GE 控制函数</a></div></li><li class="section-item"><div class="section-title"><a href="#ge_normal_mode__section_z4j_qbb_d1c" data-tocid="ge_normal_mode__section_z4j_qbb_d1c">关键流程设计</a></div></li></ul></div>
</div>
</nav>
</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>