/* * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License, version 2, as * published by the Free Software Foundation. * * Copyright (C) 2015 Naveen N. Rao, IBM Corporation */ #include "debug.h" #include "symbol.h" #include "map.h" #include "probe-event.h" #ifdef HAVE_LIBELF_SUPPORT bool elf__needs_adjust_symbols(GElf_Ehdr ehdr) { return ehdr.e_type == ET_EXEC || ehdr.e_type == ET_REL || ehdr.e_type == ET_DYN; } #endif #if !defined(_CALL_ELF) || _CALL_ELF != 2 int arch__choose_best_symbol(struct symbol *syma, struct symbol *symb __maybe_unused) { char *sym = syma->name; /* Skip over any initial dot */ if (*sym == '.') sym++; /* Avoid "SyS" kernel syscall aliases */ if (strlen(sym) >= 3 && !strncmp(sym, "SyS", 3)) return SYMBOL_B; if (strlen(sym) >= 10 && !strncmp(sym, "compat_SyS", 10)) return SYMBOL_B; return SYMBOL_A; } /* Allow matching against dot variants */ int arch__compare_symbol_names(const char *namea, const char *nameb) { /* Skip over initial dot */ if (*namea == '.') namea++; if (*nameb == '.') nameb++; return strcmp(namea, nameb); } #endif #if defined(_CALL_ELF) && _CALL_ELF == 2 #ifdef HAVE_LIBELF_SUPPORT void arch__sym_update(struct symbol *s, GElf_Sym *sym) { s->arch_sym = sym->st_other; } #endif #define PPC64LE_LEP_OFFSET 8 void arch__fix_tev_from_maps(struct perf_probe_event *pev, struct probe_trace_event *tev, struct map *map, struct symbol *sym) { int lep_offset; /* * When probing at a function entry point, we normally always want the * LEP since that catches calls to the function through both the GEP and * the LEP. Hence, we would like to probe at an offset of 8 bytes if * the user only specified the function entry. * * However, if the user specifies an offset, we fall back to using the * GEP since all userspace applications (objdump/readelf) show function * disassembly with offsets from the GEP. * * In addition, we shouldn't specify an offset for kretprobes. */ if (pev->point.offset || (!pev->uprobes && pev->point.retprobe) || !map || !sym) return; lep_offset = PPC64_LOCAL_ENTRY_OFFSET(sym->arch_sym); if (map->dso->symtab_type == DSO_BINARY_TYPE__KALLSYMS) tev->point.offset += PPC64LE_LEP_OFFSET; else if (lep_offset) { if (pev->uprobes) tev->point.address += lep_offset; else tev->point.offset += lep_offset; } } #ifdef HAVE_LIBELF_SUPPORT void arch__post_process_probe_trace_events(struct perf_probe_event *pev, int ntevs) { struct probe_trace_event *tev; struct map *map; struct symbol *sym = NULL; struct rb_node *tmp; int i = 0; map = get_target_map(pev->target, pev->uprobes); if (!map || map__load(map) < 0) return; for (i = 0; i < ntevs; i++) { tev = &pev->tevs[i]; map__for_each_symbol(map, sym, tmp) { if (map->unmap_ip(map, sym->start) == tev->point.address) arch__fix_tev_from_maps(pev, tev, map, sym); } } } #endif /* HAVE_LIBELF_SUPPORT */ #endif 09'/><table><tr><td colspan='2'/></tr><tr><td class='label'>context:</td><td class='ctrl'><select name='context' onchange='this.form.submit();'><option value='1'>1</option><option value='2'>2</option><option value='3' selected='selected'>3</option><option value='4'>4</option><option value='5'>5</option><option value='6'>6</option><option value='7'>7</option><option value='8'>8</option><option value='9'>9</option><option value='10'>10</option><option value='15'>15</option><option value='20'>20</option><option value='25'>25</option><option value='30'>30</option><option value='35'>35</option><option value='40'>40</option></select></td></tr><tr><td class='label'>space:</td><td class='ctrl'><select name='ignorews' onchange='this.form.submit();'><option value='0' selected='selected'>include</option><option value='1'>ignore</option></select></td></tr><tr><td class='label'>mode:</td><td class='ctrl'><select name='dt' onchange='this.form.submit();'><option value='0' selected='selected'>unified</option><option value='1'>ssdiff</option><option value='2'>stat only</option></select></td></tr><tr><td/><td class='ctrl'><noscript><input type='submit' value='reload'/></noscript></td></tr></table></form></div><table summary='commit info' class='commit-info'> <tr><th>author</th><td>Christophe JAILLET <christophe.jaillet@wanadoo.fr></td><td class='right'>2017-01-31 00:47:30 -0800</td></tr> <tr><th>committer</th><td>Dmitry Torokhov <dmitry.torokhov@gmail.com></td><td class='right'>2017-01-31 00:51:06 -0800</td></tr> <tr><th>commit</th><td colspan='2' class='oid'><a href='/cgit.cgi/linux/net-next.git/commit/net/ipv6?id=05e0be7c900797e9164976a6014d534ce3035909'>05e0be7c900797e9164976a6014d534ce3035909</a> (<a href='/cgit.cgi/linux/net-next.git/patch/net/ipv6?id=05e0be7c900797e9164976a6014d534ce3035909'>patch</a>)</td></tr> <tr><th>tree</th><td colspan='2' class='oid'><a href='/cgit.cgi/linux/net-next.git/tree/?id=05e0be7c900797e9164976a6014d534ce3035909'>6064ddf732b21c686c958cb9da73f6eae6de5a27</a> /<a href='/cgit.cgi/linux/net-next.git/tree/net/ipv6?id=05e0be7c900797e9164976a6014d534ce3035909'>net/ipv6</a></td></tr> <tr><th>parent</th><td colspan='2' class='oid'><a href='/cgit.cgi/linux/net-next.git/commit/net/ipv6?id=3f5c34c6d4688b3b7e1dbc7bbc68a2f03a0d6b0c'>3f5c34c6d4688b3b7e1dbc7bbc68a2f03a0d6b0c</a> (<a href='/cgit.cgi/linux/net-next.git/diff/net/ipv6?id=05e0be7c900797e9164976a6014d534ce3035909&id2=3f5c34c6d4688b3b7e1dbc7bbc68a2f03a0d6b0c'>diff</a>)</td></tr></table> <div class='commit-subject'>Input: synaptics-rmi4 - fix reversed conditions in enable/disable_irq_wake</div><div class='commit-msg'>These tests are reversed. A warning should be displayed if an error is returned, not on success. Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr> Reviewed-by: Benjamin Tissoires <benjamin.tissoires@redhat.com> Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com></div><div class='diffstat-header'><a href='/cgit.cgi/linux/net-next.git/diff/?id=05e0be7c900797e9164976a6014d534ce3035909'>Diffstat</a> (limited to 'net/ipv6')</div><table summary='diffstat' class='diffstat'>