blob: 3b182f67dad2310944b90c61fa0be3e4336c9393 [file] [log] [blame]
<!DOCTYPE html>
<html lang="en" data-content_root="../">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
<title>OPAL_PCI_GET_PHB_DIAG_DATA2 &#8212; skiboot d365a01
documentation</title>
<link rel="stylesheet" type="text/css" href="../_static/pygments.css?v=fa44fd50" />
<link rel="stylesheet" type="text/css" href="../_static/classic.css?v=514cf933" />
<script src="../_static/documentation_options.js?v=e1fecbe9"></script>
<script src="../_static/doctools.js?v=888ff710"></script>
<script src="../_static/sphinx_highlight.js?v=dc90522c"></script>
<link rel="index" title="Index" href="../genindex.html" />
<link rel="search" title="Search" href="../search.html" />
<link rel="next" title="OPAL_PCI_GET_POWER_STATE" href="opal-pci-get-power-state-120.html" />
<link rel="prev" title="OPAL_PCI_GET_HUB_DIAG_DATA" href="opal-pci-get-hub-diag-data-50.html" />
</head><body>
<div class="related" role="navigation" aria-label="related navigation">
<h3>Navigation</h3>
<ul>
<li class="right" style="margin-right: 10px">
<a href="../genindex.html" title="General Index"
accesskey="I">index</a></li>
<li class="right" >
<a href="opal-pci-get-power-state-120.html" title="OPAL_PCI_GET_POWER_STATE"
accesskey="N">next</a> |</li>
<li class="right" >
<a href="opal-pci-get-hub-diag-data-50.html" title="OPAL_PCI_GET_HUB_DIAG_DATA"
accesskey="P">previous</a> |</li>
<li class="nav-item nav-item-0"><a href="../index.html">skiboot d365a01
documentation</a> &#187;</li>
<li class="nav-item nav-item-1"><a href="index.html" accesskey="U">OPAL API Documentation</a> &#187;</li>
<li class="nav-item nav-item-this"><a href="">OPAL_PCI_GET_PHB_DIAG_DATA2</a></li>
</ul>
</div>
<div class="document">
<div class="documentwrapper">
<div class="bodywrapper">
<div class="body" role="main">
<section id="opal-pci-get-phb-diag-data2">
<span id="id1"></span><h1>OPAL_PCI_GET_PHB_DIAG_DATA2<a class="headerlink" href="#opal-pci-get-phb-diag-data2" title="Link to this heading"></a></h1>
<div class="highlight-c notranslate"><div class="highlight"><pre><span></span><span class="cp">#define OPAL_PCI_GET_PHB_DIAG_DATA2 64</span>
<span class="cm">/**</span>
<span class="cm"> * This structure defines the overlay which will be used to store PHB error</span>
<span class="cm"> * data upon request.</span>
<span class="cm"> */</span>
<span class="w"> </span><span class="k">enum</span><span class="w"> </span><span class="p">{</span>
<span class="w"> </span><span class="n">OPAL_PHB_ERROR_DATA_VERSION_1</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">1</span><span class="p">,</span>
<span class="w"> </span><span class="p">};</span>
<span class="k">enum</span><span class="w"> </span><span class="p">{</span>
<span class="w"> </span><span class="n">OPAL_PHB_ERROR_DATA_TYPE_P7IOC</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">1</span><span class="p">,</span>
<span class="w"> </span><span class="n">OPAL_PHB_ERROR_DATA_TYPE_PHB3</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">2</span><span class="p">,</span>
<span class="w"> </span><span class="n">OPAL_PHB_ERROR_DATA_TYPE_PHB4</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">3</span>
<span class="p">};</span>
<span class="k">enum</span><span class="w"> </span><span class="p">{</span>
<span class="w"> </span><span class="n">OPAL_P7IOC_NUM_PEST_REGS</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">128</span><span class="p">,</span>
<span class="w"> </span><span class="n">OPAL_PHB3_NUM_PEST_REGS</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">256</span><span class="p">,</span>
<span class="w"> </span><span class="n">OPAL_PHB4_NUM_PEST_REGS</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="mi">512</span>
<span class="p">};</span>
<span class="k">struct</span><span class="w"> </span><span class="nc">OpalIoPhbErrorCommon</span><span class="w"> </span><span class="p">{</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">version</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">ioType</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">len</span><span class="p">;</span>
<span class="p">};</span>
<span class="k">struct</span><span class="w"> </span><span class="nc">OpalIoP7IOCPhbErrorData</span><span class="w"> </span><span class="p">{</span>
<span class="w"> </span><span class="k">struct</span><span class="w"> </span><span class="nc">OpalIoPhbErrorCommon</span><span class="w"> </span><span class="n">common</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">brdgCtl</span><span class="p">;</span>
<span class="w"> </span><span class="c1">// P7IOC utl regs</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">portStatusReg</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">rootCmplxStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">busAgentStatus</span><span class="p">;</span>
<span class="w"> </span><span class="c1">// P7IOC cfg regs</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">deviceStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">slotStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">linkStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">devCmdStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">devSecStatus</span><span class="p">;</span>
<span class="w"> </span><span class="c1">// cfg AER regs</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">rootErrorStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">uncorrErrorStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">corrErrorStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">tlpHdr1</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">tlpHdr2</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">tlpHdr3</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">tlpHdr4</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">sourceId</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">rsv3</span><span class="p">;</span>
<span class="w"> </span><span class="c1">// Record data about the call to allocate a buffer.</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">errorClass</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">correlator</span><span class="p">;</span>
<span class="w"> </span><span class="c1">//P7IOC MMIO Error Regs</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">p7iocPlssr</span><span class="p">;</span><span class="w"> </span><span class="c1">// n120</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">p7iocCsr</span><span class="p">;</span><span class="w"> </span><span class="c1">// n110</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">lemFir</span><span class="p">;</span><span class="w"> </span><span class="c1">// nC00</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">lemErrorMask</span><span class="p">;</span><span class="w"> </span><span class="c1">// nC18</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">lemWOF</span><span class="p">;</span><span class="w"> </span><span class="c1">// nC40</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="c1">// nC80</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbFirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="c1">// nC88</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="c1">// nCC0</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="c1">// nCC8</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">mmioErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="c1">// nD00</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">mmioFirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="c1">// nD08</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">mmioErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="c1">// nD40</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">mmioErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="c1">// nD48</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma0ErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="c1">// nD80</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma0FirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="c1">// nD88</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma0ErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="c1">// nDC0</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma0ErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="c1">// nDC8</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma1ErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="c1">// nE00</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma1FirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="c1">// nE08</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma1ErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="c1">// nE40</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma1ErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="c1">// nE48</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">pestA</span><span class="p">[</span><span class="n">OPAL_P7IOC_NUM_PEST_REGS</span><span class="p">];</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">pestB</span><span class="p">[</span><span class="n">OPAL_P7IOC_NUM_PEST_REGS</span><span class="p">];</span>
<span class="p">};</span>
<span class="k">struct</span><span class="w"> </span><span class="nc">OpalIoPhb3ErrorData</span><span class="w"> </span><span class="p">{</span>
<span class="w"> </span><span class="k">struct</span><span class="w"> </span><span class="nc">OpalIoPhbErrorCommon</span><span class="w"> </span><span class="n">common</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">brdgCtl</span><span class="p">;</span>
<span class="w"> </span><span class="cm">/* PHB3 UTL regs */</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">portStatusReg</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">rootCmplxStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">busAgentStatus</span><span class="p">;</span>
<span class="w"> </span><span class="cm">/* PHB3 cfg regs */</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">deviceStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">slotStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">linkStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">devCmdStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">devSecStatus</span><span class="p">;</span>
<span class="w"> </span><span class="cm">/* cfg AER regs */</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">rootErrorStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">uncorrErrorStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">corrErrorStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">tlpHdr1</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">tlpHdr2</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">tlpHdr3</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">tlpHdr4</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">sourceId</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">rsv3</span><span class="p">;</span>
<span class="w"> </span><span class="cm">/* Record data about the call to allocate a buffer */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">errorClass</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">correlator</span><span class="p">;</span>
<span class="w"> </span><span class="cm">/* PHB3 MMIO Error Regs */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">nFir</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 000 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">nFirMask</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 003 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">nFirWOF</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 008 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbPlssr</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 120 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbCsr</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 110 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">lemFir</span><span class="p">;</span><span class="w"> </span><span class="cm">/* C00 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">lemErrorMask</span><span class="p">;</span><span class="w"> </span><span class="cm">/* C18 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">lemWOF</span><span class="p">;</span><span class="w"> </span><span class="cm">/* C40 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* C80 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbFirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* C88 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="cm">/* CC0 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="cm">/* CC8 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">mmioErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* D00 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">mmioFirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* D08 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">mmioErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="cm">/* D40 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">mmioErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="cm">/* D48 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma0ErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* D80 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma0FirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* D88 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma0ErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="cm">/* DC0 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma0ErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="cm">/* DC8 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma1ErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* E00 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma1FirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* E08 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma1ErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="cm">/* E40 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">dma1ErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="cm">/* E48 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">pestA</span><span class="p">[</span><span class="n">OPAL_PHB3_NUM_PEST_REGS</span><span class="p">];</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">pestB</span><span class="p">[</span><span class="n">OPAL_PHB3_NUM_PEST_REGS</span><span class="p">];</span>
<span class="p">};</span>
<span class="k">struct</span><span class="w"> </span><span class="nc">OpalIoPhb4ErrorData</span><span class="w"> </span><span class="p">{</span>
<span class="w"> </span><span class="k">struct</span><span class="w"> </span><span class="nc">OpalIoPhbErrorCommon</span><span class="w"> </span><span class="n">common</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">brdgCtl</span><span class="p">;</span>
<span class="w"> </span><span class="cm">/* XXX missing UTL registers? */</span>
<span class="w"> </span><span class="cm">/* PHB4 cfg regs */</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">deviceStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">slotStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">linkStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">devCmdStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">devSecStatus</span><span class="p">;</span>
<span class="w"> </span><span class="cm">/* cfg AER regs */</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">rootErrorStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">uncorrErrorStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">corrErrorStatus</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">tlpHdr1</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">tlpHdr2</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">tlpHdr3</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">tlpHdr4</span><span class="p">;</span>
<span class="w"> </span><span class="n">__be32</span><span class="w"> </span><span class="n">sourceId</span><span class="p">;</span>
<span class="w"> </span><span class="cm">/* PHB4 ETU Error Regs */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">nFir</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 000 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">nFirMask</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 003 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">nFirWOF</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 008 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbPlssr</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 120 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbCsr</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 110 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">lemFir</span><span class="p">;</span><span class="w"> </span><span class="cm">/* C00 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">lemErrorMask</span><span class="p">;</span><span class="w"> </span><span class="cm">/* C18 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">lemWOF</span><span class="p">;</span><span class="w"> </span><span class="cm">/* C40 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* C80 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbFirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* C88 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="cm">/* CC0 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="cm">/* CC8 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbTxeErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* D00 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbTxeFirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* D08 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbTxeErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="cm">/* D40 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbTxeErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="cm">/* D48 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRxeArbErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* D80 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRxeArbFirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* D88 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRxeArbErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="cm">/* DC0 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRxeArbErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="cm">/* DC8 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRxeMrgErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* E00 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRxeMrgFirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* E08 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRxeMrgErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="cm">/* E40 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRxeMrgErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="cm">/* E48 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRxeTceErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* E80 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRxeTceFirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* E88 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRxeTceErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="cm">/* EC0 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRxeTceErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="cm">/* EC8 */</span>
<span class="w"> </span><span class="cm">/* PHB4 REGB Error Regs */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbPblErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 1900 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbPblFirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 1908 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbPblErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 1940 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbPblErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 1948 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbPcieDlpErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 1AA0 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbPcieDlpErrorLog2</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 1AA8 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbPcieDlpErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 1AB0 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRegbErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 1C00 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRegbFirstErrorStatus</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 1C08 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRegbErrorLog0</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 1C40 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">phbRegbErrorLog1</span><span class="p">;</span><span class="w"> </span><span class="cm">/* 1C48 */</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">pestA</span><span class="p">[</span><span class="n">OPAL_PHB4_NUM_PEST_REGS</span><span class="p">];</span>
<span class="w"> </span><span class="n">__be64</span><span class="w"> </span><span class="n">pestB</span><span class="p">[</span><span class="n">OPAL_PHB4_NUM_PEST_REGS</span><span class="p">];</span>
<span class="p">};</span>
<span class="kt">int64_t</span><span class="w"> </span><span class="nf">opal_pci_get_phb_diag_data2</span><span class="p">(</span><span class="kt">uint64_t</span><span class="w"> </span><span class="n">phb_id</span><span class="p">,</span><span class="w"> </span><span class="kt">void</span><span class="w"> </span><span class="o">*</span><span class="n">diag_buffer</span><span class="p">,</span><span class="w"> </span><span class="kt">uint64_t</span><span class="w"> </span><span class="n">diag_buffer_len</span><span class="p">);</span>
</pre></div>
</div>
<p>Get PCI diagnostic data from a given PHB. Each PHB present in the device tree
has a <code class="docutils literal notranslate"><span class="pre">ibm,phb-diag-data-size</span></code> property which is the size of the diagnostic
data structure that can be returned.</p>
<p>Each PHB generation has a different structure for diagnostic data, and the
small common structure will allow the OS to work out what format the data
is coming in.</p>
<p>In future, it’s possible that the format will change to be more flexible, and
require less OS support.</p>
<section id="parameters">
<h2>Parameters<a class="headerlink" href="#parameters" title="Link to this heading"></a></h2>
<dl class="simple">
<dt><code class="docutils literal notranslate"><span class="pre">uint64_t</span> <span class="pre">phb_id</span></code></dt><dd><p>the ID of the PHB you want to retrieve data from</p>
</dd>
<dt><code class="docutils literal notranslate"><span class="pre">void</span> <span class="pre">*diag_buffer</span></code></dt><dd><p>an allocated buffer to store diag data in</p>
</dd>
<dt><code class="docutils literal notranslate"><span class="pre">uint64_t</span> <span class="pre">diag_buffer_len</span></code></dt><dd><p>size in bytes of the diag buffer</p>
</dd>
</dl>
</section>
<section id="calling">
<h2>Calling<a class="headerlink" href="#calling" title="Link to this heading"></a></h2>
<p>Retrieve the PHB’s diagnostic data. The diagnostic data is stored in the
buffer pointed by &#64;diag_buffer. Different PHB versions will store different
diagnostics, defined in include/opal-api.h as <code class="docutils literal notranslate"><span class="pre">struct</span> <span class="pre">OpalIo&lt;PHBVer&gt;ErrorData</span></code>.</p>
<p><a class="reference internal" href="index.html#opal-pci-get-phb-diag-data"><span class="std std-ref">OPAL_PCI_GET_PHB_DIAG_DATA</span></a> is deprecated and
<a class="reference internal" href="#opal-pci-get-phb-diag-data2"><span class="std std-ref">OPAL_PCI_GET_PHB_DIAG_DATA2</span></a> should be used instead.</p>
</section>
<section id="return-codes">
<h2>Return Codes<a class="headerlink" href="#return-codes" title="Link to this heading"></a></h2>
<dl class="simple">
<dt><a class="reference internal" href="return-codes.html#opal-success"><span class="std std-ref">OPAL_SUCCESS</span></a></dt><dd><p>Diagnostic data has been retrieved and stored successfully</p>
</dd>
<dt><a class="reference internal" href="return-codes.html#opal-parameter"><span class="std std-ref">OPAL_PARAMETER</span></a></dt><dd><p>The given buffer is too small to store the diagnostic data</p>
</dd>
<dt><a class="reference internal" href="return-codes.html#opal-hardware"><span class="std std-ref">OPAL_HARDWARE</span></a></dt><dd><p>The PHB is in a broken state and its data cannot be retreived</p>
</dd>
<dt><a class="reference internal" href="return-codes.html#opal-unsupported"><span class="std std-ref">OPAL_UNSUPPORTED</span></a></dt><dd><p>Diagnostic data is not implemented for this PHB type</p>
</dd>
</dl>
</section>
</section>
<div class="clearer"></div>
</div>
</div>
</div>
<div class="sphinxsidebar" role="navigation" aria-label="main navigation">
<div class="sphinxsidebarwrapper">
<div>
<h3><a href="../index.html">Table of Contents</a></h3>
<ul>
<li><a class="reference internal" href="#">OPAL_PCI_GET_PHB_DIAG_DATA2</a><ul>
<li><a class="reference internal" href="#parameters">Parameters</a></li>
<li><a class="reference internal" href="#calling">Calling</a></li>
<li><a class="reference internal" href="#return-codes">Return Codes</a></li>
</ul>
</li>
</ul>
</div>
<div>
<h4>Previous topic</h4>
<p class="topless"><a href="opal-pci-get-hub-diag-data-50.html"
title="previous chapter">OPAL_PCI_GET_HUB_DIAG_DATA</a></p>
</div>
<div>
<h4>Next topic</h4>
<p class="topless"><a href="opal-pci-get-power-state-120.html"
title="next chapter">OPAL_PCI_GET_POWER_STATE</a></p>
</div>
<div role="note" aria-label="source link">
<h3>This Page</h3>
<ul class="this-page-menu">
<li><a href="../_sources/opal-api/opal-pci-get-phb-diag-data2-64.rst.txt"
rel="nofollow">Show Source</a></li>
</ul>
</div>
<div id="searchbox" style="display: none" role="search">
<h3 id="searchlabel">Quick search</h3>
<div class="searchformwrapper">
<form class="search" action="../search.html" method="get">
<input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
<input type="submit" value="Go" />
</form>
</div>
</div>
<script>document.getElementById('searchbox').style.display = "block"</script>
</div>
</div>
<div class="clearer"></div>
</div>
<div class="related" role="navigation" aria-label="related navigation">
<h3>Navigation</h3>
<ul>
<li class="right" style="margin-right: 10px">
<a href="../genindex.html" title="General Index"
>index</a></li>
<li class="right" >
<a href="opal-pci-get-power-state-120.html" title="OPAL_PCI_GET_POWER_STATE"
>next</a> |</li>
<li class="right" >
<a href="opal-pci-get-hub-diag-data-50.html" title="OPAL_PCI_GET_HUB_DIAG_DATA"
>previous</a> |</li>
<li class="nav-item nav-item-0"><a href="../index.html">skiboot d365a01
documentation</a> &#187;</li>
<li class="nav-item nav-item-1"><a href="index.html" >OPAL API Documentation</a> &#187;</li>
<li class="nav-item nav-item-this"><a href="">OPAL_PCI_GET_PHB_DIAG_DATA2</a></li>
</ul>
</div>
<div class="footer" role="contentinfo">
&#169; Copyright 2016-2017, IBM, others.
Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
</div>
</body>
</html>