私のプログラム:DTraceが無効アドレスエラーを発生させる理由は何ですか?
typedef struct objc_class {
struct objc_class *isa;
struct objc_class *super_class;
char *name;
long version;
long info;
long instance_size;
void *ivars;
void *methodLists;
void *cache;
void *protocols;
} *Class;
struct objc_object {
Class isa;
};
/* Code to extract the class name from arg0 based on a snippet by Bill Bumgarner: http://friday.com/bbum/2008/01/26/objective-c-printing-class-name-from-dtrace/ */
objc$target:NSObject:-init:entry {
printf("time: %llu\n", timestamp);
printf("arg0: %p\n", arg0);
obj = (struct objc_object *)copyin(arg0, sizeof(struct objc_object));
printf("obj: %p\n", obj);
printf("obj->isa: %p\n", obj->isa);
isa = (Class)copyin((user_addr_t)obj->isa, sizeof(struct objc_class));
printf("isa: %p\n", obj->isa);
classname = copyinstr((user_addr_t)(isa->name));
printf("classname: %s\n", classname);
}
いくつかの出力:
dtrace: script 'test.d' matched 1 probe
dtrace: error on enabled probe ID 1 (ID 61630: objc5936:NSObject:-init:entry): invalid address (0x90206b98) in action #8 at DIF offset 28
dtrace: error on enabled probe ID 1 (ID 61630: objc5936:NSObject:-init:entry): invalid address (0x90206b98) in action #8 at DIF offset 28
dtrace: error on enabled probe ID 1 (ID 61630: objc5936:NSObject:-init:entry): invalid address (0x90206b98) in action #8 at DIF offset 28
CPU ID FUNCTION:NAME
0 61630 -init:entry time: 28391086668386
arg0: 1291ae10
obj: 6f0a1158
obj->isa: a023f360
isa: a023f360
classname: NSBitmapImageRep
1 61630 -init:entry time: 28391586872297
arg0: 12943560
obj: 6f4a1158
obj->isa: 2fca0
isa: 2fca0
classname: GrowlApplicationTicket
1 61630 -init:entry time: 28391586897807
arg0: 152060
obj: 6f4a1280
obj->isa: 2fe20
isa: 2fe20
classname: GrowlNotificationTicket
2 61630 -init:entry time: 28391079142905
arg0: 129482d0
obj: 700a1128
obj->isa: a0014140
isa: a0014140
classname: NSDistributedObjectsStatistics
2 61630 -init:entry time: 28391079252640
arg0: 147840
obj: 700a1250
obj->isa: a0014780
isa: a0014780
classname: NSDistantObjectTableEntry
なぜエラー?それはクラス名(それは唯一の%s
だと私はそれを削除する場合はエラーが表示されません)が、なぜそれはいくつかのクラスの名前が無効なポインタだと思いますか?
私のDTraceプログラムのどの行が問題を引き起こしたかを実際に教えてくれるエラーメッセージを表示する方法はありますか?
この構造検査ダンスの代わりにobject_getClassName
に電話する方法はありますか?
私はトレースしているプログラムがうまくいけばクラッシュすることはないので、クラスが本当に壊れているとは思わない。
私はこの最後の夜について考えました。 DTraceの設計は、カーネル内で実行される「コード」の量を最小限に抑え、できるだけ「安全」な状態に保ちます。 シンボル名の解決はカーネルの外側で行われます。カーネルはアドレスをバッファに記録するだけで、外部プログラムはその事実の後で何かが読めるものに変換されます。 アイデアは、なぜ「カーネル外」のアクティビティにObjCクラスの名前解決を追加しないのですか?可能かどうかを調べるために少し調べる価値があるかもしれませんし、アップルにRFEバグレポートを送ってください。 – johne