]>
Commit | Line | Data |
---|---|---|
2d21ac55 A |
1 | /* quick and dirty hack to grab credential backtrace info from kernel via sysctl. |
2 | * sysctl is only defined if xnu is built with DEBUG_CRED defined. | |
3 | * The current version of this is used to target a specific credential and gather | |
4 | * backtrace info on all references and unreferences. | |
5 | */ | |
6 | ||
7 | #include <stdio.h> | |
8 | #include <stdlib.h> | |
9 | #include <fcntl.h> | |
10 | #include <limits.h> | |
11 | #include <string.h> | |
12 | #include <errno.h> | |
13 | #include <unistd.h> | |
14 | #include <sys/stat.h> | |
15 | #include <sys/types.h> | |
16 | #include <sys/sysctl.h> | |
17 | #include <bsm/audit.h> | |
18 | ||
19 | /* bad! this is replicated in kern_credential.c. make sure they stay in sync! | |
0a7de745 | 20 | * Or better yet have commone header file? |
2d21ac55 A |
21 | */ |
22 | #define MAX_STACK_DEPTH 8 | |
23 | struct cred_backtrace { | |
0a7de745 A |
24 | int depth; |
25 | uint32_t stack[MAX_STACK_DEPTH]; | |
2d21ac55 A |
26 | }; |
27 | typedef struct cred_backtrace cred_backtrace; | |
28 | ||
29 | struct cred_debug_buffer { | |
0a7de745 A |
30 | int next_slot; |
31 | cred_backtrace stack_buffer[1]; | |
2d21ac55 A |
32 | }; |
33 | typedef struct cred_debug_buffer cred_debug_buffer; | |
34 | ||
35 | ||
36 | main( int argc, char *argv[] ) | |
37 | { | |
0a7de745 A |
38 | int err, i, j; |
39 | size_t len; | |
40 | char *my_bufferp = NULL; | |
41 | cred_debug_buffer *bt_buffp; | |
42 | cred_backtrace *btp; | |
2d21ac55 A |
43 | |
44 | /* get size of buffer we will need */ | |
45 | len = 0; | |
0a7de745 A |
46 | err = sysctlbyname( "kern.cred_bt", NULL, &len, NULL, 0 ); |
47 | if (err != 0) { | |
2d21ac55 | 48 | printf( "sysctl failed \n" ); |
0a7de745 | 49 | printf( "\terrno %d - \"%s\" \n", errno, strerror( errno )); |
2d21ac55 A |
50 | return; |
51 | } | |
0a7de745 | 52 | |
2d21ac55 A |
53 | /* get a buffer for our back traces */ |
54 | my_bufferp = malloc( len ); | |
0a7de745 A |
55 | if (my_bufferp == NULL) { |
56 | printf( "malloc error %d - \"%s\" \n", errno, strerror( errno )); | |
2d21ac55 A |
57 | return; |
58 | } | |
0a7de745 A |
59 | err = sysctlbyname( "kern.cred_bt", my_bufferp, &len, NULL, 0 ); |
60 | if (err != 0) { | |
2d21ac55 | 61 | printf( "sysctl 2 failed \n" ); |
0a7de745 | 62 | printf( "\terrno %d - \"%s\" \n", errno, strerror( errno )); |
2d21ac55 A |
63 | return; |
64 | } | |
65 | ||
66 | bt_buffp = (cred_debug_buffer *) my_bufferp; | |
0a7de745 A |
67 | btp = &bt_buffp->stack_buffer[0]; |
68 | ||
2d21ac55 | 69 | printf("number of traces %d \n", bt_buffp->next_slot); |
0a7de745 | 70 | for (i = 0; i < bt_buffp->next_slot; i++, btp++) { |
2d21ac55 | 71 | printf("[%d] ", i); |
0a7de745 A |
72 | for (j = 0; j < btp->depth; j++) { |
73 | printf("%p ", btp->stack[j]); | |
2d21ac55 A |
74 | } |
75 | printf("\n"); | |
76 | } | |
0a7de745 | 77 | |
2d21ac55 A |
78 | return; |
79 | } |