cregit-Linux how code gets into the kernel

Release 4.7 drivers/isdn/gigaset/proc.c

/*
 * Stuff used by all variants of the driver
 *
 * Copyright (c) 2001 by Stefan Eilers,
 *                       Hansjoerg Lipp <hjlipp@web.de>,
 *                       Tilman Schmidt <tilman@imap.cc>.
 *
 * =====================================================================
 *      This program is free software; you can redistribute it and/or
 *      modify it under the terms of the GNU General Public License as
 *      published by the Free Software Foundation; either version 2 of
 *      the License, or (at your option) any later version.
 * =====================================================================
 */

#include "gigaset.h"


static ssize_t show_cidmode(struct device *dev, struct device_attribute *attr, char *buf) { struct cardstate *cs = dev_get_drvdata(dev); return sprintf(buf, "%u\n", cs->cidmode); }

Contributors

PersonTokensPropCommitsCommitProp
hansjoerg lipphansjoerg lipp3173.81%125.00%
greg kroah-hartmangreg kroah-hartman921.43%125.00%
tilman schmidttilman schmidt24.76%250.00%
Total42100.00%4100.00%


static ssize_t set_cidmode(struct device *dev, struct device_attribute *attr, const char *buf, size_t count) { struct cardstate *cs = dev_get_drvdata(dev); long int value; char *end; value = simple_strtol(buf, &end, 0); while (*end) if (!isspace(*end++)) return -EINVAL; if (value < 0 || value > 1) return -EINVAL; if (mutex_lock_interruptible(&cs->mutex)) return -ERESTARTSYS; cs->waiting = 1; if (!gigaset_add_event(cs, &cs->at_state, EV_PROC_CIDMODE, NULL, value, NULL)) { cs->waiting = 0; mutex_unlock(&cs->mutex); return -ENOMEM; } gigaset_schedule_event(cs); wait_event(cs->waitqueue, !cs->waiting); mutex_unlock(&cs->mutex); return count; }

Contributors

PersonTokensPropCommitsCommitProp
hansjoerg lipphansjoerg lipp16191.48%133.33%
greg kroah-hartmangreg kroah-hartman95.11%133.33%
tilman schmidttilman schmidt63.41%133.33%
Total176100.00%3100.00%

static DEVICE_ATTR(cidmode, S_IRUGO | S_IWUSR, show_cidmode, set_cidmode); /* free sysfs for device */
void gigaset_free_dev_sysfs(struct cardstate *cs) { if (!cs->tty_dev) return; gig_dbg(DEBUG_INIT, "removing sysfs entries"); device_remove_file(cs->tty_dev, &dev_attr_cidmode); }

Contributors

PersonTokensPropCommitsCommitProp
hansjoerg lipphansjoerg lipp2777.14%240.00%
tilman schmidttilman schmidt411.43%240.00%
greg kroah-hartmangreg kroah-hartman411.43%120.00%
Total35100.00%5100.00%

/* initialize sysfs for device */
void gigaset_init_dev_sysfs(struct cardstate *cs) { if (!cs->tty_dev) return; gig_dbg(DEBUG_INIT, "setting up sysfs"); if (device_create_file(cs->tty_dev, &dev_attr_cidmode)) pr_err("could not create sysfs attribute\n"); }

Contributors

PersonTokensPropCommitsCommitProp
hansjoerg lipphansjoerg lipp2764.29%228.57%
tilman schmidttilman schmidt1126.19%457.14%
greg kroah-hartmangreg kroah-hartman49.52%114.29%
Total42100.00%7100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
hansjoerg lipphansjoerg lipp26483.81%218.18%
greg kroah-hartmangreg kroah-hartman278.57%19.09%
tilman schmidttilman schmidt247.62%872.73%
Total315100.00%11100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}