<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html><head><title>Patent US6199173 - Method for mapping environmental resources to memory for program access - Google Patents</title><script>(function(){(function(){function e(a){this.t={};this.tick=function(a,c,b){var d=void 0!=b?b:(new Date).getTime();this.t[a]=[d,c];if(void 0==b)try{window.console.timeStamp("CSI/"+a)}catch(e){}};this.tick("start",null,a)}var a;window.performance&&(a=window.performance.timing);var f=a?new e(a.responseStart):new e;window.jstiming={Timer:e,load:f};if(a){var c=a.navigationStart,d=a.responseStart;0<c&&d>=c&&(window.jstiming.srt=d-c)}if(a){var b=window.jstiming.load;0<c&&d>=c&&(b.tick("_wtsrt",void 0,c),b.tick("wtsrt_",
"_wtsrt",d),b.tick("tbsd_","wtsrt_"))}try{a=null,window.chrome&&window.chrome.csi&&(a=Math.floor(window.chrome.csi().pageT),b&&0<c&&(b.tick("_tbnd",void 0,window.chrome.csi().startE),b.tick("tbnd_","_tbnd",c))),null==a&&window.gtbExternal&&(a=window.gtbExternal.pageT()),null==a&&window.external&&(a=window.external.pageT,b&&0<c&&(b.tick("_tbnd",void 0,window.external.startE),b.tick("tbnd_","_tbnd",c))),a&&(window.jstiming.pt=a)}catch(g){}})();})();
</script><link rel="stylesheet" href="/patents/css/_4ff636b3d23669b7103f3b3a3a18b4cd/kl_intl_patents_bundle.css" type="text/css" /><script src="/books/javascript/atb_4ff636b3d23669b7103f3b3a3a18b4cd__en.js"></script><script>function googleTranslateElementInit() {new google.translate.TranslateElement({pageLanguage: "en",gaTrack: true,gaId: "UA-27188110-1",multilanguagePage: true});}</script><script src="//translate.google.com/translate_a/element.js?cb=googleTranslateElementInit"></script><meta name="DC.type" content="Patent"><meta name="DC.title" content="Method for mapping environmental resources to memory for program access"><meta name="DC.contributor" content="Karl S. Johnson" scheme="inventor"><meta name="DC.contributor" content="Walter A. Wallach" scheme="inventor"><meta name="DC.contributor" content="Ken Nguyen" scheme="inventor"><meta name="DC.contributor" content="Carlton G. Amdahl" scheme="inventor"><meta name="DC.contributor" content="Micron Electronics, Inc." scheme="assignee"><meta name="DC.date" content="1997-10-1" scheme="dateSubmitted"><meta name="DC.description" content="A network of microcontrollers for monitoring and diagnosing the environmental conditions of a computer is disclosed. The network of microcontrollers provides a management system by which computer users can accurately gauge the health of their computer. The network of microcontrollers provides users the ability to detect system fan speeds, internal temperatures and voltage levels. The invention is designed to not only be resilient to faults, but also allows for the system maintenance, modification, and growth—without downtime. Additionally, the present invention allows users to replace failed components, and add new functionality, such as new network interfaces, disk interface cards and storage, without impacting existing users. One of the primary roles of the present invention is to manage the environment without outside involvement. This self-management allows the system to continue to operate even though components have failed."><meta name="DC.date" content="2001-3-6" scheme="issued"><meta name="DC.relation" content="US:4057847" scheme="references"><meta name="DC.relation" content="US:4100597" scheme="references"><meta name="DC.relation" content="US:4449182" scheme="references"><meta name="DC.relation" content="US:4672535" scheme="references"><meta name="DC.relation" content="US:4692918" scheme="references"><meta name="DC.relation" content="US:4695946" scheme="references"><meta name="DC.relation" content="US:4769764" scheme="references"><meta name="DC.relation" content="US:4774502" scheme="references"><meta name="DC.relation" content="US:4821180" scheme="references"><meta name="DC.relation" content="US:4894792" scheme="references"><meta name="DC.relation" content="US:5007431" scheme="references"><meta name="DC.relation" content="US:5033048" scheme="references"><meta name="DC.relation" content="US:5051720" scheme="references"><meta name="DC.relation" content="US:5073932" scheme="references"><meta name="DC.relation" content="US:5103391" scheme="references"><meta name="DC.relation" content="US:5118970" scheme="references"><meta name="DC.relation" content="US:5121500" scheme="references"><meta name="DC.relation" content="US:5136708" scheme="references"><meta name="DC.relation" content="US:5136715" scheme="references"><meta name="DC.relation" content="US:5138619" scheme="references"><meta name="DC.relation" content="US:5157663" scheme="references"><meta name="DC.relation" content="US:5210855" scheme="references"><meta name="DC.relation" content="US:5245615" scheme="references"><meta name="DC.relation" content="US:5247683" scheme="references"><meta name="DC.relation" content="US:5253348" scheme="references"><meta name="DC.relation" content="US:5265098" scheme="references"><meta name="DC.relation" content="US:5266838" scheme="references"><meta name="DC.relation" content="US:5272382" scheme="references"><meta name="DC.relation" content="US:5276863" scheme="references"><meta name="DC.relation" content="US:5277615" scheme="references"><meta name="DC.relation" content="US:5280621" scheme="references"><meta name="DC.relation" content="US:5283905" scheme="references"><meta name="DC.relation" content="US:5311397" scheme="references"><meta name="DC.relation" content="US:5311451" scheme="references"><meta name="DC.relation" content="US:5367670" scheme="references"><meta name="DC.relation" content="US:5379184" scheme="references"><meta name="DC.relation" content="US:5388267" scheme="references"><meta name="DC.relation" content="US:5402431" scheme="references"><meta name="DC.relation" content="US:5423025" scheme="references"><meta name="DC.relation" content="US:5430717" scheme="references"><meta name="DC.relation" content="US:5430845" scheme="references"><meta name="DC.relation" content="US:5432715" scheme="references"><meta name="DC.relation" content="US:5432946" scheme="references"><meta name="DC.relation" content="US:5438678" scheme="references"><meta name="DC.relation" content="US:5448723" scheme="references"><meta name="DC.relation" content="US:5455933" scheme="references"><meta name="DC.relation" content="US:5460441" scheme="references"><meta name="DC.relation" content="US:5463766" scheme="references"><meta name="DC.relation" content="US:5465349" scheme="references"><meta name="DC.relation" content="US:5471617" scheme="references"><meta name="DC.relation" content="US:5471634" scheme="references"><meta name="DC.relation" content="US:5473499" scheme="references"><meta name="DC.relation" content="US:5485550" scheme="references"><meta name="DC.relation" content="US:5513314" scheme="references"><meta name="DC.relation" content="US:5513339" scheme="references"><meta name="DC.relation" content="US:5519851" scheme="references"><meta name="DC.relation" content="US:5526289" scheme="references"><meta name="DC.relation" content="US:5528409" scheme="references"><meta name="DC.relation" content="US:5530810" scheme="references"><meta name="DC.relation" content="US:5533193" scheme="references"><meta name="DC.relation" content="US:5535326" scheme="references"><meta name="DC.relation" content="US:5542055" scheme="references"><meta name="DC.relation" content="US:5546272" scheme="references"><meta name="DC.relation" content="US:5548712" scheme="references"><meta name="DC.relation" content="US:5559764" scheme="references"><meta name="DC.relation" content="US:5560022" scheme="references"><meta name="DC.relation" content="US:5566299" scheme="references"><meta name="DC.relation" content="US:5566339" scheme="references"><meta name="DC.relation" content="US:5572403" scheme="references"><meta name="DC.relation" content="US:5579487" scheme="references"><meta name="DC.relation" content="US:5579491" scheme="references"><meta name="DC.relation" content="US:5579528" scheme="references"><meta name="DC.relation" content="US:5584030" scheme="references"><meta name="DC.relation" content="US:5586250" scheme="references"><meta name="DC.relation" content="US:5588121" scheme="references"><meta name="DC.relation" content="US:5592611" scheme="references"><meta name="DC.relation" content="US:5596711" scheme="references"><meta name="DC.relation" content="US:5598407" scheme="references"><meta name="DC.relation" content="US:5602758" scheme="references"><meta name="DC.relation" content="US:5621159" scheme="references"><meta name="DC.relation" content="US:5622221" scheme="references"><meta name="DC.relation" content="US:5625238" scheme="references"><meta name="DC.relation" content="US:5627962" scheme="references"><meta name="DC.relation" content="US:5628028" scheme="references"><meta name="DC.relation" content="US:5630076" scheme="references"><meta name="DC.relation" content="US:5631847" scheme="references"><meta name="DC.relation" content="US:5636341" scheme="references"><meta name="DC.relation" content="US:5652839" scheme="references"><meta name="DC.relation" content="US:5652892" scheme="references"><meta name="DC.relation" content="US:5652908" scheme="references"><meta name="DC.relation" content="US:5655083" scheme="references"><meta name="DC.relation" content="US:5664118" scheme="references"><meta name="DC.relation" content="US:5668943" scheme="references"><meta name="DC.relation" content="US:5668992" scheme="references"><meta name="DC.relation" content="US:5669009" scheme="references"><meta name="DC.relation" content="US:5671371" scheme="references"><meta name="DC.relation" content="US:5696895" scheme="references"><meta name="DC.relation" content="US:5696949" scheme="references"><meta name="DC.relation" content="US:5701417" scheme="references"><meta name="DC.relation" content="US:5704031" scheme="references"><meta name="DC.relation" content="US:5708775" scheme="references"><meta name="DC.relation" content="US:5708776" scheme="references"><meta name="DC.relation" content="US:5712754" scheme="references"><meta name="DC.relation" content="US:5715456" scheme="references"><meta name="DC.relation" content="US:5717570" scheme="references"><meta name="DC.relation" content="US:5721935" scheme="references"><meta name="DC.relation" content="US:5803357" scheme="references"><meta name="DC.relation" content="US:5864653" scheme="references"><meta name="citation_reference" content="&quot;CAN: Technical Overview&quot;, NRTT, Ltd., Sep. 23,1997, 15 pp."><meta name="citation_reference" content="Cmaster, Usenet post to microsoft.public.windowsnt.setup, Aug. 1997, &quot;Re: FDISK switches.&quot;"><meta name="citation_reference" content="Compaq Computer Corporation, Technology Brief, pp. 1-13, Dec. 1996, &quot;Where Do I Plug the Cable?Solving the Logical-Physical Slot Numbering Problem.&quot;"><meta name="citation_reference" content="Davis, T, Usenet post to alt.msdos.programmer, Apr. 1997, &quot;Re: How do I create an FDISK batch file?&quot;"><meta name="citation_reference" content="Davis, T., Usenet post to alt.msdos.batch, Apr. 1997, &quot;Re: Need help with automating FDISK and Format . . . &quot;."><meta name="citation_reference" content="ftp.cdrom.com/pub/os2/diskutil/, PHDX software, phdx.zip download, Mar. 1995, &quot;Parallel Hard Disk Xfer.&quot;"><meta name="citation_reference" content="Gorlick, M., Conf. Proceedings: ACM/ONR Workshop on Parallel and Distributed Debugging, pp. 175-181, 1991, &quot;The Flight Recorder: An Architectural Aid for System Monitoring.&quot;"><meta name="citation_reference" content="Hildebrand, N., Usenet post to comp.msdos.programmer, May 1995, &quot;Re: Structure of disk partition into.&quot;"><meta name="citation_reference" content="IBM Technical Disclosure Bulletin, 92A+62947, pp. 391-394, Oct. 1992, Method for Card Hot Plug Detection and Control."><meta name="citation_reference" content="Lewis, L., Usenet post to alt.msdos.batch, Apr. 1997, &quot;Re: Need help with automating FDISK and Format.&quot;"><meta name="citation_reference" content="Lyons, Computer Reseller News, Issue 721, pp. 61-62, Feb. 3, 1997, &quot;ACC Releases Low-Cost Solution for ISPs.&quot;"><meta name="citation_reference" content="M. J. Schofield, &quot;Controller Area Network-How CAN Works&quot;,mschofield@cix.compulink.co.uk, Sep. 23, 1997, 4 pp."><meta name="citation_reference" content="M. J. Schofield, “Controller Area Network—How CAN Works”,mschofield@cix.compulink.co.uk, Sep. 23, 1997, 4 pp."><meta name="citation_reference" content="M2 Communications, M2 Presswire, 2 pages, Dec. 19, 1996, &quot;Novell IntranetWare Supports Hot Pluggable PCI from NetFRAME.&quot;"><meta name="citation_reference" content="Mark Lockareff, &quot;Lonworks-An Introduction&quot;, HTINews, Dec., 1996, 2 pp."><meta name="citation_reference" content="Mark Lockareff, “Lonworks—An Introduction”, HTINews, Dec., 1996, 2 pp."><meta name="citation_reference" content="NetFrame Systems Incorporated, Doc. No. 78-1000226-01, pp. 1-2, 5-8, 359-404, and 471-512, Apr. 1996,&quot;NetFrame Clustered Multiprocessing Software: NW0496 DC-ROM for Novel(R) Netware(R) 4.1 SMP, 4.1, and 3.12. &quot;"><meta name="citation_reference" content="NetFrame Systems Incorporated, Doc. No. 78-1000226-01, pp. 1-2, 5-8, 359-404, and 471-512, Apr. 1996,“NetFrame Clustered Multiprocessing Software: NW0496 DC-ROM for Novel® Netware® 4.1 SMP, 4.1, and 3.12. ”"><meta name="citation_reference" content="Netframe, http://www.netframe-support.com/technology/datasheets/data.htm, before Mar. 1997, &quot;Netframe ClusterSystem 9008 Data Sheet.&quot;"><meta name="citation_reference" content="PCI Hot-Plug Specification, Preliminary Revision for Review Only, Revision 0.9, pp. i-vi, and 1-25, Mar. 5, 1997."><meta name="citation_reference" content="Product Brochure of NetFRAME, &quot;NF450FT Network Mainframe&quot;, Feb. 1992, 14 pp."><meta name="citation_reference" content="Rigney, PC Magazine, 14(17): 375-379, Oct. 10, 1995, &quot;The One for the Road (Mobile-aware capabilities in Windows 95).&quot;"><meta name="citation_reference" content="SES SCSI-3 Enclosure Services, X3T10/Project 1212-D/Rev 8a, pp. i, iii-x, 1-76, and l-1 (index), Jan. 16, 1997."><meta name="citation_reference" content="Shanley and Anderson, PCI System Architecture, Third Edition, Chapters 15 &amp; 16, pp. 297-328, CR 1995."><meta name="citation_reference" content="Shanley, and Anderson, PCI System Architecture, Third Edition, Chapter 15, pp. 297-302, Copyright 1995, &quot;Intro To Configuration Address Space.&quot;"><meta name="citation_reference" content="Shanley, and Anderson, PCI System Architecture, Third Edition, Chapter 16, pp. 303-328, Copyright 1995, &quot;Configuration Transactions.&quot;"><meta name="citation_reference" content="Shanley, and Anderson, PCI System Architecture, Third Edition, p. 382, Copyright 1995."><meta name="citation_reference" content="Simos, M., Usenet post to comp.os.msdos.misc, Apr. 1997, &quot;Re: Auto FDISK and Format.&quot;"><meta name="citation_reference" content="Sun Microsystems Computer Company, Part No. 802-5355-10, Rev. A, May 1996, &quot;Solstice SyMON User&#39;s Guid.&quot;"><meta name="citation_reference" content="Sun Microsystems, Part No. 802-6569-11, Release 1.0.1, Nov. 1996, &quot;Remote Systems Diagnostics Installation &amp; User Guide.&quot;"><meta name="citation_reference" content="Wood, M. H., Usenet post to comp.os.netware.misc, Aug. 1996, &quot;Re: Workstation duplication method for WIN95.&quot;"><meta name="citation_patent_number" content="US:6199173"><meta name="citation_patent_application_number" content="US:08/942,214"><link rel="canonical" href="http://www.google.com/patents/US6199173"/><meta property="og:url" content="http://www.google.com/patents/US6199173"/><meta name="title" content="Patent US6199173 - Method for mapping environmental resources to memory for program access"/><meta name="description" content="A network of microcontrollers for monitoring and diagnosing the environmental conditions of a computer is disclosed. The network of microcontrollers provides a management system by which computer users can accurately gauge the health of their computer. The network of microcontrollers provides users the ability to detect system fan speeds, internal temperatures and voltage levels. The invention is designed to not only be resilient to faults, but also allows for the system maintenance, modification, and growth—without downtime. Additionally, the present invention allows users to replace failed components, and add new functionality, such as new network interfaces, disk interface cards and storage, without impacting existing users. One of the primary roles of the present invention is to manage the environment without outside involvement. This self-management allows the system to continue to operate even though components have failed."/><meta property="og:title" content="Patent US6199173 - Method for mapping environmental resources to memory for program access"/><meta property="og:type" content="book"/><meta property="og:site_name" content="Google Books"/><meta property="og:image" content="http://www.google.com/patents?id=&amp;printsec=frontcover&amp;img=1&amp;zoom=1"/><link rel="image_src" href="http://www.google.com/patents?id=&amp;printsec=frontcover&amp;img=1&amp;zoom=1"/><script>(function(){try{var aa=function(a,b,c,d){d=d||{};d._sn=["cfg",b,c].join(".");window.gbar.logger.ml(a,d)};var g=window.gbar=window.gbar||{},l=window.gbar.i=window.gbar.i||{},m={},n;function _tvn(a,b){var c=parseInt(a,10);return isNaN(c)?b:c}function _tvf(a,b){var c=parseFloat(a);return isNaN(c)?b:c}function _tvv(a){return!!a}function p(a,b,c){(c||g)[a]=b}g.bv={n:_tvn("2",0),r:"",f:".67.",e:"0",m:_tvn("0",1)};
function q(a,b,c){var d="on"+b;if(a.addEventListener)a.addEventListener(b,c,!1);else if(a.attachEvent)a.attachEvent(d,c);else{var f=a[d];a[d]=function(){var a=f.apply(this,arguments),b=c.apply(this,arguments);return void 0==a?b:void 0==b?a:b&&a}}}var s=function(a){return function(){return g.bv.m==a}},ba=s(1),ca=s(2);p("sb",ba);p("kn",ca);l.a=_tvv;l.b=_tvf;l.c=_tvn;l.i=aa;var da=window.gbar.i.i;var t,u,v,w;function ea(a){v=a}function fa(a){var b;if(b=v&&window.encodeURIComponent)b=a.href,b=!b.match(/^http[s]?:\/\/accounts\.google\.[^/]*\/ClearSID/i)&&!b.match(/^http[s]?:\/\/[^/]*\/accounts\/ClearSID/i);if(b=b&&encodeURIComponent(v()))a.href=a.href.replace(/([?&]continue=)[^&]*/,"$1"+b)}function ga(a){window.gApplication&&(a.href=window.gApplication.getTabUrl(a.href))}
function ha(a){var b=document.forms[0].q,c=window.encodeURIComponent&&b&&b.value,b=b&&b.placeholder;c&&c!=b&&(a.href=a.href.replace(/([?&])q=[^&]*|$/,function(a,b){return(b||"&")+"q="+encodeURIComponent(c)}))}n=l.a("")?ga:ha;
function x(a,b,c,d,f,e){var h=document.getElementById(a);if(h){var k=h.style;k.left=d?"auto":b+"px";k.right=d?b+"px":"auto";k.top=c+"px";k.visibility=u?"hidden":"visible";f&&e?(k.width=f+"px",k.height=e+"px"):(x(t,b,c,d,h.offsetWidth,h.offsetHeight),u=u?"":a)}}
var y=[],ia=function(a,b){y.push(b)},ja=function(a){a=a||window.event;var b=a.target||a.srcElement;a.cancelBubble=!0;null==t&&(a=document.createElement(Array.every||window.createPopup?"iframe":"div"),a.frameBorder="0",t=a.id="gbs",a.src="javascript:''",b.parentNode.appendChild(a),q(document,"click",z));var c=b,b=0;"gb3"!=c.className&&(c=c.parentNode);a=c.getAttribute("aria-owns")||"gbi";var d=c.offsetWidth,f=20<c.offsetTop?46:24;document.getElementById("tphdr")&&(f-=3);var e=!1;do b+=c.offsetLeft||
0;while(c=c.offsetParent);var c=(document.documentElement.clientWidth||document.body.clientWidth)-b-d,h,d=document.body,k=document.defaultView;k&&k.getComputedStyle?(d=k.getComputedStyle(d,""))&&(h=d.direction):h=d.currentStyle?d.currentStyle.direction:d.style.direction;h="rtl"==h;if("gbi"==a){for(d=0;k=y[d++];)k();A(null,window.navExtra);h&&(b=c,e=!0)}else h||(b=c,e=!0);u!=a&&z();x(a,b,f,e)},z=function(){u&&x(u,0,0)},A=function(a,b){var c,d=document.getElementById("gbi"),f=a;f||(f=d.firstChild);
for(;b&&(c=b.pop());){var e=d,h=c,k=f;w||(w="gb2");e.insertBefore(h,k).className=w}},ka=function(a,b,c){if((b=document.getElementById(b))&&a){a.className="gb4";var d=document.createElement("span");d.appendChild(a);d.appendChild(document.createTextNode(" | "));d.id=c;b.appendChild(d)}},la=function(){return document.getElementById("gb_70")},ma=function(){return!!u};p("qs",n);p("setContinueCb",ea);p("pc",fa);p("tg",ja);p("close",z);p("addLink",ka);p("almm",A);p("si",la);p("adh",ia);p("op",ma);var B=function(){},C=function(){},F=function(a){var b=new Image,c=D;b.onerror=b.onload=b.onabort=function(){try{delete E[c]}catch(a){}};E[c]=b;b.src=a;D=c+1},E=[],D=0;p("logger",{il:C,ml:B,log:F});var G=window.gbar.logger;var H={},na={},I=[],oa=l.b("0.1",.1),pa=l.a("1",!0),qa=function(a,b){I.push([a,b])},ra=function(a,b){H[a]=b},sa=function(a){return a in H},J={},K=function(a,b){J[a]||(J[a]=[]);J[a].push(b)},ta=function(a){K("m",a)},L=function(a,b){var c=document.createElement("script");c.src=a;c.async=pa;Math.random()<oa&&(c.onerror=function(){c.onerror=null;B(Error("Bundle load failed: name="+(b||"UNK")+" url="+a))});(document.getElementById("xjsc")||document.getElementsByTagName("body")[0]||
document.getElementsByTagName("head")[0]).appendChild(c)},N=function(a){for(var b=0,c;(c=I[b])&&c[0]!=a;++b);!c||c[1].l||c[1].s||(c[1].s=!0,M(2,a),c[1].url&&L(c[1].url,a),c[1].libs&&m.d&&m.d(c[1].libs))},O=function(a){K("gc",a)},P=null,ua=function(a){P=a},M=function(a,b,c){if(P){a={t:a,b:b};if(c)for(var d in c)a[d]=c[d];try{P(a)}catch(f){}}};p("mdc",H);p("mdi",na);p("bnc",I);p("qGC",O);p("qm",ta);p("qd",J);p("lb",N);p("mcf",ra);p("bcf",qa);p("aq",K);p("mdd","");p("has",sa);
p("trh",ua);p("tev",M);var Q=l.b("0.1",.001),R=0;
function _mlToken(a,b){try{if(1>R){R++;var c,d=a,f=b||{},e=encodeURIComponent,h=["//www.google.com/gen_204?atyp=i&zx=",(new Date).getTime(),"&jexpid=",e("17483"),"&srcpg=",e("prop=22"),"&jsr=",Math.round(1/Q),"&ogev=",e("_6jpU6ivG4eksQT_joGICQ"),"&ogf=",g.bv.f,"&ogrp=",e("1"),"&ogv=",e("1407464522.0"),"&oggv="+e("es_plusone_gc_20140723.0_p0"),"&ogd=",e("com"),"&ogc=",e("GBR"),"&ogl=",e("en")];f._sn&&(f._sn="og."+
f._sn);for(var k in f)h.push("&"),h.push(e(k)),h.push("="),h.push(e(f[k]));h.push("&emsg=");h.push(e(d.name+":"+d.message));var r=h.join("");S(r)&&(r=r.substr(0,2E3));c=r;var Aa=window.gbar.logger._aem(a,c);F(Aa)}}catch(Na){}}var S=function(a){return 2E3<=a.length},va=function(a,b){return b};function T(a){B=a;p("_itl",S,G);p("_aem",va,G);p("ml",B,G);a={};H.er=a}l.a("")?T(function(a){throw a;}):l.a("1")&&Math.random()<Q&&T(_mlToken);I.push(["m",{url:"//ssl.gstatic.com/gb/js/scm_7385cc5883250b43a39405734c1bea59.js"}]);g.mcf("c",{});g.sg={c:""};if(l.a("1")){var wa=l.a("");I.push(["gc",{auto:wa,url:"//ssl.gstatic.com/gb/js/abc/gci_91f30755d6a6b787dcc2a4062e6e9824.js",libs:"googleapis.client:plusone:gapi.iframes"}]);var xa={version:"gci_91f30755d6a6b787dcc2a4062e6e9824.js",index:"",lang:"en"};H.gc=xa;var U=function(a){window.googleapis&&window.iframes?a&&a():(a&&O(a),N("gc"))};p("lGC",U);l.a("1")&&p("lPWF",U)};window.__PVT="";if(l.a("1")&&l.a("1")){var V=function(a){U(function(){K("pw",a);N("pw")})};p("lPW",V);I.push(["pw",{url:"//ssl.gstatic.com/gb/js/abc/pwm_45f73e4df07a0e388b0fa1f3d30e7280.js"}]);var W=[],ya=function(a){W[0]=a},za=function(a,b){var c=b||{};c._sn="pw";B(a,c)},Ba={signed:W,elog:za,base:"https://plusone.google.com/u/0",loadTime:(new Date).getTime()};H.pw=Ba;var X=function(a,b){for(var c=b.split("."),d=function(){var b=arguments;a(function(){for(var a=g,d=0,e=c.length-1;d<e;++d)a=a[c[d]];a[c[d]].apply(a,b)})},f=g,e=0,h=c.length-1;e<h;++e)f=
f[c[e]]=f[c[e]]||{};return f[c[e]]=d};X(V,"pw.clk");X(V,"pw.hvr");p("su",ya,g.pw)};function Ca(){function a(){for(var b;(b=e[h++])&&"m"!=b[0]&&!b[1].auto;);b&&(M(2,b[0]),b[1].url&&L(b[1].url,b[0]),b[1].libs&&m.d&&m.d(b[1].libs));h<e.length&&setTimeout(a,0)}function b(){0<f--?setTimeout(b,0):a()}var c=l.a("1"),d=l.a(""),f=3,e=I,h=0,k=window.gbarOnReady;if(k)try{k()}catch(r){da(r,"ml","or")}d?p("ldb",a):c?q(window,"load",b):b()}p("rdl",Ca);var Da={D:1,H:2,da:3,p:4,W:5,M:6,F:7,g:8,ha:9,U:10,L:11,T:12,S:13,N:14,Q:15,P:16,fa:17,w:18,O:19,ga:20,ea:21,u:22,G:23,ja:24,ka:25,ia:26,A:27,j:28,o:29,k:30,ca:31,Z:32,$:33,J:34,K:35,ba:36,aa:37,Y:38,B:39,R:40,v:41,X:42,V:43,h:48,C:49,I:500},Y=[1,2,3,4,5,6,9,10,11,13,14,28,29,30,34,35,37,38,39,40,41,42,43,48,49,500];var Z=l.b("0.001",1E-4),Ea=l.b("1",1),Fa=!1,Ga=!1;if(l.a("1")){var Ha=Math.random();Ha<=Z&&(Fa=!0);Ha<=Ea&&(Ga=!0)}var Ia=Da,$=null;function Ja(){var a=0,b=function(b,d){l.a(d)&&(a|=b)};b(1,"");b(2,"");b(4,"");b(8,"");return a}
function Ka(a,b){var c=Z,d=Fa,f;f=a;if(!$){$={};for(var e=0;e<Y.length;e++){var h=Y[e];$[h]=!0}}if(f=!!$[f])c=Ea,d=Ga;if(d){d=encodeURIComponent;g.rp?(f=g.rp(),f="-1"!=f?f:"1"):f="1";c=["//www.google.com/gen_204?atyp=i&zx=",(new Date).getTime(),"&oge=",a,"&ogex=",d("17483"),"&ogev=",d("_6jpU6ivG4eksQT_joGICQ"),"&ogf=",g.bv.f,"&ogp=",d("22"),"&ogrp=",d(f),"&ogsr=",Math.round(1/c),"&ogv=",d("1407464522.0"),"&oggv="+
d("es_plusone_gc_20140723.0_p0"),"&ogd=",d("com"),"&ogl=",d("en"),"&ogc=",d("GBR"),"&ogus=",Ja()];if(b){"ogw"in b&&(c.push("&ogw="+b.ogw),delete b.ogw);var k;f=b;e=[];for(k in f)0!=e.length&&e.push(","),e.push(La(k)),e.push("."),e.push(La(f[k]));k=e.join("");""!=k&&(c.push("&ogad="),c.push(d(k)))}F(c.join(""))}}function La(a){"number"==typeof a&&(a+="");return"string"==typeof a?a.replace(".","%2E").replace(",","%2C"):a}C=Ka;p("il",C,G);var Ma={};H.il=Ma;setTimeout(function(){C(Ia.g)},0);}catch(e){window.gbar&&gbar.logger&&gbar.logger.ml(e,{"_sn":"cfg.init"});}})();
(function(){try{var b=window.gbar.i.i;var c=window.gbar;var f=function(d){try{var a=document.getElementById("gbom");a&&d.appendChild(a.cloneNode(!0))}catch(e){b(e,"omas","aomc")}};c.aomc=f;}catch(e){window.gbar&&gbar.logger&&gbar.logger.ml(e,{"_sn":"cfg.init"});}})();
(function(){try{var a=window.gbar;a.mcf("pm",{p:""});}catch(e){window.gbar&&gbar.logger&&gbar.logger.ml(e,{"_sn":"cfg.init"});}})();
(function(){try{window.gbar.rdl();}catch(e){window.gbar&&gbar.logger&&gbar.logger.ml(e,{"_sn":"cfg.init"});}})();
if (window['_OC_timingAction']) {window['_OC_timingAction']('patents_refpage');}</script><style>#gbar,#guser{font-size:13px;padding-top:1px !important;}#gbar{float:left;height:22px}#guser{padding-bottom:7px !important;text-align:right}.gbh,.gbd{border-top:1px solid #c9d7f1;font-size:1px}.gbh{height:0;position:absolute;top:24px;width:100%}#gbs,.gbm{background:#fff;left:0;position:absolute;text-align:left;visibility:hidden;z-index:1000}.gbm{border:1px solid;border-color:#c9d7f1 #36c #36c #a2bae7;z-index:1001}.gb1{margin-right:.5em}.gb1,.gb3{zoom:1}.gb2{display:block;padding:.2em .5em}.gb2,.gb3{text-decoration:none !important;border-bottom:none}a.gb1,a.gb4{text-decoration:underline !important}a.gb1,a.gb2,a.gb3,a.gb4{color:#00c !important}.gbi .gb3,.gbi .gb2,.gbi .gb4{color:#dd8e27 !important}.gbf .gb3,.gbf .gb2,.gbf .gb4{color:#900 !important}a.gb2:hover{background:#36c;color:#fff !important}#gbar .gbz0l{color:#000 !important;cursor:default;font-weight:bold;text-decoration:none !important}
#gbar { padding:.3em .6em !important;}</style></head><body  topmargin="3" marginheight="3"><div id=gbar><nobr><a onclick=gbar.qs(this);gbar.logger.il(1,{t:1}); class=gb1 id=gb_1 href="https://www.google.com/search?sa=N&tab=tw">Search</a> <a onclick=gbar.qs(this);gbar.logger.il(1,{t:2}); class=gb1 id=gb_2 href="http://www.google.com/search?hl=en&tbm=isch&source=og&sa=N&tab=ti">Images</a> <a onclick=gbar.qs(this);gbar.logger.il(1,{t:8}); class=gb1 id=gb_8 href="http://maps.google.com/maps?hl=en&sa=N&tab=tl">Maps</a> <a onclick=gbar.qs(this);gbar.logger.il(1,{t:78}); class=gb1 id=gb_78 href="https://play.google.com/?hl=en&sa=N&tab=t8">Play</a> <a onclick=gbar.qs(this);gbar.logger.il(1,{t:36}); class=gb1 id=gb_36 href="http://www.youtube.com/results?sa=N&tab=t1">YouTube</a> <a onclick=gbar.logger.il(1,{t:5}); class=gb1 id=gb_5 href="http://news.google.com/nwshp?hl=en&tab=tn">News</a> <a onclick=gbar.logger.il(1,{t:23}); class=gb1 id=gb_23 href="https://mail.google.com/mail/?tab=tm">Gmail</a> <a onclick=gbar.logger.il(1,{t:25}); class=gb1 id=gb_25 href="https://drive.google.com/?tab=to">Drive</a> <a class=gb3 href="http://www.google.com/intl/en/options/" onclick="this.blur();gbar.tg(event);return !1" aria-haspopup=true><u>More</u> <small>&#9660;</small></a><div class=gbm id=gbi><a onclick=gbar.logger.il(1,{t:24}); class=gb2 id=gb_24 href="https://www.google.com/calendar?tab=tc">Calendar</a><a onclick=gbar.qs(this);gbar.logger.il(1,{t:51}); class=gb2 id=gb_51 href="http://translate.google.com/?hl=en&sa=N&tab=tT">Translate</a><a onclick=gbar.logger.il(1,{t:17}); class=gb2 id=gb_17 href="http://www.google.com/mobile/?hl=en&tab=tD">Mobile</a><a onclick=gbar.qs(this);gbar.logger.il(1,{t:10}); class=gb2 id=gb_10 href="http://www.google.com/search?hl=en&tbo=u&tbm=bks&source=og&sa=N&tab=tp">Books</a><a onclick=gbar.logger.il(1,{t:212}); class=gb2 id=gb_212 href="https://wallet.google.com/manage/?tab=ta">Wallet</a><a onclick=gbar.qs(this);gbar.logger.il(1,{t:6}); class=gb2 id=gb_6 href="http://www.google.com/search?hl=en&tbo=u&tbm=shop&source=og&sa=N&tab=tf">Shopping</a><a onclick=gbar.logger.il(1,{t:30}); class=gb2 id=gb_30 href="http://www.blogger.com/?tab=tj">Blogger</a><a onclick=gbar.qs(this);gbar.logger.il(1,{t:27}); class=gb2 id=gb_27 href="http://www.google.com/finance?sa=N&tab=te">Finance</a><a onclick=gbar.qs(this);gbar.logger.il(1,{t:31}); class=gb2 id=gb_31 href="https://plus.google.com/photos?sa=N&tab=tq">Photos</a><a onclick=gbar.qs(this);gbar.logger.il(1,{t:12}); class=gb2 id=gb_12 href="http://www.google.com/search?hl=en&tbo=u&tbm=vid&source=og&sa=N&tab=tv">Videos</a><div class=gb2><div class=gbd></div></div><a onclick=gbar.logger.il(1,{t:66}); href="http://www.google.com/intl/en/options/" class=gb2>Even more &raquo;</a></div></nobr></div><div id=guser width=100%><nobr><span id=gbn class=gbi></span><span id=gbf class=gbf></span><span id=gbe></span><a target=_top id=gb_70 href="https://www.google.com/accounts/Login?service=&continue=http://www.google.com/patents%3Fhl%3Den&hl=en" class=gb4>Sign in</a><div style="display: none"><div class=gbm id=gbd5 aria-owner=gbg5><div class=gbmc><ol id=gbom class=gbmcc></ol></div></div></div></nobr></div><div class=gbh style=left:0></div><div class=gbh style=right:0></div><div role="alert" style="position: absolute; left: 0; right: 0;"><a href="http://www.google.com/patents/us6199173?hl=en&amp;output=html_text" title="Screen reader users: click this link for accessible mode. Accessible mode has the same essential features but works better with your reader."><img border="0" src="http://www.google.com/images/cleardot.gif"alt="Screen reader users: click this link for accessible mode. Accessible mode has the same essential features but works better with your reader."></a></div><div id="guser"><nobr></nobr></div><div style="clear:both;"></div><div id="gb-top-search-box" class="gb-top-search-box-small gb-reset"><table><tr><td class="logo"><a href="http://www.google.com/patents" class="logo-link"><img class="logo-img" src="/intl/en/images/logos/google_logo_41.png" alt="Go to Google Books Home" height="41"/></a></td><td><form action="http://www.google.com/search" name="f" id="vheadf" method="get"><span id="hf"></span><input type="hidden" name="tbm" value="pts"/><input type="hidden" name="tbo" value="1"/><input type="hidden" name="hl" value="en"/><table><tr><td><div class="inputs"><table><tr><td><div class="text-input"><input type="text" name="q" id="vheadq" class="text" maxlength="2048" size="31" value="" title="Search Patents" accesskey="s" autocomplete="off"/><script>window._OC_autoDir &&window._OC_autoDir('vheadq', 'tia-vheadq');</script></div></td><td><div class="submit-input"><input name="btnG" class="submit" type="submit" value=""/></div></td></tr></table></div></td><td class="col-ext-links"><div class="ext-links"><a href="http://www.google.com/advanced_patent_search">&lt;nobr&gt;Advanced Patent Search&lt;/nobr&gt;</a></div></td></tr></table></form></td></tr></table></div><div class="kd-appbar"><h2 class="kd-appname"><a href="/patents">Patents</a></h2><div class="kd-buttonbar left" id="left-toolbar-buttons"><a id="appbar-write-review-link" href=""></a><a id="appbar-view-print-sample-link" href=""></a><a id="appbar-view-ebook-sample-link" href=""></a><a id="appbar-patents-prior-art-finder-link" href="https://www.google.com/patents/related/US6199173"></a><a id="appbar-patents-discuss-this-link" href="http://www.google.com/url?id=8nxTBAABERAJ&amp;q=http://patents.stackexchange.com/redirect/google-patents%3Fpatent%3DUS6199173&amp;usg=AFQjCNEbjK79xt-fVNn8jGMWBeY9oC6beg" data-is-grant="true"></a><a id="appbar-read-patent-link" href="//docs.google.com/viewer?url=patentimages.storage.googleapis.com/pdfs/US6199173.pdf"></a><a id="appbar-download-pdf-link" href="//patentimages.storage.googleapis.com/pdfs/US6199173.pdf"></a></div><div class="kd-buttonbar right" id="right-toolbar-buttons"></div></div><div id="books-microdata" itemscope=""itemtype="http://schema.org/Book"itemid="http://www.google.com/patents/US6199173" style="display:none"><span itemprop="description">A network of microcontrollers for monitoring and diagnosing the environmental conditions of a computer is disclosed. The network of microcontrollers provides a management system by which computer users can accurately gauge the health of their computer. The network of microcontrollers provides users the...</span><span itemprop="url">http://www.google.com/patents/US6199173?utm_source=gb-gplus-share</span><span class="main-title" itemprop="name">Patent US6199173 - Method for mapping environmental resources to memory for program access</span><img itemprop="image" src="http://www.google.com/patents?id=&amp;printsec=frontcover&amp;img=1&amp;zoom=1"alt="Patent US6199173 - Method for mapping environmental resources to memory for program access" title="Patent US6199173 - Method for mapping environmental resources to memory for program access"></div><div style="display: none"><ol id="ofe-gear-menu-contents" class="gbmcc"><li class="gbe gbmtc"><a class="gbmt goog-menuitem-content" id="" href="http://www.google.com/advanced_patent_search">Advanced Patent Search</a></li></ol></div><table id="viewport_table" cellpadding="0" style="clear:both" cellspacing="0"><tr><td id="viewport_td"><div class=vertical_module_list_row><div id=intl_patents class=about_content><div id=intl_patents_v><table class="patent-bibdata"><tr><td class="patent-bibdata-heading">Publication number</td><td class="single-patent-bibdata">US6199173 B1</td></tr><tr><td class="patent-bibdata-heading">Publication type</td><td class="single-patent-bibdata">Grant</td></tr><tr><td class="patent-bibdata-heading">Application number</td><td class="single-patent-bibdata">US 08/942,214</td></tr><tr><td class="patent-bibdata-heading">Publication date</td><td class="single-patent-bibdata">Mar 6, 2001</td></tr><tr><td class="patent-bibdata-heading">Filing date</td><td class="single-patent-bibdata">Oct 1, 1997</td></tr><tr><td class="patent-bibdata-heading">Priority date<span class="patent-tooltip-anchor patent-question-icon"data-tooltip-text="The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed."></span></td><td class="single-patent-bibdata">Oct 1, 1997</td></tr><tr><td class="patent-bibdata-heading">Fee status<span class="patent-tooltip-anchor patent-question-icon"data-tooltip-text="The fee status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status or dates listed."></span></td><td class="single-patent-bibdata">Paid</td></tr><tr class="patent-bibdata-list-row alternate-patent-number"><td class="patent-bibdata-heading">Publication number</td><td><span class="patent-bibdata-value-list"><span class="patent-bibdata-value">08942214, </span><span class="patent-bibdata-value">942214, </span><span class="patent-bibdata-value">US 6199173 B1, </span><span class="patent-bibdata-value">US 6199173B1, </span><span class="patent-bibdata-value">US-B1-6199173, </span><span class="patent-bibdata-value">US6199173 B1, </span><span class="patent-bibdata-value">US6199173B1</span></span></td></tr><tr class="patent-bibdata-list-row "><td class="patent-bibdata-heading">Inventors</td><td><span class="patent-bibdata-value-list"><span class="patent-bibdata-value"><a href="http://www.google.com/search?tbo=p&tbm=pts&hl=en&q=ininventor:%22Karl+S.+Johnson%22">Karl S. Johnson</a>, </span><span class="patent-bibdata-value"><a href="http://www.google.com/search?tbo=p&tbm=pts&hl=en&q=ininventor:%22Walter+A.+Wallach%22">Walter A. Wallach</a>, </span><span class="patent-bibdata-value"><a href="http://www.google.com/search?tbo=p&tbm=pts&hl=en&q=ininventor:%22Ken+Nguyen%22">Ken Nguyen</a>, </span><span class="patent-bibdata-value"><a href="http://www.google.com/search?tbo=p&tbm=pts&hl=en&q=ininventor:%22Carlton+G.+Amdahl%22">Carlton G. Amdahl</a></span></span></td></tr><tr class="patent-bibdata-list-row "><td class="patent-bibdata-heading">Original Assignee</td><td><span class="patent-bibdata-value-list"><span class="patent-bibdata-value"><a href="http://www.google.com/search?tbo=p&tbm=pts&hl=en&q=inassignee:%22Micron+Electronics,+Inc.%22">Micron Electronics, Inc.</a></span></span></td></tr><tr class="patent-bibdata-list-row "><td class="patent-bibdata-heading">Export Citation</td><td><span class="patent-bibdata-value-list"><span class="patent-bibdata-value"><a href="/patents/US6199173.bibtex">BiBTeX</a>, </span><span class="patent-bibdata-value"><a href="/patents/US6199173.enw">EndNote</a>, </span><span class="patent-bibdata-value"><a href="/patents/US6199173.ris">RefMan</a></span></span></td></tr><tr class="patent-internal-links"><td colspan=2><span class="patent-bibdata-value"><a href="#backward-citations">Patent Citations</a> (108),</span> <span class="patent-bibdata-value"><a href="#npl-citations">Non-Patent Citations</a> (31),</span> <span class="patent-bibdata-value"><a href="#forward-citations">Referenced by</a> (25),</span> <span class="patent-bibdata-value"><a href="#classifications">Classifications</a> (16),</span> <span class="patent-bibdata-value"><a href="#legal-events">Legal Events</a> (10)</span> </td></tr><tr><td colspan=2 class="patent-bibdata-external-link-spacer-top"></td></tr><tr class="patent-bibdata-external-link-spacer-bottom"></tr><tr><td colspan=2><span class="patent-bibdata-heading">External Links:&nbsp;</span><span><span class="patent-bibdata-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://patft.uspto.gov/netacgi/nph-Parser%3FSect2%3DPTO1%26Sect2%3DHITOFF%26p%3D1%26u%3D/netahtml/PTO/search-bool.html%26r%3D1%26f%3DG%26l%3D50%26d%3DPALL%26RefSrch%3Dyes%26Query%3DPN/6199173&usg=AFQjCNE6MPYsOSKdAWoP6uwG0rk9qNkXYQ">USPTO</a>, </span><span class="patent-bibdata-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://assignments.uspto.gov/assignments/q%3Fdb%3Dpat%26pat%3D6199173&usg=AFQjCNGraMbi_Jq77JmT2mF46p5e9dALOA">USPTO Assignment</a>, </span><span class="patent-bibdata-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://worldwide.espacenet.com/publicationDetails/biblio%3FCC%3DUS%26NR%3D6199173B1%26KC%3DB1%26FT%3DD&usg=AFQjCNEcVHHKNzlR0rPqlaviWauL4Jn3xw">Espacenet</a></span></span></td></tr><tr class="patent-bibdata-group-spacer"></tr></table><div class="number-and-title"><span class="patent-title"><invention-title mxw-id="PT54721038" lang="EN" load-source="patent-office">Method for mapping environmental resources to memory for program access</invention-title></span><br><span class="patent-number">US 6199173 B1</span></div><div class="patent-section patent-abstract-section"><div class="patent-section-header"><span class="patent-section-title">Abstract</span></div><div class="patent-text"><abstract mxw-id="PA72520910" lang="EN" load-source="patent-office"> <div class="abstract">A network of microcontrollers for monitoring and diagnosing the environmental conditions of a computer is disclosed. The network of microcontrollers provides a management system by which computer users can accurately gauge the health of their computer. The network of microcontrollers provides users the ability to detect system fan speeds, internal temperatures and voltage levels. The invention is designed to not only be resilient to faults, but also allows for the system maintenance, modification, and growth—without downtime. Additionally, the present invention allows users to replace failed components, and add new functionality, such as new network interfaces, disk interface cards and storage, without impacting existing users. One of the primary roles of the present invention is to manage the environment without outside involvement. This self-management allows the system to continue to operate even though components have failed.</div>
  </abstract></div></div><div class="patent-section patent-drawings-section"><div class="patent-section-header"><span class="patent-section-title">Images<span class="patent-section-count">(24)</span></span></div><div class="patent-drawings-body"><div class="patent-drawings-carousel"><div class="drawings"><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00000.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00000.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00001.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00001.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00002.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00002.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00003.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00003.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00004.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00004.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00005.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00005.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00006.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00006.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00007.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00007.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00008.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00008.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00009.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00009.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00010.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00010.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00011.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00011.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00012.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00012.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00013.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00013.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00014.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00014.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00015.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00015.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00016.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00016.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00017.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00017.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00018.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00018.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00019.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00019.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00020.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00020.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00021.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00021.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00022.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00022.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div><div class="patent-image"><div class="patent-thumbnail"><a href="//patentimages.storage.googleapis.com/US6199173B1/US06199173-20010306-D00023.png"><img class="patent-thumbnail-image" alt="Patent Drawing"src="//patentimages.storage.googleapis.com/thumbnails/US6199173B1/US06199173-20010306-D00023.png" /></a></div><div class="patent-thumbnail-caption">&nbsp;</div></div></div></div><div class="patent-drawings-control patent-drawings-prev"><img class="patent-drawings-button-img" alt="Previous page"src="/googlebooks/images/kennedy/page_left.png"width="21" height="21" /></div><div class="patent-drawings-control patent-drawings-next"><img class="patent-drawings-button-img" alt="Next page"src="/googlebooks/images/kennedy/page_right.png"width="21" height="21" /></div></div></div><div class="patent-post-drawings"></div><div class="patent-section patent-claims-section"><div class="patent-section-header"><span class="patent-section-title">Claims<span class="patent-section-count">(22)</span></span></div><div class="patent-text"><div mxw-id="PCLM28599477" lang="EN" load-source="patent-office" class="claims">
    <claim-statement>What is claimed is: </claim-statement> <div class="claim"> <div num="1" id="US-6199173-B1-CLM-00001" class="claim">
      <div class="claim-text">1. A method of mapping environmental resources to memory, comprising:</div>
      <div class="claim-text">providing a computer, the computer comprising a processor and a memory; </div>
      <div class="claim-text">providing a microcontroller network, wherein the microcontrollers provide monitoring and control functions associated with the environmental conditions internal to the computer; </div>
      <div class="claim-text">storing in the memory a unique identifier for each of the functions; and </div>
      <div class="claim-text">executing commands on the microcontroller network by accessing any one of the unique identifies. </div>
    </div>
    </div> <div class="claim-dependent"> <div num="2" id="US-6199173-B1-CLM-00002" class="claim">
      <div class="claim-text">2. The method of claim <b>1</b>, additionally comprising providing a client computer connected to the computer, wherein the execution of commands are initiated by the client computer.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="3" id="US-6199173-B1-CLM-00003" class="claim">
      <div class="claim-text">3. The method of claim <b>1</b>, wherein executing commands includes altering the speed of a system fan.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="4" id="US-6199173-B1-CLM-00004" class="claim">
      <div class="claim-text">4. The method of claim <b>1</b>, wherein executing commands includes reading the temperature of a sensor.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="5" id="US-6199173-B1-CLM-00005" class="claim">
      <div class="claim-text">5. The method of claim <b>1</b>, wherein executing commands includes writing a message to a display.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="6" id="US-6199173-B1-CLM-00006" class="claim">
      <div class="claim-text">6. The method of claim <b>1</b>, wherein executing commands includes checking the state of a microcontroller bus.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="7" id="US-6199173-B1-CLM-00007" class="claim">
      <div class="claim-text">7. The method of claim <b>1</b>, wherein executing commands includes checking for the presence of a canister containing adapter slots.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="8" id="US-6199173-B1-CLM-00008" class="claim">
      <div class="claim-text">8. The method of claim <b>1</b>, wherein executing commands includes checking a system voltage.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="9" id="US-6199173-B1-CLM-00009" class="claim">
      <div class="claim-text">9. The method of claim <b>1</b>, wherein the unique identifier is provided in the executable code associated with executing commands.</div>
    </div>
    </div> <div class="claim"> <div num="10" id="US-6199173-B1-CLM-00010" class="claim">
      <div class="claim-text">10. A method of mapping environmental resources to memory, comprising:</div>
      <div class="claim-text">providing a computer, including a processor and memory, connected to a microcontroller network; </div>
      <div class="claim-text">connecting a plurality of sensors to the microcontroller network, the sensors monitoring one or more environmental conditions internal to the computer; </div>
      <div class="claim-text">assigning a unique identifier to each sensor; and </div>
      <div class="claim-text">providing a model of the microcontroller network in the computer memory, wherein the computer is capable of communicating with a selected one of the sensors by mapping the unique identifier of the selected sensor to the microcontroller in the network connected to the selected sensor. </div>
    </div>
    </div> <div class="claim-dependent"> <div num="11" id="US-6199173-B1-CLM-00011" class="claim">
      <div class="claim-text">11. The method of claim <b>10</b>, additionally comprising increasing the speed of a fan in the computer when the temperature of the computer exceeds a threshold temperature.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="12" id="US-6199173-B1-CLM-00012" class="claim">
      <div class="claim-text">12. The method of claim <b>10</b>, additionally comprising checking for the presence of a power supply.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="13" id="US-6199173-B1-CLM-00013" class="claim">
      <div class="claim-text">13. The method of claim <b>10</b>, additionally comprising enabling the writing of flash memory with a new basic input/out system (BIOS) program.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="14" id="US-6199173-B1-CLM-00014" class="claim">
      <div class="claim-text">14. The method of claim <b>10</b>, additionally comprising sending a message to a system log.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="15" id="US-6199173-B1-CLM-00015" class="claim">
      <div class="claim-text">15. The method of claim <b>10</b>, additionally comprising sending notification of a system fault to the central processing unit.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="16" id="US-6199173-B1-CLM-00016" class="claim">
      <div class="claim-text">16. The method of claim <b>10</b>, additionally comprising disabling power to a canister that is connected to the computer.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="17" id="US-6199173-B1-CLM-00017" class="claim">
      <div class="claim-text">17. The method of claim <b>10</b>, additionally comprising enabling power to a canister that is connected to the computer.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="18" id="US-6199173-B1-CLM-00018" class="claim">
      <div class="claim-text">18. The method of claim <b>10</b>, additionally comprising updating a watchdog timer that is maintained by the microcontroller network.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="19" id="US-6199173-B1-CLM-00019" class="claim">
      <div class="claim-text">19. The method of claim <b>10</b>, additionally comprising interconnecting the microcontroller network with an I<sup>2</sup>C bus.</div>
    </div>
    </div> <div class="claim-dependent"> <div num="20" id="US-6199173-B1-CLM-00020" class="claim">
      <div class="claim-text">20. The method of claim <b>10</b>, wherein the unique identifier is part of a management information block.</div>
    </div>
    </div> <div class="claim"> <div num="21" id="US-6199173-B1-CLM-00021" class="claim">
      <div class="claim-text">21. A method of monitoring environmental conditions in a computerized environment, the method comprising:</div>
      <div class="claim-text">creating a request message which identifies one or more environmental conditions internal to the computerized environment; </div>
      <div class="claim-text">sending the request message from a requestor to a microcontroller network which manages the environmental conditions; </div>
      <div class="claim-text">obtaining status of the conditions identified by the request message; </div>
      <div class="claim-text">creating a response message which reports the status; and </div>
      <div class="claim-text">sending the response message from the microcontroller network to the requester. </div>
    </div>
    </div> <div class="claim-dependent"> <div num="22" id="US-6199173-B1-CLM-00022" class="claim">
      <div class="claim-text">22. The method of claim <b>21</b>, wherein the requestor is a central processing unit.</div>
    </div>
  </div> </div></div></div><div class="patent-section patent-description-section"><div class="patent-section-header"><span class="patent-section-title">Description</span></div><div class="patent-text"><div mxw-id="PDES54506194" lang="EN" load-source="patent-office" class="description">
    <heading>PRIORITY CLAIM</heading> <p>The benefit under 35 U.S.C. § 119(e) of the following U.S. provisional application(s) is hereby claimed:</p>
    <p>
      <tables> <table frame="none" colsep="0" rowsep="0" class="description-table"> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="center" colwidth="42PT"> </colspec> <colspec colname="3" align="center" colwidth="49PT"> </colspec> <thead valign="bottom"> <tr class="description-tr"> <td namest="1" nameend="3" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="3"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Application</td>
                <td morerows="0" valign="top" class="description-td"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Title</td>
                <td morerows="0" valign="top" class="description-td">No.</td>
                <td morerows="0" valign="top" class="description-td">Filing Date</td>
              </tr> <tr class="description-tr"> <td namest="1" nameend="3" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="3"> </td>
              </tr> </thead> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Remote Access and Control of</td>
                <td morerows="0" valign="top" class="description-td">60/046,397</td>
                <td morerows="0" valign="top" class="description-td">May 13, 1997</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Environmental Management System”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Hardware and Software Architecture for</td>
                <td morerows="0" valign="top" class="description-td">60/047,016</td>
                <td morerows="0" valign="top" class="description-td">May 13, 1997</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Inter-Connecting an Environmental</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Management System with a Remote</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Interface”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Self Management Protocol for a</td>
                <td morerows="0" valign="top" class="description-td">60/046,416</td>
                <td morerows="0" valign="top" class="description-td">May 13, 1997</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Fly-By-Wire Service Processor”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Computer System Hardware</td>
                <td morerows="0" valign="top" class="description-td">60/046,398</td>
                <td morerows="0" valign="top" class="description-td">May 13, 1997</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Infrastructure for Hot Plugging Single</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">and Multi-Function PC</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Cards Without Embedded Bridges”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Computer System Hardware</td>
                <td morerows="0" valign="top" class="description-td">60/046,312</td>
                <td morerows="0" valign="top" class="description-td">May 13, 1997</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Infrastructure for Hot Plugging</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Multi-Function PCI Cards With</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Embedded Bridges”</td>
              </tr> <tr class="description-tr"> <td namest="1" nameend="3" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="3"> </td>
              </tr> </tbody> </tgroup> </table> </tables> </p>
    <heading>RELATED APPLICATIONS</heading> <p>This application is related to U.S. application Ser. No. 08/942,402, entitled “DIAGNOSTIC AND MANAGING DISTRIBUTED PROCESSOR SYSTEM”, U.S. application Ser. No. 08/942,448, entitled “METHOD FOR MANAGING A DISTRIBUTED PROCESSOR SYSTEM”, and U.S. application Ser. No. 08/942,222, entitled “SYSTEM FOR MAPPING ENVIRONMENTAL RESOURCES TO MEMORY FOR PROGRAM ACCESS”, which are being filed concurrently herewith.</p>
    <heading>APPENDICES</heading> <p>Appendix A, which forms a part of this disclosure, is a list of commonly owned copending U.S. patent applications. Each one of the applications listed in Appendix A is hereby incorporated herein in its entirety by reference thereto.</p>
    <heading>COPYRIGHT RIGHTS</heading> <p>A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent files or records, but otherwise reserves all copyright rights whatsoever.</p>
    <heading>BACKGROUND OF THE INVENTION</heading> <p>1. Field of the Invention</p>
    <p>The invention relates to the field of fault tolerant computer systems. More particularly, the invention relates to a managing and diagnostic system for evaluating and controlling the environmental conditions of a fault tolerant computer system.</p>
    <p>2. Description of the Related Technology</p>
    <p>As enterprise-class servers become more powerful and more capable, they are also becoming ever more sophisticated and complex. For many companies, these changes lead to concerns over server reliability and manageability, particularly in light of the increasingly critical role of server-based applications. While in the past many systems administrators were comfortable with all of the various components that made up a standards-based network server, today's generation of servers can appear as an incomprehensible, unmanageable black box. Without visibility into the underlying behavior of the system, the administrator must “fly blind.” Too often, the only indicators the network manager has on the relative health of a particular server is whether or not it is running.</p>
    <p>It is well-acknowledged that there is a lack of reliability and availability of most standards-based servers. Server downtime, resulting either from hardware or software faults or from regular maintenance, continues to be a significant problem. By one estimate, the cost of downtime in mission critical environments has risen to an annual total of $4.0 billion for U.S. businesses, with the average downtime event resulting in a $140 thousand loss in the retail industry and a $450 thousand loss in the securities industry. It has been reported that companies lose as much as $250 thousand in employee productivity for every 1% of computer downtime. With emerging Internet, intranet and collaborative applications taking on more essential business roles every day, the cost of network server downtime will continue to spiral upward. Another major cost is of system downtime administrators to diagnose and fix the system. Corporations are looking for systems which do not require real time service upon a system component failure.</p>
    <p>While hardware fault tolerance is an important element of an overall high availability architecture, it is only one piece of the puzzle. Studies show that a significant percentage of network server downtime is caused by transient faults in the I/O subsystem. Transient failures are those which make a server unusable, but which disappear when the server is restarted, leaving no information which points to a failing component. These faults may be due, for example, to the device driver, the adapter card firmware, or hardware which does not properly handle concurrent errors, and often causes servers to crash or hang. The result is hours of downtime per failure, while a system administrator discovers the failure, takes some action and manually reboots the server. In many cases, data volumes on hard disk drives become corrupt and must be repaired when the volume is mounted. A dismount-and-mount cycle may result from the lack of hot pluggability in current standards-based servers. Diagnosing intermittent errors can be a frustrating and time-consuming process. For a system to deliver consistently high availability, it should be resilient to these types of faults.</p>
    <p>Modern fault tolerant systems have the functionality monitor the ambient temperature of a storage device enclosure and the operational status of other components such the cooling fans and power supply. However, a limitation of these server systems is that they do not contain self-managing processes to correct malfunctions. Thus, if a malfunction occurs in a typical server, the one corrective measure taken by the server is to give notification of the error causing event via a computer monitor to the system administrator. If the system error caused the system to stop running, the system administrator might never know the source of the error. Traditional systems are lacking in detail and sophistication when notifying system administrators of system malfunctions. System administrators are in need of a graphical user interface for monitoring the health of a network of servers. Administrators need a simple point-and-click interface to evaluate the health of each server in the network. In addition, existing fault tolerant servers rely upon operating system maintained logs for error recording. These systems are not capable of maintaining information when the operating system is inoperable due to a system malfunction.</p>
    <p>Existing systems also do not have an interface to control the changing or addition of an adapter. Since any user on a network could be using a particular device on the server, system administrators need a software application that will control the flow of communications to a device before, during, and after a hot plug operation on an adapter.</p>
    <p>Also, in the typical fault tolerant computer system, the control logic for the diagnostic system is associated with a particular processor. Thus, if the environmental control processor malfunctioned, then all diagnostic activity on the computer would cease. In traditional systems, there is no monitoring of fans, and no means to make up cooling capacity lost when a fan fails. Some systems provide a processor located on a plug-in PCI card which can monitor some internal systems, and control turning power on and off. If this card fails, obtaining information about the system, and controlling it remotely, is no longer possible. Further, these systems are not able to affect fan speed or cooling capacity.</p>
    <p>Therefore, a need exists for improvements in server management which will result in greater reliability and dependability of operation. Server users are in need of a management system by which the users can accurately gauge the health of their system. Users need a high availability system that should not only be resilient to faults, but should allow for maintenance, modification, and growth—without downtime. System users should be able to replace failed components, and add new functionality, such as new network interfaces, disk interface cards and storage, without impacting existing users. As system demands grow, organizations must frequently expand, or scale, their computing infrastructure, adding new processing power, memory, storage and I/O capacity. With demand for 24-hour access to critical, server-based information resources, planned system downtime for system service or expansion has become unacceptable.</p>
    <heading>SUMMARY OF THE INVENTION</heading> <p>Embodiments of the inventive monitoring and management system provides system administrators with new levels of client/server system availability and management. It gives system administrators and network managers a comprehensive view into the underlying health of the server—in real time, whether on-site or off-site. In the event of a failure, the invention enables the administrator to learn why the system failed, why the system was unable to boot, and to control certain functions of the server.</p>
    <p>A method of mapping environmental resources to memory, comprising providing a computer, providing a microcontroller network, connecting the microcontroller network to a computer containing a central processor and a memory, creating an information pathway between the network of microcontrollers and specific memory addresses of the memory and executing commands on the at least one microcontroller which manage and diagnose system functions. A method of mapping environmental resources to memory, comprising providing a computer, including a processor and a memory, connected to a microcontroller network, connecting a plurality of sensors to the microcontroller network and providing a network model in the computer memory, wherein the computer is capable of communicating with a selected one of the sensors by mapping a unique identifier to the microcontroller in the network connected to the selected sensor.</p>
    <heading>BRIEF DESCRIPTION OF THE DRAWINGS</heading> <p>FIG. 1 is one embodiment of a top-level block diagram showing a fault tolerant computer system of the invention, including mass storage and network connections.</p>
    <p>FIG. 2 is one embodiment of a block diagram showing a first embodiment of a multiple bus configuration connecting I/O adapters and a network of microcontrollers to the clustered CPUs of the fault tolerant computer system shown in FIG. <b>1</b>.</p>
    <p>FIG. 3 is one embodiment of a block diagram showing a second embodiment of a multiple bus configuration connecting canisters containing I/O adapters and a network of microcontrollers to the clustered CPUs of the fault tolerant system shown in FIG. <b>1</b>.</p>
    <p>FIG. 4 is one embodiment of a top-level block diagram illustrating the microcontroller network shown in FIGS. 2 and 3.</p>
    <p>FIGS. 5A and 5B are detailed block diagrams showing one embodiment of the microcontroller network shown in FIG. 4 illustrating the signals and values monitored by each microcontroller, and the control signals generated by the microcontrollers.</p>
    <p>FIG. 6 is one embodiment of a flowchart showing the process by which a remote user can access diagnostic and managing services of the microcontroller network shown in FIGS. 4, <b>5</b>A and <b>5</b>B.</p>
    <p>FIG. 7 is one embodiment of a block diagram showing the connection of an industry standard architecture (ISA) bus to the microcontroller network shown in FIGS. 4, <b>5</b>A and <b>5</b>B.</p>
    <p>FIG. 8 is one embodiment of a flowchart showing the master to slave communications of the microcontrollers shown in FIGS. 4, <b>5</b>A and <b>5</b>B.</p>
    <p>FIG. 9 is one embodiment of a flowchart showing the slave to master communications of the microcontrollers shown in FIGS. 4, <b>5</b>A and <b>5</b>B.</p>
    <p>FIGS. 10A and 10B are flowcharts showing one process by which the System Interface, shown in FIGS. 4, <b>5</b>A and <b>5</b>B, gets commands and relays commands from the ISA bus to the network of microcontrollers.</p>
    <p>FIGS. 11A and 11B are flowcharts showing one process by which a Chassis microcontroller, shown in FIGS. 4, <b>5</b>A and <b>5</b>B, manages and diagnoses the power supply to the computer system.</p>
    <p>FIG. 12 is a flowchart showing one process by which the Chassis controller, shown in FIGS. 4, <b>5</b>A and <b>5</b>B, monitors the addition and removal of a power supply from the fault tolerant computer system.</p>
    <p>FIG. 13 is a flowchart showing one process by which the Chassis controller, shown in FIGS. 4, <b>5</b>A and <b>5</b>B, monitors temperature.</p>
    <p>FIGS. 14A and 14B are flowcharts showing one embodiment of the activities undertaken by CPU A controller, shown in FIGS. 4, <b>5</b>A and <b>5</b>B.</p>
    <p>FIG. 15 is a detailed flowchart showing one process by which the CPU A controller, show in FIGS. 4, <b>5</b>A and <b>5</b>B, monitors the fan speed for the system board of the computer.</p>
    <p>FIG. 16 is a flowchart showing one process by which activities of the CPU B controller, shown in FIGS. 4, <b>5</b>A and <b>5</b>B, scans for system faults.</p>
    <p>FIG. 17 is a flowchart showing one process by which activities of a Canister controller, shown in FIGS. 4, <b>5</b>A and <b>5</b>B, monitors the speed of the canister fan of the fault tolerant computer system.</p>
    <p>FIG. 18 is a flowchart showing one process by which activities of the System Recorder, shown in FIGS. 4, <b>5</b>A and <b>5</b>B, resets the NVRAM located on the backplane of the fault tolerant computer system.</p>
    <heading>DETAILED DESCRIPTION OF THE INVENTION</heading> <p>The following detailed description presents a description of certain specific embodiments of the present invention. However, the invention can be embodied in a multitude of different ways as defined and covered by the claims. In this description, reference is made to the drawings wherein like parts are designated with like numerals throughout.</p>
    <p>FIG. 1 is one embodiment of a block diagram showing a fault tolerant computer system of the present invention. Typically the computer system is one server in a network of servers and communicating with client computers. Such a configuration of computers is often referred to as a client-server architecture. A fault tolerant server is useful for mission critical applications such as the securities business where any computer down time can result in catastrophic financial consequences. A fault tolerant computer will allow for a fault to be isolated and not propagate through the system thus providing complete or minimal disruption to continuing operation. Fault tolerant systems also provide redundant components such as adapters so service can continue even when one component fails.</p>
    <p>The system includes a fault tolerant computer system <b>100</b> connecting to external peripheral devices through high speed I/O channels <b>102</b> and <b>104</b>. The peripheral devices communicate and are connected to the high speed I/O channels <b>102</b> and <b>104</b> by mass storage buses <b>106</b> and <b>107</b>. In different embodiments of the invention, the bus system <b>106</b>, <b>107</b> could be Peripheral Component Interconnect (PCI), Microchannel, Industrial Standard Architecture (ISA) and Extended ISA (EISA) architectures. In one embodiment of the invention, the buses <b>106</b>, <b>107</b> are PCI. Various kinds of peripheral controllers <b>108</b>, <b>112</b>, <b>116</b>, and <b>128</b>, may be connected to the buses <b>106</b> and <b>107</b> including mass storage controllers, network adapters and communications adapters. Mass storage controllers attach to data storage devices such as magnetic disk, tape, optical disk, CD-ROM. These data storage devices connect to the mass storage controllers using one of a number of industry standard interconnects, such as small computer storage interface (SCSI), IDE, EIDE, SMD. Peripheral controllers and I/O devices are generally off-the-shelf products. For instance, sample vendors for a magnetic disk controller <b>108</b> and magnetic disks <b>110</b> include Qlogic, and Quantum (respectively). Each magnetic disk may hold multiple Gigabytes of data.</p>
    <p>A client server computer system typically includes one or more network interface controllers (NICs) <b>112</b> and <b>128</b>. The network interface controllers <b>112</b> and <b>128</b> allow digital communication between the fault tolerant computer system <b>100</b> and other computers (not shown) such as a network of servers via a connection <b>130</b>. For LAN embodiments of the network adapter, the network media used may be, for example, Ethernet (IEEE 802.3), Token Ring (IEEE 802.5), Fiber Distributed Datalink Interface (FDDI) or Asynchronous Transfer Mode (ATM).</p>
    <p>In the computer system <b>100</b>, the high speed I/O channels, buses and controllers (<b>102</b>-<b>128</b>) may, for instance, be provided in pairs. In this example, if one of these should fail, another independent channel, bus or controller is available for use until the failed one is repaired.</p>
    <p>In one embodiment of the invention, a remote computer <b>132</b> is connected to the fault tolerant computer system <b>100</b>. The remote computer <b>132</b> provides some control over the fault tolerant computer system <b>100</b>, such as requesting system status.</p>
    <p>FIG. 2 shows one embodiment of the bus structure of the fault tolerant computer system <b>100</b>. A number ‘n’ of central processing units (CPUs) <b>200</b> are connected through a host bus <b>202</b> to a memory controller <b>204</b>, which allows for access to semiconductor memory by the other system components. In one embodiment of the invention, there are four CPUs <b>200</b>, each being an Intel Pentium® Pro microprocessor. A number of bridges <b>206</b>, <b>208</b> and <b>210</b> connect the host bus to three additional bus systems <b>212</b>, <b>214</b>, and <b>216</b>. These bridges correspond to high speed I/O channels <b>102</b> and <b>104</b> shown in FIG. <b>1</b>. The buses <b>212</b>, <b>214</b> and <b>216</b> correspond to the buses <b>106</b> and <b>107</b> shown in FIG. <b>1</b>. The bus systems <b>212</b>, <b>214</b> and <b>216</b>, referred to as PC buses, may be any standards-based bus system such as PCI, ISA, EISA and Microchannel. In one embodiment of the invention, the bus systems <b>212</b>, <b>214</b>, <b>216</b> are PCI. In another embodiment of the invention a proprietary bus is used.</p>
    <p>An ISA Bridge <b>218</b> is connected to the bus system <b>212</b> to support legacy devices such as a keyboard, one or more floppy disk drives and a mouse. A network of microcontrollers <b>225</b> is also interfaced to the ISA bus <b>226</b> to monitor and diagnose the environmental health of the fault tolerant system. Further discussion of the network will be provided below.</p>
    <p>A bridge <b>230</b> and a bridge <b>232</b> connects PC buses <b>214</b> and <b>216</b> with PC buses <b>234</b> and <b>236</b> to provide expansion slots for peripheral devices or adapters. Separating the devices <b>238</b> and <b>240</b> on PC buses <b>234</b> and <b>236</b> reduces the potential that a device or other transient I/O error will bring the entire system down or stop the system administrator from communicating with the system.</p>
    <p>FIG. 3 shows an alternative bus structure embodiment of the fault tolerant computer system <b>100</b>. The two PC buses <b>214</b> and <b>216</b> contain bridges <b>242</b>, <b>244</b>, <b>246</b> and <b>248</b> to PC bus systems <b>250</b>, <b>252</b>, <b>254</b>, and <b>256</b>. As with the PC buses <b>214</b> and <b>216</b>, the PC buses <b>250</b>, <b>252</b>, <b>254</b> and <b>256</b> can be designed according to any type of bus architecture including PCI, ISA, EISA, and Microchannel. The PC buses <b>250</b>, <b>252</b>, <b>254</b>, and <b>256</b> are connected, respectively, to a canister <b>258</b>, <b>260</b>, <b>262</b> and <b>264</b>. The canisters <b>258</b>, <b>260</b>, <b>262</b>, and <b>264</b> are casings for a detachable bus system and provide multiple slots for adapters. In the illustrated canister, there are four adapter slots.</p>
    <p>Referring now to FIG. 4, the present invention for monitoring and diagnosing environmental conditions may be implemented by using a network of microcontrollers <b>225</b> located on the fault tolerant computer system <b>100</b>. In one embodiment some of the microcontrollers are placed on a system board or motherboard <b>302</b> while other microcontrollers are placed on a backplane <b>304</b>. Furthermore, in the embodiment of FIG. 3, some of the microcontrollers such as Canister controller A <b>324</b> may reside on a removable canister.</p>
    <p>FIG. 4 illustrates that the network of microcontrollers <b>225</b> is connected to one of the CPUs <b>200</b> by an ISA bus <b>308</b>. The ISA <b>308</b> bus interfaces the network of microcontrollers <b>225</b> which are connected on the microcontroller bus <b>310</b> through a System Interface <b>312</b>. In one embodiment of the invention, the microcontrollers communicate through an I<sup>2</sup>C serial bus, also referred to as a microcontroller bus <b>310</b>. The document “The I<sup>2</sup>C Bus and How to Use It” (Philips Semiconductor, 1992) is hereby incorporated by reference. The I<sup>2</sup>C bus is a bi-directional two-wire bus and operates at a 400 kbps rate in the present embodiment. However, other bus structures and protocols could be employed in connection with this invention. In other embodiments, IEEE 1394 (Firewire), IEEE 422, IEEE 488 (GPIB). RS-185, Apple ADB, Universal Serial Bus (USB), or Controller Area Network (CAN) could be utilized as the microcontroller bus. Control on the microcontroller bus is distributed. Each microcontroller can be a sender (a master) or a receiver (a slave) and each is interconnected by this bus. A microcontroller directly controls its own resources, and indirectly controls resources of other microcontrollers on the bus.</p>
    <p>Here are some of the features of the I<sup>2</sup>C-bus:</p>
    <p>Only two bus line are required: a serial data line (SDA) and a serial clock line (SCL).</p>
    <p>Each device connected to the bus is software addressable by a unique address and simple master/slave relationships exist at all times; masters can operate as master-transmitters or as muter-receivers.</p>
    <p>The bus is a true multi-master bus including collision detection and arbitration to prevent data corruption if two or more masters simultaneously initiate data transfer.</p>
    <p>Serial, 8-bit oriented, bi-directional data transfers can be made at up to 400 kbit/second in the fast mode.</p>
    <p>Two wires, serial data (SDA) and serial clock (SCL), carry information between the devices connected to the I<sup>2</sup>C bus. Each device is recognized by a unique address and can operate as either a transmitter or receiver, depending on the function of the device. Further, each device can operate from time to time as both a transmitter and a receiver. For example, a memory device connected to the I<sup>2</sup>C bus could both receive and transmit data. In addition to transmitters and receivers, devices can also be considered as masters or slaves when performing data transfers (see Table 1). A master is the device which initiates a data transfer on the bus and generates the clock signals to permit that transfer. At that time, any device addressed is considered a slave.</p>
    <p>
      <tables> <table frame="none" colsep="0" rowsep="0" class="description-table"> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="center" colwidth="217PT"> </colspec> <thead valign="bottom"> <tr class="description-tr"> <td namest="1" nameend="1" morerows="0" rowsep="1" valign="top" class="description-td" colspan="1">TABLE 1</td>
              </tr> </thead> <tbody valign="top"> <tr class="description-tr"> <td namest="1" nameend="1" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="1"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Definition of I<sup>2</sup>C-bus terminology</td>
              </tr> </tbody> </tgroup> <tgroup cols="2" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="56PT"> </colspec> <colspec colname="2" align="left" colwidth="161PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Term</td>
                <td morerows="0" valign="top" class="description-td">Description</td>
              </tr> <tr class="description-tr"> <td namest="1" nameend="2" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="2"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Transmitter</td>
                <td morerows="0" valign="top" class="description-td">The device which sends the data to the bus</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Receiver</td>
                <td morerows="0" valign="top" class="description-td">The device which receives the data from the bus</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Master</td>
                <td morerows="0" valign="top" class="description-td">The device which initiates a transfer, generates clock</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">signals and terminates a transfer</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Slave</td>
                <td morerows="0" valign="top" class="description-td">The device addressed by a master</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Multi-master</td>
                <td morerows="0" valign="top" class="description-td">More than one master can attempt to control the bus at</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">the same time without corrupting the message. Each</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">device at separate times may act as a master.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Arbitration</td>
                <td morerows="0" valign="top" class="description-td">Procedure to ensure that, if more than one master</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">simultaneously tries to control the bus, only one is</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">allowed to do so and the message is not corrupted</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Synchronization</td>
                <td morerows="0" valign="top" class="description-td">Procedure to synchronize the clock signal of two or</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">more devices</td>
              </tr> <tr class="description-tr"> <td namest="1" nameend="2" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="2"> </td>
              </tr> </tbody> </tgroup> </table> </tables> </p>
    <p>The I<sup>2</sup>C-bus is a multi-master bus. This means that more than one device capable of controlling the bus can be connected to it. As masters are usually microcontrollers, consider the case of a data transfer between two microcontrollers connected to the I<sup>2</sup>C-bus. This highlights the master-slave and receiver-transmitter relationships to be found on the I<sup>2</sup>C-bus. It should be noted that these relationships are not permanent, but only depend on the direction of data transfer at that time. The transfer of data between microcontrollers is further described in FIG. <b>8</b>.</p>
    <p>The possibility of connecting more than one microcontroller to the I<sup>2</sup>C-bus means that more than one master could try to initiate a data transfer at the same time. To avoid the conflict that might ensue from such an event, an arbitration procedure has been developed. This procedure relies on the wired-AND connection of all I<sup>2</sup>C interfaces to the I<sup>2</sup>C-bus.</p>
    <p>If two or more masters try to put information onto the bus, as long as they put the same information onto the bus, there is no problem. Each monitors the state of the SDL. If a microcontroller expects to find that the SDL is high, but finds that it is low, the microcontroller assumes it lost the arbitration and stops sending data. The clock signals during arbitration are a synchronized combination of the clocks generated by the masters the wired-AND connection to the SCL line.</p>
    <p>Generation of clock signal on the I<sup>2</sup>C-bus is always the responsibility of master devices. Each master microcontroller generates its own clock signals when transferring data on the bus.</p>
    <p>In one embodiment, the command, diagnostic, monitoring and history functions of the microcontroller network <b>102</b> are accessed using a global network memory and a protocol has been defined so that applications can access system resources without intimate knowledge of the underlying network of microcontrollers. That is, any function may be queried simply by generating a network “read” request targeted at the function's known global network address. In the same fashion, a function may be exercised simply by “writing” to its global network address. Any microcontroller may initiate read/write activity by sending a message on the I<sup>2</sup>C bus to the microcontroller responsible for the function (which can be determined from the known global address of the function). The network memory model includes typing information as part of the memory addressing information.</p>
    <p>Referring to FIG. 4, in one embodiment of the invention, the network of microcontrollers <b>310</b> includes ten processors. One of the purposes of the microcontroller network <b>225</b> is to transfer messages to the other components of the server system <b>100</b>. The processors or microcontrollers include: a System Interface <b>312</b>, a CPU A controller <b>314</b>, a CPU B controller <b>316</b>, a System Recorder <b>320</b>, a Chassis controller <b>318</b>, a Canister A controller <b>324</b>, a Canister B controller <b>326</b>, a Canister C controller <b>328</b>, a Canister D controller <b>330</b> and a Remote Interface controller <b>332</b>. The System Interface controller <b>312</b>, the CPU A controller <b>314</b> and the CPU B controller <b>316</b> are located on a system board <b>302</b> in the fault tolerant computer system <b>100</b>. Also located on the system board are one or more central processing units (CPUs) or microprocessors <b>200</b> and the Industry Standard Architecture (ISA) bus <b>226</b> that connects to the System Interface Controller <b>312</b>. The CPUs <b>200</b> may be any conventional general purpose single-chip or multi-chip microprocessor such as a Pentium 7, Pentium® Pro or Pentium® II processor available from Intel Corporation, A MIPS® processor available from Silicon Graphics, Inc., a SPARC processor from Sun Microsystems, Inc., a Power PC® processor available from Motorola, or an ALPHA® processor available from Digital Equipment Corporation. In addition, the CPUs <b>200</b> may be any conventional special purpose microprocessor such as a digital signal processor or a graphics processor.</p>
    <p>The System Recorder <b>320</b> and Chassis controller <b>318</b>, along with a data string such as a random access non-volatile access memory (NVRAM) <b>322</b> that connects to the System Recorder <b>320</b>, are located on a backplane <b>304</b> of the fault tolerant computer system <b>100</b>. The data storage <b>322</b> may be independently powered and may retain its contents when power is unavailable. The data storage <b>322</b> is used to log system status, so that when a failure of the computer <b>100</b> occurs, maintenance personnel can access the storage <b>322</b> and search for information about what component failed. An NVRAM is used for the data storage <b>322</b> in one embodiment but other embodiments may use other types and sizes of storage devices.</p>
    <p>The System Recorder <b>320</b> and Chassis controller <b>318</b> are the first microcontrollers to power up when server power is applied. The System Recorder <b>320</b>, the Chassis controller <b>318</b> and the Remote Interface microcontroller <b>332</b> are the three microcontrollers that have an independent bias 5 Volt power supplied to them if main server power is off. This independent bias 5 Volt power is provided by a Remote Interface Board (not shown). The Canister controllers <b>324</b>-<b>330</b> are not considered to be part of the backplane <b>304</b> because each is mounted on a card attached to the canister.</p>
    <p>FIGS. 5A and 5B are one embodiment of a block diagram that illustrates some of the signal lines that are used by the different microcontrollers. Some of the signal lines connect to actuators and other signal lines connect to sensors. In one embodiment of the invention the microcontrollers in the network are commercially available microcontrollers. Examples of off-the-shelf microcontrollers are the PIC16c65 and the PIC16c74 available from Microchip Technology Inc, the 8051 from Intel Corporation, the 8751 available from Atmel, and a P80CL580 microprocessor available from Philips, could be utilized.</p>
    <p>The Chassis controller <b>318</b> is connected to a set of temperature detectors <b>502</b>, <b>504</b>, and <b>506</b> which read the temperature on the backplane <b>304</b> and the system board <b>302</b>. FIG. 5 also illustrates the signal lines that connect the System Recorder <b>320</b> to the NVRAM <b>322</b> and a timer chip <b>520</b>. In one embodiment of the invention, the System Recorder <b>320</b> is the only microcontroller that can access the NVRAM <b>322</b>. The Canister controller <b>324</b> is connected to a Fan Tachometer Signal Mux <b>508</b> which is used to detect the speed of the fans. The CPU A controller <b>314</b> also is connected to a fan mux <b>310</b> which gathers the fan speed of system fans. The CPU A controller <b>314</b> displays errors to a user by writing to an LCD display <b>512</b>. Any microcontroller can request the CPU A controller <b>314</b> to write a message to the LCD display <b>512</b>. The System Interface <b>312</b> is connected to a response buffer <b>514</b> which queues outgoing response signals in the order that they are received. Similarly, a request signal buffer <b>516</b> is connected to the System Interface <b>312</b> and stores, or queues request signals in the order that they are received.</p>
    <p>Software applications can access the network of microcontrollers <b>225</b> by using the software program header file that is listed at the end of the specification in the section titled “Header File for Global Memory Addresses.” This header file provides a global memory address for each function of the microcontroller network <b>225</b>. By using the definitions provided by this header file, applications can request and send information to the microcontroller network <b>225</b> without needing to know where a particular sensor or activator resides in the microcontroller network.</p>
    <p>FIG. 6 is one embodiment of a flowchart illustrating the process by which under one implementation of the present invention, a remote application connected, say, through the connection of FIG. 1, can access the network of microcontrollers <b>225</b>. Starting at state <b>600</b>, a remote software application, such as a generic system management application like Hewlett-Packard Open View, or an application specific to this computer system, retrieves a management information block (MIB) object by reading and interpreting a MIB file, or by an application's implicit knowledge of the MIB object's structure. This retrieval could be the result of an operator using a graphical user interface (GUI), or as the result of some automatic system management process. The MIB is a description of objects, which have a standard structure, and contain information specific to the MIB object ID associated with a particular MIB object. At a block <b>602</b>, the remote application builds a request for information by creating a request which references a particular MIB object by its object ID, sends the request to the target computer using a protocol called SNMP (simple network management protocol). SNMP is a type of TCP/IP protocol. Moving to state <b>604</b>, the remote software sends the SNMP packet to a local agent Microsoft WinSNMP, for example, which is running on the fault tolerant computer system <b>100</b>, which includes the network of microcontrollers <b>225</b> (FIG. <b>4</b>). The agent is a specialized program which can interpret MIB object IDs and objects. The local agent software runs on one of the CPUs <b>200</b> of FIGS. 2 and 3.</p>
    <p>The local agent examines the SNMP request packet (state <b>606</b>). If the local agent does not recognize the request, the local agent passes the SNMP packet to an extension SNMP agent. Proceeding to state <b>608</b>, the extension SNMP agent dissects the object ID. The extension SNMP agent is coded to recognize from the object ID, which memory mapped resources managed by the network of microcontrollers need to be accessed (state <b>608</b>). The agent then builds the required requests for the memory mapped information in the command protocol format understood by the network of microcontrollers <b>225</b>. The agent then forwards the request to a microcontroller network device driver (state <b>610</b>).</p>
    <p>The device driver then sends the information to the network of microcontrollers <b>225</b> at state <b>612</b>. The network of microcontrollers <b>225</b> provides a result to the device driver in state <b>614</b>. The result is returned to the extension agent, which uses the information to build the MIB object, and return it to the SNMNP agent (state <b>616</b>). The local SNMP agent forwards the MIB object via SNMFP to the remote agent (state <b>616</b>). Finally, in state <b>620</b>, the remote agent forwards the result to the remote application software.</p>
    <p>For example, if a remote application needs to know the speed of a fan, the remote application reads a file to find the object ID for fan speed. The object ID for the fan speed request may be “837.2.3.6.2”. Each set of numbers in the object ID represent hierarchical groups of data. For example the number “3” of the object ID represents the cooling system. The “3.6” portion of the object ID represents the fans in the cooling. All three numbers “3.6.2” indicate speed for a particular fan in a particular cooling group.</p>
    <p>In this example, the remote application creates a SNMP packet containing the object ID to get the fan speed on the computer <b>100</b>. The remote application then sends the SNMP packet to the local agent. Since the local agent does not recognize the fan speed object ID, the local agent forwards the SNMP packet to the extension agent. The extension agent parses the object ID to identify which specific memory mapped resources of the network of microcontrollers <b>225</b> are needed to build the MIB object whose object ID was just parsed. The extension agent then creates a message in the command protocol required by the network of microcontrollers <b>225</b>. A device driver which knows how to communicate requests to the network of microcontrollers <b>225</b> takes this message and relays the command to the network of microcontrollers <b>225</b>. Once the network of microcontrollers <b>225</b> finds the fan speed, it relays the results to the device driver. The device driver passes the information to the extension agent. The agent takes the information supplied by the microcontroller network device driver and creates a new SNMP packet. The local agent forwards this packet to the remote agent, which then relays the fan speed which is contained in the packet to the remote application program.</p>
    <p>FIG. 7 is one embodiment of a block diagram of the interface between the network of microcontrollers <b>225</b> and the ISA bus <b>226</b> of FIGS. 2 and 3. The interface to the network of microcontrollers <b>225</b> includes a System Interface processor <b>312</b> which receives event and request signals, processes these signals, and transmits command, status and response signals to the operating system of the CPUs <b>200</b>. In one embodiment, the System Interface processor <b>312</b> is a PIC16C65 controller chip, available from Microchip, Technology Inc., which includes an event memory (not shown) organized as a bit vector, having at least sixteen bits. Each bit in the bit vector represents a particular type of event. Writing an event to the System Interface processor <b>312</b> sets a bit in the bit vector that represents the event. Upon receiving an event signal from another microcontroller, the System Interface <b>312</b> interrupts CPUs <b>200</b>. Upon receiving the interrupt, the CPUs <b>200</b> will check the status of the System Interface <b>312</b> to ascertain that an event is pending. Alternatively, the CPUs <b>200</b> may periodically poll the status of the System Interface <b>312</b> to ascertain whether an event is pending. The CPUs <b>200</b> may then read the bit vector in the System Interface <b>312</b> to ascertain the type of event that occurred and thereafter notify a system operator of the event by displaying an event message on a monitor connected to the fault tolerant computer <b>100</b> or another computer in the server network. After the system operator has been notified of the event, as described above, she may then obtain further information about the system failure which generated the event signal by accessing the NVRAM <b>322</b>.</p>
    <p>The System Interface <b>312</b> communicates with the CPUs <b>200</b> by receiving request signals from the CPUs <b>200</b> and sending response signals back to the CPUs <b>200</b>. Furthermore, the System Interface <b>312</b> can send and receive status and command signals to and from the CPUs <b>200</b>. For example, a request signal may be sent from a software application inquiring as to whether the System Interface <b>312</b> has received any event signals, or inquiring as to the status of a particular processor, subsystem, operating parameter. The following discussion explains how in further detail at the state <b>612</b>, the device driver sends the request to the network of microcontrollers, and then, how the network of microcontrollers returns the result (state <b>614</b>). A request signal buffer <b>516</b> is connected to the System Interface <b>312</b> and stores, or queues, request signals in the order that they are received, first in-first out (FIFO). Similarly, a response buffer <b>514</b> is connected to the System Interface <b>312</b> and queues outgoing response signals in the order that they are received (FIFO). These queues are one byte wide, (messages on the I<sup>2</sup>C bus are sequences of 8-bit bytes, transmitted bit serially on the SDL).</p>
    <p>A message data register (MDR) <b>707</b> is connected to the request and response buffers <b>516</b> and <b>514</b> and controls the arbitration of messages to and from the System Interface <b>312</b> via the request and response buffers <b>516</b> and <b>514</b>. In one embodiment, the MDR <b>707</b> is eight bits wide and has a fixed address which may be accessed by the server's operating system via the ISA bus <b>226</b> connected to the MDR <b>707</b>. As shown in FIG. 7, the MDR <b>707</b> has an I/O address of 0CC0h. When software application running on one of the CPUs <b>200</b> desires to send a request signal to the System Interface <b>312</b>, it does so by writing a message one byte at a time to the MDR <b>707</b>. The application then indicates to the system interface processor <b>312</b> that the command has been completely written, and may be processed.</p>
    <p>The system interface processor <b>312</b> writes the response one byte at a time to the response queue, then indicates to the CPU (via an interrupt or a bit in the status register) that the response is complete, and ready to be read. The CPU <b>200</b> then reads the response queue one byte at a time by reading the MDR <b>707</b> until all bytes of the response are read.</p>
    <p>The following is one embodiment of the command protocol used to communicate with the network of microcontrollers <b>225</b>.</p>
    <p>
      <tables> <table frame="none" colsep="0" rowsep="0" class="description-table"> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="center" colwidth="217PT"> </colspec> <thead valign="bottom"> <tr class="description-tr"> <td namest="1" nameend="1" morerows="0" rowsep="1" valign="top" class="description-td" colspan="1">TABLE 2</td>
              </tr> <tr class="description-tr"> <td namest="1" nameend="1" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="1"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Command Protocol Format</td>
              </tr> <tr class="description-tr"> <td namest="1" nameend="1" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="1"> </td>
              </tr> </thead> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">READ REQUEST FORMAT</td>
              </tr> </tbody> </tgroup> <tgroup cols="4" colsep="0" rowsep="0" align="left"> <colspec colname="OFFSET" align="left" colwidth="35PT"> </colspec> <colspec colname="1" align="left" colwidth="56PT"> </colspec> <colspec colname="2" align="left" colwidth="70PT"> </colspec> <colspec colname="3" align="left" colwidth="56PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Offset</td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 0</td>
                <td morerows="0" valign="top" class="description-td">Slave</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Addr</td>
                <td morerows="0" valign="top" class="description-td">0</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">(7 bits)</td>
                <td morerows="0" valign="top" class="description-td">LSBit</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 1</td>
                <td morerows="0" valign="top" class="description-td">MSBit (1)</td>
                <td morerows="0" valign="top" class="description-td">Type</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="OFFSET" align="left" colwidth="35PT"> </colspec> <colspec colname="1" align="left" colwidth="56PT"> </colspec> <colspec colname="2" align="center" colwidth="126PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 2</td>
                <td morerows="0" valign="top" class="description-td">Command ID (LSB)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 3</td>
                <td morerows="0" valign="top" class="description-td">Command ID (MSB)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 4</td>
                <td morerows="0" valign="top" class="description-td">Read Request Length</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 5</td>
                <td morerows="0" valign="top" class="description-td">Check Sum</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="center" colwidth="217PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">READ RESPONSE FORMAT</td>
              </tr> </tbody> </tgroup> <tgroup cols="4" colsep="0" rowsep="0" align="left"> <colspec colname="OFFSET" align="left" colwidth="35PT"> </colspec> <colspec colname="1" align="left" colwidth="56PT"> </colspec> <colspec colname="2" align="left" colwidth="70PT"> </colspec> <colspec colname="3" align="left" colwidth="56PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Offset</td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 0</td>
                <td morerows="0" valign="top" class="description-td">Slave Addr</td>
                <td morerows="0" valign="top" class="description-td">1</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">(7 bits)</td>
                <td morerows="0" valign="top" class="description-td">LSBit</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="OFFSET" align="left" colwidth="35PT"> </colspec> <colspec colname="1" align="left" colwidth="56PT"> </colspec> <colspec colname="2" align="center" colwidth="126PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 1</td>
                <td morerows="0" valign="top" class="description-td">Read Response</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Length (N)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 2</td>
                <td morerows="0" valign="top" class="description-td">Data Byte 1</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">.</td>
                <td morerows="0" valign="top" class="description-td">.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">.</td>
                <td morerows="0" valign="top" class="description-td">.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">.</td>
                <td morerows="0" valign="top" class="description-td">.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte</td>
                <td morerows="0" valign="top" class="description-td">Data Byte N</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">N + 1</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte</td>
                <td morerows="0" valign="top" class="description-td">Status</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">N + 2</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte</td>
                <td morerows="0" valign="top" class="description-td">Check Sum</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">N + 3</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte</td>
                <td morerows="0" valign="top" class="description-td">Inverted Slave Addr</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">N + 4</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="center" colwidth="217PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">WRITE REQUEST FORMAT</td>
              </tr> </tbody> </tgroup> <tgroup cols="4" colsep="0" rowsep="0" align="left"> <colspec colname="OFFSET" align="left" colwidth="35PT"> </colspec> <colspec colname="1" align="left" colwidth="56PT"> </colspec> <colspec colname="2" align="left" colwidth="70PT"> </colspec> <colspec colname="3" align="left" colwidth="56PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Offset</td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 0</td>
                <td morerows="0" valign="top" class="description-td">Slave</td>
                <td morerows="0" valign="top" class="description-td">0</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Addr</td>
                <td morerows="0" valign="top" class="description-td">LSBit</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">(7 bits)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 1</td>
                <td morerows="0" valign="top" class="description-td">MSBit (0)</td>
                <td morerows="0" valign="top" class="description-td">Type</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="OFFSET" align="left" colwidth="35PT"> </colspec> <colspec colname="1" align="left" colwidth="56PT"> </colspec> <colspec colname="2" align="center" colwidth="126PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 2</td>
                <td morerows="0" valign="top" class="description-td">Command ID (LSB)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 3</td>
                <td morerows="0" valign="top" class="description-td">Command ID (MSB)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 4</td>
                <td morerows="0" valign="top" class="description-td">Write Request Length</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">(N)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 5</td>
                <td morerows="0" valign="top" class="description-td">Data Byte 1</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">.</td>
                <td morerows="0" valign="top" class="description-td">.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">.</td>
                <td morerows="0" valign="top" class="description-td">.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">.</td>
                <td morerows="0" valign="top" class="description-td">.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte N + 4</td>
                <td morerows="0" valign="top" class="description-td">Data Byte N</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte N + 5</td>
                <td morerows="0" valign="top" class="description-td">Check Sum</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="center" colwidth="217PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">WRITE RESPONSE FORMAT</td>
              </tr> </tbody> </tgroup> <tgroup cols="4" colsep="0" rowsep="0" align="left"> <colspec colname="OFFSET" align="left" colwidth="35PT"> </colspec> <colspec colname="1" align="left" colwidth="56PT"> </colspec> <colspec colname="2" align="left" colwidth="70PT"> </colspec> <colspec colname="3" align="left" colwidth="56PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Offset</td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 0</td>
                <td morerows="0" valign="top" class="description-td">Slave</td>
                <td morerows="0" valign="top" class="description-td">1</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Addr</td>
                <td morerows="0" valign="top" class="description-td">LSBit</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">(7 bits)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 1</td>
                <td morerows="0" valign="top" class="description-td">Write</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Response</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Length (0)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 2</td>
                <td morerows="0" valign="top" class="description-td">Status</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 3</td>
                <td morerows="0" valign="top" class="description-td">Check Sum</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Byte 4</td>
                <td morerows="0" valign="top" class="description-td">Inverted Slave Addr</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td namest="OFFSET" nameend="3" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="4"> </td>
              </tr> </tbody> </tgroup> </table> </tables> </p>
    <p>The following is a description of each of the fields in the command protocol.</p>
    <p>
      <tables> <table frame="none" colsep="0" rowsep="0" pgwide="1" class="description-table"> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="center" colwidth="273PT"> </colspec> <thead valign="bottom"> <tr class="description-tr"> <td namest="1" nameend="1" morerows="0" rowsep="1" valign="top" class="description-td" colspan="1">TABLE 3</td>
              </tr> </thead> <tbody valign="top"> <tr class="description-tr"> <td namest="1" nameend="1" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="1"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Description of Command Protocol Fields</td>
              </tr> </tbody> </tgroup> <tgroup cols="2" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="91PT"> </colspec> <colspec colname="2" align="left" colwidth="182PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">FIELD</td>
                <td morerows="0" valign="top" class="description-td">DESCRIPTION</td>
              </tr> <tr class="description-tr"> <td namest="1" nameend="2" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="2"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Slave Addr</td>
                <td morerows="0" valign="top" class="description-td">Specifies the processor identification code. This field is</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">7 bits wide. Bit [7 . . . 1].</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">LSBit</td>
                <td morerows="0" valign="top" class="description-td">Specifies what type of activity is taking place. If LSBit</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">is clear (0), the master is writing to a slave. If LSBit is</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">set (1), the master is reading from a slave.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">MSBit</td>
                <td morerows="0" valign="top" class="description-td">Specifies the type of command. It is bit 7 of byte 1 of</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">a request. If this bit is clear (0), this is a write</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">command. If it is set (1), this is a read command.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Type</td>
                <td morerows="0" valign="top" class="description-td">Specifies the data type of this command, such as bit or</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">string.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Command ID (LSB)</td>
                <td morerows="0" valign="top" class="description-td">Specifies the least significant byte of the address of the</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">processor.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Command ID (MSB)</td>
                <td morerows="0" valign="top" class="description-td">Specifies the most significant byte of the address of the</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">processor.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Length (N)</td>
                <td morerows="0" valign="top" class="description-td">Specifies the length of the data that the master expects to</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Read Request</td>
                <td morerows="0" valign="top" class="description-td">get back from a read response. The length, which is in</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">bytes, does not include the Status, Check Sum, and</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Inverted Slave Addr fields.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Read Response</td>
                <td morerows="0" valign="top" class="description-td">Specifies the length of the data immediately following</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">this byte, that is byte 2 through byte N + 1. The length,</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">which is in bytes, does not include the Status, Check</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Sum, and Inverted Slave Addr fields.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Write Request</td>
                <td morerows="0" valign="top" class="description-td">Specifies the length of the data immediately following</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">this byte, that is byte 2 through byte N + 1. The length,</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">which is in bytes, does not include the Status, Check</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Sum, and Inverted Slave Addr fields.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Write Response</td>
                <td morerows="0" valign="top" class="description-td">Always specified as 0.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Data Byte 1</td>
                <td morerows="0" valign="top" class="description-td">Specifies the data in a read request and response, and a</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">write request.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Data Byte N</td>
                <td morerows="0" valign="top" class="description-td">Specifies whether or not this command executes</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Status</td>
                <td morerows="0" valign="top" class="description-td">successfully. A non-zero entry indicates a failure.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Check Sum</td>
                <td morerows="0" valign="top" class="description-td">Specifies a direction control byte to ensure the integrity</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">of a message on the wire.</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Inverted Slave Addr</td>
                <td morerows="0" valign="top" class="description-td">Specifies the Slave Addr, which is inverted.</td>
              </tr> <tr class="description-tr"> <td namest="1" nameend="2" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="2"> </td>
              </tr> </tbody> </tgroup> </table> </tables> </p>
    <p>The System Interface <b>312</b> further includes a command and status register (CSR) <b>709</b> which initiates operations and reports on status. The operation and functionality of CSR <b>709</b> is described in further detail below. Both synchronous and asynchronous I/O modes are provided by the System Interface <b>312</b>. During a synchronous mode of operation, the device driver waits for a request to be completed. During an asynchronous mode of operation the device driver sends the request, and asks to be interrupted when the request completes. To support asynchronous operations, an interrupt line <b>711</b> is connected between the System Interface <b>312</b> and the ISA bus <b>226</b> and provides the ability to request an interrupt when asynchronous I/O is complete, or when an event occurs while the interrupt is enabled. As shown in FIG. 7, in one embodiment, the address of the interrupt line <b>711</b> is fixed and indicated as IRQ <b>15</b> which is an interrupt address number used specifically for the ISA bus <b>226</b>.</p>
    <p>The MDR <b>707</b> and the request and response buffers <b>516</b> and <b>514</b>, respectively, transfer messages between a software application running on the CPUs <b>200</b> and the failure reporting system of the invention. The buffers <b>516</b> and <b>514</b> have two functions: (1) they store data in situations where one bus is running faster than the other, i.e., the different clock rates, between the ISA bus <b>226</b> and the microcontroller bus <b>310</b>; and (2) they serve as interim buffers for the transfer of messages—this relieves the System Interface <b>312</b> of having to provide this buffer.</p>
    <p>When the MDR <b>707</b> is written to by the ISA bus <b>226</b>, it loads a byte into the request buffer <b>226</b>. When the MDR <b>707</b> is read from the ISA bus <b>516</b>, it unloads a byte from the response buffer <b>514</b>. The System Interface <b>312</b> reads and executes messages from buffer <b>516</b> when a message command is received in the CSR <b>709</b>. A response message is written to the response buffer <b>514</b> when the System Interface <b>312</b> completes executing the command. The system operator receives a completed message over the microcontroller bus <b>310</b>. A software application can read and write message data to and from the buffers <b>516</b> and <b>514</b> by executing read and write instructions through the MDR <b>707</b>.</p>
    <p>The CSR <b>709</b> has two functions. The first is to initiate commands, and the second is to report status. The System Interface commands are usually executed synchronously. That is, after issuing a command, the microcontroller network device driver should continue to poll the CSR <b>709</b> status to confirm command completion. In addition to synchronous I/O mode, the microcontroller network device driver can also request an asynchronous I/O mode for each command by setting a “Asyn Req” bit in the command. In this mode, an interrupt is generated and sent to the ISA bus <b>226</b>, via the interrupt line <b>711</b>, after the command has completed executing.</p>
    <p>In the described embodiment, the interrupt is asserted through IRQ<b>15</b> of the ISA programmable interrupt controller (PIC). The ISA PIC interrupts the CPU <b>200</b>s when a signal transitioning from high to low, or from low to high, is detected at the proper input pin (edge triggered). Alternatively, the interrupt line <b>711</b> may utilize connect to a level-triggered input. A level-triggered interrupt request is recognized by keeping the signal at the same level, or changing the level of a signal, to send an interrupt. The microcontroller network device driver can either enable or disable interrupts by sending “Enable Ints” and “Disable Ints” commands to the CSR <b>719</b>. If the interrupt <b>711</b> line is enabled, the System Interface <b>312</b> asserts the interrupt signal IRQ<b>15</b> of the PIC to the ISA bus <b>226</b>, either when an asynchronous I/O is complete or when an event has been detected.</p>
    <p>In the embodiment shown in FIG. 2, the System Interface <b>312</b> may be a single-threaded interface. Since messages are first stored in the queue, then retrieved from the queue by the other side of the interface, a device driver should write one message, containing a sequence of bytes, at a time. Thus, only one message should be in progress at a time using the System Interface <b>312</b>. Therefore, a program or application must allocate the System Interface <b>312</b> for its use before using it, and then de-allocate the interface <b>514</b> when its operation is complete. The CSR <b>709</b> indicates which operator is allocated access to the System Interface <b>312</b>.</p>
    <p>Referring to FIGS. 3 and 7, an example of how messages are communicated between the System Interface <b>312</b> and CPUs <b>200</b> in one embodiment of the invention is as follows (all byte values are provided in hexadecimal numbering). A system management program (not shown) sends a command to the network of microcontrollers <b>225</b> to check temperature and fan speed. To read the temperature from CPU A controller <b>314</b> the program builds a message for the device driver to forward to the network of microcontrollers <b>225</b>. First, the device driver on CPUs <b>200</b> allocates the interface by writing the byte “01” to the CSR <b>709</b>. If another request was received, the requester would have to wait until the previous request was completed. To read the temperature from Chassis controller <b>318</b> the device driver would write into the request queue <b>516</b> through the MDR <b>707</b> the bytes “02 83 03 00 FF”. The first byte “02” would signify to the System Interface <b>312</b> that a command is intended for the Chassis controller <b>318</b>. The first bits of the second byte “83” indicates that a master is writing to a slave. The last or least significant three bits of the byte “83” indicate the data type of the request. The third and fourth bytes “03 00” indicate that the read request temperature function of the Chassis controller <b>318</b> is being requested. The final byte “FF” is the checksum.</p>
    <p>After writing the bytes to the MDR <b>707</b>, a “13” (message command) is written by the device driver to the CSR <b>709</b>, indicating the command is ready to be executed. The System Interface processor <b>312</b> passes the message bytes to the microcontroller bus <b>310</b>, receives a response, and puts the bytes into the response FIFO <b>514</b>. Since there is only one system interface processor <b>312</b>, there is no chance that message bytes will get intermingled.</p>
    <p>After all bytes are written to the response FIFO, the System Interface processor <b>312</b> sets a bit in the CSR <b>709</b> indicating message completion. If directed to do so by the device driver, the system interface <b>312</b> asserts an interrupt on IRQ <b>15</b> upon completion of the task.</p>
    <p>The CPUs <b>200</b> would then read from the response buffer <b>516</b> through the MDR <b>707</b> the bytes “02 05 27 3C 27 26 27 00”. The first byte in the string is the slave address shown as Byte <b>0</b> in the Read Response Format. The first byte <b>02</b> indicates that the CPU A Chassis controller <b>318</b> was the originator of the message. The second byte “05” indicates the number of temperature readings that follow. The second Byte “05” maps to Byte <b>1</b> of the Read Response Format. In this example, the Chassis controller <b>318</b> returned five temperatures. The second reading, byte “3C” (60 decimal) is above normal operational values. The last byte “00” is a check sum which is used to ensure the integrity of a message.</p>
    <p>The CPUs <b>200</b> agent and device driver requests the fan speed by writing the bytes “03 83 04 00 FF” to the network of microcontroller <b>225</b>. Each byte follows the read request format specified in Table 2. The first byte “03” indicates that the command is for the CPU A Controller <b>314</b>. The second byte “83” indicates that the command is a read request of a string data type.</p>
    <p>A response of “03 06 41 43 41 42 41 40 00” would be read from MDR <b>707</b> by the device driver. The first byte “03” indicates to the device driver that the command is from the CPU A controller <b>314</b>. The speed bytes “41 43 41 42 41 40” indicate the revolutions per second of a fan in hexadecimal. The last byte read from the MDR <b>707</b> “00” is the checksum.</p>
    <p>Since one of the temperatures is higher than the warning threshold, 55° C., and fan speed is within normal (low) range, a system administrator or system management software may set the fan speed to high with the command bytes “03 01 01 00 01 01 FF”. The command byte “03” indicates that the command is for the CPU A <b>314</b>. The first byte indicates that a write command is requested. The third and fourth bytes, which correspond to byte <b>2</b> and <b>3</b> of the write request format, indicate a request to increase the fan speed. The fifth byte, which corresponds to byte <b>4</b> of the write request format indicates to the System Interface <b>312</b> that one byte is being sent. The sixth byte contains the data that is being sent. The last byte “FF” is the checksum.</p>
    <p>FIG. 8 is one embodiment of a flowchart describing the process by which a master microcontroller communicates with a slave microcontroller. Messages between microcontrollers can be initiated by any microcontroller on the microcontroller bus <b>310</b> (FIG. <b>4</b>). A master microcontroller starts out in state <b>800</b>.</p>
    <p>In state <b>802</b>, the microcontroller arbitrates for the start bit. If a microcontroller sees a start bit on the microcontroller bus <b>310</b>, it cannot gain control of the microcontroller bus <b>310</b>. The master microcontroller proceeds to state <b>804</b>. In the state <b>804</b>, the microcontroller increments a counter every millisecond. The microcontroller then returns to state <b>800</b> to arbitrate again for the start bit. If at state <b>806</b> the count reaches 50 ms, the master has failed to gain the bus (states <b>808</b> and <b>810</b>). The microcontroller then returns to the state <b>800</b> to retry the arbitration process.</p>
    <p>If in the state <b>802</b>, no start bit is seen on the microcontroller bus <b>310</b>, the microcontroller bus <b>310</b> is assumed to be free (i.e., the microcontroller has successfully arbitrated won arbitration for the microcontroller bus <b>310</b>). The microcontroller sends a byte at a time on the microcontroller bus <b>310</b> (state <b>812</b>). After the microcontroller has sent each byte, the microcontroller queries the microcontroller bus <b>310</b> to insure that the microcontroller bus <b>310</b> is still functional. If the SDA and SCL lines of the microcontroller bus <b>310</b> are not low, the microcontroller is sure that the microcontroller bus <b>310</b> is functional and proceeds to state <b>816</b>. If the SDA and SCL lines are not drawn high, then the microcontroller starts to poll the microcontroller bus <b>310</b> to see if it is functional. Moving to state <b>819</b>, the microcontroller increments a counter Y and waits every 22 microseconds. If the counter Y is less than five milliseconds (state <b>820</b>), the state <b>814</b> is reentered and the microcontroller bus <b>310</b> is checked again. If the SDA and SCL lines are low for 5 milliseconds (indicated when, at state <b>820</b>, the counter Y exceeds 5 milliseconds), the microcontroller enters state <b>822</b> and assumes there is a microcontroller bus error. The microcontroller then terminates its control of the microcontroller bus <b>310</b> (state <b>824</b>).</p>
    <p>If in the state <b>814</b>, the SDA/SCL lines do not stay low (state <b>816</b>), the master microcontroller waits for a response from a slave microcontroller (state <b>816</b>). If the master microcontroller has not received a response, the microcontroller enters state <b>826</b>. The microcontroller starts a counter which is incremented every one millisecond. Moving to state <b>828</b>, if the counter reaches fifty milliseconds, the microcontroller enters state <b>830</b> indicating a microcontroller bus error. The microcontroller then resets the microcontroller bus <b>310</b> (state <b>832</b>).</p>
    <p>Returning to state <b>816</b>, if the master microcontroller does receive a response in state <b>816</b>, the microcontroller enters state <b>818</b> and receives the data from the slave microcontroller. At state <b>820</b>, the master microcontroller is finished communicating with the slave microcontroller.</p>
    <p>FIG. 9 is one embodiment of a block diagram illustrating the process by which a slave microcontroller communicates with a master microcontroller. Starting in state <b>900</b>, the slave microcontroller receives a byte from a master microcontroller. The first byte of an incoming message always contains the slave address. This slave address is checked by all of the microcontrollers on the microcontroller bus <b>310</b>. Whichever microcontroller matches the slave address to its own address handles the request.</p>
    <p>At a decision state <b>902</b>, an interrupt is generated on the slave microcontroller. The microcontroller checks if the byte received is the first received from the master microcontroller (state <b>904</b>). If the current byte received is the first byte received, the slave microcontroller sets a bus time-out flag (state <b>906</b>). Otherwise, the slave microcontroller proceeds to check if the message is complete (state <b>908</b>). If the message is incomplete, the microcontroller proceeds to the state <b>900</b> to receive the remainder of bytes from the master microcontroller. If at state <b>908</b>, the slave microcontroller determines that the complete message has been received, the microcontroller proceeds to state <b>909</b>.</p>
    <p>Once the microcontroller has received the first byte, the microcontroller will continue to check if there is an interrupt on the microcontroller bus <b>310</b>. If no interrupt is posted on the microcontroller bus <b>310</b>, the slave microcontroller will check to see if the bus time-out flag is set. The bus time-out flag is set once a byte has been received from a master microcontroller. If in the decision state <b>910</b> the microcontroller determines that the bus time-out flag is set, the slave microcontroller will proceed to check for an interrupt every 10 milliseconds up to 500 milliseconds. For this purpose, the slave microcontroller increments the counter every 10 milliseconds (state <b>912</b>). In state <b>914</b>, the microcontroller checks to see if the microcontroller bus <b>310</b> has timed out. If the slave microcontroller has not received additional bytes from the master microcontroller, the slave microcontroller assumes that the microcontroller bus <b>310</b> is hung and resets the microcontroller bus <b>310</b> (state <b>916</b>). Next, the slave microcontroller aborts the request and awaits further requests from other master microcontrollers (state <b>918</b>).</p>
    <p>Referring to the state <b>909</b>, the bus timeout bit is cleared, and the request is processed and the response is formulated. Moving to state <b>920</b>, the response is sent a byte at a time. At state <b>922</b>, the same bus check is made as was described for the state <b>814</b>. States <b>922</b>, <b>923</b> and <b>928</b> form the same bus check and timeout as states <b>814</b>, <b>819</b> and <b>820</b>. If in state <b>928</b> this check times out, a bus error exists, and this transaction is aborted (states <b>930</b> and <b>932</b>).</p>
    <p>FIGS. 10A and 10B are flow diagrams showing one process by which the System Interface <b>312</b> handles requests from other microcontrollers in the microcontroller network and the ISA bus <b>226</b> (FIGS. <b>4</b> and <b>5</b>). The System Interface <b>312</b> relays messages from the ISA bus <b>226</b> to other microcontrollers in the network of microcontrollers <b>225</b>. The System Interface <b>312</b> also relays messages from the network of microcontrollers to the ISA bus <b>226</b>.</p>
    <p>Referring to FIGS. 10A and 10B, the System Interface <b>312</b> initializes all variables and the stack pointer (state <b>1000</b>). Moving to state <b>1002</b>, the System Interface <b>312</b> starts its main loop in which it performs various functions. The System Interface <b>312</b> next checks the bus timeout bit to see if the microcontroller bus <b>310</b> has timed-out (decision state <b>1004</b>). If the microcontroller bus <b>310</b> has timed-out, the System Interface <b>312</b> resets the microcontroller bus <b>310</b> in state <b>1006</b>.</p>
    <p>Proceeding to a decision state <b>1008</b>, the System Interface <b>312</b> checks to see if any event messages have been received. An event occurs when the System Interface <b>312</b> receives information from another microcontroller regarding a change to the state of the system. At state <b>1010</b>, the System Interface <b>312</b> sets the event bit in the CSR <b>709</b> to one. The System Interface <b>312</b> also sends an interrupt to the operating system if the CSR <b>709</b> has requested interrupt notification.</p>
    <p>Proceeding to a decision state <b>1012</b>, the System Interface <b>312</b> checks to see if a device driver for the operating system has input a command to the CSR. If the System Interface <b>312</b> does not find a command, the System Interface <b>312</b> returns to state <b>1002</b>. If the System Interface does find a command from the operating system, the System Interface parses the command. For the “allocate command”, the System Interface <b>312</b> resets the queue to the ISA bus <b>226</b> resets the done bit in the CSR <b>709</b> (state <b>1016</b>) and sets the CSR Interface Owner ID (state <b>1016</b>). The Owner ID bits identify which device driver owns control of the System Interface <b>312</b>.</p>
    <p>For the “de-allocate command”, the System Interface <b>312</b> resets the queue to the ISA bus <b>226</b>, resets the done bit in the CSR <b>709</b>, and clears the Owner ID bits (state <b>1018</b>).</p>
    <p>For the “clear done bit command” the System Interface <b>312</b> clears the done bit in the CSR <b>709</b> (state <b>1020</b>). For the “enable interrupt command” the System Interface <b>312</b> sets the interrupt enable bit in the CSR <b>709</b> (state <b>1022</b>). For the “disable interrupt command,” the System Interface <b>312</b> sets the interrupt enable bit in the CSR <b>709</b> (state <b>1024</b>). For the “clear interrupt request command”, the System Interface <b>312</b> clears the interrupt enable bit in the CSR <b>709</b> (state <b>1026</b>).</p>
    <p>If the request from the operating system was not meant for the System Interface <b>312</b>, the command is intended for another microcontroller in the network <b>225</b>. The only valid command remaining is the “message command.” Proceeding to state <b>1028</b>, the System Interface <b>312</b> reads message bytes from the request buffer <b>516</b>. From the state <b>1028</b>, the System Interface <b>312</b> proceeds to a decision state <b>1030</b> in which the System Interface <b>312</b> checks whether the command was for itself. If the command was for the System Interface <b>312</b>, moving to state <b>1032</b>, the System Interface <b>312</b> processes the command. If the ID did not match an internal command address, the System Interface <b>312</b> relays the command the appropriate microcontroller (state <b>1034</b>) by sending the message bytes out over the microcontroller bus <b>310</b>.</p>
    <p>FIGS. 11A and 11B are flowcharts showing an embodiment of the functions performed by the Chassis controller <b>318</b>. Starting in the state <b>1100</b>, the Chassis controller <b>318</b> initializes its variables and stack pointer.</p>
    <p>Proceeding to state <b>1102</b>, the Chassis controller <b>318</b> reads the serial numbers of the microcontrollers contained on the system board <b>302</b> and the backplane <b>304</b>. The Chassis controller <b>318</b> also reads the serial numbers for the Canister controllers <b>324</b>, <b>326</b>, <b>328</b> and <b>330</b>. The Chassis controller <b>318</b> stores all of these serial numbers in the NVRAM <b>322</b>.</p>
    <p>Next, the Chassis controller <b>318</b> start its main loop in which it performs various diagnostics (state <b>1104</b>). The Chassis controller <b>318</b> checks to see if the microcontroller bus <b>310</b> has timed-out (state <b>1106</b>). If the bus has timed-out, the Chassis controller <b>318</b> resets the microcontroller bus <b>310</b> (state <b>1008</b>). If the microcontroller bus <b>310</b> has not timed out the Chassis controller proceeds to a decision state <b>1110</b> in which the Chassis controller <b>318</b> checks to see if a user has pressed a power switch.</p>
    <p>If the Chassis controller <b>318</b> determines a user has pressed a power switch, the Chassis controller changes the state of the power to either on or off (state <b>1112</b>). Additionally, the Chassis controller logs the new power state into the NVRAM <b>322</b>.</p>
    <p>The Chassis controller <b>318</b> proceeds to handle any power requests from the Remote Interface <b>332</b> (state <b>1114</b>). As shown in FIG. 9, a power request message to this microcontroller is received when the arriving message interrupts the microcontroller. The message is processed and a bit is set indicating request has been made to toggle power. At state <b>1114</b>, the Chassis controller <b>318</b> checks this bit. If the bit is set, the Chassis controller <b>318</b> toggles the system, i.e., off-to-on or on-to-off, power and logs a message into the NVRAM <b>322</b> that the system power has changed state (state <b>1116</b>).</p>
    <p>Proceeding to state <b>1118</b>, the Chassis controller <b>318</b> checks the operating system watch dog counter for a time out. If the Chassis controller <b>318</b> finds that the operating system has failed to update the timer, the Chassis controller <b>318</b> proceeds to log a message with the NVRAM <b>322</b> (state <b>1120</b>). Additionally, the Chassis controller <b>318</b> sends an event to the System Interface <b>312</b> and the Remote Interface <b>332</b>.</p>
    <p>Since it takes some time for the power supplies to settle and produce stable DC power, the Chassis controller delays before proceeding to check DC (state <b>1122</b>).</p>
    <p>The Chassis controller <b>318</b> then checks for changes in the canisters <b>258</b>-<b>264</b> (state <b>1124</b>), such as a canister being inserted or removed. If a change is detected, the Chassis controller <b>318</b> logs a message to the NVRAM <b>322</b> (state <b>1126</b>). Additionally, the Chassis controller <b>318</b> sends an event to the System Interface <b>312</b> and the Remote Interface <b>332</b>.</p>
    <p>The Chassis controller <b>318</b> proceeds to check the power supply for a change in status (state <b>1128</b>). The process by which the Chassis controller <b>318</b> checks the power supply is described in further detail in the discussion for FIG. <b>12</b>.</p>
    <p>The Chassis controller then checks the temperature of the system (state <b>1132</b>). The process by which the Chassis controller <b>318</b> checks the temperature is described in further detail in the discussion for FIG. <b>13</b>.</p>
    <p>At state <b>1136</b>, the Chassis controller <b>318</b> reads all of the voltage level signals. The Chassis controller <b>318</b> saves these voltage levels values in an internal register for reference by other microcontrollers.</p>
    <p>Next, the Chassis controller <b>318</b> checks the power supply signals for AC/DC changes (state <b>1138</b>). If the Chassis controller <b>318</b> detects a change in the Chassis controller <b>318</b>, the Chassis controller <b>318</b> logs a message to the NVRAM <b>322</b> (state <b>1140</b>). Additionally, the Chassis controller <b>318</b> sends an event to the System Interface <b>312</b> and the Remote Interface <b>332</b> that a AC/DC signal has changed. The Chassis controller <b>318</b> then returns to state <b>1104</b> to repeat the monitoring process.</p>
    <p>FIG. 12 is a flowchart showing one process by which the Chassis controller <b>318</b> checks the state of the redundant power supplies termed number 1 and 2. These power supplies are monitored and controlled by the chassis controller <b>318</b> through the signal lines shown in FIG. <b>5</b>A. When a power supply fails or requires maintenance, the other supply maintains power to the computer <b>100</b>. To determine whether a power supply is operating properly or not, its status of inserted or removed (by maintenance personnel) should be ascertained. Furthermore, a change in status should be recorded in the NVRAM <b>322</b>. FIG. 12 describes in greater detail the state <b>1128</b> shown in FIG. <b>1</b>B.</p>
    <p>Starting in state <b>1202</b>, the Chassis controller <b>318</b> checks the power supply bit. If the power supply bit indicates that a power supply should be present, the Chassis controller checks whether power supply “number 1” has been removed (state <b>1204</b>). If power supply number 1 has been removed, the chassis microcontroller <b>318</b> checks whether its internal state indicates power supply number one should be present. If the internal state was determined to be present, then the slot is checked to see whether power supply number 1 is still physically present (state <b>1204</b>). If power supply number 1 has been removed, the PS_PRESENT#1 bit is changed to not present (state <b>1208</b>). The Chassis controller <b>318</b> then logs a message in the NVRAM <b>322</b>.</p>
    <p>Referring to state <b>1206</b>, if the PS_PRESENT#1 bit indicates that power supply number 1 is not present, the Chassis controller <b>318</b> checks whether power supply number 1 has been inserted (i.e., checks to see if it is now physically present) (state <b>1206</b>). If it has been inserted, the Chassis controller <b>318</b> then logs a message into the NVRAM <b>322</b> that the power supply number 1 has been inserted (state <b>1210</b>) and changes the value of PS_PRESENT#1 to present.</p>
    <p>After completion, states <b>1204</b>, <b>1206</b>, <b>1208</b>, and <b>1210</b> proceed to state <b>1212</b> to monitor power supply number <b>2</b>. The Chassis controller <b>318</b> checks whether the PS_PRESENT#2 bit is set to present. If the PS_PRESENT#2 bit indicates that power supply “number 2” should be there, the Chassis controller <b>318</b> proceeds to state <b>1224</b>. Otherwise, the Chassis controller <b>318</b> proceeds to state <b>1226</b>. At state <b>1224</b>, the Chassis controller <b>318</b> checks if power supply number 2 is still present. If power supply number 2 has been removed, the Chassis controller <b>318</b> logs in the NVRAM <b>322</b> that power supply number 2 has been removed (state <b>1228</b>). The chassis controller also changes the value of PS_PRESENT#2 bit to not present.</p>
    <p>Referring to decision state <b>1226</b>, if the PS_PRESENT#2 bit indicates that no power supply number 2 is present, the Chassis controller <b>318</b> checks if power supply number 2 has been inserted. If so, the Chassis controller <b>318</b> then logs a message into the NVRAM <b>322</b> that power supply number 2 has been inserted and changes the value of PS_PRESENT#2 to present (state <b>1230</b>). After completion of states <b>1224</b>, <b>1226</b>, <b>1228</b>, and <b>1230</b>, the chassis controller <b>318</b> proceeds to state <b>1232</b> to monitor the AC/DC power supply changed signal.</p>
    <p>If in decision state <b>1234</b> the Chassis controller <b>318</b> finds that the AC/DC power supply changed signal from the power supplies is asserted, the change in status is recorded in state <b>1236</b>. The Chassis controller <b>318</b> continues the monitoring process by proceeding to the state <b>1132</b> in FIG. <b>11</b>B.</p>
    <p>FIG. 13 is a flowchart showing one process by which the Chassis controller <b>318</b> monitors the temperature of the system. As shown in FIG. 5A, the Chassis controller <b>318</b> receives temperature detector signal lines from five temperature detectors located on the backplane and the motherboard. If either component indicates it is overheating, preventative action may be taken manually, by a technician, or automatically by the network of microcontrollers <b>225</b>. FIG. 13 describes in greater detail the state <b>1132</b> shown in FIG. <b>11</b>B.</p>
    <p>To read the temperature of the Chassis, the Chassis controller <b>318</b> reads the temperature detectors <b>502</b>, <b>504</b>, and <b>506</b> (state <b>1300</b>). In the embodiment of the invention shown in FIG. 13 there are five temperature detectors (two temperature detectors not shown). Another embodiment includes three temperature detectors as shown.</p>
    <p>The Chassis controller <b>318</b> checks the temperature detector <b>502</b> to see if the temperature is less than −25° C. or if the temperature is greater than or equal to 55° C. (state <b>1308</b>). Temperatures in this range are considered normal operating temperatures. Of course, other embodiments may use other temperature ranges. If the temperature is operating inside normal operating boundaries, the Chassis controller <b>318</b> proceeds to state <b>1310</b>. If the temperature is outside normal operating boundaries, the Chassis controller <b>318</b> proceeds to state <b>1312</b>. At state <b>1312</b>, the Chassis controller <b>318</b> evaluates the temperature a second time to check if the temperature is greater than or equal to 70° C. or less than or equal to −25° C. If the temperature falls below or above outside of these threshold values, the Chassis controller proceeds to state <b>1316</b>. Temperatures in this range are considered so far out of normal operating temperatures, that the computer <b>100</b> should be shutdown. Of course, other temperature ranges may be used in other embodiments.</p>
    <p>Referring to state <b>1316</b>, if the temperature level reading is critical, the Chassis controller <b>318</b> logs a message in the NVRAM <b>322</b> that the system was shut down due to excessive temperature. The Chassis controller <b>318</b> then proceeds to turn off power to the system in state <b>1320</b>, but may continue to operate from a bias or power supply.</p>
    <p>Otherwise, if the temperature is outside normal operating temperatures, but only slightly deviant, the Chassis controller <b>318</b> sets a bit in the temperature warning status register (state <b>1314</b>). Additionally, the Chassis controller <b>318</b> logs a message in the NVRAM <b>322</b> that the temperature is reaching dangerous levels (state <b>1318</b>).</p>
    <p>The Chassis controller <b>318</b> follows the aforementioned process for each temperature detector on the system. Referring back to state <b>1310</b>, which was entered after determining a normal temperature from one of the temperature detectors, the Chassis controller <b>318</b> checks a looping variable “N” to see if all the sensors were read. If all sensors were not read, the Chassis controller <b>318</b> returns to state <b>1300</b> to read another temperature detector. Otherwise, if all temperature detectors were read, the Chassis controller <b>318</b> proceeds to state <b>1322</b>. At state <b>1322</b>, the Chassis controller <b>318</b> checks a warning status register (not shown). If no bit is set in the temperature warning status register, the Chassis controller <b>318</b> returns to the state <b>1136</b> in FIG. <b>11</b>B. If the Chassis controller <b>318</b> determines that a bit in the warning status register was set for one of the sensors, the Chassis controller <b>318</b> proceeds to recheck all of the sensors (state <b>1324</b>). If the temperature of the sensors are still at a dangerous level, the Chassis Controller <b>318</b> maintains the warning bits in the warning status register. The Chassis controller <b>318</b> then proceeds to the state <b>1136</b> (FIG. <b>11</b>B). At state <b>1324</b>, if the temperatures of the sensors are now at normal operating values, the Chassis controller <b>318</b> proceeds to clear all of the bits in the warning status register (state <b>1326</b>). After clearing the register, the Chassis controller <b>318</b> proceeds to state <b>1328</b> to log a message in the NVRAM <b>322</b> that the temperature has returned to normal operational values, and the Chassis controller <b>318</b> proceeds to the state <b>11136</b> (FIG. <b>11</b>B).</p>
    <p>FIGS. 14A and 14B are flowcharts showing the functions performed by one embodiment of the CPU A controller <b>314</b>. The CPU A controller <b>314</b> is located on the system board <b>302</b> and conducts diagnostic checks for: a microcontroller bus timeout, a manual system board reset, a low system fan speed, a software reset command, general faults, a request to write to flash memory, checks system flag status, and a system fault.</p>
    <p>The CPU A controller <b>314</b>, starting in state <b>1400</b>, initializes its variables and stack pointer. Next, in state <b>1402</b> the CPU A controller <b>314</b> starts its main loop in which it performs various diagnostics which are described below. At state <b>1404</b>, the CPU A controller <b>314</b> checks the microcontroller bus <b>310</b> for a time out. If the microcontroller bus <b>310</b> has timed out, the CPU A controller <b>314</b> resets the microcontroller bus <b>310</b> (state <b>1406</b>). From either state <b>1404</b> or <b>1406</b>, the CPU A controller <b>314</b> proceeds to check whether the manual reset switch (not shown) is pressed on the system board <b>302</b> (decision state <b>1408</b>). If the CPU A controller <b>314</b> determines that the manual reset switch is pressed, the CPU A controller resets system board by asserting a reset signal (state <b>1410</b>).</p>
    <p>From either state <b>1408</b> or <b>1410</b>, the CPU A controller <b>314</b> proceeds to check the fan speed (decision state <b>1412</b>). If any of a number of fans speed is low (see FIG. <b>15</b> and discussion below), the CPU A controller <b>314</b> logs a message to NVRAM <b>322</b> (state <b>1414</b>). Additionally, the CPU A controller <b>314</b> sends an event to the Remote Interface <b>334</b> and the System Interface <b>312</b>. The CPU A controller <b>314</b> next proceeds to check whether a software reset command was issued by either the computer <b>100</b> or the remote computer <b>132</b> (state <b>1416</b>). If such a command was sent, the CPU A controller <b>314</b> logs a message in NVRAM <b>322</b> that system software requested the reset command (state <b>1418</b>). Additionally, the CPU A controller <b>314</b> also resets the system bus <b>202</b>.</p>
    <p>From either state <b>1416</b> or <b>1418</b>, the CPU A controller <b>314</b> checks the flags bits (not shown) to determine if a user defined system fault occurred (state <b>1420</b>). If the CPU A controller <b>314</b> determines that a user defined system fault occurred, the CPU A controller <b>314</b> proceeds to display the fault on an LCD display <b>512</b> (FIG. 5B) (state <b>1422</b>).</p>
    <p>From either state <b>1420</b> or <b>1422</b> the CPU A controller <b>314</b> proceeds to a state <b>1424</b> (if flash bit was not enabled) to check the flash enable bit maintained in memory on the CPU B controller <b>316</b>. If the flash enable bit is set, the CPU A controller <b>314</b> displays a code for flash enabled on the LCD display <b>512</b>. The purpose of the flash enable bit is further described in the description for the CPU B controller <b>316</b> (FIG. <b>16</b>).</p>
    <p>From either state <b>1424</b> or <b>1426</b> (if the flash bit was not enabled), the CPU A controller <b>314</b> proceeds to state <b>1428</b> and checks for system faults. If the CPU A controller <b>314</b> determines that a fault occurred, the CPU A controller <b>314</b> displays the fault on the LCD display <b>512</b> (state <b>1430</b>). From state <b>1428</b> if no fault occurred, or from state <b>1430</b>, the CPU A controller <b>314</b> proceeds to the checks the system status flag located in the CPU A controller's memory (decision state <b>1432</b>). If the status flag indicates an error, the CPU A controller <b>314</b> proceeds to state <b>1434</b> and displays error information on the LCD display <b>512</b>.</p>
    <p>From either state <b>1432</b> or <b>1434</b>, the CPU controller proceeds to state <b>1402</b> to repeat the monitoring process.</p>
    <p>FIG. 15 is a flowchart showing one process by which the CPU A controller <b>314</b> monitors the fan speed. FIG. 15 is a more detailed description of the function of state <b>1412</b> in FIG. <b>14</b>A. Starting in state <b>1502</b>, the CPU A controller <b>314</b> reads the speed of each of the fans <b>1506</b>, <b>1508</b>, and <b>1510</b>. The fan speed is processed by a Fan Tachometer Signal Mux <b>508</b> (also shown in FIG. 5B) which updates the CPU A controller <b>314</b>. The CPU A controller <b>314</b> then checks to see if a fan speed is above a specified threshold (state <b>1512</b>). If the fan speed is above the threshold, the CPU A controller <b>314</b> proceeds to state <b>1514</b>. Otherwise, if the fan speed is operating below a specified low speed limit, the CPU A controller <b>314</b> proceeds to state <b>1522</b>.</p>
    <p>On the other hand, when the fan is operating above the low speed limit at state <b>1514</b>, the CPU A controller <b>314</b> checks the hot_swap_fan register (not shown) if the -particular fan was hot swapped. If the fan was hot swapped, the CPU A controller <b>314</b> proceeds to clear the fan's bit in both the fan_fault register (not shown) and the hot_swap_fan register (state <b>1516</b>). After clearing these bits, the CPU A controller <b>314</b> checks the fan fault register (state <b>1518</b>). If the fan fault register is all clear, the CPU A controller <b>314</b> proceeds to set the fan to low speed (state <b>1520</b>) and logs a message to the NVRAM <b>322</b>. The CPU A controller <b>314</b> then proceeds to state <b>1536</b> to check for a temperature warning.</p>
    <p>Now, referring back to state <b>1522</b>, if a fan speed is below a specified threshold limit, the CPU A controller <b>314</b> checks to see if the fan's speed is zero. If the fan's speed is zero, the CPU A controller <b>314</b> sets the bit in the hot_swap_fan register in state <b>1524</b> to indicate that the fan has a fault and should be replaced. If the fan's speed is not zero, the CPU A controller <b>314</b> will proceed to set a bit in the fan_fault register (state <b>1526</b>). Moving to state <b>1528</b>, the speed of any fans still operating is increased to high, and a message is written to the NVRAM <b>322</b>.</p>
    <p>In one alternative embodiment, the system self-manages temperature as follows: from either state <b>1520</b> or <b>1528</b>, the CPU A controller <b>314</b> moves to state <b>1536</b> and checks whether a message was received from the Chassis controller <b>318</b> indicating temperature warning. If a temperature warning is indicated, and if there are no fan faults involving fans in the cooling group associated with the warning, the speed of fans in that cooling group is increased to provide more cooling capacity (state <b>1538</b>).</p>
    <p>Proceeding to state <b>1530</b> from either state <b>1536</b> or <b>1538</b>, the CPU A controller <b>314</b> increments a fan counter stored inside of microcontroller memory. If at state <b>1531</b>, there are more fans to check, the CPU A controller <b>314</b> returns to state <b>1502</b> to monitor the speed of the other fans. Otherwise, the CPU controller <b>314</b> returns to state <b>1416</b> (FIG. <b>14</b>).</p>
    <p>FIG. 16 is one embodiment of a flow diagram showing the functions performed by the CPU B controller <b>316</b>. The CPU B controller <b>316</b> scans for system faults, scans the microcontroller bus <b>310</b>, and provides flash enable. The CPU B controller <b>316</b>, starting at state <b>1600</b>, initializes its variables and stack pointer.</p>
    <p>After initializing its internal state, the CPU B controller <b>316</b> enters a diagnostic loop at state <b>1602</b>. The CPU B controller <b>316</b> then checks the microcontroller bus <b>310</b> for a time out (decision state <b>1604</b>). If the microcontroller bus <b>310</b> has timed out, the CPU B controller <b>316</b> resets the microcontroller bus <b>310</b> in state <b>1606</b>. If the microcontroller bus <b>310</b> has not timed out (state <b>1604</b>) or after state <b>1606</b>, the CPU B controller <b>316</b> proceeds to check the system fault register (not shown) (decision state <b>1608</b>).</p>
    <p>If the CPU B controller <b>316</b> finds a system fault, the CPU B controller <b>316</b> proceeds to log a message into the NVRAM <b>322</b> stating that a system fault occurred (state <b>1610</b>). The CPU B controller <b>316</b> then sends an event to the System Interface <b>312</b> and the Remote Interface <b>332</b>. Additionally, the CPU B controller <b>316</b> turns on one of a number of LED indicators <b>518</b> (FIG. <b>5</b>B).</p>
    <p>If no system fault occurred, or from state <b>1610</b>, the CPU B controller <b>316</b> scans the microcontroller bus <b>310</b> (decision state <b>1612</b>). If the microcontroller bus <b>310</b> is hung then the CPU B controller <b>316</b> proceeds to flash an LED display <b>512</b> that the microcontroller bus <b>310</b> is hung (state <b>1614</b>). Otherwise, if the bus is not hung the CPU B controller <b>316</b> then proceeds to state <b>1624</b>.</p>
    <p>The CPU B controller <b>316</b> proceeds to check for a bus stop bit time out (decision state <b>1624</b>). If the stop bit has timed out, the CPU B controller <b>316</b> generates a stop bit on the microcontroller bus for error recovery in case the stop bit is inadvertently being held low by another microcontroller (state <b>1626</b>).</p>
    <p>From either state <b>1624</b> or <b>1626</b>, the CPU B controller <b>316</b> proceeds to check the flash enable bit to determine if the flash enable bit (not shown) is set (state <b>1628</b>). If the CPU B controller <b>316</b> determines that the flash enable bit is set (by previously having received a message requesting it), the CPU B controller <b>316</b> proceeds to log a message to the NVRAM <b>322</b> (state <b>1630</b>). A flash update is performed by the BIOS if the system boot disk includes code to update a flash memory (not shown). The BIOS writes new code into the flash memory only if the flash memory is enabled for writing. A software application running on the CPUs <b>200</b> can send messages requesting that BIOS flash be enabled. At state <b>1630</b>, the 12 Volts needed to write the flash memory is turned on or left turned on. If the flash enable bit is not on, control passes to state <b>1629</b>, where the 12 Volts is turned off, disabling writing of the flash memory.</p>
    <p>From either state <b>1629</b> or <b>1630</b>, the CPU B controller <b>316</b> proceeds to repeat the aforementioned process of monitoring for system faults (state <b>1602</b>).</p>
    <p>FIG. 17 is one embodiment of a flowchart showing the functions performed by the Canister controllers <b>324</b>, <b>326</b>, <b>328</b> and <b>330</b> shown in FIGS. 4 and 5. The Canister controllers <b>324</b>, <b>326</b>, <b>328</b> and <b>330</b> examine canister fan speeds, control power to the canister, and determine which canister slots contain cards. The Canister controllers <b>324</b>-<b>330</b>, starting in state <b>1700</b>, initialize their variables and stack pointers.</p>
    <p>Next, in state <b>1702</b> the Canister controllers <b>324</b>-<b>330</b> start their main loop in which they performs various diagnostics, which are further described below. The Canister controllers <b>324</b>-<b>330</b> check the microcontroller bus <b>310</b> for a time out (state <b>1704</b>). If the microcontroller bus <b>310</b> has timed out, the Canister controllers <b>324</b>-<b>330</b> reset the microcontroller bus <b>310</b> in state <b>1706</b>. After the Canister controller <b>324</b>-<b>330</b> reset the microcontroller bus <b>310</b>, or if the microcontroller bus <b>310</b> has not timed out, the Canister controllers <b>324</b>-<b>330</b> proceed to examine the speed of the fans (decision state <b>1708</b>). As determined by tachometer signal lines connected through a fan multiplexer <b>508</b> (FIG. <b>5</b>), if either of two canister fans is below the lower threshold, the event is logged, an event is sent to the System Interface <b>312</b> and, speed, in a self-management embodiment, the fan speed is set to high. The Canister controllers <b>324</b>-<b>330</b> check the fan speed again, and if they are still low the canister controlling <b>324</b>-<b>330</b> signal a fan fault and register an error message in the NVRAM <b>322</b> (state <b>1710</b>).</p>
    <p>If the Canister controller received a request message to turn on or off canister power, a bit would have been previously set. If the Canister controllers <b>324</b>-<b>330</b> find this bit set (state <b>1712</b>), they turn the power to the canister on, and light the canister's LED. If the bit is cleared, power to the canister is turned off, as is the LED (state <b>1714</b>).</p>
    <p>Next, the Canister controllers <b>324</b>-<b>330</b> read a signal for each slot which indicates whether the slot contains an adapter (state <b>1716</b>). The Canister controllers <b>324</b>-<b>330</b> then returns to the state <b>1702</b>, to repeat the aforementioned monitoring process.</p>
    <p>FIG. 18 is one embodiment of a flowchart showing the functions performed by the System Recorder controller <b>320</b>. The System Recorder controller <b>320</b> maintains a system log in the NVRAM <b>322</b>. The System Recorder <b>320</b> starting in state <b>1800</b> initializes its variables and stack pointer.</p>
    <p>Next, at state <b>1802</b> the System Recorder <b>320</b> starts its main loop in which the System Recorder <b>320</b> performs various functions, which are further described below. First, the System Recorder <b>320</b> checks the microcontroller bus <b>310</b> for a time out (state <b>1804</b>). If the microcontroller bus <b>310</b> has timed out, the System Recorder <b>320</b> resets the microcontroller bus <b>310</b> in state <b>1806</b>. After the System Recorder <b>320</b> resets the bus, or if the microcontroller bus <b>310</b> has not timed out, the System Recorder <b>320</b> checks to see if another microcontroller had requested the System Recorder <b>320</b> to reset the NVRAM <b>322</b> (state <b>1808</b>). If requested, the System Recorder <b>320</b> proceeds to reset all the memory in the NVRAM <b>322</b> to zero (decision state <b>1810</b>). After resetting the NVRAM <b>322</b>, or if no microcontroller had requested such a reset, the System Recorder <b>320</b> proceeds to a get the real time clock every second from a timer chip <b>520</b> (FIG. 5A) (decision state <b>1812</b>).</p>
    <p>From time to time, the System Recorder <b>320</b> will be interrupted by the receipt of messages. When these messages are for storing data in the NVRAM <b>322</b>, they are carried out as they are received and the messages are stored in the NVRAM <b>322</b>. Thus, there is no state in the flow of FIG. 18 to explicitly store messages. The System Recorder then returns to the state <b>1802</b> to repeat the aforementioned monitoring process.</p>
    <p>While the above detailed description has shown, described, and pointed out the fundamental novel features of the invention as applied to various embodiments, it will be understood that various omissions and substitutions and changes in the form and details of the system illustrated by be made by those skilled in the art, without departing from the intent of the invention.</p>
    <p>
      <tables> <table frame="none" colsep="0" rowsep="0" pgwide="1" class="description-table"> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="center" colwidth="364PT"> </colspec> <thead valign="bottom"> <tr class="description-tr"> <td namest="1" nameend="1" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="1"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Header File for Global Memory Addresses</td>
              </tr> <tr class="description-tr"> <td namest="1" nameend="1" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="1"> </td>
              </tr> </thead> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#ifndef SDL_TYPES</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#ifndef FAR_POINTERS</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">typedef unsigned char *BYTEADDRESS;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">typedef unsigned short *WORDADDRESS;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">typedef unsigned long *LONGADDRESS;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">typedef char *SBYTEADDRESS;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">typedef short *SWORDADDRESS;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">typedef long *SLONGADDRESS;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#else</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">typedef unsigned Long BYTEADDRESS;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">typedef unsigned Long WORDADDRESS;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">typedef unsigned long LONGADDRESS;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">typedef unsigned long SBYTEADDRESS;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">typedef unsigned Long SWORDADDRESS;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">typedef unsigned Long SLONGADDRESS;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#endif</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define SDL_TYPES 1</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#endif</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* $Module CS9000WS.SDL$ */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Copyright 1996 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* By NetFRAME Systems Inc. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Milpitas, California U.S.A. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* $Author: Ken Nguyen $ */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* $Date: 31 Mar 1997 15:28:08 $ */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* $Revision */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* $Description$ */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* This file contains the NetFRAME Wire Service message and interface definition. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* for the C59000 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* $EndDescription$ */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Revision History */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* $Log: P:/inc/cs9000ws.sdl $ */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.16 31 Mar 1997 15:28:08 Ken Nguyen */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Added WSEvent variables, Severity bytes and WS commands. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.15 28 Jan 1997 16:31:32 Ken Nguyen */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Cleaned up SDL file */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Added Buffer Event Commands and Event ID Number. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.14 27 Nov 1996 14:10:12 Ken Nguyen */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Added commands for Raptor 8 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Added WSEVENT_CPU event. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.13 25 Oct 1996 16:48:18 Ken Nguyen */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Fixed a Problem of Canister Fan Fault Status. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.10 10 Oct 1996 16:33:04 Ken Nguyen */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Added a command to count Log entry. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.9 30 Sep 1996 18:42:50 Ken Nguyen */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Added Canister Fault Commands */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.8 30 Sep 1996 17:34:16 Karl Johnson */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Added definitions for remote interface serial protocol */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Added NVRAM error counter */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.7 13 Sep 1996 11:22:22 Ken Nguyen */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Corrected Temperature data length */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.6 09 Sep 1996 17:24:48 Karl Johnson */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Added WS_SYSLOG_CLOCK - the clock used by the log recorder to time stamp */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.5 20 Aug 1996 01:08:36 Karl Johnson */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Added screen event and corrected BOOTDEVS name. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.4 01 Aug 1996 15:32:50 Karl Johnson */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Cleanup and added new status values. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.3 26 Jul 1996 17:14:38 Karl Johnson */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Reduced maximum number of event types. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Added a Success Status. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.2 08 Jul 1996 15:57:32 Karl Johnson */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Changed read write bit in datatype definition. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Added WS_BOOTDEVS missed in translating specification. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.1 19 Jun 1996 14:15:28 Karl Johnson */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Added LCD low level access items. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Rev 1.0 18 Jun 1996 14:06:58 Karl Johnson */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Initial revision. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* *********************************************** */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* This is the Wire Service Message format */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#ifndef PIC_PROCESSOR</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">struct WSMessage</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> {</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> unsigned char ToProcesor;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> unsigned char Type_RW</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> unsigned char AddressLow;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> unsigned char AddressHi;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> unsigned char WriteLength;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* WriteData BLOCK_BYTE 0; Write data stream goes here */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> };</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSMessage_S 5</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">struct WSResponse</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> {</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> unsigned char FromProcesor;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> unsigned char ReadLength;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* ReadData BLOCK_BYTE 0; Read data stream goes here */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> unsigned char Status;</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> };</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSResponse_S 3</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#endif</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Wire Service Local Interface Definitions */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Command (CSR Write) Register definitions */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_RequestInt</td>
                <td morerows="0" valign="top" class="description-td">0 × 80</td>
                <td morerows="0" valign="top" class="description-td">/* Request interrupt on command complete */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_Allocate1</td>
                <td morerows="0" valign="top" class="description-td">0 × 01</td>
                <td morerows="0" valign="top" class="description-td">/* Allocate interface as ID 1 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_Allocate2</td>
                <td morerows="0" valign="top" class="description-td">0 × 02</td>
                <td morerows="0" valign="top" class="description-td">/* Allocate interface as ID 2 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_Allocate3</td>
                <td morerows="0" valign="top" class="description-td">0 × 03</td>
                <td morerows="0" valign="top" class="description-td">/* Allocate interface as ID 3 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_Allocate4</td>
                <td morerows="0" valign="top" class="description-td">0 × 04</td>
                <td morerows="0" valign="top" class="description-td">/* Allocate interface as ID 4 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_Allocate5</td>
                <td morerows="0" valign="top" class="description-td">0 × 05</td>
                <td morerows="0" valign="top" class="description-td">/* Allocate interface as ID 5 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_Allocate6</td>
                <td morerows="0" valign="top" class="description-td">0 × 06</td>
                <td morerows="0" valign="top" class="description-td">/* Allocate interface as ID 6 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_Allocate7</td>
                <td morerows="0" valign="top" class="description-td">0 × 07</td>
                <td morerows="0" valign="top" class="description-td">/* Allocate interface as ID 7 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_Deallocate</td>
                <td morerows="0" valign="top" class="description-td">0 × 10</td>
                <td morerows="0" valign="top" class="description-td">/* Deallocate interface */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_EnableInts</td>
                <td morerows="0" valign="top" class="description-td">0 × 11</td>
                <td morerows="0" valign="top" class="description-td">/* Enable interrupts for events */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_DisableInts</td>
                <td morerows="0" valign="top" class="description-td">0 × 12</td>
                <td morerows="0" valign="top" class="description-td">/* Disable interrupts for events */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_Message</td>
                <td morerows="0" valign="top" class="description-td">0 × 13</td>
                <td morerows="0" valign="top" class="description-td">/* Process message in FIFO and set done */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_ClearDone</td>
                <td morerows="0" valign="top" class="description-td">0 × 20</td>
                <td morerows="0" valign="top" class="description-td">/* Clear done bit &amp; error bit and clear FIFOs */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_ClearIntReq</td>
                <td morerows="0" valign="top" class="description-td">0 × 21</td>
                <td morerows="0" valign="top" class="description-td">/* Clear Interrupt Request bit */</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* ( Must poll WSTS_IntReq =&gt; 0 for completion) */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_Reset</td>
                <td morerows="0" valign="top" class="description-td">0 × 0a5</td>
                <td morerows="0" valign="top" class="description-td">/* Reset interface */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_DiagMode</td>
                <td morerows="0" valign="top" class="description-td">0 × 05a</td>
                <td morerows="0" valign="top" class="description-td">/* Enter Diagnostic mode */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSCMD_ExitDiagMode</td>
                <td morerows="0" valign="top" class="description-td">0 × 00</td>
                <td morerows="0" valign="top" class="description-td">/* Exit Diagnostic mode */</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Status (CSR Read) Register definitions */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSSTS_Error</td>
                <td morerows="0" valign="top" class="description-td">0 × 80</td>
                <td morerows="0" valign="top" class="description-td">/* Error processing command */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSSTS_IntEna</td>
                <td morerows="0" valign="top" class="description-td">0 × 40</td>
                <td morerows="0" valign="top" class="description-td">/* Event Interrupts are enabled */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSSTS_Events</td>
                <td morerows="0" valign="top" class="description-td">0 × 20</td>
                <td morerows="0" valign="top" class="description-td">/* One or more events occurred */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSSTS_Done</td>
                <td morerows="0" valign="top" class="description-td">0 × 10</td>
                <td morerows="0" valign="top" class="description-td">/* Message command is done */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSSTS_IntReq</td>
                <td morerows="0" valign="top" class="description-td">0 × 08</td>
                <td morerows="0" valign="top" class="description-td">/* Interrupt is being requested */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSSTS_AllocMask</td>
                <td morerows="0" valign="top" class="description-td">0 × 07</td>
                <td morerows="0" valign="top" class="description-td">/* ID of owner of interface */</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* IO Addresses of Wire Service Local Interface */</td>
              </tr> </tbody> </tgroup> <tgroup cols="2" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="238PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOC_Data</td>
                <td morerows="0" valign="top" class="description-td">0 × 0CC0</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOC_CSR</td>
                <td morerows="0" valign="top" class="description-td">0 × 0CC1</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* ********************************************************* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* These are the data type definitions */</td>
              </tr> </tbody> </tgroup> <tgroup cols="2" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="238PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSTYPE_BIT</td>
                <td morerows="0" valign="top" class="description-td">0 × 01</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSTYPE_BYTE</td>
                <td morerows="0" valign="top" class="description-td">0 × 02</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSTYPE_STRING</td>
                <td morerows="0" valign="top" class="description-td">0 × 03</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSTYPE_LOG</td>
                <td morerows="0" valign="top" class="description-td">0 × 04</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSTYPE_EVENT</td>
                <td morerows="0" valign="top" class="description-td">0 × 05</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSTYPE_QUEUE</td>
                <td morerows="0" valign="top" class="description-td">0 × 06</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSTYPE_ARRAY</td>
                <td morerows="0" valign="top" class="description-td">0 × 07</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSTYPE_LOCK</td>
                <td morerows="0" valign="top" class="description-td">0 × 08</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSTYPE_SCREEN</td>
                <td morerows="0" valign="top" class="description-td">0 × 09</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSOP_READ</td>
                <td morerows="0" valign="top" class="description-td">0 × 80</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSOP_WRITE</td>
                <td morerows="0" valign="top" class="description-td">0 × 00</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSEVENT_CAN_CHG</td>
                <td morerows="0" valign="top" class="description-td">0 × 01</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSEVENT_PS_CHG</td>
                <td morerows="0" valign="top" class="description-td">0 × 02</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSEVENT_QUEUE</td>
                <td morerows="0" valign="top" class="description-td">0 × 03</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSEVENT_TEMP</td>
                <td morerows="0" valign="top" class="description-td">0 × 04</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSEVENT_ACOK</td>
                <td morerows="0" valign="top" class="description-td">0 × 05</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSEVENT_DCOK</td>
                <td morerows="0" valign="top" class="description-td">0 × 06</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSEVENT_FAN</td>
                <td morerows="0" valign="top" class="description-td">0 × 07</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSEVENT_SCREEN</td>
                <td morerows="0" valign="top" class="description-td">0 × 08</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSEVENT_CPU</td>
                <td morerows="0" valign="top" class="description-td">0 × 09</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSEVENT_OS_TimeOut</td>
                <td morerows="0" valign="top" class="description-td">0 × 0A</td>
                <td morerows="0" valign="top" class="description-td">/* Event of OS's Timer is timed out */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSEVENT_PCI_TimeOut</td>
                <td morerows="0" valign="top" class="description-td">0 × 0B</td>
                <td morerows="0" valign="top" class="description-td">/* Event of Power ON/OFF PCI Slot is timed out */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSEVENT_CALLOUT</td>
                <td morerows="0" valign="top" class="description-td">0 × 0C</td>
                <td morerows="0" valign="top" class="description-td">/* Call Out Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSEVENT_MAXVALUE</td>
                <td morerows="0" valign="top" class="description-td">0 × 0F</td>
                <td morerows="0" valign="top" class="description-td">/* Make sure no event values exceed this value */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSERR_NONE</td>
                <td morerows="0" valign="top" class="description-td">0 × 00</td>
                <td morerows="0" valign="top" class="description-td">/* No error occurred */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSERR_NONODE</td>
                <td morerows="0" valign="top" class="description-td">0 × 01</td>
                <td morerows="0" valign="top" class="description-td">/* Slave addressed did not respond */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSERR_NOADDRESS</td>
                <td morerows="0" valign="top" class="description-td">0 × 02</td>
                <td morerows="0" valign="top" class="description-td">/* Slave responded that it had no such type/address */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSERR_CORRUPTED</td>
                <td morerows="0" valign="top" class="description-td">0 × 03</td>
                <td morerows="0" valign="top" class="description-td">/* Message or Response is not valid */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSERR_UNDERRUN</td>
                <td morerows="0" valign="top" class="description-td">0 × 04</td>
                <td morerows="0" valign="top" class="description-td">/* Message could not be completely transmitted or received</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSERR_DATACHECK</td>
                <td morerows="0" valign="top" class="description-td">0 × 05</td>
                <td morerows="0" valign="top" class="description-td">/* Message data checksum received incorrectly (try again if</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">possible ) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSERR_OPERATION</td>
                <td morerows="0" valign="top" class="description-td">0 × 06</td>
                <td morerows="0" valign="top" class="description-td">/* Slave operation not possible (e.g. Wr to R/O) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSERR_NODATA</td>
                <td morerows="0" valign="top" class="description-td">0 × 07</td>
                <td morerows="0" valign="top" class="description-td">/* Slave responded no data available at address (queue/log)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSPID_SYSLOG</td>
                <td morerows="0" valign="top" class="description-td">0 × 01</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSPID_BACKPLANE</td>
                <td morerows="0" valign="top" class="description-td">0 × 02</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSPID_SYSTEMA</td>
                <td morerows="0" valign="top" class="description-td">0 × 03</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSPID_SYSTEMB</td>
                <td morerows="0" valign="top" class="description-td">0 × 04</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSPID_LOCAL_IF</td>
                <td morerows="0" valign="top" class="description-td">0 × 10</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSPID_REMOTE_IF</td>
                <td morerows="0" valign="top" class="description-td">0 × 11</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSPID_CANISTER1</td>
                <td morerows="0" valign="top" class="description-td">0 × 20</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSPID_CANISTER2</td>
                <td morerows="0" valign="top" class="description-td">0 × 21</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSPID_CANISTER3</td>
                <td morerows="0" valign="top" class="description-td">0 × 22</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSPID_CANISTER4</td>
                <td morerows="0" valign="top" class="description-td">0 × 23</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* ********************************************************* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Wire Service Remote Interface Protocol Constants */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_SOM</td>
                <td morerows="0" valign="top" class="description-td">0 × 7B</td>
                <td morerows="0" valign="top" class="description-td">/* Serial Start Of Message */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_EOM</td>
                <td morerows="0" valign="top" class="description-td">0 × 7D</td>
                <td morerows="0" valign="top" class="description-td">/* Serial End Of Message */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_SUB</td>
                <td morerows="0" valign="top" class="description-td">0 × 5C</td>
                <td morerows="0" valign="top" class="description-td">/* Serial Substitute next character */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_EVT</td>
                <td morerows="0" valign="top" class="description-td">0 × 5E</td>
                <td morerows="0" valign="top" class="description-td">/* Serial Event indicator */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_REQ_IDENTIFY</td>
                <td morerows="0" valign="top" class="description-td">0 × 01</td>
                <td morerows="0" valign="top" class="description-td">/* Request Identity and reset sequence */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_REQ_SECURE</td>
                <td morerows="0" valign="top" class="description-td">0 × 02</td>
                <td morerows="0" valign="top" class="description-td">/* Request to enter Security mode (logon) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_REQ_UNSECURE</td>
                <td morerows="0" valign="top" class="description-td">0 × 03</td>
                <td morerows="0" valign="top" class="description-td">/* Request to leave Security mode */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_REQ_MESSAGE</td>
                <td morerows="0" valign="top" class="description-td">0 × 04</td>
                <td morerows="0" valign="top" class="description-td">/* Request contains WS message to process */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_REQ_POLL</td>
                <td morerows="0" valign="top" class="description-td">0 × 05</td>
                <td morerows="0" valign="top" class="description-td">/* Request status */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_STAT_OK</td>
                <td morerows="0" valign="top" class="description-td">0 × 01</td>
                <td morerows="0" valign="top" class="description-td">/* Request OK return data valid */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_STAT_OK_EVENT</td>
                <td morerows="0" valign="top" class="description-td">0 × 02</td>
                <td morerows="0" valign="top" class="description-td">/* Request OK return data valid (Event(s) pending</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_STAT_E_SEQUENCE</td>
                <td morerows="0" valign="top" class="description-td">0 × 03</td>
                <td morerows="0" valign="top" class="description-td">/* Request not in Sequence */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_STAT_E_DATACHECK</td>
                <td morerows="0" valign="top" class="description-td">0 × 03</td>
                <td morerows="0" valign="top" class="description-td">/* Request check byte not correct */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_STAT_E_FORMAT</td>
                <td morerows="0" valign="top" class="description-td">0 × 04</td>
                <td morerows="0" valign="top" class="description-td">/* Request format incorrect */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSRI_STAT_E_SECURE</td>
                <td morerows="0" valign="top" class="description-td">0 × 05</td>
                <td morerows="0" valign="top" class="description-td">/* Request requires Security mode */</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* ********************************************************* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Wire Service Log Message Constants */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* First byte of log message data: Severity Level Byte */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_LEVEL_UNKNOWN</td>
                <td morerows="0" valign="top" class="description-td">0 × 00</td>
                <td morerows="0" valign="top" class="description-td">/* Unknown */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_LEVEL_INFO</td>
                <td morerows="0" valign="top" class="description-td">0 × 10</td>
                <td morerows="0" valign="top" class="description-td">/* Informational */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_LEVEL_WARN</td>
                <td morerows="0" valign="top" class="description-td">0 × 20</td>
                <td morerows="0" valign="top" class="description-td">/* Warning */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_LEVEL_ERROR</td>
                <td morerows="0" valign="top" class="description-td">0 × 30</td>
                <td morerows="0" valign="top" class="description-td">/* Error */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_LEVEL_FATAL</td>
                <td morerows="0" valign="top" class="description-td">0 × 40</td>
                <td morerows="0" valign="top" class="description-td">/* Severe/Fatal Error */</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Second byte of log message data: Source/Encoding Byte */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* - which entity logged the entry in the 4 high bits */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* - which type of encoding of the message is used in the 4 low bits of the byte. */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_SRC_INTERNAL</td>
                <td morerows="0" valign="top" class="description-td">0 × 00</td>
                <td morerows="0" valign="top" class="description-td">/* Wire Service Internal */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_SRC_0BDIAG</td>
                <td morerows="0" valign="top" class="description-td">0 × 10</td>
                <td morerows="0" valign="top" class="description-td">/* Onboard Diagnostics */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_SRC_EXDIAG</td>
                <td morerows="0" valign="top" class="description-td">0 × 20</td>
                <td morerows="0" valign="top" class="description-td">/* External Diagnostics */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_SRC_BIOS</td>
                <td morerows="0" valign="top" class="description-td">0 × 30</td>
                <td morerows="0" valign="top" class="description-td">/* BIOS */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_SRC_DOS</td>
                <td morerows="0" valign="top" class="description-td">0 × 40</td>
                <td morerows="0" valign="top" class="description-td">/* DOS */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_SRC_WIN</td>
                <td morerows="0" valign="top" class="description-td">0 × 50</td>
                <td morerows="0" valign="top" class="description-td">/* Windows,Win95 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_SRC_WINNT</td>
                <td morerows="0" valign="top" class="description-td">0 × 60</td>
                <td morerows="0" valign="top" class="description-td">/* Windows/NT */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_SRC_NETWARE</td>
                <td morerows="0" valign="top" class="description-td">0 × 70</td>
                <td morerows="0" valign="top" class="description-td">/* NetWare */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_TYPE_BINARY</td>
                <td morerows="0" valign="top" class="description-td">0 × 00</td>
                <td morerows="0" valign="top" class="description-td">/* Message data is Binary */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_TYPE_ASCII</td>
                <td morerows="0" valign="top" class="description-td">0 × 10</td>
                <td morerows="0" valign="top" class="description-td">/* Message data is ASCII */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WSLOG_TYPE_UNICODE</td>
                <td morerows="0" valign="top" class="description-td">0 × 20</td>
                <td morerows="0" valign="top" class="description-td">/* Message data is Unicode */</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* ********************************************************* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* This is the Wire Service addresses for named items. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Addresses are composed of three parts: Processor ID, Data Type and Subaddress */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* In this table the address is encoded as a 4 bytes in hexadecimal notation: */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* PPTTAAAAh where PP is the processor ID, TT is the data type and AL AH is the */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* 2 byte subaddress. Processor ID's 00 and 20 are special, 00 applies to all */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* processors and 20 applies to all canister processors. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/*</td>
                <td morerows="0" valign="top" class="description-td">PPTTALAH */</td>
                <td morerows="0" valign="top" class="description-td"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_DESCRIPTION</td>
                <td morerows="0" valign="top" class="description-td">0 × 00030100</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Wire Service Processor Type/Description */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_REVISION</td>
                <td morerows="0" valign="top" class="description-td">0 × 00030200</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Wire Service Software Revision/Date Info */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_WDOG_CALLOUT</td>
                <td morerows="0" valign="top" class="description-td">0 × 01010200</td>
                <td morerows="0" valign="top" class="description-td">/* (L) This is a bit controlling callout on a wathcdog</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">timeout. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_WDOG_RESET</td>
                <td morerows="0" valign="top" class="description-td">0 × 01010300</td>
                <td morerows="0" valign="top" class="description-td">/* (L) This is a bit controlling system on a wathcdog</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">timeout. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_NVRAM_RESET</td>
                <td morerows="0" valign="top" class="description-td">0 × 01020100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Trigger to reset NVRAM Data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_BOOTFLAG1</td>
                <td morerows="0" valign="top" class="description-td">0 × 01020200</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System Boot Flag 1 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_BOOTFLAG2</td>
                <td morerows="0" valign="top" class="description-td">0 × 01020300</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System Boot Flag 2 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_BOOTFLAG3</td>
                <td morerows="0" valign="top" class="description-td">0 × 01020400</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System Boot Flag 3 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_BOOTFLAG4</td>
                <td morerows="0" valign="top" class="description-td">0 × 01020500</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System Boot Flag 4 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_XDATA_KBYTES</td>
                <td morerows="0" valign="top" class="description-td">0 × 01020600</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Size of the WS_SYS_XDATA in</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">kilobytes */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_NVRAM_FAULTS</td>
                <td morerows="0" valign="top" class="description-td">0 × 01020700</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Faults detected in NVRAM Data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_XDATA</td>
                <td morerows="0" valign="top" class="description-td">0 × 01070000</td>
                <td morerows="0" valign="top" class="description-td">/* Byte Array for storage of arbitrary external data</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">in NVRAM */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_LOG</td>
                <td morerows="0" valign="top" class="description-td">0 × 01040000</td>
                <td morerows="0" valign="top" class="description-td">/* System Log */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_QUEUE</td>
                <td morerows="0" valign="top" class="description-td">0 × 01060100</td>
                <td morerows="0" valign="top" class="description-td">/* (Q) Queue of data going to Remote Interface */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SI_QUEUE</td>
                <td morerows="0" valign="top" class="description-td">0 × 01060200</td>
                <td morerows="0" valign="top" class="description-td">/* (Q) Queue of data going to System Interface */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_SCREEN</td>
                <td morerows="0" valign="top" class="description-td">0 × 01090000</td>
                <td morerows="0" valign="top" class="description-td">/* System Screen */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CALLOUT_SCRIPT</td>
                <td morerows="0" valign="top" class="description-td">0 × 01030300</td>
                <td morerows="0" valign="top" class="description-td">/* (S) The callout script for remote notification */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_PASSWORD</td>
                <td morerows="0" valign="top" class="description-td">0 × 01030400</td>
                <td morerows="0" valign="top" class="description-td">/* (S) The access password for Wire Service */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_BP_SERIAL</td>
                <td morerows="0" valign="top" class="description-td">0 × 01030500</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Back Plane serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_CAN_SERIAL1</td>
                <td morerows="0" valign="top" class="description-td">0 × 01030600</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Canister 1 Serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_CAN_SERIAL2</td>
                <td morerows="0" valign="top" class="description-td">0 × 01030700</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Canister 2 Serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_CAN_SERIAL3</td>
                <td morerows="0" valign="top" class="description-td">0 × 01030800</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Canister 3 Serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_CAN_SERIAL4</td>
                <td morerows="0" valign="top" class="description-td">0 × 01030900</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Canister 4 Serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_RI_SERIAL</td>
                <td morerows="0" valign="top" class="description-td">0 × 01031600</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Remote Interface serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_SB_SERIAL</td>
                <td morerows="0" valign="top" class="description-td">0 × 01031700</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known System Board serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_PS_SERIAL1</td>
                <td morerows="0" valign="top" class="description-td">0 × 01031800</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Power Supply 1 serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_PS_SERIAL2</td>
                <td morerows="0" valign="top" class="description-td">0 × 01031900</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Power Supply 2 serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_PS_SERIAL3</td>
                <td morerows="0" valign="top" class="description-td">0 × 01031a00</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Power Supply 3 serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_NAME</td>
                <td morerows="0" valign="top" class="description-td">0 × 01031b00</td>
                <td morerows="0" valign="top" class="description-td">/* (S) System Identifying Name */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BOOTDEVS</td>
                <td morerows="0" valign="top" class="description-td">0 × 01031c00</td>
                <td morerows="0" valign="top" class="description-td">/* (S) BIOS Boot drive information */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_LOG_CLOCK</td>
                <td morerows="0" valign="top" class="description-td">0 × 01031d00</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Current time from log timestamp clock (seconds)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_LOG_COUNT</td>
                <td morerows="0" valign="top" class="description-td">0 × 01031e00</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Number of Log Entry */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_MODEM_INIT</td>
                <td morerows="0" valign="top" class="description-td">0 × 01031f00</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Modem initialization string */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID01</td>
                <td morerows="0" valign="top" class="description-td">0 × 01032000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Canister Change Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID02</td>
                <td morerows="0" valign="top" class="description-td">0 × 01032100</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Power Supply Change Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID03</td>
                <td morerows="0" valign="top" class="description-td">0 × 01032200</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Queue Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID04</td>
                <td morerows="0" valign="top" class="description-td">0 × 01032300</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Temp Warn or Shut Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID05</td>
                <td morerows="0" valign="top" class="description-td">0 × 01032400</td>
                <td morerows="0" valign="top" class="description-td">/* (S) ACOK Change Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID06</td>
                <td morerows="0" valign="top" class="description-td">0 × 01032500</td>
                <td morerows="0" valign="top" class="description-td">/* (S) DCOK Change Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID07</td>
                <td morerows="0" valign="top" class="description-td">0 × 01032600</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Fan Fault Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID08</td>
                <td morerows="0" valign="top" class="description-td">0 × 01032700</td>
                <td morerows="0" valign="top" class="description-td">l* (S) Screen Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID09</td>
                <td morerows="0" valign="top" class="description-td">0 × 01032800</td>
                <td morerows="0" valign="top" class="description-td">/* (S) CPU Fault Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID0A</td>
                <td morerows="0" valign="top" class="description-td">0 × 01032900</td>
                <td morerows="0" valign="top" class="description-td">/* (S) OS_TimeOut Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CALLOUT_MASK</td>
                <td morerows="0" valign="top" class="description-td">0 × 01034000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Call Out Masking string */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BIOS_REV</td>
                <td morerows="0" valign="top" class="description-td">0 × 01034100</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Storage of current BIOS Revision */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_POWER</td>
                <td morerows="0" valign="top" class="description-td">0 × 02010100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Controls system master power 54POWER_ON</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_REQ_POWER</td>
                <td morerows="0" valign="top" class="description-td">0 × 020 10200</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Set to request main power on */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BP_P12V</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Analog Measure of +12 volt main supply */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BP_P3V</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020200</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Analog Measure of +3.3 volt main supply */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BP_N12V</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020300</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Analog Measure of −12 volt main supply */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BP_P5V</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020400</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Analog Measure of +5 volt main supply */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BP_VREF</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020500</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Analog Measure of VREF */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_BP_TYPE</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020600</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Type of system backplane currently only two</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">types Type 0 = 4 canister (small) and Type 1 = 8 canister (large) */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_CAN_PRES</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020700</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Presence bits for canisters (LSB = 1, MSB = 5)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_PS_ACOK</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020800</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Power supply ACOK status (LSB = 1, MSB = 3)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_PS_DCOK</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020900</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Power supply DCOK status (LSB = 1, MSB = 3)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_PS_PRES</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020a00</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Presence bits for power supplies (LSB = 1,</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">MSB = 3) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_RSTIMER</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020b00</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Used to delay reset/run until power stabilized</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_TEMP_SHUT</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020c00</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Shutdown temperature. Initialized to ??? */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_TEMP_WARN</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020d00</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Warming temperature. Initialized to ??? */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_WDOG</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020e00</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System watchdog timer */</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* First issues following command in phase 2 */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_OS_RESOLUTION_16</td>
                <td morerows="0" valign="top" class="description-td">0 × 04020600</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Set Resolution (0,1,2,3) of Timer1 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_OS_COUNTER_16</td>
                <td morerows="0" valign="top" class="description-td">0 × 04020700</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Set Counter from (00 FFh) of Timer1 */</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* If either operation's failed that it will response error code “02h” back, then try raptor 8 and future</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">command */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_OS_RESOLUTION_8</td>
                <td morerows="0" valign="top" class="description-td">0 × 02020f00</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Set Resolution (0,1,2,3) of Timer1 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_OS_COUNTER_8</td>
                <td morerows="0" valign="top" class="description-td">0 × 02021000</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Set Counter from (00 - FFh) of Timer1 */</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* If it's failed it is raptor 16 phase 1 that does not support watchdog */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_TEMP_DATA</td>
                <td morerows="0" valign="top" class="description-td">0 × 02030300</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Temperatures of all sensors on temperature bus</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">in address order */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FAN_HI</td>
                <td morerows="0" valign="top" class="description-td">0 × 03010100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) System Board Fans HI */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FAN_LED</td>
                <td morerows="0" valign="top" class="description-td">0 × 030 10200</td>
                <td morerows="0" valign="top" class="description-td">/* (L) System Board Fan Fault LED */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_RUN</td>
                <td morerows="0" valign="top" class="description-td">0 × 03010300</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Controls the system halt/run line S1_OK_TO_RUN. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_SB_TYPE</td>
                <td morerows="0" valign="top" class="description-td">0 × 03010400</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Set System Type (0: Raptor16 or 1:Raptor 8)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_BUSCORE</td>
                <td morerows="0" valign="top" class="description-td">0 × 03020200</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System Board BUS/CORE speed ratio to use</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">on reset */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FANFAULT</td>
                <td morerows="0" valign="top" class="description-td">0 × 03020300</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System Board Fan fault bits */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FAN_LOLIM</td>
                <td morerows="0" valign="top" class="description-td">0 × 03020400</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Fan speed low speed fault limit */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_LCD_COMMAND</td>
                <td morerows="0" valign="top" class="description-td">0 × 03020500</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Low level LCD Controller Command</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_LCD_DATA</td>
                <td morerows="0" valign="top" class="description-td">0 × 03020600</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Low level LCD Controller Data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_LCD_MSG</td>
                <td morerows="0" valign="top" class="description-td">0 × 03020700</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Send a Byte of Fault Bits from Monitor-B to Monitor-A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_DIMM_TYPE</td>
                <td morerows="0" valign="top" class="description-td">0 × 03030300</td>
                <td morerows="0" valign="top" class="description-td">/* (S) The type of DIMM in each DIMM socket as</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">a 16 byte string */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FAN_DATA</td>
                <td morerows="0" valign="top" class="description-td">0 × 03030400</td>
                <td morerows="0" valign="top" class="description-td">/* (S) System Board Fan speed data in fan number</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">order */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_LCDI</td>
                <td morerows="0" valign="top" class="description-td">0 × 03030500</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Value to display on LCD Top line */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_LCD2</td>
                <td morerows="0" valign="top" class="description-td">0 × 03030600</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Value to display on LCD Bottom line */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_LCD_STRING</td>
                <td morerows="0" valign="top" class="description-td">0 × 03030700</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Low Level LCD Display string at current</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">position */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_MESSAGE</td>
                <td morerows="0" valign="top" class="description-td">0 × 03030800</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Value to stored from LCD Messages */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_NMI_REG</td>
                <td morerows="0" valign="top" class="description-td">0 × 04010100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) NMI Request bit */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_CPU_FAULT</td>
                <td morerows="0" valign="top" class="description-td">0 × 04010200</td>
                <td morerows="0" valign="top" class="description-td">/* (L) CPU Fault Summary */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FLASH_ENA</td>
                <td morerows="0" valign="top" class="description-td">0 × 04010300</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates FLASH ROW write enabled */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FRU_FAULT</td>
                <td morerows="0" valign="top" class="description-td">0 × 04010400</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates the FRU status */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_JTAG</td>
                <td morerows="0" valign="top" class="description-td">0 × 04010500</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Enables JTAG chain on system board */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYSFAULT</td>
                <td morerows="0" valign="top" class="description-td">0 × 04010600</td>
                <td morerows="0" valign="top" class="description-td">/* (L) System Fault Summary */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_OVERTEMP</td>
                <td morerows="0" valign="top" class="description-td">0 × 04010700</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates Overtemp fault */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN1_FAN_SYSFLT</td>
                <td morerows="0" valign="top" class="description-td">0 × 04010800</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates Canister #1 Fan System Fault</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN2_FAN_SYSFLT</td>
                <td morerows="0" valign="top" class="description-td">0 × 04010900</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates Canister #2 Fan System Fault</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN3_FAN_SYSFLT</td>
                <td morerows="0" valign="top" class="description-td">0 × 0401A00</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates Canister #3 Fan System Fault</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN4_FAN_SYSFLT</td>
                <td morerows="0" valign="top" class="description-td">0 × 04010B00</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates Canister #4 Fan System Fault</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_NMI_MASK</td>
                <td morerows="0" valign="top" class="description-td">0 × 04020100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) CPU NMI processor mask (LSB = CPU1) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_CPU_ERR</td>
                <td morerows="0" valign="top" class="description-td">0 × 04020200</td>
                <td morerows="0" valign="top" class="description-td">/* (B) CPU Error bits (LSB = CPU1) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_CPU_POK</td>
                <td morerows="0" valign="top" class="description-td">0 × 04020300</td>
                <td morerows="0" valign="top" class="description-td">/* (B) CPU Power OK (LSB = CPU1) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_CPU_PRES</td>
                <td morerows="0" valign="top" class="description-td">0 × 04020400</td>
                <td morerows="0" valign="top" class="description-td">/* (B) CPU Presence bits (LSB = CPU1) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_CPU_TEMP</td>
                <td morerows="0" valign="top" class="description-td">0 × 04020500</td>
                <td morerows="0" valign="top" class="description-td">/* (B) CPU Thermal fault bits (LSB = CPU1) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SI_EVENTS</td>
                <td morerows="0" valign="top" class="description-td">0 × 10050100</td>
                <td morerows="0" valign="top" class="description-td">/* (E) System Interface Event Queue */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_CD</td>
                <td morerows="0" valign="top" class="description-td">0 × 11010100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Status of Remote Port Modern CD */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_CTS</td>
                <td morerows="0" valign="top" class="description-td">0 × 11010200</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Status of Remote Port Modern CTS */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_DSR</td>
                <td morerows="0" valign="top" class="description-td">0 × 11010300</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Status of Remote Port Modem DSR */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_DTR</td>
                <td morerows="0" valign="top" class="description-td">0 × 11010400</td>
                <td morerows="0" valign="top" class="description-td">/* (L) State of Remote Port Modern DTR */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_RTS</td>
                <td morerows="0" valign="top" class="description-td">0 × 11010500</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Status of Remote Port Modem RTS */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_CALLOUT</td>
                <td morerows="0" valign="top" class="description-td">0 × 11020100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Controls Call out Script activation */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CALLOUT_STATUS</td>
                <td morerows="0" valign="top" class="description-td">0 × 11020200</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Read Call Out Status */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_EVENTS</td>
                <td morerows="0" valign="top" class="description-td">0 × 11050100</td>
                <td morerows="0" valign="top" class="description-td">/* (E) Remote Interface Event Queue */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_FAN_HI</td>
                <td morerows="0" valign="top" class="description-td">0 × 20010100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Canister Fans HI */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_FAN_LED</td>
                <td morerows="0" valign="top" class="description-td">0 × 20010200</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Canister Fan Fault LED */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_POWER</td>
                <td morerows="0" valign="top" class="description-td">0 × 20010500</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Controls canister PCI slot power */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_55_PRESENT</td>
                <td morerows="0" valign="top" class="description-td">0 × 20010600</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates the presence of something in slot 5</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_CAN_TYPE</td>
                <td morerows="0" valign="top" class="description-td">0 × 20010700</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Set System Type (O: Raptor16 or 1:Raptor 8)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_FAN_LOLIM</td>
                <td morerows="0" valign="top" class="description-td">0 × 20020100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Fan Low speed fault limit */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_PCI_PRESENT</td>
                <td morerows="0" valign="top" class="description-td">0 × 20020200</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Reflects PCI card slot[1 . . . 4] presence</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">indicator pins (MSB to LSB) 4B,4A,3B,3A,2B,2A,1B,1A */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_FANFAULT</td>
                <td morerows="0" valign="top" class="description-td">0 × 20020300</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Canister Fan Fault Bits */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_PCI_SLOT_PWR</td>
                <td morerows="0" valign="top" class="description-td">0 × 20020400</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Turn on/off PCI Slot of Raptor 8 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_FAN_DATA</td>
                <td morerows="0" valign="top" class="description-td">0 × 20030300</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Canister Fan speed data */</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* ********************************************************* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* This is the Wire Service Attributes for named items. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* The attribute information is stored in a symbolic constant named the same */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* as the named item then followed by two underscores */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* Attributes consist of: */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/*  RIW access for internal WS (I), BIOS/OS (0), administrator (A), and general (G) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/*  groups. (0 = NoAccess 1 = Read Only, 2 = Write Only, 3 = Read/Write) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/*  maximum possible reques/response length of item in bytes (LL) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/*  Group Name ID (ID) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/*       IOAGLLID */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_DESCRIPTION<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11114000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Wire Service Processor Type/Description */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_REVISION<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11112000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Wire Service Software Revision/Date Info */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_WDOG_CALLOUT</td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) This is a bit controlling callout on a</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">wathcdog timeout. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_WDOG_RESET<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) This is a bit controlling system on a wathcdog</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">timeout. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_NVRAM_RESET<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 22200100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Trigger to reset NVRAM Data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_BOOTFLAG1</td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System Boot Flag 1 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_BOOTFLAG2</td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System Boot Flag 2 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_BOOTFLAG3</td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System Boot Flag 3 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_BOOTFLAG4</td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System Boot Flag 4 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_XDATK_KBYTES<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Size of the WS_SYS_XDATA in</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">kilobytes */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_XDATA<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 3331ff00</td>
                <td morerows="0" valign="top" class="description-td">/* Byte Array for storage of arbitrary external data</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">in NVRAM */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_NVRAM_FAULTS</td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Faults detected in NVRAM Data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_LOG<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 3311ff00</td>
                <td morerows="0" valign="top" class="description-td">/* System Log */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_QUEUE<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 3300ff00</td>
                <td morerows="0" valign="top" class="description-td">/* (0) Queue of data going to Remote Interface */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SI_QUEUE<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 3300ff00</td>
                <td morerows="0" valign="top" class="description-td">/* (0) Queue of data going to System Interface */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_SCREEN<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 3311ff00</td>
                <td morerows="0" valign="top" class="description-td">/* System Screen */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CALLOUT_SCRIPT</td>
                <td morerows="0" valign="top" class="description-td">0 × 3330ff00</td>
                <td morerows="0" valign="top" class="description-td">/* (S) The callout script for remote</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">notification */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_PASSWORD<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33301000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) The access password for Wire Service */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_BP_SERIAL<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known BackPlane serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_CAN_SERIAL 1<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Canister 1 Serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_CAN_SERIAL2<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Canister 2 Serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_CAN_SERIAL3<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Canister 3 Serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_CAN_SERIAL4<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Canister 4 Serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_RI_SERIAL<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Remote Interface serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_SB_SERIAL<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known System Board serial data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_PS_SERIAL1<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Power Supply 1 serial data</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_PS_SERIAL2<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Power Supply 2 serial data</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_PS_SERIAL3<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Last known Power Supply 3 serial data</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_NAME<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33312000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) System Identifying Name */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BOOTDEVS<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 3331ff00</td>
                <td morerows="0" valign="top" class="description-td">/* (S) BIOS Boot drive information */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_LOG_CLOCK</td>
                <td morerows="0" valign="top" class="description-td">0 × 11110400</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Current time from log timestamp clock</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">(seconds) *J</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_LOG_COUNT</td>
                <td morerows="0" valign="top" class="description-td">0 × 11110200</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Number of Log entries */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_MODEM_INIT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33315000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Modern initialization string */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID01<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Canister Change Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID02<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Power Supply Change Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID03<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Queue Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID04<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Temp Warn or Shut Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID05<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) ACOK Change Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID06<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) DCOK Change Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID07<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Fan Fault Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID05<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Screen Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID09<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) CPU Fault Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_EVENT_ID0A<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) OS_TimeOut Event */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CALLOUT_MASK<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31110200</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Call Out Masking string */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BIOS_REV<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 31111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Storage of current BIOS Revision */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_POWER<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Controls system master power S4_POWER_ON</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_REGPOWER<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 22200100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Set to request main power on */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BP_P2V<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Analog Measure of +12 volt main supply */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BP_P3V<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Analog Measure of +3.3 volt main supply */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BP_NI2V<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Analog Measure of −12 volt main supply */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BP_P5V<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Analog Measure of +5 volt main supply *1</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_BP_VREF<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Analog Measure of VREF */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_BP_TYPE<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Type of system backplane currently only two</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">types Type 0 = 4 canister (small) and Type 1 = 8 canister (large) */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_CAN_PRES<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Presence bits for canisters (LSB = 1, MSB = 8)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_PS_ACOK<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Power supply ACOK status (LSB = 1, MSB = 3)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_PS_DCOK<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Power supply DCOK status (LSB = 1, MSB = 3)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_PS_PRES<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Presence bits for power supplies (LSB = 1,</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">MSB = 3) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_RSTIMER<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Used to delay reset/run until power stabilized</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_TEMP_SHUT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Shutdown temperature. Initialized to</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">??? */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_TEMP_WARN<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Warning temperature. Initialized to ???</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_WDOG<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System watchdog timer #1</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* First issues following command in phase 2 */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_05_RESOLUTION_16<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Set Resolution (0,1,2,3) of Timer1 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_05_COUNTER_16</td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Set Counter from (00 - FFh) of Timer1</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* If either operation's failed that it will response error code “02h” back, then try raptor 8 and future</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">command */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_05_RESOLUTION_8<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) SetResolution (0,1,2,3) of Timer1 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_05_COUNTER_8<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Set Counter from (00 - FFh) of Timer1 */</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">/* If it's failed it is raptor 16 phase 1 that does not support watchdog */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_TEMP_DATA<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110500</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Temperatures of all sensors on</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">temperature bus in address order */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FAN_HI<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) System Board Fans HI */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FAN_LED<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) System Board Fan Fault LED */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_RUN<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Controls the system halt/run line</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">S_OK_TO_RUN. */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_SB_TYPE<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Set System Type (0:Raptor 16 or 1:Raptor 8)</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">*/</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_BUSCORE<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System Board BUS/CORE speed ratio to use</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">on reset */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FANFAULT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) System Board Fan fault bits */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FAN_LOLIM<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Fan speed low speed fault limit */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_LCD_COMMAND<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 22000100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Low Level LCD Controller Command</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_LCD_DATA<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 22000100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Low level LCD Controller Data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">*/</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_LCD_MSG<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Send a Byte of Fault Bits from Monitor-B to</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Monitor-A */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_DIMM_TYPE<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11111000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) The type of DIMM in each DIMM socket as</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">a 16 byte string */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FAN_DATA<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110600</td>
                <td morerows="0" valign="top" class="description-td">/* (S) System Board Fan speed data in fan number</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">order */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_LCD1<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33311000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Value to display on LCD Top line */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_LCD2<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33311000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Value to display on LCD Bottom line */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_LCD_STRING<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 22004000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Low Level LCD Display string at current</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">position */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_MESSAGE<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11112000</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Value to stored from LCD Messages */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_NMI_REG</td>
                <td morerows="0" valign="top" class="description-td">0 × 22200100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) NMI Request bit */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_CPU_FAULT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) CPU Fault Summary */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FLASH_ENA<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates FLASH ROW write enabled */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_FRU_FAULT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates the FRU status */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_JTAG<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Enables JTAG chain on system board */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYSFAULT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) System Fault Summary */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_OVERTEMP<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates Overtemp fault */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN1_FAN_SYSFLT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates Canister #1 Fan System Fault</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN2_FAN_SYSFLT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates Canister #2 Fan System Fault</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN3_FAN_SYSFLT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates Canister #3 Fan System Fault</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN4_FAN_SYSFLT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates Canister #4 Fan System Fault</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_NMI_MASK<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) CPU NMI processor mask (LSB = CPUI) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_CPU_ERR<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) CPU Error bits (LSB = CPUI) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_CPU_POK<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) CPU Power OK (LSB = CPUI) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_CPU_PRES<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) CPU Presence bits (LSB = CPUI) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SB_CPU_TEMP<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) CPU Thermal fault bits (LSB = CPUI) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SI_EVENTS<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33001000</td>
                <td morerows="0" valign="top" class="description-td">/* (E) System Interface Event Queue */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_CD<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Status of Remote Port Modern CD */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_CTS<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Status of Remote Port Modern CTS */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_DSR<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Status of Remote Port Modern DSR */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_DTR<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) State of Remote Port Modern DTR */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_RTS<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Status of Remote Port Modern RTS */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_CALLOUT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Controls Call out Script activation */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CALLOUT_STATUS<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Read Call Out Status */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_RI_EVENTS<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33002000</td>
                <td morerows="0" valign="top" class="description-td">/* (E) Remote Interface Event Queue */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_FAN_HI<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Canister Fans HI */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_FAN_LED<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Canister Fan Fault LED */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_POWER<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Controls canister PCI slot power */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_55_PRESENT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Indicates the presence of something</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">in slot 5 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_SYS_CAN_TYPE<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (L) Set System Type (O: Raptor 16 of 1: Raptor</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">8) */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_FAN_LOLIM</td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">J* (B) Fan low speed fault limit */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_PCI_PRESENT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Reflects PCI card slot[1 . . . 4] presence</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">indicator pins (MSB to LSB) 4B,4A,3B,3A,2B,2A,1B,1A */</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="126PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="189PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_FANFAULT<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Canister Fan Fault Bits */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_PCI_SLOT_PWR<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 33310100</td>
                <td morerows="0" valign="top" class="description-td">/* (B) Turn on/off PCI Slot of Raptor 8 */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#define WS_CAN_FAN_DATA<sub>—</sub> </td>
                <td morerows="0" valign="top" class="description-td">0 × 11110200</td>
                <td morerows="0" valign="top" class="description-td">/* (S) Canister Fan speed data */</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#ifndef FAR_POINTERS</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#ifndef NEAR_POINTERS</td>
              </tr> </tbody> </tgroup> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="364PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#include “***ERROR - Pointer Type not defined”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#endif</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">#endif</td>
              </tr> <tr class="description-tr"> <td namest="1" nameend="1" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="1"> </td>
              </tr> </tbody> </tgroup> </table> </tables> </p>
    <p>
      <tables> <table frame="none" colsep="0" rowsep="0" pgwide="1" class="description-table"> <tgroup cols="1" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="center" colwidth="273PT"> </colspec> <thead valign="bottom"> <tr class="description-tr"> <td namest="1" nameend="1" morerows="0" rowsep="1" valign="top" class="description-td" colspan="1">APPENDIX A</td>
              </tr> </thead> <tbody valign="top"> <tr class="description-tr"> <td namest="1" nameend="1" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="1"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Incorporation by Reference of Commonly Owned Applications</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">The following patent applications, commonly owned and filed October 1, 1997,</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">are hereby incorporated herein in their entirety by reference thereto:</td>
              </tr> </tbody> </tgroup> <tgroup cols="3" colsep="0" rowsep="0" align="left"> <colspec colname="1" align="left" colwidth="147PT"> </colspec> <colspec colname="2" align="left" colwidth="49PT"> </colspec> <colspec colname="3" align="left" colwidth="77PT"> </colspec> <tbody valign="top"> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td"> </td>
                <td morerows="0" valign="top" class="description-td">Application</td>
                <td morerows="0" valign="top" class="description-td">Attorney Docket</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Title</td>
                <td morerows="0" valign="top" class="description-td">No.</td>
                <td morerows="0" valign="top" class="description-td">No.</td>
              </tr> <tr class="description-tr"> <td namest="1" nameend="3" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="3"> </td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System Architecture for Remote Access</td>
                <td morerows="0" valign="top" class="description-td">08/942,160</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.002A1</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">and Control of Environmental</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Management”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method of Remote Access and Control of</td>
                <td morerows="0" valign="top" class="description-td">08/942,215</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.002A2</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Environmental Management”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System for Independent Powering of</td>
                <td morerows="0" valign="top" class="description-td">08/942,410</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.002A3</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Diagnostic Processes on a Computer</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">System”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method of Independent Powering of</td>
                <td morerows="0" valign="top" class="description-td">08/942,320</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.002A4</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Diagnostic Processes on a Computer</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">System”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Diagnostic and Managing Distributed</td>
                <td morerows="0" valign="top" class="description-td">08/942,402</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.005A1</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Processor System”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for Managing a Distributed</td>
                <td morerows="0" valign="top" class="description-td">08/942,448</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.005A2</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Processor System”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System for Mapping Environmental</td>
                <td morerows="0" valign="top" class="description-td">08/942,222</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.005A3</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Resources to Memory for Program Access”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Hot Add of Devices Software</td>
                <td morerows="0" valign="top" class="description-td">08/942,309</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.006A1</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Architecture”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for The Hot Add of Devices”</td>
                <td morerows="0" valign="top" class="description-td">08/942,306</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.006A2</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Hot Swap of Devices Software</td>
                <td morerows="0" valign="top" class="description-td">08/942,311</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.006A3</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Architecture”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for The Hot Swap of Devices”</td>
                <td morerows="0" valign="top" class="description-td">08/942,457</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.006A4</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for the Hot Add of a Network</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Adapter on a System Including a</td>
                <td morerows="0" valign="top" class="description-td">08/943,072</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.006A5</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Dynamically Loaded Adapter Driver”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for the Hot Add of a Mass</td>
                <td morerows="0" valign="top" class="description-td">08/942,069</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.006A6</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Storage Adapter on a System Including a</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Statically Loaded Adapter Driver”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for the Hot Add of a Network</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Adapter on a System Including a Statically</td>
                <td morerows="0" valign="top" class="description-td">08/942,465</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.006A7</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Loaded Adapter Driver”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for the Hot Add of a Mass</td>
                <td morerows="0" valign="top" class="description-td">08/962,963 </td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.006A8</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Storage Adapter on a System Including a</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Dynamically Loaded Adapter Driver”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for the Hot Swap of a Network</td>
                <td morerows="0" valign="top" class="description-td">08/943,078</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.006A9</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Adapter on a System Including a</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Dynamically Loaded Adapter Driver”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for the Hot Swap of a Mass</td>
                <td morerows="0" valign="top" class="description-td">08/942,336</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.006A10</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Storage Adapter on a System Including a</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Statically Loaded Adapter Driver”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for the Hot Swap of a Network</td>
                <td morerows="0" valign="top" class="description-td">08/942,459</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.006A11</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Adapter on a System Including a Statically</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Loaded Adapter Driver”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for the Hot Swap of a Mass</td>
                <td morerows="0" valign="top" class="description-td">08/942,458</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.006A12</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Storage Adapter on a System Including a</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Dynamically Loaded Adapter Driver”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method of Performing an Extensive</td>
                <td morerows="0" valign="top" class="description-td">08/942,463</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.008A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Diagnostic Test in Conjunction with a</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">BIOS Test Routine”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Apparatus for Performing an Extensive</td>
                <td morerows="0" valign="top" class="description-td">08/942,163</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.009A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Diagnostic Test in Conjunction with a</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">BIOS Test Routine”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Configuration Management Method for</td>
                <td morerows="0" valign="top" class="description-td">08/941,268</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.010A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Hot Adding and Hot Replacing Devices”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Configuration Management System for</td>
                <td morerows="0" valign="top" class="description-td">08/942,408</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.011A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Hot Adding and Hot Replacing Devices”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Apparatus for Interfacing Buses”</td>
                <td morerows="0" valign="top" class="description-td">08/942,382</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.012A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for Interfacing Buses”</td>
                <td morerows="0" valign="top" class="description-td">08/942,413</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.013A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Computer Fan Speed Control Device”</td>
                <td morerows="0" valign="top" class="description-td">08/942,447</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.016A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Computer Fan Speed Control Method”</td>
                <td morerows="0" valign="top" class="description-td">08/942,216</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.017A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System for Powering Up and Powering</td>
                <td morerows="0" valign="top" class="description-td">08/943,076</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.018A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Down a Server”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method of Powering Up and Powering</td>
                <td morerows="0" valign="top" class="description-td">08/943,077</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.019A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Down a Server”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System for Resetting a Server”</td>
                <td morerows="0" valign="top" class="description-td">03/942,333</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.020A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method of Resetting a Server”</td>
                <td morerows="0" valign="top" class="description-td">08/942,405</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.021A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System for Displaying Flight Recorder”</td>
                <td morerows="0" valign="top" class="description-td">08/942,070</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.022A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method of Displaying Flight Recorder”</td>
                <td morerows="0" valign="top" class="description-td">03/942,068</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.023A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Synchronous Communication Interface”</td>
                <td morerows="0" valign="top" class="description-td">03/943,355</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.024A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Synchronous Communication Emulation”</td>
                <td morerows="0" valign="top" class="description-td">08/942,004</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.025A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Software System Facilitating the</td>
                <td morerows="0" valign="top" class="description-td">08/942,317</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.026A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Replacement or Insertion of Devices in a</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Computer System”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for Facilitating the Replacement</td>
                <td morerows="0" valign="top" class="description-td">08/942,316</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.027A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">or Insertion of Devices in a Computer</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">System”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System Management Oraphical User</td>
                <td morerows="0" valign="top" class="description-td">08/943,357</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.028A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Interface”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Display of System Information”</td>
                <td morerows="0" valign="top" class="description-td">03/942,195</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.029A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Data Management System Supporting Hot</td>
                <td morerows="0" valign="top" class="description-td">08/942,129</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.030A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Plug Operations on a Computer”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Data Management Method Supporting</td>
                <td morerows="0" valign="top" class="description-td">08/942,124</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.031A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Hot Plug Operations on a Computer”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Alert Configurator and Manager”</td>
                <td morerows="0" valign="top" class="description-td">08/942,005</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.032A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Managing Computer System Alerts”</td>
                <td morerows="0" valign="top" class="description-td">08/943,356</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.033A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Computer Fan Speed Control System”</td>
                <td morerows="0" valign="top" class="description-td">08/940,301</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.034A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Computer Fan Speed Control System</td>
                <td morerows="0" valign="top" class="description-td">03/941,267</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.035A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Method”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Black Box Recorder for Information</td>
                <td morerows="0" valign="top" class="description-td">08/942,381</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.036A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">System Events”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method of Recording Information System</td>
                <td morerows="0" valign="top" class="description-td">08/942,164</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.037A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Events”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for Automatically Reporting a</td>
                <td morerows="0" valign="top" class="description-td">03/942,168</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.040A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">System Failure in a Server”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System for Automatically Reporting a</td>
                <td morerows="0" valign="top" class="description-td">08/942,384</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.041A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">System Failure in a Server”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Expansion of PCI Bus Loading Capacity”</td>
                <td morerows="0" valign="top" class="description-td">08/942,404</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.042A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for Expanding PCI Bus Loading</td>
                <td morerows="0" valign="top" class="description-td">08/942,223</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.043A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Capacity”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System for Displaying System Status”</td>
                <td morerows="0" valign="top" class="description-td">08/942,347</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.044A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method of Displaying System Status”</td>
                <td morerows="0" valign="top" class="description-td">08/942,071</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.045A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Fault Tolerant Computer System”</td>
                <td morerows="0" valign="top" class="description-td">08/942,194</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.046A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for Hot Swapping of Network</td>
                <td morerows="0" valign="top" class="description-td">08/943,044</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.047A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Components”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“A Method for Communicating a Software</td>
                <td morerows="0" valign="top" class="description-td">08/942,221</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.048A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Generated Pulse Waveform Between Two</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Servers in a Network”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“A System for Communicating a Software</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Generated Pulse Waveform Between Two</td>
                <td morerows="0" valign="top" class="description-td">08/942,409</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.049A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Servers in a Network”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for Clustering Software</td>
                <td morerows="0" valign="top" class="description-td">08/942,318</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.050A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Applications”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System for Clustering Software</td>
                <td morerows="0" valign="top" class="description-td">08/942,411</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.051A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Applications”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method for Automatically Configuring a</td>
                <td morerows="0" valign="top" class="description-td">08/942,319</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.052A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Server after Hot Add of a Device”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System for Automatically Configuring a</td>
                <td morerows="0" valign="top" class="description-td">08/942,331</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.053A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Server after Hot Add of a Device”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method of Automatically Configuring and</td>
                <td morerows="0" valign="top" class="description-td">08/942,412</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.054A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Formatting a Computer System and</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Installing Software”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System for Automatically Configuring</td>
                <td morerows="0" valign="top" class="description-td">08/941,955</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.055A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">and Formatting a Computer System and</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Installing Software”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Determining Slot Numbers in a</td>
                <td morerows="0" valign="top" class="description-td">08/942,462</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.056A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">Computer”</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System for Detecting Errors in a Network”</td>
                <td morerows="0" valign="top" class="description-td">08/942,169</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.058A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method of Detecting Errors in a Network”</td>
                <td morerows="0" valign="top" class="description-td">08/940,302</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.059A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“System for Detecting Network Errors”</td>
                <td morerows="0" valign="top" class="description-td">08/942,407</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.060A</td>
              </tr> <tr class="description-tr"> <td morerows="0" valign="top" class="description-td">“Method of Detecting Network Errors”</td>
                <td morerows="0" valign="top" class="description-td">08/942,573</td>
                <td morerows="0" valign="top" class="description-td">MNFRAME.061A</td>
              </tr> <tr class="description-tr"> <td namest="1" nameend="3" morerows="0" rowsep="1" valign="top" align="center" class="description-td" colspan="3"> </td>
              </tr> </tbody> </tgroup> </table> </tables> </p>
    </div></div></div><div class="patent-section patent-tabular-section"><a id="backward-citations"></a><div class="patent-section-header"><span class="patent-section-title">Patent Citations</span></div><table class="patent-data-table"><thead class="patent-data-table-thead"><tr class="patent-data-table"><th class="patent-data-table-th">Cited Patent</th><th class="patent-data-table-th">Filing date</th><th class="patent-data-table-th">Publication date</th><th class="patent-data-table-th">Applicant</th><th class="patent-data-table-th">Title</th></tr></thead><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US4057847">US4057847</a></td><td class="patent-data-table-td patent-date-value">Jun 14, 1976</td><td class="patent-data-table-td patent-date-value">Nov 8, 1977</td><td class="patent-data-table-td ">Sperry Rand Corporation</td><td class="patent-data-table-td ">Remote controlled test interface unit</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US4100597">US4100597</a></td><td class="patent-data-table-td patent-date-value">Apr 2, 1976</td><td class="patent-data-table-td patent-date-value">Jul 11, 1978</td><td class="patent-data-table-td ">International Business Machines Corporation</td><td class="patent-data-table-td ">Computer controlled distribution apparatus for distributing transactions to and from controlled machine tools having means independent of the computer for completing or stopping a tool function initiated by a computer transaction</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US4449182">US4449182</a></td><td class="patent-data-table-td patent-date-value">Oct 5, 1981</td><td class="patent-data-table-td patent-date-value">May 15, 1984</td><td class="patent-data-table-td ">Digital Equipment Corporation</td><td class="patent-data-table-td ">Interface between a pair of processors, such as host and peripheral-controlling processors in data processing systems</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US4672535">US4672535</a></td><td class="patent-data-table-td patent-date-value">Mar 18, 1985</td><td class="patent-data-table-td patent-date-value">Jun 9, 1987</td><td class="patent-data-table-td ">Tandem Computers Incorporated</td><td class="patent-data-table-td ">Multiprocessor system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US4692918">US4692918</a></td><td class="patent-data-table-td patent-date-value">Dec 17, 1984</td><td class="patent-data-table-td patent-date-value">Sep 8, 1987</td><td class="patent-data-table-td ">At&amp;T Bell Laboratories</td><td class="patent-data-table-td ">In a distributed processing system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US4695946">US4695946</a></td><td class="patent-data-table-td patent-date-value">Oct 25, 1984</td><td class="patent-data-table-td patent-date-value">Sep 22, 1987</td><td class="patent-data-table-td ">Unisys Corporation</td><td class="patent-data-table-td ">Maintenance subsystem for computer network including power control and remote diagnostic center</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US4769764">US4769764</a></td><td class="patent-data-table-td patent-date-value">Aug 11, 1986</td><td class="patent-data-table-td patent-date-value">Sep 6, 1988</td><td class="patent-data-table-td ">Isaac Levanon</td><td class="patent-data-table-td ">Modular computer system with portable travel unit</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US4774502">US4774502</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Jul 27, 1987</td><td class="patent-data-table-td patent-date-value">Sep 27, 1988</td><td class="patent-data-table-td ">Nittan Co., Ltd.</td><td class="patent-data-table-td ">Environmental abnormality detection apparatus</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US4821180">US4821180</a></td><td class="patent-data-table-td patent-date-value">Feb 25, 1985</td><td class="patent-data-table-td patent-date-value">Apr 11, 1989</td><td class="patent-data-table-td ">Itt Corporation</td><td class="patent-data-table-td ">Device interface controller for intercepting communication between a microcomputer and peripheral devices to control data transfers</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US4894792">US4894792</a></td><td class="patent-data-table-td patent-date-value">Sep 30, 1988</td><td class="patent-data-table-td patent-date-value">Jan 16, 1990</td><td class="patent-data-table-td ">Tandy Corporation</td><td class="patent-data-table-td ">Portable computer with removable and replaceable add-on modules</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5007431">US5007431</a></td><td class="patent-data-table-td patent-date-value">May 3, 1988</td><td class="patent-data-table-td patent-date-value">Apr 16, 1991</td><td class="patent-data-table-td ">Care Systems, Inc.</td><td class="patent-data-table-td ">Apparatus and method for updated recording of irregularities in an electrocardiogram waveform</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5033048">US5033048</a></td><td class="patent-data-table-td patent-date-value">Apr 19, 1990</td><td class="patent-data-table-td patent-date-value">Jul 16, 1991</td><td class="patent-data-table-td ">Digital Equipment Corporation</td><td class="patent-data-table-td ">Memory selftest method and apparatus same</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5051720">US5051720</a></td><td class="patent-data-table-td patent-date-value">Nov 13, 1989</td><td class="patent-data-table-td patent-date-value">Sep 24, 1991</td><td class="patent-data-table-td ">Secure Telecom, Inc.</td><td class="patent-data-table-td ">Remote control system using power line of remote site</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5073932">US5073932</a></td><td class="patent-data-table-td patent-date-value">Aug 31, 1990</td><td class="patent-data-table-td patent-date-value">Dec 17, 1991</td><td class="patent-data-table-td ">Oded Yossifor</td><td class="patent-data-table-td ">Secured data transmission and error recovery mechanism in cordless telephones</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5103391">US5103391</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">May 31, 1989</td><td class="patent-data-table-td patent-date-value">Apr 7, 1992</td><td class="patent-data-table-td ">M. T. Mcbrian Inc.</td><td class="patent-data-table-td ">Control system for controlling environmental conditions in a closed building or other conditions</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5118970">US5118970</a></td><td class="patent-data-table-td patent-date-value">Dec 8, 1990</td><td class="patent-data-table-td patent-date-value">Jun 2, 1992</td><td class="patent-data-table-td ">Storage Technology Corporation</td><td class="patent-data-table-td ">Controller for disabling a data bus</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5121500">US5121500</a></td><td class="patent-data-table-td patent-date-value">May 13, 1991</td><td class="patent-data-table-td patent-date-value">Jun 9, 1992</td><td class="patent-data-table-td ">International Business Machines Corporation</td><td class="patent-data-table-td ">Preliminary polling for identification and location of removable/replaceable computer components prior to power-up</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5136708">US5136708</a></td><td class="patent-data-table-td patent-date-value">Apr 3, 1990</td><td class="patent-data-table-td patent-date-value">Aug 4, 1992</td><td class="patent-data-table-td ">Oce-Nederland B.V.</td><td class="patent-data-table-td ">Distributed office automation system with specific task assignment among workstations</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5136715">US5136715</a></td><td class="patent-data-table-td patent-date-value">May 30, 1989</td><td class="patent-data-table-td patent-date-value">Aug 4, 1992</td><td class="patent-data-table-td ">Fujitsu Limited</td><td class="patent-data-table-td ">Terminal apparatus for resetting by remote control</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5138619">US5138619</a></td><td class="patent-data-table-td patent-date-value">Feb 15, 1990</td><td class="patent-data-table-td patent-date-value">Aug 11, 1992</td><td class="patent-data-table-td ">National Semiconductor Corporation</td><td class="patent-data-table-td ">Built-in self test for integrated circuit memory</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5157663">US5157663</a></td><td class="patent-data-table-td patent-date-value">Sep 24, 1990</td><td class="patent-data-table-td patent-date-value">Oct 20, 1992</td><td class="patent-data-table-td ">Novell, Inc.</td><td class="patent-data-table-td ">Fault tolerant computer system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5210855">US5210855</a></td><td class="patent-data-table-td patent-date-value">Oct 7, 1992</td><td class="patent-data-table-td patent-date-value">May 11, 1993</td><td class="patent-data-table-td ">International Business Machines Corporation</td><td class="patent-data-table-td ">System for computer peripheral bus for allowing hot extraction on insertion without disrupting adjacent devices</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5245615">US5245615</a></td><td class="patent-data-table-td patent-date-value">Jun 6, 1991</td><td class="patent-data-table-td patent-date-value">Sep 14, 1993</td><td class="patent-data-table-td ">International Business Machines Corporation</td><td class="patent-data-table-td ">Diagnostic system and interface for a personal computer</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5247683">US5247683</a></td><td class="patent-data-table-td patent-date-value">Jun 19, 1991</td><td class="patent-data-table-td patent-date-value">Sep 21, 1993</td><td class="patent-data-table-td ">International Business Machines Corporation</td><td class="patent-data-table-td ">System and method for installing software and updating configuration files</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5253348">US5253348</a></td><td class="patent-data-table-td patent-date-value">Sep 25, 1992</td><td class="patent-data-table-td patent-date-value">Oct 12, 1993</td><td class="patent-data-table-td ">Apple Computer, Inc.</td><td class="patent-data-table-td ">Method of arbitration for buses operating at different speeds</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5265098">US5265098</a></td><td class="patent-data-table-td patent-date-value">Aug 3, 1990</td><td class="patent-data-table-td patent-date-value">Nov 23, 1993</td><td class="patent-data-table-td ">International Business Machines Corporation</td><td class="patent-data-table-td ">Method and means for managing DASD array accesses when operating in degraded mode</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5266838">US5266838</a></td><td class="patent-data-table-td patent-date-value">Dec 5, 1991</td><td class="patent-data-table-td patent-date-value">Nov 30, 1993</td><td class="patent-data-table-td ">Thinking Machines Corporation</td><td class="patent-data-table-td ">Power supply system including power sharing control arrangement</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5272382">US5272382</a></td><td class="patent-data-table-td patent-date-value">Sep 9, 1991</td><td class="patent-data-table-td patent-date-value">Dec 21, 1993</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">Power supply for computer system manager</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5276863">US5276863</a></td><td class="patent-data-table-td patent-date-value">Jun 28, 1991</td><td class="patent-data-table-td patent-date-value">Jan 4, 1994</td><td class="patent-data-table-td ">Digital Equipment Corporation</td><td class="patent-data-table-td ">Computer system console</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5277615">US5277615</a></td><td class="patent-data-table-td patent-date-value">Sep 24, 1992</td><td class="patent-data-table-td patent-date-value">Jan 11, 1994</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">Apparatus for removably supporting a plurality of hot plug-connected hard disk drives</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5280621">US5280621</a></td><td class="patent-data-table-td patent-date-value">Feb 17, 1993</td><td class="patent-data-table-td patent-date-value">Jan 18, 1994</td><td class="patent-data-table-td ">Zenith Data Systems Corporation</td><td class="patent-data-table-td ">Personal computer having dedicated processors for peripheral devices interconnected to the CPU by way of a system control processor</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5283905">US5283905</a></td><td class="patent-data-table-td patent-date-value">Jun 24, 1991</td><td class="patent-data-table-td patent-date-value">Feb 1, 1994</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">Power supply for computer system manager</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5311397">US5311397</a></td><td class="patent-data-table-td patent-date-value">Aug 6, 1992</td><td class="patent-data-table-td patent-date-value">May 10, 1994</td><td class="patent-data-table-td ">Logistics Management Inc.</td><td class="patent-data-table-td ">Computer with modules readily replaceable by unskilled personnel</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5311451">US5311451</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Dec 6, 1991</td><td class="patent-data-table-td patent-date-value">May 10, 1994</td><td class="patent-data-table-td ">M. T. Mcbrian Company, Inc.</td><td class="patent-data-table-td ">Reconfigurable controller for monitoring and controlling environmental conditions</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5367670">US5367670</a></td><td class="patent-data-table-td patent-date-value">Feb 4, 1994</td><td class="patent-data-table-td patent-date-value">Nov 22, 1994</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">Computer system manager for monitoring events and operating parameters and generating alerts</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5379184">US5379184</a></td><td class="patent-data-table-td patent-date-value">Oct 25, 1993</td><td class="patent-data-table-td patent-date-value">Jan 3, 1995</td><td class="patent-data-table-td ">Unisys Corporation</td><td class="patent-data-table-td ">Pry-in/pry-out disk drive receptacle</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5388267">US5388267</a></td><td class="patent-data-table-td patent-date-value">May 29, 1991</td><td class="patent-data-table-td patent-date-value">Feb 7, 1995</td><td class="patent-data-table-td ">Dell Usa, L.P.</td><td class="patent-data-table-td ">Method booting of a computer system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5402431">US5402431</a></td><td class="patent-data-table-td patent-date-value">Nov 23, 1993</td><td class="patent-data-table-td patent-date-value">Mar 28, 1995</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">Innate bus monitoring system for computer system manager</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5423025">US5423025</a></td><td class="patent-data-table-td patent-date-value">Sep 29, 1992</td><td class="patent-data-table-td patent-date-value">Jun 6, 1995</td><td class="patent-data-table-td ">Amdahl Corporation</td><td class="patent-data-table-td ">Error handling mechanism for a controller having a plurality of servers</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5430717">US5430717</a></td><td class="patent-data-table-td patent-date-value">Dec 23, 1993</td><td class="patent-data-table-td patent-date-value">Jul 4, 1995</td><td class="patent-data-table-td ">Krone Ag</td><td class="patent-data-table-td ">Digital electronic loop crossconnect and carrier system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5430845">US5430845</a></td><td class="patent-data-table-td patent-date-value">Jun 17, 1992</td><td class="patent-data-table-td patent-date-value">Jul 4, 1995</td><td class="patent-data-table-td ">Unisys Corporation</td><td class="patent-data-table-td ">Peripheral device interface for dynamically selecting boot disk device driver</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5432715">US5432715</a></td><td class="patent-data-table-td patent-date-value">Jun 29, 1993</td><td class="patent-data-table-td patent-date-value">Jul 11, 1995</td><td class="patent-data-table-td ">Hitachi, Ltd.</td><td class="patent-data-table-td ">Computer system and monitoring method</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5432946">US5432946</a></td><td class="patent-data-table-td patent-date-value">Apr 11, 1991</td><td class="patent-data-table-td patent-date-value">Jul 11, 1995</td><td class="patent-data-table-td ">International Business Machines Corp.</td><td class="patent-data-table-td ">LAN server personal computer with unattended activation capability</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5438678">US5438678</a></td><td class="patent-data-table-td patent-date-value">Mar 23, 1993</td><td class="patent-data-table-td patent-date-value">Aug 1, 1995</td><td class="patent-data-table-td ">Smith; Peter L.</td><td class="patent-data-table-td ">Self-powered computer accessory device for power extraction from attached data signals and method of operating thereof</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5448723">US5448723</a></td><td class="patent-data-table-td patent-date-value">Oct 15, 1993</td><td class="patent-data-table-td patent-date-value">Sep 5, 1995</td><td class="patent-data-table-td ">Tandem Computers Incorporated</td><td class="patent-data-table-td ">Method and apparatus for fault tolerant connection of a computing system to local area networks</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5455933">US5455933</a></td><td class="patent-data-table-td patent-date-value">Jul 14, 1993</td><td class="patent-data-table-td patent-date-value">Oct 3, 1995</td><td class="patent-data-table-td ">Dell Usa, L.P.</td><td class="patent-data-table-td ">Circuit and method for remote diagnosis of personal computers</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5460441">US5460441</a></td><td class="patent-data-table-td patent-date-value">Nov 1, 1994</td><td class="patent-data-table-td patent-date-value">Oct 24, 1995</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">Rack-mounted computer apparatus</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5463766">US5463766</a></td><td class="patent-data-table-td patent-date-value">Jul 14, 1993</td><td class="patent-data-table-td patent-date-value">Oct 31, 1995</td><td class="patent-data-table-td ">Dell Usa, L.P.</td><td class="patent-data-table-td ">In a computer system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5465349">US5465349</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Oct 5, 1994</td><td class="patent-data-table-td patent-date-value">Nov 7, 1995</td><td class="patent-data-table-td ">Gemplus Card International</td><td class="patent-data-table-td ">System for monitoring abnormal integrated circuit operating conditions and causing selective microprocessor interrupts</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5471617">US5471617</a></td><td class="patent-data-table-td patent-date-value">Aug 21, 1992</td><td class="patent-data-table-td patent-date-value">Nov 28, 1995</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">Computer management system and associated management information base</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5471634">US5471634</a></td><td class="patent-data-table-td patent-date-value">Mar 29, 1994</td><td class="patent-data-table-td patent-date-value">Nov 28, 1995</td><td class="patent-data-table-td ">The United States Of America As Represented By The Secretary Of The Navy</td><td class="patent-data-table-td ">Network file server with automatic sensing means</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5473499">US5473499</a></td><td class="patent-data-table-td patent-date-value">Jun 30, 1993</td><td class="patent-data-table-td patent-date-value">Dec 5, 1995</td><td class="patent-data-table-td ">Harris Corporation</td><td class="patent-data-table-td ">Hot pluggable motherboard bus connection method</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5485550">US5485550</a></td><td class="patent-data-table-td patent-date-value">Jan 17, 1995</td><td class="patent-data-table-td patent-date-value">Jan 16, 1996</td><td class="patent-data-table-td ">Apple Computer, Inc.</td><td class="patent-data-table-td ">Method and apparatus for fuzzy logic rule execution</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5513314">US5513314</a></td><td class="patent-data-table-td patent-date-value">Jan 27, 1995</td><td class="patent-data-table-td patent-date-value">Apr 30, 1996</td><td class="patent-data-table-td ">Auspex Systems, Inc.</td><td class="patent-data-table-td ">Computer system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5513339">US5513339</a></td><td class="patent-data-table-td patent-date-value">Dec 19, 1994</td><td class="patent-data-table-td patent-date-value">Apr 30, 1996</td><td class="patent-data-table-td ">At&amp;T Corp.</td><td class="patent-data-table-td ">Concurrent fault simulation of circuits with both logic elements and functional circuits</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5519851">US5519851</a></td><td class="patent-data-table-td patent-date-value">Mar 14, 1994</td><td class="patent-data-table-td patent-date-value">May 21, 1996</td><td class="patent-data-table-td ">Sun Microsystems, Inc.</td><td class="patent-data-table-td ">Portable PCMCIA interface for a host computer</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5526289">US5526289</a></td><td class="patent-data-table-td patent-date-value">Jun 14, 1993</td><td class="patent-data-table-td patent-date-value">Jun 11, 1996</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">Temperature dependent fan control circuit for personal computer</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5528409">US5528409</a></td><td class="patent-data-table-td patent-date-value">Oct 13, 1994</td><td class="patent-data-table-td patent-date-value">Jun 18, 1996</td><td class="patent-data-table-td ">Nt International, Inc.</td><td class="patent-data-table-td ">Fiber-optic interface system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5530810">US5530810</a></td><td class="patent-data-table-td patent-date-value">Jun 7, 1995</td><td class="patent-data-table-td patent-date-value">Jun 25, 1996</td><td class="patent-data-table-td ">3Com Corporation</td><td class="patent-data-table-td ">Apparatus for live bus insertion of add-on devices</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5533193">US5533193</a></td><td class="patent-data-table-td patent-date-value">Jun 24, 1994</td><td class="patent-data-table-td patent-date-value">Jul 2, 1996</td><td class="patent-data-table-td ">Xerox Corporation</td><td class="patent-data-table-td ">Method of saving machine fault information including transferring said information to another memory when an occurrence of predetermined events or faults of a reproduction machine is recognized</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5535326">US5535326</a></td><td class="patent-data-table-td patent-date-value">Jun 6, 1995</td><td class="patent-data-table-td patent-date-value">Jul 9, 1996</td><td class="patent-data-table-td ">International Business Machines Corporation</td><td class="patent-data-table-td ">System and method for logical console verification and feedback</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5542055">US5542055</a></td><td class="patent-data-table-td patent-date-value">May 28, 1993</td><td class="patent-data-table-td patent-date-value">Jul 30, 1996</td><td class="patent-data-table-td ">International Business Machines Corp.</td><td class="patent-data-table-td ">System for counting the number of peripheral buses in each hierarch connected to primary bus for creating map of peripheral buses to locate peripheral devices</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5546272">US5546272</a></td><td class="patent-data-table-td patent-date-value">Jan 18, 1995</td><td class="patent-data-table-td patent-date-value">Aug 13, 1996</td><td class="patent-data-table-td ">Dell Usa, L.P.</td><td class="patent-data-table-td ">Serial fan cooling subsystem for computer systems</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5548712">US5548712</a></td><td class="patent-data-table-td patent-date-value">Jan 19, 1995</td><td class="patent-data-table-td patent-date-value">Aug 20, 1996</td><td class="patent-data-table-td ">Hewlett-Packard Company</td><td class="patent-data-table-td ">Data storage system and method for managing asynchronous attachment and detachment of storage disks</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5559764">US5559764</a></td><td class="patent-data-table-td patent-date-value">Aug 18, 1994</td><td class="patent-data-table-td patent-date-value">Sep 24, 1996</td><td class="patent-data-table-td ">International Business Machines Corporation</td><td class="patent-data-table-td ">HMC: A hybrid mirror-and-chained data replication method to support high data availability for disk arrays</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5560022">US5560022</a></td><td class="patent-data-table-td patent-date-value">Jul 19, 1994</td><td class="patent-data-table-td patent-date-value">Sep 24, 1996</td><td class="patent-data-table-td ">Intel Corporation</td><td class="patent-data-table-td ">In a computer system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5566299">US5566299</a></td><td class="patent-data-table-td patent-date-value">Dec 30, 1993</td><td class="patent-data-table-td patent-date-value">Oct 15, 1996</td><td class="patent-data-table-td ">Lockheed Martin Corporation</td><td class="patent-data-table-td ">Fault tolerant method and system for high availability document image and coded data processing</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5566339">US5566339</a></td><td class="patent-data-table-td patent-date-value">Oct 23, 1992</td><td class="patent-data-table-td patent-date-value">Oct 15, 1996</td><td class="patent-data-table-td ">Fox Network Systems, Inc.</td><td class="patent-data-table-td ">System and method for monitoring computer environment and operation</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5572403">US5572403</a></td><td class="patent-data-table-td patent-date-value">Jan 18, 1995</td><td class="patent-data-table-td patent-date-value">Nov 5, 1996</td><td class="patent-data-table-td ">Dell Usa, L.P.</td><td class="patent-data-table-td ">Plenum bypass serial fan cooling subsystem for computer systems</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5579487">US5579487</a></td><td class="patent-data-table-td patent-date-value">Jun 30, 1994</td><td class="patent-data-table-td patent-date-value">Nov 26, 1996</td><td class="patent-data-table-td ">Teletransaction, Inc.</td><td class="patent-data-table-td ">Portable work slate computer with multiple docking positions for interchangeably receiving removable modules</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5579491">US5579491</a></td><td class="patent-data-table-td patent-date-value">Jul 7, 1994</td><td class="patent-data-table-td patent-date-value">Nov 26, 1996</td><td class="patent-data-table-td ">Dell U.S.A., L.P.</td><td class="patent-data-table-td ">Local proactive hot swap request/acknowledge system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5579528">US5579528</a></td><td class="patent-data-table-td patent-date-value">Apr 3, 1995</td><td class="patent-data-table-td patent-date-value">Nov 26, 1996</td><td class="patent-data-table-td ">Dell Usa, L.P.</td><td class="patent-data-table-td ">Computer system employing docking bay with spring loaded connector pins and file coherency method</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5584030">US5584030</a></td><td class="patent-data-table-td patent-date-value">Feb 2, 1994</td><td class="patent-data-table-td patent-date-value">Dec 10, 1996</td><td class="patent-data-table-td ">3Com Corporation</td><td class="patent-data-table-td ">Method and apparatus for live insertion and removal of electronic sub-assemblies</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5586250">US5586250</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Nov 12, 1993</td><td class="patent-data-table-td patent-date-value">Dec 17, 1996</td><td class="patent-data-table-td ">Conner Peripherals, Inc.</td><td class="patent-data-table-td ">SCSI-coupled module for monitoring and controlling SCSI-coupled raid bank and bank environment</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5588121">US5588121</a></td><td class="patent-data-table-td patent-date-value">May 9, 1996</td><td class="patent-data-table-td patent-date-value">Dec 24, 1996</td><td class="patent-data-table-td ">International Computers Limited</td><td class="patent-data-table-td ">Parallel computer having MAC-relay layer snooped transport header to determine if a message should be routed directly to transport layer depending on its destination</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5592611">US5592611</a></td><td class="patent-data-table-td patent-date-value">Mar 14, 1995</td><td class="patent-data-table-td patent-date-value">Jan 7, 1997</td><td class="patent-data-table-td ">Network Integrity, Inc.</td><td class="patent-data-table-td ">Stand-in computer server</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5596711">US5596711</a></td><td class="patent-data-table-td patent-date-value">Jan 26, 1995</td><td class="patent-data-table-td patent-date-value">Jan 21, 1997</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">Computer failure recovery and alert system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5598407">US5598407</a></td><td class="patent-data-table-td patent-date-value">Sep 28, 1992</td><td class="patent-data-table-td patent-date-value">Jan 28, 1997</td><td class="patent-data-table-td ">Sixtel S.P.A.</td><td class="patent-data-table-td ">Cordless local area network having a fixed central control device</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5602758">US5602758</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Jan 26, 1995</td><td class="patent-data-table-td patent-date-value">Feb 11, 1997</td><td class="patent-data-table-td ">Gas Research Institute</td><td class="patent-data-table-td ">Installation link-up procedure</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5621159">US5621159</a></td><td class="patent-data-table-td patent-date-value">Nov 2, 1995</td><td class="patent-data-table-td patent-date-value">Apr 15, 1997</td><td class="patent-data-table-td ">Dell Usa L.P.</td><td class="patent-data-table-td ">Method and apparatus for determining fan bearing friction</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5622221">US5622221</a></td><td class="patent-data-table-td patent-date-value">May 17, 1995</td><td class="patent-data-table-td patent-date-value">Apr 22, 1997</td><td class="patent-data-table-td ">Taco, Inc.</td><td class="patent-data-table-td ">Integrated zoning circulator with priority controller</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5625238">US5625238</a></td><td class="patent-data-table-td patent-date-value">Feb 3, 1995</td><td class="patent-data-table-td patent-date-value">Apr 29, 1997</td><td class="patent-data-table-td ">Motorola, Inc.</td><td class="patent-data-table-td ">Apparatus for non-disruptively interconnecting perpheral device modules with a host device</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5627962">US5627962</a></td><td class="patent-data-table-td patent-date-value">Dec 30, 1994</td><td class="patent-data-table-td patent-date-value">May 6, 1997</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">Circuit for reassigning the power-on processor in a multiprocessing system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5628028">US5628028</a></td><td class="patent-data-table-td patent-date-value">Mar 2, 1995</td><td class="patent-data-table-td patent-date-value">May 6, 1997</td><td class="patent-data-table-td ">Data Translation, Inc.</td><td class="patent-data-table-td ">Reprogrammable PCMCIA card and method and apparatus employing same</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5630076">US5630076</a></td><td class="patent-data-table-td patent-date-value">May 5, 1995</td><td class="patent-data-table-td patent-date-value">May 13, 1997</td><td class="patent-data-table-td ">Apple Computer, Inc.</td><td class="patent-data-table-td ">In a computer system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5631847">US5631847</a></td><td class="patent-data-table-td patent-date-value">Apr 27, 1995</td><td class="patent-data-table-td patent-date-value">May 20, 1997</td><td class="patent-data-table-td ">Elonex I.P. Holdings, Ltd</td><td class="patent-data-table-td ">Error notification system for a computer</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5636341">US5636341</a></td><td class="patent-data-table-td patent-date-value">Jun 7, 1995</td><td class="patent-data-table-td patent-date-value">Jun 3, 1997</td><td class="patent-data-table-td ">Hitachi, Ltd.</td><td class="patent-data-table-td ">Fault processing method and information processing system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5652839">US5652839</a></td><td class="patent-data-table-td patent-date-value">Mar 29, 1994</td><td class="patent-data-table-td patent-date-value">Jul 29, 1997</td><td class="patent-data-table-td ">The United States Of America As Represented By The Secretary Of The Navy</td><td class="patent-data-table-td ">Method of non-intrusively sensing status in a computer peripheral</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5652892">US5652892</a></td><td class="patent-data-table-td patent-date-value">Oct 17, 1994</td><td class="patent-data-table-td patent-date-value">Jul 29, 1997</td><td class="patent-data-table-td ">Hitachi, Ltd.</td><td class="patent-data-table-td ">Method and apparatus for controlling remote power source</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5652908">US5652908</a></td><td class="patent-data-table-td patent-date-value">Jun 7, 1995</td><td class="patent-data-table-td patent-date-value">Jul 29, 1997</td><td class="patent-data-table-td ">International Business Machines Corporation</td><td class="patent-data-table-td ">Method and apparatus for establishing communications sessions in a remote resource control environment</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5655083">US5655083</a></td><td class="patent-data-table-td patent-date-value">Jun 7, 1995</td><td class="patent-data-table-td patent-date-value">Aug 5, 1997</td><td class="patent-data-table-td ">Emc Corporation</td><td class="patent-data-table-td ">Programmable rset system and method for computer network</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5664118">US5664118</a></td><td class="patent-data-table-td patent-date-value">Mar 24, 1995</td><td class="patent-data-table-td patent-date-value">Sep 2, 1997</td><td class="patent-data-table-td ">Kabushiki Kaisha Toshiba</td><td class="patent-data-table-td ">Computer system having detachable expansion unit</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5668943">US5668943</a></td><td class="patent-data-table-td patent-date-value">May 24, 1996</td><td class="patent-data-table-td patent-date-value">Sep 16, 1997</td><td class="patent-data-table-td ">International Business Machines Corporation</td><td class="patent-data-table-td ">Virtual shared disks with application transparent recovery</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5668992">US5668992</a></td><td class="patent-data-table-td patent-date-value">Aug 1, 1994</td><td class="patent-data-table-td patent-date-value">Sep 16, 1997</td><td class="patent-data-table-td ">International Business Machines Corporation</td><td class="patent-data-table-td ">Self-configuring computer system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5669009">US5669009</a></td><td class="patent-data-table-td patent-date-value">Feb 23, 1996</td><td class="patent-data-table-td patent-date-value">Sep 16, 1997</td><td class="patent-data-table-td ">Hughes Electronics</td><td class="patent-data-table-td ">Signal processing array</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5671371">US5671371</a></td><td class="patent-data-table-td patent-date-value">Oct 18, 1995</td><td class="patent-data-table-td patent-date-value">Sep 23, 1997</td><td class="patent-data-table-td ">Hitachi, Ltd.</td><td class="patent-data-table-td ">For use in a data processing system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5696895">US5696895</a></td><td class="patent-data-table-td patent-date-value">Jun 19, 1995</td><td class="patent-data-table-td patent-date-value">Dec 9, 1997</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">Fault tolerant multiple network servers</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5696949">US5696949</a></td><td class="patent-data-table-td patent-date-value">Jun 15, 1995</td><td class="patent-data-table-td patent-date-value">Dec 9, 1997</td><td class="patent-data-table-td ">Intel Corporation</td><td class="patent-data-table-td ">System for PCI slots expansion using asynchronous PCI-to-PCI bridge with clock generator for providing clock signal to the expansion mother board and expansion side of bridge</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5701417">US5701417</a></td><td class="patent-data-table-td patent-date-value">Mar 27, 1991</td><td class="patent-data-table-td patent-date-value">Dec 23, 1997</td><td class="patent-data-table-td ">Microstar Laboratories</td><td class="patent-data-table-td ">Method and apparatus for providing initial instructions through a communications interface in a multiple computer system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5704031">US5704031</a></td><td class="patent-data-table-td patent-date-value">Dec 8, 1995</td><td class="patent-data-table-td patent-date-value">Dec 30, 1997</td><td class="patent-data-table-td ">Fujitsu Limited</td><td class="patent-data-table-td ">Method of performing self-diagnosing hardware, software and firmware at a client node in a client/server system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5708775">US5708775</a></td><td class="patent-data-table-td patent-date-value">Oct 17, 1995</td><td class="patent-data-table-td patent-date-value">Jan 13, 1998</td><td class="patent-data-table-td ">Fuji Xerox Co., Ltd.</td><td class="patent-data-table-td ">Fault information notification system localized at each network server</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5708776">US5708776</a></td><td class="patent-data-table-td patent-date-value">May 9, 1996</td><td class="patent-data-table-td patent-date-value">Jan 13, 1998</td><td class="patent-data-table-td ">Elonex I.P. Holdings</td><td class="patent-data-table-td ">Automatic recovery for network appliances</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5712754">US5712754</a></td><td class="patent-data-table-td patent-date-value">Apr 15, 1996</td><td class="patent-data-table-td patent-date-value">Jan 27, 1998</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">For a computer</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5715456">US5715456</a></td><td class="patent-data-table-td patent-date-value">Feb 13, 1995</td><td class="patent-data-table-td patent-date-value">Feb 3, 1998</td><td class="patent-data-table-td ">International Business Machines Corporation</td><td class="patent-data-table-td ">Method and apparatus for booting a computer system without pre-installing an operating system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5717570">US5717570</a></td><td class="patent-data-table-td patent-date-value">Oct 6, 1995</td><td class="patent-data-table-td patent-date-value">Feb 10, 1998</td><td class="patent-data-table-td ">Elonex I.P. Holdings Ltd.</td><td class="patent-data-table-td ">Enhanced mini-tower computer architecture</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5721935">US5721935</a></td><td class="patent-data-table-td patent-date-value">Feb 18, 1997</td><td class="patent-data-table-td patent-date-value">Feb 24, 1998</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">Apparatus and method for entering low power mode in a computer system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5803357">US5803357</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Feb 19, 1997</td><td class="patent-data-table-td patent-date-value">Sep 8, 1998</td><td class="patent-data-table-td ">Coleman Safety And Security Products, Inc.</td><td class="patent-data-table-td ">Thermostat with remote temperature sensors and incorporating a measured temperature feature for averaging ambient temperatures at selected sensors</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US5864653">US5864653</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Dec 31, 1996</td><td class="patent-data-table-td patent-date-value">Jan 26, 1999</td><td class="patent-data-table-td ">Compaq Computer Corporation</td><td class="patent-data-table-td ">PCI hot spare capability for failed components</td></tr></table><div class="patent-section-footer">* Cited by examiner</div></div><div class="patent-section patent-tabular-section"><a id="npl-citations"></a><div class="patent-section-header"><span class="patent-section-title">Non-Patent Citations</span></div><table class="patent-data-table"><thead class="patent-data-table-thead"><tr class="patent-data-table"><th colspan="3"class="patent-data-table-th">Reference</th></tr></thead><tr><td class="patent-data-table-td ">1</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">"<a href='http://scholar.google.com/scholar?q="CAN%3A+Technical+Overview"'>CAN: Technical Overview</a>", NRTT, Ltd., Sep. 23,1997, 15 pp.</td></tr><tr><td class="patent-data-table-td ">2</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Cmaster, Usenet post to microsoft.public.windowsnt.setup, Aug. 1997, "<a href='http://scholar.google.com/scholar?q="Re%3A+FDISK+switches."'>Re: FDISK switches.</a>"</td></tr><tr><td class="patent-data-table-td ">3</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Compaq Computer Corporation, Technology Brief, pp. 1-13, Dec. 1996, "<a href='http://scholar.google.com/scholar?q="Where+Do+I+Plug+the+Cable%3FSolving+the+Logical-Physical+Slot+Numbering+Problem."'>Where Do I Plug the Cable?Solving the Logical-Physical Slot Numbering Problem.</a>"</td></tr><tr><td class="patent-data-table-td ">4</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Davis, T, Usenet post to alt.msdos.programmer, Apr. 1997, "<a href='http://scholar.google.com/scholar?q="Re%3A+How+do+I+create+an+FDISK+batch+file%3F"'>Re: How do I create an FDISK batch file?</a>"</td></tr><tr><td class="patent-data-table-td ">5</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Davis, T., Usenet post to alt.msdos.batch, Apr. 1997, "<a href='http://scholar.google.com/scholar?q="Re%3A+Need+help+with+automating+FDISK+and+Format+.+.+.+"'>Re: Need help with automating FDISK and Format . . . </a>".</td></tr><tr><td class="patent-data-table-td ">6</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">ftp.cdrom.com/pub/os2/diskutil/, PHDX software, phdx.zip download, Mar. 1995, "<a href='http://scholar.google.com/scholar?q="Parallel+Hard+Disk+Xfer."'>Parallel Hard Disk Xfer.</a>"</td></tr><tr><td class="patent-data-table-td ">7</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Gorlick, M., Conf. Proceedings: ACM/ONR Workshop on Parallel and Distributed Debugging, pp. 175-181, 1991, "<a href='http://scholar.google.com/scholar?q="The+Flight+Recorder%3A+An+Architectural+Aid+for+System+Monitoring."'>The Flight Recorder: An Architectural Aid for System Monitoring.</a>"</td></tr><tr><td class="patent-data-table-td ">8</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Hildebrand, N., Usenet post to comp.msdos.programmer, May 1995, "<a href='http://scholar.google.com/scholar?q="Re%3A+Structure+of+disk+partition+into."'>Re: Structure of disk partition into.</a>"</td></tr><tr><td class="patent-data-table-td ">9</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">IBM Technical Disclosure Bulletin, 92A+62947, pp. 391-394, Oct. 1992, Method for Card Hot Plug Detection and Control.</td></tr><tr><td class="patent-data-table-td ">10</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Lewis, L., Usenet post to alt.msdos.batch, Apr. 1997, "<a href='http://scholar.google.com/scholar?q="Re%3A+Need+help+with+automating+FDISK+and+Format."'>Re: Need help with automating FDISK and Format.</a>"</td></tr><tr><td class="patent-data-table-td ">11</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Lyons, Computer Reseller News, Issue 721, pp. 61-62, Feb. 3, 1997, "<a href='http://scholar.google.com/scholar?q="ACC+Releases+Low-Cost+Solution+for+ISPs."'>ACC Releases Low-Cost Solution for ISPs.</a>"</td></tr><tr><td class="patent-data-table-td ">12</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">M. J. Schofield, "<a href='http://scholar.google.com/scholar?q="Controller+Area+Network-How+CAN+Works"'>Controller Area Network-How CAN Works</a>",mschofield@cix.compulink.co.uk, Sep. 23, 1997, 4 pp.</td></tr><tr><td class="patent-data-table-td ">13</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">M. J. Schofield, "<a href='http://scholar.google.com/scholar?q="Controller+Area+Network%E2%80%94How+CAN+Works"'>Controller Area Network—How CAN Works</a>",mschofield@cix.compulink.co.uk, Sep. 23, 1997, 4 pp.</td></tr><tr><td class="patent-data-table-td ">14</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">M2 Communications, M2 Presswire, 2 pages, Dec. 19, 1996, "<a href='http://scholar.google.com/scholar?q="Novell+IntranetWare+Supports+Hot+Pluggable+PCI+from+NetFRAME."'>Novell IntranetWare Supports Hot Pluggable PCI from NetFRAME.</a>"</td></tr><tr><td class="patent-data-table-td ">15</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Mark Lockareff, "<a href='http://scholar.google.com/scholar?q="Lonworks-An+Introduction"'>Lonworks-An Introduction</a>", HTINews, Dec., 1996, 2 pp.</td></tr><tr><td class="patent-data-table-td ">16</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Mark Lockareff, "<a href='http://scholar.google.com/scholar?q="Lonworks%E2%80%94An+Introduction"'>Lonworks—An Introduction</a>", HTINews, Dec., 1996, 2 pp.</td></tr><tr><td class="patent-data-table-td ">17</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">NetFrame Systems Incorporated, Doc. No. 78-1000226-01, pp. 1-2, 5-8, 359-404, and 471-512, Apr. 1996,"<a href='http://scholar.google.com/scholar?q="NetFrame+Clustered+Multiprocessing+Software%3A+NW0496+DC-ROM+for+Novel%28R%29+Netware%28R%29+4.1+SMP%2C+4.1%2C+and+3.12.+"'>NetFrame Clustered Multiprocessing Software: NW0496 DC-ROM for Novel(R) Netware(R) 4.1 SMP, 4.1, and 3.12. </a>"</td></tr><tr><td class="patent-data-table-td ">18</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">NetFrame Systems Incorporated, Doc. No. 78-1000226-01, pp. 1-2, 5-8, 359-404, and 471-512, Apr. 1996,"<a href='http://scholar.google.com/scholar?q="NetFrame+Clustered+Multiprocessing+Software%3A+NW0496+DC-ROM+for+Novel%C2%AE+Netware%C2%AE+4.1+SMP%2C+4.1%2C+and+3.12.+"'>NetFrame Clustered Multiprocessing Software: NW0496 DC-ROM for Novel® Netware® 4.1 SMP, 4.1, and 3.12. </a>"</td></tr><tr><td class="patent-data-table-td ">19</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Netframe, http://www.netframe-support.com/technology/datasheets/data.htm, before Mar. 1997, "<a href='http://scholar.google.com/scholar?q="Netframe+ClusterSystem+9008+Data+Sheet."'>Netframe ClusterSystem 9008 Data Sheet.</a>"</td></tr><tr><td class="patent-data-table-td ">20</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">PCI Hot-Plug Specification, Preliminary Revision for Review Only, Revision 0.9, pp. i-vi, and 1-25, Mar. 5, 1997.</td></tr><tr><td class="patent-data-table-td ">21</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Product Brochure of NetFRAME, "<a href='http://scholar.google.com/scholar?q="NF450FT+Network+Mainframe"'>NF450FT Network Mainframe</a>", Feb. 1992, 14 pp.</td></tr><tr><td class="patent-data-table-td ">22</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Rigney, PC Magazine, 14(17): 375-379, Oct. 10, 1995, "<a href='http://scholar.google.com/scholar?q="The+One+for+the+Road+%28Mobile-aware+capabilities+in+Windows+95%29."'>The One for the Road (Mobile-aware capabilities in Windows 95).</a>"</td></tr><tr><td class="patent-data-table-td ">23</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">SES SCSI-3 Enclosure Services, X3T10/Project 1212-D/Rev 8a, pp. i, iii-x, 1-76, and l-1 (index), Jan. 16, 1997.</td></tr><tr><td class="patent-data-table-td ">24</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Shanley and Anderson, PCI System Architecture, Third Edition, Chapters 15 &amp; 16, pp. 297-328, CR 1995.</td></tr><tr><td class="patent-data-table-td ">25</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Shanley, and Anderson, PCI System Architecture, Third Edition, Chapter 15, pp. 297-302, Copyright 1995, "<a href='http://scholar.google.com/scholar?q="Intro+To+Configuration+Address+Space."'>Intro To Configuration Address Space.</a>"</td></tr><tr><td class="patent-data-table-td ">26</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Shanley, and Anderson, PCI System Architecture, Third Edition, Chapter 16, pp. 303-328, Copyright 1995, "<a href='http://scholar.google.com/scholar?q="Configuration+Transactions."'>Configuration Transactions.</a>"</td></tr><tr><td class="patent-data-table-td ">27</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Shanley, and Anderson, PCI System Architecture, Third Edition, p. 382, Copyright 1995.</td></tr><tr><td class="patent-data-table-td ">28</td><td class="patent-data-table-td "><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td ">Simos, M., Usenet post to comp.os.msdos.misc, Apr. 1997, "<a href='http://scholar.google.com/scholar?q="Re%3A+Auto+FDISK+and+Format."'>Re: Auto FDISK and Format.</a>"</td></tr><tr><td class="patent-data-table-td ">29</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Sun Microsystems Computer Company, Part No. 802-5355-10, Rev. A, May 1996, "<a href='http://scholar.google.com/scholar?q="Solstice+SyMON+User%27s+Guid."'>Solstice SyMON User's Guid.</a>"</td></tr><tr><td class="patent-data-table-td ">30</td><td class="patent-data-table-td "></td><td class="patent-data-table-td ">Sun Microsystems, Part No. 802-6569-11, Release 1.0.1, Nov. 1996, "<a href='http://scholar.google.com/scholar?q="Remote+Systems+Diagnostics+Installation+%26amp%3B+User+Guide."'>Remote Systems Diagnostics Installation &amp; User Guide.</a>"</td></tr><tr><td class="patent-data-table-td ">31</td><td class="patent-data-table-td "><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td ">Wood, M. H., Usenet post to comp.os.netware.misc, Aug. 1996, "<a href='http://scholar.google.com/scholar?q="Re%3A+Workstation+duplication+method+for+WIN95."'>Re: Workstation duplication method for WIN95.</a>"</td></tr></table><div class="patent-section-footer">* Cited by examiner</div></div><div class="patent-section patent-tabular-section"><a id="forward-citations"></a><div class="patent-section-header"><span class="patent-section-title">Referenced by</span></div><table class="patent-data-table"><thead class="patent-data-table-thead"><tr class="patent-data-table"><th class="patent-data-table-th">Citing Patent</th><th class="patent-data-table-th">Filing date</th><th class="patent-data-table-th">Publication date</th><th class="patent-data-table-th">Applicant</th><th class="patent-data-table-th">Title</th></tr></thead><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US6510522">US6510522</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Nov 20, 1998</td><td class="patent-data-table-td patent-date-value">Jan 21, 2003</td><td class="patent-data-table-td ">Compaq Information Technologies Group, L.P.</td><td class="patent-data-table-td ">Apparatus and method for providing access security to a device coupled upon a two-wire bidirectional bus</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US6667868">US6667868</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Oct 3, 2001</td><td class="patent-data-table-td patent-date-value">Dec 23, 2003</td><td class="patent-data-table-td ">Maxim Integrated Products, Inc.</td><td class="patent-data-table-td ">Thermal shutdown control for multi-channel integrated circuit boards</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US6690616">US6690616</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Jul 21, 1999</td><td class="patent-data-table-td patent-date-value">Feb 10, 2004</td><td class="patent-data-table-td ">Ulrich Bahr</td><td class="patent-data-table-td ">Method and device for detecting objects, especially used as a parking assistance device in a motor vehicle</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7027356">US7027356</a></td><td class="patent-data-table-td patent-date-value">Aug 22, 2003</td><td class="patent-data-table-td patent-date-value">Apr 11, 2006</td><td class="patent-data-table-td ">Volkswagen Ag</td><td class="patent-data-table-td ">Method and device for detecting objects, especially used as a parking assistance device in a motor vehicle</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7062761">US7062761</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Jul 10, 2001</td><td class="patent-data-table-td patent-date-value">Jun 13, 2006</td><td class="patent-data-table-td ">Micron Technology, Inc.</td><td class="patent-data-table-td ">Dynamic arrays and overlays with bounds policies</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7114034">US7114034</a></td><td class="patent-data-table-td patent-date-value">Feb 24, 2004</td><td class="patent-data-table-td patent-date-value">Sep 26, 2006</td><td class="patent-data-table-td ">Micron Technology, Inc.</td><td class="patent-data-table-td ">Caching of dynamic arrays</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7127559">US7127559</a></td><td class="patent-data-table-td patent-date-value">Jul 10, 2001</td><td class="patent-data-table-td patent-date-value">Oct 24, 2006</td><td class="patent-data-table-td ">Micron Technology, Inc.</td><td class="patent-data-table-td ">Caching of dynamic arrays</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7168007">US7168007</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Apr 14, 2003</td><td class="patent-data-table-td patent-date-value">Jan 23, 2007</td><td class="patent-data-table-td ">Sun Microsystems, Inc.</td><td class="patent-data-table-td ">Field replaceable unit (FRU) identification system tool</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7222200">US7222200</a></td><td class="patent-data-table-td patent-date-value">Oct 14, 2004</td><td class="patent-data-table-td patent-date-value">May 22, 2007</td><td class="patent-data-table-td ">Dell Products L.P.</td><td class="patent-data-table-td ">Method for synchronizing processors in SMI following a memory hot plug event</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7353113">US7353113</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Dec 7, 2004</td><td class="patent-data-table-td patent-date-value">Apr 1, 2008</td><td class="patent-data-table-td ">Sprague Michael C</td><td class="patent-data-table-td ">System, method and computer program product for aquatic environment assessment</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7403986">US7403986</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Oct 18, 2001</td><td class="patent-data-table-td patent-date-value">Jul 22, 2008</td><td class="patent-data-table-td ">Network Equipment Technologies, Inc.</td><td class="patent-data-table-td ">Method for synchronizing circuit related objects between network management systems and network control processors</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7500040">US7500040</a></td><td class="patent-data-table-td patent-date-value">Mar 12, 2007</td><td class="patent-data-table-td patent-date-value">Mar 3, 2009</td><td class="patent-data-table-td ">Dell Products L.P.</td><td class="patent-data-table-td ">Method for synchronizing processors following a memory hot plug event</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7577790">US7577790</a></td><td class="patent-data-table-td patent-date-value">May 4, 2006</td><td class="patent-data-table-td patent-date-value">Aug 18, 2009</td><td class="patent-data-table-td ">Micron Technology, Inc.</td><td class="patent-data-table-td ">Caching of dynamic arrays</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7657698">US7657698</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Jun 24, 2005</td><td class="patent-data-table-td patent-date-value">Feb 2, 2010</td><td class="patent-data-table-td ">Intel Corporation</td><td class="patent-data-table-td ">Systems and methods for chassis identification</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7694250">US7694250</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Jan 13, 2005</td><td class="patent-data-table-td patent-date-value">Apr 6, 2010</td><td class="patent-data-table-td ">Renault Sas</td><td class="patent-data-table-td ">Method for design and verification of safety critical systems</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7849367">US7849367</a></td><td class="patent-data-table-td patent-date-value">Apr 10, 2008</td><td class="patent-data-table-td patent-date-value">Dec 7, 2010</td><td class="patent-data-table-td ">Oracle International Corporation</td><td class="patent-data-table-td ">Method for performing a corrective action upon a sub-system</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US7849368">US7849368</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Apr 10, 2008</td><td class="patent-data-table-td patent-date-value">Dec 7, 2010</td><td class="patent-data-table-td ">Oracle International Corporation</td><td class="patent-data-table-td ">Method for monitoring server sub-system health</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US8302100">US8302100</a></td><td class="patent-data-table-td patent-date-value">Aug 12, 2005</td><td class="patent-data-table-td patent-date-value">Oct 30, 2012</td><td class="patent-data-table-td ">Galactic Computing Corporation Bvi/Bc</td><td class="patent-data-table-td ">System for balance distribution of requests across multiple servers using dynamic metrics</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US8316131">US8316131</a></td><td class="patent-data-table-td patent-date-value">Mar 26, 2010</td><td class="patent-data-table-td patent-date-value">Nov 20, 2012</td><td class="patent-data-table-td ">Galactic Computing Corporation Bvi/Bc</td><td class="patent-data-table-td ">Method and system for providing dynamic hosted service management across disparate accounts/sites</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US8332832">US8332832</a></td><td class="patent-data-table-td patent-date-value">May 31, 2006</td><td class="patent-data-table-td patent-date-value">Dec 11, 2012</td><td class="patent-data-table-td ">Micron Technology, Inc.</td><td class="patent-data-table-td ">Dynamic arrays and overlays with bounds policies</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US8429049">US8429049</a></td><td class="patent-data-table-td patent-date-value">Jul 27, 2011</td><td class="patent-data-table-td patent-date-value">Apr 23, 2013</td><td class="patent-data-table-td ">Galactic Computing Corporation Bvi/Ibc</td><td class="patent-data-table-td ">Method and system for allocating computing resources</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US8538843">US8538843</a></td><td class="patent-data-table-td patent-date-value">Nov 30, 2010</td><td class="patent-data-table-td patent-date-value">Sep 17, 2013</td><td class="patent-data-table-td ">Galactic Computing Corporation Bvi/Bc</td><td class="patent-data-table-td ">Method and system for operating an E-commerce service provider</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US8645222">US8645222</a></td><td class="patent-data-table-td patent-date-value">Jun 17, 2011</td><td class="patent-data-table-td patent-date-value">Feb 4, 2014</td><td class="patent-data-table-td ">Jpmorgan Chase Bank, N.A.</td><td class="patent-data-table-td ">System and methods for mobile ordering and payment</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/US8782621">US8782621</a></td><td class="patent-data-table-td patent-date-value">Sep 14, 2012</td><td class="patent-data-table-td patent-date-value">Jul 15, 2014</td><td class="patent-data-table-td ">Micron Technology, Inc.</td><td class="patent-data-table-td ">Dynamic arrays and overlays with bounds policies</td></tr><tr><td class="patent-data-table-td citation-patent"><a href="/patents/EP1300736A2?cl=en">EP1300736A2</a><span class='patent-tooltip-anchor' data-tooltip-text="Cited by examiner"> *</span></td><td class="patent-data-table-td patent-date-value">Sep 26, 2002</td><td class="patent-data-table-td patent-date-value">Apr 9, 2003</td><td class="patent-data-table-td ">Alcatel Canada Inc.</td><td class="patent-data-table-td ">System and method for element equipment status monitoring using a network</td></tr></table><div class="patent-section-footer">* Cited by examiner</div></div><div class="patent-section patent-tabular-section"><a id="classifications"></a><div class="patent-section-header"><span class="patent-section-title">Classifications</span></div><table class="patent-data-table"><thead class="patent-data-table-thead"><tr class="patent-data-table"><th class="patent-data-table-th"> </th><th class="patent-data-table-th"> </th></tr></thead><tr><td class="patent-data-table-td ">U.S. Classification</td><td class="patent-data-table-td "><span class="nested-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://www.uspto.gov/web/patents/classification/uspc714/defs714.htm&usg=AFQjCNF69HBVWbRkdZeFUtAyhUaqKU35WQ#C714S004100">714/4.1</a></span>, <span class="nested-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://www.uspto.gov/web/patents/classification/uspc714/defs714.htm&usg=AFQjCNF69HBVWbRkdZeFUtAyhUaqKU35WQ#C714SE11179">714/E11.179</a></span>, <span class="nested-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://www.uspto.gov/web/patents/classification/uspc714/defs714.htm&usg=AFQjCNF69HBVWbRkdZeFUtAyhUaqKU35WQ#C714S047300">714/47.3</a></span>, <span class="nested-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://www.uspto.gov/web/patents/classification/uspc714/defs714.htm&usg=AFQjCNF69HBVWbRkdZeFUtAyhUaqKU35WQ#C714S047200">714/47.2</a></span>, <span class="nested-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://www.uspto.gov/web/patents/classification/uspc714/defs714.htm&usg=AFQjCNF69HBVWbRkdZeFUtAyhUaqKU35WQ#C714S037000">714/37</a></span>, <span class="nested-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://www.uspto.gov/web/patents/classification/uspc714/defs714.htm&usg=AFQjCNF69HBVWbRkdZeFUtAyhUaqKU35WQ#C714S003000">714/3</a></span>, <span class="nested-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://www.uspto.gov/web/patents/classification/uspc714/defs714.htm&usg=AFQjCNF69HBVWbRkdZeFUtAyhUaqKU35WQ#C714S048000">714/48</a></span>, <span class="nested-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://www.uspto.gov/web/patents/classification/uspc714/defs714.htm&usg=AFQjCNF69HBVWbRkdZeFUtAyhUaqKU35WQ#C714S004120">714/4.12</a></span></td></tr><tr><td class="patent-data-table-td ">International Classification</td><td class="patent-data-table-td "><span class="nested-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://web2.wipo.int/ipcpub/&usg=AFQjCNER44F5jlVoswCkvW3YEcB5lW4moA#refresh=page&notion=scheme&version=20130101&symbol=G06F0001200000">G06F1/20</a></span>, <span class="nested-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://web2.wipo.int/ipcpub/&usg=AFQjCNER44F5jlVoswCkvW3YEcB5lW4moA#refresh=page&notion=scheme&version=20130101&symbol=G06F0011300000">G06F11/30</a></span></td></tr><tr><td class="patent-data-table-td ">Cooperative Classification</td><td class="patent-data-table-td "><span class="nested-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://worldwide.espacenet.com/classification&usg=AFQjCNGs5WqSrPE3A4ZP63zGuM6PRNfEFA#!/CPC=G06F11/3065">G06F11/3065</a></span>, <span class="nested-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://worldwide.espacenet.com/classification&usg=AFQjCNGs5WqSrPE3A4ZP63zGuM6PRNfEFA#!/CPC=G06F1/206">G06F1/206</a></span>, <span class="nested-value"><a href="http://www.google.com/url?id=8nxTBAABERAJ&q=http://worldwide.espacenet.com/classification&usg=AFQjCNGs5WqSrPE3A4ZP63zGuM6PRNfEFA#!/CPC=G06F11/3058">G06F11/3058</a></span></td></tr><tr><td class="patent-data-table-td ">European Classification</td><td class="patent-data-table-td "><span class="nested-value">G06F11/30E</span>, <span class="nested-value">G06F11/30R</span>, <span class="nested-value">G06F1/20T</span></td></tr></table><div class="patent-section-footer"></div></div><div class="patent-section patent-tabular-section"><a id="legal-events"></a><div class="patent-section-header"><span class="patent-section-title">Legal Events</span></div><table class="patent-data-table"><thead class="patent-data-table-thead"><tr class="patent-data-table"><th class="patent-data-table-th">Date</th><th class="patent-data-table-th">Code</th><th class="patent-data-table-th">Event</th><th class="patent-data-table-th">Description</th></tr></thead><tr><td class="patent-data-table-td patent-date-value">Jul 2, 2013</td><td class="patent-data-table-td ">B1</td><td class="patent-data-table-td ">Reexamination certificate first reexamination</td><td class="patent-data-table-td "><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">CLAIMS 1, 10 AND 21 ARE DETERMINED TO BE PATENTABLE AS AMENDED.CLAIMS 2-9, 11-20 AND 22, DEPENDENT ON AN AMENDED CLAIM, ARE DETERMINED TO BE PATENTABLE.NEW CLAIMS 23-28 ARE ADDED AND DETERMINED TO BE PATENTABLE.</span></div></td></tr><tr><td class="patent-data-table-td patent-date-value">Aug 8, 2012</td><td class="patent-data-table-td ">FPAY</td><td class="patent-data-table-td ">Fee payment</td><td class="patent-data-table-td "><div class="nested-key-value"><span class="nested-key">Year of fee payment: </span><span class="nested-value">12</span></div></td></tr><tr><td class="patent-data-table-td patent-date-value">Jul 17, 2012</td><td class="patent-data-table-td ">RR</td><td class="patent-data-table-td ">Request for reexamination filed</td><td class="patent-data-table-td "><div class="nested-key-value"><span class="nested-key">Effective date: </span><span class="nested-value">20120530</span></div></td></tr><tr><td class="patent-data-table-td patent-date-value">Jan 4, 2010</td><td class="patent-data-table-td ">AS</td><td class="patent-data-table-td ">Assignment</td><td class="patent-data-table-td "><div class="nested-key-value"><span class="nested-key">Owner name: </span><span class="nested-value">ROUND ROCK RESEARCH, LLC,NEW YORK</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100204;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Effective date: </span><span class="nested-value">20091223</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100203;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100211;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100223;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100225;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100302;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100304;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100309;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100316;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100318;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100323;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100325;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100329;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100330;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100406;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100408;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100413;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100420;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100504;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100511;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100518;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;US-ASSIGNMENT DATABASE UPDATED:20100525;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;REEL/FRAME:23786/416</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;REEL/FRAME:023786/0416</span></div><div class="nested-key-value"><span class="nested-key">Owner name: </span><span class="nested-value">ROUND ROCK RESEARCH, LLC, NEW YORK</span></div></td></tr><tr><td class="patent-data-table-td patent-date-value">Aug 27, 2008</td><td class="patent-data-table-td ">FPAY</td><td class="patent-data-table-td ">Fee payment</td><td class="patent-data-table-td "><div class="nested-key-value"><span class="nested-key">Year of fee payment: </span><span class="nested-value">8</span></div></td></tr><tr><td class="patent-data-table-td patent-date-value">Aug 4, 2004</td><td class="patent-data-table-td ">FPAY</td><td class="patent-data-table-td ">Fee payment</td><td class="patent-data-table-td "><div class="nested-key-value"><span class="nested-key">Year of fee payment: </span><span class="nested-value">4</span></div></td></tr><tr><td class="patent-data-table-td patent-date-value">Jun 17, 2003</td><td class="patent-data-table-td ">CC</td><td class="patent-data-table-td ">Certificate of correction</td><td class="patent-data-table-td "></td></tr><tr><td class="patent-data-table-td patent-date-value">Oct 22, 2001</td><td class="patent-data-table-td ">AS</td><td class="patent-data-table-td ">Assignment</td><td class="patent-data-table-td "><div class="nested-key-value"><span class="nested-key">Owner name: </span><span class="nested-value">MICRON TECHNOLOGY, INC., IDAHO</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MEI CALIFORNIA INC;REEL/FRAME:012232/0436</span></div><div class="nested-key-value"><span class="nested-key">Effective date: </span><span class="nested-value">20010322</span></div><div class="nested-key-value"><span class="nested-key">Owner name: </span><span class="nested-value">MICRON TECHNOLOGY, INC. P.O. BOX 6 8000 SOUTH FEDE</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MEI CALIFORNIA INC /AR;REEL/FRAME:012232/0436</span></div></td></tr><tr><td class="patent-data-table-td patent-date-value">Mar 30, 2001</td><td class="patent-data-table-td ">AS</td><td class="patent-data-table-td ">Assignment</td><td class="patent-data-table-td "><div class="nested-key-value"><span class="nested-key">Owner name: </span><span class="nested-value">MEI CALIFORNIA, INC., CALIFORNIA</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICRON ELECTRONICS, INC.;REEL/FRAME:011658/0956</span></div><div class="nested-key-value"><span class="nested-key">Effective date: </span><span class="nested-value">20010322</span></div><div class="nested-key-value"><span class="nested-key">Owner name: </span><span class="nested-value">MEI CALIFORNIA, INC. 1545 BARBER LANE MILPITAS CAL</span></div></td></tr><tr><td class="patent-data-table-td patent-date-value">Mar 9, 1998</td><td class="patent-data-table-td ">AS</td><td class="patent-data-table-td ">Assignment</td><td class="patent-data-table-td "><div class="nested-key-value"><span class="nested-key">Owner name: </span><span class="nested-value">MICRON ELECTRONICS, INC., IDAHO</span></div><div class="nested-key-value"><span class="nested-key">Free format text: </span><span class="nested-value">ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:JOHNSON, KARL S.;WALLACH, WALTER A.;NGUYEN, KEN;AND OTHERS;REEL/FRAME:009034/0821;SIGNING DATES FROM 19980109 TO 19980210</span></div></td></tr></table><div class="patent-section-footer"></div></div><div class="modal-dialog" id="patent-images-lightbox"><div class="patent-lightbox-controls"><div class="patent-lightbox-rotate-controls"><div class="patent-lightbox-rotation-text">Rotate</div><div class="rotate-icon rotate-ccw-icon"></div><div class="rotate-icon rotate-cw-icon"></div></div><div class="patent-lightbox-index-counter"></div><a class="patent-lightbox-fullsize-link" target="_blank">Original Image</a><div class="patent-drawings-control patent-drawings-next"><img class="patent-drawings-button-img"src="/googlebooks/images/kennedy/page_right.png" alt="Next page"width="21" height="21" /></div><div class="patent-drawings-control patent-drawings-prev"><img class="patent-drawings-button-img"src="/googlebooks/images/kennedy/page_left.png" alt="Previous page"width="21" height="21" /></div></div><div class="modal-dialog-content"><div class="patent-lightbox-image-holder"><div class="patent-lightbox-placeholder"></div></div></div></div><script>_OC_initPatentsAtb({image_not_available_html: " Image not available"});</script></div></div></div></td></tr></table><script>(function() {var href = window.location.href;if (href.indexOf('?') !== -1) {var parameters = href.split('?')[1].split('&');for (var i = 0; i < parameters.length; i++) {var param = parameters[i].split('=');if (param[0] == 'focus') {var elem = document.getElementById(param[1]);if (elem) {elem.focus();}}}}})();</script><script>_OC_addFlags({LockSrc:"/books/javascript/lock_4ff636b3d23669b7103f3b3a3a18b4cd.js", Host:"http://www.google.com/", IsBooksRentalEnabled:1, IsWebstoreDisplayCaseEnabled:1, IsObfuscationEnabled:1, IsBrowsingHistoryEnabled:1, IsWebReaderSvgEnabled:0, IsGeoLayerEnabled:1, IsImageModeNotesEnabled:1, IsCopyMenuItemEnabled:1, IsGiftingEnabled:0, IsWebReaderUniversalPaginatorEnabled:0, IsOfflineBubbleEnabled:1, IsReaderEnabledForPlayRequests:1, IsFutureOnSaleVolumesEnabled:1, IsOfflineRestrictedCopyEnabled:1, IsBooksUnifiedLeftNavEnabled:1, IsRestrictedCopyEnabled:1, IsZipitFolderCollectionEnabled:1, IsEndOfSampleRecommendationsEnabled:1, IsRatingsOnBookcardsEnabled:1, IsAdsDisabled:0, IsIframePageDisplayEnabled:0, IsEmbeddedMediaEnabled:1, IsImageModeAnnotationsEnabled:1, IsMyLibraryGooglePlusEnabled:1, IsImagePageProviderEnabled:0, IsBookcardListPriceSmall:0, IsInternalUser:0, IsBooksShareButtonEnabled:0, IsPreOrdersEnabled:0, IsDisabledRandomBookshelves:0, WebstoreDisplayCasePosition:3});_OC_Run({"enable_p13n":false,"add_vol_to_collection_base_url":"http://www.google.com/patents?op=add\u0026sig=ACfU3U2aN0N5YICPwGWMoZXCEWPA2Ly3Bg\u0026id=8nxTBAABERAJ","remove_vol_from_collection_base_url":"http://www.google.com/patents?op=remove\u0026sig=ACfU3U1ho8DBdpOtmrCHz1V-gRvlldUHpA\u0026id=8nxTBAABERAJ","logged_in":false,"p13n_save_user_settings_url":"http://www.google.com/patents?op=edit_user_settings\u0026sig=ACfU3U04HqWpX-6AdF4aYQOB2L98ZwbgFQ","is_cobrand":false,"sign_in_url":"https://www.google.com/accounts/Login?service=\u0026continue=http://www.google.com/patents%3Fhl%3Den\u0026hl=en","is_play_enabled":true}, {"volume_id":"","is_ebook":true,"volumeresult":{"has_flowing_text":false,"has_scanned_text":true,"can_download_pdf":false,"can_download_epub":false,"is_pdf_drm_enabled":false,"is_epub_drm_enabled":false,"download_pdf_url":"http://www.google.com/patents/download/Method_for_mapping_environmental_resourc.pdf?id=8nxTBAABERAJ\u0026output=pdf\u0026sig=ACfU3U1onk8wwYypVMwChhAMgPQPmcAUng"},"sample_url":"http://www.google.com/patents/reader?id=8nxTBAABERAJ\u0026printsec=frontcover\u0026output=reader\u0026source=gbs_atb_hover","is_browsable":true,"is_public_domain":true}, {});</script><div id="footer_table" style="font-size:83%;text-align:center;position:relative;top:20px;height:4.5em;margin-top:2em"><div style="margin-bottom:8px"><a href=http://www.google.com/><nobr>Google&nbsp;Home</nobr></a> - <a href=//www.google.com/patents/sitemap/><nobr>Sitemap</nobr></a> - <a href=http://www.google.com/googlebooks/uspto.html><nobr>USPTO Bulk Downloads</nobr></a> - <a href=/intl/en/privacy/><nobr>Privacy Policy</nobr></a> - <a href=/intl/en/policies/terms/><nobr>Terms of Service</nobr></a> - <a href=https://support.google.com/faqs/answer/2539193?hl=en><nobr>About Google Patents</nobr></a> - <a href="http://www.google.com/tools/feedback/intl/en/error.html" onclick="try{_OC_startFeedback({productId: '72792',locale: 'en'});return false;}catch(e){}"><nobr>Send Feedback</nobr></a></div><span>Data provided by IFI CLAIMS Patent Services</span><br><span >&copy;2012 Google</span></div> <script type="text/javascript">var gaJsHost = (("https:" == document.location.protocol) ? "https://ssl." : "http://www.");document.write(unescape("%3Cscript src='" + gaJsHost + "google-analytics.com/ga.js' type='text/javascript'%3E%3C/script%3E"));</script><script type="text/javascript">var pageTracker = _gat._getTracker("UA-27188110-1");pageTracker._setCookiePath("/patents/");pageTracker._trackPageview();</script> </body></html>