Vim -p : SEGV 신호를 잡았습니까?


12

-p옵션으로 Vim을 시작할 때이 문제가 발생 합니다. 처음부터 시작했다고 가정 해 봅시다.

vim -p first.txt second.txt

그런 다음 편집 후 사용으로 first.txt이동합니다 . 나는 키 를 다시 누른다. 이 오류가 발생합니다second.txtgtggG

Vim: Caught deadly signal SEGV

이 시점에서 Vim은을 포함한 신호에 응답하지 않습니다 Ctrl D. 터미널을 종료해야만이 세션을 닫을 수 있습니다.

이 문제는 -p옵션으로 Vim을 호출 할 때만 발생합니다 . first.txt먼저 연 다음 open 을 사용 :tabe하면 second.txt이 문제가 발생하지 않습니다.

왜 이런 일이 발생할 수 있습니까?


출력 vim --version:

VIM - Vi IMproved 7.4 (2013 Aug 10, compiled Jan  2 2014 19:40:46)
Included patches: 1-52
Modified by pkg-vim-maintainers@lists.alioth.debian.org
Compiled by buildd@
Huge version with GTK2-GNOME GUI.  Features included (+) or not (-):
+acl             +farsi           +mouse_netterm   +syntax
+arabic          +file_in_path    +mouse_sgr       +tag_binary
+autocmd         +find_in_path    -mouse_sysmouse  +tag_old_static
+balloon_eval    +float           +mouse_urxvt     -tag_any_white
+browse          +folding         +mouse_xterm     +tcl
++builtin_terms  -footer          +multi_byte      +terminfo
+byte_offset     +fork()          +multi_lang      +termresponse
+cindent         +gettext         -mzscheme        +textobjects
+clientserver    -hangul_input    +netbeans_intg   +title
+clipboard       +iconv           +path_extra      +toolbar
+cmdline_compl   +insert_expand   +perl            +user_commands
+cmdline_hist    +jumplist        +persistent_undo +vertsplit
+cmdline_info    +keymap          +postscript      +virtualedit
+comments        +langmap         +printer         +visual
+conceal         +libcall         +profile         +visualextra
+cryptv          +linebreak       +python          +viminfo
+cscope          +lispindent      -python3         +vreplace
+cursorbind      +listcmds        +quickfix        +wildignore
+cursorshape     +localmap        +reltime         +wildmenu
+dialog_con_gui  +lua             +rightleft       +windows
+diff            +menu            +ruby            +writebackup
+digraphs        +mksession       +scrollbind      +X11
+dnd             +modify_fname    +signs           -xfontset
-ebcdic          +mouse           +smartindent     +xim
+emacs_tags      +mouseshape      -sniff           +xsmp_interact
+eval            +mouse_dec       +startuptime     +xterm_clipboard
+ex_extra        +mouse_gpm       +statusline      -xterm_save
+extra_search    -mouse_jsbterm   -sun_workshop    +xpm
   system vimrc file: "$VIM/vimrc"
     user vimrc file: "$HOME/.vimrc"
 2nd user vimrc file: "~/.vim/vimrc"
      user exrc file: "$HOME/.exrc"
  system gvimrc file: "$VIM/gvimrc"
    user gvimrc file: "$HOME/.gvimrc"
2nd user gvimrc file: "~/.vim/gvimrc"
    system menu file: "$VIMRUNTIME/menu.vim"
  fall-back for $VIM: "/usr/share/vim"
Compilation: gcc -c -I. -Iproto -DHAVE_CONFIG_H -DFEAT_GUI_GTK  -pthread -I/usr/include/gtk-2.0 -I/usr/lib/i386-linux-gnu/gtk-2.0/include -I/usr/include/atk-1.0 -I/usr/include/cairo -I/usr/include/gdk-pixbuf-2.0 -I/usr/include/pango-1.0 -I/usr/include/gio-unix-2.0/ -I/usr/include/freetype2 -I/usr/include/glib-2.0 -I/usr/lib/i386-linux-gnu/glib-2.0/include -I/usr/include/pixman-1 -I/usr/include/libpng12 -I/usr/include/harfbuzz   -pthread -DORBIT2=1 -D_REENTRANT -I/usr/include/libgnomeui-2.0 -I/usr/include/libart-2.0 -I/usr/include/gconf/2 -I/usr/include/gnome-keyring-1 -I/usr/include/libgnome-2.0 -I/usr/include/libbonoboui-2.0 -I/usr/include/libgnomecanvas-2.0 -I/usr/include/gtk-2.0 -I/usr/include/gdk-pixbuf-2.0 -I/usr/include/gnome-vfs-2.0 -I/usr/lib/i386-linux-gnu/gnome-vfs-2.0/include -I/usr/include/dbus-1.0 -I/usr/lib/i386-linux-gnu/dbus-1.0/include -I/usr/include/glib-2.0 -I/usr/lib/i386-linux-gnu/glib-2.0/include -I/usr/include/orbit-2.0 -I/usr/include/libbonobo-2.0 -I/usr/include/bonobo-activation-2.0 -I/usr/include/libxml2 -I/usr/include/pango-1.0 -I/usr/include/gail-1.0 -I/usr/include/harfbuzz -I/usr/include/freetype2 -I/usr/include/atk-1.0 -I/usr/lib/i386-linux-gnu/gtk-2.0/include -I/usr/include/cairo -I/usr/include/gio-unix-2.0/ -I/usr/include/pixman-1 -I/usr/include/libpng12     -g -O2 -fstack-protector --param=ssp-buffer-size=4 -Wformat -Werror=format-security -U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=1     -I/usr/include/tcl8.6  -D_REENTRANT=1  -D_THREAD_SAFE=1  -D_LARGEFILE64_SOURCE=1  
Linking: gcc   -L. -Wl,-Bsymbolic-functions -Wl,-z,relro -rdynamic -Wl,-export-dynamic -Wl,-E  -Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,--as-needed -o vim   -lgtk-x11-2.0 -lgdk-x11-2.0 -latk-1.0 -lgio-2.0 -lpangoft2-1.0 -lpangocairo-1.0 -lgdk_pixbuf-2.0 -lcairo -lpango-1.0 -lfontconfig -lgobject-2.0 -lglib-2.0 -lfreetype     -lgnomeui-2 -lSM -lICE -lbonoboui-2 -lgnomevfs-2 -lgnomecanvas-2 -lgnome-2 -lpopt -lbonobo-2 -lbonobo-activation -lORBit-2 -lart_lgpl_2 -lgtk-x11-2.0 -lgdk-x11-2.0 -latk-1.0 -lgio-2.0 -lpangoft2-1.0 -lpangocairo-1.0 -lgdk_pixbuf-2.0 -lcairo -lpango-1.0 -lfontconfig -lfreetype -lgconf-2 -lgthread-2.0 -lgmodule-2.0 -lgobject-2.0 -lglib-2.0   -lSM -lICE -lXpm -lXt -lX11 -lXdmcp -lSM -lICE  -lm -ltinfo -lnsl  -lselinux  -lacl -lattr -lgpm -ldl  -L/usr/lib -llua5.2 -Wl,-E  -fstack-protector -L/usr/local/lib  -L/usr/lib/perl/5.18/CORE -lperl -ldl -lm -lpthread -lcrypt -L/usr/lib/python2.7/config-i386-linux-gnu -lpython2.7 -lpthread -ldl -lutil -lm -Xlinker -export-dynamic -Wl,-O1 -Wl,-Bsymbolic-functions  -L/usr/lib/i386-linux-gnu -ltcl8.6 -ldl -lz -lpthread -lieee -lm -lruby-1.9.1 -lpthread -lrt -ldl -lcrypt -lm  -L/usr/lib   

출력 uname -a:

Linux nitish 3.13.0-45-generic #74-Ubuntu SMP Tue Jan 13 19:37:48 UTC 2015 i686 i686 i686 GNU/Linux

@Carpetsmoker의 의견을 바탕으로 문제가 내 .vimrc파일 때문이라는 것을 알았습니다 . 그래서 .vimrc파일의 일부가 주석 처리 된 명령을 실행하는 데 문제가 있는지 확인했습니다 . 마침내 나는 문제가 선에 있다는 것을 알았습니다.

set columns=1000

무고한 명령이 어떻게이 문제를 일으킬 수 있습니까? :help columns이것에 관한 유용한 정보를 제공하지 않았습니다.


2
어떤 vim (및 패치 레벨)을 사용하고 있습니까? (vim --version 출력과 같은) 그리고 어떤 OS? 그럼에도 불구하고 vim을 업데이트하는 것이 좋습니다. Mac을 사용 중이고 command-T와 같은 루비 플러그인을 사용하는 경우, 플러그인을 다시 설치하거나 vim이 rvm 루비가 아닌 시스템 루비를 사용하고 있는지 확인하십시오 (일부 사람들에게는 문제가 발생한 것으로 보입니다)
davidlowryduda

1
vim을 다음과 같이 시작할 수 있습니다 vim -u NONE -p first.txt second.txt. 이렇게하면 vimrc 파일이로드되지 않습니다.
Martin Tournoij

@hatter vim이 설치 또는 컴파일 되었습니까? 7.4로 업그레이드하여 도움이되는지 확인할 수 있습니다.
kenorb

@kenorb Vim이 설치되었습니다.
nitishch

@Carpetsmoker 그것은 일했다!! 이것이 .vimrc파일에 문제가 있음을 확실하게 지적합니까 ?
nitishch

답변:


6

segfault라고도하는 SEGV 신호는 거의 항상 실행중인 프로그램의 버그 (이 경우에는 vim) 때문입니다. (다른 원인은 하드웨어 결함 또는 한 번 푸른 달에 커널 버그와 같은 것입니다).

따라서 실제로 버그를보고해야합니다. :help bug-reports버그보고 방법에 대한 지침을 제공합니다. 문제를 재현하는 데 필요한 최소한의 단계가 이미있는 것처럼 들리므로 대부분의 작업이 필요합니다. 그래도 아직 최신 버전이 아닌지 확인하려면 Vim의 최신 버전을 먼저 테스트해야합니다.


Vim 7.4를 사용하고 있습니다. 공식 웹 사이트는 이것이 최신 버전이라고 말합니다.
nitishch

@hatter 사용 가능한 것보다 적은 수의 패치가 적용되었습니다.
derobert

그는 데비안을 운영하고있어서 다음과 같이 설명합니다 :-)
Martin Tournoij

@Carpetsmoker 데비안을 실행 중이고 패치 488을 통과했습니다 ... OP가 왜 오래된 지 잘 모르겠습니다. Wheezy (현재 릴리스)에는 7.3이 있으므로 OP는이를 사용하지 않습니다. 불안정, 제시하고, 위지 - 백 포트가 모두 7.4 패치 488.이 (주어를, 640은 그래서, 아직 다소 오래된 전류이다.)
derobert

3

세그먼테이션 오류로 인해 vim이 충돌하면 소프트웨어 버그 또는 하드웨어 문제로 인한 메모리 액세스 위반을 나타냅니다.

이 문제가 반복적으로 발생하면 다음을 순서대로 수행해야합니다.

  1. 를 실행하여 플러그인을 비활성화 vim -u NONE하고 도움이되는지 확인하십시오.
  2. vim을 최신 안정 버전으로 업그레이드하십시오.
  3. vim을 최신 개발 버전으로 업그레이드하십시오.
  4. 선택적으로 다른 컴퓨터에서 동일한 vim 버전을 다시 확인하십시오 (하드웨어 문제로 인해 발생할 수 있음).
  5. vim디버거 (예 : gdb vim:)에서 실행 하고 역 추적을 확인하십시오 (SEGV 이후 gdb: 유형 bt또는 bt full).
  6. 역 추적에 기호가 없으면 vim을 다시 컴파일하여 해당 기호를 포함시켜야합니다.
  7. 역 추적을 완료 한 경우 비슷한 문제를 확인하거나 vim의 버그 추적기 (일반 vim의 경우) 에서 새 버그를보고 하거나을 확인하십시오 :help bugs. 다른 버전의 vim (예 : gVim, MacVim, NeoVim)이있는 경우 올바른 관리자에게보고하십시오.

2
이것은 내 시스템에서만 발생합니다. 에서는 발생하지 않습니다 -u NONE. 선 보인다 set columns=1000에서가 .vimrc범인입니다.
nitishch

0

세그먼테이션 결함은 netbeans와 같은 상호 작용 서버에 연결될 수도 있고 구성 에서 다른 프로그램 (플러그인 ...)이 기대하는 (또는 유사한) autocmd버퍼 (예 : BufNewFile작업) 를 무효화하는 경우도 있습니다 (예 .vim:) .vimrc.

일반적인 오류 메시지는 다음과 같습니다.

missing ! or / in <number>:<command>

여기서 command할 수 있습니다 예를 들어,editFile

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.