about summary refs log tree commit diff stats
path: root/html/subx/052kernel_string_equal.subx.html
blob: 5322761dfc1e83ab215f83b25340620421bc405b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
generated by cgit-pink 1.4.1-2-gfad0 (git 2.36.2.497.gbbea4dcf42) at 2024-12-23 10:38:50 +0000
 


0
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<title>Mu - subx/052kernel_string_equal.subx</title>
<meta name="Generator" content="Vim/8.0">
<meta name="plugin-version" content="vim7.4_v2">
<meta name="syntax" content="none">
<meta name="settings" content="number_lines,use_css,no_foldcolumn,expand_tabs,line_ids,prevent_copy=">
<meta name="colorscheme" content="minimal">
<style type="text/css">
<!--
pre { font-family: monospace; color: #aaaaaa; background-color: #080808; }
body { font-size: 12pt; font-family: monospace; color: #aaaaaa; background-color: #080808; }
a { color:#eeeeee; text-decoration: none; }
a:hover { text-decoration: underline; }
* { font-size: 12pt; font-size: 1em; }
.LineNr { color: #444444; }
.Delimiter { color: #800080; }
.Comment { color: #9090ff; }
.Comment a { color:#0000ee; text-decoration:underline; }
.SalientComment { color: #00ffff; }
-->
</style>

<script type='text/javascript'>
<!--

/* function to open any folds containing a jumped-to line before jumping to it */
function JumpToLine()
{
  var lineNum;
  lineNum = window.location.hash;
  lineNum = lineNum.substr(1); /* strip off '#' */

  if (lineNum.indexOf('L') == -1) {
    lineNum = 'L'+lineNum;
  }
  lineElem = document.getElementById(lineNum);
  /* Always jump to new location even if the line was hidden inside a fold, or
   * we corrected the raw number to a line ID.
   */
  if (lineElem) {
    lineElem.scrollIntoView(true);
  }
  return true;
}
if ('onhashchange' in window) {
  window.onhashchange = JumpToLine;
}

-->
</script>
</head>
<body onload='JumpToLine();'>
<pre id='vimCodeElement'>
<span id="L1" class="LineNr">  1 </span><span class="SalientComment">## Checking null-terminated ascii strings.</span>
<span id="L2" class="LineNr">  2 </span><span class="Comment">#</span>
<span id="L3" class="LineNr">  3 </span><span class="Comment"># By default we create strings with a 4-byte length prefix rather than a null suffix.</span>
<span id="L4" class="LineNr">  4 </span><span class="Comment"># However we still need null-prefixed strings when interacting with the Linux</span>
<span id="L5" class="LineNr">  5 </span><span class="Comment"># kernel in a few places. This layer implements a function for comparing</span>
<span id="L6" class="LineNr">  6 </span><span class="Comment"># a null-terminated 'kernel string' with a length-prefixed 'SubX string'.</span>
<span id="L7" class="LineNr">  7 </span><span class="Comment">#</span>
<span id="L8" class="LineNr">  8 </span><span class="Comment"># To run (from the subx directory):</span>
<span id="L9" class="LineNr">  9 </span><span class="Comment">#   $ subx translate 05[0-2]*.subx -o /tmp/tmp52</span>
<span id="L10" class="LineNr"> 10 </span><span class="Comment">#   $ subx run /tmp/tmp52  # runs a series of tests</span>
<span id="L11" class="LineNr"> 11 </span><span class="Comment">#   ......  # all tests pass</span>
<span id="L12" class="LineNr"> 12 </span><span class="Comment">#</span>
<span id="L13" class="LineNr"> 13 </span><span class="Comment"># (We can't yet run the tests when given a &quot;test&quot; commandline argument,</span>
<span id="L14" class="LineNr"> 14 </span><span class="Comment"># because checking for it would require the function being tested! Breakage</span>
<span id="L15" class="LineNr"> 15 </span><span class="Comment"># would cause tests to not run, rather than to fail as we'd like.)</span>
<span id="L16" class="LineNr"> 16 </span>
<span id="L17" class="LineNr"> 17 </span>== code
<span id="L18" class="LineNr"> 18 </span>
<span id="L19" class="LineNr"> 19 </span><span class="Comment"># instruction                     effective address                                                   operand     displacement    immediate</span>
<span id="L20" class="LineNr"> 20 </span><span class="Comment"># op          subop               mod             rm32          base        index         scale       r32</span>
<span id="L21" class="LineNr"> 21 </span><span class="Comment"># 1-3 bytes   3 bits              2 bits          3 bits        3 bits      3 bits        2 bits      2 bits      0/1/2/4 bytes   0/1/2/4 bytes</span>
<span id="L22" class="LineNr"> 22 </span>
<span id="L23" class="LineNr"> 23 </span><span class="Comment"># main:  (manual test if this is the last file loaded)</span>
<span id="L24" class="LineNr"> 24 </span>  e8/call  run-tests/disp32  <span class="Comment"># 'run-tests' is a function created automatically by SubX. It calls all functions that start with 'test-'.</span>
<span id="L25" class="LineNr"> 25 </span>  <span class="Comment"># exit(Num-test-failures)</span>
<span id="L26" class="LineNr"> 26 </span>  8b/copy                         0/mod/indirect  5/rm32/.disp32           <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>          3/r32/EBX   Num-test-failures/disp32          <span class="Comment"># copy *Num-test-failures to EBX</span>
<span id="L27" class="LineNr"> 27 </span>  b8/copy-to-EAX  1/imm32
<span id="L28" class="LineNr"> 28 </span>  cd/syscall  0x80/imm8
<span id="L29" class="LineNr"> 29 </span>
<span id="L30" class="LineNr"> 30 </span><span class="Comment"># compare a null-terminated ascii string with a more idiomatic length-prefixed byte array</span>
<span id="L31" class="LineNr"> 31 </span><span class="Comment"># reason for the name: the only place we should have null-terminated ascii strings is from commandline args</span>
<span id="L32" class="LineNr"> 32 </span>kernel-string-equal:  <span class="Comment"># s : null-terminated ascii string, benchmark : length-prefixed ascii string -&gt; EAX : boolean</span>
<span id="L33" class="LineNr"> 33 </span>  <span class="Comment"># prolog</span>
<span id="L34" class="LineNr"> 34 </span>  55/push-EBP
<span id="L35" class="LineNr"> 35 </span>  89/copy                         3/mod/direct    5/rm32/EBP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>          4/r32/ESP  <span class="Delimiter"> . </span>             <span class="Delimiter"> . </span>                <span class="Comment"># copy ESP to EBP</span>
<span id="L36" class="LineNr"> 36 </span>  <span class="Comment"># save registers</span>
<span id="L37" class="LineNr"> 37 </span>  51/push-ECX
<span id="L38" class="LineNr"> 38 </span>  52/push-EDX
<span id="L39" class="LineNr"> 39 </span>  53/push-EBX
<span id="L40" class="LineNr"> 40 </span>  56/push-ESI
<span id="L41" class="LineNr"> 41 </span>  57/push-EDI
<span id="L42" class="LineNr"> 42 </span>
<span id="L43" class="LineNr"> 43 </span>  <span class="Comment"># pseudocode:</span>
<span id="L44" class="LineNr"> 44 </span>  <span class="Comment">#   initialize n = b.length</span>
<span id="L45" class="LineNr"> 45 </span>  <span class="Comment">#   initialize s1 = s</span>
<span id="L46" class="LineNr"> 46 </span>  <span class="Comment">#   initialize s2 = b.data</span>
<span id="L47" class="LineNr"> 47 </span>  <span class="Comment">#   i = 0</span>
<span id="L48" class="LineNr"> 48 </span>  <span class="Comment">#   for (i = 0; i &lt; n; ++n)</span>
<span id="L49" class="LineNr"> 49 </span>  <span class="Comment">#     c1 = *s1</span>
<span id="L50" class="LineNr"> 50 </span>  <span class="Comment">#     c2 = *s2</span>
<span id="L51" class="LineNr"> 51 </span>  <span class="Comment">#     if c1 == 0</span>
<span id="L52" class="LineNr"> 52 </span>  <span class="Comment">#       return false</span>
<span id="L53" class="LineNr"> 53 </span>  <span class="Comment">#     if c1 != c2</span>
<span id="L54" class="LineNr"> 54 </span>  <span class="Comment">#       return false</span>
<span id="L55" class="LineNr"> 55 </span>  <span class="Comment">#   return *s1 == 0</span>
<span id="L56" class="LineNr"> 56 </span>  <span class="Comment">#</span>
<span id="L57" class="LineNr"> 57 </span>  <span class="Comment"># initialize s into EDI</span>
<span id="L58" class="LineNr"> 58 </span>  8b/copy                         1/mod/*+disp8   4/rm32/sib    5/base/EBP  4/index/none <span class="Delimiter"> . </span>          7/r32/EDI   8/disp8        <span class="Delimiter"> . </span>                <span class="Comment"># copy *(EBP+8) to EDI</span>
<span id="L59" class="LineNr"> 59 </span>  <span class="Comment"># initialize benchmark length n into EDX</span>
<span id="L60" class="LineNr"> 60 </span>  8b/copy                         1/mod/*+disp8   4/rm32/sib    5/base/EBP  4/index/none <span class="Delimiter"> . </span>          2/r32/EDX   0xc/disp8      <span class="Delimiter"> . </span>                <span class="Comment"># copy *(EBP+12) to EDX</span>
<span id="L61" class="LineNr"> 61 </span>  8b/copy                         0/mod/indirect  2/rm32/EDX   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>          2/r32/EDX  <span class="Delimiter"> . </span>             <span class="Delimiter"> . </span>                <span class="Comment"># copy *EDX to EDX</span>
<span id="L62" class="LineNr"> 62 </span>  <span class="Comment"># initialize benchmark data into ESI</span>
<span id="L63" class="LineNr"> 63 </span>  8b/copy                         1/mod/*+disp8   4/rm32/sib    5/base/EBP  4/index/none <span class="Delimiter"> . </span>          6/r32/ESI   0xc/disp8      <span class="Delimiter"> . </span>                <span class="Comment"># copy *(EBP+12) to ESI</span>
<span id="L64" class="LineNr"> 64 </span>  81          0/subop/add         3/mod/direct    6/rm32/ESI   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              4/imm32           <span class="Comment"># add to ESI</span>
<span id="L65" class="LineNr"> 65 </span>  <span class="Comment"># initialize loop counter i into ECX</span>
<span id="L66" class="LineNr"> 66 </span>  b9/copy-to-ECX  0/imm32/exit
<span id="L67" class="LineNr"> 67 </span>  <span class="Comment"># while (i/ECX &lt; n/EDX)</span>
<span id="L68" class="LineNr"> 68 </span>$kernel-string-equal:loop:
<span id="L69" class="LineNr"> 69 </span>  39/compare                      3/mod/direct    1/rm32/ECX   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>          2/r32/EDX  <span class="Delimiter"> . </span>             <span class="Delimiter"> . </span>                <span class="Comment"># compare ECX with EDX</span>
<span id="L70" class="LineNr"> 70 </span>  74/jump-if-equal  $kernel-string-equal:break/disp8
<span id="L71" class="LineNr"> 71 </span>    <span class="Comment"># c1/EAX, c2/EBX = *s, *benchmark</span>
<span id="L72" class="LineNr"> 72 </span>  b8/copy-to-EAX  0/imm32
<span id="L73" class="LineNr"> 73 </span>  8a/copy                         0/mod/indirect  7/rm32/EDI   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>          0/r32/EAX  <span class="Delimiter"> . </span>             <span class="Delimiter"> . </span>                <span class="Comment"># copy byte at *EDI to lower byte of EAX</span>
<span id="L74" class="LineNr"> 74 </span>  bb/copy-to-EBX  0/imm32
<span id="L75" class="LineNr"> 75 </span>  8a/copy                         0/mod/indirect  6/rm32/ESI   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>          3/r32/EBX  <span class="Delimiter"> . </span>             <span class="Delimiter"> . </span>                <span class="Comment"># copy byte at *ESI to lower byte of EBX</span>
<span id="L76" class="LineNr"> 76 </span>    <span class="Comment"># if (c1 == 0) return false</span>
<span id="L77" class="LineNr"> 77 </span>  3d/compare-EAX  0/imm32
<span id="L78" class="LineNr"> 78 </span>  74/jump-if-equal  $kernel-string-equal:false/disp8
<span id="L79" class="LineNr"> 79 </span>    <span class="Comment"># if (c1 != c2) return false</span>
<span id="L80" class="LineNr"> 80 </span>  39/compare                      3/mod/direct    0/rm32/EAX   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>          3/r32/EBX  <span class="Delimiter"> . </span>             <span class="Delimiter"> . </span>                <span class="Comment"># compare EAX with EBX</span>
<span id="L81" class="LineNr"> 81 </span>  75/jump-if-not-equal  $kernel-string-equal:false/disp8
<span id="L82" class="LineNr"> 82 </span>    <span class="Comment"># ++s1, ++s2, ++i</span>
<span id="L83" class="LineNr"> 83 </span>  41/inc-ECX
<span id="L84" class="LineNr"> 84 </span>  46/inc-ESI
<span id="L85" class="LineNr"> 85 </span>  47/inc-EDI
<span id="L86" class="LineNr"> 86 </span>  <span class="Comment"># end while</span>
<span id="L87" class="LineNr"> 87 </span>  eb/jump  $kernel-string-equal:loop/disp8
<span id="L88" class="LineNr"> 88 </span>$kernel-string-equal:break:
<span id="L89" class="LineNr"> 89 </span>  <span class="Comment"># if (*s/EDI == 0) return true</span>
<span id="L90" class="LineNr"> 90 </span>  b8/copy-to-EAX  0/imm32
<span id="L91" class="LineNr"> 91 </span>  8a/copy                         0/mod/indirect  7/rm32/EDI   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>          0/r32/EAX  <span class="Delimiter"> . </span>             <span class="Delimiter"> . </span>                <span class="Comment"># copy byte at *EDI to lower byte of EAX</span>
<span id="L92" class="LineNr"> 92 </span>  3d/compare-EAX  0/imm32
<span id="L93" class="LineNr"> 93 </span>  75/jump-if-not-equal  $kernel-string-equal:false/disp8
<span id="L94" class="LineNr"> 94 </span>$kernel-string-equal:true:
<span id="L95" class="LineNr"> 95 </span>  b8/copy-to-EAX  1/imm32
<span id="L96" class="LineNr"> 96 </span>  eb/jump  $kernel-string-equal:end/disp8
<span id="L97" class="LineNr"> 97 </span>  <span class="Comment"># return false</span>
<span id="L98" class="LineNr"> 98 </span>$kernel-string-equal:false:
<span id="L99" class="LineNr"> 99 </span>  b8/copy-to-EAX  0/imm32
<span id="L100" class="LineNr">100 </span>
<span id="L101" class="LineNr">101 </span>$kernel-string-equal:end:
<span id="L102" class="LineNr">102 </span>  <span class="Comment"># restore registers</span>
<span id="L103" class="LineNr">103 </span>  5f/pop-to-EDI
<span id="L104" class="LineNr">104 </span>  5e/pop-to-ESI
<span id="L105" class="LineNr">105 </span>  5b/pop-to-EBX
<span id="L106" class="LineNr">106 </span>  5a/pop-to-EDX
<span id="L107" class="LineNr">107 </span>  59/pop-to-ECX
<span id="L108" class="LineNr">108 </span>  <span class="Comment"># epilog</span>
<span id="L109" class="LineNr">109 </span>  89/copy                         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>          5/r32/EBP  <span class="Delimiter"> . </span>             <span class="Delimiter"> . </span>                <span class="Comment"># copy EBP to ESP</span>
<span id="L110" class="LineNr">110 </span>  5d/pop-to-EBP
<span id="L111" class="LineNr">111 </span>  c3/return
<span id="L112" class="LineNr">112 </span>
<span id="L113" class="LineNr">113 </span><span class="SalientComment">## tests</span>
<span id="L114" class="LineNr">114 </span>
<span id="L115" class="LineNr">115 </span>test-compare-null-kernel-string-with-empty-array:
<span id="L116" class="LineNr">116 </span>  <span class="Comment"># EAX = kernel-string-equal(Null-kernel-string, &quot;&quot;)</span>
<span id="L117" class="LineNr">117 </span>    <span class="Comment"># push args</span>
<span id="L118" class="LineNr">118 </span>  68/push  &quot;&quot;/imm32
<span id="L119" class="LineNr">119 </span>  68/push  Null-kernel-string/imm32
<span id="L120" class="LineNr">120 </span>    <span class="Comment"># call</span>
<span id="L121" class="LineNr">121 </span>  e8/call  kernel-string-equal/disp32
<span id="L122" class="LineNr">122 </span>    <span class="Comment"># discard args</span>
<span id="L123" class="LineNr">123 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              8/imm32           <span class="Comment"># add to ESP</span>
<span id="L124" class="LineNr">124 </span>  <span class="Comment"># call check-ints-equal(EAX, 1, msg)</span>
<span id="L125" class="LineNr">125 </span>    <span class="Comment"># push args</span>
<span id="L126" class="LineNr">126 </span>  68/push  &quot;F - test-compare-null-kernel-string-with-empty-array&quot;/imm32
<span id="L127" class="LineNr">127 </span>  68/push  1/imm32/true
<span id="L128" class="LineNr">128 </span>  50/push-EAX
<span id="L129" class="LineNr">129 </span>    <span class="Comment"># call</span>
<span id="L130" class="LineNr">130 </span>  e8/call  check-ints-equal/disp32
<span id="L131" class="LineNr">131 </span>    <span class="Comment"># discard args</span>
<span id="L132" class="LineNr">132 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              0xc/imm32         <span class="Comment"># add to ESP</span>
<span id="L133" class="LineNr">133 </span>  c3/return
<span id="L134" class="LineNr">134 </span>
<span id="L135" class="LineNr">135 </span>test-compare-null-kernel-string-with-non-empty-array:
<span id="L136" class="LineNr">136 </span>  <span class="Comment"># EAX = kernel-string-equal(Null-kernel-string, &quot;Abc&quot;)</span>
<span id="L137" class="LineNr">137 </span>    <span class="Comment"># push args</span>
<span id="L138" class="LineNr">138 </span>  68/push  &quot;Abc&quot;/imm32
<span id="L139" class="LineNr">139 </span>  68/push  Null-kernel-string/imm32
<span id="L140" class="LineNr">140 </span>    <span class="Comment"># call</span>
<span id="L141" class="LineNr">141 </span>  e8/call  kernel-string-equal/disp32
<span id="L142" class="LineNr">142 </span>    <span class="Comment"># discard args</span>
<span id="L143" class="LineNr">143 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              8/imm32           <span class="Comment"># add to ESP</span>
<span id="L144" class="LineNr">144 </span>  <span class="Comment"># call check-ints-equal(EAX, 0, msg)</span>
<span id="L145" class="LineNr">145 </span>    <span class="Comment"># push args</span>
<span id="L146" class="LineNr">146 </span>  68/push  &quot;F - test-compare-null-kernel-string-with-non-empty-array&quot;/imm32
<span id="L147" class="LineNr">147 </span>  68/push  0/imm32/false
<span id="L148" class="LineNr">148 </span>  50/push-EAX
<span id="L149" class="LineNr">149 </span>    <span class="Comment"># call</span>
<span id="L150" class="LineNr">150 </span>  e8/call  check-ints-equal/disp32
<span id="L151" class="LineNr">151 </span>    <span class="Comment"># discard args</span>
<span id="L152" class="LineNr">152 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              0xc/imm32         <span class="Comment"># add to ESP</span>
<span id="L153" class="LineNr">153 </span>  c3/return
<span id="L154" class="LineNr">154 </span>
<span id="L155" class="LineNr">155 </span>test-compare-kernel-string-with-equal-array:
<span id="L156" class="LineNr">156 </span>  <span class="Comment"># EAX = kernel-string-equal(Abc-kernel-string, &quot;Abc&quot;)</span>
<span id="L157" class="LineNr">157 </span>    <span class="Comment"># push args</span>
<span id="L158" class="LineNr">158 </span>  68/push  &quot;Abc&quot;/imm32
<span id="L159" class="LineNr">159 </span>  68/push  Abc-kernel-string/imm32
<span id="L160" class="LineNr">160 </span>    <span class="Comment"># call</span>
<span id="L161" class="LineNr">161 </span>  e8/call  kernel-string-equal/disp32
<span id="L162" class="LineNr">162 </span>    <span class="Comment"># discard args</span>
<span id="L163" class="LineNr">163 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              8/imm32           <span class="Comment"># add to ESP</span>
<span id="L164" class="LineNr">164 </span>  <span class="Comment"># call check-ints-equal(EAX, 1, msg)</span>
<span id="L165" class="LineNr">165 </span>    <span class="Comment"># push args</span>
<span id="L166" class="LineNr">166 </span>  68/push  &quot;F - test-compare-kernel-string-with-equal-array&quot;/imm32
<span id="L167" class="LineNr">167 </span>  68/push  1/imm32/true
<span id="L168" class="LineNr">168 </span>  50/push-EAX
<span id="L169" class="LineNr">169 </span>    <span class="Comment"># call</span>
<span id="L170" class="LineNr">170 </span>  e8/call  check-ints-equal/disp32
<span id="L171" class="LineNr">171 </span>    <span class="Comment"># discard args</span>
<span id="L172" class="LineNr">172 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              0xc/imm32         <span class="Comment"># add to ESP</span>
<span id="L173" class="LineNr">173 </span>  c3/return
<span id="L174" class="LineNr">174 </span>
<span id="L175" class="LineNr">175 </span>test-compare-kernel-string-with-inequal-array:
<span id="L176" class="LineNr">176 </span>  <span class="Comment"># EAX = kernel-string-equal(Abc-kernel-string, &quot;Adc&quot;)</span>
<span id="L177" class="LineNr">177 </span>    <span class="Comment"># push args</span>
<span id="L178" class="LineNr">178 </span>  68/push  &quot;Adc&quot;/imm32
<span id="L179" class="LineNr">179 </span>  68/push  Abc-kernel-string/imm32
<span id="L180" class="LineNr">180 </span>    <span class="Comment"># call</span>
<span id="L181" class="LineNr">181 </span>  e8/call  kernel-string-equal/disp32
<span id="L182" class="LineNr">182 </span>    <span class="Comment"># discard args</span>
<span id="L183" class="LineNr">183 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              8/imm32           <span class="Comment"># add to ESP</span>
<span id="L184" class="LineNr">184 </span>  <span class="Comment"># call check-ints-equal(EAX, 0, msg)</span>
<span id="L185" class="LineNr">185 </span>    <span class="Comment"># push args</span>
<span id="L186" class="LineNr">186 </span>  68/push  &quot;F - test-compare-kernel-string-with-equal-array&quot;/imm32
<span id="L187" class="LineNr">187 </span>  68/push  0/imm32/false
<span id="L188" class="LineNr">188 </span>  50/push-EAX
<span id="L189" class="LineNr">189 </span>    <span class="Comment"># call</span>
<span id="L190" class="LineNr">190 </span>  e8/call  check-ints-equal/disp32
<span id="L191" class="LineNr">191 </span>    <span class="Comment"># discard args</span>
<span id="L192" class="LineNr">192 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              0xc/imm32         <span class="Comment"># add to ESP</span>
<span id="L193" class="LineNr">193 </span>  c3/return
<span id="L194" class="LineNr">194 </span>
<span id="L195" class="LineNr">195 </span>test-compare-kernel-string-with-empty-array:
<span id="L196" class="LineNr">196 </span>  <span class="Comment"># EAX = kernel-string-equal(Abc-kernel-string, &quot;&quot;)</span>
<span id="L197" class="LineNr">197 </span>    <span class="Comment"># push args</span>
<span id="L198" class="LineNr">198 </span>  68/push  &quot;&quot;/imm32
<span id="L199" class="LineNr">199 </span>  68/push  Abc-kernel-string/imm32
<span id="L200" class="LineNr">200 </span>    <span class="Comment"># call</span>
<span id="L201" class="LineNr">201 </span>  e8/call  kernel-string-equal/disp32
<span id="L202" class="LineNr">202 </span>    <span class="Comment"># discard args</span>
<span id="L203" class="LineNr">203 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              8/imm32           <span class="Comment"># add to ESP</span>
<span id="L204" class="LineNr">204 </span>  <span class="Comment"># call check-ints-equal(EAX, 0)</span>
<span id="L205" class="LineNr">205 </span>    <span class="Comment"># push args</span>
<span id="L206" class="LineNr">206 </span>  68/push  &quot;F - test-compare-kernel-string-with-equal-array&quot;/imm32
<span id="L207" class="LineNr">207 </span>  68/push  0/imm32/false
<span id="L208" class="LineNr">208 </span>  50/push-EAX
<span id="L209" class="LineNr">209 </span>    <span class="Comment"># call</span>
<span id="L210" class="LineNr">210 </span>  e8/call  check-ints-equal/disp32
<span id="L211" class="LineNr">211 </span>    <span class="Comment"># discard args</span>
<span id="L212" class="LineNr">212 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              0xc/imm32         <span class="Comment"># add to ESP</span>
<span id="L213" class="LineNr">213 </span>  c3/return
<span id="L214" class="LineNr">214 </span>
<span id="L215" class="LineNr">215 </span>test-compare-kernel-string-with-shorter-array:
<span id="L216" class="LineNr">216 </span>  <span class="Comment"># EAX = kernel-string-equal(Abc-kernel-string, &quot;Ab&quot;)</span>
<span id="L217" class="LineNr">217 </span>    <span class="Comment"># push args</span>
<span id="L218" class="LineNr">218 </span>  68/push  &quot;Ab&quot;/imm32
<span id="L219" class="LineNr">219 </span>  68/push  Abc-kernel-string/imm32
<span id="L220" class="LineNr">220 </span>    <span class="Comment"># call</span>
<span id="L221" class="LineNr">221 </span>  e8/call  kernel-string-equal/disp32
<span id="L222" class="LineNr">222 </span>    <span class="Comment"># discard args</span>
<span id="L223" class="LineNr">223 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              8/imm32           <span class="Comment"># add to ESP</span>
<span id="L224" class="LineNr">224 </span>  <span class="Comment"># call check-ints-equal(EAX, 0)</span>
<span id="L225" class="LineNr">225 </span>    <span class="Comment"># push args</span>
<span id="L226" class="LineNr">226 </span>  68/push  &quot;F - test-compare-kernel-string-with-shorter-array&quot;/imm32
<span id="L227" class="LineNr">227 </span>  68/push  0/imm32/false
<span id="L228" class="LineNr">228 </span>  50/push-EAX
<span id="L229" class="LineNr">229 </span>    <span class="Comment"># call</span>
<span id="L230" class="LineNr">230 </span>  e8/call  check-ints-equal/disp32
<span id="L231" class="LineNr">231 </span>    <span class="Comment"># discard args</span>
<span id="L232" class="LineNr">232 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              0xc/imm32         <span class="Comment"># add to ESP</span>
<span id="L233" class="LineNr">233 </span>  c3/return
<span id="L234" class="LineNr">234 </span>
<span id="L235" class="LineNr">235 </span>test-compare-kernel-string-with-longer-array:
<span id="L236" class="LineNr">236 </span>  <span class="Comment"># EAX = kernel-string-equal(Abc-kernel-string, &quot;Abcd&quot;)</span>
<span id="L237" class="LineNr">237 </span>    <span class="Comment"># push args</span>
<span id="L238" class="LineNr">238 </span>  68/push  &quot;Abcd&quot;/imm32
<span id="L239" class="LineNr">239 </span>  68/push  Abc-kernel-string/imm32
<span id="L240" class="LineNr">240 </span>    <span class="Comment"># call</span>
<span id="L241" class="LineNr">241 </span>  e8/call  kernel-string-equal/disp32
<span id="L242" class="LineNr">242 </span>    <span class="Comment"># discard args</span>
<span id="L243" class="LineNr">243 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              8/imm32           <span class="Comment"># add to ESP</span>
<span id="L244" class="LineNr">244 </span>  <span class="Comment"># call check-ints-equal(EAX, 0)</span>
<span id="L245" class="LineNr">245 </span>    <span class="Comment"># push args</span>
<span id="L246" class="LineNr">246 </span>  68/push  &quot;F - test-compare-kernel-string-with-longer-array&quot;/imm32
<span id="L247" class="LineNr">247 </span>  68/push  0/imm32/false
<span id="L248" class="LineNr">248 </span>  50/push-EAX
<span id="L249" class="LineNr">249 </span>    <span class="Comment"># call</span>
<span id="L250" class="LineNr">250 </span>  e8/call  check-ints-equal/disp32
<span id="L251" class="LineNr">251 </span>    <span class="Comment"># discard args</span>
<span id="L252" class="LineNr">252 </span>  81          0/subop/add         3/mod/direct    4/rm32/ESP   <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>           <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>         <span class="Delimiter"> . </span>              0xc/imm32         <span class="Comment"># add to ESP</span>
<span id="L253" class="LineNr">253 </span>  c3/return
<span id="L254" class="LineNr">254 </span>
<span id="L255" class="LineNr">255 </span>== data
<span id="L256" class="LineNr">256 </span>
<span id="L257" class="LineNr">257 </span>Null-kernel-string:
<span id="L258" class="LineNr">258 </span>  00/null
<span id="L259" class="LineNr">259 </span>Abc-kernel-string:
<span id="L260" class="LineNr">260 </span>  41/A 62/b 63/c 00/null
<span id="L261" class="LineNr">261 </span>
<span id="L262" class="LineNr">262 </span><span class="Comment"># vim&#0058;nowrap:textwidth=0</span>
</pre>
</body>
</html>
<!-- vim: set foldmethod=manual : -->