cregit-Linux how code gets into the kernel

Release 4.11 drivers/cpufreq/cpufreq_governor_attr_set.c

Directory: drivers/cpufreq
/*
 * Abstract code for CPUFreq governor tunable sysfs attributes.
 *
 * Copyright (C) 2016, Intel Corporation
 * Author: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
 *
 * 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 "cpufreq_governor.h"


static inline struct gov_attr_set *to_gov_attr_set(struct kobject *kobj) { return container_of(kobj, struct gov_attr_set, kobj); }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki25100.00%1100.00%
Total25100.00%1100.00%


static inline struct governor_attr *to_gov_attr(struct attribute *attr) { return container_of(attr, struct governor_attr, attr); }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki25100.00%1100.00%
Total25100.00%1100.00%


static ssize_t governor_show(struct kobject *kobj, struct attribute *attr, char *buf) { struct governor_attr *gattr = to_gov_attr(attr); return gattr->show(to_gov_attr_set(kobj), buf); }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki43100.00%1100.00%
Total43100.00%1100.00%


static ssize_t governor_store(struct kobject *kobj, struct attribute *attr, const char *buf, size_t count) { struct gov_attr_set *attr_set = to_gov_attr_set(kobj); struct governor_attr *gattr = to_gov_attr(attr); int ret; mutex_lock(&attr_set->update_lock); ret = attr_set->usage_count ? gattr->store(attr_set, buf, count) : -EBUSY; mutex_unlock(&attr_set->update_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki86100.00%1100.00%
Total86100.00%1100.00%

const struct sysfs_ops governor_sysfs_ops = { .show = governor_show, .store = governor_store, }; EXPORT_SYMBOL_GPL(governor_sysfs_ops);
void gov_attr_set_init(struct gov_attr_set *attr_set, struct list_head *list_node) { INIT_LIST_HEAD(&attr_set->policy_list); mutex_init(&attr_set->update_lock); attr_set->usage_count = 1; list_add(list_node, &attr_set->policy_list); }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki47100.00%1100.00%
Total47100.00%1100.00%

EXPORT_SYMBOL_GPL(gov_attr_set_init);
void gov_attr_set_get(struct gov_attr_set *attr_set, struct list_head *list_node) { mutex_lock(&attr_set->update_lock); attr_set->usage_count++; list_add(list_node, &attr_set->policy_list); mutex_unlock(&attr_set->update_lock); }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki46100.00%1100.00%
Total46100.00%1100.00%

EXPORT_SYMBOL_GPL(gov_attr_set_get);
unsigned int gov_attr_set_put(struct gov_attr_set *attr_set, struct list_head *list_node) { unsigned int count; mutex_lock(&attr_set->update_lock); list_del(list_node); count = --attr_set->usage_count; mutex_unlock(&attr_set->update_lock); if (count) return count; kobject_put(&attr_set->kobj); mutex_destroy(&attr_set->update_lock); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki74100.00%1100.00%
Total74100.00%1100.00%

EXPORT_SYMBOL_GPL(gov_attr_set_put);

Overall Contributors

PersonTokensPropCommitsCommitProp
Rafael J. Wysocki387100.00%1100.00%
Total387100.00%1100.00%
Directory: drivers/cpufreq
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.