| 1 |
714 |
jeremybenn |
// runtime.def -- runtime functions called by generated code. -*- C++ -*-
|
| 2 |
|
|
|
| 3 |
|
|
// Copyright 2011 The Go Authors. All rights reserved.
|
| 4 |
|
|
// Use of this source code is governed by a BSD-style
|
| 5 |
|
|
// license that can be found in the LICENSE file.
|
| 6 |
|
|
|
| 7 |
|
|
// Definitions for the Go runtime functions.
|
| 8 |
|
|
|
| 9 |
|
|
// Parameter type helper macros.
|
| 10 |
|
|
#define ABFT6(T1, T2, T3, T4, T5, T6) \
|
| 11 |
|
|
{ RFT_ ## T1, RFT_ ## T2, RFT_ ## T3, RFT_ ## T4, RFT_ ## T5, RFT_ ## T6 }
|
| 12 |
|
|
#define P0() ABFT6(VOID, VOID, VOID, VOID, VOID, VOID)
|
| 13 |
|
|
#define P1(T) ABFT6(T, VOID, VOID, VOID, VOID, VOID)
|
| 14 |
|
|
#define P2(T1, T2) ABFT6(T1, T2, VOID, VOID, VOID, VOID)
|
| 15 |
|
|
#define P3(T1, T2, T3) ABFT6(T1, T2, T3, VOID, VOID, VOID)
|
| 16 |
|
|
#define P4(T1, T2, T3, T4) ABFT6(T1, T2, T3, T4, VOID, VOID)
|
| 17 |
|
|
#define P5(T1, T2, T3, T4, T5) ABFT6(T1, T2, T3, T4, T5, VOID)
|
| 18 |
|
|
#define P6(T1,T2,T3,T4,T5,T6) ABFT6(T1, T2, T3, T4, T5, T6)
|
| 19 |
|
|
|
| 20 |
|
|
// Result type helper macros.
|
| 21 |
|
|
#define ABFT2(T1, T2) { RFT_ ## T1, RFT_ ## T2 }
|
| 22 |
|
|
#define R0() ABFT2(VOID, VOID)
|
| 23 |
|
|
#define R1(T) ABFT2(T, VOID)
|
| 24 |
|
|
#define R2(T1, T2) ABFT2(T1, T2)
|
| 25 |
|
|
|
| 26 |
|
|
// Define all the Go runtime functions. The first parameter is the
|
| 27 |
|
|
// enum code used to refer to the function. The second parameter is
|
| 28 |
|
|
// the name. The third is the parameter types and the fourth is the
|
| 29 |
|
|
// result types.
|
| 30 |
|
|
|
| 31 |
|
|
// The standard C memcmp function, used for struct comparisons.
|
| 32 |
|
|
DEF_GO_RUNTIME(MEMCMP, "memcmp", P3(POINTER, POINTER, UINTPTR), R1(INT))
|
| 33 |
|
|
|
| 34 |
|
|
// Range over a string, returning the next index.
|
| 35 |
|
|
DEF_GO_RUNTIME(STRINGITER, "runtime.stringiter", P2(STRING, INT), R1(INT))
|
| 36 |
|
|
|
| 37 |
|
|
// Range over a string, returning the next index and character.
|
| 38 |
|
|
DEF_GO_RUNTIME(STRINGITER2, "runtime.stringiter2", P2(STRING, INT),
|
| 39 |
|
|
R2(INT, RUNE))
|
| 40 |
|
|
|
| 41 |
|
|
// Concatenate two strings.
|
| 42 |
|
|
DEF_GO_RUNTIME(STRING_PLUS, "__go_string_plus", P2(STRING, STRING), R1(STRING))
|
| 43 |
|
|
|
| 44 |
|
|
// Compare two strings.
|
| 45 |
|
|
DEF_GO_RUNTIME(STRCMP, "__go_strcmp", P2(STRING, STRING), R1(INT))
|
| 46 |
|
|
|
| 47 |
|
|
// Take a slice of a string.
|
| 48 |
|
|
DEF_GO_RUNTIME(STRING_SLICE, "__go_string_slice", P3(STRING, INT, INT),
|
| 49 |
|
|
R1(STRING))
|
| 50 |
|
|
|
| 51 |
|
|
// Convert an integer to a string.
|
| 52 |
|
|
DEF_GO_RUNTIME(INT_TO_STRING, "__go_int_to_string", P1(INT), R1(STRING))
|
| 53 |
|
|
|
| 54 |
|
|
// Convert a byte array to a string.
|
| 55 |
|
|
DEF_GO_RUNTIME(BYTE_ARRAY_TO_STRING, "__go_byte_array_to_string",
|
| 56 |
|
|
P2(POINTER, INT), R1(STRING))
|
| 57 |
|
|
|
| 58 |
|
|
// Convert an int array to a string.
|
| 59 |
|
|
DEF_GO_RUNTIME(INT_ARRAY_TO_STRING, "__go_int_array_to_string",
|
| 60 |
|
|
P2(POINTER, INT), R1(STRING))
|
| 61 |
|
|
|
| 62 |
|
|
// Convert a string to a byte slice.
|
| 63 |
|
|
DEF_GO_RUNTIME(STRING_TO_BYTE_ARRAY, "__go_string_to_byte_array",
|
| 64 |
|
|
P1(STRING), R1(SLICE))
|
| 65 |
|
|
|
| 66 |
|
|
// Convert a string to an int slice.
|
| 67 |
|
|
DEF_GO_RUNTIME(STRING_TO_INT_ARRAY, "__go_string_to_int_array",
|
| 68 |
|
|
P1(STRING), R1(SLICE))
|
| 69 |
|
|
|
| 70 |
|
|
|
| 71 |
|
|
// Make a slice.
|
| 72 |
|
|
DEF_GO_RUNTIME(MAKESLICE1, "__go_make_slice1", P2(TYPE, UINTPTR), R1(SLICE))
|
| 73 |
|
|
DEF_GO_RUNTIME(MAKESLICE2, "__go_make_slice2", P3(TYPE, UINTPTR, UINTPTR),
|
| 74 |
|
|
R1(SLICE))
|
| 75 |
|
|
DEF_GO_RUNTIME(MAKESLICE1BIG, "__go_make_slice1_big", P2(TYPE, UINT64),
|
| 76 |
|
|
R1(SLICE))
|
| 77 |
|
|
DEF_GO_RUNTIME(MAKESLICE2BIG, "__go_make_slice2_big", P3(TYPE, UINT64, UINT64),
|
| 78 |
|
|
R1(SLICE))
|
| 79 |
|
|
|
| 80 |
|
|
|
| 81 |
|
|
// Make a map.
|
| 82 |
|
|
DEF_GO_RUNTIME(MAKEMAP, "__go_new_map", P2(MAPDESCRIPTOR, UINTPTR), R1(MAP))
|
| 83 |
|
|
DEF_GO_RUNTIME(MAKEMAPBIG, "__go_new_map_big", P2(MAPDESCRIPTOR, UINT64),
|
| 84 |
|
|
R1(MAP))
|
| 85 |
|
|
|
| 86 |
|
|
// Build a map from a composite literal.
|
| 87 |
|
|
DEF_GO_RUNTIME(CONSTRUCT_MAP, "__go_construct_map",
|
| 88 |
|
|
P6(POINTER, UINTPTR, UINTPTR, UINTPTR, UINTPTR, POINTER),
|
| 89 |
|
|
R1(MAP))
|
| 90 |
|
|
|
| 91 |
|
|
// Get the length of a map (the number of entries).
|
| 92 |
|
|
DEF_GO_RUNTIME(MAP_LEN, "__go_map_len", P1(MAP), R1(INT))
|
| 93 |
|
|
|
| 94 |
|
|
// Look up a key in a map.
|
| 95 |
|
|
DEF_GO_RUNTIME(MAP_INDEX, "__go_map_index", P3(MAP, POINTER, BOOL),
|
| 96 |
|
|
R1(POINTER))
|
| 97 |
|
|
|
| 98 |
|
|
// Look up a key in a map returning whether it is present.
|
| 99 |
|
|
DEF_GO_RUNTIME(MAPACCESS2, "runtime.mapaccess2",
|
| 100 |
|
|
P4(TYPE, MAP, POINTER, POINTER), R1(BOOL))
|
| 101 |
|
|
|
| 102 |
|
|
// Tuple assignment to a map element.
|
| 103 |
|
|
DEF_GO_RUNTIME(MAPASSIGN2, "runtime.mapassign2",
|
| 104 |
|
|
P4(MAP, POINTER, POINTER, BOOL), R0())
|
| 105 |
|
|
|
| 106 |
|
|
// Delete a key from a map.
|
| 107 |
|
|
DEF_GO_RUNTIME(MAPDELETE, "runtime.mapdelete", P2(MAP, POINTER), R0())
|
| 108 |
|
|
|
| 109 |
|
|
// Begin a range over a map.
|
| 110 |
|
|
DEF_GO_RUNTIME(MAPITERINIT, "runtime.mapiterinit", P2(MAP, MAPITER), R0())
|
| 111 |
|
|
|
| 112 |
|
|
// Range over a map, returning the next key.
|
| 113 |
|
|
DEF_GO_RUNTIME(MAPITER1, "runtime.mapiter1", P2(MAPITER, POINTER), R0())
|
| 114 |
|
|
|
| 115 |
|
|
// Range over a map, returning the next key and value.
|
| 116 |
|
|
DEF_GO_RUNTIME(MAPITER2, "runtime.mapiter2", P3(MAPITER, POINTER, POINTER),
|
| 117 |
|
|
R0())
|
| 118 |
|
|
|
| 119 |
|
|
// Range over a map, moving to the next map entry.
|
| 120 |
|
|
DEF_GO_RUNTIME(MAPITERNEXT, "runtime.mapiternext", P1(MAPITER), R0())
|
| 121 |
|
|
|
| 122 |
|
|
|
| 123 |
|
|
// Make a channel.
|
| 124 |
|
|
DEF_GO_RUNTIME(MAKECHAN, "__go_new_channel", P2(TYPE, UINTPTR), R1(CHAN))
|
| 125 |
|
|
DEF_GO_RUNTIME(MAKECHANBIG, "__go_new_channel_big", P2(TYPE, UINT64), R1(CHAN))
|
| 126 |
|
|
|
| 127 |
|
|
// Get the length of a channel (the number of unread values).
|
| 128 |
|
|
DEF_GO_RUNTIME(CHAN_LEN, "__go_chan_len", P1(CHAN), R1(INT))
|
| 129 |
|
|
|
| 130 |
|
|
// Get the capacity of a channel (the size of the buffer).
|
| 131 |
|
|
DEF_GO_RUNTIME(CHAN_CAP, "__go_chan_cap", P1(CHAN), R1(INT))
|
| 132 |
|
|
|
| 133 |
|
|
// Send a small value on a channel.
|
| 134 |
|
|
DEF_GO_RUNTIME(SEND_SMALL, "__go_send_small", P3(TYPE, CHAN, UINT64), R0())
|
| 135 |
|
|
|
| 136 |
|
|
// Send a big value on a channel.
|
| 137 |
|
|
DEF_GO_RUNTIME(SEND_BIG, "__go_send_big", P3(TYPE, CHAN, POINTER), R0())
|
| 138 |
|
|
|
| 139 |
|
|
// Receive a small value from a channel.
|
| 140 |
|
|
DEF_GO_RUNTIME(RECEIVE_SMALL, "__go_receive_small", P2(TYPE, CHAN), R1(UINT64))
|
| 141 |
|
|
|
| 142 |
|
|
// Receive a big value from a channel.
|
| 143 |
|
|
DEF_GO_RUNTIME(RECEIVE_BIG, "__go_receive_big", P3(TYPE, CHAN, POINTER), R0())
|
| 144 |
|
|
|
| 145 |
|
|
// Receive a value from a channel returning whether it is closed.
|
| 146 |
|
|
DEF_GO_RUNTIME(CHANRECV2, "runtime.chanrecv2", P3(TYPE, CHAN, POINTER),
|
| 147 |
|
|
R1(BOOL))
|
| 148 |
|
|
|
| 149 |
|
|
|
| 150 |
|
|
// Start building a select statement.
|
| 151 |
|
|
DEF_GO_RUNTIME(NEWSELECT, "runtime.newselect", P1(INT), R1(POINTER))
|
| 152 |
|
|
|
| 153 |
|
|
// Add a default clause to a select statement.
|
| 154 |
|
|
DEF_GO_RUNTIME(SELECTDEFAULT, "runtime.selectdefault", P2(POINTER, INT), R0())
|
| 155 |
|
|
|
| 156 |
|
|
// Add a send clause to a select statement.
|
| 157 |
|
|
DEF_GO_RUNTIME(SELECTSEND, "runtime.selectsend",
|
| 158 |
|
|
P4(POINTER, CHAN, POINTER, INT), R0())
|
| 159 |
|
|
|
| 160 |
|
|
// Add a receive clause to a select statement, for a clause which does
|
| 161 |
|
|
// not check whether the channel is closed.
|
| 162 |
|
|
DEF_GO_RUNTIME(SELECTRECV, "runtime.selectrecv",
|
| 163 |
|
|
P4(POINTER, CHAN, POINTER, INT), R0())
|
| 164 |
|
|
|
| 165 |
|
|
// Add a receive clause to a select statement, for a clause which does
|
| 166 |
|
|
// check whether the channel is closed.
|
| 167 |
|
|
DEF_GO_RUNTIME(SELECTRECV2, "runtime.selectrecv2",
|
| 168 |
|
|
P5(POINTER, CHAN, POINTER, BOOLPTR, INT), R0())
|
| 169 |
|
|
|
| 170 |
|
|
// Run a select, returning the index of the selected clause.
|
| 171 |
|
|
DEF_GO_RUNTIME(SELECTGO, "runtime.selectgo", P1(POINTER), R1(INT))
|
| 172 |
|
|
|
| 173 |
|
|
|
| 174 |
|
|
// Panic.
|
| 175 |
|
|
DEF_GO_RUNTIME(PANIC, "__go_panic", P1(EFACE), R0())
|
| 176 |
|
|
|
| 177 |
|
|
// Recover.
|
| 178 |
|
|
DEF_GO_RUNTIME(RECOVER, "__go_recover", P0(), R1(EFACE))
|
| 179 |
|
|
|
| 180 |
|
|
// Recover when called directly from defer.
|
| 181 |
|
|
DEF_GO_RUNTIME(DEFERRED_RECOVER, "__go_deferred_recover", P0(), R1(EFACE))
|
| 182 |
|
|
|
| 183 |
|
|
// Decide whether this function can call recover.
|
| 184 |
|
|
DEF_GO_RUNTIME(CAN_RECOVER, "__go_can_recover", P1(POINTER), R1(BOOL))
|
| 185 |
|
|
|
| 186 |
|
|
// Get the return address of the function.
|
| 187 |
|
|
DEF_GO_RUNTIME(RETURN_ADDRESS, "__go_return_address", P1(INT), R1(POINTER))
|
| 188 |
|
|
|
| 189 |
|
|
// Set the return address for defer in a defer thunk.
|
| 190 |
|
|
DEF_GO_RUNTIME(SET_DEFER_RETADDR, "__go_set_defer_retaddr", P1(POINTER),
|
| 191 |
|
|
R1(BOOL))
|
| 192 |
|
|
|
| 193 |
|
|
// Check for a deferred function in an exception handler.
|
| 194 |
|
|
DEF_GO_RUNTIME(CHECK_DEFER, "__go_check_defer", P1(BOOLPTR), R0())
|
| 195 |
|
|
|
| 196 |
|
|
// Run deferred functions.
|
| 197 |
|
|
DEF_GO_RUNTIME(UNDEFER, "__go_undefer", P1(BOOLPTR), R0())
|
| 198 |
|
|
|
| 199 |
|
|
// Panic with a runtime error.
|
| 200 |
|
|
DEF_GO_RUNTIME(RUNTIME_ERROR, "__go_runtime_error", P1(INT), R0())
|
| 201 |
|
|
|
| 202 |
|
|
|
| 203 |
|
|
// Close.
|
| 204 |
|
|
DEF_GO_RUNTIME(CLOSE, "__go_close", P1(CHAN), R0())
|
| 205 |
|
|
|
| 206 |
|
|
|
| 207 |
|
|
// Copy.
|
| 208 |
|
|
DEF_GO_RUNTIME(COPY, "__go_copy", P3(POINTER, POINTER, UINTPTR), R0())
|
| 209 |
|
|
|
| 210 |
|
|
// Append.
|
| 211 |
|
|
DEF_GO_RUNTIME(APPEND, "__go_append", P4(SLICE, POINTER, UINTPTR, UINTPTR),
|
| 212 |
|
|
R1(SLICE))
|
| 213 |
|
|
|
| 214 |
|
|
|
| 215 |
|
|
// Register roots (global variables) for the garbage collector.
|
| 216 |
|
|
DEF_GO_RUNTIME(REGISTER_GC_ROOTS, "__go_register_gc_roots", P1(POINTER), R0())
|
| 217 |
|
|
|
| 218 |
|
|
|
| 219 |
|
|
// Allocate memory.
|
| 220 |
|
|
DEF_GO_RUNTIME(NEW, "__go_new", P1(UINTPTR), R1(POINTER))
|
| 221 |
|
|
|
| 222 |
|
|
// Allocate memory which can not contain pointers.
|
| 223 |
|
|
DEF_GO_RUNTIME(NEW_NOPOINTERS, "__go_new_nopointers", P1(UINTPTR), R1(POINTER))
|
| 224 |
|
|
|
| 225 |
|
|
|
| 226 |
|
|
// Allocate a trampoline for a function literal.
|
| 227 |
|
|
DEF_GO_RUNTIME(ALLOCATE_GO_TRAMPOLINE, "__go_allocate_trampoline",
|
| 228 |
|
|
P2(UINTPTR, POINTER), R1(POINTER))
|
| 229 |
|
|
|
| 230 |
|
|
|
| 231 |
|
|
// Start a new goroutine.
|
| 232 |
|
|
DEF_GO_RUNTIME(GO, "__go_go", P2(FUNC_PTR, POINTER), R0())
|
| 233 |
|
|
|
| 234 |
|
|
|
| 235 |
|
|
// Defer a function.
|
| 236 |
|
|
DEF_GO_RUNTIME(DEFER, "__go_defer", P3(BOOLPTR, FUNC_PTR, POINTER), R0())
|
| 237 |
|
|
|
| 238 |
|
|
|
| 239 |
|
|
// Convert an empty interface to an empty interface, returning ok.
|
| 240 |
|
|
DEF_GO_RUNTIME(IFACEE2E2, "runtime.ifaceE2E2", P1(EFACE), R2(EFACE, BOOL))
|
| 241 |
|
|
|
| 242 |
|
|
// Convert a non-empty interface to an empty interface, returning ok.
|
| 243 |
|
|
DEF_GO_RUNTIME(IFACEI2E2, "runtime.ifaceI2E2", P1(IFACE), R2(EFACE, BOOL))
|
| 244 |
|
|
|
| 245 |
|
|
// Convert an empty interface to a non-empty interface, returning ok.
|
| 246 |
|
|
DEF_GO_RUNTIME(IFACEE2I2, "runtime.ifaceE2I2", P2(TYPE, EFACE),
|
| 247 |
|
|
R2(IFACE, BOOL))
|
| 248 |
|
|
|
| 249 |
|
|
// Convert a non-empty interface to a non-empty interface, returning ok.
|
| 250 |
|
|
DEF_GO_RUNTIME(IFACEI2I2, "runtime.ifaceI2I2", P2(TYPE, IFACE),
|
| 251 |
|
|
R2(IFACE, BOOL))
|
| 252 |
|
|
|
| 253 |
|
|
// Convert an empty interface to a pointer type, returning ok.
|
| 254 |
|
|
DEF_GO_RUNTIME(IFACEE2T2P, "runtime.ifaceE2T2P", P2(TYPE, EFACE),
|
| 255 |
|
|
R2(POINTER, BOOL))
|
| 256 |
|
|
|
| 257 |
|
|
// Convert a non-empty interface to a pointer type, return ok.
|
| 258 |
|
|
DEF_GO_RUNTIME(IFACEI2T2P, "runtime.ifaceI2T2P", P2(TYPE, IFACE),
|
| 259 |
|
|
R2(POINTER, BOOL))
|
| 260 |
|
|
|
| 261 |
|
|
// Convert an empty interface to a non-pointer type, returning ok.
|
| 262 |
|
|
DEF_GO_RUNTIME(IFACEE2T2, "runtime.ifaceE2T2", P3(TYPE, EFACE, POINTER),
|
| 263 |
|
|
R1(BOOL))
|
| 264 |
|
|
|
| 265 |
|
|
// Convert a non-empty interface to a non-pointer type, returning ok.
|
| 266 |
|
|
DEF_GO_RUNTIME(IFACEI2T2, "runtime.ifaceI2T2", P3(TYPE, IFACE, POINTER),
|
| 267 |
|
|
R1(BOOL))
|
| 268 |
|
|
|
| 269 |
|
|
// A type assertion from one interface type to another. This is
|
| 270 |
|
|
// used for a type assertion.
|
| 271 |
|
|
DEF_GO_RUNTIME(ASSERT_INTERFACE, "__go_assert_interface", P2(TYPE, TYPE), R0())
|
| 272 |
|
|
|
| 273 |
|
|
// Convert one interface type to another. This is used for an
|
| 274 |
|
|
// assignment.
|
| 275 |
|
|
DEF_GO_RUNTIME(CONVERT_INTERFACE, "__go_convert_interface", P2(TYPE, TYPE),
|
| 276 |
|
|
R1(POINTER))
|
| 277 |
|
|
|
| 278 |
|
|
// Check whether an interface type may be converted to a
|
| 279 |
|
|
// non-interface type.
|
| 280 |
|
|
DEF_GO_RUNTIME(CHECK_INTERFACE_TYPE, "__go_check_interface_type",
|
| 281 |
|
|
P3(TYPE, TYPE, TYPE), R0())
|
| 282 |
|
|
|
| 283 |
|
|
// Return whether we can convert an interface type to a type.
|
| 284 |
|
|
DEF_GO_RUNTIME(IFACEI2TP, "runtime.ifaceI2Tp", P2(TYPE, TYPE), R1(BOOL))
|
| 285 |
|
|
|
| 286 |
|
|
// Get the type descriptor of an empty interface.
|
| 287 |
|
|
DEF_GO_RUNTIME(EFACETYPE, "runtime.efacetype", P1(EFACE), R1(TYPE))
|
| 288 |
|
|
|
| 289 |
|
|
// Get the type descriptor of a non-empty interface.
|
| 290 |
|
|
DEF_GO_RUNTIME(IFACETYPE, "runtime.ifacetype", P1(IFACE), R1(TYPE))
|
| 291 |
|
|
|
| 292 |
|
|
|
| 293 |
|
|
// Compare two type descriptors for equality.
|
| 294 |
|
|
DEF_GO_RUNTIME(IFACETYPEEQ, "runtime.ifacetypeeq", P2(TYPE, TYPE), R1(BOOL))
|
| 295 |
|
|
|
| 296 |
|
|
// Compare two empty interface values.
|
| 297 |
|
|
DEF_GO_RUNTIME(EMPTY_INTERFACE_COMPARE, "__go_empty_interface_compare",
|
| 298 |
|
|
P2(EFACE, EFACE), R1(INT))
|
| 299 |
|
|
|
| 300 |
|
|
// Compare an empty interface value to a non-interface value.
|
| 301 |
|
|
DEF_GO_RUNTIME(EMPTY_INTERFACE_VALUE_COMPARE,
|
| 302 |
|
|
"__go_empty_interface_value_compare",
|
| 303 |
|
|
P3(EFACE, TYPE, POINTER), R1(INT))
|
| 304 |
|
|
|
| 305 |
|
|
// Compare two non-empty interface values.
|
| 306 |
|
|
DEF_GO_RUNTIME(INTERFACE_COMPARE, "__go_interface_compare",
|
| 307 |
|
|
P2(IFACE, IFACE), R1(INT))
|
| 308 |
|
|
|
| 309 |
|
|
// Compare a non-empty interface value to a non-interface value.
|
| 310 |
|
|
DEF_GO_RUNTIME(INTERFACE_VALUE_COMPARE, "__go_interface_value_compare",
|
| 311 |
|
|
P3(IFACE, TYPE, POINTER), R1(INT))
|
| 312 |
|
|
|
| 313 |
|
|
// Compare a non-empty interface value to an interface value.
|
| 314 |
|
|
DEF_GO_RUNTIME(INTERFACE_EMPTY_COMPARE, "__go_interface_empty_compare",
|
| 315 |
|
|
P2(IFACE, EFACE), R1(INT))
|
| 316 |
|
|
|
| 317 |
|
|
|
| 318 |
|
|
// Print a string (for print/println).
|
| 319 |
|
|
DEF_GO_RUNTIME(PRINT_STRING, "__go_print_string", P1(STRING), R0())
|
| 320 |
|
|
|
| 321 |
|
|
// Print a uint64 (for print/println).
|
| 322 |
|
|
DEF_GO_RUNTIME(PRINT_UINT64, "__go_print_uint64", P1(UINT64), R0())
|
| 323 |
|
|
|
| 324 |
|
|
// Print a int64 (for print/println).
|
| 325 |
|
|
DEF_GO_RUNTIME(PRINT_INT64, "__go_print_int64", P1(INT64), R0())
|
| 326 |
|
|
|
| 327 |
|
|
// Print a float64 (for print/println).
|
| 328 |
|
|
DEF_GO_RUNTIME(PRINT_DOUBLE, "__go_print_double", P1(FLOAT64), R0())
|
| 329 |
|
|
|
| 330 |
|
|
// Print a complex128 (for print/println).
|
| 331 |
|
|
DEF_GO_RUNTIME(PRINT_COMPLEX, "__go_print_complex", P1(COMPLEX128), R0())
|
| 332 |
|
|
|
| 333 |
|
|
// Print a bool (for print/println).
|
| 334 |
|
|
DEF_GO_RUNTIME(PRINT_BOOL, "__go_print_bool", P1(BOOL), R0())
|
| 335 |
|
|
|
| 336 |
|
|
// Print a pointer/map/channel/function (for print/println).
|
| 337 |
|
|
DEF_GO_RUNTIME(PRINT_POINTER, "__go_print_pointer", P1(POINTER), R0())
|
| 338 |
|
|
|
| 339 |
|
|
// Print an empty interface (for print/println).
|
| 340 |
|
|
DEF_GO_RUNTIME(PRINT_EMPTY_INTERFACE, "__go_print_empty_interface",
|
| 341 |
|
|
P1(EFACE), R0())
|
| 342 |
|
|
|
| 343 |
|
|
// Print a non-empty interface (for print/println).
|
| 344 |
|
|
DEF_GO_RUNTIME(PRINT_INTERFACE, "__go_print_interface", P1(IFACE), R0())
|
| 345 |
|
|
|
| 346 |
|
|
// Print a slice (for print/println).
|
| 347 |
|
|
DEF_GO_RUNTIME(PRINT_SLICE, "__go_print_slice", P1(SLICE), R0())
|
| 348 |
|
|
|
| 349 |
|
|
// Print a space (for println).
|
| 350 |
|
|
DEF_GO_RUNTIME(PRINT_SPACE, "__go_print_space", P0(), R0())
|
| 351 |
|
|
|
| 352 |
|
|
// Print a newline (for println).
|
| 353 |
|
|
DEF_GO_RUNTIME(PRINT_NL, "__go_print_nl", P0(), R0())
|
| 354 |
|
|
|
| 355 |
|
|
|
| 356 |
|
|
// Remove helper macros.
|
| 357 |
|
|
#undef ABFT6
|
| 358 |
|
|
#undef ABFT2
|
| 359 |
|
|
#undef P0
|
| 360 |
|
|
#undef P1
|
| 361 |
|
|
#undef P2
|
| 362 |
|
|
#undef P3
|
| 363 |
|
|
#undef P4
|
| 364 |
|
|
#undef P5
|
| 365 |
|
|
#undef P6
|
| 366 |
|
|
#undef R0
|
| 367 |
|
|
#undef R1
|
| 368 |
|
|
#undef R2
|