// RUN: llvm-tblgen -gen-runtime-libcalls -I %p/../../include %s | FileCheck %s include "llvm/IR/RuntimeLibcallsImpl.td" def SDIVREM_I8 : RuntimeLibcall; def UDIVREM_I16 : RuntimeLibcall; def MALLOC : RuntimeLibcall; def TARGET_OVERRIDE_CC : RuntimeLibcall; def __divmodqi4 : RuntimeLibcallImpl; def __udivmodhi4 : RuntimeLibcallImpl; // Test a case where a target wants to set a different calling // convention on a generic builtin def __target_override_cc : RuntimeLibcallImpl; def malloc : RuntimeLibcallImpl; def isAVR : RuntimeLibcallPredicate<[{TT.getArch() == Triple::avr}]>; def isAVRHurd : RuntimeLibcallPredicate< [{TT.getArch() == Triple::avr && TT.isOSHurd()}]>; def AVRLibrary : SystemRuntimeLibrary) >; // Test with default calling convention def AVRHurdLibrary : SystemRuntimeLibrary)> { let DefaultLibcallCallingConv = LibcallCallingConv<[{isFoo() ? CallingConv::Fast : CallingConv::GHC}]>; } def isMSP430 : RuntimeLibcallPredicate<[{TT.getArch() == Triple::msp430}]>; def MSP430LibraryWithCondCC : SystemRuntimeLibrary>, LibcallsWithCC<(add __udivmodhi4), MSP430_BUILTIN, RuntimeLibcallPredicate<[{ isBar() }]>>) >; // CHECK: void llvm::RTLIB::RuntimeLibcallsInfo::setTargetRuntimeLibcallSets(const llvm::Triple &TT, ExceptionHandling ExceptionModel, FloatABI::ABIType FloatABI, EABI EABIVersion, StringRef ABIName) { // CHECK: if (TT.getArch() == Triple::avr && TT.isOSHurd()) { // CHECK-NEXT: const CallingConv::ID DefaultCC = isFoo() ? CallingConv::Fast : CallingConv::GHC; // CHECK-NEXT: for (CallingConv::ID &Entry : LibcallImplCallingConvs) { // CHECK-NEXT: Entry = DefaultCC; // CHECK-NEXT: } // CHECK-EMPTY: // CHECK-NEXT: setLibcallsImpl({ // CHECK-NEXT: {RTLIB::MALLOC, RTLIB::malloc}, // malloc // CHECK-NEXT: }); // CHECK-EMPTY: // CHECK-NEXT: setLibcallsImpl({ // CHECK-NEXT: {RTLIB::SDIVREM_I8, RTLIB::__divmodqi4}, // __divmodqi4 // CHECK-NEXT: {RTLIB::UDIVREM_I16, RTLIB::__udivmodhi4}, // __udivmodhi4 // CHECK-NEXT: }, CallingConv::AVR_BUILTIN); // CHECK-EMPTY: // CHECK-NEXT: return; // CHECK-NEXT: } // CHECK-EMPTY: // CHECK-NEXT: if (TT.getArch() == Triple::avr) { // CHECK-NEXT: setLibcallsImpl({ // CHECK-NEXT: {RTLIB::MALLOC, RTLIB::malloc}, // malloc // CHECK-NEXT: }); // CHECK-EMPTY: // CHECK-NEXT: setLibcallsImpl({ // CHECK-NEXT: {RTLIB::SDIVREM_I8, RTLIB::__divmodqi4}, // __divmodqi4 // CHECK-NEXT: {RTLIB::UDIVREM_I16, RTLIB::__udivmodhi4}, // __udivmodhi4 // CHECK-NEXT: }, CallingConv::AVR_BUILTIN); // CHECK-EMPTY: // CHECK-NEXT: return; // CHECK-NEXT: } // CHECK-EMPTY: // CHECK-NEXT: if (TT.getArch() == Triple::msp430) { // CHECK-NEXT: setLibcallsImpl({ // CHECK-NEXT: {RTLIB::MALLOC, RTLIB::malloc}, // malloc // CHECK-NEXT: }); // CHECK-EMPTY: // CHECK-NEXT: if ( isFoo() ) { // CHECK-NEXT: setLibcallsImpl({ // CHECK-NEXT: {RTLIB::SDIVREM_I8, RTLIB::__divmodqi4}, // __divmodqi4 // CHECK-NEXT: }, CallingConv::AVR_BUILTIN); // CHECK-EMPTY: // CHECK-NEXT: } // CHECK-EMPTY: // CHECK-NEXT: if ( isBar() ) { // CHECK-NEXT: setLibcallsImpl({ // CHECK-NEXT: {RTLIB::UDIVREM_I16, RTLIB::__udivmodhi4}, // __udivmodhi4 // CHECK-NEXT: }, CallingConv::MSP430_BUILTIN); // CHECK-EMPTY: // CHECK-NEXT: } // CHECK-EMPTY: // CHECK-NEXT: return; // CHECK-NEXT: }