AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题

问题[gdb](unix)

Martin Hope
CrunchySlime
Asked: 2024-04-09 22:22:58 +0800 CST

多个应用程序出现总线错误(核心转储)

  • 6

我的 endeavourOS 系统遇到奇怪的行为。

就上下文而言,它似乎是在格式错误的 svg 文件导致 inkscape 和我的系统崩溃之后开始发生的,之后我需要硬重启它。

对于几个应用程序(列出我测试过的最后几个应用程序:,,,flameshot) ,我在终端中收到了一条消息,仅此而已。通过一些谷歌搜索,我明白我需要使用,但我无法理解它的输出:keepassxcquiterssBus error (core dumped)gdb

$ gdb flameshot
[...]
For help, type "help".
Type "apropos word" to search for commands related to "word"...
Reading symbols from flameshot...

This GDB supports auto-downloading debuginfo from the following URLs:
  <https://debuginfod.archlinux.org>
Enable debuginfod for this session? (y or [n]) y
Debuginfod has been enabled.
To make this setting permanent, add 'set debuginfod enabled on' to .gdbinit.
Reading symbols from /home/user/.cache/debuginfod_client/b8258803335f21d12df1003c59200a5afb4dc585/debuginfo...                                                                                                                              

(gdb) run flameshot
Starting program: /usr/bin/flameshot flamshot
Downloading separate debug info for system-supplied DSO at 0x7ffff7fc6000                                                                                                                                                                 
Download failed: Connection reset by peer.  Continuing without separate debug info for system-supplied DSO at 0x7ffff7fc6000.                                                                                                             

Program received signal SIGBUS, Bus error.
memset () at ../sysdeps/x86_64/multiarch/../multiarch/memset-vec-unaligned-erms.S:244
244             VMOVU   %VMM(0), (%rdi)
                                                                                                                                                                                                   
(gdb) backtrace
#0  memset () at ../sysdeps/x86_64/multiarch/../multiarch/memset-vec-unaligned-erms.S:244
#1  0x00007ffff7fcf524 in _dl_map_segments (loader=0x7fffffffd300, has_holes=<optimized out>, maplength=<optimized out>, nloadcmds=<optimized out>, loadcmds=<optimized out>, type=<optimized out>, header=0x8, fd=<optimized out>, 
    l=0x7ffff7f89530) at ./dl-map-segments.h:176
#2  _dl_map_object_from_fd (name=name@entry=0x555555569361 "libQt5Widgets.so.5", origname=origname@entry=0x0, fd=<optimized out>, fbp=fbp@entry=0x7fffffffd3a0, realname=<optimized out>, loader=loader@entry=0x7ffff7ffe2e0, 
    l_type=<optimized out>, mode=<optimized out>, stack_endp=<optimized out>, nsid=<optimized out>) at dl-load.c:1258
#3  0x00007ffff7fd0b01 in _dl_map_object (loader=<optimized out>, name=0x555555569361 "libQt5Widgets.so.5", type=1, trace_mode=<optimized out>, mode=0, nsid=<optimized out>) at dl-load.c:2249
#4  0x00007ffff7fca865 in openaux (a=a@entry=0x7fffffffd950) at dl-deps.c:64
#5  0x00007ffff7fc94e1 in __GI__dl_catch_exception (exception=exception@entry=0x7fffffffd930, operate=operate@entry=0x7ffff7fca830 <openaux>, args=args@entry=0x7fffffffd950) at dl-catch.c:237
#6  0x00007ffff7fcacc5 in _dl_map_object_deps (map=map@entry=0x7ffff7ffe2e0, preloads=<optimized out>, npreloads=npreloads@entry=0, trace_mode=<optimized out>, open_mode=open_mode@entry=0) at dl-deps.c:232
#7  0x00007ffff7fe695e in dl_main (phdr=<optimized out>, phnum=<optimized out>, user_entry=<optimized out>, auxv=<optimized out>) at rtld.c:1965
#8  0x00007ffff7fe3583 in _dl_sysdep_start (start_argptr=start_argptr@entry=0x7fffffffe180, dl_main=dl_main@entry=0x7ffff7fe5040 <dl_main>) at ../sysdeps/unix/sysv/linux/dl-sysdep.c:140
#9  0x00007ffff7fe4d6e in _dl_start_final (arg=0x7fffffffe180) at rtld.c:494
#10 _dl_start (arg=0x7fffffffe180) at rtld.c:581
#11 0x00007ffff7fe3b68 in _start () from /lib64/ld-linux-x86-64.so.2
#12 0x0000000000000002 in ?? ()
#13 0x00007fffffffe58e in ?? ()
#14 0x00007fffffffe5a1 in ?? ()
#15 0x0000000000000000 in ?? ()
(gdb) 

编辑:完整回溯:https://pastebin.com/grMUQiWH

我现在该从哪里着手解决这个问题?

gdb
  • 1 个回答
  • 21 Views
Martin Hope
jian
Asked: 2023-08-20 16:04:55 +0800 CST

gdb 执行到特定函数

  • 5

https://git.postgresql.org/cgit/postgresql.git/tree/src/test/modules/delay_execution/delay_execution.c
https://stackoverflow.com/questions/11967440/stepping-into-specific-function-in -gdb

我加载了延迟执行模块。
然后gdb -p $proc
对 gdb 还很陌生。我可以让gdb直接执行到delay_execution_planner的开头吗?步骤很多,一步步按好像不太好。

gdb
  • 1 个回答
  • 13 Views
Martin Hope
KSroido
Asked: 2022-01-18 03:36:17 +0800 CST

调试符号在 Arch linux 上用于 gdb 调试的实际含义是什么?

  • 1

PS 英语不是我的母语;请原谅打字错误。

我(也许)了解动态链接中 ELF 文件中符号的基本主要思想。

参考教科书,如果我需要动态链接到 .so 或类似的东西,那么我需要链接目标的函数名称(比如说,如果我们只谈论函数)。然后加载器做一些事情来找到你的目标的真实位置。然后做其他事情来加载它。函数的名字是一些我们可以称之为符号的东西。

但是,在调试中,以下内容让我感到困惑。

我尝试在 Arch linux 上安装 pwndbg(GDB 插件)并遇到了一些问题。按照这些说明 [ 1 ] [ 2 ],我已经解决了这些问题。但不太明白解决方案是如何工作的。

解决方案提供者的发帖人,也是插件的作者说,Arch的glibc没有“调试符号”,需要手动安装,而Ubuntu的glibc有“调试符号”——不需要手动安装.

所以这里有一个问题真的让我很困惑。

  1. 为什么我可以为 lib安装符号,例如 glibc。如果 .so (ELF) 文件没有符号,则将符号放入其中。这将破坏 ELF 文件格式,因为 ELF 是基于文件相对偏移量的,不是吗?那么INSTALL实际上做了什么?或者在这种情况下实际上“符号”是什么意思?

  2. gcc -g(“gcc -g 生成 GDB 调试器使用的调试信息”)实际上生成了什么?它们(我安装的东西)是一样的吗?如果我需要“生成调试信息”,那么我必须需要源代码,对吗?

arch-linux gdb
  • 1 个回答
  • 367 Views
Martin Hope
cassepipe
Asked: 2021-09-23 05:13:14 +0800 CST

如何让 gdb 默认以 vi 模式启动?

  • 1

我知道我可以使用CTRL+ALT+Jingdb来获取 vim 键绑定,但我如何gdb在默认情况下以 vi 模式启动?

gdb vi-mode
  • 1 个回答
  • 122 Views
Martin Hope
Taekahn
Asked: 2019-08-06 08:36:39 +0800 CST

按信号过滤数百个核心转储

  • 0

如果我在一个目录中有数百个核心转储,并且想将其过滤到仅由特定信号生成的核心转储,而不必一次手动打开 GDB 中的每个核心转储,有没有办法做到这一点?

GDB 确实允许您通过 -ex 标志传递命令,但 GDB 的输出不会进入控制台,所以我不能只在所有文件上运行它并 grep 结果。

core-dump gdb
  • 1 个回答
  • 44 Views
Martin Hope
Maxim
Asked: 2019-03-15 08:43:28 +0800 CST

如何在 Debian 9 上为 gdb 启用 TUI?

  • 4

调试时,在装配时抢劫通常很有帮助,但在 Debian 9 上,当我尝试时,layout asm我得到:

Undefined command: "layout". Try "help".

根据一些互联网研究,我似乎需要启用 TUI,但我不确定如何启用或安装它。

debian gdb
  • 1 个回答
  • 2725 Views
Martin Hope
z.h.
Asked: 2019-01-07 00:06:09 +0800 CST

gdb-customize 命令,如何测试是否设置了变量?

  • 0

我正在使用 gdb 进行调试,需要定义一些辅助命令。基本上我希望我的自定义命令根据给定的参数数量以不同的方式运行。

所以我要测试是否$arg*给出,见下面的代码:

define pgdir

    set $pgdir = $arg0

    if ($arg1) {
        // show the corresponding PDE
    } else {
        // show the whole page directory
    }

end

是否可以测试变量是否为无效?

gdb
  • 3 个回答
  • 96 Views
Martin Hope
Matthijs Steen
Asked: 2018-11-15 13:15:56 +0800 CST

如何防止进程写入 systemd 日志?

  • 6

我正在使用第三方 .NET Core 应用程序(VS Code 扩展使用的二进制发行版),不幸的是,它启用了诊断日志记录,但没有明显的方法来禁用它(我已经向作者报告了这一点)。理想的解决方案(除了能够禁用它)是,如果我可以向 systemd 指定它不应该为该特定程序记录任何内容,但我一直无法找到任何方法来做到这一点。这是我到目前为止尝试的所有内容:

我尝试的第一件事是重定向stdout到: 。这确实禁用了任何正常输出,但诊断日志仍被写入 systemd 日志。stderr/dev/nulldotnet-app > /dev/null 2>&1

我希望应用程序有一个命令行参数,允许我禁用诊断日志记录。它确实有一个冗长的参数,但经过试验,它似乎只对正常输出产生影响,而不是诊断日志记录。

通过使用strace并查找对 的调用connect,我发现应用程序将诊断日志直接写入/dev/log.

该路径/dev/log是指向的符号链接/run/systemd/journal/dev-log,因此为了验证我的发现,我将符号链接更改为指向/dev/null。这确实阻止了诊断日志显示在 systemd 日志中。

我被告知LD_PRELOAD并制作了一个库,connect用我自己的版本替换了标准,在尝试连接到/dev/log. 这在我的测试程序中正常工作,但在 .NET Core 应用程序中失败,在 .NET Core 应用程序中失败connect ENOENT /tmp/CoreFxPipe_1ddf2df2725f40a68990c92cb4d1ff1e。我尝试了我的库,但即使我所做的只是直接将参数传递给标准connect函数,它仍然会失败并出现同样的错误。

然后我尝试使用 Linux 命名空间来制作它,以便仅/dev/log指向/dev/null.NET Core 应用程序:unshare --map-root-user --mount sh -c "mount --bind /dev/null /dev/log; dotnet-app $@". 这也因同样的错误而失败,即使它再次适用于我的测试程序。即使只是使用unshare --map-root-user --mount dotnet-app "$@"也会因错误而失败。

接下来,我尝试在应用程序运行时gdb关闭文件描述符。/dev/log这有效,但经过一段时间后它会重新打开它。我还尝试将文件描述符更改为指向,这也有效,但一段时间后/dev/null它也被重置为。/dev/log

我最后一次尝试是编写自己的 UNIX 套接字,它会过滤掉所有由 .NET Core 应用程序写入的内容。这确实有效,但我了解到 PID 与写入 UNIX 套接字的内容一起发送,因此传递给 systemd 日志的所有内容都会报告来自支持我的 UNIX 套接字的程序的 PID。

现在这个解决方案对我来说是可以接受的,因为在我的系统上几乎没有使用/dev/log,但我欢迎更好的解决方案。例如,我读到有可能将某些东西欺骗为 UNIX 套接字的 root,但我无法找到更多相关信息。

或者,如果有人可能对为什么两者都有任何见解,LD_PRELOAD并且unshare.NET Core 应用程序可能会失败,而他们对于写入的简单 C 测试程序工作正常/dev/log?

gdb systemd-journald
  • 1 个回答
  • 1532 Views
Martin Hope
Ciro Santilli OurBigBook.com
Asked: 2018-10-24 07:47:01 +0800 CST

如何从源代码构建 GDB 文档?

  • 4

我已经下载了 GDB 源代码:

git clone git://sourceware.org/git/binutils-gdb.git

现在如何从源代码生成文档,可以从以下网址下载:https ://sourceware.org/gdb/current/onlinedocs/ ?

我对 HTML 文档特别感兴趣,尤其是如果可以构建它的单页版本的话。

我在 GDB 大师 f47998d69f8d290564c022b010e63d5886a1fd7d 之后gdb-8.2-release。

gdb
  • 2 个回答
  • 492 Views
Martin Hope
Viesturs
Asked: 2018-07-15 05:38:17 +0800 CST

gdb 在一个命令中

  • 8

program当我使用参数调试可执行文件时arg1 arg2,gdb我执行以下序列

gdb
file ./program
run arg1 arg2
bt
quit

如何从 shell 脚本中的一个命令行执行相同的操作?

gdb
  • 3 个回答
  • 16686 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve