<!DOCTYPE html>
<html lang="en">
<head>
<title>Asuro: PCI</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="generator" content="PasDoc 0.15.0">
<meta http-equiv="content-type" content="text/html; charset=utf-8">
<link rel="stylesheet" type="text/css" href="tipuesearch/tipuesearch.css">

<link rel="StyleSheet" type="text/css" href="pasdoc.css">
</head>
<body>
<table class="container"><tr><td class="navigation">
<h2>Asuro</h2><p><a href="AllUnits.html" class="navigation">Units</a></p><p><a href="ClassHierarchy.html" class="navigation">Class Hierarchy</a></p><p><a href="AllClasses.html" class="navigation">Classes, Interfaces, Objects and Records</a></p><p><a href="AllTypes.html" class="navigation">Types</a></p><p><a href="AllVariables.html" class="navigation">Variables</a></p><p><a href="AllConstants.html" class="navigation">Constants</a></p><p><a href="AllFunctions.html" class="navigation">Functions and Procedures</a></p><p><a href="AllIdentifiers.html" class="navigation">Identifiers</a></p><p><a href="GVUses.png" class="navigation">Unit dependency graph</a></p><form class="search-form" action="_tipue_results.html"><div class="search-input"><input type="text" name="q" id="tipue_search_input"></div><div class="search-button"><input type="button" id="tipue_search_button" onclick="this.form.submit();"></div></form>
<div style="clear: both"></div>

<script type="text/javascript">
$(document).ready(function() {
    $('#tipue_search_input').tipuesearch({
        /* 10 items to display seems standard */
        'show': 10,
        /* For PasDoc docs, showing urls is not very useful,
           since the page title already shows the unit and identifier. */
        'showURL': false
    });
});
</script>
</td><td class="content">
<h1 class="unit">Unit PCI</h1>
<div class="sections">
<div class="one_section"><a class="section" href="#PasDoc-Description">Description</a></div><div class="one_section"><a class="section" href="#PasDoc-Uses">Uses</a></div><div class="one_section">Classes, Interfaces, Objects and Records</div><div class="one_section"><a class="section" href="#PasDoc-FuncsProcs">Functions and Procedures</a></div><div class="one_section"><a class="section" href="#PasDoc-Types">Types</a></div><div class="one_section"><a class="section" href="#PasDoc-Constants">Constants</a></div><div class="one_section"><a class="section" href="#PasDoc-Variables">Variables</a></div></div>
<span id="PasDoc-Description"></span><h2 class="description">Description</h2>
<p>
Driver-&gt;Bus-&gt;<code>PCI</code> - Peripheral Component Interconnect Driver.

<p> </p>
<span id="PasDoc-Uses"></span><h2 class="uses">Uses</h2>
<ul class="useslist"><li><a  href="tracer.html">tracer</a></li><li><a  href="util.html">util</a></li><li><a  href="console.html">console</a></li><li><a  href="drivertypes.html">drivertypes</a></li><li><a  href="lmemorymanager.html">lmemorymanager</a></li><li><a  href="vmemorymanager.html">vmemorymanager</a></li><li><a  href="drivermanagement.html">drivermanagement</a></li></ul><h2 class="overview">Overview</h2>
<span id="PasDoc-FuncsProcs"></span><h3 class="summary">Functions and Procedures</h3>
<table class="summary wide_list">
<tr class="list">
<td class="itemcode"><code>procedure <b><a  href="PCI.html#init">init</a></b>();</code></td>
</tr>
<tr class="list2">
<td class="itemcode"><code>procedure <b><a  href="PCI.html#scanBus">scanBus</a></b>(bus : <a  href="system.html#uInt8">uint8</a>);</code></td>
</tr>
<tr class="list">
<td class="itemcode"><code>function <b><a  href="PCI.html#loadDeviceConfig">loadDeviceConfig</a></b>(bus : <a  href="system.html#uInt8">uint8</a>; slot : <a  href="system.html#uInt8">uint8</a>; func : <a  href="system.html#uInt8">uint8</a>) : boolean;</code></td>
</tr>
<tr class="list2">
<td class="itemcode"><code>function <b><a  href="PCI.html#getDeviceInfo">getDeviceInfo</a></b>(class_code : <a  href="system.html#uInt8">uint8</a>; subclass_code : <a  href="system.html#uInt8">uint8</a>; prog_if : <a  href="system.html#uInt8">uint8</a>; var count : <a  href="system.html#uInt32">uint32</a>) : <a  href="drivertypes.html#TDeviceArray">TdeviceArray</a>;</code></td>
</tr>
<tr class="list">
<td class="itemcode"><code>procedure <b><a  href="PCI.html#requestConfig">requestConfig</a></b>(bus : <a  href="system.html#uInt8">uint8</a>; slot : <a  href="system.html#uInt8">uint8</a>; func : <a  href="system.html#uInt8">uint8</a>; row : <a  href="system.html#uInt8">uint8</a>);</code></td>
</tr>
<tr class="list2">
<td class="itemcode"><code>procedure <b><a  href="PCI.html#writeConfig">writeConfig</a></b>(bus: <a  href="system.html#uInt8">uint8</a>; slot : <a  href="system.html#uInt8">uint8</a>; func : <a  href="system.html#uInt8">uint8</a>; row : <a  href="system.html#uInt8">uint8</a>; val : <a  href="system.html#uInt32">uint32</a>);</code></td>
</tr>
<tr class="list">
<td class="itemcode"><code>procedure <b><a  href="PCI.html#setBusMaster">setBusMaster</a></b>(bus : <a  href="system.html#uInt8">uint8</a>; slot : <a  href="system.html#uInt8">uint8</a>; func : <a  href="system.html#uInt8">uint8</a>; master : boolean);</code></td>
</tr>
</table>
<span id="PasDoc-Types"></span><h3 class="summary">Types</h3>
<table class="summary wide_list">
<tr class="list">
<td class="itemcode"><code><b><a  href="PCI.html#TPCI_Device_Bridge">TPCI_Device_Bridge</a></b> = bitpacked record
        device_id          : <a  href="system.html#uInt16">uint16</a>;
        vendor_id          : <a  href="system.html#uInt16">uint16</a>;
        status             : <a  href="system.html#uInt16">uint16</a>;
        command            : <a  href="system.html#uInt16">uint16</a>;
        class_code         : <a  href="system.html#uInt8">uint8</a>; 
        subclass_class     : <a  href="system.html#uInt8">uint8</a>; 
        prog_if            : <a  href="system.html#uInt8">uint8</a>;
        revision_id        : <a  href="system.html#uInt8">uint8</a>;
        BIST               : <a  href="system.html#uInt8">uint8</a>;
        header_type        : <a  href="system.html#uInt8">uint8</a>;
        latency_timer      : <a  href="system.html#uInt8">uint8</a>;
        cache_size         : <a  href="system.html#uInt8">uint8</a>;
        address0           : <a  href="system.html#uInt32">uint32</a>;
        address1           : <a  href="system.html#uInt32">uint32</a>;
        latency_timer2     : <a  href="system.html#uInt8">uint8</a>;
        subordinate_bus    : <a  href="system.html#uInt8">uint8</a>;
        secondery_bus      : <a  href="system.html#uInt8">uint8</a>;
        primary_bus        : <a  href="system.html#uInt8">uint8</a>;
        secondery_status   : <a  href="system.html#uInt16">uint16</a>;
        io_limit           : <a  href="system.html#uInt8">uint8</a>;
        io_base            : <a  href="system.html#uInt8">uint8</a>;
        memory_limit       : <a  href="system.html#uInt16">uint16</a>;
        memory_base        : <a  href="system.html#uInt16">uint16</a>;
        pref_memory_limit  : <a  href="system.html#uInt16">uint16</a>;
        pref_memory_base   : <a  href="system.html#uInt16">uint16</a>;
        pref_base_upper    : <a  href="system.html#uInt32">uint32</a>;
        pref_limit_upper   : <a  href="system.html#uInt32">uint32</a>;
        io_limit_upper     : <a  href="system.html#uInt16">uint16</a>;
        io_base_upper      : <a  href="system.html#uInt16">uint16</a>;
        reserved           : <a  href="system.html#uInt16">uint16</a>;
        reserved0          : <a  href="system.html#uInt8">uint8</a>;
        capability_pointer : <a  href="system.html#uInt8">uint8</a>;
        epx_rom_addr       : <a  href="system.html#uInt32">uint32</a>;
        bridge_control     : <a  href="system.html#uInt16">uint16</a>;
        interrupt_pin      : <a  href="system.html#uInt8">uint8</a>;
        interrupt_line     : <a  href="system.html#uInt8">uint8</a>;
    end;</code></td>
</tr>
</table>
<span id="PasDoc-Constants"></span><h3 class="summary">Constants</h3>
<table class="summary wide_list">
<tr class="list">
<td class="itemcode"><code><b><a  href="PCI.html#PCI_PORT_CONF_ADDR">PCI_PORT_CONF_ADDR</a></b> = $CF8;</code></td>
</tr>
<tr class="list2">
<td class="itemcode"><code><b><a  href="PCI.html#PCI_PORT_CONF_DATA">PCI_PORT_CONF_DATA</a></b> = $CFC;</code></td>
</tr>
</table>
<span id="PasDoc-Variables"></span><h3 class="summary">Variables</h3>
<table class="summary wide_list">
<tr class="list">
<td class="itemcode"><code><b><a  href="PCI.html#devices">devices</a></b>: array[0..1024] of <a  href="drivertypes.html#TPCI_Device">TPCI_Device</a>;</code></td>
</tr>
<tr class="list2">
<td class="itemcode"><code><b><a  href="PCI.html#busses">busses</a></b>: array[0..256] of <a  href="PCI.html#TPCI_Device_Bridge">TPCI_Device_Bridge</a>;</code></td>
</tr>
<tr class="list">
<td class="itemcode"><code><b><a  href="PCI.html#device_count">device_count</a></b>: <a  href="system.html#uInt16">uint16</a>;</code></td>
</tr>
<tr class="list2">
<td class="itemcode"><code><b><a  href="PCI.html#bus_count">bus_count</a></b>: <a  href="system.html#uInt8">uint8</a> = 1;</code></td>
</tr>
<tr class="list">
<td class="itemcode"><code><b><a  href="PCI.html#get_device_count">get_device_count</a></b>: <a  href="system.html#uInt8">uint8</a>;</code></td>
</tr>
</table>
<h2 class="description">Description</h2>
<h3 class="detail">Functions and Procedures</h3>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="init"></span><code>procedure <b>init</b>();</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="scanBus"></span><code>procedure <b>scanBus</b>(bus : <a  href="system.html#uInt8">uint8</a>);</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="loadDeviceConfig"></span><code>function <b>loadDeviceConfig</b>(bus : <a  href="system.html#uInt8">uint8</a>; slot : <a  href="system.html#uInt8">uint8</a>; func : <a  href="system.html#uInt8">uint8</a>) : boolean;</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="getDeviceInfo"></span><code>function <b>getDeviceInfo</b>(class_code : <a  href="system.html#uInt8">uint8</a>; subclass_code : <a  href="system.html#uInt8">uint8</a>; prog_if : <a  href="system.html#uInt8">uint8</a>; var count : <a  href="system.html#uInt32">uint32</a>) : <a  href="drivertypes.html#TDeviceArray">TdeviceArray</a>;</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="requestConfig"></span><code>procedure <b>requestConfig</b>(bus : <a  href="system.html#uInt8">uint8</a>; slot : <a  href="system.html#uInt8">uint8</a>; func : <a  href="system.html#uInt8">uint8</a>; row : <a  href="system.html#uInt8">uint8</a>);</code></td>
</tr>
<tr><td colspan="1">
<p>
(Will in future)returns TPCI_DEVICE.vendor_id := 0xFFFF if no device found.</p>
</td></tr>
</table>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="writeConfig"></span><code>procedure <b>writeConfig</b>(bus: <a  href="system.html#uInt8">uint8</a>; slot : <a  href="system.html#uInt8">uint8</a>; func : <a  href="system.html#uInt8">uint8</a>; row : <a  href="system.html#uInt8">uint8</a>; val : <a  href="system.html#uInt32">uint32</a>);</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="setBusMaster"></span><code>procedure <b>setBusMaster</b>(bus : <a  href="system.html#uInt8">uint8</a>; slot : <a  href="system.html#uInt8">uint8</a>; func : <a  href="system.html#uInt8">uint8</a>; master : boolean);</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<h3 class="detail">Types</h3>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="TPCI_Device_Bridge"></span><code><b>TPCI_Device_Bridge</b> = bitpacked record
        device_id          : <a  href="system.html#uInt16">uint16</a>;
        vendor_id          : <a  href="system.html#uInt16">uint16</a>;
        status             : <a  href="system.html#uInt16">uint16</a>;
        command            : <a  href="system.html#uInt16">uint16</a>;
        class_code         : <a  href="system.html#uInt8">uint8</a>; 
        subclass_class     : <a  href="system.html#uInt8">uint8</a>; 
        prog_if            : <a  href="system.html#uInt8">uint8</a>;
        revision_id        : <a  href="system.html#uInt8">uint8</a>;
        BIST               : <a  href="system.html#uInt8">uint8</a>;
        header_type        : <a  href="system.html#uInt8">uint8</a>;
        latency_timer      : <a  href="system.html#uInt8">uint8</a>;
        cache_size         : <a  href="system.html#uInt8">uint8</a>;
        address0           : <a  href="system.html#uInt32">uint32</a>;
        address1           : <a  href="system.html#uInt32">uint32</a>;
        latency_timer2     : <a  href="system.html#uInt8">uint8</a>;
        subordinate_bus    : <a  href="system.html#uInt8">uint8</a>;
        secondery_bus      : <a  href="system.html#uInt8">uint8</a>;
        primary_bus        : <a  href="system.html#uInt8">uint8</a>;
        secondery_status   : <a  href="system.html#uInt16">uint16</a>;
        io_limit           : <a  href="system.html#uInt8">uint8</a>;
        io_base            : <a  href="system.html#uInt8">uint8</a>;
        memory_limit       : <a  href="system.html#uInt16">uint16</a>;
        memory_base        : <a  href="system.html#uInt16">uint16</a>;
        pref_memory_limit  : <a  href="system.html#uInt16">uint16</a>;
        pref_memory_base   : <a  href="system.html#uInt16">uint16</a>;
        pref_base_upper    : <a  href="system.html#uInt32">uint32</a>;
        pref_limit_upper   : <a  href="system.html#uInt32">uint32</a>;
        io_limit_upper     : <a  href="system.html#uInt16">uint16</a>;
        io_base_upper      : <a  href="system.html#uInt16">uint16</a>;
        reserved           : <a  href="system.html#uInt16">uint16</a>;
        reserved0          : <a  href="system.html#uInt8">uint8</a>;
        capability_pointer : <a  href="system.html#uInt8">uint8</a>;
        epx_rom_addr       : <a  href="system.html#uInt32">uint32</a>;
        bridge_control     : <a  href="system.html#uInt16">uint16</a>;
        interrupt_pin      : <a  href="system.html#uInt8">uint8</a>;
        interrupt_line     : <a  href="system.html#uInt8">uint8</a>;
    end;</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<h3 class="detail">Constants</h3>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="PCI_PORT_CONF_ADDR"></span><code><b>PCI_PORT_CONF_ADDR</b> = $CF8;</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="PCI_PORT_CONF_DATA"></span><code><b>PCI_PORT_CONF_DATA</b> = $CFC;</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<h3 class="detail">Variables</h3>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="devices"></span><code><b>devices</b>: array[0..1024] of <a  href="drivertypes.html#TPCI_Device">TPCI_Device</a>;</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="busses"></span><code><b>busses</b>: array[0..256] of <a  href="PCI.html#TPCI_Device_Bridge">TPCI_Device_Bridge</a>;</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="device_count"></span><code><b>device_count</b>: <a  href="system.html#uInt16">uint16</a>;</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="bus_count"></span><code><b>bus_count</b>: <a  href="system.html#uInt8">uint8</a> = 1;</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<table class="detail wide_list">
<tr class="list">
<td class="itemcode"><span id="get_device_count"></span><code><b>get_device_count</b>: <a  href="system.html#uInt8">uint8</a>;</code></td>
</tr>
<tr><td colspan="1">
&nbsp;</td></tr>
</table>
<h2 class="authors">Authors</h2>
<ul class="authors">
<li>Aaron Hance &lt;<a  href="mailto:ah@aaronhance.me">ah@aaronhance.me</a>&gt;</li>
<li>Kieron Morris &lt;<a  href="mailto:kjm@kieronmorris.me">kjm@kieronmorris.me</a>&gt;</li>
</ul>
<hr><span class="appinfo"><em>Generated by <a  href="https://github.com/pasdoc/pasdoc/wiki">PasDoc 0.15.0</a>. </em>
</span>
</td></tr></table></body></html>