cregit-Linux how code gets into the kernel

Release 4.11 sound/aoa/soundbus/core.c

/*
 * soundbus
 *
 * Copyright 2006 Johannes Berg <johannes@sipsolutions.net>
 *
 * GPL v2, can be found in COPYING.
 */

#include <linux/module.h>
#include "soundbus.h"

MODULE_AUTHOR("Johannes Berg <johannes@sipsolutions.net>");
MODULE_LICENSE("GPL");
MODULE_DESCRIPTION("Apple Soundbus");


struct soundbus_dev *soundbus_dev_get(struct soundbus_dev *dev) { struct device *tmp; if (!dev) return NULL; tmp = get_device(&dev->ofdev.dev); if (tmp) return to_soundbus_device(tmp); else return NULL; }

Contributors

PersonTokensPropCommitsCommitProp
Johannes Berg51100.00%1100.00%
Total51100.00%1100.00%

EXPORT_SYMBOL_GPL(soundbus_dev_get);
void soundbus_dev_put(struct soundbus_dev *dev) { if (dev) put_device(&dev->ofdev.dev); }

Contributors

PersonTokensPropCommitsCommitProp
Johannes Berg24100.00%1100.00%
Total24100.00%1100.00%

EXPORT_SYMBOL_GPL(soundbus_dev_put);
static int soundbus_probe(struct device *dev) { int error = -ENODEV; struct soundbus_driver *drv; struct soundbus_dev *soundbus_dev; drv = to_soundbus_driver(dev->driver); soundbus_dev = to_soundbus_device(dev); if (!drv->probe) return error; soundbus_dev_get(soundbus_dev); error = drv->probe(soundbus_dev); if (error) soundbus_dev_put(soundbus_dev); return error; }

Contributors

PersonTokensPropCommitsCommitProp
Johannes Berg79100.00%1100.00%
Total79100.00%1100.00%


static int soundbus_uevent(struct device *dev, struct kobj_uevent_env *env) { struct soundbus_dev * soundbus_dev; struct platform_device * of; const char *compat; int retval = 0; int cplen, seen = 0; if (!dev) return -ENODEV; soundbus_dev = to_soundbus_device(dev); if (!soundbus_dev) return -ENODEV; of = &soundbus_dev->ofdev; /* stuff we want to pass to /sbin/hotplug */ retval = add_uevent_var(env, "OF_NAME=%s", of->dev.of_node->name); if (retval) return retval; retval = add_uevent_var(env, "OF_TYPE=%s", of->dev.of_node->type); if (retval) return retval; /* Since the compatible field can contain pretty much anything * it's not really legal to split it out with commas. We split it * up using a number of environment variables instead. */ compat = of_get_property(of->dev.of_node, "compatible", &cplen); while (compat && cplen > 0) { int tmp = env->buflen; retval = add_uevent_var(env, "OF_COMPATIBLE_%d=%s", seen, compat); if (retval) return retval; compat += env->buflen - tmp; cplen -= env->buflen - tmp; seen += 1; } retval = add_uevent_var(env, "OF_COMPATIBLE_N=%d", seen); if (retval) return retval; retval = add_uevent_var(env, "MODALIAS=%s", soundbus_dev->modalias); return retval; }

Contributors

PersonTokensPropCommitsCommitProp
Johannes Berg16370.26%114.29%
Eric Rannaud3916.81%114.29%
Kay Sievers177.33%114.29%
Grant C. Likely104.31%228.57%
Stephen Rothwell31.29%228.57%
Total232100.00%7100.00%


static int soundbus_device_remove(struct device *dev) { struct soundbus_dev * soundbus_dev = to_soundbus_device(dev); struct soundbus_driver * drv = to_soundbus_driver(dev->driver); if (dev->driver && drv->remove) drv->remove(soundbus_dev); soundbus_dev_put(soundbus_dev); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Johannes Berg58100.00%1100.00%
Total58100.00%1100.00%


static void soundbus_device_shutdown(struct device *dev) { struct soundbus_dev * soundbus_dev = to_soundbus_device(dev); struct soundbus_driver * drv = to_soundbus_driver(dev->driver); if (dev->driver && drv->shutdown) drv->shutdown(soundbus_dev); }

Contributors

PersonTokensPropCommitsCommitProp
Johannes Berg50100.00%1100.00%
Total50100.00%1100.00%

/* soundbus_dev_attrs is declared in sysfs.c */ ATTRIBUTE_GROUPS(soundbus_dev); static struct bus_type soundbus_bus_type = { .name = "aoa-soundbus", .probe = soundbus_probe, .uevent = soundbus_uevent, .remove = soundbus_device_remove, .shutdown = soundbus_device_shutdown, .dev_groups = soundbus_dev_groups, };
int soundbus_add_one(struct soundbus_dev *dev) { static int devcount; /* sanity checks */ if (!dev->attach_codec || !dev->ofdev.dev.of_node || dev->pcmname || dev->pcmid != -1) { printk(KERN_ERR "soundbus: adding device failed sanity check!\n"); return -EINVAL; } dev_set_name(&dev->ofdev.dev, "soundbus:%x", ++devcount); dev->ofdev.dev.bus = &soundbus_bus_type; return of_device_register(&dev->ofdev); }

Contributors

PersonTokensPropCommitsCommitProp
Johannes Berg8494.38%133.33%
Grant C. Likely33.37%133.33%
Kay Sievers22.25%133.33%
Total89100.00%3100.00%

EXPORT_SYMBOL_GPL(soundbus_add_one);
void soundbus_remove_one(struct soundbus_dev *dev) { of_device_unregister(&dev->ofdev); }

Contributors

PersonTokensPropCommitsCommitProp
Johannes Berg18100.00%1100.00%
Total18100.00%1100.00%

EXPORT_SYMBOL_GPL(soundbus_remove_one);
int soundbus_register_driver(struct soundbus_driver *drv) { /* initialize common driver fields */ drv->driver.name = drv->name; drv->driver.bus = &soundbus_bus_type; /* register with core */ return driver_register(&drv->driver); }

Contributors

PersonTokensPropCommitsCommitProp
Johannes Berg40100.00%1100.00%
Total40100.00%1100.00%

EXPORT_SYMBOL_GPL(soundbus_register_driver);
void soundbus_unregister_driver(struct soundbus_driver *drv) { driver_unregister(&drv->driver); }

Contributors

PersonTokensPropCommitsCommitProp
Johannes Berg18100.00%1100.00%
Total18100.00%1100.00%

EXPORT_SYMBOL_GPL(soundbus_unregister_driver);
static int __init soundbus_init(void) { return bus_register(&soundbus_bus_type); }

Contributors

PersonTokensPropCommitsCommitProp
Benjamin Herrenschmidt16100.00%1100.00%
Total16100.00%1100.00%


static void __exit soundbus_exit(void) { bus_unregister(&soundbus_bus_type); }

Contributors

PersonTokensPropCommitsCommitProp
Benjamin Herrenschmidt15100.00%1100.00%
Total15100.00%1100.00%

subsys_initcall(soundbus_init); module_exit(soundbus_exit);

Overall Contributors

PersonTokensPropCommitsCommitProp
Johannes Berg68185.66%110.00%
Eric Rannaud394.91%110.00%
Benjamin Herrenschmidt324.03%110.00%
Kay Sievers192.39%220.00%
Grant C. Likely131.64%220.00%
Quentin Lambert81.01%110.00%
Stephen Rothwell30.38%220.00%
Total795100.00%10100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.