/* Set tz value * by: John Stultz * (C) Copyright Linaro 2016 * Licensed under the GPLv2 * * 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. */ #include #include #include #include #include #include #include #include #ifdef KTEST #include "../kselftest.h" #else static inline int ksft_exit_pass(void) { exit(0); } static inline int ksft_exit_fail(void) { exit(1); } #endif int set_tz(int min, int dst) { struct timezone tz; tz.tz_minuteswest = min; tz.tz_dsttime = dst; return settimeofday(0, &tz); } int get_tz_min(void) { struct timezone tz; struct timeval tv; memset(&tz, 0, sizeof(tz)); gettimeofday(&tv, &tz); return tz.tz_minuteswest; } int get_tz_dst(void) { struct timezone tz; struct timeval tv; memset(&tz, 0, sizeof(tz)); gettimeofday(&tv, &tz); return tz.tz_dsttime; } int main(int argc, char **argv) { int i, ret; int min, dst; min = get_tz_min(); dst = get_tz_dst(); printf("tz_minuteswest started at %i, dst at %i\n", min, dst); printf("Checking tz_minuteswest can be properly set: "); for (i = -15*60; i < 15*60; i += 30) { ret = set_tz(i, dst); ret = get_tz_min(); if (ret != i) { printf("[FAILED] expected: %i got %i\n", i, ret); goto err; } } printf("[OK]\n"); printf("Checking invalid tz_minuteswest values are caught: "); if (!set_tz(-15*60-1, dst)) { printf("[FAILED] %i didn't return failure!\n", -15*60-1); goto err; } if (!set_tz(15*60+1, dst)) { printf("[FAILED] %i didn't return failure!\n", 15*60+1); goto err; } if (!set_tz(-24*60, dst)) { printf("[FAILED] %i didn't return failure!\n", -24*60); goto err; } if (!set_tz(24*60, dst)) { printf("[FAILED] %i didn't return failure!\n", 24*60); goto err; } printf("[OK]\n"); set_tz(min, dst); return ksft_exit_pass(); err: set_tz(min, dst); return ksft_exit_fail(); } lect>
diff options
context:
space:
mode:
authorLiam R. Howlett <Liam.Howlett@Oracle.com>2017-01-17 10:59:03 -0500
committerDavid S. Miller <davem@davemloft.net>2017-01-30 14:27:54 -0800
commit047487241ff59374fded8c477f21453681f5995c (patch)
tree1c2616bd373ce5ea28aac2a53e32f5b5834901ce /sound/firewire
parent7a7dc961a28b965a0d0303c2e989df17b411708b (diff)
sparc64: Handle PIO & MEM non-resumable errors.
User processes trying to access an invalid memory address via PIO will receive a SIGBUS signal instead of causing a panic. Memory errors will receive a SIGKILL since a SIGBUS may result in a coredump which may attempt to repeat the faulting access. Signed-off-by: Liam R. Howlett <Liam.Howlett@Oracle.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'sound/firewire')