for (i = 0; i < MAX_ATTEMPT; i++) { /* * If anything bad happens in ASM and we fail to set ret * because *handwave* TM this will cause failure
*/ long ret = 0xdead; long rc = 0xbeef;
alarm(0); /* Disable any pending */
signaled = 0;
alarm(TIMEOUT);
FAIL_IF(tcheck_transactional());
rc = tm_signal_self(getpid(), SIGUSR1, &ret); if (ret == 0xdead) /* * This basically means the transaction aborted before we * even got to the suspend... this is crazy but it * happens. * Yes this also means we might never make forward * progress... the alarm() will trip eventually...
*/ continue;
if (rc || ret) { /* Ret is actually an errno */
printf("TEXASR 0x%016lx, TFIAR 0x%016lx\n",
__builtin_get_texasr(), __builtin_get_tfiar());
fprintf(stderr, "(%d) Fail reason: %d rc=0x%lx ret=0x%lx\n",
i, fail, rc, ret);
FAIL_IF(ret);
} while(!signaled && !fail) asmvolatile("": : :"memory"); if (!signaled) {
fprintf(stderr, "(%d) Fail reason: %d rc=0x%lx ret=0x%lx\n",
i, fail, rc, ret);
FAIL_IF(fail); /* For the line number */
}
}
return 0;
}
int main(void)
{ return test_harness(test_signal_tm, "signal_tm");
}
Messung V0.5
¤ Dauer der Verarbeitung: 0.1 Sekunden
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.