OSX: вывод dtrace printf(), write_nocancel() на основе сценария dtruss

Мне нужно видеть вывод printf моей программы синхронно с выводом dtrace.

Мне нравится создавать свою собственную версию команды dtrace, которая выдает эквивалентный вывод команды "sudo dtruss -t write_nocancel ls".

Это "правильная команда / вывод dtruss":

sudo dtruss -t write_nocancel ls
Chap1   Chap10  Chap11  Chap12  Chap2   Chap3   Chap4   Chap5   Chap6   Chap7   Chap8   Chap9   README
SYSCALL(args)        = return
write_nocancel(0x1, "Chap1\tChap10\tChap11\tChap12\tChap2\tChap3\tChap4\tChap5\tChap6\tChap7\tChap8\tChap9\tREADME\n\0", 0x52)       = 82 0

Основываясь на просмотре исходного кода скрипта dtruss, я попробовал эту команду dtrace, но она не удалась.

    sudo  dtrace -q \
    -n '*:*:write_nocancel:entry {self->arg0=arg0; self->arg1 =arg1; \
    self->arg2 =arg2; self->code=0; } ' \
            -n '*:*:write_nocancel:return { \
        printf("return %s(0x%X, \"%S\", 0x%X)         = %d %d", \
        probefunc,self->arg0,       arg0 == -1 ? "" : stringof(copyin(self->arg1,arg0)),self->arg2,(int)arg0, \
  (int)errno); }' \
             -c ls   2>&1 
                Chap1
                Chap10
                Chap11
                Chap12
                Chap2
                Chap3
                Chap4
                Chap5
                Chap6
                Chap7
                Chap8
                Chap9
                README
                dtrace: error on enabled probe ID 3 (ID 209288: fbt:mach_kernel:write_nocancel:return): invalid address (0xffffff80218dfc40) in action #3 at DIF offset 92
                dtrace: error on enabled probe ID 4 (ID 958: syscall::write_nocancel:return): invalid address (0xffffff80218dfc40) in action #3 at DIF offset 92
                dtrace: error on enabled probe ID 3 (ID 209288: fbt:mach_kernel:write_nocancel:return): invalid address (0xffffff801a7c0010) in action #3 at DIF offset 92

Любые эксперты по dtrace могут понять, как это исправить?

1 ответ

Найдите ответ: (вопрос о двух вариантах -n).

sudo  dtrace -q -n \
    'syscall::write_nocancel:entry{self->start = 1; \
        self->vstart = 1; self->arg0 = arg0; \
        self->arg1 = arg1; self->arg2 = arg2;}   \
    *:*:write_nocancel:return /self->start/ \
    { printf("return %s(0x%X, \"%S\", 0x%X)         = %d %d" \
        ,probefunc,self->arg0,      \
        arg0 == -1 ? "" : stringof(copyin(self->arg1,arg0)),\
        self->arg2,(int)arg0,   (int)errno); }' \
    -c ls   2>&1 
Другие вопросы по тегам