<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> <meta http-equiv="X-UA-Compatible" content="IE=9"/> <meta name="generator" content="Doxygen 1.8.16"/> <meta name="viewport" content="width=device-width, initial-scale=1"/> <title>UbixOS V2: C:/Dev/git/UbixOS/sys/include/pci/pci.h File Reference</title> <link href="tabs.css" rel="stylesheet" type="text/css"/> <script type="text/javascript" src="jquery.js"></script> <script type="text/javascript" src="dynsections.js"></script> <link href="navtree.css" rel="stylesheet" type="text/css"/> <script type="text/javascript" src="resize.js"></script> <script type="text/javascript" src="navtreedata.js"></script> <script type="text/javascript" src="navtree.js"></script> <script type="text/javascript"> /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */ $(document).ready(initResizable); /* @license-end */</script> <link href="search/search.css" rel="stylesheet" type="text/css"/> <script type="text/javascript" src="search/searchdata.js"></script> <script type="text/javascript" src="search/search.js"></script> <link href="doxygen.css" rel="stylesheet" type="text/css" /> </head> <body> <div id="top"><!-- do not remove this div, it is closed by doxygen! --> <div id="titlearea"> <table cellspacing="0" cellpadding="0"> <tbody> <tr style="height: 56px;"> <td id="projectalign" style="padding-left: 0.5em;"> <div id="projectname">UbixOS V2  <span id="projectnumber">2.0</span> </div> </td> </tr> </tbody> </table> </div> <!-- end header part --> <!-- Generated by Doxygen 1.8.16 --> <script type="text/javascript"> /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */ var searchBox = new SearchBox("searchBox", "search",false,'Search'); /* @license-end */ </script> <script type="text/javascript" src="menudata.js"></script> <script type="text/javascript" src="menu.js"></script> <script type="text/javascript"> /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */ $(function() { initMenu('',true,false,'search.php','Search'); $(document).ready(function() { init_search(); }); }); /* @license-end */</script> <div id="main-nav"></div> </div><!-- top --> <div id="side-nav" class="ui-resizable side-nav-resizable"> <div id="nav-tree"> <div id="nav-tree-contents"> <div id="nav-sync" class="sync"></div> </div> </div> <div id="splitbar" style="-moz-user-select:none;" class="ui-resizable-handle"> </div> </div> <script type="text/javascript"> /* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&dn=gpl-2.0.txt GPL-v2 */ $(document).ready(function(){initNavTree('pci_8h.html','');}); /* @license-end */ </script> <div id="doc-content"> <!-- window showing the filter options --> <div id="MSearchSelectWindow" onmouseover="return searchBox.OnSearchSelectShow()" onmouseout="return searchBox.OnSearchSelectHide()" onkeydown="return searchBox.OnSearchSelectKey(event)"> </div> <!-- iframe showing the search results (closed by default) --> <div id="MSearchResultsWindow"> <iframe src="javascript:void(0)" frameborder="0" name="MSearchResults" id="MSearchResults"> </iframe> </div> <div class="header"> <div class="summary"> <a href="#nested-classes">Data Structures</a> | <a href="#define-members">Macros</a> | <a href="#func-members">Functions</a> </div> <div class="headertitle"> <div class="title">pci.h File Reference</div> </div> </div><!--header--> <div class="contents"> <div class="textblock"><code>#include <<a class="el" href="include_2sys_2types_8h_source.html">sys/types.h</a>></code><br /> </div><div class="textblock"><div class="dynheader"> Include dependency graph for pci.h:</div> <div class="dyncontent"> <div class="center"><img src="pci_8h__incl.png" border="0" usemap="#C_1_2Dev_2git_2UbixOS_2sys_2include_2pci_2pci_8h" alt=""/></div> </div> </div><div class="textblock"><div class="dynheader"> This graph shows which files directly or indirectly include this file:</div> <div class="dyncontent"> <div class="center"><img src="pci_8h__dep__incl.png" border="0" usemap="#C_1_2Dev_2git_2UbixOS_2sys_2include_2pci_2pci_8hdep" alt=""/></div> </div> </div> <p><a href="pci_8h_source.html">Go to the source code of this file.</a></p> <table class="memberdecls"> <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="nested-classes"></a> Data Structures</h2></td></tr> <tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct  </td><td class="memItemRight" valign="bottom"><a class="el" href="structconfadd.html">confadd</a></td></tr> <tr class="separator:"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:"><td class="memItemLeft" align="right" valign="top">struct  </td><td class="memItemRight" valign="bottom"><a class="el" href="structpciConfig.html">pciConfig</a></td></tr> <tr class="separator:"><td class="memSeparator" colspan="2"> </td></tr> </table><table class="memberdecls"> <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="define-members"></a> Macros</h2></td></tr> <tr class="memitem:a3c5cd622462bb50b6dab4c189e219eb9"><td class="memItemLeft" align="right" valign="top">#define </td><td class="memItemRight" valign="bottom"><a class="el" href="pci_8h.html#a3c5cd622462bb50b6dab4c189e219eb9">countof</a>(a)   (sizeof(a) / sizeof(a[0]))</td></tr> <tr class="separator:a3c5cd622462bb50b6dab4c189e219eb9"><td class="memSeparator" colspan="2"> </td></tr> </table><table class="memberdecls"> <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a> Functions</h2></td></tr> <tr class="memitem:a5c450b9e2534226b162a16de0ef6b434"><td class="memItemLeft" align="right" valign="top">int </td><td class="memItemRight" valign="bottom"><a class="el" href="pci_8h.html#a5c450b9e2534226b162a16de0ef6b434">pci_init</a> ()</td></tr> <tr class="separator:a5c450b9e2534226b162a16de0ef6b434"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a9a16d3ca1d4538415b752ab0c58e72ba"><td class="memItemLeft" align="right" valign="top"><a class="el" href="include_2sys_2types_8h.html#a0238af00180b6d9278fa1c6aa790fdf4">uint32_t</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="pci_8h.html#a9a16d3ca1d4538415b752ab0c58e72ba">pciProbe</a> (int bus, int dev, int func)</td></tr> <tr class="separator:a9a16d3ca1d4538415b752ab0c58e72ba"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a09d5fac523ec602b928a2eeb2dc3eee6"><td class="memItemLeft" align="right" valign="top"><a class="el" href="objgfx30_8h.html#ada085051a6d9a8e00a2cb256d1af14ba">uInt32</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="pci_8h.html#a09d5fac523ec602b928a2eeb2dc3eee6">pciRead</a> (int bus, int dev, int func, int reg, int bytes)</td></tr> <tr class="separator:a09d5fac523ec602b928a2eeb2dc3eee6"><td class="memSeparator" colspan="2"> </td></tr> <tr class="memitem:a562e38dfaaab5bd65c08f7ee9769235d"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="pci_8h.html#a562e38dfaaab5bd65c08f7ee9769235d">pciWrite</a> (int bus, int dev, int func, int reg, <a class="el" href="objgfx30_8h.html#ada085051a6d9a8e00a2cb256d1af14ba">uInt32</a> v, int bytes)</td></tr> <tr class="separator:a562e38dfaaab5bd65c08f7ee9769235d"><td class="memSeparator" colspan="2"> </td></tr> </table> <h2 class="groupheader">Macro Definition Documentation</h2> <a id="a3c5cd622462bb50b6dab4c189e219eb9"></a> <h2 class="memtitle"><span class="permalink"><a href="#a3c5cd622462bb50b6dab4c189e219eb9">◆ </a></span>countof</h2> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname">#define countof</td> <td>(</td> <td class="paramtype"> </td> <td class="paramname">a</td><td>)</td> <td>   (sizeof(a) / sizeof(a[0]))</td> </tr> </table> </div><div class="memdoc"> <p class="definition">Definition at line <a class="el" href="pci_8h_source.html#l00098">98</a> of file <a class="el" href="pci_8h_source.html">pci.h</a>.</p> </div> </div> <h2 class="groupheader">Function Documentation</h2> <a id="a5c450b9e2534226b162a16de0ef6b434"></a> <h2 class="memtitle"><span class="permalink"><a href="#a5c450b9e2534226b162a16de0ef6b434">◆ </a></span>pci_init()</h2> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname">int pci_init </td> <td>(</td> <td class="paramname"></td><td>)</td> <td></td> </tr> </table> </div><div class="memdoc"> <p class="definition">Definition at line <a class="el" href="pci_8c_source.html#l00244">244</a> of file <a class="el" href="pci_8c_source.html">pci.c</a>.</p> <p class="reference">References <a class="el" href="pci_8h_source.html#l00083">pciConfig::bus</a>, <a class="el" href="pci_8h_source.html#l00044">pciConfig::classCode</a>, <a class="el" href="pci_8h_source.html#l00098">countof</a>, <a class="el" href="pci_8h_source.html#l00084">pciConfig::dev</a>, <a class="el" href="pci_8h_source.html#l00085">pciConfig::func</a>, <a class="el" href="pci_8h_source.html#l00065">pciConfig::intLine</a>, <a class="el" href="pci_8h_source.html#l00066">pciConfig::intPin</a>, <a class="el" href="kprintf_8c_source.html#l00259">kprintf()</a>, <a class="el" href="pci_8c_source.html#l00037">name</a>, <a class="el" href="pci_8c.html#a06d7d37b951914590189751cececa69f">pciClasses</a>, <a class="el" href="pci_8c_source.html#l00139">pciProbe()</a>, <a class="el" href="pci_8h_source.html#l00042">pciConfig::progIf</a>, <a class="el" href="pci_8h_source.html#l00043">pciConfig::subClass</a>, and <a class="el" href="pci_8h_source.html#l00035">pciConfig::vendorID</a>.</p> <div class="dynheader"> Here is the call graph for this function:</div> <div class="dyncontent"> <div class="center"><img src="pci_8h_a5c450b9e2534226b162a16de0ef6b434_cgraph.png" border="0" usemap="#pci_8h_a5c450b9e2534226b162a16de0ef6b434_cgraph" alt=""/></div> </div> </div> </div> <a id="a9a16d3ca1d4538415b752ab0c58e72ba"></a> <h2 class="memtitle"><span class="permalink"><a href="#a9a16d3ca1d4538415b752ab0c58e72ba">◆ </a></span>pciProbe()</h2> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname"><a class="el" href="include_2sys_2types_8h.html#a0238af00180b6d9278fa1c6aa790fdf4">uint32_t</a> pciProbe </td> <td>(</td> <td class="paramtype">int </td> <td class="paramname"><em>bus</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">int </td> <td class="paramname"><em>dev</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">int </td> <td class="paramname"><em>func</em> </td> </tr> <tr> <td></td> <td>)</td> <td></td><td></td> </tr> </table> </div><div class="memdoc"> <p class="definition">Definition at line <a class="el" href="pci_8c_source.html#l00139">139</a> of file <a class="el" href="pci_8c_source.html">pci.c</a>.</p> <p class="reference">References <a class="el" href="pci_8h_source.html#l00051">pciConfig::bar</a>, <a class="el" href="pci_8h_source.html#l00049">pciConfig::bist</a>, <a class="el" href="pci_8h_source.html#l00083">pciConfig::bus</a>, <a class="el" href="pci_8h_source.html#l00046">pciConfig::cacheLineSize</a>, <a class="el" href="pci_8h_source.html#l00044">pciConfig::classCode</a>, <a class="el" href="pci_8h_source.html#l00038">pciConfig::command</a>, <a class="el" href="pci_8h_source.html#l00084">pciConfig::dev</a>, <a class="el" href="pci_8h_source.html#l00036">pciConfig::deviceID</a>, <a class="el" href="pci_8h_source.html#l00085">pciConfig::func</a>, <a class="el" href="pci_8h_source.html#l00048">pciConfig::headerType</a>, <a class="el" href="pci_8h_source.html#l00065">pciConfig::intLine</a>, <a class="el" href="pci_8h_source.html#l00066">pciConfig::intPin</a>, <a class="el" href="kmalloc_8c_source.html#l00342">kfree()</a>, <a class="el" href="kmalloc_8c_source.html#l00241">kmalloc()</a>, <a class="el" href="kprintf_8c_source.html#l00259">kprintf()</a>, <a class="el" href="pci_8h_source.html#l00047">pciConfig::latencyTimer</a>, <a class="el" href="string_8h.html#ace4b911463887af5e748326323e99a23">memset()</a>, <a class="el" href="pci_8c_source.html#l00076">pciRead()</a>, <a class="el" href="pci_8c_source.html#l00108">pciWrite()</a>, <a class="el" href="pci_8h_source.html#l00042">pciConfig::progIf</a>, <a class="el" href="pci_8h_source.html#l00039">pciConfig::status</a>, <a class="el" href="pci_8h_source.html#l00043">pciConfig::subClass</a>, and <a class="el" href="pci_8h_source.html#l00035">pciConfig::vendorID</a>.</p> <p class="reference">Referenced by <a class="el" href="pci_8c_source.html#l00244">pci_init()</a>.</p> <div class="dynheader"> Here is the call graph for this function:</div> <div class="dyncontent"> <div class="center"><img src="pci_8h_a9a16d3ca1d4538415b752ab0c58e72ba_cgraph.png" border="0" usemap="#pci_8h_a9a16d3ca1d4538415b752ab0c58e72ba_cgraph" alt=""/></div> </div> </div> </div> <a id="a09d5fac523ec602b928a2eeb2dc3eee6"></a> <h2 class="memtitle"><span class="permalink"><a href="#a09d5fac523ec602b928a2eeb2dc3eee6">◆ </a></span>pciRead()</h2> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname"><a class="el" href="objgfx30_8h.html#ada085051a6d9a8e00a2cb256d1af14ba">uInt32</a> pciRead </td> <td>(</td> <td class="paramtype">int </td> <td class="paramname"><em>bus</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">int </td> <td class="paramname"><em>dev</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">int </td> <td class="paramname"><em>func</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">int </td> <td class="paramname"><em>reg</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">int </td> <td class="paramname"><em>bytes</em> </td> </tr> <tr> <td></td> <td>)</td> <td></td><td></td> </tr> </table> </div><div class="memdoc"> <p class="definition">Definition at line <a class="el" href="pci_8c_source.html#l00076">76</a> of file <a class="el" href="pci_8c_source.html">pci.c</a>.</p> <p class="reference">References <a class="el" href="pci_8h_source.html#l00093">confadd::bus</a>, <a class="el" href="pci_8h_source.html#l00092">confadd::dev</a>, <a class="el" href="pci_8h_source.html#l00095">confadd::enable</a>, <a class="el" href="pci_8h_source.html#l00091">confadd::func</a>, <a class="el" href="io_8c_source.html#l00038">inportByte()</a>, <a class="el" href="io_8c_source.html#l00133">inportDWord()</a>, <a class="el" href="io_8c_source.html#l00055">inportWord()</a>, <a class="el" href="io_8c_source.html#l00118">outportDWord()</a>, and <a class="el" href="pci_8h_source.html#l00090">confadd::reg</a>.</p> <p class="reference">Referenced by <a class="el" href="pci_8c_source.html#l00139">pciProbe()</a>.</p> <div class="dynheader"> Here is the call graph for this function:</div> <div class="dyncontent"> <div class="center"><img src="pci_8h_a09d5fac523ec602b928a2eeb2dc3eee6_cgraph.png" border="0" usemap="#pci_8h_a09d5fac523ec602b928a2eeb2dc3eee6_cgraph" alt=""/></div> </div> </div> </div> <a id="a562e38dfaaab5bd65c08f7ee9769235d"></a> <h2 class="memtitle"><span class="permalink"><a href="#a562e38dfaaab5bd65c08f7ee9769235d">◆ </a></span>pciWrite()</h2> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname">void pciWrite </td> <td>(</td> <td class="paramtype">int </td> <td class="paramname"><em>bus</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">int </td> <td class="paramname"><em>dev</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">int </td> <td class="paramname"><em>func</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">int </td> <td class="paramname"><em>reg</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype"><a class="el" href="objgfx30_8h.html#ada085051a6d9a8e00a2cb256d1af14ba">uInt32</a> </td> <td class="paramname"><em>v</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">int </td> <td class="paramname"><em>bytes</em> </td> </tr> <tr> <td></td> <td>)</td> <td></td><td></td> </tr> </table> </div><div class="memdoc"> <p class="definition">Definition at line <a class="el" href="pci_8c_source.html#l00108">108</a> of file <a class="el" href="pci_8c_source.html">pci.c</a>.</p> <p class="reference">References <a class="el" href="pci_8h_source.html#l00093">confadd::bus</a>, <a class="el" href="pci_8h_source.html#l00092">confadd::dev</a>, <a class="el" href="pci_8h_source.html#l00095">confadd::enable</a>, <a class="el" href="pci_8h_source.html#l00091">confadd::func</a>, <a class="el" href="io_8c_source.html#l00072">outportByte()</a>, <a class="el" href="io_8c_source.html#l00118">outportDWord()</a>, <a class="el" href="io_8c_source.html#l00103">outportWord()</a>, and <a class="el" href="pci_8h_source.html#l00090">confadd::reg</a>.</p> <p class="reference">Referenced by <a class="el" href="pci_8c_source.html#l00139">pciProbe()</a>.</p> <div class="dynheader"> Here is the call graph for this function:</div> <div class="dyncontent"> <div class="center"><img src="pci_8h_a562e38dfaaab5bd65c08f7ee9769235d_cgraph.png" border="0" usemap="#pci_8h_a562e38dfaaab5bd65c08f7ee9769235d_cgraph" alt=""/></div> </div> </div> </div> </div><!-- contents --> </div><!-- doc-content --> <!-- start footer part --> <div id="nav-path" class="navpath"><!-- id is needed for treeview function! --> <ul> <li class="navelem"><a class="el" href="dir_e6bb53534ac0e427887cf7a94c0c004e.html">C:</a></li><li class="navelem"><a class="el" href="dir_d99d5d4662bf24521eef49da6a8cd34d.html">Dev</a></li><li class="navelem"><a class="el" href="dir_474a4b306371cf7e7f6fa12cb0b77df6.html">git</a></li><li class="navelem"><a class="el" href="dir_849109bbd106d461b128d63e5babcedf.html">UbixOS</a></li><li class="navelem"><a class="el" href="dir_6ec99f6d7d5182ba8913209ab70c9f18.html">sys</a></li><li class="navelem"><a class="el" href="dir_d1be8160e739b6eed1f7843efdbae1b3.html">include</a></li><li class="navelem"><a class="el" href="dir_3c613c826710371b20c56a4c4011e29a.html">pci</a></li><li class="navelem"><a class="el" href="pci_8h.html">pci.h</a></li> <li class="footer">Generated by <a href="http://www.doxygen.org/index.html"> <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.16 </li> </ul> </div> </body> </html>