-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathtest_ioreport.m
123 lines (110 loc) · 5.74 KB
/
test_ioreport.m
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
#import <Foundation/Foundation.h>
enum {
kIOReportIterOk,
};
typedef struct IOReportSubscriptionRef* IOReportSubscriptionRef;
typedef CFDictionaryRef IOReportSampleRef;
extern IOReportSubscriptionRef IOReportCreateSubscription(void* a, CFMutableDictionaryRef desiredChannels, CFMutableDictionaryRef* subbedChannels, uint64_t channel_id, CFTypeRef b);
extern CFMutableDictionaryRef IOReportCopyChannelsInGroup(NSString*, NSString*, uint64_t, uint64_t, uint64_t);
extern CFMutableDictionaryRef IOReportCopyAllChannels(uint64_t, uint64_t);
extern int IOReportGetChannelCount(CFMutableDictionaryRef);
struct IOReporter_client_subscription;
extern CFDictionaryRef IOReportCreateSamples(IOReportSubscriptionRef iorsub, CFMutableDictionaryRef subbedChannels, CFTypeRef a);
typedef int (^ioreportiterateblock)(IOReportSampleRef ch);
extern void IOReportIterate(CFDictionaryRef samples, ioreportiterateblock);
extern int IOReportChannelGetFormat(CFDictionaryRef samples);
extern long IOReportSimpleGetIntegerValue(CFDictionaryRef, int);
extern NSString* IOReportChannelGetDriverName(CFDictionaryRef);
extern NSString* IOReportChannelGetChannelName(CFDictionaryRef);
extern int IOReportStateGetCount(CFDictionaryRef);
extern uint64_t IOReportStateGetResidency(CFDictionaryRef, int);
extern NSString* IOReportStateGetNameForIndex(CFDictionaryRef, int);
extern NSString* IOReportChannelGetUnitLabel(CFDictionaryRef);
extern NSString* IOReportChannelGetGroup(CFDictionaryRef);
extern NSString* IOReportChannelGetSubGroup(CFDictionaryRef);
extern NSString* IOReportSampleCopyDescription(CFDictionaryRef, int, int);
extern uint64_t IOReportArrayGetValueAtIndex(CFDictionaryRef, int);
extern int IOReportHistogramGetBucketCount(CFDictionaryRef);
extern int IOReportHistogramGetBucketMinValue(CFDictionaryRef, int);
extern int IOReportHistogramGetBucketMaxValue(CFDictionaryRef, int);
extern int IOReportHistogramGetBucketSum(CFDictionaryRef, int);
extern int IOReportHistogramGetBucketHits(CFDictionaryRef, int);
typedef uint8_t IOReportFormat;
enum {
kIOReportInvalidFormat = 0,
kIOReportFormatSimple = 1,
kIOReportFormatState = 2,
kIOReportFormatHistogram = 3,
kIOReportFormatSimpleArray = 4
};
int main(int argc, char* argv[])
{
CFMutableDictionaryRef channels;
if (argc >= 2) {
channels = IOReportCopyChannelsInGroup([NSString stringWithCString:argv[1] encoding:NSUTF8StringEncoding], 0x0, 0x0, 0x0, 0x0);
} else {
channels = IOReportCopyAllChannels(0x0, 0x0);
}
// int channel_count = IOReportGetChannelCount(channels);
CFMutableDictionaryRef subscribed_channels = NULL;
IOReportSubscriptionRef sub = IOReportCreateSubscription(NULL, channels, &subscribed_channels, 0, 0);
if (!sub) {
printf("cannot find any channel\n");
exit(-1);
}
NSLog(@"subscribed: %@", subscribed_channels);
CFDictionaryRef samples = NULL;
if ((samples = IOReportCreateSamples(sub, subscribed_channels, NULL))) {
IOReportIterate(samples, ^(IOReportSampleRef ch) {
NSString* driver_name = IOReportChannelGetDriverName(ch);
NSString* group = IOReportChannelGetGroup(ch);
NSString* subgroup = IOReportChannelGetSubGroup(ch);
NSString* channel_name = IOReportChannelGetChannelName(ch);
uint8_t report_format = IOReportChannelGetFormat(ch);
NSString* label = IOReportChannelGetUnitLabel(ch);
switch (report_format) {
case kIOReportFormatSimple: {
uint32_t value = IOReportSimpleGetIntegerValue(ch, 0);
NSLog(@"%@: %@: %@: %@: %u (%@)", driver_name, group, subgroup, channel_name, value, label);
} break;
case kIOReportFormatState: {
int state_count = IOReportStateGetCount(ch);
// NSLog(@"state count = %x", state_count);
for (int idx = 0; idx < state_count; idx++) {
NSString* state_name = IOReportStateGetNameForIndex(ch, idx);
uint64_t value = IOReportStateGetResidency(ch, idx);
NSLog(@"%@: %@: %@: %@: %@: %lld (%@)", driver_name, group, subgroup, channel_name, state_name, value, label);
}
} break;
case kIOReportFormatSimpleArray: {
// dunno where/how to get the number of elements of the array
// it seems this on is only used by CLPC per cluster info, so set it to 2
for (int idx = 0; idx < 2; idx++) {
uint64_t value = IOReportArrayGetValueAtIndex(ch, idx);
NSLog(@"%@: %@: %@: %@: %llu (%@)", driver_name, group, subgroup, channel_name, value, label);
}
} break;
case kIOReportFormatHistogram: {
int64_t hits, min, max, sum;
NSLog(@"%@: %@: %@: %@: (%@)", driver_name, group, subgroup, channel_name, label);
int bucket_count = IOReportHistogramGetBucketCount(ch);
NSLog(@"Bkt | hits min max sum\n");
for (int i = 0; i < bucket_count; i++) {
hits = IOReportHistogramGetBucketHits(ch, i);
min = IOReportHistogramGetBucketMinValue(ch, i);
max = IOReportHistogramGetBucketMaxValue(ch, i);
sum = IOReportHistogramGetBucketSum(ch, i);
NSLog(@"%3d | %4lld %3lld %3lld %3lld\n", i, hits, min, max, sum);
}
} break;
default:
NSLog(@"%@: %@: %@: (%@)", group, subgroup, channel_name, label);
NSLog(@"format = %hhx", report_format);
}
return kIOReportIterOk;
});
} else {
printf("Internal failure: Failed to get power state information\n");
}
exit(0);
}