/* * Copyright(c) 2022 Qualcomm Innovation Center, Inc. All Rights Reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, see . */ #include #include #include void sig_user(int sig, siginfo_t *info, void *puc) { asm("r7 = #0\n\t" "p0 = r7\n\t" "p1 = r7\n\t" "p2 = r7\n\t" "p3 = r7\n\t" : : : "r7", "p0", "p1", "p2", "p3"); } int main() { int err = 0; unsigned int i = 100000; struct sigaction act; struct itimerspec it; timer_t tid; struct sigevent sev; act.sa_sigaction = sig_user; sigemptyset(&act.sa_mask); act.sa_flags = SA_SIGINFO; sigaction(SIGUSR1, &act, NULL); sev.sigev_notify = SIGEV_SIGNAL; sev.sigev_signo = SIGUSR1; sev.sigev_value.sival_ptr = &tid; timer_create(CLOCK_REALTIME, &sev, &tid); it.it_interval.tv_sec = 0; it.it_interval.tv_nsec = 100000; it.it_value.tv_sec = 0; it.it_value.tv_nsec = 100000; timer_settime(tid, 0, &it, NULL); asm("loop0(1f, %1)\n\t" "1: r8 = #0xff\n\t" " p0 = r8\n\t" " p1 = r8\n\t" " p2 = r8\n\t" " p3 = r8\n\t" " jump 3f\n\t" "2: memb(%0) = #1\n\t" " jump 4f\n\t" "3:\n\t" " r8 = p0\n\t" " p0 = cmp.eq(r8, #0xff)\n\t" " if (!p0) jump 2b\n\t" " r8 = p1\n\t" " p0 = cmp.eq(r8, #0xff)\n\t" " if (!p0) jump 2b\n\t" " r8 = p2\n\t" " p0 = cmp.eq(r8, #0xff)\n\t" " if (!p0) jump 2b\n\t" " r8 = p3\n\t" " p0 = cmp.eq(r8, #0xff)\n\t" " if (!p0) jump 2b\n\t" "4: {}: endloop0\n\t" : : "r"(&err), "r"(i) : "memory", "r8", "p0", "p1", "p2", "p3"); puts(err ? "FAIL" : "PASS"); return err; }