#include "unwind.h" #include "thread.h" #include "session.h" #include "debug.h" #include "arch/common.h" struct unwind_libunwind_ops __weak *local_unwind_libunwind_ops; struct unwind_libunwind_ops __weak *x86_32_unwind_libunwind_ops; struct unwind_libunwind_ops __weak *arm64_unwind_libunwind_ops; static void unwind__register_ops(struct thread *thread, struct unwind_libunwind_ops *ops) { thread->unwind_libunwind_ops = ops; } int unwind__prepare_access(struct thread *thread, struct map *map, bool *initialized) { const char *arch; enum dso_type dso_type; struct unwind_libunwind_ops *ops = local_unwind_libunwind_ops; int err; if (thread->addr_space) { pr_debug("unwind: thread map already set, dso=%s\n", map->dso->name); if (initialized) *initialized = true; return 0; } /* env->arch is NULL for live-mode (i.e. perf top) */ if (!thread->mg->machine->env || !thread->mg->machine->env->arch) goto out_register; dso_type = dso__type(map->dso, thread->mg->machine); if (dso_type == DSO__TYPE_UNKNOWN) return 0; arch = normalize_arch(thread->mg->machine->env->arch); if (!strcmp(arch, "x86")) { if (dso_type != DSO__TYPE_64BIT) ops = x86_32_unwind_libunwind_ops; } else if (!strcmp(arch, "arm64") || !strcmp(arch, "arm")) { if (dso_type == DSO__TYPE_64BIT) ops = arm64_unwind_libunwind_ops; } if (!ops) { pr_err("unwind: target platform=%s is not supported\n", arch); return -1; } out_register: unwind__register_ops(thread, ops); err = thread->unwind_libunwind_ops->prepare_access(thread); if (initialized) *initialized = err ? false : true; return err; } void unwind__flush_access(struct thread *thread) { if (thread->unwind_libunwind_ops) thread->unwind_libunwind_ops->flush_access(thread); } void unwind__finish_access(struct thread *thread) { if (thread->unwind_libunwind_ops) thread->unwind_libunwind_ops->finish_access(thread); } int unwind__get_entries(unwind_entry_cb_t cb, void *arg, struct thread *thread, struct perf_sample *data, int max_stack) { if (thread->unwind_libunwind_ops) return thread->unwind_libunwind_ops->get_entries(cb, arg, thread, data, max_stack); return 0; } class='right' method='get' action='/cgit.cgi/linux/net-next.git/log/drivers/usb/host/hwa-hc.c'>
path: root/drivers/usb/host/hwa-hc.c
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2017-02-02 12:34:27 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2017-02-02 12:34:27 -0800
commitf2557779e1a9cfbf69c99b74da26cc1b2b10e752 (patch)
tree8ddca65c897199add553948c429072b8bd463692 /drivers/usb/host/hwa-hc.c
parent6d04dfc8966019b8b0977b2cb942351f13d2b178 (diff)
parent030305d69fc6963c16003f50d7e8d74b02d0a143 (diff)
Merge tag 'pci-v4.10-fixes-2' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci
Pull PCI fix from Bjorn Helgaas: "Configure ASPM on the link from a PCI-to-PCIe bridge (avoids a NULL pointer dereference on topologies including these bridges)" * tag 'pci-v4.10-fixes-2' of git://git.kernel.org/pub/scm/linux/kernel/git/helgaas/pci: PCI/ASPM: Handle PCI-to-PCIe bridges as roots of PCIe hierarchies
Diffstat (limited to 'drivers/usb/host/hwa-hc.c')