cregit-Linux how code gets into the kernel

Release 4.14 drivers/acpi/proc.c

Directory: drivers/acpi
// SPDX-License-Identifier: GPL-2.0
#include <linux/proc_fs.h>
#include <linux/seq_file.h>
#include <linux/export.h>
#include <linux/suspend.h>
#include <linux/bcd.h>
#include <linux/acpi.h>
#include <linux/uaccess.h>

#include "sleep.h"
#include "internal.h"


#define _COMPONENT		ACPI_SYSTEM_COMPONENT

/*
 * this file provides support for:
 * /proc/acpi/wakeup
 */

ACPI_MODULE_NAME("sleep")


static int acpi_system_wakeup_device_seq_show(struct seq_file *seq, void *offset) { struct list_head *node, *next; seq_printf(seq, "Device\tS-state\t Status Sysfs node\n"); mutex_lock(&acpi_device_lock); list_for_each_safe(node, next, &acpi_wakeup_device_list) { struct acpi_device *dev = container_of(node, struct acpi_device, wakeup_list); struct acpi_device_physical_node *entry; if (!dev->wakeup.flags.valid) continue; seq_printf(seq, "%s\t S%d\t", dev->pnp.bus_id, (u32) dev->wakeup.sleep_state); mutex_lock(&dev->physical_node_lock); if (!dev->physical_node_count) { seq_printf(seq, "%c%-8s\n", dev->wakeup.flags.valid ? '*' : ' ', device_may_wakeup(&dev->dev) ? "enabled" : "disabled"); } else { struct device *ldev; list_for_each_entry(entry, &dev->physical_node_list, node) { ldev = get_device(entry->dev); if (!ldev) continue; if (&entry->node != dev->physical_node_list.next) seq_printf(seq, "\t\t"); seq_printf(seq, "%c%-8s %s:%s\n", dev->wakeup.flags.valid ? '*' : ' ', (device_may_wakeup(&dev->dev) || device_may_wakeup(ldev)) ? "enabled" : "disabled", ldev->bus ? ldev->bus->name : "no-bus", dev_name(ldev)); put_device(ldev); } } mutex_unlock(&dev->physical_node_lock); } mutex_unlock(&acpi_device_lock); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Len Brown11340.65%19.09%
Lan Tianyu9032.37%19.09%
Rafael J. Wysocki3010.79%327.27%
David Brownell258.99%19.09%
Andreas Fleig124.32%19.09%
Kay Sievers31.08%19.09%
David Shaohua Li20.72%19.09%
Linus Torvalds20.72%19.09%
Pavel Machek10.36%19.09%
Total278100.00%11100.00%


static void physical_device_enable_wakeup(struct acpi_device *adev) { struct acpi_device_physical_node *entry; mutex_lock(&adev->physical_node_lock); list_for_each_entry(entry, &adev->physical_node_list, node) if (entry->dev && device_can_wakeup(entry->dev)) { bool enable = !device_may_wakeup(entry->dev); device_set_wakeup_enable(entry->dev, enable); } mutex_unlock(&adev->physical_node_lock); }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki5877.33%375.00%
Lan Tianyu1722.67%125.00%
Total75100.00%4100.00%


static ssize_t acpi_system_write_wakeup_device(struct file *file, const char __user * buffer, size_t count, loff_t * ppos) { struct list_head *node, *next; char strbuf[5]; char str[5] = ""; if (count > 4) count = 4; if (copy_from_user(strbuf, buffer, count)) return -EFAULT; strbuf[count] = '\0'; sscanf(strbuf, "%s", str); mutex_lock(&acpi_device_lock); list_for_each_safe(node, next, &acpi_wakeup_device_list) { struct acpi_device *dev = container_of(node, struct acpi_device, wakeup_list); if (!dev->wakeup.flags.valid) continue; if (!strncmp(dev->pnp.bus_id, str, 4)) { if (device_can_wakeup(&dev->dev)) { bool enable = !device_may_wakeup(&dev->dev); device_set_wakeup_enable(&dev->dev, enable); } else { physical_device_enable_wakeup(dev); } break; } } mutex_unlock(&acpi_device_lock); return count; }

Contributors

PersonTokensPropCommitsCommitProp
Len Brown15979.50%337.50%
Rafael J. Wysocki3517.50%337.50%
Cyril Roelandt42.00%112.50%
David Shaohua Li21.00%112.50%
Total200100.00%8100.00%


static int acpi_system_wakeup_device_open_fs(struct inode *inode, struct file *file) { return single_open(file, acpi_system_wakeup_device_seq_show, PDE_DATA(inode)); }

Contributors

PersonTokensPropCommitsCommitProp
Len Brown2896.55%150.00%
Al Viro13.45%150.00%
Total29100.00%2100.00%

static const struct file_operations acpi_system_wakeup_device_fops = { .owner = THIS_MODULE, .open = acpi_system_wakeup_device_open_fs, .read = seq_read, .write = acpi_system_write_wakeup_device, .llseek = seq_lseek, .release = single_release, };
void __init acpi_sleep_proc_init(void) { /* 'wakeup device' [R/W] */ proc_create("wakeup", S_IFREG | S_IRUGO | S_IWUSR, acpi_root_dir, &acpi_system_wakeup_device_fops); }

Contributors

PersonTokensPropCommitsCommitProp
Len Brown1248.00%116.67%
Patrick Mochel624.00%116.67%
Denis V. Lunev312.00%116.67%
Pavel Machek28.00%116.67%
Rami Rosen14.00%116.67%
David Brownell14.00%116.67%
Total25100.00%6100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Len Brown34450.44%310.71%
Rafael J. Wysocki12318.04%517.86%
Lan Tianyu11917.45%27.14%
David Brownell263.81%27.14%
Patrick Mochel223.23%13.57%
Andreas Fleig121.76%13.57%
Denis V. Lunev81.17%13.57%
David Shaohua Li40.59%13.57%
Cyril Roelandt40.59%13.57%
Pavel Machek30.44%13.57%
Kay Sievers30.44%13.57%
Rashika Kheria30.44%13.57%
Linus Torvalds30.44%27.14%
Paul Gortmaker30.44%13.57%
Lv Zheng10.15%13.57%
Greg Kroah-Hartman10.15%13.57%
Rami Rosen10.15%13.57%
Arjan van de Ven10.15%13.57%
Al Viro10.15%13.57%
Total682100.00%28100.00%
Directory: drivers/acpi
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.