1 //===-- CodeGen/RuntimeLibcalls.h - Runtime Library Calls -------*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // This file defines the enum representing the list of runtime library calls
11 // the backend may emit during code generation, and also some helper functions.
13 //===----------------------------------------------------------------------===//
15 #ifndef LLVM_CODEGEN_RUNTIMELIBCALLS_H
16 #define LLVM_CODEGEN_RUNTIMELIBCALLS_H
18 #include "llvm/CodeGen/ValueTypes.h"
22 /// RTLIB::Libcall enum - This enum defines all of the runtime library calls
23 /// the backend can emit. The various long double types cannot be merged,
24 /// because 80-bit library functions use "xf" and 128-bit use "tf".
26 /// When adding PPCF128 functions here, note that their names generally need
27 /// to be overridden for Darwin with the xxx$LDBL128 form. See
28 /// PPCISelLowering.cpp.
248 FPTOSINT_PPCF128_I32,
249 FPTOSINT_PPCF128_I64,
250 FPTOSINT_PPCF128_I128,
263 FPTOUINT_PPCF128_I32,
264 FPTOUINT_PPCF128_I64,
265 FPTOUINT_PPCF128_I128,
270 SINTTOFP_I32_PPCF128,
275 SINTTOFP_I64_PPCF128,
280 SINTTOFP_I128_PPCF128,
285 UINTTOFP_I32_PPCF128,
290 UINTTOFP_I64_PPCF128,
295 UINTTOFP_I128_PPCF128,
336 // ELEMENT-WISE UNORDERED-ATOMIC MEMORY of different element sizes
337 MEMCPY_ELEMENT_UNORDERED_ATOMIC_1,
338 MEMCPY_ELEMENT_UNORDERED_ATOMIC_2,
339 MEMCPY_ELEMENT_UNORDERED_ATOMIC_4,
340 MEMCPY_ELEMENT_UNORDERED_ATOMIC_8,
341 MEMCPY_ELEMENT_UNORDERED_ATOMIC_16,
343 MEMMOVE_ELEMENT_UNORDERED_ATOMIC_1,
344 MEMMOVE_ELEMENT_UNORDERED_ATOMIC_2,
345 MEMMOVE_ELEMENT_UNORDERED_ATOMIC_4,
346 MEMMOVE_ELEMENT_UNORDERED_ATOMIC_8,
347 MEMMOVE_ELEMENT_UNORDERED_ATOMIC_16,
349 MEMSET_ELEMENT_UNORDERED_ATOMIC_1,
350 MEMSET_ELEMENT_UNORDERED_ATOMIC_2,
351 MEMSET_ELEMENT_UNORDERED_ATOMIC_4,
352 MEMSET_ELEMENT_UNORDERED_ATOMIC_8,
353 MEMSET_ELEMENT_UNORDERED_ATOMIC_16,
355 // EXCEPTION HANDLING
358 // Note: there's two sets of atomics libcalls; see
359 // <http://llvm.org/docs/Atomics.html> for more info on the
360 // difference between them.
362 // Atomic '__sync_*' libcalls.
363 SYNC_VAL_COMPARE_AND_SWAP_1,
364 SYNC_VAL_COMPARE_AND_SWAP_2,
365 SYNC_VAL_COMPARE_AND_SWAP_4,
366 SYNC_VAL_COMPARE_AND_SWAP_8,
367 SYNC_VAL_COMPARE_AND_SWAP_16,
368 SYNC_LOCK_TEST_AND_SET_1,
369 SYNC_LOCK_TEST_AND_SET_2,
370 SYNC_LOCK_TEST_AND_SET_4,
371 SYNC_LOCK_TEST_AND_SET_8,
372 SYNC_LOCK_TEST_AND_SET_16,
373 SYNC_FETCH_AND_ADD_1,
374 SYNC_FETCH_AND_ADD_2,
375 SYNC_FETCH_AND_ADD_4,
376 SYNC_FETCH_AND_ADD_8,
377 SYNC_FETCH_AND_ADD_16,
378 SYNC_FETCH_AND_SUB_1,
379 SYNC_FETCH_AND_SUB_2,
380 SYNC_FETCH_AND_SUB_4,
381 SYNC_FETCH_AND_SUB_8,
382 SYNC_FETCH_AND_SUB_16,
383 SYNC_FETCH_AND_AND_1,
384 SYNC_FETCH_AND_AND_2,
385 SYNC_FETCH_AND_AND_4,
386 SYNC_FETCH_AND_AND_8,
387 SYNC_FETCH_AND_AND_16,
392 SYNC_FETCH_AND_OR_16,
393 SYNC_FETCH_AND_XOR_1,
394 SYNC_FETCH_AND_XOR_2,
395 SYNC_FETCH_AND_XOR_4,
396 SYNC_FETCH_AND_XOR_8,
397 SYNC_FETCH_AND_XOR_16,
398 SYNC_FETCH_AND_NAND_1,
399 SYNC_FETCH_AND_NAND_2,
400 SYNC_FETCH_AND_NAND_4,
401 SYNC_FETCH_AND_NAND_8,
402 SYNC_FETCH_AND_NAND_16,
403 SYNC_FETCH_AND_MAX_1,
404 SYNC_FETCH_AND_MAX_2,
405 SYNC_FETCH_AND_MAX_4,
406 SYNC_FETCH_AND_MAX_8,
407 SYNC_FETCH_AND_MAX_16,
408 SYNC_FETCH_AND_UMAX_1,
409 SYNC_FETCH_AND_UMAX_2,
410 SYNC_FETCH_AND_UMAX_4,
411 SYNC_FETCH_AND_UMAX_8,
412 SYNC_FETCH_AND_UMAX_16,
413 SYNC_FETCH_AND_MIN_1,
414 SYNC_FETCH_AND_MIN_2,
415 SYNC_FETCH_AND_MIN_4,
416 SYNC_FETCH_AND_MIN_8,
417 SYNC_FETCH_AND_MIN_16,
418 SYNC_FETCH_AND_UMIN_1,
419 SYNC_FETCH_AND_UMIN_2,
420 SYNC_FETCH_AND_UMIN_4,
421 SYNC_FETCH_AND_UMIN_8,
422 SYNC_FETCH_AND_UMIN_16,
424 // Atomic '__atomic_*' libcalls.
446 ATOMIC_COMPARE_EXCHANGE,
447 ATOMIC_COMPARE_EXCHANGE_1,
448 ATOMIC_COMPARE_EXCHANGE_2,
449 ATOMIC_COMPARE_EXCHANGE_4,
450 ATOMIC_COMPARE_EXCHANGE_8,
451 ATOMIC_COMPARE_EXCHANGE_16,
487 ATOMIC_FETCH_NAND_16,
489 // Stack Protector Fail.
490 STACKPROTECTOR_CHECK_FAIL,
498 /// getFPEXT - Return the FPEXT_*_* value for the given types, or
499 /// UNKNOWN_LIBCALL if there is none.
500 Libcall getFPEXT(EVT OpVT, EVT RetVT);
502 /// getFPROUND - Return the FPROUND_*_* value for the given types, or
503 /// UNKNOWN_LIBCALL if there is none.
504 Libcall getFPROUND(EVT OpVT, EVT RetVT);
506 /// getFPTOSINT - Return the FPTOSINT_*_* value for the given types, or
507 /// UNKNOWN_LIBCALL if there is none.
508 Libcall getFPTOSINT(EVT OpVT, EVT RetVT);
510 /// getFPTOUINT - Return the FPTOUINT_*_* value for the given types, or
511 /// UNKNOWN_LIBCALL if there is none.
512 Libcall getFPTOUINT(EVT OpVT, EVT RetVT);
514 /// getSINTTOFP - Return the SINTTOFP_*_* value for the given types, or
515 /// UNKNOWN_LIBCALL if there is none.
516 Libcall getSINTTOFP(EVT OpVT, EVT RetVT);
518 /// getUINTTOFP - Return the UINTTOFP_*_* value for the given types, or
519 /// UNKNOWN_LIBCALL if there is none.
520 Libcall getUINTTOFP(EVT OpVT, EVT RetVT);
522 /// Return the SYNC_FETCH_AND_* value for the given opcode and type, or
523 /// UNKNOWN_LIBCALL if there is none.
524 Libcall getSYNC(unsigned Opc, MVT VT);
526 /// getMEMCPY_ELEMENT_UNORDERED_ATOMIC - Return
527 /// MEMCPY_ELEMENT_UNORDERED_ATOMIC_* value for the given element size or
528 /// UNKNOW_LIBCALL if there is none.
529 Libcall getMEMCPY_ELEMENT_UNORDERED_ATOMIC(uint64_t ElementSize);
531 /// getMEMMOVE_ELEMENT_UNORDERED_ATOMIC - Return
532 /// MEMMOVE_ELEMENT_UNORDERED_ATOMIC_* value for the given element size or
533 /// UNKNOW_LIBCALL if there is none.
534 Libcall getMEMMOVE_ELEMENT_UNORDERED_ATOMIC(uint64_t ElementSize);
536 /// getMEMSET_ELEMENT_UNORDERED_ATOMIC - Return
537 /// MEMSET_ELEMENT_UNORDERED_ATOMIC_* value for the given element size or
538 /// UNKNOW_LIBCALL if there is none.
539 Libcall getMEMSET_ELEMENT_UNORDERED_ATOMIC(uint64_t ElementSize);