#undef TRACE_SYSTEM #define TRACE_SYSTEM sunvnet #if !defined(_TRACE_SUNVNET_H) || defined(TRACE_HEADER_MULTI_READ) #define _TRACE_SUNVNET_H #include TRACE_EVENT(vnet_rx_one, TP_PROTO(int lsid, int rsid, int index, int needs_ack), TP_ARGS(lsid, rsid, index, needs_ack), TP_STRUCT__entry( __field(int, lsid) __field(int, rsid) __field(int, index) __field(int, needs_ack) ), TP_fast_assign( __entry->lsid = lsid; __entry->rsid = rsid; __entry->index = index; __entry->needs_ack = needs_ack; ), TP_printk("(%x:%x) walk_rx_one index %d; needs_ack %d", __entry->lsid, __entry->rsid, __entry->index, __entry->needs_ack) ); DECLARE_EVENT_CLASS(vnet_tx_stopped_ack_template, TP_PROTO(int lsid, int rsid, int ack_end, int npkts), TP_ARGS(lsid, rsid, ack_end, npkts), TP_STRUCT__entry( __field(int, lsid) __field(int, rsid) __field(int, ack_end) __field(int, npkts) ), TP_fast_assign( __entry->lsid = lsid; __entry->rsid = rsid; __entry->ack_end = ack_end; __entry->npkts = npkts; ), TP_printk("(%x:%x) stopped ack for %d; npkts %d", __entry->lsid, __entry->rsid, __entry->ack_end, __entry->npkts) ); DEFINE_EVENT(vnet_tx_stopped_ack_template, vnet_tx_send_stopped_ack, TP_PROTO(int lsid, int rsid, int ack_end, int npkts), TP_ARGS(lsid, rsid, ack_end, npkts)); DEFINE_EVENT(vnet_tx_stopped_ack_template, vnet_tx_defer_stopped_ack, TP_PROTO(int lsid, int rsid, int ack_end, int npkts), TP_ARGS(lsid, rsid, ack_end, npkts)); DEFINE_EVENT(vnet_tx_stopped_ack_template, vnet_tx_pending_stopped_ack, TP_PROTO(int lsid, int rsid, int ack_end, int npkts), TP_ARGS(lsid, rsid, ack_end, npkts)); TRACE_EVENT(vnet_rx_stopped_ack, TP_PROTO(int lsid, int rsid, int end), TP_ARGS(lsid, rsid, end), TP_STRUCT__entry( __field(int, lsid) __field(int, rsid) __field(int, end) ), TP_fast_assign( __entry->lsid = lsid; __entry->rsid = rsid; __entry->end = end; ), TP_printk("(%x:%x) stopped ack for index %d", __entry->lsid, __entry->rsid, __entry->end) ); TRACE_EVENT(vnet_tx_trigger, TP_PROTO(int lsid, int rsid, int start, int err), TP_ARGS(lsid, rsid, start, err), TP_STRUCT__entry( __field(int, lsid) __field(int, rsid) __field(int, start) __field(int, err) ), TP_fast_assign( __entry->lsid = lsid; __entry->rsid = rsid; __entry->start = start; __entry->err = err; ), TP_printk("(%x:%x) Tx trigger for %d sent with err %d %s", __entry->lsid, __entry->rsid, __entry->start, __entry->err, __entry->err > 0 ? "(ok)" : " ") ); TRACE_EVENT(vnet_skip_tx_trigger, TP_PROTO(int lsid, int rsid, int last), TP_ARGS(lsid, rsid, last), TP_STRUCT__entry( __field(int, lsid) __field(int, rsid) __field(int, last) ), TP_fast_assign( __entry->lsid = lsid; __entry->rsid = rsid; __entry->last = last; ), TP_printk("(%x:%x) Skip Tx trigger. Last trigger sent was %d", __entry->lsid, __entry->rsid, __entry->last) ); #endif /* _TRACE_SOCK_H */ /* This part must be outside protection */ #include 5b11b24d8ff2b81366'>bnep/Kconfig
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2017-01-31 19:03:21 +0100
committerThomas Gleixner <tglx@linutronix.de>2017-01-31 20:22:18 +0100
commitaaaec6fc755447a1d056765b11b24d8ff2b81366 (patch)
treea7f4167960ee1df86739905b6ccdeb95465bfe5f /net/bluetooth/bnep/Kconfig
parent08d85f3ea99f1eeafc4e8507936190e86a16ee8c (diff)
x86/irq: Make irq activate operations symmetric
The recent commit which prevents double activation of interrupts unearthed interesting code in x86. The code (ab)uses irq_domain_activate_irq() to reconfigure an already activated interrupt. That trips over the prevention code now. Fix it by deactivating the interrupt before activating the new configuration. Fixes: 08d85f3ea99f1 "irqdomain: Avoid activating interrupts more than once" Reported-and-tested-by: Mike Galbraith <efault@gmx.de> Reported-and-tested-by: Borislav Petkov <bp@alien8.de> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Cc: Andrey Ryabinin <aryabinin@virtuozzo.com> Cc: Marc Zyngier <marc.zyngier@arm.com> Cc: stable@vger.kernel.org Link: http://lkml.kernel.org/r/alpine.DEB.2.20.1701311901580.3457@nanos
Diffstat (limited to 'net/bluetooth/bnep/Kconfig')