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 / 问题 / 528461
Accepted
Kingsley
Kingsley
Asked: 2019-07-05 15:37:27 +0800 CST2019-07-05 15:37:27 +0800 CST 2019-07-05 15:37:27 +0800 CST

Solaris pstack 如何读取输出/输出格式

  • 772

我pstack在核心文件上有来自 Solaris 的输出。我不明白如何将日志中的数字映射到段错误时相关函数正在使用的参数。

输出中的数字似乎比函数调用的参数数量更多。哪些数字是参数值/地址?

该手册根本没有帮助。

 ...
 fffffffec993a8a8 sigacthandler (b, ffffffff7fffd5e0, ffffffff7fffd300, 14b7b0, fffffffec9a86000, b) + 5c
 --- called from signal handler with signal 11 (SIGSEGV) ---
 fffffffeba4422b0 XmMessageBoxGetChild (100400, 5, 5, 0, 118, fffffffeba62e000) + e4
 000000010026a83c GetMessageDialog (101317440, 0, ffffffff7fffe130, 100420, 100400, 127a94) + 214
 000000010026ab0c _XmtDisplayMessage (101317440, 0, 1000c9510, 1011927e5, ffffffff7fffe240, 101192780) + 278
 000000010026b048 XmtDisplayInformationMsg (1000c9000, 1000c9, 100000, 2, 0, ffffffff7fffe2f8) + 44
 00000001001573ec _smog_w_alarm_post_ack_actions (101314990, 101192760, 1003a0, 1009f4970, 101317440, 100000) + 100
 000000010015819c __select_cb (101314990, ffffffff7fffe560, 101317440, 10113bfc0, 1000916d0, 10120c9d0) + 1b4
 0000000100257a04 XmtCallCallback (101314990, 100257, ffffffff7fffe560, 101183530, 0, 0) + 3c4
 ...

我们所涉及的应用程序函数中仅有的两个是__select_cb()和_smog_w_alarm_post_ack_actions(),其他的是 Motif GUI/Widget 库调用。但是,看看我们的函数定义:

static void __select_cb( Widget w, XtPointer call_data );
void _smog_w_alarm_post_ack_actions( Widget w, Alarm_Public_Data *alarm );

每个函数只有两个参数。我希望其中一个Widget指针不正确(可能指向一个已经关闭的窗口)。我想知道这些数字中的哪些(如果有)映射到实际参数值/地址,以帮助调试问题。

solaris c
  • 1 1 个回答
  • 1279 Views

1 个回答

  • Voted
  1. Best Answer
    Andrew Henle
    2019-07-07T04:58:44+08:002019-07-07T04:58:44+08:00

    打印的函数参数pstack是“最佳猜测”努力,因为pstack()它不是完整的调试器,在某些情况下,即使是完整的调试器也不能保证在没有完整调试数据的情况下准确再现函数的参数。

    Solarispstack命令建立在提供进程控制和信息功能的libproc.so库之上。请参阅Illumospstack源代码,了解该实用程序如何使用函数pstack检索进程调用堆栈。Pstack_iter()

    根据注释部分:

    笔记

    确定每个帧的参数的数量和值,以及所有寄存器的值,在某种程度上是启发式的。因此,传递给函数的 、 和 参数中regs的argc值不能保证是正确的。argvcall-back()

    通常可以推断出参数是什么——你可以sigacthandler (b, ...在上面看到--- called from signal handler with signal 11 (SIGSEGV) ---。在这种情况下,十六进制b是十进制11- SIGSEGV。

    类似的值101314990可能是堆地址,类似的值ffffffff7fffe560可能是堆栈地址。您可以使用该pmap实用程序检查进程的地址空间以验证这些值。

    如果您需要更多确定性,请使用完整的调试器并使用调试符号进行编译。

    • 2

相关问题

  • Solaris 11:两个服务清单!我要一个

  • 我可以在不删除主目录的情况下对用户进行 userdel 吗?

  • 阻止损坏的 NFS 挂载锁定 solaris 11.3 中的目录?

  • 基于 OpenCV 的程序优化嵌入式 linux OS [关闭]

  • 在 Solaris 上;查找、附加到 tar 球并压缩问题

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