【问题标题】:grep -f on OS X produces segfaultOS X 上的 grep -f 产生段错误
【发布时间】:2013-06-19 06:53:52
【问题描述】:

如果你有 Mac,试试这个:

echo 'abcd*' > grepfile
echo 'abc$' >> grepfile
echo '^abc' >> grepfile
echo "fojeiwuroiuwet\nljfajsljkfabcdddjlfkajlkj\nabcaaa\nzzzabc\n" | grep -f grepfile

这是版本:

$ grep --v
grep (BSD grep) 2.5.1-FreeBSD

这是一台跟上 Apple 软件更新的机器(2012 版的 rMBP),所以我使用的是 10.8.4。

我验证了从源代码编译的 GNU grep 不会遇到这个问题。确实是 2.14 版本,这是 2.5.1 之后的一大堆版本。

但是,如果没有一些效率极低的循环为每个正则表达式派生一个 grep,那么如何才能完成针对一系列正则表达式测试某些输入的任务呢?

编辑:我解决这个问题的方法类似于:while read REGEX; do [[ ... =~ $REGEX ]] ... done < regexfile

问题:此版本的 grep 是否存在已知错误?我们如何设置我们的系统,以便它们能够与 grep 的正则表达式文件一起正常工作?

更新:看起来有些人报告它工作正常(即使使用这个特定的 FreeBSD 2.5.1 grep)。我可以采取哪些步骤来尝试找出它可能正在使用哪个 .so/.dylib?有人可以做一个shasum /usr/bin/grep 并告诉我它是否适合你吗? (我不确定这是否会提供很多信息,但我所追求的是我的计算机配置是否搞砸了,或者这是否是该版本软件的一些实际存在的问题。)

$ shasum /usr/bin/grep
eac59389d09642decbb8551e2c975f795934bfbf  /usr/bin/grep

这里有更多信息:

$ codesign -dvvv /usr/bin/grep
Executable=/usr/bin/grep
Identifier=com.apple.zgrep
Format=Mach-O thin (x86_64)
CodeDirectory v=20100 size=224 flags=0x0(none) hashes=6+2 location=embedded
Hash type=sha1 size=20
CDHash=93b823c000188f8737653d8333c90a6db9361d70
Signature size=4064
Authority=Software Signing
Authority=Apple Code Signing Certification Authority
Authority=Apple Root CA
Info.plist=not bound
Sealed Resources=none
Internal requirements count=2 size=208

进一步调查:

$ gdb /usr/bin/grep
GNU gdb 6.3.50-20050815 (Apple version gdb-1824) (Thu Nov 15 10:42:43 UTC 2012)
Copyright 2004 Free Software Foundation, Inc.
GDB is free software, covered by the GNU General Public License, and you are
welcome to change it and/or distribute copies of it under certain conditions.
Type "show copying" to see the conditions.
There is absolutely no warranty for GDB.  Type "show warranty" for details.
This GDB was configured as "x86_64-apple-darwin"...Reading symbols for shared libraries .... done

(gdb) start -f grepfile
Function "main" not defined.
Make breakpoint pending on future shared library load? (y or [n])
Starting program: /usr/bin/grep -f grepfile
Reading symbols for shared libraries +++.............................. done
abc
abc

Program received signal EXC_BAD_ACCESS, Could not access memory.
Reason: KERN_INVALID_ADDRESS at address: 0x0000000101000000
0x00007fff89b5d1b3 in memchr ()
(gdb) where
#0  0x00007fff89b5d1b3 in memchr ()
#1  0x00007fff89b8e45a in __sfvwrite ()
#2  0x00007fff89b8e861 in fwrite ()
#3  0x0000000100003138 in _mh_execute_header ()
#4  0x0000000100002988 in _mh_execute_header ()
#5  0x0000000100001c28 in _mh_execute_header ()
#6  0x00007fff8e2d57e1 in start ()
(gdb)

我也重新启动了机器。它在 gdb 中重复地做同样的事情。

【问题讨论】:

  • 然后我切换到我的 Macbook Air 并且它工作了,然后我检查并安装了自制 grep 2.14。我相信在我了解 ack 的那一天,我正在测试 grep 与 ack。所以这是在 Mac 上获得正确 grep 的另一种方法,使用自制软件。这有点可悲,因为我使用自制软件来获取 gettext 以便编译 grep,甚至没有首先检查 grep...
  • 对于过去的我已经找到的事情重新寻找答案很烦人。是酿造公式homebrew/dupes/grep
  • FWIW,您的示例对我来说适用于 OS X 10.8.4 附带的库存 Apple /usr/bin/grep(也是 2.5.1-FreeBSD)。
  • @NedDeily 很有趣。让我在另一台macbook上用2.5.1测试一下……
  • 这越来越有趣了。 macbook air(我认为是 2011 年中版本;它是 Sandy Bridge MBA)正在运行 Lion 10.7.5 并具有grep (GNU grep) 2.5.1,并且处理得也很好。那我一定是在这台机器上搞砸了??

标签: macos grep segmentation-fault freebsd bsd


【解决方案1】:

我在 MacBook Air 上安装了 OSX 10.8.4,您的示例默认情况下不会崩溃,但只有在添加 --color 参数时才会崩溃。

说明

当您将通配符(星号)与终端颜色混合时通常会发生这种崩溃,这是软件错误。

还可以查看另一个更简单的示例:

echo 'abc*' | grep --color=auto -e ".*" -e a

这里似乎--color=auto 有所不同(没有它或设置为never,它不会崩溃)。 所以我假设你的 grep 默认在终端中使用颜色。

解决方案

确保您的 grep 不是启用颜色的 grep 的别名,或者默认情况下未启用颜色。

您始终可以尝试使用 --color=never 运行 grep。

对于永久解决方案,我已报告错误报告:

http://www.freebsd.org/cgi/query-pr.cgi?pr=181263

所以问题可以在软件本身中解决。


如果您想访问更详细的崩溃日志,请转到控制台、显示日志列表并在用户诊断报告下找到崩溃日志。

例如:

Thread 0 Crashed:: Dispatch queue: com.apple.main-thread
0   libsystem_c.dylib               0x00007fff8a8da1b3 memchr + 15
1   libsystem_c.dylib               0x00007fff8a90b45a __sfvwrite + 578
2   libsystem_c.dylib               0x00007fff8a90b861 fwrite + 114
3   grep                            0x000000010a4a3138 0x10a4a0000 + 12600
4   grep                            0x000000010a4a2988 0x10a4a0000 + 10632
5   grep                            0x000000010a4a1c28 0x10a4a0000 + 7208
6   libdyld.dylib                   0x00007fff8daf77e1 start + 1

以下是有关崩溃的更详细说明:

A quick test

  $ env -i bsdgrep -Fi without_nls usr.bin/grep/grep.c
  $ env -i gnugrep -Fi without_nls usr.bin/grep/grep.c
  #ifndef WITHOUT_NLS
  #ifndef WITHOUT_NLS
  #ifndef WITHOUT_NLS

shows that bsd fgrep already fails to ignore case. And if you throw
a few more options to the mix it'd crash, e.g.

  $ env -i LC_CTYPE=en_US.UTF-8 TERM=xterm bsdgrep --color -Fir without_nls usr.bin/grep/
  [...]
  Program received signal SIGSEGV, Segmentation fault.
  0x0000000801007ff2 in memchr (s=0x61167a, c=10, n=18446744073707490297) at /usr/src/lib/libc/string/memchr.c:48
  48                              if (*p++ == (unsigned char)c)
  (gdb) bt
  #0  0x0000000801007ff2 in memchr (s=0x61167a, c=10, n=18446744073707490297) at /usr/src/lib/libc/string/memchr.c:48
  #1  0x0000000801007b03 in __sfvwrite (fp=0x801247770, uio=0x7fffffffd8f0) at /usr/src/lib/libc/stdio/fvwrite.c:170
  #2  0x0000000801007698 in fwrite (buf=0x608c03, size=18446744073709551606, count=1, fp=0x801247770)
      at /usr/src/lib/libc/stdio/fwrite.c:95
  #3  0x0000000000405498 in printline (line=0x7fffffffdb70, sep=58, matches=0x7fffffffd990, m=9)
      at /usr/src/usr.bin/grep/util.c:500
  #4  0x0000000000404f51 in procline (l=0x7fffffffdb70, nottext=0) at /usr/src/usr.bin/grep/util.c:381
  #5  0x000000000040489f in procfile (fn=0x80140b600 "usr.bin/grep/nls/es_ES.ISO8859-1.msg") at /usr/src/usr.bin/grep/util.c:239
  #6  0x00000000004044d7 in grep_tree (argv=0x7fffffffdd30) at /usr/src/usr.bin/grep/util.c:163
  #7  0x0000000000403ea9 in main (argc=5, argv=0x7fffffffdd10) at /usr/src/usr.bin/grep/grep.c:689

来源:http://lists.freebsd.org/pipermail/freebsd-current/2011-August/026502.html


即使版本相同,在不同的 OSX 上似乎也有不同的 grep 二进制文件:

$ grep --v
grep (BSD grep) 2.5.1-FreeBSD
$ shasum /usr/bin/grep
350ee11e1868e18c9707ea7035184a114f40badf  /usr/bin/grep
$ codesign -dvvv /usr/bin/grep
Executable=/usr/bin/grep
Identifier=com.apple.zgrep
Format=Mach-O thin (x86_64)
CodeDirectory v=20100 size=224 flags=0x0(none) hashes=6+2 location=embedded
Hash type=sha1 size=20
CDHash=1537b3ed49878d5d18482859a37318164a2a40f1
Signature size=4064
Authority=Software Signing
Authority=Apple Code Signing Certification Authority
Authority=Apple Root CA
Info.plist=not bound
Sealed Resources=none
Internal requirements count=2 size=176

【讨论】:

  • 嘿,感谢您深入研究这个!我不确定我是否将它别名为显示颜色,但我绝对更喜欢有颜色(当然脚本不需要它)。我相信它没有别名,但会默认使用颜色。希望在脚本中使用它时(应该让它智能地禁用颜色)它不会遇到问题!
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2011-11-13
  • 1970-01-01
  • 1970-01-01
  • 2015-06-22
  • 1970-01-01
  • 2013-11-02
  • 1970-01-01
相关资源
最近更新 更多