ZealOS/docs/Kernel/KDebug.CC.html
TomAwezome 6b3fd2fecb Rename abs_addres to abs_address.
Update documentation/comments to rename addr, fun, var, stmt, blk, desc, reg, seg, ptr, dup, clus, val, and bttn, to address, function, variable, statement, block, description, register, segment, pointer, duplicate, cluster, value, and button, respectively.
2021-10-06 21:35:32 -04:00

786 lines
80 KiB
HTML
Executable file

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=US-ASCII">
<meta name="generator" content="ZealOS V1.01">
<style type="text/css">
body {background-color:#fef1f0;}
.cF0{color:#000000;background-color:#fef1f0;}
.cF1{color:#0148a4;background-color:#fef1f0;}
.cF2{color:#3b7901;background-color:#fef1f0;}
.cF3{color:#057c7e;background-color:#fef1f0;}
.cF4{color:#bb2020;background-color:#fef1f0;}
.cF5{color:#9e42ae;background-color:#fef1f0;}
.cF6{color:#b57901;background-color:#fef1f0;}
.cF7{color:#b2b6af;background-color:#fef1f0;}
.cF8{color:#555753;background-color:#fef1f0;}
.cF9{color:#678fbb;background-color:#fef1f0;}
.cFA{color:#82bc49;background-color:#fef1f0;}
.cFB{color:#0097a2;background-color:#fef1f0;}
.cFC{color:#e26a6a;background-color:#fef1f0;}
.cFD{color:#c671bc;background-color:#fef1f0;}
.cFE{color:#c7ab00;background-color:#fef1f0;}
.cFF{color:#fef1f0;background-color:#fef1f0;}
</style>
</head>
<body>
<pre style="font-family:monospace;font-size:12pt">
<a name="l1"></a><span class=cF1>Bool</span><span class=cF0> </span><span class=cF5>CheckPtr</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *ptr)
<a name="l2"></a>{</span><span class=cF2>//Check if address is valid pointer.</span><span class=cF0>
<a name="l3"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cFB>mem_heap_base</span><span class=cF0> &lt;= ptr &lt;= </span><span class=cFB>mem_mapped_space</span><span class=cF0>)
<a name="l4"></a> </span><span class=cF1>return</span><span class=cF0> *</span><span class=cF5>MemPageTable</span><span class=cF0>(ptr) &amp; </span><span class=cFE>1</span><span class=cF0>;
<a name="l5"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l6"></a> </span><span class=cF1>return</span><span class=cF0> </span><span class=cFB>mem_boot_base</span><span class=cF0> &lt; ptr &lt; </span><span class=cF3>VGAM_GRAPHICS</span><span class=cF0>;
<a name="l7"></a>}
<a name="l8"></a>
<a name="l9"></a></span><span class=cF1>Bool</span><span class=cF0> </span><span class=cF5>CheckCodePtr</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *ptr)
<a name="l10"></a>{</span><span class=cF2>//Check if address is valid code address.</span><span class=cF0>
<a name="l11"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cFB>mem_heap_base</span><span class=cF0> &lt;= ptr &lt;= </span><span class=cFB>mem_heap_limit</span><span class=cF0>)
<a name="l12"></a> </span><span class=cF1>return</span><span class=cF0> *</span><span class=cF5>MemPageTable</span><span class=cF0>(ptr) &amp; </span><span class=cFE>1</span><span class=cF0>;
<a name="l13"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l14"></a> </span><span class=cF1>return</span><span class=cF0> </span><span class=cFB>mem_boot_base</span><span class=cF0> &lt; ptr &lt; </span><span class=cF3>VGAM_GRAPHICS</span><span class=cF0>;
<a name="l15"></a>}
<a name="l16"></a>
<a name="l17"></a></span><span class=cF1>Bool</span><span class=cF0> </span><span class=cF5>CheckOnStack</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *ptr, </span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>)
<a name="l18"></a>{</span><span class=cF2>//Check if address is valid stack address.</span><span class=cF0>
<a name="l19"></a> </span><span class=cF1>Bool</span><span class=cF0> res = </span><span class=cF3>FALSE</span><span class=cF0>;
<a name="l20"></a>
<a name="l21"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l22"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l23"></a> </span><span class=cF1>if</span><span class=cF0> (task)
<a name="l24"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l25"></a> </span><span class=cF1>if</span><span class=cF0> (&amp;task-&gt;stack-&gt;stack_base &lt;= ptr &lt;= </span><span class=cF7>(</span><span class=cF0>&amp;task-&gt;stack-&gt;stack_base</span><span class=cF7>)(</span><span class=cF1>U8</span><span class=cF0> *</span><span class=cF7>)</span><span class=cF0> + task-&gt;stack-&gt;stack_size)
<a name="l26"></a> res = </span><span class=cF3>TRUE</span><span class=cF0>;
<a name="l27"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l28"></a> </span><span class=cF1>else</span><span class=cF0> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cFB>mem_heap_base</span><span class=cF0> &lt;= ptr &lt;= </span><span class=cFB>mem_heap_limit</span><span class=cF0>)
<a name="l29"></a> res = </span><span class=cF3>TRUE</span><span class=cF0>;
<a name="l30"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l31"></a>
<a name="l32"></a> </span><span class=cF1>return</span><span class=cF0> res;
<a name="l33"></a>}
<a name="l34"></a>
<a name="l35"></a></span><span class=cF9>I64</span><span class=cF0> </span><span class=cF5>UnusedStack</span><span class=cF0>(</span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>)
<a name="l36"></a>{</span><span class=cF2>//Count of usused bytes in task's stack.</span><span class=cF0>
<a name="l37"></a> </span><span class=cF9>I64</span><span class=cF0> res;
<a name="l38"></a>
<a name="l39"></a> </span><span class=cF1>if</span><span class=cF0> (!task)
<a name="l40"></a> task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l41"></a>
<a name="l42"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l43"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l44"></a> </span><span class=cF1>if</span><span class=cF0> (task == </span><span class=cF5>Fs</span><span class=cF0>)
<a name="l45"></a> res = </span><span class=cF5>RSPGet</span><span class=cF0>()(</span><span class=cF1>U8</span><span class=cF0> *) - (&amp;task-&gt;stack-&gt;stack_base)(</span><span class=cF1>U8</span><span class=cF0> *);
<a name="l46"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l47"></a> res = task-&gt;rsp(</span><span class=cF1>U8</span><span class=cF0> *) - (&amp;task-&gt;stack-&gt;stack_base)(</span><span class=cF1>U8</span><span class=cF0> *);
<a name="l48"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l49"></a>
<a name="l50"></a> </span><span class=cF1>return</span><span class=cF0> res;
<a name="l51"></a>}
<a name="l52"></a>
<a name="l53"></a></span><span class=cF1>U8</span><span class=cF0> *</span><span class=cF5>Caller</span><span class=cF0>(</span><span class=cF9>I64</span><span class=cF0> num=</span><span class=cFE>1</span><span class=cF0>)
<a name="l54"></a>{</span><span class=cF2>//Returns the address of the function which called this one,</span><span class=cF0>
<a name="l55"></a></span><span class=cF2>//or the caller of the caller, etc.</span><span class=cF0>
<a name="l56"></a> </span><span class=cF1>U8</span><span class=cF0> **rbp = </span><span class=cF5>RBPGet</span><span class=cF0>, **ptr;
<a name="l57"></a>
<a name="l58"></a> </span><span class=cF1>while</span><span class=cF0> (num--)
<a name="l59"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l60"></a> </span><span class=cF1>if</span><span class=cF0> (rbp &gt;= *rbp)
<a name="l61"></a> </span><span class=cF1>return</span><span class=cF0> </span><span class=cF3>NULL</span><span class=cF0>;
<a name="l62"></a> rbp = *rbp;
<a name="l63"></a> </span><span class=cF1>if</span><span class=cF0> (!</span><span class=cF5>CheckOnStack</span><span class=cF7>(</span><span class=cF0>rbp, </span><span class=cF5>Fs</span><span class=cF7>)</span><span class=cF0>)
<a name="l64"></a> </span><span class=cF1>return</span><span class=cF0> </span><span class=cF3>NULL</span><span class=cF0>;
<a name="l65"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l66"></a> ptr = rbp + </span><span class=cFE>1</span><span class=cF0>;
<a name="l67"></a> </span><span class=cF1>return</span><span class=cF0> *ptr;
<a name="l68"></a>}
<a name="l69"></a>
<a name="l70"></a></span><span class=cF1>U8</span><span class=cF0> *</span><span class=cF5>TaskCaller</span><span class=cF0>(</span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>, </span><span class=cF9>I64</span><span class=cF0> num=</span><span class=cFE>0</span><span class=cF0>, </span><span class=cF1>Bool</span><span class=cF0> saved_context=</span><span class=cF3>FALSE</span><span class=cF0>)
<a name="l71"></a>{</span><span class=cF2>//Fetches address of Nth caller on task's stack.</span><span class=cF0>
<a name="l72"></a> </span><span class=cF1>U8</span><span class=cF0> **ptr, **rbp, **rsp;
<a name="l73"></a>
<a name="l74"></a> </span><span class=cF1>if</span><span class=cF0> (!task)
<a name="l75"></a> task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l76"></a> </span><span class=cF1>if</span><span class=cF0> (!saved_context &amp;&amp; task == </span><span class=cF5>Fs</span><span class=cF0>)
<a name="l77"></a> </span><span class=cF1>return</span><span class=cF0> </span><span class=cF5>Caller</span><span class=cF0>(num + </span><span class=cFE>1</span><span class=cF0>);
<a name="l78"></a> </span><span class=cF1>if</span><span class=cF0> (!</span><span class=cF5>TaskValidate</span><span class=cF7>(</span><span class=cF0>task</span><span class=cF7>)</span><span class=cF0>)
<a name="l79"></a> </span><span class=cF1>return</span><span class=cF0> </span><span class=cF3>NULL</span><span class=cF0>;
<a name="l80"></a> rbp = task-&gt;rbp;
<a name="l81"></a> rsp = task-&gt;rsp;
<a name="l82"></a> </span><span class=cF1>if</span><span class=cF0> (num)
<a name="l83"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l84"></a> </span><span class=cF1>while</span><span class=cF0> (</span><span class=cF5>CheckOnStack</span><span class=cF7>(</span><span class=cF0>rbp, task</span><span class=cF7>)</span><span class=cF0>)
<a name="l85"></a> {
<a name="l86"></a> ptr = rbp + </span><span class=cFE>1</span><span class=cF0>;
<a name="l87"></a> </span><span class=cF1>if</span><span class=cF0> (! --num)
<a name="l88"></a> </span><span class=cF1>return</span><span class=cF0> *ptr;
<a name="l89"></a> </span><span class=cF1>if</span><span class=cF0> (rbp &gt;= *rbp)
<a name="l90"></a> </span><span class=cF1>break</span><span class=cF0>;
<a name="l91"></a> rbp = *rbp;
<a name="l92"></a> }
<a name="l93"></a> </span><span class=cF1>return</span><span class=cF0> </span><span class=cF3>NULL</span><span class=cF0>;
<a name="l94"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l95"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l96"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l97"></a> </span><span class=cF1>if</span><span class=cF0> (task-&gt;rip == </span><span class=cFD>_RET</span><span class=cF0>)
<a name="l98"></a> </span><span class=cF1>return</span><span class=cF0> *rsp;
<a name="l99"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l100"></a> </span><span class=cF1>return</span><span class=cF0> task-&gt;rip;
<a name="l101"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l102"></a>}
<a name="l103"></a>#</span><span class=cF1>define</span><span class=cF0> STACK_REP_LEN </span><span class=cFE>32</span><span class=cF0>
<a name="l104"></a>
<a name="l105"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>StackRep</span><span class=cF0>(</span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>)
<a name="l106"></a>{</span><span class=cF2>//Reports whats on the stack.</span><span class=cF0>
<a name="l107"></a> </span><span class=cF9>I64</span><span class=cF0> i, j, addr, **rbp, **rsp, *my_rsp[STACK_REP_LEN];
<a name="l108"></a> </span><span class=cF9>CHashTable</span><span class=cF0> *old_hash = </span><span class=cF5>Fs</span><span class=cF0>-&gt;hash_table;
<a name="l109"></a>
<a name="l110"></a> </span><span class=cF1>if</span><span class=cF0> (!task)
<a name="l111"></a> task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l112"></a> </span><span class=cF1>if</span><span class=cF0> (!</span><span class=cF5>TaskValidate</span><span class=cF7>(</span><span class=cF0>task</span><span class=cF7>)</span><span class=cF0>)
<a name="l113"></a> </span><span class=cF1>return</span><span class=cF0>;
<a name="l114"></a>
<a name="l115"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l116"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l117"></a> </span><span class=cF1>if</span><span class=cF0> (task == </span><span class=cF5>Fs</span><span class=cF0>)
<a name="l118"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l119"></a> rbp = </span><span class=cF5>RBPGet</span><span class=cF0>;
<a name="l120"></a> rsp = rbp + </span><span class=cFE>3</span><span class=cF0>;
<a name="l121"></a> rbp = *rbp;
<a name="l122"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l123"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l124"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l125"></a> rsp = task-&gt;rsp;
<a name="l126"></a> rbp = task-&gt;rbp;
<a name="l127"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l128"></a> </span><span class=cF1>if</span><span class=cF0> (task-&gt;rip == </span><span class=cFD>_RET</span><span class=cF0>)
<a name="l129"></a> addr = *rsp;
<a name="l130"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l131"></a> addr = task-&gt;rip;
<a name="l132"></a> </span><span class=cF5>MemCopy</span><span class=cF0>(my_rsp, rsp, STACK_REP_LEN * </span><span class=cF1>sizeof</span><span class=cF7>(</span><span class=cF1>U8</span><span class=cF0> *</span><span class=cF7>)</span><span class=cF0>);
<a name="l133"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l134"></a>
<a name="l135"></a> </span><span class=cF5>Fs</span><span class=cF0>-&gt;hash_table = task-&gt;hash_table;
<a name="l136"></a> </span><span class=cF1>for</span><span class=cF0> (i = </span><span class=cFE>0</span><span class=cF0>; i &lt; STACK_REP_LEN; i++)
<a name="l137"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l138"></a> </span><span class=cF6>&quot;%08X [RSP+%04X]: %016X &quot;</span><span class=cF0>, rsp + i, i * </span><span class=cF1>sizeof</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *), my_rsp[i];
<a name="l139"></a> </span><span class=cF1>while</span><span class=cF0> (</span><span class=cF3>TRUE</span><span class=cF0>)
<a name="l140"></a> {
<a name="l141"></a> </span><span class=cF1>if</span><span class=cF0> (!</span><span class=cF7>(</span><span class=cF0>&amp;task-&gt;stack-&gt;stack_base &lt;= rbp &lt; (&amp;task-&gt;stack-&gt;stack_base)(</span><span class=cF1>U8</span><span class=cF0> *) + task-&gt;stack-&gt;stack_size</span><span class=cF7>)</span><span class=cF0>)
<a name="l142"></a> </span><span class=cF1>break</span><span class=cF0>;
<a name="l143"></a> j = rbp - rsp;
<a name="l144"></a> </span><span class=cF1>if</span><span class=cF0> (j &gt;= i)
<a name="l145"></a> </span><span class=cF1>break</span><span class=cF0>;
<a name="l146"></a> addr = my_rsp[j + </span><span class=cFE>1</span><span class=cF0>];
<a name="l147"></a> </span><span class=cF1>if</span><span class=cF0> (rbp &gt;= my_rsp[j])
<a name="l148"></a> </span><span class=cF1>break</span><span class=cF0>;
<a name="l149"></a> rbp = my_rsp[j];
<a name="l150"></a> }
<a name="l151"></a> </span><span class=cF1>if</span><span class=cF0> (my_rsp[i] == addr &amp;&amp; !</span><span class=cF5>IsRaw</span><span class=cF0>)
<a name="l152"></a> </span><span class=cF6>&quot;$BG,YELLOW$&quot;</span><span class=cF0>;
<a name="l153"></a> </span><span class=cF6>&quot;%P&quot;</span><span class=cF0>, my_rsp[i];
<a name="l154"></a> </span><span class=cF1>if</span><span class=cF0> (!</span><span class=cF5>IsRaw</span><span class=cF0>)
<a name="l155"></a> </span><span class=cF6>&quot;$BG$&quot;</span><span class=cF0>;
<a name="l156"></a> </span><span class=cF6>'\n'</span><span class=cF0>;
<a name="l157"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l158"></a> </span><span class=cF6>'\n'</span><span class=cF0>;
<a name="l159"></a> </span><span class=cF5>Fs</span><span class=cF0>-&gt;hash_table = old_hash;
<a name="l160"></a>}
<a name="l161"></a>
<a name="l162"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>CallerRep</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> **rbp=</span><span class=cF3>NULL</span><span class=cF0>, </span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>)
<a name="l163"></a>{</span><span class=cF2>//Prints a report of calling routines.</span><span class=cF0>
<a name="l164"></a> </span><span class=cF9>I64</span><span class=cF0> **ptr;
<a name="l165"></a>
<a name="l166"></a> </span><span class=cF1>if</span><span class=cF0> (!task)
<a name="l167"></a> task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l168"></a> </span><span class=cF1>if</span><span class=cF0> (!rbp)
<a name="l169"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l170"></a> </span><span class=cF1>if</span><span class=cF0> (task == </span><span class=cF5>Fs</span><span class=cF0>)
<a name="l171"></a> rbp = </span><span class=cF5>RBPGet</span><span class=cF0>;
<a name="l172"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l173"></a> rbp = task-&gt;rbp;
<a name="l174"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l175"></a> </span><span class=cF6>&quot;CallerRep:\n&quot;</span><span class=cF0>;
<a name="l176"></a> </span><span class=cF1>while</span><span class=cF0> (</span><span class=cF5>CheckOnStack</span><span class=cF7>(</span><span class=cF0>rbp, task</span><span class=cF7>)</span><span class=cF0>)
<a name="l177"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l178"></a> ptr = rbp + </span><span class=cFE>1</span><span class=cF0>;
<a name="l179"></a> </span><span class=cF6>&quot;%08X: %08tX: %P\n&quot;</span><span class=cF0>, ptr, *ptr, *ptr;
<a name="l180"></a> </span><span class=cF1>if</span><span class=cF0> (rbp &gt;= *rbp)
<a name="l181"></a> </span><span class=cF1>break</span><span class=cF0>;
<a name="l182"></a> rbp = *rbp;
<a name="l183"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l184"></a>}
<a name="l185"></a>
<a name="l186"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>D</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *addr, </span><span class=cF9>I64</span><span class=cF0> count=</span><span class=cFE>0x80</span><span class=cF0>, </span><span class=cF1>Bool</span><span class=cF0> show_offset=</span><span class=cF3>TRUE</span><span class=cF0>)
<a name="l187"></a>{</span><span class=cF2>//Dump mem, showing offsets.</span><span class=cF0>
<a name="l188"></a></span><span class=cF2>//See </span><a href="https://zeal-operating-system.github.io/ZealOS/System/DolDoc/DocPutS.CC.html#l366"><span class=cF4>DocD</span></a><span class=cF2>() for a live dump.</span><span class=cF0>
<a name="l189"></a> </span><span class=cF9>I64</span><span class=cF0> i, j, ch;
<a name="l190"></a> </span><span class=cF1>U8</span><span class=cF0> *ptr = addr;
<a name="l191"></a>
<a name="l192"></a> </span><span class=cF1>while</span><span class=cF0> (count)
<a name="l193"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l194"></a> </span><span class=cF1>if</span><span class=cF0> (show_offset)
<a name="l195"></a> </span><span class=cF6>&quot;%08X &quot;</span><span class=cF0>, ptr - addr;
<a name="l196"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l197"></a> </span><span class=cF6>&quot;%010X &quot;</span><span class=cF0>, ptr;
<a name="l198"></a> </span><span class=cF1>if</span><span class=cF0> (count &gt; </span><span class=cFE>16</span><span class=cF0>)
<a name="l199"></a> j = </span><span class=cFE>16</span><span class=cF0>;
<a name="l200"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l201"></a> j = count;
<a name="l202"></a> </span><span class=cF1>for</span><span class=cF0> (i = </span><span class=cFE>0</span><span class=cF0>; i &lt; j; i++)
<a name="l203"></a> </span><span class=cF6>&quot;%02X &quot;</span><span class=cF0>, ptr[i];
<a name="l204"></a> </span><span class=cF1>for</span><span class=cF0> (; i &lt; </span><span class=cFE>16</span><span class=cF0>; i++)
<a name="l205"></a> </span><span class=cF6>&quot; &quot;</span><span class=cF0>;
<a name="l206"></a> </span><span class=cF1>for</span><span class=cF0> (i = </span><span class=cFE>0</span><span class=cF0>; i &lt; j; i++)
<a name="l207"></a> {
<a name="l208"></a> ch = ptr[i];
<a name="l209"></a> </span><span class=cF1>if</span><span class=cF0> (ch &lt; </span><span class=cF3>CH_SPACE</span><span class=cF0> || ch == </span><span class=cF3>CH_BACKSPACE</span><span class=cF0>)
<a name="l210"></a> ch = </span><span class=cF6>'.'</span><span class=cF0>;
<a name="l211"></a> </span><span class=cF6>''</span><span class=cF0> ch;
<a name="l212"></a> </span><span class=cF1>if</span><span class=cF0> (ch == </span><span class=cF6>'$'</span><span class=cF0>)
<a name="l213"></a> </span><span class=cF6>''</span><span class=cF0> ch;
<a name="l214"></a> }
<a name="l215"></a> </span><span class=cF6>'\n'</span><span class=cF0>;
<a name="l216"></a> count -= j;
<a name="l217"></a> ptr += j;
<a name="l218"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l219"></a>}
<a name="l220"></a>
<a name="l221"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>Dm</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *addr, </span><span class=cF9>I64</span><span class=cF0> count=</span><span class=cFE>0x80</span><span class=cF0>)
<a name="l222"></a>{</span><span class=cF2>//Show mem address, not offsets.</span><span class=cF0>
<a name="l223"></a> </span><span class=cF5>D</span><span class=cF0>(addr, count, </span><span class=cF3>FALSE</span><span class=cF0>);
<a name="l224"></a>}
<a name="l225"></a>
<a name="l226"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>Da</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> **addr, </span><span class=cF9>I64</span><span class=cF0> count=</span><span class=cFE>0x10</span><span class=cF0>)
<a name="l227"></a>{</span><span class=cF2>//Dump mem, showing symbolic addresses.</span><span class=cF0>
<a name="l228"></a> </span><span class=cF1>while</span><span class=cF0> (count-- &gt; </span><span class=cFE>0</span><span class=cF0>)
<a name="l229"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l230"></a> </span><span class=cF6>&quot;%08X:%08X,%P\n&quot;</span><span class=cF0>, addr, *addr, *addr;
<a name="l231"></a> addr++;
<a name="l232"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l233"></a>}
<a name="l234"></a>
<a name="l235"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>RawPrint</span><span class=cF0>(</span><span class=cF9>I64</span><span class=cF0> mS=</span><span class=cFE>100</span><span class=cF0>, </span><span class=cF1>U8</span><span class=cF0> *format, ...)
<a name="l236"></a>{</span><span class=cF2>//Print using </span><a href="https://zeal-operating-system.github.io/ZealOS/Kernel/KMisc.CC.html#l257"><span class=cF4>Raw</span></a><span class=cF2> screen output for a length of time.</span><span class=cF0>
<a name="l237"></a></span><span class=cF2>//Your heap must be good.</span><span class=cF0>
<a name="l238"></a> </span><span class=cF1>U8</span><span class=cF0> *buf = </span><span class=cF5>StrPrintJoin</span><span class=cF0>(</span><span class=cF3>NULL</span><span class=cF0>, format, argc, argv);
<a name="l239"></a> </span><span class=cF1>Bool</span><span class=cF0> old_raw, old_input_filter;
<a name="l240"></a>
<a name="l241"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l242"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l243"></a> old_raw = </span><span class=cF5>Raw</span><span class=cF0>(</span><span class=cF3>ON</span><span class=cF0>);
<a name="l244"></a> old_input_filter = </span><span class=cF5>LBtr</span><span class=cF0>(&amp;</span><span class=cF5>Fs</span><span class=cF0>-&gt;task_flags, </span><span class=cF3>TASKf_INPUT_FILTER_TASK</span><span class=cF0>);
<a name="l245"></a> </span><span class=cF6>&quot;%s&quot;</span><span class=cF0>, buf;
<a name="l246"></a> </span><span class=cF5>Busy</span><span class=cF0>(mS &lt;&lt; </span><span class=cFE>10</span><span class=cF0>);
<a name="l247"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l248"></a>
<a name="l249"></a> </span><span class=cF5>LBEqual</span><span class=cF0>(&amp;</span><span class=cF5>Fs</span><span class=cF0>-&gt;task_flags, </span><span class=cF3>TASKf_INPUT_FILTER_TASK</span><span class=cF0>, old_input_filter);
<a name="l250"></a> </span><span class=cF5>Raw</span><span class=cF0>(old_raw);
<a name="l251"></a> </span><span class=cF5>Free</span><span class=cF0>(buf);
<a name="l252"></a>}
<a name="l253"></a>
<a name="l254"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>RawD</span><span class=cF0>(</span><span class=cF9>I64</span><span class=cF0> mS=</span><span class=cFE>100</span><span class=cF0>, </span><span class=cF1>U8</span><span class=cF0> *addr, </span><span class=cF9>I64</span><span class=cF0> count=</span><span class=cFE>0x80</span><span class=cF0>)
<a name="l255"></a>{</span><span class=cF2>//Dumps a block of mem using </span><a href="https://zeal-operating-system.github.io/ZealOS/Kernel/KMisc.CC.html#l257"><span class=cF4>Raw</span></a><span class=cF0>
<a name="l256"></a></span><span class=cF2>//screen output for a fixed length</span><span class=cF0>
<a name="l257"></a> </span><span class=cF2>//of time.</span><span class=cF0>
<a name="l258"></a> </span><span class=cF1>Bool</span><span class=cF0> old_raw, old_input_filter;
<a name="l259"></a>
<a name="l260"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l261"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l262"></a> old_raw = </span><span class=cF5>Raw</span><span class=cF0>(</span><span class=cF3>ON</span><span class=cF0>);
<a name="l263"></a> old_input_filter = </span><span class=cF5>LBtr</span><span class=cF0>(&amp;</span><span class=cF5>Fs</span><span class=cF0>-&gt;task_flags, </span><span class=cF3>TASKf_INPUT_FILTER_TASK</span><span class=cF0>);
<a name="l264"></a> </span><span class=cF5>D</span><span class=cF0>(addr, count);
<a name="l265"></a> </span><span class=cF5>Busy</span><span class=cF0>(mS &lt;&lt; </span><span class=cFE>10</span><span class=cF0>);
<a name="l266"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l267"></a>
<a name="l268"></a> </span><span class=cF5>LBEqual</span><span class=cF0>(&amp;</span><span class=cF5>Fs</span><span class=cF0>-&gt;task_flags, </span><span class=cF3>TASKf_INPUT_FILTER_TASK</span><span class=cF0>, old_input_filter);
<a name="l269"></a> </span><span class=cF5>Raw</span><span class=cF0>(old_raw);
<a name="l270"></a>}
<a name="l271"></a>
<a name="l272"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>RawDm</span><span class=cF0>(</span><span class=cF9>I64</span><span class=cF0> mS=</span><span class=cFE>100</span><span class=cF0>, </span><span class=cF1>U8</span><span class=cF0> *addr, </span><span class=cF9>I64</span><span class=cF0> count=</span><span class=cFE>0x80</span><span class=cF0>)
<a name="l273"></a>{</span><span class=cF2>//Dumps a block of mem using </span><a href="https://zeal-operating-system.github.io/ZealOS/Kernel/KMisc.CC.html#l257"><span class=cF4>Raw</span></a><span class=cF0>
<a name="l274"></a></span><span class=cF2>//screen output for a fixed length</span><span class=cF0>
<a name="l275"></a> </span><span class=cF2>//of time.</span><span class=cF0>
<a name="l276"></a> </span><span class=cF1>Bool</span><span class=cF0> old_raw, old_input_filter;
<a name="l277"></a>
<a name="l278"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l279"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l280"></a> old_raw = </span><span class=cF5>Raw</span><span class=cF0>(</span><span class=cF3>ON</span><span class=cF0>);
<a name="l281"></a> old_input_filter = </span><span class=cF5>LBtr</span><span class=cF0>(&amp;</span><span class=cF5>Fs</span><span class=cF0>-&gt;task_flags, </span><span class=cF3>TASKf_INPUT_FILTER_TASK</span><span class=cF0>);
<a name="l282"></a> </span><span class=cF5>Dm</span><span class=cF0>(addr, count);
<a name="l283"></a> </span><span class=cF5>Busy</span><span class=cF0>(mS &lt;&lt; </span><span class=cFE>10</span><span class=cF0>);
<a name="l284"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l285"></a>
<a name="l286"></a> </span><span class=cF5>LBEqual</span><span class=cF0>(&amp;</span><span class=cF5>Fs</span><span class=cF0>-&gt;task_flags, </span><span class=cF3>TASKf_INPUT_FILTER_TASK</span><span class=cF0>, old_input_filter);
<a name="l287"></a> </span><span class=cF5>Raw</span><span class=cF0>(old_raw);
<a name="l288"></a>}
<a name="l289"></a>
<a name="l290"></a></span><span class=cF9>I64</span><span class=cF0> *</span><span class=cF5>TaskRegAddr</span><span class=cF0>(</span><span class=cF9>CTask</span><span class=cF0> *task, </span><span class=cF9>I64</span><span class=cF0> reg_num)
<a name="l291"></a>{
<a name="l292"></a> </span><span class=cF1>switch</span><span class=cF0> (reg_num)
<a name="l293"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l294"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cF3>REG_RAX</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;rax;
<a name="l295"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cF3>REG_RCX</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;rcx;
<a name="l296"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cF3>REG_RDX</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;rdx;
<a name="l297"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cF3>REG_RBX</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;rbx;
<a name="l298"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cF3>REG_RSP</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;rsp;
<a name="l299"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cF3>REG_RBP</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;rbp;
<a name="l300"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cF3>REG_RSI</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;rsi;
<a name="l301"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cF3>REG_RDI</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;rdi;
<a name="l302"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cFE>8</span><span class=cF0> : </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;r8;
<a name="l303"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cFE>9</span><span class=cF0> : </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;r9;
<a name="l304"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cFE>10</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;r10;
<a name="l305"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cFE>11</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;r11;
<a name="l306"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cFE>12</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;r12;
<a name="l307"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cFE>13</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;r13;
<a name="l308"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cFE>14</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;r14;
<a name="l309"></a> </span><span class=cF1>case</span><span class=cF0> </span><span class=cFE>15</span><span class=cF0>: </span><span class=cF1>return</span><span class=cF0> &amp;task-&gt;r15;
<a name="l310"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l311"></a> </span><span class=cF1>return</span><span class=cF0> </span><span class=cF3>NULL</span><span class=cF0>;
<a name="l312"></a>}
<a name="l313"></a>
<a name="l314"></a>#</span><span class=cF1>define</span><span class=cF0> RAWDR_COL (</span><span class=cFB>text</span><span class=cF0>.cols - </span><span class=cFE>40</span><span class=cF0>)
<a name="l315"></a>
<a name="l316"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>RawDr</span><span class=cF0>(</span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>)
<a name="l317"></a>{
<a name="l318"></a> </span><span class=cF9>I64</span><span class=cF0> i, j, old_col = </span><span class=cFB>text</span><span class=cF0>.raw_col;
<a name="l319"></a> </span><span class=cF1>Bool</span><span class=cF0> old_raw = </span><span class=cF5>Raw</span><span class=cF0>(</span><span class=cF3>ON</span><span class=cF0>);
<a name="l320"></a> </span><span class=cF1>U8</span><span class=cF0> buf[</span><span class=cFE>200</span><span class=cF0>];
<a name="l321"></a>
<a name="l322"></a> </span><span class=cF1>if</span><span class=cF0> (!task)
<a name="l323"></a> task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l324"></a>
<a name="l325"></a> </span><span class=cFB>text</span><span class=cF0>.raw_col = RAWDR_COL;
<a name="l326"></a> </span><span class=cF6>'.'</span><span class=cF0>;
<a name="l327"></a> </span><span class=cF1>for</span><span class=cF0> (j = </span><span class=cFE>0</span><span class=cF0>; j &lt; </span><span class=cFB>text</span><span class=cF0>.cols - RAWDR_COL - </span><span class=cFE>1</span><span class=cF0>; j++)
<a name="l328"></a> </span><span class=cF6>'.'</span><span class=cF0>;
<a name="l329"></a>
<a name="l330"></a> </span><span class=cF1>for</span><span class=cF0> (i = </span><span class=cFE>0</span><span class=cF0>; i &lt; </span><span class=cFE>16</span><span class=cF0>; i++)
<a name="l331"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l332"></a> </span><span class=cFB>text</span><span class=cF0>.raw_col = (i + </span><span class=cFE>1</span><span class=cF0>) * </span><span class=cFB>text</span><span class=cF0>.cols + RAWDR_COL;
<a name="l333"></a> </span><span class=cF6>&quot;.%3Z: %016X\n&quot;</span><span class=cF0>, i, </span><span class=cF6>&quot;ST_U64_REGS&quot;</span><span class=cF0>, *</span><span class=cF5>TaskRegAddr</span><span class=cF0>(task, i);
<a name="l334"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l335"></a>
<a name="l336"></a> i++;
<a name="l337"></a>
<a name="l338"></a> </span><span class=cFB>text</span><span class=cF0>.raw_col = i++ * </span><span class=cFB>text</span><span class=cF0>.cols + RAWDR_COL;
<a name="l339"></a> </span><span class=cF6>&quot;.RIP: %016X\n&quot;</span><span class=cF0>, task-&gt;rip;
<a name="l340"></a>
<a name="l341"></a> </span><span class=cFB>text</span><span class=cF0>.raw_col = i++ * </span><span class=cFB>text</span><span class=cF0>.cols + RAWDR_COL;
<a name="l342"></a> </span><span class=cF6>&quot;.%-*tp\n&quot;</span><span class=cF0>, </span><span class=cFB>text</span><span class=cF0>.cols - (RAWDR_COL + </span><span class=cFE>1</span><span class=cF0>) - </span><span class=cFE>1</span><span class=cF0>, </span><span class=cF5>Fs</span><span class=cF0>-&gt;rip;
<a name="l343"></a>
<a name="l344"></a> </span><span class=cFB>text</span><span class=cF0>.raw_col = i++ * </span><span class=cFB>text</span><span class=cF0>.cols + RAWDR_COL;
<a name="l345"></a> </span><span class=cF6>'.'</span><span class=cF0>;
<a name="l346"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cF5>Bt</span><span class=cF7>(</span><span class=cF0>&amp;</span><span class=cFB>sys_run_level</span><span class=cF0>, </span><span class=cF3>RLf_COMPILER</span><span class=cF7>)</span><span class=cF0>)
<a name="l347"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l348"></a> j = </span><span class=cF5>Fs</span><span class=cF0>-&gt;rip;
<a name="l349"></a> </span><span class=cF5>Ui</span><span class=cF0>(buf, &amp;j,,, </span><span class=cF3>TRUE</span><span class=cF0>);
<a name="l350"></a> </span><span class=cF6>&quot;%s&quot;</span><span class=cF0>, buf;
<a name="l351"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l352"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l353"></a> </span><span class=cF6>'\n'</span><span class=cF0>;
<a name="l354"></a>
<a name="l355"></a> </span><span class=cFB>text</span><span class=cF0>.raw_col = i * </span><span class=cFB>text</span><span class=cF0>.cols + RAWDR_COL;
<a name="l356"></a> </span><span class=cF6>'.'</span><span class=cF0>;
<a name="l357"></a> </span><span class=cF1>for</span><span class=cF0> (j = </span><span class=cFE>0</span><span class=cF0>; j &lt; </span><span class=cFB>text</span><span class=cF0>.cols - RAWDR_COL - </span><span class=cFE>1</span><span class=cF0>; j++)
<a name="l358"></a> </span><span class=cF6>'.'</span><span class=cF0>;
<a name="l359"></a>
<a name="l360"></a> </span><span class=cFB>text</span><span class=cF0>.raw_col = </span><span class=cFB>text</span><span class=cF0>.cols - </span><span class=cFE>1</span><span class=cF0>;
<a name="l361"></a> </span><span class=cF6>'.'</span><span class=cF0>;
<a name="l362"></a> </span><span class=cF1>for</span><span class=cF0> (j = </span><span class=cFE>2</span><span class=cF0>; j &lt; i + </span><span class=cFE>1</span><span class=cF0>; j++)
<a name="l363"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l364"></a> </span><span class=cFB>text</span><span class=cF0>.raw_col = j * </span><span class=cFB>text</span><span class=cF0>.cols - </span><span class=cFE>1</span><span class=cF0>;
<a name="l365"></a> </span><span class=cF6>'.'</span><span class=cF0>;
<a name="l366"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l367"></a> </span><span class=cFB>text</span><span class=cF0>.raw_col = j * </span><span class=cFB>text</span><span class=cF0>.cols - </span><span class=cFE>1</span><span class=cF0>;
<a name="l368"></a> </span><span class=cF6>'.'</span><span class=cF0>;
<a name="l369"></a>
<a name="l370"></a> </span><span class=cFB>text</span><span class=cF0>.raw_col = old_col;
<a name="l371"></a> </span><span class=cF5>Raw</span><span class=cF0>(old_raw);
<a name="l372"></a>}
<a name="l373"></a>
<a name="l374"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>Dr</span><span class=cF0>(</span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>)
<a name="l375"></a>{</span><span class=cF2>//Dump registers</span><span class=cF0>
<a name="l376"></a> </span><span class=cF9>I64</span><span class=cF0> i;
<a name="l377"></a>
<a name="l378"></a> </span><span class=cF1>if</span><span class=cF0> (!task)
<a name="l379"></a> task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l380"></a> </span><span class=cF1>for</span><span class=cF0> (i = </span><span class=cFE>0</span><span class=cF0>; i &lt; </span><span class=cFE>16</span><span class=cF0>; i++)
<a name="l381"></a> </span><span class=cF6>&quot;%3Z: %016X\n&quot;</span><span class=cF0>, i, </span><span class=cF6>&quot;ST_U64_REGS&quot;</span><span class=cF0>, *</span><span class=cF5>TaskRegAddr</span><span class=cF0>(task, i);
<a name="l382"></a> </span><span class=cF6>&quot;RIP: %016X\n&quot;</span><span class=cF0>, task-&gt;rip;
<a name="l383"></a>}
<a name="l384"></a>
<a name="l385"></a></span><span class=cF1>U8</span><span class=cF0> *</span><span class=cFD>SysGetStr2</span><span class=cF0>(</span><span class=cF9>I64</span><span class=cF0>)
<a name="l386"></a>{
<a name="l387"></a> </span><span class=cF1>U8</span><span class=cF0> buf[</span><span class=cFE>512</span><span class=cF0>];
<a name="l388"></a>
<a name="l389"></a> </span><span class=cF5>StrNGet</span><span class=cF0>(buf, </span><span class=cFE>512</span><span class=cF0>, </span><span class=cF3>FALSE</span><span class=cF0>);
<a name="l390"></a> </span><span class=cF1>return</span><span class=cF0> </span><span class=cF5>StrNew</span><span class=cF0>(buf);
<a name="l391"></a>}
<a name="l392"></a>
<a name="l393"></a></span><span class=cF9>CBpt</span><span class=cF0> *</span><span class=cF5>BptFind</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *needle_addr, </span><span class=cF9>CTask</span><span class=cF0> *haystack_task=</span><span class=cF3>NULL</span><span class=cF0>, </span><span class=cF1>Bool</span><span class=cF0> rem=</span><span class=cF3>FALSE</span><span class=cF0>)
<a name="l394"></a>{
<a name="l395"></a> </span><span class=cF9>CBpt</span><span class=cF0> *res=</span><span class=cF3>NULL</span><span class=cF0>, *tmpb, *tmpb1, *tmpb2;
<a name="l396"></a>
<a name="l397"></a> </span><span class=cF1>if</span><span class=cF0> (!haystack_task)
<a name="l398"></a> haystack_task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l399"></a>
<a name="l400"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l401"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l402"></a> tmpb1 = &amp;haystack_task-&gt;bpt_list;
<a name="l403"></a> tmpb = haystack_task-&gt;bpt_list;
<a name="l404"></a> </span><span class=cF1>while</span><span class=cF0> (tmpb)
<a name="l405"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l406"></a> tmpb2 = tmpb-&gt;next;
<a name="l407"></a> </span><span class=cF1>if</span><span class=cF0> (tmpb-&gt;addr == needle_addr)
<a name="l408"></a> {
<a name="l409"></a> res = tmpb;
<a name="l410"></a> </span><span class=cF1>if</span><span class=cF0> (rem)
<a name="l411"></a> tmpb1-&gt;next = tmpb2;
<a name="l412"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l413"></a> tmpb1 = &amp;tmpb-&gt;next;
<a name="l414"></a> }
<a name="l415"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l416"></a> tmpb1 = &amp;tmpb-&gt;next;
<a name="l417"></a> tmpb = tmpb2;
<a name="l418"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l419"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l420"></a>
<a name="l421"></a> </span><span class=cF1>return</span><span class=cF0> res;
<a name="l422"></a>}
<a name="l423"></a>
<a name="l424"></a></span><span class=cF1>Bool</span><span class=cF0> </span><span class=cF5>BptS</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *addr, </span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>, </span><span class=cF1>Bool</span><span class=cF0> live=</span><span class=cF3>TRUE</span><span class=cF0>)
<a name="l425"></a>{</span><span class=cF2>//Set breakpoint.</span><span class=cF0>
<a name="l426"></a> </span><span class=cF9>CBpt</span><span class=cF0> *tmpb;
<a name="l427"></a> </span><span class=cF1>Bool</span><span class=cF0> res = </span><span class=cF3>TRUE</span><span class=cF0>;
<a name="l428"></a> </span><span class=cF1>if</span><span class=cF0> (!task)
<a name="l429"></a> task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l430"></a>
<a name="l431"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l432"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l433"></a> </span><span class=cF1>if</span><span class=cF0> (!</span><span class=cF7>(</span><span class=cF0>tmpb = </span><span class=cF5>BptFind</span><span class=cF0>(addr, task, </span><span class=cF3>FALSE</span><span class=cF0>)</span><span class=cF7>)</span><span class=cF0>)
<a name="l434"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l435"></a> tmpb = </span><span class=cF5>CAlloc</span><span class=cF0>(</span><span class=cF1>sizeof</span><span class=cF7>(</span><span class=cF9>CBpt</span><span class=cF7>)</span><span class=cF0>, task);
<a name="l436"></a> tmpb-&gt;addr = addr;
<a name="l437"></a> tmpb-&gt;val = *addr;
<a name="l438"></a> res = </span><span class=cF3>FALSE</span><span class=cF0>;
<a name="l439"></a> tmpb-&gt;next = task-&gt;bpt_list;
<a name="l440"></a>
<a name="l441"></a> task-&gt;bpt_list = tmpb;
<a name="l442"></a> </span><span class=cF1>if</span><span class=cF0> (task == </span><span class=cF5>Fs</span><span class=cF0> &amp;&amp; live)
<a name="l443"></a> *addr = </span><span class=cF3>OC_BPT</span><span class=cF0>;
<a name="l444"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l445"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l446"></a>
<a name="l447"></a> </span><span class=cF1>return</span><span class=cF0> res;
<a name="l448"></a>}
<a name="l449"></a>
<a name="l450"></a></span><span class=cF1>Bool</span><span class=cF0> </span><span class=cF5>BptR</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *addr, </span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>, </span><span class=cF1>Bool</span><span class=cF0> live=</span><span class=cF3>TRUE</span><span class=cF0>, </span><span class=cF1>Bool</span><span class=cF0> rem=</span><span class=cF3>TRUE</span><span class=cF0>)
<a name="l451"></a>{</span><span class=cF2>//Remove breakpoint.</span><span class=cF0>
<a name="l452"></a> </span><span class=cF9>CBpt</span><span class=cF0> *tmpb;
<a name="l453"></a> </span><span class=cF1>Bool</span><span class=cF0> res = </span><span class=cF3>FALSE</span><span class=cF0>;
<a name="l454"></a>
<a name="l455"></a> </span><span class=cF1>if</span><span class=cF0> (!task)
<a name="l456"></a> task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l457"></a>
<a name="l458"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l459"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l460"></a> </span><span class=cF1>if</span><span class=cF0> (tmpb = </span><span class=cF5>BptFind</span><span class=cF7>(</span><span class=cF0>addr, task, rem</span><span class=cF7>)</span><span class=cF0>)
<a name="l461"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l462"></a> </span><span class=cF1>if</span><span class=cF0> (task == </span><span class=cF5>Fs</span><span class=cF0> &amp;&amp; live)
<a name="l463"></a> *tmpb-&gt;addr = tmpb-&gt;val;
<a name="l464"></a> res = </span><span class=cF3>TRUE</span><span class=cF0>;
<a name="l465"></a> </span><span class=cF1>if</span><span class=cF0> (rem)
<a name="l466"></a> </span><span class=cF5>Free</span><span class=cF0>(tmpb);
<a name="l467"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l468"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l469"></a>
<a name="l470"></a> </span><span class=cF1>return</span><span class=cF0> res;
<a name="l471"></a>}
<a name="l472"></a>
<a name="l473"></a></span><span class=cF1>Bool</span><span class=cF0> </span><span class=cF5>B</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *addr, </span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>, </span><span class=cF1>Bool</span><span class=cF0> live=</span><span class=cF3>TRUE</span><span class=cF0>)
<a name="l474"></a>{</span><span class=cF2>//Toggle breakpoint.</span><span class=cF0>
<a name="l475"></a></span><span class=cF2>//Return: TRUE if removed.</span><span class=cF0>
<a name="l476"></a> </span><span class=cF1>Bool</span><span class=cF0> res = </span><span class=cF3>FALSE</span><span class=cF0>;
<a name="l477"></a>
<a name="l478"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l479"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l480"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cF5>BptFind</span><span class=cF7>(</span><span class=cF0>addr, task, </span><span class=cF3>FALSE</span><span class=cF7>)</span><span class=cF0>)
<a name="l481"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l482"></a> </span><span class=cF5>BptR</span><span class=cF0>(addr, task, live, </span><span class=cF3>TRUE</span><span class=cF0>);
<a name="l483"></a> res = </span><span class=cF3>TRUE</span><span class=cF0>;
<a name="l484"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l485"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l486"></a> </span><span class=cF5>BptS</span><span class=cF0>(addr, task, live);
<a name="l487"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l488"></a>
<a name="l489"></a> </span><span class=cF1>return</span><span class=cF0> res;
<a name="l490"></a>}
<a name="l491"></a>
<a name="l492"></a></span><span class=cF9>I64</span><span class=cF0> </span><span class=cF5>B2</span><span class=cF0>(</span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>, </span><span class=cF1>Bool</span><span class=cF0> live=</span><span class=cF3>TRUE</span><span class=cF0>)
<a name="l493"></a>{</span><span class=cF2>//Remove all breakpoints.</span><span class=cF0>
<a name="l494"></a></span><span class=cF2>//Return: count of removed.</span><span class=cF0>
<a name="l495"></a> </span><span class=cF9>I64</span><span class=cF0> res = </span><span class=cFE>0</span><span class=cF0>;
<a name="l496"></a> </span><span class=cF9>CBpt</span><span class=cF0> *tmpb, *tmpb1;
<a name="l497"></a>
<a name="l498"></a> </span><span class=cF1>if</span><span class=cF0> (!task)
<a name="l499"></a> task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l500"></a>
<a name="l501"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l502"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l503"></a> tmpb = task-&gt;bpt_list;
<a name="l504"></a> task-&gt;bpt_list = </span><span class=cF3>NULL</span><span class=cF0>;
<a name="l505"></a> </span><span class=cF1>while</span><span class=cF0> (tmpb)
<a name="l506"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l507"></a> tmpb1 = tmpb-&gt;next;
<a name="l508"></a> </span><span class=cF1>if</span><span class=cF0> (task == </span><span class=cF5>Fs</span><span class=cF0> &amp;&amp; live)
<a name="l509"></a> *tmpb-&gt;addr = tmpb-&gt;val;
<a name="l510"></a> </span><span class=cF5>Free</span><span class=cF0>(tmpb);
<a name="l511"></a> tmpb = tmpb1;
<a name="l512"></a> res++;
<a name="l513"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l514"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l515"></a>
<a name="l516"></a> </span><span class=cF1>return</span><span class=cF0> res;
<a name="l517"></a>}
<a name="l518"></a>
<a name="l519"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>G</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *ip=</span><span class=cF3>INVALID_PTR</span><span class=cF0>, </span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>)
<a name="l520"></a>{</span><span class=cF2>//Go</span><span class=cF0>
<a name="l521"></a> </span><span class=cF1>if</span><span class=cF0> (!task)
<a name="l522"></a> task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l523"></a> </span><span class=cF1>if</span><span class=cF0> (ip != </span><span class=cF3>INVALID_PTR</span><span class=cF0>)
<a name="l524"></a> task-&gt;rip = ip;
<a name="l525"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cF5>BptFind</span><span class=cF7>(</span><span class=cF0>task-&gt;rip, task</span><span class=cF7>)</span><span class=cF0>)
<a name="l526"></a> </span><span class=cF6>&quot;\nBreakpoints found.\n&quot;</span><span class=cF0>
<a name="l527"></a> </span><span class=cF6>&quot;Do one of the following, first:\n&quot;</span><span class=cF0>
<a name="l528"></a> </span><span class=cF6>&quot;&gt;S;\t\t\t//Single step\n&quot;</span><span class=cF0>
<a name="l529"></a> </span><span class=cF6>&quot;&gt;B2;\t\t//Clear all break points\n&quot;</span><span class=cF0>
<a name="l530"></a> </span><span class=cF6>&quot;&gt;G2;\t\t//Clear all break points and Go\n\n&quot;</span><span class=cF0>
<a name="l531"></a> </span><span class=cF6>&quot;After resuming, &lt;CTRL-ALT-n&gt; next focus task\n&quot;</span><span class=cF0>
<a name="l532"></a> </span><span class=cF6>&quot;After resuming, &lt;CTRL-ALT-v&gt; flushes screen VGA cache\n&quot;</span><span class=cF0>;
<a name="l533"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l534"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l535"></a> </span><span class=cF5>LBtr</span><span class=cF0>(&amp;task-&gt;task_flags, </span><span class=cF3>TASKf_DISABLE_BPTS</span><span class=cF0>);
<a name="l536"></a> </span><span class=cF5>LBtr</span><span class=cF0>(&amp;task-&gt;rflags, </span><span class=cF3>RFLAGf_TRAP</span><span class=cF0>);</span><span class=cF2>//No single step</span><span class=cF0>
<a name="l537"></a> </span><span class=cF5>Suspend</span><span class=cF0>(task, </span><span class=cF3>FALSE</span><span class=cF0>);
<a name="l538"></a> </span><span class=cF1>if</span><span class=cF0> (task == </span><span class=cF5>Fs</span><span class=cF0>)
<a name="l539"></a> {
<a name="l540"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cF5>IsDebugMode</span><span class=cF0> &amp;&amp; task-&gt;next_cc != &amp;task-&gt;next_cc)
<a name="l541"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l542"></a> </span><span class=cF6>&quot;Exit Debug\n&quot;</span><span class=cF0>;
<a name="l543"></a> </span><span class=cF5>Btr</span><span class=cF0>(&amp;task-&gt;last_cc-&gt;flags, </span><span class=cF3>CCf_PROMPT</span><span class=cF0>);
<a name="l544"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l545"></a> }
<a name="l546"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l547"></a> </span><span class=cF5>Exit</span><span class=cF0>;
<a name="l548"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l549"></a>}
<a name="l550"></a>
<a name="l551"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>G2</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *ip=</span><span class=cF3>INVALID_PTR</span><span class=cF0>, </span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>)
<a name="l552"></a>{</span><span class=cF2>//Remove all breakpoints and Go.</span><span class=cF0>
<a name="l553"></a> </span><span class=cF1>if</span><span class=cF0> (!task)
<a name="l554"></a> task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l555"></a> </span><span class=cF5>B2</span><span class=cF0>(task);
<a name="l556"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cFB>ext</span><span class=cF0>[</span><span class=cF3>EXT_WIN_FOCUS</span><span class=cF0>])
<a name="l557"></a> </span><span class=cF5>CallExtNum</span><span class=cF0>(</span><span class=cF3>EXT_WIN_FOCUS</span><span class=cF0>, </span><span class=cFB>debug</span><span class=cF0>.focus_task);
<a name="l558"></a> </span><span class=cF5>LFBFlush</span><span class=cF0>;
<a name="l559"></a> </span><span class=cF5>G</span><span class=cF0>(ip, task);
<a name="l560"></a>}
<a name="l561"></a>
<a name="l562"></a></span><span class=cF1>public</span><span class=cF0> </span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>S</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *ip=</span><span class=cF3>INVALID_PTR</span><span class=cF0>, </span><span class=cF9>CTask</span><span class=cF0> *task=</span><span class=cF3>NULL</span><span class=cF0>) </span><span class=cF2>//Single-step.</span><span class=cF0>
<a name="l563"></a>{</span><span class=cF2>//Single step.</span><span class=cF0>
<a name="l564"></a> </span><span class=cF1>if</span><span class=cF0> (!task)
<a name="l565"></a> task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l566"></a>
<a name="l567"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l568"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l569"></a> </span><span class=cF1>if</span><span class=cF0> (ip != </span><span class=cF3>INVALID_PTR</span><span class=cF0>)
<a name="l570"></a> task-&gt;rip = ip;
<a name="l571"></a> </span><span class=cF5>LBts</span><span class=cF0>(&amp;task-&gt;task_flags, </span><span class=cF3>TASKf_DISABLE_BPTS</span><span class=cF0>);
<a name="l572"></a> </span><span class=cF5>LBts</span><span class=cF0>(&amp;task-&gt;rflags, </span><span class=cF3>RFLAGf_TRAP</span><span class=cF0>);
<a name="l573"></a> </span><span class=cF5>Suspend</span><span class=cF0>(task, </span><span class=cF3>FALSE</span><span class=cF0>);
<a name="l574"></a> </span><span class=cF1>if</span><span class=cF0> (task == </span><span class=cF5>Fs</span><span class=cF0>)
<a name="l575"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l576"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cF5>IsDebugMode</span><span class=cF0>)
<a name="l577"></a> {
<a name="l578"></a> </span><span class=cF1>if</span><span class=cF0> (task-&gt;next_cc != &amp;task-&gt;next_cc)
<a name="l579"></a> </span><span class=cF5>Btr</span><span class=cF0>(&amp;task-&gt;last_cc-&gt;flags, </span><span class=cF3>CCf_PROMPT</span><span class=cF0>);
<a name="l580"></a> }
<a name="l581"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l582"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l583"></a> </span><span class=cF5>Exit</span><span class=cF0>;
<a name="l584"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l585"></a>}
<a name="l586"></a>
<a name="l587"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cFD>DebugHelp</span><span class=cF0>()
<a name="l588"></a>{
<a name="l589"></a> </span><span class=cF6>&quot;\n&quot;</span><span class=cF0>
<a name="l590"></a> </span><span class=cF6>&quot;The cmd line is basically the same as normal.</span><span class=cF0> </span><span class=cF6>Here are some common\n&quot;</span><span class=cF0>
<a name="l591"></a> </span><span class=cF6>&quot;debugging commands.\n\n&quot;</span><span class=cF0>
<a name="l592"></a> </span><span class=cF6>&quot;&gt;EdLite(\&quot;FileName\&quot;);\t\t\t\t// Edit file.\n&quot;</span><span class=cF0>
<a name="l593"></a> </span><span class=cF6>&quot;&gt;D(0x100000);\t\t\t\t\t\t// Dump page tables.\n&quot;</span><span class=cF0>
<a name="l594"></a> </span><span class=cF6>&quot;&gt;Dm(0x100000);\t\t\t\t\t\t// Dump page tables.\n&quot;</span><span class=cF0>
<a name="l595"></a> </span><span class=cF6>&quot;&gt;Dm(Fs, sizeof(CTask));\t\t\t\t// Dump current task record.\n&quot;</span><span class=cF0>
<a name="l596"></a> </span><span class=cF6>&quot;&gt;ClassRep(Fs, \&quot;CTask\&quot;, 1);\t\t\t// Dump current task record.\n&quot;</span><span class=cF0>
<a name="l597"></a> </span><span class=cF6>&quot;&gt;ClassRep(Fs,, 1);\t\t\t\t\t// (It knows lastclass.)\n&quot;</span><span class=cF0>
<a name="l598"></a> </span><span class=cF6>&quot;&gt;CallerRep;\t\t\t\t\t\t\t// Stack trace report.\n&quot;</span><span class=cF0>
<a name="l599"></a> </span><span class=cF6>&quot;&gt;Da(_RSP);\t\t\t\t\t\t\t// Dump stack.\n&quot;</span><span class=cF0>
<a name="l600"></a> </span><span class=cF6>&quot;&gt;Dr;\t\t\t\t\t\t\t\t// Dump Registers.\n&quot;</span><span class=cF0>
<a name="l601"></a> </span><span class=cF6>&quot;&gt;1 + 2 * 3 + &amp;Print;\t\t\t\t// Show calculation res.\n&quot;</span><span class=cF0>
<a name="l602"></a> </span><span class=cF6>&quot;&gt;*(0x70000)(I64 *) = 0x123456789;\t// Assign value to 0x70000-0x70007.\n&quot;</span><span class=cF0>
<a name="l603"></a> </span><span class=cF6>&quot;&gt;_RAX = 0x1234;\t\t\t\t\t\t// Set RAX to 0x1234.\n&quot;</span><span class=cF0>
<a name="l604"></a> </span><span class=cF6>&quot;&gt;_RIP = &amp;Break;\t\t\t\t\t\t// Set RIP.\n&quot;</span><span class=cF0>
<a name="l605"></a> </span><span class=cF6>&quot;&gt;I64 i;\t\t\t\t\t\t\t\t// Declare variable.\n&quot;</span><span class=cF0>
<a name="l606"></a> </span><span class=cF6>&quot;&gt;i = _RCX + _RDX;\t\t\t\t\t// Assign to variable.\n&quot;</span><span class=cF0>
<a name="l607"></a> </span><span class=cF6>&quot;&gt;U(&amp;Print+0x8);\t\t\t\t\t\t// Unassemble Print.\n&quot;</span><span class=cF0>
<a name="l608"></a> </span><span class=cF6>&quot;&gt;Uf(\&quot;Print\&quot;);\t\t\t\t\t\t// Unassembler function \&quot;Print\&quot;.\n&quot;</span><span class=cF0>
<a name="l609"></a> </span><span class=cF6>&quot;&gt;Man(\&quot;Print\&quot;);\t\t\t\t\t\t// Edit Src for \&quot;Print\&quot;.\n&quot;</span><span class=cF0>
<a name="l610"></a> </span><span class=cF6>&quot;&gt;E(_RIP);\t\t\t\t\t\t\t// Edit Src Code.\n&quot;</span><span class=cF0>
<a name="l611"></a> </span><span class=cF6>&quot;&gt;Fix;\t\t\t\t\t\t\t\t// Edit Last Err Src Code.\n&quot;</span><span class=cF0>
<a name="l612"></a> </span><span class=cF6>&quot;&gt;B(&amp;Main+0x20);\t\t\t\t\t\t// Toggle break point.\n\n&quot;</span><span class=cF0>
<a name="l613"></a> </span><span class=cF6>&quot;&gt;B2;\t\t\t\t\t\t\t\t// Clear all break points.\n&quot;</span><span class=cF0>
<a name="l614"></a> </span><span class=cF6>&quot;&gt;S;\t\t\t\t\t\t\t\t\t// Single step.\n&quot;</span><span class=cF0>
<a name="l615"></a> </span><span class=cF6>&quot;&gt;G;\t\t\t\t\t\t\t\t\t// Resume execution.\n&quot;</span><span class=cF0>
<a name="l616"></a> </span><span class=cF6>&quot;&gt;G2;\t\t\t\t\t\t\t\t// B2;LFBFlush;WinFocus;G;\n&quot;</span><span class=cF0>
<a name="l617"></a> </span><span class=cF6>&quot;&gt;Exit;\t\t\t\t\t\t\t\t// Exit (kill) task.\n\n&quot;</span><span class=cF0>
<a name="l618"></a> </span><span class=cF6>&quot;After resuming, &lt;CTRL-ALT-n&gt; next focus task.\n&quot;</span><span class=cF0>
<a name="l619"></a> </span><span class=cF6>&quot;After resuming, &lt;CTRL-ALT-v&gt; flushes screen VGA cache.\n\n&quot;</span><span class=cF0>;
<a name="l620"></a>}
<a name="l621"></a>
<a name="l622"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cFD>Debug2</span><span class=cF0>()
<a name="l623"></a>{
<a name="l624"></a> </span><span class=cF1>Bool</span><span class=cF0> old_win_inhibit, old_waiting_message, old_single;
<a name="l625"></a> </span><span class=cF9>I64</span><span class=cF0> i, old_getstr2;
<a name="l626"></a> </span><span class=cF1>U8</span><span class=cF0> buf[</span><span class=cFE>200</span><span class=cF0>];
<a name="l627"></a>
<a name="l628"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cFB>debug</span><span class=cF0>.panic)
<a name="l629"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l630"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cF5>IsRaw</span><span class=cF0>)
<a name="l631"></a> {
<a name="l632"></a> i = </span><span class=cF5>Fs</span><span class=cF0>-&gt;rip;
<a name="l633"></a> </span><span class=cF5>Ui</span><span class=cF0>(buf, &amp;i);
<a name="l634"></a> </span><span class=cF6>&quot;%s&quot;</span><span class=cF0>, buf;
<a name="l635"></a> }
<a name="l636"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l637"></a> </span><span class=cF5>U</span><span class=cF0>(</span><span class=cF5>Fs</span><span class=cF0>-&gt;rip, </span><span class=cFE>1</span><span class=cF0>);
<a name="l638"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l639"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l640"></a> </span><span class=cFB>debug</span><span class=cF0>.panic = </span><span class=cF3>TRUE</span><span class=cF0>;
<a name="l641"></a> old_waiting_message = </span><span class=cF5>LBtr</span><span class=cF0>(&amp;</span><span class=cF5>Fs</span><span class=cF0>-&gt;task_flags, </span><span class=cF3>TASKf_AWAITING_MESSAGE</span><span class=cF0>);
<a name="l642"></a> old_win_inhibit = </span><span class=cF5>Fs</span><span class=cF0>-&gt;win_inhibit;
<a name="l643"></a> </span><span class=cF5>Fs</span><span class=cF0>-&gt;win_inhibit = </span><span class=cF3>WIG_USER_TASK_DEFAULT</span><span class=cF0>;
<a name="l644"></a> </span><span class=cFB>sys_focus_task</span><span class=cF0> = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l645"></a> </span><span class=cFB>kbd</span><span class=cF0>.scan_code = </span><span class=cFE>0</span><span class=cF0>;
<a name="l646"></a> old_getstr2 = </span><span class=cFB>fp_getstr2</span><span class=cF0>;
<a name="l647"></a> </span><span class=cFB>fp_getstr2</span><span class=cF0> = &amp;</span><span class=cFD>SysGetStr2</span><span class=cF0>;
<a name="l648"></a> old_single = </span><span class=cF5>SingleUser</span><span class=cF0>(</span><span class=cF3>OFF</span><span class=cF0>);
<a name="l649"></a> </span><span class=cF1>while</span><span class=cF0> (!</span><span class=cFB>mouse_hard</span><span class=cF0>.install_attempts)
<a name="l650"></a> </span><span class=cF5>Yield</span><span class=cF0>;
<a name="l651"></a> </span><span class=cF5>SingleUser</span><span class=cF0>(old_single);
<a name="l652"></a> </span><span class=cF5>UserTaskCont</span><span class=cF0>;
<a name="l653"></a> </span><span class=cFB>fp_getstr2</span><span class=cF0> = old_getstr2;
<a name="l654"></a> </span><span class=cF5>Fs</span><span class=cF0>-&gt;win_inhibit = old_win_inhibit;
<a name="l655"></a> </span><span class=cF5>LBEqual</span><span class=cF0>(&amp;</span><span class=cF5>Fs</span><span class=cF0>-&gt;task_flags, </span><span class=cF3>TASKf_AWAITING_MESSAGE</span><span class=cF0>, old_waiting_message);
<a name="l656"></a>}
<a name="l657"></a>
<a name="l658"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cFD>Fault3</span><span class=cF0>(</span><span class=cF9>I64</span><span class=cF0> fault_num, </span><span class=cF9>I64</span><span class=cF0> fault_err_code)
<a name="l659"></a>{
<a name="l660"></a> </span><span class=cF1>no_warn</span><span class=cF0> fault_err_code;
<a name="l661"></a>
<a name="l662"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l663"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l664"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cF5>Gs</span><span class=cF0>-&gt;num &amp;&amp; </span><span class=cFB>debug</span><span class=cF0>.mp_crash)
<a name="l665"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l666"></a> </span><span class=cFB>mp_count</span><span class=cF0> = </span><span class=cFE>1</span><span class=cF0>;
<a name="l667"></a> </span><span class=cFB>debug</span><span class=cF0>.mp_crash-&gt;cpu_num = </span><span class=cF5>Gs</span><span class=cF0>-&gt;num;
<a name="l668"></a> </span><span class=cFB>debug</span><span class=cF0>.mp_crash-&gt;task = </span><span class=cF5>Fs</span><span class=cF0>;
<a name="l669"></a> </span><span class=cFB>debug</span><span class=cF0>.mp_crash-&gt;rip = </span><span class=cF5>Fs</span><span class=cF0>-&gt;rip;
<a name="l670"></a> </span><span class=cFB>debug</span><span class=cF0>.mp_crash-&gt;message = </span><span class=cFB>debug</span><span class=cF0>.message;
<a name="l671"></a> </span><span class=cFB>debug</span><span class=cF0>.mp_crash-&gt;message_num = </span><span class=cFB>debug</span><span class=cF0>.message_num;
<a name="l672"></a> </span><span class=cF5>MPInt</span><span class=cF0>(</span><span class=cF3>I_MP_CRASH</span><span class=cF0>, </span><span class=cFE>0</span><span class=cF0>);
<a name="l673"></a> </span><span class=cF5>SysHlt</span><span class=cF0>;
<a name="l674"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l675"></a>
<a name="l676"></a> </span><span class=cF6>&quot;\n\tZealOS Debugger\n\n&quot;</span><span class=cF0>
<a name="l677"></a> </span><span class=cF6>&quot; Type Help; for help.\n\n&quot;</span><span class=cF0>;
<a name="l678"></a>
<a name="l679"></a> </span><span class=cF5>Beep</span><span class=cF0>(</span><span class=cFE>62</span><span class=cF0>, </span><span class=cF3>TRUE</span><span class=cF0>);
<a name="l680"></a> </span><span class=cF1>if</span><span class=cF0> (fault_num == </span><span class=cF3>I_DEBUG</span><span class=cF0>)
<a name="l681"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l682"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cFB>debug</span><span class=cF0>.message)
<a name="l683"></a> {
<a name="l684"></a> </span><span class=cF6>&quot;\n!!! %s&quot;</span><span class=cF0>, </span><span class=cFB>debug</span><span class=cF0>.message;
<a name="l685"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cFB>debug</span><span class=cF0>.message_num)
<a name="l686"></a> </span><span class=cF6>&quot;%016X&quot;</span><span class=cF0>, </span><span class=cFB>debug</span><span class=cF0>.message_num;
<a name="l687"></a> </span><span class=cF6>&quot; !!!\n\n&quot;</span><span class=cF0>;
<a name="l688"></a> }
<a name="l689"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l690"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cFB>debug</span><span class=cF0>.panic)
<a name="l691"></a> </span><span class=cF5>CallerRep</span><span class=cF0>;
<a name="l692"></a> </span><span class=cFD>Debug2</span><span class=cF0>;
<a name="l693"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l694"></a>}
<a name="l695"></a>
<a name="l696"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cFD>Fault2</span><span class=cF0>(</span><span class=cF9>I64</span><span class=cF0> fault_num, </span><span class=cF9>I64</span><span class=cF0> fault_err_code)
<a name="l697"></a>{</span><span class=cF2>//Called from </span><a href="https://zeal-operating-system.github.io/ZealOS/Kernel/KInterrupts.CC.html#l91"><span class=cF4>Fault2</span></a><span class=cF2>.</span><span class=cF0>
<a name="l698"></a></span><span class=cF2>//Be careful not to swap-out and ruin the saved context</span><span class=cF0>
<a name="l699"></a> </span><span class=cF1>Bool</span><span class=cF0> was_raw, was_single_user, was_silent, was_in_debug, was_mouse_enabled;
<a name="l700"></a> </span><span class=cF9>I64</span><span class=cF0> i, old_raw_flags = </span><span class=cFB>text</span><span class=cF0>.raw_flags;
<a name="l701"></a>
<a name="l702"></a> was_single_user = </span><span class=cF5>SingleUser</span><span class=cF0>(</span><span class=cF3>ON</span><span class=cF0>);
<a name="l703"></a> </span><span class=cF1>if</span><span class=cF0> (!</span><span class=cF5>IsDebugMode</span><span class=cF0>)
<a name="l704"></a> </span><span class=cFB>debug</span><span class=cF0>.focus_task = </span><span class=cFB>sys_focus_task</span><span class=cF0>;
<a name="l705"></a> </span><span class=cFB>sys_focus_task</span><span class=cF0> = </span><span class=cF3>NULL</span><span class=cF0>;
<a name="l706"></a> </span><span class=cF1>if</span><span class=cF0> (fault_num == </span><span class=cF3>I_BPT</span><span class=cF0>)
<a name="l707"></a> </span><span class=cF5>Fs</span><span class=cF0>-&gt;rip--;
<a name="l708"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cF5>Fs</span><span class=cF0>-&gt;debug_task)
<a name="l709"></a> </span><span class=cF5>CallExtNum</span><span class=cF0>(</span><span class=cF3>EXT_DEBUG_RESUME</span><span class=cF0>, fault_num, fault_err_code);
<a name="l710"></a> </span><span class=cF1>else</span><span class=cF0>
<a name="l711"></a> </span><span class=cF7>{</span><span class=cF0>
<a name="l712"></a> was_mouse_enabled = </span><span class=cF5>CallExtStr</span><span class=cF0>(</span><span class=cF6>&quot;MouseHardEnable&quot;</span><span class=cF0>, </span><span class=cF3>FALSE</span><span class=cF0>);
<a name="l713"></a> was_raw = </span><span class=cF5>Raw</span><span class=cF0>(</span><span class=cF3>ON</span><span class=cF0>);
<a name="l714"></a> was_silent = </span><span class=cF5>Silent</span><span class=cF0>(</span><span class=cF3>OFF</span><span class=cF0>);
<a name="l715"></a> </span><span class=cFB>text</span><span class=cF0>.raw_flags |= </span><span class=cF3>RAWF_SHOW_DOLLAR</span><span class=cF0>|</span><span class=cF3>RAWF_SCROLL</span><span class=cF0>;
<a name="l716"></a>
<a name="l717"></a> </span><span class=cF6>&quot;Task \&quot;&quot;</span><span class=cF0>;
<a name="l718"></a> </span><span class=cF6>&quot;%s&quot;</span><span class=cF0>, </span><span class=cF5>Fs</span><span class=cF0>-&gt;task_title;
<a name="l719"></a> </span><span class=cF6>&quot;\&quot;\n&quot;</span><span class=cF0>;
<a name="l720"></a> </span><span class=cF6>&quot;Fault: 0x%02X %Z\n&quot;</span><span class=cF0>, fault_num, fault_num, </span><span class=cF6>&quot;ST_INT_NAMES&quot;</span><span class=cF0>;
<a name="l721"></a> </span><span class=cF6>&quot;Err Code: %08X\n&quot;</span><span class=cF0>, fault_err_code;
<a name="l722"></a> was_in_debug = </span><span class=cF5>DebugMode</span><span class=cF0>(</span><span class=cF3>ON</span><span class=cF0>);
<a name="l723"></a> </span><span class=cF6>&quot;RIP: %08X&quot;</span><span class=cF0>, </span><span class=cF5>Fs</span><span class=cF0>-&gt;rip; </span><span class=cF2>//Sometimes crashes on %p, so do this first</span><span class=cF0>
<a name="l724"></a> </span><span class=cF6>&quot;:%p\nRSP: %08X\n&quot;</span><span class=cF0>, </span><span class=cF5>Fs</span><span class=cF0>-&gt;rip, </span><span class=cF5>Fs</span><span class=cF0>-&gt;rsp;
<a name="l725"></a> </span><span class=cF1>if</span><span class=cF0> (fault_num == </span><span class=cF3>I_PAGE_FAULT</span><span class=cF0>)
<a name="l726"></a> {
<a name="l727"></a> </span><span class=cF1>MOV_RAX_CR2</span><span class=cF0>
<a name="l728"></a> i = </span><span class=cF5>RAXGet</span><span class=cF0>;
<a name="l729"></a> </span><span class=cF6>&quot;Fault Addr: %08X:%p\n&quot;</span><span class=cF0>, i, i;
<a name="l730"></a> }
<a name="l731"></a> </span><span class=cFD>Fault3</span><span class=cF0>(fault_num, fault_err_code);
<a name="l732"></a> </span><span class=cF5>DebugMode</span><span class=cF0>(was_in_debug);
<a name="l733"></a> </span><span class=cF5>Silent</span><span class=cF0>(was_silent);
<a name="l734"></a> </span><span class=cF5>Raw</span><span class=cF0>(was_raw);
<a name="l735"></a> </span><span class=cF5>CallExtStr</span><span class=cF0>(</span><span class=cF6>&quot;MouseHardEnable&quot;</span><span class=cF0>, was_mouse_enabled);
<a name="l736"></a> </span><span class=cFB>text</span><span class=cF0>.raw_flags = old_raw_flags;
<a name="l737"></a> </span><span class=cF7>}</span><span class=cF0>
<a name="l738"></a> </span><span class=cF5>SingleUser</span><span class=cF0>(was_single_user);
<a name="l739"></a> </span><span class=cF1>if</span><span class=cF0> (</span><span class=cF5>LBtr</span><span class=cF7>(</span><span class=cF0>&amp;</span><span class=cF5>Fs</span><span class=cF0>-&gt;task_flags, </span><span class=cF3>TASKf_KILL_AFTER_DEBUG</span><span class=cF7>)</span><span class=cF0>)
<a name="l740"></a> </span><span class=cF5>Exit</span><span class=cF0>;
<a name="l741"></a>}
<a name="l742"></a>
<a name="l743"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>Panic</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *message=</span><span class=cF3>NULL</span><span class=cF0>, </span><span class=cF9>I64</span><span class=cF0> message_num=</span><span class=cFE>0</span><span class=cF0>, </span><span class=cF1>Bool</span><span class=cF0> panic=</span><span class=cF3>TRUE</span><span class=cF0>)
<a name="l744"></a>{</span><span class=cF2>//Enter the debugger with panic?</span><span class=cF0>
<a name="l745"></a> </span><span class=cF1>PUSHFD</span><span class=cF0>
<a name="l746"></a> </span><span class=cF1>CLI</span><span class=cF0>
<a name="l747"></a> </span><span class=cFB>debug</span><span class=cF0>.message = message;
<a name="l748"></a> </span><span class=cFB>debug</span><span class=cF0>.message_num = message_num;
<a name="l749"></a> </span><span class=cFB>debug</span><span class=cF0>.panic = panic;
<a name="l750"></a> </span><span class=cF1>INT</span><span class=cF0> </span><span class=cF3>I_DEBUG</span><span class=cF0>
<a name="l751"></a> </span><span class=cF1>POPFD</span><span class=cF0>
<a name="l752"></a>}
<a name="l753"></a>
<a name="l754"></a></span><span class=cF1>U0</span><span class=cF0> </span><span class=cF5>Debug</span><span class=cF0>(</span><span class=cF1>U8</span><span class=cF0> *message=</span><span class=cF3>NULL</span><span class=cF0>, </span><span class=cF9>I64</span><span class=cF0> message_num=</span><span class=cFE>0</span><span class=cF0>)
<a name="l755"></a>{</span><span class=cF2>//Enter debugger, no panic.</span><span class=cF0>
<a name="l756"></a> </span><span class=cF5>Panic</span><span class=cF0>(message, message_num, </span><span class=cF3>FALSE</span><span class=cF0>);
<a name="l757"></a>}
</span></pre></body>
</html>