-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathaccess.c
91 lines (81 loc) · 2.51 KB
/
access.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
/**
* Loco program runner core
* Copyright (C) 2011 Lodevil(Du Jiong)
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "access.h"
#include <sys/syscall.h>
#include <sys/ptrace.h>
#include <fcntl.h>
#include <string.h>
int fileAccess(PyObject *files, const char *file, long flags) {
PyObject *perm_obj;
long perm;
if ((perm_obj = PyDict_GetItemString(files, file)) == NULL) {
return 0;
}
//printf("%s:%d\n",file,flags);
perm = PyInt_AsLong(perm_obj);
if (perm == flags)
return 1;
return 0;
}
static long file_temp[100];
int checkAccess(struct Runobj *runobj, int pid, struct user_regs_struct *regs) {
#if __WORDSIZE == 64
if (!runobj->inttable[regs->orig_rax])
#else
if (!runobj->inttable[regs->orig_eax])
#endif
return ACCESS_CALL_ERR;
#if __WORDSIZE == 64
switch (regs->orig_rax)
#else
switch (regs->orig_eax)
#endif
{
case SYS_open: {
int i, j;
for (i = 0; i < 100; i++) {
#if __WORDSIZE == 64
long t = ptrace(PTRACE_PEEKDATA, pid,
regs->rdi + i * sizeof(long), NULL);
#else
long t = ptrace(PTRACE_PEEKDATA, pid, regs->ebx + i*sizeof(long), NULL);
#endif
file_temp[i] = t;
const char* test = (const char*) &file_temp[i];
for (j = 0; j < sizeof(long); j++) {
if (!test[j]) {
goto l_cont;
}
}
}
l_cont: file_temp[99] = 0;
#if __WORDSIZE == 64
if (fileAccess(runobj->files, (const char *) file_temp, regs->rsi))
#else
if(fileAccess(runobj->files, (const char *)file_temp, regs->ecx))
#endif
return ACCESS_OK;
return ACCESS_FILE_ERR;
}
}
return ACCESS_OK;
}
const char* lastFileAccess(void) {
file_temp[99] = 0;
return (const char*) file_temp;
}