cregit-Linux how code gets into the kernel

Release 4.10 drivers/acpi/proc.c

Directory: drivers/acpi
#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.run_wake ? '*' : ' ', 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.run_wake ? '*' : ' ', (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 brownlen brown11340.65%110.00%
lan tianyulan tianyu9132.73%110.00%
rafael j. wysockirafael j. wysocki2810.07%220.00%
david brownelldavid brownell258.99%110.00%
andreas fleigandreas fleig124.32%110.00%
kay sieverskay sievers31.08%110.00%
li shaohuali shaohua20.72%110.00%
pavel machekpavel machek20.72%110.00%
linus torvaldslinus torvalds20.72%110.00%
Total278100.00%10100.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. wysockirafael j. wysocki5877.33%375.00%
lan tianyulan 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 brownlen brown15979.50%337.50%
rafael j. wysockirafael j. wysocki3517.50%337.50%
cyril roelandtcyril roelandt42.00%112.50%
li shaohuali shaohua21.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 brownlen brown2896.55%150.00%
al viroal 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 brownlen brown1248.00%116.67%
patrick mochelpatrick mochel624.00%116.67%
denis v. lunevdenis v. lunev312.00%116.67%
pavel machekpavel machek28.00%116.67%
rami rosenrami rosen14.00%116.67%
david brownelldavid brownell14.00%116.67%
Total25100.00%6100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
len brownlen brown34450.51%311.11%
rafael j. wysockirafael j. wysocki12117.77%414.81%
lan tianyulan tianyu11817.33%27.41%
david brownelldavid brownell263.82%27.41%
patrick mochelpatrick mochel223.23%13.70%
andreas fleigandreas fleig121.76%13.70%
denis v. lunevdenis v. lunev81.17%13.70%
cyril roelandtcyril roelandt40.59%13.70%
li shaohuali shaohua40.59%13.70%
pavel machekpavel machek40.59%13.70%
linus torvaldslinus torvalds30.44%27.41%
rashika kheriarashika kheria30.44%13.70%
kay sieverskay sievers30.44%13.70%
paul gortmakerpaul gortmaker30.44%13.70%
andy groverandy grover20.29%13.70%
rami rosenrami rosen10.15%13.70%
al viroal viro10.15%13.70%
arjan van de venarjan van de ven10.15%13.70%
lv zhenglv zheng10.15%13.70%
Total681100.00%27100.00%
Directory: drivers/acpi
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.