/* * POWER Data Stream Control Register (DSCR) sysfs interface test * * This test updates to system wide DSCR default through the sysfs interface * and then verifies that all the CPU specific DSCR defaults are updated as * well verified from their sysfs interfaces. * * Copyright 2015, Anshuman Khandual, IBM Corporation. * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 as published * by the Free Software Foundation. */ #include "dscr.h" static int check_cpu_dscr_default(char *file, unsigned long val) { char buf[10]; int fd, rc; fd = open(file, O_RDWR); if (fd == -1) { perror("open() failed"); return 1; } rc = read(fd, buf, sizeof(buf)); if (rc == -1) { perror("read() failed"); return 1; } close(fd); buf[rc] = '\0'; if (strtol(buf, NULL, 16) != val) { printf("DSCR match failed: %ld (system) %ld (cpu)\n", val, strtol(buf, NULL, 16)); return 1; } return 0; } static int check_all_cpu_dscr_defaults(unsigned long val) { DIR *sysfs; struct dirent *dp; char file[LEN_MAX]; sysfs = opendir(CPU_PATH); if (!sysfs) { perror("opendir() failed"); return 1; } while ((dp = readdir(sysfs))) { if (!(dp->d_type & DT_DIR)) continue; if (!strcmp(dp->d_name, "cpuidle")) continue; if (!strstr(dp->d_name, "cpu")) continue; sprintf(file, "%s%s/dscr", CPU_PATH, dp->d_name); if (access(file, F_OK)) continue; if (check_cpu_dscr_default(file, val)) return 1; } closedir(sysfs); return 0; } int dscr_sysfs(void) { unsigned long orig_dscr_default; int i, j; orig_dscr_default = get_default_dscr(); for (i = 0; i < COUNT; i++) { for (j = 0; j < DSCR_MAX; j++) { set_default_dscr(j); if (check_all_cpu_dscr_defaults(j)) goto fail; } } set_default_dscr(orig_dscr_default); return 0; fail: set_default_dscr(orig_dscr_default); return 1; } int main(int argc, char *argv[]) { return test_harness(dscr_sysfs, "dscr_sysfs_test"); } o/asm?id=f9a42e0d58cf0fe3d902e63d4582f2ea4cd2bb8b'>diff
path: root/tools/virtio/asm
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2017-01-30 15:47:19 -0800
committerLinus Torvalds <torvalds@linux-foundation.org>2017-01-30 15:47:19 -0800
commitf9a42e0d58cf0fe3d902e63d4582f2ea4cd2bb8b (patch)
tree4078d3ae27d4ebb85bdcd4d84e9b9a4d059f22bb /tools/virtio/asm
parent751321b3dd5040dc5be19bd23f985e80c914621a (diff)
parent54791b276b4000b307339f269d3bf7db877d536f (diff)
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc
Pull sparc fixes from David Miller: "Several small bug fixes and tidies, along with a fix for non-resumable memory errors triggered by userspace" * git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc: sparc64: Handle PIO & MEM non-resumable errors. sparc64: Zero pages on allocation for mondo and error queues. sparc: Fixed typo in sstate.c. Replaced panicing with panicking sparc: use symbolic names for tsb indexing
Diffstat (limited to 'tools/virtio/asm')