2016-11-17 05:58:04 +08:00
|
|
|
; RUN: llc < %s -march=avr | FileCheck %s
|
|
|
|
|
|
|
|
define avr_intrcc void @interrupt_handler() {
|
|
|
|
; CHECK-LABEL: interrupt_handler:
|
|
|
|
; CHECK: sei
|
|
|
|
; CHECK-NEXT: push r0
|
|
|
|
; CHECK-NEXT: push r1
|
|
|
|
; CHECK-NEXT: in r0, 63
|
|
|
|
; CHECK-NEXT: push r0
|
2017-11-24 23:36:43 +08:00
|
|
|
; CHECK: clr r0
|
2016-11-17 05:58:04 +08:00
|
|
|
; CHECK: pop r0
|
|
|
|
; CHECK-NEXT: out 63, r0
|
|
|
|
; CHECK-NEXT: pop r1
|
|
|
|
; CHECK-NEXT: pop r0
|
|
|
|
; CHECK-NEXT: reti
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2020-03-31 14:00:18 +08:00
|
|
|
define void @interrupt_handler_via_ir_attribute() #0 {
|
|
|
|
; CHECK-LABEL: interrupt_handler_via_ir_attribute:
|
|
|
|
; CHECK: sei
|
|
|
|
; CHECK-NEXT: push r0
|
|
|
|
; CHECK-NEXT: push r1
|
|
|
|
; CHECK-NEXT: in r0, 63
|
|
|
|
; CHECK-NEXT: push r0
|
|
|
|
; CHECK: clr r0
|
|
|
|
; CHECK: pop r0
|
|
|
|
; CHECK-NEXT: out 63, r0
|
|
|
|
; CHECK-NEXT: pop r1
|
|
|
|
; CHECK-NEXT: pop r0
|
|
|
|
; CHECK-NEXT: reti
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2016-11-17 05:58:04 +08:00
|
|
|
define avr_signalcc void @signal_handler() {
|
|
|
|
; CHECK-LABEL: signal_handler:
|
|
|
|
; CHECK-NOT: sei
|
|
|
|
; CHECK: push r0
|
|
|
|
; CHECK-NEXT: push r1
|
|
|
|
; CHECK-NEXT: in r0, 63
|
|
|
|
; CHECK-NEXT: push r0
|
2017-11-24 23:36:43 +08:00
|
|
|
; CHECK: clr r0
|
2016-11-17 05:58:04 +08:00
|
|
|
; CHECK: pop r0
|
|
|
|
; CHECK-NEXT: out 63, r0
|
|
|
|
; CHECK-NEXT: pop r1
|
|
|
|
; CHECK-NEXT: pop r0
|
|
|
|
; CHECK-NEXT: reti
|
|
|
|
ret void
|
|
|
|
}
|
2020-03-31 14:00:18 +08:00
|
|
|
|
2020-03-31 14:28:01 +08:00
|
|
|
define void @signal_handler_via_attribute() #1 {
|
|
|
|
; CHECK-LABEL: signal_handler_via_attribute:
|
|
|
|
; CHECK-NOT: sei
|
|
|
|
; CHECK: push r0
|
|
|
|
; CHECK-NEXT: push r1
|
|
|
|
; CHECK-NEXT: in r0, 63
|
|
|
|
; CHECK-NEXT: push r0
|
|
|
|
; CHECK: clr r0
|
|
|
|
; CHECK: pop r0
|
|
|
|
; CHECK-NEXT: out 63, r0
|
|
|
|
; CHECK-NEXT: pop r1
|
|
|
|
; CHECK-NEXT: pop r0
|
|
|
|
; CHECK-NEXT: reti
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
2020-03-31 14:00:18 +08:00
|
|
|
attributes #0 = { "interrupt" }
|
|
|
|
attributes #1 = { "signal" }
|