/* * 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"); } >commitdiff
path: root/drivers/usb/host/ehci-sysfs.c
diff options
context:
space:
mode:
authorDan Williams <dan.j.williams@intel.com>2017-02-04 14:47:31 -0800
committerDan Williams <dan.j.williams@intel.com>2017-02-04 14:47:31 -0800
commitbfb34527a32a1a576d9bfb7026d3ab0369a6cd60 (patch)
treedb4d58c52d766eeb0c87cd6dba005839de933ede /drivers/usb/host/ehci-sysfs.c
parente471486c13b82b1338d49c798f78bb62b1ed0a9e (diff)
libnvdimm, pfn: fix memmap reservation size versus 4K alignment
When vmemmap_populate() allocates space for the memmap it does so in 2MB sized chunks. The libnvdimm-pfn driver incorrectly accounts for this when the alignment of the device is set to 4K. When this happens we trigger memory allocation failures in altmap_alloc_block_buf() and trigger warnings of the form: WARNING: CPU: 0 PID: 3376 at arch/x86/mm/init_64.c:656 arch_add_memory+0xe4/0xf0 [..] Call Trace: dump_stack+0x86/0xc3 __warn+0xcb/0xf0 warn_slowpath_null+0x1d/0x20 arch_add_memory+0xe4/0xf0 devm_memremap_pages+0x29b/0x4e0 Fixes: 315c562536c4 ("libnvdimm, pfn: add 'align' attribute, default to HPAGE_SIZE") Cc: <stable@vger.kernel.org> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
Diffstat (limited to 'drivers/usb/host/ehci-sysfs.c')