123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- // SPDX-License-Identifier: GPL-2.0-only
- /*
- * Interface for power-management for ppc64 compliant platform
- *
- * Manish Ahuja <[email protected]>
- *
- * Feb 2007
- *
- * Copyright (C) 2007 IBM Corporation.
- */
- #include <linux/kobject.h>
- #include <linux/string.h>
- #include <linux/errno.h>
- #include <linux/init.h>
- #include <asm/machdep.h>
- #include "pseries.h"
- unsigned long rtas_poweron_auto; /* default and normal state is 0 */
- static ssize_t auto_poweron_show(struct kobject *kobj,
- struct kobj_attribute *attr, char *buf)
- {
- return sprintf(buf, "%lu\n", rtas_poweron_auto);
- }
- static ssize_t auto_poweron_store(struct kobject *kobj,
- struct kobj_attribute *attr,
- const char *buf, size_t n)
- {
- int ret;
- unsigned long ups_restart;
- ret = sscanf(buf, "%lu", &ups_restart);
- if ((ret == 1) && ((ups_restart == 1) || (ups_restart == 0))){
- rtas_poweron_auto = ups_restart;
- return n;
- }
- return -EINVAL;
- }
- static struct kobj_attribute auto_poweron_attr =
- __ATTR(auto_poweron, 0644, auto_poweron_show, auto_poweron_store);
- #ifndef CONFIG_PM
- struct kobject *power_kobj;
- static struct attribute *g[] = {
- &auto_poweron_attr.attr,
- NULL,
- };
- static const struct attribute_group attr_group = {
- .attrs = g,
- };
- static int __init pm_init(void)
- {
- power_kobj = kobject_create_and_add("power", NULL);
- if (!power_kobj)
- return -ENOMEM;
- return sysfs_create_group(power_kobj, &attr_group);
- }
- machine_core_initcall(pseries, pm_init);
- #else
- static int __init apo_pm_init(void)
- {
- return (sysfs_create_file(power_kobj, &auto_poweron_attr.attr));
- }
- machine_device_initcall(pseries, apo_pm_init);
- #endif
|