<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="theme-color" content="#375EAB">

  <title>src/syscall/mksyscall.pl - The Go Programming Language</title>

<link type="text/css" rel="stylesheet" href="https://golang.org/lib/godoc/style.css">

<link rel="search" type="application/opensearchdescription+xml" title="godoc" href="https://golang.org/opensearch.xml" />

<link rel="stylesheet" href="https://golang.org/lib/godoc/jquery.treeview.css">
<script type="text/javascript">window.initFuncs = [];</script>
<script type="text/javascript">
var _gaq = _gaq || [];
_gaq.push(["_setAccount", "UA-11222381-2"]);
_gaq.push(["b._setAccount", "UA-49880327-6"]);
window.trackPageview = function() {
  _gaq.push(["_trackPageview", location.pathname+location.hash]);
  _gaq.push(["b._trackPageview", location.pathname+location.hash]);
};
window.trackPageview();
window.trackEvent = function(category, action, opt_label, opt_value, opt_noninteraction) {
  _gaq.push(["_trackEvent", category, action, opt_label, opt_value, opt_noninteraction]);
  _gaq.push(["b._trackEvent", category, action, opt_label, opt_value, opt_noninteraction]);
};
</script>
</head>
<body>

<div id='lowframe' style="position: fixed; bottom: 0; left: 0; height: 0; width: 100%; border-top: thin solid grey; background-color: white; overflow: auto;">
...
</div><!-- #lowframe -->

<div id="topbar" class="wide"><div class="container">
<div class="top-heading" id="heading-wide"><a href="https://golang.org/">The Go Programming Language</a></div>
<div class="top-heading" id="heading-narrow"><a href="https://golang.org/">Go</a></div>
<a href="mksyscall.pl#" id="menu-button"><span id="menu-button-arrow">&#9661;</span></a>
<form method="GET" action="https://golang.org/search">
<div id="menu">
<a href="../../doc.1">Documents</a>
<a href="../../pkg.1">Packages</a>
<a href="https://golang.org/project/">The Project</a>
<a href="https://golang.org/help/">Help</a>

<a href="https://golang.org/blog/">Blog</a>


<a id="playgroundButton" href="../../play" title="Show Go Playground">Play</a>

<span class="search-box"><input type="search" id="search" name="q" placeholder="Search" aria-label="Search" required><button type="submit"><span><!-- magnifying glass: --><svg width="24" height="24" viewBox="0 0 24 24"><title>submit search</title><path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"/><path d="M0 0h24v24H0z" fill="none"/></svg></span></button></span>
</div>
</form>

</div></div>


<div id="playground" class="play">
	<div class="input"><textarea class="code" spellcheck="false">package main

import "fmt"

func main() {
	fmt.Println("Hello, 世界")
}</textarea></div>
	<div class="output"></div>
	<div class="buttons">
		<a class="run" title="Run this code [shift-enter]">Run</a>
		<a class="fmt" title="Format this code">Format</a>
		
		<a class="share" title="Share this code">Share</a>
		
	</div>
</div>


<div id="page" class="wide">
<div class="container">


  <h1>
    Text file
    <a href="../../src.1">src</a>/<a href="../syscall.1">syscall</a>/<span class="text-muted">mksyscall.pl</span>
  </h1>





  <h2>
    Documentation: <a href="../../pkg/syscall.1">syscall</a>
  </h2>



<div id="nav"></div>


<pre><span id="L1" class="ln">     1</span>	#!/usr/bin/env perl
<span id="L2" class="ln">     2</span>	# Copyright 2009 The Go Authors. All rights reserved.
<span id="L3" class="ln">     3</span>	# Use of this source code is governed by a BSD-style
<span id="L4" class="ln">     4</span>	# license that can be found in the LICENSE file.
<span id="L5" class="ln">     5</span>	
<span id="L6" class="ln">     6</span>	# This program reads a file containing function prototypes
<span id="L7" class="ln">     7</span>	# (like syscall_darwin.go) and generates system call bodies.
<span id="L8" class="ln">     8</span>	# The prototypes are marked by lines beginning with &#34;//sys&#34;
<span id="L9" class="ln">     9</span>	# and read like func declarations if //sys is replaced by func, but:
<span id="L10" class="ln">    10</span>	#	* The parameter lists must give a name for each argument.
<span id="L11" class="ln">    11</span>	#	  This includes return parameters.
<span id="L12" class="ln">    12</span>	#	* The parameter lists must give a type for each argument:
<span id="L13" class="ln">    13</span>	#	  the (x, y, z int) shorthand is not allowed.
<span id="L14" class="ln">    14</span>	#	* If the return parameter is an error number, it must be named errno.
<span id="L15" class="ln">    15</span>	
<span id="L16" class="ln">    16</span>	# A line beginning with //sysnb is like //sys, except that the
<span id="L17" class="ln">    17</span>	# goroutine will not be suspended during the execution of the system
<span id="L18" class="ln">    18</span>	# call.  This must only be used for system calls which can never
<span id="L19" class="ln">    19</span>	# block, as otherwise the system call could cause all goroutines to
<span id="L20" class="ln">    20</span>	# hang.
<span id="L21" class="ln">    21</span>	
<span id="L22" class="ln">    22</span>	use strict;
<span id="L23" class="ln">    23</span>	
<span id="L24" class="ln">    24</span>	my $cmdline = &#34;mksyscall.pl &#34; . join(&#39; &#39;, @ARGV);
<span id="L25" class="ln">    25</span>	my $errors = 0;
<span id="L26" class="ln">    26</span>	my $_32bit = &#34;&#34;;
<span id="L27" class="ln">    27</span>	my $plan9 = 0;
<span id="L28" class="ln">    28</span>	my $openbsd = 0;
<span id="L29" class="ln">    29</span>	my $netbsd = 0;
<span id="L30" class="ln">    30</span>	my $dragonfly = 0;
<span id="L31" class="ln">    31</span>	my $nacl = 0;
<span id="L32" class="ln">    32</span>	my $arm = 0; # 64-bit value should use (even, odd)-pair
<span id="L33" class="ln">    33</span>	my $tags = &#34;&#34;;  # build tags
<span id="L34" class="ln">    34</span>	
<span id="L35" class="ln">    35</span>	if($ARGV[0] eq &#34;-b32&#34;) {
<span id="L36" class="ln">    36</span>		$_32bit = &#34;big-endian&#34;;
<span id="L37" class="ln">    37</span>		shift;
<span id="L38" class="ln">    38</span>	} elsif($ARGV[0] eq &#34;-l32&#34;) {
<span id="L39" class="ln">    39</span>		$_32bit = &#34;little-endian&#34;;
<span id="L40" class="ln">    40</span>		shift;
<span id="L41" class="ln">    41</span>	}
<span id="L42" class="ln">    42</span>	if($ARGV[0] eq &#34;-plan9&#34;) {
<span id="L43" class="ln">    43</span>		$plan9 = 1;
<span id="L44" class="ln">    44</span>		shift;
<span id="L45" class="ln">    45</span>	}
<span id="L46" class="ln">    46</span>	if($ARGV[0] eq &#34;-openbsd&#34;) {
<span id="L47" class="ln">    47</span>		$openbsd = 1;
<span id="L48" class="ln">    48</span>		shift;
<span id="L49" class="ln">    49</span>	}
<span id="L50" class="ln">    50</span>	if($ARGV[0] eq &#34;-netbsd&#34;) {
<span id="L51" class="ln">    51</span>		$netbsd = 1;
<span id="L52" class="ln">    52</span>		shift;
<span id="L53" class="ln">    53</span>	}
<span id="L54" class="ln">    54</span>	if($ARGV[0] eq &#34;-dragonfly&#34;) {
<span id="L55" class="ln">    55</span>		$dragonfly = 1;
<span id="L56" class="ln">    56</span>		shift;
<span id="L57" class="ln">    57</span>	}
<span id="L58" class="ln">    58</span>	if($ARGV[0] eq &#34;-nacl&#34;) {
<span id="L59" class="ln">    59</span>		$nacl = 1;
<span id="L60" class="ln">    60</span>		shift;
<span id="L61" class="ln">    61</span>	}
<span id="L62" class="ln">    62</span>	if($ARGV[0] eq &#34;-arm&#34;) {
<span id="L63" class="ln">    63</span>		$arm = 1;
<span id="L64" class="ln">    64</span>		shift;
<span id="L65" class="ln">    65</span>	}
<span id="L66" class="ln">    66</span>	if($ARGV[0] eq &#34;-tags&#34;) {
<span id="L67" class="ln">    67</span>		shift;
<span id="L68" class="ln">    68</span>		$tags = $ARGV[0];
<span id="L69" class="ln">    69</span>		shift;
<span id="L70" class="ln">    70</span>	}
<span id="L71" class="ln">    71</span>	
<span id="L72" class="ln">    72</span>	if($ARGV[0] =~ /^-/) {
<span id="L73" class="ln">    73</span>		print STDERR &#34;usage: mksyscall.pl [-b32 | -l32] [-tags x,y] [file ...]\n&#34;;
<span id="L74" class="ln">    74</span>		exit 1;
<span id="L75" class="ln">    75</span>	}
<span id="L76" class="ln">    76</span>	
<span id="L77" class="ln">    77</span>	sub parseparamlist($) {
<span id="L78" class="ln">    78</span>		my ($list) = @_;
<span id="L79" class="ln">    79</span>		$list =~ s/^\s*//;
<span id="L80" class="ln">    80</span>		$list =~ s/\s*$//;
<span id="L81" class="ln">    81</span>		if($list eq &#34;&#34;) {
<span id="L82" class="ln">    82</span>			return ();
<span id="L83" class="ln">    83</span>		}
<span id="L84" class="ln">    84</span>		return split(/\s*,\s*/, $list);
<span id="L85" class="ln">    85</span>	}
<span id="L86" class="ln">    86</span>	
<span id="L87" class="ln">    87</span>	sub parseparam($) {
<span id="L88" class="ln">    88</span>		my ($p) = @_;
<span id="L89" class="ln">    89</span>		if($p !~ /^(\S*) (\S*)$/) {
<span id="L90" class="ln">    90</span>			print STDERR &#34;$ARGV:$.: malformed parameter: $p\n&#34;;
<span id="L91" class="ln">    91</span>			$errors = 1;
<span id="L92" class="ln">    92</span>			return (&#34;xx&#34;, &#34;int&#34;);
<span id="L93" class="ln">    93</span>		}
<span id="L94" class="ln">    94</span>		return ($1, $2);
<span id="L95" class="ln">    95</span>	}
<span id="L96" class="ln">    96</span>	
<span id="L97" class="ln">    97</span>	my $text = &#34;&#34;;
<span id="L98" class="ln">    98</span>	while(&lt;&gt;) {
<span id="L99" class="ln">    99</span>		chomp;
<span id="L100" class="ln">   100</span>		s/\s+/ /g;
<span id="L101" class="ln">   101</span>		s/^\s+//;
<span id="L102" class="ln">   102</span>		s/\s+$//;
<span id="L103" class="ln">   103</span>		my $nonblock = /^\/\/sysnb /;
<span id="L104" class="ln">   104</span>		next if !/^\/\/sys / &amp;&amp; !$nonblock;
<span id="L105" class="ln">   105</span>	
<span id="L106" class="ln">   106</span>		# Line must be of the form
<span id="L107" class="ln">   107</span>		#	func Open(path string, mode int, perm int) (fd int, errno error)
<span id="L108" class="ln">   108</span>		# Split into name, in params, out params.
<span id="L109" class="ln">   109</span>		if(!/^\/\/sys(nb)? (\w+)\(([^()]*)\)\s*(?:\(([^()]+)\))?\s*(?:=\s*((?i)_?SYS_[A-Z0-9_]+))?$/) {
<span id="L110" class="ln">   110</span>			print STDERR &#34;$ARGV:$.: malformed //sys declaration\n&#34;;
<span id="L111" class="ln">   111</span>			$errors = 1;
<span id="L112" class="ln">   112</span>			next;
<span id="L113" class="ln">   113</span>		}
<span id="L114" class="ln">   114</span>		my ($func, $in, $out, $sysname) = ($2, $3, $4, $5);
<span id="L115" class="ln">   115</span>	
<span id="L116" class="ln">   116</span>		# Split argument lists on comma.
<span id="L117" class="ln">   117</span>		my @in = parseparamlist($in);
<span id="L118" class="ln">   118</span>		my @out = parseparamlist($out);
<span id="L119" class="ln">   119</span>	
<span id="L120" class="ln">   120</span>		# Try in vain to keep people from editing this file.
<span id="L121" class="ln">   121</span>		# The theory is that they jump into the middle of the file
<span id="L122" class="ln">   122</span>		# without reading the header.
<span id="L123" class="ln">   123</span>		$text .= &#34;// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT\n\n&#34;;
<span id="L124" class="ln">   124</span>	
<span id="L125" class="ln">   125</span>		# Go function header.
<span id="L126" class="ln">   126</span>		my $out_decl = @out ? sprintf(&#34; (%s)&#34;, join(&#39;, &#39;, @out)) : &#34;&#34;;
<span id="L127" class="ln">   127</span>		$text .= sprintf &#34;func %s(%s)%s {\n&#34;, $func, join(&#39;, &#39;, @in), $out_decl;
<span id="L128" class="ln">   128</span>	
<span id="L129" class="ln">   129</span>		# Check if err return available
<span id="L130" class="ln">   130</span>		my $errvar = &#34;&#34;;
<span id="L131" class="ln">   131</span>		foreach my $p (@out) {
<span id="L132" class="ln">   132</span>			my ($name, $type) = parseparam($p);
<span id="L133" class="ln">   133</span>			if($type eq &#34;error&#34;) {
<span id="L134" class="ln">   134</span>				$errvar = $name;
<span id="L135" class="ln">   135</span>				last;
<span id="L136" class="ln">   136</span>			}
<span id="L137" class="ln">   137</span>		}
<span id="L138" class="ln">   138</span>	
<span id="L139" class="ln">   139</span>		# Prepare arguments to Syscall.
<span id="L140" class="ln">   140</span>		my @args = ();
<span id="L141" class="ln">   141</span>		my $n = 0;
<span id="L142" class="ln">   142</span>		foreach my $p (@in) {
<span id="L143" class="ln">   143</span>			my ($name, $type) = parseparam($p);
<span id="L144" class="ln">   144</span>			if($type =~ /^\*/) {
<span id="L145" class="ln">   145</span>				push @args, &#34;uintptr(unsafe.Pointer($name))&#34;;
<span id="L146" class="ln">   146</span>			} elsif($type eq &#34;string&#34; &amp;&amp; $errvar ne &#34;&#34;) {
<span id="L147" class="ln">   147</span>				$text .= &#34;\tvar _p$n *byte\n&#34;;
<span id="L148" class="ln">   148</span>				$text .= &#34;\t_p$n, $errvar = BytePtrFromString($name)\n&#34;;
<span id="L149" class="ln">   149</span>				$text .= &#34;\tif $errvar != nil {\n\t\treturn\n\t}\n&#34;;
<span id="L150" class="ln">   150</span>				push @args, &#34;uintptr(unsafe.Pointer(_p$n))&#34;;
<span id="L151" class="ln">   151</span>				$n++;
<span id="L152" class="ln">   152</span>			} elsif($type eq &#34;string&#34;) {
<span id="L153" class="ln">   153</span>				print STDERR &#34;$ARGV:$.: $func uses string arguments, but has no error return\n&#34;;
<span id="L154" class="ln">   154</span>				$text .= &#34;\tvar _p$n *byte\n&#34;;
<span id="L155" class="ln">   155</span>				$text .= &#34;\t_p$n, _ = BytePtrFromString($name)\n&#34;;
<span id="L156" class="ln">   156</span>				push @args, &#34;uintptr(unsafe.Pointer(_p$n))&#34;;
<span id="L157" class="ln">   157</span>				$n++;
<span id="L158" class="ln">   158</span>			} elsif($type =~ /^\[\](.*)/) {
<span id="L159" class="ln">   159</span>				# Convert slice into pointer, length.
<span id="L160" class="ln">   160</span>				# Have to be careful not to take address of &amp;a[0] if len == 0:
<span id="L161" class="ln">   161</span>				# pass dummy pointer in that case.
<span id="L162" class="ln">   162</span>				# Used to pass nil, but some OSes or simulators reject write(fd, nil, 0).
<span id="L163" class="ln">   163</span>				$text .= &#34;\tvar _p$n unsafe.Pointer\n&#34;;
<span id="L164" class="ln">   164</span>				$text .= &#34;\tif len($name) &gt; 0 {\n\t\t_p$n = unsafe.Pointer(\&amp;${name}[0])\n\t}&#34;;
<span id="L165" class="ln">   165</span>				$text .= &#34; else {\n\t\t_p$n = unsafe.Pointer(&amp;_zero)\n\t}&#34;;
<span id="L166" class="ln">   166</span>				$text .= &#34;\n&#34;;
<span id="L167" class="ln">   167</span>				push @args, &#34;uintptr(_p$n)&#34;, &#34;uintptr(len($name))&#34;;
<span id="L168" class="ln">   168</span>				$n++;
<span id="L169" class="ln">   169</span>			} elsif($type eq &#34;int64&#34; &amp;&amp; ($openbsd || $netbsd)) {
<span id="L170" class="ln">   170</span>				push @args, &#34;0&#34;;
<span id="L171" class="ln">   171</span>				if($_32bit eq &#34;big-endian&#34;) {
<span id="L172" class="ln">   172</span>					push @args, &#34;uintptr($name&gt;&gt;32)&#34;, &#34;uintptr($name)&#34;;
<span id="L173" class="ln">   173</span>				} elsif($_32bit eq &#34;little-endian&#34;) {
<span id="L174" class="ln">   174</span>					push @args, &#34;uintptr($name)&#34;, &#34;uintptr($name&gt;&gt;32)&#34;;
<span id="L175" class="ln">   175</span>				} else {
<span id="L176" class="ln">   176</span>					push @args, &#34;uintptr($name)&#34;;
<span id="L177" class="ln">   177</span>				}
<span id="L178" class="ln">   178</span>			} elsif($type eq &#34;int64&#34; &amp;&amp; $dragonfly) {
<span id="L179" class="ln">   179</span>				if ($func !~ /^extp(read|write)/i) {
<span id="L180" class="ln">   180</span>					push @args, &#34;0&#34;;
<span id="L181" class="ln">   181</span>				}
<span id="L182" class="ln">   182</span>				if($_32bit eq &#34;big-endian&#34;) {
<span id="L183" class="ln">   183</span>					push @args, &#34;uintptr($name&gt;&gt;32)&#34;, &#34;uintptr($name)&#34;;
<span id="L184" class="ln">   184</span>				} elsif($_32bit eq &#34;little-endian&#34;) {
<span id="L185" class="ln">   185</span>					push @args, &#34;uintptr($name)&#34;, &#34;uintptr($name&gt;&gt;32)&#34;;
<span id="L186" class="ln">   186</span>				} else {
<span id="L187" class="ln">   187</span>					push @args, &#34;uintptr($name)&#34;;
<span id="L188" class="ln">   188</span>				}
<span id="L189" class="ln">   189</span>			} elsif($type eq &#34;int64&#34; &amp;&amp; $_32bit ne &#34;&#34;) {
<span id="L190" class="ln">   190</span>				if(@args % 2 &amp;&amp; $arm) {
<span id="L191" class="ln">   191</span>					# arm abi specifies 64-bit argument uses
<span id="L192" class="ln">   192</span>					# (even, odd) pair
<span id="L193" class="ln">   193</span>					push @args, &#34;0&#34;
<span id="L194" class="ln">   194</span>				}
<span id="L195" class="ln">   195</span>				if($_32bit eq &#34;big-endian&#34;) {
<span id="L196" class="ln">   196</span>					push @args, &#34;uintptr($name&gt;&gt;32)&#34;, &#34;uintptr($name)&#34;;
<span id="L197" class="ln">   197</span>				} else {
<span id="L198" class="ln">   198</span>					push @args, &#34;uintptr($name)&#34;, &#34;uintptr($name&gt;&gt;32)&#34;;
<span id="L199" class="ln">   199</span>				}
<span id="L200" class="ln">   200</span>			} else {
<span id="L201" class="ln">   201</span>				push @args, &#34;uintptr($name)&#34;;
<span id="L202" class="ln">   202</span>			}
<span id="L203" class="ln">   203</span>		}
<span id="L204" class="ln">   204</span>	
<span id="L205" class="ln">   205</span>		# Determine which form to use; pad args with zeros.
<span id="L206" class="ln">   206</span>		my $asm = &#34;Syscall&#34;;
<span id="L207" class="ln">   207</span>		if ($nonblock) {
<span id="L208" class="ln">   208</span>			$asm = &#34;RawSyscall&#34;;
<span id="L209" class="ln">   209</span>		}
<span id="L210" class="ln">   210</span>		if(@args &lt;= 3) {
<span id="L211" class="ln">   211</span>			while(@args &lt; 3) {
<span id="L212" class="ln">   212</span>				push @args, &#34;0&#34;;
<span id="L213" class="ln">   213</span>			}
<span id="L214" class="ln">   214</span>		} elsif(@args &lt;= 6) {
<span id="L215" class="ln">   215</span>			$asm .= &#34;6&#34;;
<span id="L216" class="ln">   216</span>			while(@args &lt; 6) {
<span id="L217" class="ln">   217</span>				push @args, &#34;0&#34;;
<span id="L218" class="ln">   218</span>			}
<span id="L219" class="ln">   219</span>		} elsif(@args &lt;= 9) {
<span id="L220" class="ln">   220</span>			$asm .= &#34;9&#34;;
<span id="L221" class="ln">   221</span>			while(@args &lt; 9) {
<span id="L222" class="ln">   222</span>				push @args, &#34;0&#34;;
<span id="L223" class="ln">   223</span>			}
<span id="L224" class="ln">   224</span>		} else {
<span id="L225" class="ln">   225</span>			print STDERR &#34;$ARGV:$.: too many arguments to system call\n&#34;;
<span id="L226" class="ln">   226</span>		}
<span id="L227" class="ln">   227</span>	
<span id="L228" class="ln">   228</span>		# System call number.
<span id="L229" class="ln">   229</span>		if($sysname eq &#34;&#34;) {
<span id="L230" class="ln">   230</span>			$sysname = &#34;SYS_$func&#34;;
<span id="L231" class="ln">   231</span>			$sysname =~ s/([a-z])([A-Z])/${1}_$2/g;	# turn FooBar into Foo_Bar
<span id="L232" class="ln">   232</span>			$sysname =~ y/a-z/A-Z/;
<span id="L233" class="ln">   233</span>			if($nacl) {
<span id="L234" class="ln">   234</span>				$sysname =~ y/A-Z/a-z/;
<span id="L235" class="ln">   235</span>			}
<span id="L236" class="ln">   236</span>		}
<span id="L237" class="ln">   237</span>	
<span id="L238" class="ln">   238</span>		# Actual call.
<span id="L239" class="ln">   239</span>		my $args = join(&#39;, &#39;, @args);
<span id="L240" class="ln">   240</span>		my $call = &#34;$asm($sysname, $args)&#34;;
<span id="L241" class="ln">   241</span>	
<span id="L242" class="ln">   242</span>		# Assign return values.
<span id="L243" class="ln">   243</span>		my $body = &#34;&#34;;
<span id="L244" class="ln">   244</span>		my @ret = (&#34;_&#34;, &#34;_&#34;, &#34;_&#34;);
<span id="L245" class="ln">   245</span>		my $do_errno = 0;
<span id="L246" class="ln">   246</span>		for(my $i=0; $i&lt;@out; $i++) {
<span id="L247" class="ln">   247</span>			my $p = $out[$i];
<span id="L248" class="ln">   248</span>			my ($name, $type) = parseparam($p);
<span id="L249" class="ln">   249</span>			my $reg = &#34;&#34;;
<span id="L250" class="ln">   250</span>			if($name eq &#34;err&#34; &amp;&amp; !$plan9) {
<span id="L251" class="ln">   251</span>				$reg = &#34;e1&#34;;
<span id="L252" class="ln">   252</span>				$ret[2] = $reg;
<span id="L253" class="ln">   253</span>				$do_errno = 1;
<span id="L254" class="ln">   254</span>			} elsif($name eq &#34;err&#34; &amp;&amp; $plan9) {
<span id="L255" class="ln">   255</span>				$ret[0] = &#34;r0&#34;;
<span id="L256" class="ln">   256</span>				$ret[2] = &#34;e1&#34;;
<span id="L257" class="ln">   257</span>				next;
<span id="L258" class="ln">   258</span>			} else {
<span id="L259" class="ln">   259</span>				$reg = sprintf(&#34;r%d&#34;, $i);
<span id="L260" class="ln">   260</span>				$ret[$i] = $reg;
<span id="L261" class="ln">   261</span>			}
<span id="L262" class="ln">   262</span>			if($type eq &#34;bool&#34;) {
<span id="L263" class="ln">   263</span>				$reg = &#34;$reg != 0&#34;;
<span id="L264" class="ln">   264</span>			}
<span id="L265" class="ln">   265</span>			if($type eq &#34;int64&#34; &amp;&amp; $_32bit ne &#34;&#34;) {
<span id="L266" class="ln">   266</span>				# 64-bit number in r1:r0 or r0:r1.
<span id="L267" class="ln">   267</span>				if($i+2 &gt; @out) {
<span id="L268" class="ln">   268</span>					print STDERR &#34;$ARGV:$.: not enough registers for int64 return\n&#34;;
<span id="L269" class="ln">   269</span>				}
<span id="L270" class="ln">   270</span>				if($_32bit eq &#34;big-endian&#34;) {
<span id="L271" class="ln">   271</span>					$reg = sprintf(&#34;int64(r%d)&lt;&lt;32 | int64(r%d)&#34;, $i, $i+1);
<span id="L272" class="ln">   272</span>				} else {
<span id="L273" class="ln">   273</span>					$reg = sprintf(&#34;int64(r%d)&lt;&lt;32 | int64(r%d)&#34;, $i+1, $i);
<span id="L274" class="ln">   274</span>				}
<span id="L275" class="ln">   275</span>				$ret[$i] = sprintf(&#34;r%d&#34;, $i);
<span id="L276" class="ln">   276</span>				$ret[$i+1] = sprintf(&#34;r%d&#34;, $i+1);
<span id="L277" class="ln">   277</span>			}
<span id="L278" class="ln">   278</span>			if($reg ne &#34;e1&#34; || $plan9) {
<span id="L279" class="ln">   279</span>				$body .= &#34;\t$name = $type($reg)\n&#34;;
<span id="L280" class="ln">   280</span>			}
<span id="L281" class="ln">   281</span>		}
<span id="L282" class="ln">   282</span>		if ($ret[0] eq &#34;_&#34; &amp;&amp; $ret[1] eq &#34;_&#34; &amp;&amp; $ret[2] eq &#34;_&#34;) {
<span id="L283" class="ln">   283</span>			$text .= &#34;\t$call\n&#34;;
<span id="L284" class="ln">   284</span>		} else {
<span id="L285" class="ln">   285</span>			$text .= &#34;\t$ret[0], $ret[1], $ret[2] := $call\n&#34;;
<span id="L286" class="ln">   286</span>		}
<span id="L287" class="ln">   287</span>		$text .= $body;
<span id="L288" class="ln">   288</span>	
<span id="L289" class="ln">   289</span>		if ($plan9 &amp;&amp; $ret[2] eq &#34;e1&#34;) {
<span id="L290" class="ln">   290</span>			$text .= &#34;\tif int32(r0) == -1 {\n&#34;;
<span id="L291" class="ln">   291</span>			$text .= &#34;\t\terr = e1\n&#34;;
<span id="L292" class="ln">   292</span>			$text .= &#34;\t}\n&#34;;
<span id="L293" class="ln">   293</span>		} elsif ($do_errno) {
<span id="L294" class="ln">   294</span>			$text .= &#34;\tif e1 != 0 {\n&#34;;
<span id="L295" class="ln">   295</span>			$text .= &#34;\t\terr = errnoErr(e1)\n&#34;;
<span id="L296" class="ln">   296</span>			$text .= &#34;\t}\n&#34;;
<span id="L297" class="ln">   297</span>		}
<span id="L298" class="ln">   298</span>		$text .= &#34;\treturn\n&#34;;
<span id="L299" class="ln">   299</span>		$text .= &#34;}\n\n&#34;;
<span id="L300" class="ln">   300</span>	}
<span id="L301" class="ln">   301</span>	
<span id="L302" class="ln">   302</span>	chomp $text;
<span id="L303" class="ln">   303</span>	chomp $text;
<span id="L304" class="ln">   304</span>	
<span id="L305" class="ln">   305</span>	if($errors) {
<span id="L306" class="ln">   306</span>		exit 1;
<span id="L307" class="ln">   307</span>	}
<span id="L308" class="ln">   308</span>	
<span id="L309" class="ln">   309</span>	print &lt;&lt;EOF;
<span id="L310" class="ln">   310</span>	// $cmdline
<span id="L311" class="ln">   311</span>	// MACHINE GENERATED BY THE COMMAND ABOVE; DO NOT EDIT
<span id="L312" class="ln">   312</span>	
<span id="L313" class="ln">   313</span>	// +build $tags
<span id="L314" class="ln">   314</span>	
<span id="L315" class="ln">   315</span>	package syscall
<span id="L316" class="ln">   316</span>	
<span id="L317" class="ln">   317</span>	import &#34;unsafe&#34;
<span id="L318" class="ln">   318</span>	
<span id="L319" class="ln">   319</span>	$text
<span id="L320" class="ln">   320</span>	EOF
<span id="L321" class="ln">   321</span>	exit 0;
</pre><p><a href="https://golang.org/src/syscall/mksyscall.pl?m=text">View as plain text</a></p>

<div id="footer">
Build version go1.10.<br>
Except as <a href="https://developers.google.com/site-policies#restrictions">noted</a>,
the content of this page is licensed under the
Creative Commons Attribution 3.0 License,
and code is licensed under a <a href="https://golang.org/LICENSE">BSD license</a>.<br>
<a href="https://golang.org/doc/tos.html">Terms of Service</a> |
<a href="http://www.google.com/intl/en/policies/privacy/">Privacy Policy</a>
</div>

</div><!-- .container -->
</div><!-- #page -->

<!-- TODO(adonovan): load these from <head> using "defer" attribute? -->
<script type="text/javascript" src="https://golang.org/lib/godoc/jquery.js"></script>
<script type="text/javascript" src="https://golang.org/lib/godoc/jquery.treeview.js"></script>
<script type="text/javascript" src="https://golang.org/lib/godoc/jquery.treeview.edit.js"></script>


<script type="text/javascript" src="https://golang.org/lib/godoc/playground.js"></script>

<script>var goVersion = "go1.10";</script>
<script type="text/javascript" src="https://golang.org/lib/godoc/godocs.js"></script>

<script type="text/javascript">
(function() {
  var ga = document.createElement("script"); ga.type = "text/javascript"; ga.async = true;
  ga.src = ("https:" == document.location.protocol ? "https://ssl" : "http://www") + ".google-analytics.com/ga.js";
  var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(ga, s);
})();
</script>
</body>
</html>

